Forked from awalthefirst's Pen Free Code Camp Weather App.
Forked from Free Code Camp's Pen Free Code Camp Weather App.
A Pen by Razafindrakoto on CodePen.
Forked from awalthefirst's Pen Free Code Camp Weather App.
Forked from Free Code Camp's Pen Free Code Camp Weather App.
A Pen by Razafindrakoto on CodePen.
<body ng-app="Weather"> | |
<div class="container" ng-controller="MainCtrl"> | |
<div class="row"> | |
<header class="col-xs-12 text-center"> | |
<h1>Free C<i class="wi wi-hail"></i>de Camp </h1> | |
<h1>Weather App</h1> | |
</header> | |
<div class="col-xs-8 col-xs-offset-2"> | |
<div class="text-center status"> | |
<p>{{Data.city}}, {{Data.country}}</p> | |
<p>{{Data.temp}} °<span class="temp" ng-click="Data.sys()">{{Data.unit}}</span></p> | |
<p>{{Data.des}}</p> | |
</div> | |
<div class="text-center all-icon"> | |
<div class="icon sun-shower hide "> | |
<div class="cloud"></div> | |
<div class="sun"> | |
<div class="rays"></div> | |
</div> | |
<div class="rain"></div> | |
</div> | |
<div class="icon thunder-storm hide thunderstom"> | |
<div class="cloud"></div> | |
<div class="lightning"> | |
<div class="bolt"></div> | |
<div class="bolt"></div> | |
</div> | |
</div> | |
<div class="icon cloudy hide clouds"> | |
<div class="cloud"></div> | |
<div class="cloud"></div> | |
</div> | |
<div class="icon flurries hide snow"> | |
<div class="cloud"></div> | |
<div class="snow"> | |
<div class="flake"></div> | |
<div class="flake"></div> | |
</div> | |
</div> | |
<div class="icon sunny hide clear"> | |
<div class="sun"> | |
<div class="rays"></div> | |
</div> | |
</div> | |
<div class="icon rainy hide rain"> | |
<div class="cloud"></div> | |
<div class="rain"></div> | |
</div> | |
</div> | |
<p class="text-center">Inspired By <a href="http://codepen.io/joshbader/full/EjXgqr/" target="_blank">joshbader</a></p> | |
</div> | |
</div> | |
</div> | |
</body> |
var app = angular.module('Weather', []); | |
app.factory('WeatherApi', function($http) { | |
var obj = {}; | |
obj.getLoc = function() { | |
return $http.jsonp("http://ipinfo.io/json?callback=JSON_CALLBACK"); | |
}; | |
obj.getCurrent = function(city) { | |
var api = "http://api.openweathermap.org/data/2.5/weather?q="; | |
var units = "&units=metric"; | |
var appid = "&APPID=061f24cf3cde2f60644a8240302983f2" | |
var cb = "&callback=JSON_CALLBACK"; | |
return $http.jsonp(api + city + units+ appid + cb); | |
}; | |
return obj | |
}); | |
app.controller('MainCtrl', function($scope, WeatherApi) { | |
$scope.Data = {}; | |
$scope.Data.unit ='C'; | |
$scope.Data.sysChange = false; | |
WeatherApi.getLoc().success(function(data) { | |
var city = data.city + ',' + data.country; | |
$scope.Data.city = data.city; | |
$scope.Data.country = data.country; | |
WeatherApi.getCurrent(city).success(function(data) { | |
CurrentWeather(data) | |
}); | |
}); | |
function CurrentWeather(data) { | |
$scope.Data.temp = Math.round(data.main.temp); | |
$scope.Data.Cel = Math.round(data.main.temp); | |
$scope.Data.des = data.weather[0].main; | |
$scope.Data.Fah = Math.round( ($scope.Data.temp * 9)/5 + 32 ); | |
return IconGen($scope.Data.des); | |
} | |
function IconGen(city) { | |
var city = city.toLowerCase() | |
switch (city) { | |
case 'dizzle': | |
addIcon(city) | |
break; | |
case 'clouds': | |
addIcon(city) | |
break; | |
case 'rain': | |
addIcon(city) | |
break; | |
case 'snow': | |
addIcon(city) | |
break; | |
case 'clear': | |
addIcon(city) | |
break; | |
case 'thunderstom': | |
addIcon(city) | |
break; | |
default: | |
$('div.clouds').removeClass('hide'); | |
} | |
} | |
function addIcon(city) { | |
$('div.' + city).removeClass('hide'); | |
} | |
$scope.Data.sys= function(){ | |
if($scope.Data.sysChange){ | |
$scope.Data.unit ='C'; | |
$scope.Data.temp = $scope.Data.Cel; | |
return $scope.Data.sysChange = false; | |
} | |
$scope.Data.unit ='F'; | |
$scope.Data.temp = $scope.Data.Fah; | |
return $scope.Data.sysChange = true; | |
} | |
}); |
<script src="//cdnjs.cloudflare.com/ajax/libs/jquery/2.1.3/jquery.min.js"></script> | |
<script src="//cdnjs.cloudflare.com/ajax/libs/angular.js/1.3.14/angular.min.js"></script> |
body { | |
font-family: 'Roboto'; | |
color: #fff; | |
background-color: #161616; | |
} | |
.status p { | |
font-size: 1.8em; | |
text-transform: capitalize; | |
} | |
header { | |
margin-bottom: 30px; | |
} | |
.temp{ | |
cursor:pointer; | |
color:#006dcc; | |
} | |
.temp:hover{ | |
color:#005096; | |
} | |
h1 { | |
font-size: 5em; | |
} | |
.all-icon { | |
margin-bottom: 20px; | |
} | |
div.hide { | |
display: none; | |
} | |
.icon { | |
color: #161616; | |
position: relative; | |
display: inline-block; | |
width: 12rem; | |
height: 10rem; | |
} | |
.cloud { | |
position: absolute; | |
z-index: 1; | |
top: 50%; | |
left: 50%; | |
width: 3.6875rem; | |
height: 3.6875rem; | |
margin: -1.84375rem; | |
background: currentColor; | |
border-radius: 50%; | |
box-shadow: -2.1875rem 0.6875rem 0 -0.6875rem, 2.0625rem 0.9375rem 0 -0.9375rem, 0 0 0 0.375rem #fff, -2.1875rem 0.6875rem 0 -0.3125rem #fff, 2.0625rem 0.9375rem 0 -0.5625rem #fff; | |
} | |
.cloud:after { | |
content: ''; | |
position: absolute; | |
bottom: 0; | |
left: -0.5rem; | |
display: block; | |
width: 4.5625rem; | |
height: 1rem; | |
background: currentColor; | |
box-shadow: 0 0.375rem #fff; | |
} | |
.cloud:nth-child(2) { | |
z-index: 0; | |
background: #fff; | |
box-shadow: -2.1875rem 0.6875rem 0 -0.6875rem #fff, 2.0625rem 0.9375rem 0 -0.9375rem #fff, 0 0 0 0.375rem #fff, -2.1875rem 0.6875rem 0 -0.3125rem #fff, 2.0625rem 0.9375rem 0 -0.5625rem #fff; | |
opacity: 0.3; | |
-webkit-transform: scale(0.5) translate(6rem, -3rem); | |
-ms-transform: scale(0.5) translate(6rem, -3rem); | |
transform: scale(0.5) translate(6rem, -3rem); | |
-webkit-animation: cloud 4s linear infinite; | |
animation: cloud 4s linear infinite; | |
} | |
.cloud:nth-child(2):after { | |
background: #fff; | |
} | |
.sun { | |
position: absolute; | |
top: 50%; | |
left: 50%; | |
width: 2.5rem; | |
height: 2.5rem; | |
margin: -1.25rem; | |
background: currentColor; | |
border-radius: 50%; | |
box-shadow: 0 0 0 0.375rem #fff; | |
-webkit-animation: spin 12s infinite linear; | |
animation: spin 12s infinite linear; | |
} | |
.rays { | |
position: absolute; | |
top: -2rem; | |
left: 50%; | |
display: block; | |
width: 0.375rem; | |
height: 1.125rem; | |
margin-left: -0.1875rem; | |
background: #fff; | |
border-radius: 0.25rem; | |
box-shadow: 0 5.375rem #fff; | |
} | |
.rays:before, | |
.rays:after { | |
content: ''; | |
position: absolute; | |
top: 0rem; | |
left: 0rem; | |
display: block; | |
width: 0.375rem; | |
height: 1.125rem; | |
-webkit-transform: rotate(60deg); | |
-ms-transform: rotate(60deg); | |
transform: rotate(60deg); | |
-webkit-transform-origin: 50% 3.25rem; | |
-ms-transform-origin: 50% 3.25rem; | |
transform-origin: 50% 3.25rem; | |
background: #fff; | |
border-radius: 0.25rem; | |
box-shadow: 0 5.375rem #fff; | |
} | |
.rays:before { | |
-webkit-transform: rotate(120deg); | |
-ms-transform: rotate(120deg); | |
transform: rotate(120deg); | |
} | |
.cloud + .sun { | |
margin: -2rem 1rem; | |
} | |
.rain, | |
.lightning, | |
.snow { | |
position: absolute; | |
z-index: 2; | |
top: 50%; | |
left: 50%; | |
width: 3.75rem; | |
height: 3.75rem; | |
margin: 0.375rem 0 0 -2rem; | |
background: currentColor; | |
} | |
.rain:after { | |
content: ''; | |
position: absolute; | |
z-index: 2; | |
top: 50%; | |
left: 50%; | |
width: 1.125rem; | |
height: 1.125rem; | |
margin: -1rem 0 0 -0.25rem; | |
background: #0cf; | |
border-radius: 100% 0 60% 50% / 60% 0 100% 50%; | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 rgba(255, 255, 255, 0.2); | |
-webkit-transform: rotate(-28deg); | |
-ms-transform: rotate(-28deg); | |
transform: rotate(-28deg); | |
-webkit-animation: rain 3s linear infinite; | |
animation: rain 3s linear infinite; | |
} | |
.bolt { | |
position: absolute; | |
top: 50%; | |
left: 50%; | |
width: 1rem; | |
height: 0.5rem; | |
margin: -0.875rem 0 0 -0.5rem; | |
color: #fff; | |
background: #fff; | |
opacity: 0.3; | |
-webkit-animation: lightning 2s linear infinite; | |
animation: lightning 2s linear infinite; | |
} | |
.bolt:nth-child(2) { | |
width: 0.5rem; | |
height: 0.25rem; | |
margin: -1.875rem 0 0 -1.5rem; | |
-webkit-transform: translate(2.5rem, 2.25rem); | |
-ms-transform: translate(2.5rem, 2.25rem); | |
transform: translate(2.5rem, 2.25rem); | |
opacity: 0.2; | |
-webkit-animation: lightning 1.5s linear infinite; | |
animation: lightning 1.5s linear infinite; | |
} | |
.bolt:before, | |
.bolt:after { | |
content: ''; | |
position: absolute; | |
z-index: 2; | |
top: 50%; | |
left: 50%; | |
margin: -1.75rem 0 0 -1.25rem; | |
border-top: 1.25rem solid transparent; | |
border-right: 0.75rem solid; | |
border-bottom: 0.75rem solid; | |
border-left: 0.5rem solid transparent; | |
-webkit-transform: skewX(-10deg); | |
-ms-transform: skewX(-10deg); | |
transform: skewX(-10deg); | |
} | |
.bolt:after { | |
margin: -0.25rem 0 0 -0.0125rem; | |
border-top: 0.75rem solid; | |
border-right: 0.5rem solid transparent; | |
border-bottom: 1.25rem solid transparent; | |
border-left: 0.75rem solid; | |
-webkit-transform: skewX(-10deg); | |
-ms-transform: skewX(-10deg); | |
transform: skewX(-10deg); | |
} | |
.bolt:nth-child(2):before { | |
margin: -0.875rem 0 0 -0.75rem; | |
border-top: 0.625rem solid transparent; | |
border-right: 0.375rem solid; | |
border-bottom: 0.375rem solid; | |
border-left: 0.25rem solid transparent; | |
} | |
.bolt:nth-child(2):after { | |
margin: -0.125rem 0 0 0; | |
border-top: 0.375rem solid; | |
border-right: 0.25rem solid transparent; | |
border-bottom: 0.625rem solid transparent; | |
border-left: 0.375rem solid; | |
} | |
.flake:before, | |
.flake:after { | |
position: absolute; | |
top: 50%; | |
left: 50%; | |
margin: -1.25rem 0 0 -1.25rem; | |
content: '\2744'; | |
color: #fff; | |
list-height: 1em; | |
opacity: 0.2; | |
-webkit-animation: spin 8s linear infinite reverse; | |
animation: spin 8s linear infinite reverse; | |
} | |
.flake:after { | |
margin: -0.125rem 0 0 -1.375rem; | |
font-size: 1.5rem; | |
opacity: 0.4; | |
-webkit-animation: spin 14s linear infinite; | |
animation: spin 14s linear infinite; | |
} | |
.flake:nth-child(2):before { | |
margin: -0.875rem 0 0 0.25rem; | |
font-size: 1.25rem; | |
opacity: 0.2; | |
-webkit-animation: spin 10s linear infinite; | |
animation: spin 10s linear infinite; | |
} | |
.flake:nth-child(2):after { | |
margin: 0.5rem 0 0 0.125rem; | |
font-size: 2rem; | |
opacity: 0.4; | |
-webkit-animation: spin 16s linear infinite reverse; | |
animation: spin 16s linear infinite reverse; | |
} | |
/* Animations */ | |
@-webkit-keyframes spin { | |
100% { | |
-webkit-transform: rotate(360deg); | |
transform: rotate(360deg); | |
} | |
} | |
@keyframes spin { | |
100% { | |
-webkit-transform: rotate(360deg); | |
transform: rotate(360deg); | |
} | |
} | |
@-webkit-keyframes cloud { | |
0% { | |
opacity: 0; | |
} | |
50% { | |
opacity: 0.3; | |
} | |
100% { | |
opacity: 0; | |
-webkit-transform: scale(0.5) translate(-6rem, -3rem); | |
transform: scale(0.5) translate(-6rem, -3rem); | |
} | |
} | |
@keyframes cloud { | |
0% { | |
opacity: 0; | |
} | |
50% { | |
opacity: 0.3; | |
} | |
100% { | |
opacity: 0; | |
-webkit-transform: scale(0.5) translate(-6rem, -3rem); | |
transform: scale(0.5) translate(-6rem, -3rem); | |
} | |
} | |
@-webkit-keyframes rain { | |
0% { | |
background: #0cf; | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 #0cf; | |
} | |
25% { | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem #0cf, -1.375rem -0.125rem 0 rgba(255, 255, 255, 0.2); | |
} | |
50% { | |
background: rgba(255, 255, 255, 0.3); | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem #0cf, -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 rgba(255, 255, 255, 0.2); | |
} | |
100% { | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 #0cf; | |
} | |
} | |
@keyframes rain { | |
0% { | |
background: #0cf; | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 #0cf; | |
} | |
25% { | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem #0cf, -1.375rem -0.125rem 0 rgba(255, 255, 255, 0.2); | |
} | |
50% { | |
background: rgba(255, 255, 255, 0.3); | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem #0cf, -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 rgba(255, 255, 255, 0.2); | |
} | |
100% { | |
box-shadow: 0.625rem 0.875rem 0 -0.125rem rgba(255, 255, 255, 0.2), -0.875rem 1.125rem 0 -0.125rem rgba(255, 255, 255, 0.2), -1.375rem -0.125rem 0 #0cf; | |
} | |
} | |
@-webkit-keyframes lightning { | |
45% { | |
color: #fff; | |
background: #fff; | |
opacity: 0.2; | |
} | |
50% { | |
color: #0cf; | |
background: #0cf; | |
opacity: 1; | |
} | |
55% { | |
color: #fff; | |
background: #fff; | |
opacity: 0.2; | |
} | |
} | |
@keyframes lightning { | |
45% { | |
color: #fff; | |
background: #fff; | |
opacity: 0.2; | |
} | |
50% { | |
color: #0cf; | |
background: #0cf; | |
opacity: 1; | |
} | |
55% { | |
color: #fff; | |
background: #fff; | |
opacity: 0.2; | |
} | |
} |
<link href="https://cdnjs.cloudflare.com/ajax/libs/weather-icons/1.3.2/css/weather-icons.min.css" rel="stylesheet" /> | |
<link href="//maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css" rel="stylesheet" /> |