mirror of
https://git.friendi.ca/friendica/friendica-addons.git
synced 2024-11-25 06:03:41 +00:00
typo
This commit is contained in:
parent
4d6cfe14d0
commit
c1f26a22c3
1 changed files with 87 additions and 43 deletions
|
@ -1,13 +1,18 @@
|
||||||
<?php
|
<?php
|
||||||
/**
|
/**
|
||||||
* Name: Current Weather
|
* Name: Current Weather
|
||||||
* Description: Shows current weather conditions for user's location on their network page.<br />Find the location code for the station or airport nearest you <a href="http://en.wikipedia.org/wiki/International_Air_Transport_Association_airport_code" target="_blank">here</a>.
|
* Description: Shows current weather conditions for user's location on their network page.
|
||||||
* Version: 1.0
|
* Version: 1.1
|
||||||
* Author: Tony Baldwin <http://friendica.tonybaldwin.info/u/t0ny>
|
* Author: Tony Baldwin <http://friendica.tonybaldwin.info/u/t0ny>
|
||||||
* Author: Fabio Comuni <http://kirkgroup.com/u/fabrixxm>
|
* Author: Fabio Comuni <http://kirkgroup.com/u/fabrixxm>
|
||||||
|
* Author: Tobias Diekershoff <https://f.diekershoff.de/u/tobias>
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
require_once('addon/curweather/getweather.php');
|
use Cmfcmf\OpenWeatherMap;
|
||||||
|
use Cmfcmf\OpenWeatherMap\Exception as OWMException;
|
||||||
|
|
||||||
|
// Must point to composer's autoload file.
|
||||||
|
require('vendor/autoload.php');
|
||||||
|
|
||||||
function curweather_install() {
|
function curweather_install() {
|
||||||
register_hook('network_mod_init', 'addon/curweather/curweather.php', 'curweather_network_mod_init');
|
register_hook('network_mod_init', 'addon/curweather/curweather.php', 'curweather_network_mod_init');
|
||||||
|
@ -35,21 +40,45 @@ function curweather_network_mod_init(&$fk_app,&$b) {
|
||||||
// the $rpt value is needed for location
|
// the $rpt value is needed for location
|
||||||
// which getweather uses to fetch the weather data for weather and temp
|
// which getweather uses to fetch the weather data for weather and temp
|
||||||
$rpt = get_pconfig(local_user(), 'curweather', 'curweather_loc');
|
$rpt = get_pconfig(local_user(), 'curweather', 'curweather_loc');
|
||||||
$wxdata = GetWeather::get($rpt);
|
|
||||||
$temp = $wxdata['TEMPERATURE_STRING'];
|
|
||||||
$weather = $wxdata['WEATHER'];
|
|
||||||
$rhumid = $wxdata['RELATIVE_HUMIDITY'];
|
|
||||||
$pressure = $wxdata['PRESSURE_STRING'];
|
|
||||||
$wind = $wxdata['WIND_STRING'];
|
|
||||||
$curweather = '<div id="curweather-network" class="widget">
|
|
||||||
<div class="title tool">
|
|
||||||
<h4>'.t("Current Weather").'</h4></div>';
|
|
||||||
|
|
||||||
$curweather .= "Weather: $weather<br />
|
|
||||||
Temperature: $temp<br />
|
// set the language to the browsers language and use metric units
|
||||||
Relative Humidity: $rhumid<br />
|
$lang = $_SESSION['language'];
|
||||||
Pressure: $pressure<br />
|
$units = get_pconfig( local_user(), 'curweather', 'curweather_units');
|
||||||
Wind: $wind";
|
$appid = get_config('curweather','appid');
|
||||||
|
if ($units==="")
|
||||||
|
$units = 'metric';
|
||||||
|
// Get OpenWeatherMap object. Don't use caching (take a look into
|
||||||
|
// Example_Cache.php to see how it works).
|
||||||
|
$owm = new OpenWeatherMap();
|
||||||
|
|
||||||
|
try {
|
||||||
|
$weather = $owm->getWeather($rpt, $units, $lang, $appid);
|
||||||
|
$temp = $weather->temperature->getValue();
|
||||||
|
if ( $units === 'metric') {
|
||||||
|
$temp .= '°C';
|
||||||
|
} else {
|
||||||
|
$temp .= '°F';
|
||||||
|
};
|
||||||
|
$rhumid = $weather->humidity;
|
||||||
|
$pressure = $weather->pressure;
|
||||||
|
$wind = $weather->wind->speed . " " . $weather->wind->direction;
|
||||||
|
$description = $weather->clouds->getDescription();
|
||||||
|
} catch(OWMException $e) {
|
||||||
|
alert ( 'OpenWeatherMap exception: ' . $e->getMessage() . ' (Code ' . $e->getCode() . ').');
|
||||||
|
} catch(\Exception $e) {
|
||||||
|
alert ('General exception: ' . $e->getMessage() . ' (Code ' . $e->getCode() . ').');
|
||||||
|
}
|
||||||
|
|
||||||
|
$curweather = '<div id="curweather-network" class="widget">
|
||||||
|
<div class="title tool">
|
||||||
|
<h4>'.t("Current Weather").': '.$weather->city->name.'</h4></div>';
|
||||||
|
|
||||||
|
$curweather .= "$description; $temp<br />";
|
||||||
|
$curweather .= t('Relative Humidity').": $rhumid<br />";
|
||||||
|
$curweather .= t('Pressure').": $pressure<br />";
|
||||||
|
$curweather .= t('Wind').": $wind<br />";
|
||||||
|
$curweather .= '<span style="font-size:0.8em;">'. t('Data by').': <a href="http://openweathermap.org">OpenWeatherMap</a>. <a href="http://openweathermap.org/Maps?zoom=7&lat='.$weather->city->lat.'&lon='.$weather->city->lon.'&layers=B0FTTFF">'.t('Show on map').'</a></span>';
|
||||||
|
|
||||||
$curweather .= '</div><div class="clear"></div>';
|
$curweather .= '</div><div class="clear"></div>';
|
||||||
|
|
||||||
|
@ -63,6 +92,7 @@ function curweather_plugin_settings_post($a,$post) {
|
||||||
return;
|
return;
|
||||||
set_pconfig(local_user(),'curweather','curweather_loc',trim($_POST['curweather_loc']));
|
set_pconfig(local_user(),'curweather','curweather_loc',trim($_POST['curweather_loc']));
|
||||||
set_pconfig(local_user(),'curweather','curweather_enable',intval($_POST['curweather_enable']));
|
set_pconfig(local_user(),'curweather','curweather_enable',intval($_POST['curweather_enable']));
|
||||||
|
set_pconfig(local_user(),'curweather','curweather_units',trim($_POST['curweather_units']));
|
||||||
|
|
||||||
info( t('Current Weather settings updated.') . EOL);
|
info( t('Current Weather settings updated.') . EOL);
|
||||||
}
|
}
|
||||||
|
@ -73,36 +103,50 @@ function curweather_plugin_settings(&$a,&$s) {
|
||||||
if(! local_user())
|
if(! local_user())
|
||||||
return;
|
return;
|
||||||
|
|
||||||
/* Add our stylesheet to the curweather so we can make our settings look nice */
|
|
||||||
|
|
||||||
$a->page['htmlhead'] .= '<link rel="stylesheet" type="text/css" href="' . $a->get_baseurl() . '/addon/curweather/curweather.css' . '" media="all" />' . "\r\n";
|
|
||||||
|
|
||||||
/* Get the current state of our config variable */
|
/* Get the current state of our config variable */
|
||||||
|
|
||||||
$curweather_loc = get_pconfig(local_user(), 'curweather', 'curweather_loc');
|
$curweather_loc = get_pconfig(local_user(), 'curweather', 'curweather_loc');
|
||||||
|
$curweather_units = get_pconfig(local_user(), 'curweather', 'curweather_units');
|
||||||
|
$appid = get_config('curweather','appid');
|
||||||
|
if (x($appid)) {
|
||||||
|
$noappidtext = t('No APPID found, please contact your admin to optain one.');
|
||||||
|
} else {
|
||||||
|
$noappidtext = '';
|
||||||
|
}
|
||||||
$enable = intval(get_pconfig(local_user(),'curweather','curweather_enable'));
|
$enable = intval(get_pconfig(local_user(),'curweather','curweather_enable'));
|
||||||
$enable_checked = (($enable) ? ' checked="checked" ' : '');
|
$enable_checked = (($enable) ? ' checked="checked" ' : '');
|
||||||
|
|
||||||
|
// load template and replace the macros
|
||||||
/* Add some HTML to the existing form */
|
$t = get_markup_template("settings.tpl", "addon/curweather/" );
|
||||||
|
$s = replace_macros ($t, array(
|
||||||
$s .= '<div class="settings-block">';
|
'$submit' => t('Save Settings'),
|
||||||
$s .= '<h3>' . t('Current Weather') . '</h3>';
|
'$header' => t('curweather Settings'),
|
||||||
$s .= '<div id="curweather-settings-wrapper">';
|
'$noappidtext' => t('No APPID found, please contact your admin to optain one.'),
|
||||||
$s .= '<p>Find the location code for the airport/weather station nearest you <a href="http://en.wikipedia.org/wiki/International_Air_Transport_Association_airport_code" target="_blank">here</a>.</p>';
|
'$info' => t('Enter either the name of your location or the zip code.'),
|
||||||
$s .= '<label id="curweather-location-label" for="curweather_loc">' . t('Weather Location: ') . '</label>';
|
'$curweather_loc' => array( 'curweather_loc', t('Your Location'), $curweather_loc, t('Identifier of your location (name or zip code), e.g. <em>Berlin,DE</em> or <em>14476,DE</em>.') ),
|
||||||
$s .= '<input id="curweather-location" type="text" name="curweather_loc" value="' . $curweather_loc . '"/>';
|
'$curweather_units' => array( 'curweather_units', t('Units'), $curweather_units, t('select if the temperatur should be displayed in °C or °F'), array('metric'=>'°C', 'imperial'=>'°F')),
|
||||||
$s .= '<div class="clear"></div>';
|
'$enabled' => array( 'curweather_enable', t('Show weather data'), $enable, '')
|
||||||
$s .= '<label id="curweather-enable-label" for="curweather_enable">' . t('Enable Current Weather') . '</label>';
|
));
|
||||||
$s .= '<input id="curweather-enable" type="checkbox" name="curweather_enable" value="1" ' . $enable_checked . '/>';
|
return;
|
||||||
$s .= '<div class="clear"></div>';
|
|
||||||
|
|
||||||
$s .= '</div>';
|
|
||||||
|
|
||||||
/* provide a submit button */
|
|
||||||
|
|
||||||
$s .= '<div class="settings-submit-wrapper" ><input type="submit" name="curweather-settings-submit" class="settings-submit" value="' . t('Save Settings') . '" /></div></div>';
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
// Config stuff for the admin panel to let the admin of the node set a APPID
|
||||||
|
// for accessing the API of openweathermap
|
||||||
|
function curweather_plugin_admin_post (&$a) {
|
||||||
|
if(! is_site_admin())
|
||||||
|
return;
|
||||||
|
if ($_POST['curweather-submit']) {
|
||||||
|
set_config('curweather','appid',trim($_POST['appid']));
|
||||||
|
info( t('Curweather settings saved.'.EOL));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
function curweather_plugin_admin (&$a, &$o) {
|
||||||
|
if(! is_site_admin())
|
||||||
|
return;
|
||||||
|
$appid = get_config('curweather','appid');
|
||||||
|
$t = get_markup_template("admin.tpl", "addon/curweather/" );
|
||||||
|
$o = replace_macros ($t, array(
|
||||||
|
'$submit' => t('Save Settings'),
|
||||||
|
'$appid' => array('appid', t('Your APPID'), $appid, t('Your API key provided by OpenWeatherMap'))
|
||||||
|
));
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue