From 5c7da64ea83b4b274e31bc4dbd1fc62b413cb965 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 11 Sep 2013 11:08:50 -0700 Subject: [PATCH 01/23] Replaced admin Twitter feed with blog feed. Added Total Users online count to tab description. --- e107_admin/includes/infopanel.php | 57 ++--- e107_themes/bootstrap/admin_style.css | 5 +- e107_web/js/tweet/jquery.tweet.js | 264 -------------------- e107_web/js/zrssfeed/jquery.zrssfeed.min.js | 8 + 4 files changed, 37 insertions(+), 297 deletions(-) delete mode 100644 e107_web/js/tweet/jquery.tweet.js create mode 100644 e107_web/js/zrssfeed/jquery.zrssfeed.min.js diff --git a/e107_admin/includes/infopanel.php b/e107_admin/includes/infopanel.php index 3f72994b0..a50853d49 100644 --- a/e107_admin/includes/infopanel.php +++ b/e107_admin/includes/infopanel.php @@ -17,6 +17,8 @@ if (!defined('e107_INIT')) exit; } +define('ADMINFEED', 'http://e107.org/adminfeed'); +define('ADMINFEEDMORE', 'http://e107.org/blog'); class adminstyle_infopanel { @@ -25,33 +27,19 @@ class adminstyle_infopanel function __construct() { - e107::js('core','tweet/jquery.tweet.js'); - // e107::css('core','tweet/jquery.tweet.css'); + e107::js('core','zrssfeed/jquery.zrssfeed.min.js'); // http://www.zazar.net/developers/jquery/zrssfeed/ + + $code = " + - $code = <<- {time} » {retweet_action}", - filter: function(t){ return ! /^@\w+/.test(t.tweet_raw_text); }, - auto_join_text_default: "", - auto_join_text_ed: "", - auto_join_text_ing: "", - auto_join_text_reply: "", - auto_join_text_url: "", - loading_text: " Loading news...", - refresh_interval: 60 - }); - }); -EOF; - - - + $('#e-adminfeed').rssfeed('".ADMINFEED."', { + limit: 3, + header: false, + linktarget: '_blank' + }); + }); +"; global $user_pref; // quick fix. $pref = e107::getPref(); @@ -89,8 +77,9 @@ EOF; $pref = e107::getPref(); $frm = e107::getForm(); - /* - XXX Check Bootstrap bug is fixed. + + // XXX Check Bootstrap bug is fixed. + /* echo ' '; - */ - + */ //TODO LANs throughout. global $style, $user_pref; @@ -213,7 +201,7 @@ EOF; // ------------------------------- e107 News -------------------------------- - $text2 = $ns->tablerender("e107 News","
","core-infopanel_news",true); + $text2 = $ns->tablerender("e107 News","
","core-infopanel_news",true); @@ -354,7 +342,7 @@ EOF; $dashboard = '
@@ -380,7 +368,7 @@ EOF; - function renderOnlineUsers() + function renderOnlineUsers($data=false) { $ol = e107::getOnline(); @@ -408,6 +396,11 @@ EOF; "; $online = $ol->userList() + $ol->guestList(); + + if($data == 'count') + { + return count($online); + } // echo "Users: ".print_a($online); diff --git a/e107_themes/bootstrap/admin_style.css b/e107_themes/bootstrap/admin_style.css index 98a977dc1..70b175151 100644 --- a/e107_themes/bootstrap/admin_style.css +++ b/e107_themes/bootstrap/admin_style.css @@ -898,7 +898,10 @@ li.plupload_delete a { background-position: -525px 0; width: 16px; height: 16px; } - +li.rssRow > div { + font-size: 80%; + color: rgb(153, 153, 153); +} diff --git a/e107_web/js/tweet/jquery.tweet.js b/e107_web/js/tweet/jquery.tweet.js deleted file mode 100644 index d611c5aa3..000000000 --- a/e107_web/js/tweet/jquery.tweet.js +++ /dev/null @@ -1,264 +0,0 @@ -// jquery.tweet.js - See http://tweet.seaofclouds.com/ or https://github.com/seaofclouds/tweet for more info -// Copyright (c) 2008-2012 Todd Matthews & Steve Purcell -(function (factory) { - if (typeof define === 'function' && define.amd) - define(['jquery'], factory); // AMD support for RequireJS etc. - else - factory(jQuery); -}(function ($) { - $.fn.tweet = function(o){ - var s = $.extend({ - username: null, // [string or array] required unless using the 'query' option; one or more twitter screen names (use 'list' option for multiple names, where possible) - list: null, // [string] optional name of list belonging to username - favorites: false, // [boolean] display the user's favorites instead of his tweets - query: null, // [string] optional search query (see also: http://search.twitter.com/operators) - avatar_size: null, // [integer] height and width of avatar if displayed (48px max) - count: 3, // [integer] how many tweets to display? - fetch: null, // [integer] how many tweets to fetch via the API (set this higher than 'count' if using the 'filter' option) - page: 1, // [integer] which page of results to fetch (if count != fetch, you'll get unexpected results) - retweets: true, // [boolean] whether to fetch (official) retweets (not supported in all display modes) - intro_text: null, // [string] do you want text BEFORE your your tweets? - outro_text: null, // [string] do you want text AFTER your tweets? - join_text: null, // [string] optional text in between date and tweet, try setting to "auto" - auto_join_text_default: " I said, ", // [string] auto text for non verb: "I said" bullocks - auto_join_text_ed: " I ", // [string] auto text for past tense: "I" surfed - auto_join_text_ing: " I am ", // [string] auto tense for present tense: "I was" surfing - auto_join_text_reply: " I replied to ", // [string] auto tense for replies: "I replied to" @someone "with" - auto_join_text_url: " I was looking at ", // [string] auto tense for urls: "I was looking at" http:... - loading_text: null, // [string] optional loading text, displayed while tweets load - refresh_interval: null, // [integer] optional number of seconds after which to reload tweets - twitter_url: "twitter.com", // [string] custom twitter url, if any (apigee, etc.) - twitter_api_url: "api.twitter.com", // [string] custom twitter api url, if any (apigee, etc.) - twitter_search_url: "search.twitter.com", // [string] custom twitter search url, if any (apigee, etc.) - template: "{avatar}{time}{join} {text}", // [string or function] template used to construct each tweet
  • - see code for available vars - comparator: function(tweet1, tweet2) { // [function] comparator used to sort tweets (see Array.sort) - return tweet2["tweet_time"] - tweet1["tweet_time"]; - }, - filter: function(tweet) { // [function] whether or not to include a particular tweet (be sure to also set 'fetch') - return true; - } - // You can attach callbacks to the following events using jQuery's standard .bind() mechanism: - // "loaded" -- triggered when tweets have been fetched and rendered - }, o); - - // See http://daringfireball.net/2010/07/improved_regex_for_matching_urls - var url_regexp = /\b((?:https?:\/\/|www\d{0,3}[.]|[a-z0-9.\-]+[.][a-z]{2,4}\/)(?:[^\s()<>]+|\(([^\s()<>]+|(\([^\s()<>]+\)))*\))+(?:\(([^\s()<>]+|(\([^\s()<>]+\)))*\)|[^\s`!()\[\]{};:'".,<>?«»“”‘’]))/gi; - - // Expand values inside simple string templates with {placeholders} - function t(template, info) { - if (typeof template === "string") { - var result = template; - for(var key in info) { - var val = info[key]; - result = result.split('{'+key+'}').join(val === null ? '' : val); - } - return result; - } else return template(info); - } - // Export the t function for use when passing a function as the 'template' option - $.extend({tweet: {t: t}}); - - function replacer (regex, replacement) { - return function() { - var returning = []; - this.each(function() { - returning.push(this.replace(regex, replacement)); - }); - return $(returning); - }; - } - - function escapeHTML(s) { - return s.replace(//g,"^>"); - } - - $.fn.extend({ - linkUser: replacer(/(^|[\W])@(\w+)/gi, "$1@$2"), - // Support various latin1 (\u00**) and arabic (\u06**) alphanumeric chars - linkHash: replacer(/(?:^| )[\#]+([\w\u00c0-\u00d6\u00d8-\u00f6\u00f8-\u00ff\u0600-\u06ff]+)/gi, - ' #$1'), - makeHeart: replacer(/(<)+[3]/gi, "") - }); - - function linkURLs(text, entities) { - return text.replace(url_regexp, function(match) { - var url = (/^[a-z]+:/i).test(match) ? match : "http://"+match; - var text = match; - for(var i = 0; i < entities.length; ++i) { - var entity = entities[i]; - if (entity.url == url && entity.expanded_url) { - url = entity.expanded_url; - text = entity.display_url; - break; - } - } - return ""+escapeHTML(text)+""; - }); - } - - function parse_date(date_str) { - // The non-search twitter APIs return inconsistently-formatted dates, which Date.parse - // cannot handle in IE. We therefore perform the following transformation: - // "Wed Apr 29 08:53:31 +0000 2009" => "Wed, Apr 29 2009 08:53:31 +0000" - return Date.parse(date_str.replace(/^([a-z]{3})( [a-z]{3} \d\d?)(.*)( \d{4})$/i, '$1,$2$4$3')); - } - - function extract_relative_time(date) { - var toInt = function(val) { return parseInt(val, 10); }; - var relative_to = new Date(); - var delta = toInt((relative_to.getTime() - date) / 1000); - if (delta < 1) delta = 0; - return { - days: toInt(delta / 86400), - hours: toInt(delta / 3600), - minutes: toInt(delta / 60), - seconds: toInt(delta) - }; - } - - function format_relative_time(time_ago) { - if ( time_ago.days > 2 ) return 'about ' + time_ago.days + ' days ago'; - if ( time_ago.hours > 24 ) return 'about a day ago'; - if ( time_ago.hours > 2 ) return 'about ' + time_ago.hours + ' hours ago'; - if ( time_ago.minutes > 45 ) return 'about an hour ago'; - if ( time_ago.minutes > 2 ) return 'about ' + time_ago.minutes + ' minutes ago'; - if ( time_ago.seconds > 1 ) return 'about ' + time_ago.seconds + ' seconds ago'; - return 'just now'; - } - - function build_auto_join_text(text) { - if (text.match(/^(@([A-Za-z0-9-_]+)) .*/i)) { - return s.auto_join_text_reply; - } else if (text.match(url_regexp)) { - return s.auto_join_text_url; - } else if (text.match(/^((\w+ed)|just) .*/im)) { - return s.auto_join_text_ed; - } else if (text.match(/^(\w*ing) .*/i)) { - return s.auto_join_text_ing; - } else { - return s.auto_join_text_default; - } - } - - function build_api_url() { - var proto = ('https:' == document.location.protocol ? 'https:' : 'http:'); - var count = (s.fetch === null) ? s.count : s.fetch; - var common_params = '&callback=?'; - if (s.list) { - return proto+"//"+s.twitter_api_url+"/1/"+s.username[0]+"/lists/"+s.list+"/statuses.json?page="+s.page+"&per_page="+count+common_params; - } else if (s.favorites) { - return proto+"//"+s.twitter_api_url+"/1/favorites.json?screen_name="+s.username[0]+"&page="+s.page+"&count="+count+common_params; - } else if (s.query === null && s.username.length == 1) { - return proto+'//'+s.twitter_api_url+'/1/statuses/user_timeline.json?screen_name='+s.username[0]+'&count='+count+(s.retweets ? '&include_rts=1' : '')+'&page='+s.page+common_params; - } else { - var query = (s.query || 'from:'+s.username.join(' OR from:')); - return proto+'//'+s.twitter_search_url+'/search.json?&q='+encodeURIComponent(query)+'&rpp='+count+'&page='+s.page+common_params; - } - } - - function extract_avatar_url(item, secure) { - if (secure) { - return ('user' in item) ? - item.user.profile_image_url_https : - extract_avatar_url(item, false). - replace(/^http:\/\/[a-z0-9]{1,3}\.twimg\.com\//, "https://s3.amazonaws.com/twitter_production/"); - } else { - return item.profile_image_url || item.user.profile_image_url; - } - } - - // Convert twitter API objects into data available for - // constructing each tweet
  • using a template - function extract_template_data(item){ - var o = {}; - o.item = item; - o.source = item.source; - o.screen_name = item.from_user || item.user.screen_name; - // The actual user name is not returned by all Twitter APIs, so please do not - // file an issue if it is empty: - o.name = item.from_user_name || item.user.name; - o.retweet = typeof(item.retweeted_status) != 'undefined'; - - o.tweet_time = parse_date(item.created_at); - o.join_text = s.join_text == "auto" ? build_auto_join_text(item.text) : s.join_text; - o.tweet_id = item.id_str; - o.twitter_base = "http://"+s.twitter_url+"/"; - o.user_url = o.twitter_base+o.screen_name; - o.tweet_url = o.user_url+"/status/"+o.tweet_id; - o.reply_url = o.twitter_base+"intent/tweet?in_reply_to="+o.tweet_id; - o.retweet_url = o.twitter_base+"intent/retweet?tweet_id="+o.tweet_id; - o.favorite_url = o.twitter_base+"intent/favorite?tweet_id="+o.tweet_id; - o.retweeted_screen_name = o.retweet && item.retweeted_status.user.screen_name; - o.tweet_relative_time = format_relative_time(extract_relative_time(o.tweet_time)); - o.entities = item.entities ? (item.entities.urls || []).concat(item.entities.media || []) : []; - o.tweet_raw_text = o.retweet ? ('RT @'+o.retweeted_screen_name+' '+item.retweeted_status.text) : item.text; // avoid '...' in long retweets - o.tweet_text = $([linkURLs(o.tweet_raw_text, o.entities)]).linkUser().linkHash()[0]; - o.retweeted_tweet_text = $([linkURLs(item.text, o.entities)]).linkUser().linkHash()[0]; - o.tweet_text_fancy = $([o.tweet_text]).makeHeart()[0]; - - o.avatar_size = s.avatar_size; - o.avatar_url = extract_avatar_url(o.retweet ? item.retweeted_status : item, (document.location.protocol === 'https:')); - o.avatar_screen_name = o.retweet ? o.retweeted_screen_name : o.screen_name; - o.avatar_profile_url = o.twitter_base+o.avatar_screen_name; - - // Default spans, and pre-formatted blocks for common layouts - o.user = t('{screen_name}', o); - o.join = s.join_text ? t('{join_text}', o) : ''; - o.avatar = o.avatar_size ? - t('{avatar_screen_name}\'s avatar', o) : ''; - o.time = t('{tweet_relative_time}', o); - o.text = t('{tweet_text_fancy}', o); - o.retweeted_text = t('{retweeted_tweet_text}', o); - o.reply_action = t('reply', o); - o.retweet_action = t('retweet', o); - o.favorite_action = t('favorite', o); - return o; - } - - function render_tweets(widget, tweets) { - var list = $('
      '); - list.append($.map(tweets, function(o) { return "
    • " + t(s.template, o) + "
    • "; }).join('')). - children('li:first').addClass('tweet_first').end(). - children('li:odd').addClass('tweet_even').end(). - children('li:even').addClass('tweet_odd'); - - $(widget).empty().append(list); - if (s.intro_text) list.before('

      '+s.intro_text+'

      '); - if (s.outro_text) list.after('

      '+s.outro_text+'

      '); - - $(widget).trigger("loaded").trigger((tweets.length === 0 ? "empty" : "full")); - if (s.refresh_interval) { - window.setTimeout(function() { $(widget).trigger("tweet:load"); }, 1000 * s.refresh_interval); - } - } - - function load(widget) { - var loading = $('

      '+s.loading_text+'

      '); - if (s.loading_text) $(widget).not(":has(.tweet_list)").empty().append(loading); - $.getJSON(build_api_url(), function(data){ - var tweets = $.map(data.results || data, extract_template_data); - tweets = $.grep(tweets, s.filter).sort(s.comparator).slice(0, s.count); - $(widget).trigger("tweet:retrieved", [tweets]); - }); - } - - return this.each(function(i, widget){ - if(s.username && typeof(s.username) == "string"){ - s.username = [s.username]; - } - - $(widget).unbind("tweet:render").unbind("tweet:retrieved").unbind("tweet:load"). - bind({ - "tweet:load": function() { load(widget); }, - "tweet:retrieved": function(ev, tweets) { - $(widget).trigger("tweet:render", [tweets]) - }, - "tweet:render": function(ev, tweets) { - render_tweets($(widget), tweets); - } - }).trigger("tweet:load"); - }); - }; -})); diff --git a/e107_web/js/zrssfeed/jquery.zrssfeed.min.js b/e107_web/js/zrssfeed/jquery.zrssfeed.min.js new file mode 100644 index 000000000..893b448a0 --- /dev/null +++ b/e107_web/js/zrssfeed/jquery.zrssfeed.min.js @@ -0,0 +1,8 @@ +(function(l){l.fn.rssfeed=function(b,h,w){h=l.extend({limit:10,offset:1,header:!0,titletag:"h4",date:!0,dateformat:"datetime",content:!0,snippet:!0,media:!0,showerror:!0,errormsg:"",key:null,ssl:!1,linktarget:"_self",linkredirect:"",linkcontent:!1,sort:"",sortasc:!0,historical:!1},h);return this.each(function(z,q){var u=l(q),f="";h.ssl&&(f="s");u.hasClass("rssFeed")||u.addClass("rssFeed");if(null==b)return!1;0'+b.title+"
  • ");m+='
      ';for(f=e.offset;fa?a="< 1 min":(3600>a?(a=Math.round(a/60)-1,c="min"):86400>a?(a=Math.round(a/3600)-1,c="hour"):604800>a?(a=Math.round(a/86400)-1,c="day"):(a=Math.round(a/604800)-1,c="week"),1'+g.title+"";e.date&&a&&(j[d].html+="
      "+a+"
      ");e.content&&(g=e.snippet&&""!=g.contentSnippet?g.contentSnippet:g.content,e.linkcontent&&(g=''+g+""),j[d].html+="

      "+g+"

      ");if(e.media&&0'+r.split("/").pop()+" ("+s+", ",s=Math.floor(Math.log(t)/Math.log(1024)),t=(t/Math.pow(1024,Math.floor(s))).toFixed(2)+" "+"bytes kb MB GB TB PB".split(" ")[s];c.html=y+(r+t+")")}j[d].html+="
    "}}e.sort&&j.sort(function(a,c){if(e.sortasc)var b= +a.sort,d=c.sort;else b=c.sort,d=a.sort;if("date"==e.sort)return new Date(b)-new Date(d);b=b.toLowerCase();d=d.toLowerCase();return bd?1:0});l.each(j,function(a){m+='
  • '+j[a].html+"
  • ";v="odd"==v?"even":"odd"});m+="";l(q).html(m);l("a",q).attr("target",e.linktarget)}l.isFunction(w)&&w.call(this,u)}else h.showerror&&(d=""!=h.errormsg?h.errormsg:b.responseDetails),l(q).html('

    '+d+"

    ")})})};var p=function(b){b+="";2>b.length&& +(b="0"+b);return b},x=function(b){return"Jan Feb Mar Apr May Jun Jul Aug Sep Oct Nov Dec".split(" ")[b]}})(jQuery); \ No newline at end of file From 64c50ea1564f54566ee7f32ce6fccc47868ce138 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 11 Sep 2013 11:43:09 -0700 Subject: [PATCH 02/23] Added TODO note about new e_rss standard. See chatbox_menu/e_rss.php for an example of the v2 standard. --- e107_plugins/calendar_menu/e_rss.php | 3 +++ e107_plugins/download/e_rss.php | 2 ++ e107_plugins/forum/e_rss.php | 2 +- 3 files changed, 6 insertions(+), 1 deletion(-) diff --git a/e107_plugins/calendar_menu/e_rss.php b/e107_plugins/calendar_menu/e_rss.php index 6ff9062d1..dd861cc74 100644 --- a/e107_plugins/calendar_menu/e_rss.php +++ b/e107_plugins/calendar_menu/e_rss.php @@ -25,6 +25,9 @@ if (!e107::isInstalled('calendar_menu')) return; include_lan(e_PLUGIN.'calendar_menu/languages/'.e_LANGUAGE.'_admin_calendar_menu.php'); // RSS messages are in admin language file +//FIXME TODO - Use v2 method. See chatbox_menu/e_rss.php + + //##### create feed for admin, return array $eplug_rss_feed -------------------------------- $feed['name'] = EC_ADLAN_A12; $feed['url'] = 'calendar'; //the identifier for the rss feed url diff --git a/e107_plugins/download/e_rss.php b/e107_plugins/download/e_rss.php index 00625b0e4..272927237 100644 --- a/e107_plugins/download/e_rss.php +++ b/e107_plugins/download/e_rss.php @@ -16,6 +16,8 @@ if (!defined('e107_INIT')) { exit; } +//FIXME TODO - Use v2 method. See chatbox_menu/e_rss.php + //##### create feed for admin, return array $eplug_rss_feed -------------------------------- // Download $feed['name'] = ADLAN_24; diff --git a/e107_plugins/forum/e_rss.php b/e107_plugins/forum/e_rss.php index 7ee27b7f3..861445278 100644 --- a/e107_plugins/forum/e_rss.php +++ b/e107_plugins/forum/e_rss.php @@ -2,7 +2,7 @@ if (!defined('e107_INIT')) { exit; } - +//FIXME TODO - Use v2 method. See chatbox_menu/e_rss.php //##### create feed for admin, return array $eplug_rss_feed -------------------------------- $feed = get_forum_rss(); From 39cd18bfb02bfeaab7a698eb6815fa1266a42c21 Mon Sep 17 00:00:00 2001 From: Cameron Date: Wed, 11 Sep 2013 11:45:10 -0700 Subject: [PATCH 03/23] Another e_rss note added. --- e107_plugins/featurebox/e_rss.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/e107_plugins/featurebox/e_rss.php b/e107_plugins/featurebox/e_rss.php index 15eecee88..5aa50ca21 100644 --- a/e107_plugins/featurebox/e_rss.php +++ b/e107_plugins/featurebox/e_rss.php @@ -2,7 +2,7 @@ if (!defined('e107_INIT')) { exit; } - +//FIXME TODO - Use v2 method. See chatbox_menu/e_rss.php //##### create feed for admin, return array $eplug_rss_feed -------------------------------- $feed['name'] = 'Featurebox'; From 496adc75719f7f66b1870edfbb23abae4f6eec51 Mon Sep 17 00:00:00 2001 From: Moc Date: Thu, 12 Sep 2013 19:55:15 +0200 Subject: [PATCH 04/23] Updated calendar_menu RSS feed to v2 standards --- e107_plugins/calendar_menu/e_rss.php | 141 ++++++++++++++------------- 1 file changed, 75 insertions(+), 66 deletions(-) diff --git a/e107_plugins/calendar_menu/e_rss.php b/e107_plugins/calendar_menu/e_rss.php index dd861cc74..6adb06fc1 100644 --- a/e107_plugins/calendar_menu/e_rss.php +++ b/e107_plugins/calendar_menu/e_rss.php @@ -6,80 +6,89 @@ * Released under the terms and conditions of the * GNU General Public License (http://www.gnu.org/licenses/gpl.txt) * - * RSS news feed shim + * RSS calendar feed */ -/** - * e107 Event calendar plugin - * - * RSS news feed shim - * - * @package e107_plugins - * @subpackage event_calendar - */ +// TODO LAN if (!defined('e107_INIT')) { exit; } -if (!e107::isInstalled('calendar_menu')) return; - -include_lan(e_PLUGIN.'calendar_menu/languages/'.e_LANGUAGE.'_admin_calendar_menu.php'); // RSS messages are in admin language file - - -//FIXME TODO - Use v2 method. See chatbox_menu/e_rss.php - - -//##### create feed for admin, return array $eplug_rss_feed -------------------------------- -$feed['name'] = EC_ADLAN_A12; -$feed['url'] = 'calendar'; //the identifier for the rss feed url -$feed['topic_id'] = ''; //the topic_id, empty on default (to select a certain category) -$feed['path'] = 'calendar_menu'; //this is the plugin path location -$feed['text'] = EC_ADLAN_A157; -$feed['class'] = '0'; -$feed['limit'] = '9'; -//##### ------------------------------------------------------------------------------------ - -require_once('ecal_class.php'); -$ecal_class = new ecal_class; - -//##### create rss data, return as array $eplug_rss_data ----------------------------------- -$current_day = $ecal_class->cal_date['mday']; -$current_month = $ecal_class->cal_date['mon']; -$current_year = $ecal_class->cal_date['year']; -$current = mktime(0,0,0,$current_month, $current_day, $current_year); - -$qry = " -SELECT e.*, c.event_cat_name -FROM `#event` AS e -LEFT JOIN `#event_cat` AS c ON c.event_cat_id = e.event_category -WHERE e.event_start>='{$current}' AND c.event_cat_class REGEXP '".e_CLASS_REGEXP."' -ORDER BY e.event_start ASC LIMIT 0,".$this->limit; - -$rss = array(); -$sqlrss = new db; -if($items = $sqlrss->db_Select_gen($qry)) +// v2.x Standard +class calendar_menu_rss { - $i=0; - while($rowrss = $sqlrss -> db_Fetch()) + /** + * Admin RSS Configuration + */ + function config() { - $tmp = explode(".", $rowrss['event_author']); - $rss[$i]['author'] = $tmp[1]; - $rss[$i]['author_email'] = ''; - $rss[$i]['link'] = $e107->base_path.$PLUGINS_DIRECTORY."calendar_menu/event.php?".$rowrss['event_start'].".event.".$rowrss['event_id']; - $rss[$i]['linkid'] = $rowrss['event_id']; - $rss[$i]['title'] = $rowrss['event_title']; - $rss[$i]['description'] = ''; - $rss[$i]['category_name'] = $rowrss['event_cat_name']; - $rss[$i]['category_link'] = ''; - $rss[$i]['datestamp'] = $rowrss['event_start']; - $rss[$i]['enc_url'] = ""; - $rss[$i]['enc_leng'] = ""; - $rss[$i]['enc_type'] = ""; - $i++; + $config = array(); + + $config[] = array( + 'name' => 'Calendar', + 'url' => 'calendar', + 'topic_id' => '', + 'description' => 'This is the rss feed for the calendar entries', // that's 'description' not 'text' + 'class' => '0', + 'limit' => '9' + ); + + return $config; } -} -//##### ------------------------------------------------------------------------------------ + + /** + * Compile RSS Data + * @param $parms array url, limit, id + * @return array + */ + function data($parms='') + { + $sql = e107::getDb(); + + require_once('ecal_class.php'); + $ecal_class = new ecal_class; -$eplug_rss_feed[] = $feed; -$eplug_rss_data[] = $rss; + $current_day = $ecal_class->cal_date['mday']; + $current_month = $ecal_class->cal_date['mon']; + $current_year = $ecal_class->cal_date['year']; + $current = mktime(0,0,0,$current_month, $current_day, $current_year); + + $rss = array(); + $i=0; + + $query = " + SELECT e.*, c.event_cat_name + FROM `#event` AS e + LEFT JOIN `#event_cat` AS c ON c.event_cat_id = e.event_category + WHERE e.event_start>='{$current}' AND c.event_cat_class REGEXP '".e_CLASS_REGEXP."' + ORDER BY e.event_start ASC LIMIT 0,".$parms['limit']; + + if($items = $sql->gen($query)) + { + + while($row = $sql->fetch()) + { + $tmp = explode(".", $row['event_author']); + $rss[$i]['author'] = $tmp[1]; + $rss[$i]['author_email'] = ''; + $rss[$i]['link'] = "calendar_menu/event.php?".$row['event_start'].".event.".$row['event_id']; + $rss[$i]['linkid'] = $row['event_id']; + $rss[$i]['title'] = $row['event_title']; + $rss[$i]['description'] = ''; + $rss[$i]['category_name'] = $row['event_cat_name']; + $rss[$i]['category_link'] = ''; + $rss[$i]['datestamp'] = $row['event_start']; + $rss[$i]['enc_url'] = ""; + $rss[$i]['enc_leng'] = ""; + $rss[$i]['enc_type'] = ""; + $i++; + } + + } + + return $rss; + } + + +} ?> \ No newline at end of file From c8824ee28904a27ea1bf51fc7b529bbc8c1d11cd Mon Sep 17 00:00:00 2001 From: Moc Date: Thu, 12 Sep 2013 20:10:30 +0200 Subject: [PATCH 05/23] Moved Chatbox notify LAN to Global --- e107_plugins/chatbox_menu/languages/English/English.php | 9 --------- .../chatbox_menu/languages/English/English_global.php | 7 +++++++ 2 files changed, 7 insertions(+), 9 deletions(-) diff --git a/e107_plugins/chatbox_menu/languages/English/English.php b/e107_plugins/chatbox_menu/languages/English/English.php index 8cf0543b6..61f4ec318 100644 --- a/e107_plugins/chatbox_menu/languages/English/English.php +++ b/e107_plugins/chatbox_menu/languages/English/English.php @@ -41,14 +41,5 @@ define("CHATBOX_L23", "Error!"); define("CHATBOX_L24", "You do not have the correct permissions to view this page."); define("CHATBOX_L25", "[ this post has been blocked by admin ]"); -// Notify -define("NT_LAN_CB_1", "Chatbox Events"); -define("NT_LAN_CB_2", "Message posted"); -define("NT_LAN_CB_3", "Posted by"); -define("NT_LAN_CB_4", "IP Address"); -define("NT_LAN_CB_5", "Message"); -define("NT_LAN_CB_6", "Chatbox Message Posted"); - - define("LAN_CHATBOX_100", "Type your message here."); ?> \ No newline at end of file diff --git a/e107_plugins/chatbox_menu/languages/English/English_global.php b/e107_plugins/chatbox_menu/languages/English/English_global.php index 9b49390ce..63c3804f7 100644 --- a/e107_plugins/chatbox_menu/languages/English/English_global.php +++ b/e107_plugins/chatbox_menu/languages/English/English_global.php @@ -12,5 +12,12 @@ define("LAN_AL_CHBLAN_03","Chatbox posts recalculated"); define("LAN_AL_CHBLAN_04",""); define("LAN_AL_CHBLAN_05",""); +// Notify +define("NT_LAN_CB_1", "Chatbox Events"); +define("NT_LAN_CB_2", "Message posted"); +define("NT_LAN_CB_3", "Posted by"); +define("NT_LAN_CB_4", "IP Address"); +define("NT_LAN_CB_5", "Message"); +define("NT_LAN_CB_6", "Chatbox Message Posted"); ?> \ No newline at end of file From 369304a81a3727bea4b2aac72af18d130fed4143 Mon Sep 17 00:00:00 2001 From: Moc Date: Mon, 16 Sep 2013 12:45:35 +0200 Subject: [PATCH 06/23] Updated calendar_menu notify to v2 standards --- e107_plugins/calendar_menu/e_notify.php | 69 +++++++++++-------------- 1 file changed, 31 insertions(+), 38 deletions(-) diff --git a/e107_plugins/calendar_menu/e_notify.php b/e107_plugins/calendar_menu/e_notify.php index 3ded1b3c5..7e53430e2 100644 --- a/e107_plugins/calendar_menu/e_notify.php +++ b/e107_plugins/calendar_menu/e_notify.php @@ -6,57 +6,50 @@ * Released under the terms and conditions of the * GNU General Public License (http://www.gnu.org/licenses/gpl.txt) * - * Notify shim - * - * $Source: /cvs_backup/e107_0.8/e107_plugins/calendar_menu/e_notify.php,v $ - * $Revision$ - * $Date$ - * $Author$ - */ - -/** - * e107 Event calendar plugin - * - * Notify shim - * - * @package e107_plugins - * @subpackage event_calendar - * @version $Id$; */ if (!defined('e107_INIT')) { exit; } -if(defined('ADMIN_PAGE') && ADMIN_PAGE === true) -{ - include_lan(e_PLUGIN.'calendar_menu/languages/'.e_LANGUAGE.'_class.php'); - $config_category = NT_LAN_EC_1; - $config_events = array('ecalnew' => NT_LAN_EC_7, 'ecaledit' => NT_LAN_EC_2); -} - -if (!function_exists('notify_ecalnew')) -{ - function notify_ecalnew($data) +// v2.x Standard +class calendar_menu_notify extends notify +{ + function config() + { + + $config = array(); + + $config[] = array( + 'name' => NT_LAN_EC_7, + 'function' => "ecalnew", + 'category' => '' + ); + + $config[] = array( + 'name' => NT_LAN_EC_2, + 'function' => "ecaledit", + 'category' => '' + ); + + return $config; + } + + function ecalnew($data) { - global $nt; - include_lan(e_PLUGIN.'calendar_menu/languages/'.e_LANGUAGE.'.php'); $message = NT_LAN_EC_3.': '.USERNAME.' ('.NT_LAN_EC_4.': '.$data['ip'].' )
    '; $message .= NT_LAN_EC_5.':
    '.$data['cmessage'].'

    '; - $nt -> send('ecaledit', NT_LAN_EC_6, $message); + + $this->send('ecalnew', NT_LAN_EC_6, $message); } -} -if (!function_exists('notify_ecaledit')) -{ - function notify_ecaledit($data) + function ecaledit($data) { - global $nt; - include_lan(e_PLUGIN.'calendar_menu/languages/'.e_LANGUAGE.'.php'); $message = NT_LAN_EC_3.': '.USERNAME.' ('.NT_LAN_EC_4.': '.$data['ip'].' )
    '; $message .= NT_LAN_EC_5.':
    '.$data['cmessage'].'

    '; - $nt -> send('ecaledit', NT_LAN_EC_8, $message); - } -} + $this->send('ecaledit', NT_LAN_EC_8, $message); + } + +} ?> \ No newline at end of file From db24f48c7c92d6954dcafb237dfd6703f409224b Mon Sep 17 00:00:00 2001 From: Moc Date: Mon, 16 Sep 2013 12:46:02 +0200 Subject: [PATCH 07/23] Moved calendar_menu notify LAN to Global --- e107_plugins/calendar_menu/languages/English_class.php | 5 +++-- e107_plugins/calendar_menu/languages/English_global.php | 9 +++++++++ 2 files changed, 12 insertions(+), 2 deletions(-) diff --git a/e107_plugins/calendar_menu/languages/English_class.php b/e107_plugins/calendar_menu/languages/English_class.php index 46b358a9c..986c15952 100644 --- a/e107_plugins/calendar_menu/languages/English_class.php +++ b/e107_plugins/calendar_menu/languages/English_class.php @@ -48,7 +48,8 @@ define('EC_LAN_RECUR_1300', 'Third'); define('EC_LAN_RECUR_1400', 'Fourth'); -// Notify +/* +// Notify - moved to Global define('NT_LAN_EC_1', 'Event Calendar Events'); define('NT_LAN_EC_2', 'Event Updated'); define('NT_LAN_EC_3', 'Update by'); @@ -56,7 +57,7 @@ define('NT_LAN_EC_4', 'IP Address'); define('NT_LAN_EC_5', 'Message'); define('NT_LAN_EC_6', 'Event Calendar - Event added'); define('NT_LAN_EC_7', 'New event posted'); -define('NT_LAN_EC_8', 'Event Calendar - Event modified'); +define('NT_LAN_EC_8', 'Event Calendar - Event modified');*/ ?> \ No newline at end of file diff --git a/e107_plugins/calendar_menu/languages/English_global.php b/e107_plugins/calendar_menu/languages/English_global.php index e01e3bb22..9d807af0c 100644 --- a/e107_plugins/calendar_menu/languages/English_global.php +++ b/e107_plugins/calendar_menu/languages/English_global.php @@ -5,5 +5,14 @@ define("LAN_PLUGIN_CALENDAR_MENU_CONFIG", "Configure Event Calendar"); define("LAN_PLUGIN_CALENDAR_MENU_DESCRIPTION", "This plugin is a fully featured event calendar with calendar menu."); define("LAN_PLUGIN_CALENDAR_MENU_LINK", "Calendar"); +// Notify +//define('NT_LAN_EC_1', 'Event Calendar Events'); +define('NT_LAN_EC_2', 'Event Updated'); +define('NT_LAN_EC_3', 'Update by'); +define('NT_LAN_EC_4', 'IP Address'); +define('NT_LAN_EC_5', 'Message'); +define('NT_LAN_EC_6', 'Event Calendar - Event added'); +define('NT_LAN_EC_7', 'New event posted'); +define('NT_LAN_EC_8', 'Event Calendar - Event modified'); ?> \ No newline at end of file From 2176c625fb1f9414abdf1844b995f1867589e662 Mon Sep 17 00:00:00 2001 From: Moc Date: Mon, 16 Sep 2013 12:46:52 +0200 Subject: [PATCH 08/23] Minor code clean-up (notify LAN are now in global LAN) --- e107_plugins/chatbox_menu/e_notify.php | 4 ++-- e107_plugins/gsitemap/e_cron.php | 14 +------------- 2 files changed, 3 insertions(+), 15 deletions(-) diff --git a/e107_plugins/chatbox_menu/e_notify.php b/e107_plugins/chatbox_menu/e_notify.php index 206639f88..65b46cfb2 100644 --- a/e107_plugins/chatbox_menu/e_notify.php +++ b/e107_plugins/chatbox_menu/e_notify.php @@ -36,7 +36,7 @@ class chatbox_menu_notify extends notify // plugin-folder + '_notify' { function config() { - // include_lan(e_PLUGIN."chatbox_menu/languages/".e_LANGUAGE."/".e_LANGUAGE.".php"); Use English_global.php instead. + //include_lan(e_PLUGIN."chatbox_menu/languages/".e_LANGUAGE."/".e_LANGUAGE.".php"); Use English_global.php instead. $config = array(); @@ -51,7 +51,7 @@ class chatbox_menu_notify extends notify // plugin-folder + '_notify' function cboxpost($data) { - include_lan(e_PLUGIN."chatbox_menu/languages/".e_LANGUAGE."/".e_LANGUAGE.".php"); // Use English_global.php instead. + //include_lan(e_PLUGIN."chatbox_menu/languages/".e_LANGUAGE."/".e_LANGUAGE.".php"); // Use English_global.php instead. $message = NT_LAN_CB_3.': '.USERNAME.' ('.NT_LAN_CB_4.': '.e107::getIPHandler()->ipDecode($data['ip']).' )
    '; $message .= NT_LAN_CB_5.':
    '.$data['cmessage'].'

    '; diff --git a/e107_plugins/gsitemap/e_cron.php b/e107_plugins/gsitemap/e_cron.php index 8aba2a6cc..44765991c 100644 --- a/e107_plugins/gsitemap/e_cron.php +++ b/e107_plugins/gsitemap/e_cron.php @@ -2,25 +2,15 @@ /* * e107 website system * - * Copyright (C) 2008-2009 e107 Inc (e107.org) + * Copyright (C) 2008-2013 e107 Inc (e107.org) * Released under the terms and conditions of the * GNU General Public License (http://www.gnu.org/licenses/gpl.txt) * * Plugin configuration module - gsitemap * - * $Source: /cvs_backup/e107_0.8/e107_plugins/gsitemap/e_cron.php,v $ - * $Revision$ - * $Date$ - * $Author$ - * */ if (!defined('e107_INIT')) { exit; } -/*if(!plugInstalled('gsitemap')) -{ - return; -}*/ - class gsitemap_cron // include plugin-folder in the name. { @@ -48,7 +38,6 @@ class gsitemap_cron // include plugin-folder in the name. } - function myfunction() { // Whatever code you wish. @@ -57,7 +46,6 @@ class gsitemap_cron // include plugin-folder in the name. } - function sendEmail() { From 2042ecd473c9847135d873ef2828e235e98b2a04 Mon Sep 17 00:00:00 2001 From: Moc Date: Mon, 16 Sep 2013 12:57:42 +0200 Subject: [PATCH 09/23] Forum - created global, moved notify lan to global, added NAME/DESC LAN for plugin.xml --- .../languages/English/English_global.php | 26 +++++++++++++++++++ .../languages/English/lan_forum_notify.php | 6 +++-- e107_plugins/forum/plugin.xml | 4 +-- 3 files changed, 32 insertions(+), 4 deletions(-) create mode 100644 e107_plugins/forum/languages/English/English_global.php diff --git a/e107_plugins/forum/languages/English/English_global.php b/e107_plugins/forum/languages/English/English_global.php new file mode 100644 index 000000000..76b94ddc2 --- /dev/null +++ b/e107_plugins/forum/languages/English/English_global.php @@ -0,0 +1,26 @@ + \ No newline at end of file diff --git a/e107_plugins/forum/languages/English/lan_forum_notify.php b/e107_plugins/forum/languages/English/lan_forum_notify.php index a69673ce0..b61f66124 100644 --- a/e107_plugins/forum/languages/English/lan_forum_notify.php +++ b/e107_plugins/forum/languages/English/lan_forum_notify.php @@ -15,7 +15,9 @@ * */ -define('FORUM_NT_1', 'Forum Events'); +// DEPRECATED FILE - NOTIFY LAN ARE NOW IN GLOBAL + +/*define('FORUM_NT_1', 'Forum Events'); define('FORUM_NT_2', 'Thread'); define('FORUM_NT_3', 'Post'); define('FORUM_NT_4', 'added by'); @@ -32,4 +34,4 @@ define('FORUM_NT_NEWTHREAD_PROB', 'New thread created by probationary member'); define('FORUM_NT_THREAD_DELETED', 'Thread deleted'); define('FORUM_NT_THREAD_SPLIT', 'Thread split'); define('FORUM_NT_POST_DELETED', 'Post deleted'); -define('FORUM_NT_POST_REPORTED', 'Post reported'); +define('FORUM_NT_POST_REPORTED', 'Post reported');*/ diff --git a/e107_plugins/forum/plugin.xml b/e107_plugins/forum/plugin.xml index 14cf4c9ec..51c3ddb20 100755 --- a/e107_plugins/forum/plugin.xml +++ b/e107_plugins/forum/plugin.xml @@ -1,7 +1,7 @@ - + - This plugin is a fully featured Forum system + This plugin is a fully featured forum system content Configure Forum From 98688f5aea706337ee0288771bc2ba0bdd02f3ce Mon Sep 17 00:00:00 2001 From: Moc Date: Mon, 16 Sep 2013 13:11:12 +0200 Subject: [PATCH 10/23] Updated forum e_notify to v2 standards --- e107_plugins/forum/e_notify.php | 151 ++++++++++-------- .../languages/English/English_global.php | 20 +-- 2 files changed, 96 insertions(+), 75 deletions(-) diff --git a/e107_plugins/forum/e_notify.php b/e107_plugins/forum/e_notify.php index e816753b2..ccb46e818 100644 --- a/e107_plugins/forum/e_notify.php +++ b/e107_plugins/forum/e_notify.php @@ -10,75 +10,94 @@ * */ +// TODO - create notify messages + LAN + if (!defined('e107_INIT')) { exit; } -if(defined('ADMIN_PAGE') && ADMIN_PAGE === true) -{ - include_lan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/lan_forum_notify.php'); // FIXME needs changing after forum lan rewrite - $config_category = FORUM_NT_1; - $config_events = array( - 'forum_nt' => FORUM_NT_NEWTHREAD, - 'forum_ntp' => FORUM_NT_NEWTHREAD_PROB, - 'forum_thread_del' => FORUM_NT_THREAD_DELETED, - 'forum_thread_split' => FORUM_NT_THREAD_SPLIT, - 'forum_post_del' => FORUM_NT_POST_DELETED, - 'forum_post_rep' => FORUM_NT_POST_REPORTED - ); +// v2.x Standard +class forum_notify extends notify +{ + function config() + { + + $config = array(); + + $config[] = array( + 'name' => FORUM_NT_NEWTOPIC, + 'function' => "forum_nt", + 'category' => '' + ); + + $config[] = array( + 'name' => FORUM_NT_NEWTOPIC_PROB, + 'function' => "forum_ntp", + 'category' => '' + ); + + $config[] = array( + 'name' => FORUM_NT_TOPIC_DELETED, + 'function' => "forum_topic_del", + 'category' => '' + ); + + $config[] = array( + 'name' => FORUM_NT_TOPIC_SPLIT, + 'function' => "forum_topic_split", + 'category' => '' + ); + + $config[] = array( + 'name' => FORUM_NT_POST_DELETED, + 'function' => "forum_post_del", + 'category' => '' + ); + + $config[] = array( + 'name' => FORUM_NT_POST_REPORTED, + 'function' => "forum_post_rep", + 'category' => '' + ); + + return $config; + } + + function forum_nt($data) + { + $message = 'todo'; + $this->send('forum_nt', FORUM_NT_6, $message); + } + + function forum_ntp($data) + { + $message = 'todo'; + $this->send('forum_nt', FORUM_NT_7, $message); + } + + function forum_topic_del($data) + { + $message = 'todo'; + $this->send('forum_topic_del', FORUM_NT_8, $message); + } + + function forum_topic_split($data) + { + $message = 'todo'; + $this->send('forum_topic_split', FORUM_NT_9, $message); + } + + function forum_post_del($data) + { + $message = 'todo'; + $this->send('forum_post_del', FORUM_NT_10, $message); + } + + function forum_post_rep($data) + { + $message = 'todo'; + $this->send('forum_post_rep', FORUM_NT_11, $message); + } + } -if (!function_exists('notify_forum_nt')) -{ - function notify_forum_nt($data) - { - $e107 = e107::getInstance(); - include_lan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/lan_forum_notify.php'); - $message = 'todo'; - $e107->notify->send('forum_nt', FORUM_NT_6, $message); - } -} - -if (!function_exists('notify_forum_ntp')) -{ - function notify_forum_ntp($data) - { - $e107 = e107::getInstance(); - include_lan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/lan_forum_notify.php'); - $message = 'todo'; - $e107->notify->send('forum_ntp', FORUM_NT_7, $message); - } -} - -if (!function_exists('forum_thread_del')) -{ - function forum_thread_del($data) - { - $e107 = e107::getInstance(); - include_lan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/lan_forum_notify.php'); - $message = 'todo'; - $e107->notify->send('forum_thread_del', FORUM_NT_8, $message); - } -} - -if (!function_exists('forum_thread_split')) -{ - function forum_thread_split($data) - { - $e107 = e107::getInstance(); - include_lan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/lan_forum_notify.php'); - $message = 'todo'; - $e107->notify->send('forum_thread_split', FORUM_NT_8, $message); - } -} - -if (!function_exists('forum_post_rep')) -{ - function forum_post_rep($data) - { - $e107 = e107::getInstance(); - include_lan(e_PLUGIN.'forum/languages/'.e_LANGUAGE.'/lan_forum_notify.php'); - $message = 'todo'; - $e107->notify->send('forum_post_rep', FORUM_NT_9, $message); - } -} ?> \ No newline at end of file diff --git a/e107_plugins/forum/languages/English/English_global.php b/e107_plugins/forum/languages/English/English_global.php index 76b94ddc2..674b435f7 100644 --- a/e107_plugins/forum/languages/English/English_global.php +++ b/e107_plugins/forum/languages/English/English_global.php @@ -4,11 +4,13 @@ define("LAN_PLUGIN_FORUM_NAME", "Forum"); define("LAN_PLUGIN_FORUM_DESC", "This plugin is a fully featured forum system."); // Notify -define('FORUM_NT_1', 'Forum Events'); -define('FORUM_NT_2', 'Thread'); -define('FORUM_NT_3', 'Post'); -define('FORUM_NT_4', 'added by'); -define('FORUM_NT_5', 'moved by'); +// TODO - LAN cleanup (see e_notify) + +//define('FORUM_NT_1', 'Forum Events'); +//define('FORUM_NT_2', 'Thread'); +//define('FORUM_NT_3', 'Post'); +//define('FORUM_NT_4', 'added by'); +//define('FORUM_NT_5', 'moved by'); define('FORUM_NT_6', 'Forum - Thread created'); define('FORUM_NT_7', 'Forum - Thread created by new user'); define('FORUM_NT_8', 'Forum - Thread deleted'); @@ -16,10 +18,10 @@ define('FORUM_NT_9', 'Forum - Thread split'); define('FORUM_NT_10', 'Forum - Post deleted'); define('FORUM_NT_11', 'Forum - Post reported'); -define('FORUM_NT_NEWTHREAD', 'New thread created'); -define('FORUM_NT_NEWTHREAD_PROB', 'New thread created by probationary member'); -define('FORUM_NT_THREAD_DELETED', 'Thread deleted'); -define('FORUM_NT_THREAD_SPLIT', 'Thread split'); +define('FORUM_NT_NEWTOPIC', 'New topic created'); +define('FORUM_NT_NEWTOPIC_PROB', 'New topic created by probationary member'); +define('FORUM_NT_TOPIC_DELETED', 'Topic deleted'); +define('FORUM_NT_TOPIC_SPLIT', 'Topic split'); define('FORUM_NT_POST_DELETED', 'Post deleted'); define('FORUM_NT_POST_REPORTED', 'Post reported'); From 6dd2738e0bd848d6a282d6b016b5ee408dd76f14 Mon Sep 17 00:00:00 2001 From: Moc Date: Mon, 16 Sep 2013 13:22:01 +0200 Subject: [PATCH 11/23] Minor LAN correction --- e107_plugins/forum/forum.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/e107_plugins/forum/forum.php b/e107_plugins/forum/forum.php index 377bde70e..16327195d 100644 --- a/e107_plugins/forum/forum.php +++ b/e107_plugins/forum/forum.php @@ -243,7 +243,7 @@ $newflag_list = $forum->forumGetUnreadForums(); if (!$forumList) { - $ns->tablerender(PAGE_NAME, "
    ".LAN_FORUM_0067.'
    ', array('forum', '51')); + $ns->tablerender(LAN_FORUM_0001, "
    ".LAN_FORUM_0067.'
    ', array('forum', '51')); require_once(FOOTERF); exit; } From 7678f3fecc9f41fafc134c11bdaf188b34161ad6 Mon Sep 17 00:00:00 2001 From: Cameron Date: Mon, 16 Sep 2013 14:12:04 -0700 Subject: [PATCH 12/23] Issue #439 CAPTCHA was difficult to read on some backgrounds. Added support for constant e_CAPTCHA_FONTCOLOR (use hex color) which may be used in theme.php --- e107_admin/auth.php | 4 ++ e107_handlers/secure_img_handler.php | 70 ++++++++++++++++++++++++---- e107_images/secimg.php | 13 +++++- 3 files changed, 78 insertions(+), 9 deletions(-) diff --git a/e107_admin/auth.php b/e107_admin/auth.php index 79cda598f..5799d6174 100644 --- a/e107_admin/auth.php +++ b/e107_admin/auth.php @@ -18,6 +18,10 @@ if (!defined('e107_INIT')) { exit; } + +define('e_CAPTCHA_FONTCOLOR','#F9A533'); + + // Required for a clean v1.x -> v2 upgrade. $core = e107::getConfig('core'); if($core->get('admintheme') != 'bootstrap') diff --git a/e107_handlers/secure_img_handler.php b/e107_handlers/secure_img_handler.php index 5cbad7227..ca55b9e2d 100644 --- a/e107_handlers/secure_img_handler.php +++ b/e107_handlers/secure_img_handler.php @@ -24,6 +24,7 @@ class secure_image protected $MYSQL_INFO; protected $THIS_DIR; protected $BASE_DIR; + public $FONT_COLOR = "90,90,90"; function secure_image() { @@ -135,25 +136,60 @@ class secure_image } - + //XXX Discuss - Add more posibilities for themers? e_CAPTCHA_BGIMAGE, e_CAPTCH_WIDTH, e_CAPTCHA_HEIGHT? function r_image() { if ($user_func = e107::getOverride()->check($this,'r_image')) { return call_user_func($user_func); } - + + if(defined('e_CAPTCHA_FONTCOLOR')) + { + $color = str_replace("#","", e_CAPTCHA_FONTCOLOR); + } + else + { + $color = 'cccccc'; + } + $code = $this->create_code(); - return "Missing Code"; + return "Missing Code"; } + + function renderImage() // Alias of r_image { return $this->r_image(); } + function hex2rgb($hex) + { + $hex = str_replace("#", "", $hex); + + if(strlen($hex) == 3) + { + $r = hexdec(substr($hex,0,1).substr($hex,0,1)); + $g = hexdec(substr($hex,1,1).substr($hex,1,1)); + $b = hexdec(substr($hex,2,1).substr($hex,2,1)); + } + else + { + $r = hexdec(substr($hex,0,2)); + $g = hexdec(substr($hex,2,2)); + $b = hexdec(substr($hex,4,2)); + } + + $rgb = array($r, $g, $b); + + return implode(",", $rgb); + } + + + function renderInput() { @@ -180,8 +216,14 @@ class secure_image /** * Render the generated Image. Called without class2 environment (standalone). */ - function render($qcode) + function render($qcode, $color='') { + if($color) + { + $this->FONT_COLOR = $this->hex2rgb($color); + } + + // echo "COLOR: ".$this->FONT_COLOR; require_once($this->BASE_DIR.$this->HANDLERS_DIRECTORY."override_class.php"); $over = new override; @@ -262,7 +304,7 @@ class secure_image $fontpath = $this->BASE_DIR.$this->FONTS_DIRECTORY; $secureimg['image'] = "generic/code_bg"; $secureimg['angle'] = "0"; - $secureimg['color'] = "90,90,90"; // red,green,blue + $secureimg['color'] = $this->FONT_COLOR; // red,green,blue $secureimg['x'] = "1"; $secureimg['y'] = "21"; @@ -323,18 +365,21 @@ class secure_image // removing the black from the placeholder - + $image = $this->imageCreateTransparent(100,35); //imagecreatetruecolor(100, 35); + + if(isset($secureimg['color'])) { $tmp = explode(",",$secureimg['color']); $text_color = imagecolorallocate($image,$tmp[0],$tmp[1],$tmp[2]); + } else { $text_color = imagecolorallocate($image, 90, 90, 90); } - + header("Content-type: image/{$type}"); if(isset($secureimg['font']) && is_readable($fontpath.$secureimg['font'])) @@ -346,6 +391,8 @@ class secure_image imagestring ($image, 5, 12, 2, $code, $text_color); } + imagesavealpha($image, true); + switch($type) { case "jpeg": @@ -363,7 +410,14 @@ class secure_image } - + function imageCreateTransparent($x, $y) + { + $imageOut = imagecreatetruecolor($x, $y); + $backgroundColor = imagecolorallocatealpha($imageOut, 0, 0, 0, 127); + imagefill($imageOut, 0, 0, $backgroundColor); + return $imageOut; + } + diff --git a/e107_images/secimg.php b/e107_images/secimg.php index afb36fc65..47c850731 100644 --- a/e107_images/secimg.php +++ b/e107_images/secimg.php @@ -40,7 +40,18 @@ require_once(realpath(e_BASE.$HANDLERS_DIRECTORY.DIRECTORY_SEPARATOR."secure_img $sim = new secure_image(); -$sim->render($_SERVER['QUERY_STRING']); +$code = $_GET['id']; + +if(preg_match('/^[a-f0-9]{6}$/i', $_GET['clr'])) //hex color is valid +{ + $color = $_GET['clr']; +} +else +{ + $color = "cccccc"; +} + +$sim->render($code,$color); exit; From 54c0bbe4b68980e2822624b9957a187e1410c37a Mon Sep 17 00:00:00 2001 From: Cameron Date: Mon, 16 Sep 2013 14:12:44 -0700 Subject: [PATCH 13/23] Wordpress news import tweaks --- e107_plugins/import/admin_import.php | 2 +- .../providers/wordpress_import_class.php | 97 +++++++++++++++---- 2 files changed, 80 insertions(+), 19 deletions(-) diff --git a/e107_plugins/import/admin_import.php b/e107_plugins/import/admin_import.php index 00f7a26d7..08a93a4e8 100644 --- a/e107_plugins/import/admin_import.php +++ b/e107_plugins/import/admin_import.php @@ -150,7 +150,7 @@ class import_main_ui extends e_admin_ui function help() { - return "Some help text from admin-ui"; + return "Some help text for admin-ui"; } diff --git a/e107_plugins/import/providers/wordpress_import_class.php b/e107_plugins/import/providers/wordpress_import_class.php index 1ff7553f8..6095d96e6 100644 --- a/e107_plugins/import/providers/wordpress_import_class.php +++ b/e107_plugins/import/providers/wordpress_import_class.php @@ -35,7 +35,47 @@ class wordpress_import extends base_import_class public $supported = array('users','news','page','links'); public $mprefix = 'wp_'; + function init() + { + + + $this->newsAuthor = intval($_POST['news_author']); + + // if($data = e107::getDb('phpbb')->retrieve('userclass_classes','userclass_id',"userclass_name='FORUM_MODERATOR' ")) + // { + // $this->forum_moderator_class = $data; + // } + + } + function config() + { + $sql = e107::getDb(); + + $sql->select('user','user_id, user_name','user_admin = 1'); + + $adminList = array(); + + $adminList[0] = "Default"; + + while($row = $sql->fetch()) + { + $id = $row['user_id']; + $adminList[$id] = $row['user_name']; + } + $frm = e107::getForm(); + + $var[0]['caption'] = "News Author Override (optional)"; + $var[0]['html'] = $frm->select('news_author',$adminList); + $var[0]['help'] = "Change the author of the news items"; + + // $var[1]['caption'] = "Include revisions"; + // $var[1]['html'] = $frm->checkbox('news_revisions',1); + // $var[1]['help'] = "Change the author of the news items"; + + return $var; + } + // Set up a query for the specified task. @@ -59,9 +99,9 @@ class wordpress_import extends base_import_class LEFT JOIN {$this->DBPrefix}usermeta AS l ON (u.ID = l.user_id AND l.meta_key = 'last_name') GROUP BY u.ID"; - // $this->ourDB -> db_Select_gen($query); + // $this->ourDB -> gen($query); - $result = $this->ourDB->db_Select_gen($query); + $result = $this->ourDB->gen($query); if ($result === FALSE) return FALSE; @@ -79,26 +119,26 @@ class wordpress_import extends base_import_class break; case 'news' : - $query = "SELECT * FROM {$this->DBPrefix}posts WHERE post_type = 'post' AND post_status !='trash' ORDER BY ID"; - $result = $this->ourDB->db_Select_gen($query); + $query = "SELECT * FROM {$this->DBPrefix}posts WHERE (post_type = 'post') AND post_status !='trash' AND post_status != 'auto-draft' ORDER BY ID"; + $result = $this->ourDB->gen($query); if ($result === FALSE) return FALSE; break; case 'page' : $query = "SELECT * FROM {$this->DBPrefix}posts WHERE post_type = 'page' AND post_status !='trash' ORDER BY ID"; - $result = $this->ourDB->db_Select_gen($query); + $result = $this->ourDB->gen($query); if ($result === FALSE) return FALSE; break; case 'media' : $query = "SELECT * FROM {$this->DBPrefix}posts WHERE post_type = 'attachment' AND post_status !='trash' ORDER BY ID"; - $result = $this->ourDB->db_Select_gen($query); + $result = $this->ourDB->gen($query); if ($result === FALSE) return FALSE; break; case 'links': $query = "SELECT * FROM {$this->DBPrefix}links WHERE link_id !='' ORDER BY link_id"; - $result = $this->ourDB->db_Select_gen($query); + $result = $this->ourDB->gen($query); if ($result === FALSE) return FALSE; break; @@ -205,22 +245,22 @@ class wordpress_import extends base_import_class */ // $target['news_id'] = $source['ID']; - $target['news_title'] = $source['post_title']; + $target['news_title'] = $this->convertText($source['post_title']); $target['news_sef'] = $source['post_name']; - $target['news_body'] = (vartrue($source['post_content'])) ? "[html]".$source['post_content']."[/html]" : ""; + $target['news_body'] = (vartrue($source['post_content'])) ? "[html]".$this->convertText($source['post_content'])."[/html]" : ""; // $target['news_extended'] = ''; // $target['news_meta_keywords'] = ''; // $target['news_meta_description'] = ''; $target['news_datestamp'] = strtotime($source['post_date']); - $target['news_author'] = $source['post_author']; + $target['news_author'] = ($this->newsAuthor !=0) ? $this->newsAuthor : $source['post_author']; // $target['news_category'] = ''; $target['news_allow_comments'] = ($source['comment_status']=='open') ? 1 : 0; $target['news_start'] = ''; $target['news_end'] = ''; - $target['news_class'] = ''; - $target['news_render_type'] = ''; + $target['news_class'] = $this->newsClass($source['post_status']); + // $target['news_render_type'] = '0'; $target['news_comment_total'] = $source['comment_count']; - $target['news_summary'] = $source['post_excerpt']; + $target['news_summary'] = $this->convertText($source['post_excerpt']); $target['news_thumbnail'] = ''; $target['news_sticky'] = ''; @@ -232,6 +272,14 @@ class wordpress_import extends base_import_class + // Convert Wordpress Status to e107 News visibility class. + function newsClass($status) + { + $convert = array('publish'=> e_UC_PUBLIC, 'inherit' => e_UC_NOBODY, 'draft' => e_UC_NOBODY); + + return intval($convert[$status]); + + } /** * Align source data to e107 Page Table @@ -257,9 +305,9 @@ class wordpress_import extends base_import_class } // $target['page_id'] = $source['ID']; // auto increment - $target['page_title'] = $source['post_title']; + $target['page_title'] = $this->convertText($source['post_title']); $target['page_sef'] = $source['post_name']; - $target['page_text'] = (vartrue($source['post_content'])) ? "[html]".$source['post_content']."[/html]" : ""; + $target['page_text'] = (vartrue($source['post_content'])) ? "[html]".$this->convertText($source['post_content'])."[/html]" : ""; $target['page_metakeys'] = ''; $target['page_metadscr'] = ''; $target['page_datestamp'] = strtotime($source['post_date']); @@ -321,9 +369,9 @@ class wordpress_import extends base_import_class */ - $target['link_name'] = $source['link_name']; + $target['link_name'] = $this->convertText($source['link_name']); $target['link_url'] = $source['link_url']; - $target['link_description'] = (vartrue($source['link_description'])) ? "[html]".$source['link_description']."[/html]" : ""; + $target['link_description'] = (vartrue($source['link_description'])) ? "[html]".$this->convertText($source['link_description'])."[/html]" : ""; // $target['link_button'] = ''; // $target['link_category'] = ''; // $target['link_order'] = ''; @@ -341,7 +389,20 @@ class wordpress_import extends base_import_class - + function convertText($text) + { + //$text = e107::getParser()->toDb($text); + return $text; + + $text = html_entity_decode($text,ENT_QUOTES,'UTF-8'); + + $detected = mb_detect_encoding($text); // 'ISO-8859-1' + $text = iconv($detected,'UTF-8',$text); + + + + return $text; + } From 9e6350cdbe8331ff548d6cfc00e3d0bf7d560d93 Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 17 Sep 2013 10:07:59 -0700 Subject: [PATCH 14/23] CAPTCHA on admin login page css styling --- e107_admin/auth.php | 4 +++- e107_handlers/secure_img_handler.php | 2 +- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/e107_admin/auth.php b/e107_admin/auth.php index 5799d6174..ef78b9a66 100644 --- a/e107_admin/auth.php +++ b/e107_admin/auth.php @@ -219,7 +219,7 @@ else .submit { } - .placeholder { color: #bbb; font-style:italic } + .placeholder { color: #646667; font-style:italic } ::-webkit-input-placeholder { font-style:italic; color: #bbb; } @@ -231,6 +231,8 @@ else #userpass {background: url(".e_IMAGE."admin_images/lock_16.png) no-repeat scroll 7px 9px; padding:7px;padding-left:30px; width:218px; } + #code-verify { padding: 7px; width: 140px } + input[disabled] { color: silver; } button[disabled] span { color: silver; } .title_clean { display:none; } diff --git a/e107_handlers/secure_img_handler.php b/e107_handlers/secure_img_handler.php index ca55b9e2d..0536d6a58 100644 --- a/e107_handlers/secure_img_handler.php +++ b/e107_handlers/secure_img_handler.php @@ -199,7 +199,7 @@ class secure_image } $frm = e107::getForm(); - return $frm->hidden("rand_num", $this->random_number).$frm->text("code_verify", "", 20, array("size"=>20,"title"=> LAN_ENTER_CODE,'required'=>1)); + return $frm->hidden("rand_num", $this->random_number).$frm->text("code_verify", "", 20, array("size"=>20,"title"=> LAN_ENTER_CODE,'required'=>1, 'placeholder'=>LAN_ENTER_CODE)); } function renderLabel() From a38cf55506f767564ade0b7cf9845a4ac2cd6883 Mon Sep 17 00:00:00 2001 From: Axeia Date: Thu, 26 Sep 2013 15:57:53 +0200 Subject: [PATCH 15/23] {NEWSCATICON} Now has the news category title as alt text The alt attribute of the news category icon now has the title of the news category as its alt text. --- e107_core/shortcodes/batch/news_shortcodes.php | 9 ++++----- 1 file changed, 4 insertions(+), 5 deletions(-) diff --git a/e107_core/shortcodes/batch/news_shortcodes.php b/e107_core/shortcodes/batch/news_shortcodes.php index c7adb86ca..c215baf4b 100644 --- a/e107_core/shortcodes/batch/news_shortcodes.php +++ b/e107_core/shortcodes/batch/news_shortcodes.php @@ -400,8 +400,7 @@ class news_shortcodes extends e_shortcode $src = (is_readable(e_IMAGE_ABS."newspost_images/".$category_icon)) ? e_IMAGE_ABS."newspost_images/".$category_icon : e_IMAGE_ABS."icons/".$category_icon; } - - + $alt_text = e107::getParser()->toHTML($this->news_item['category_name'], FALSE ,'defs'); //TODO - remove inline styles if($this->param['caticon'] == ''){$this->param['caticon'] = 'border:0px';} @@ -412,12 +411,12 @@ class news_shortcodes extends e_shortcode break; case 'tag': - return ""; + return "$alt_text"; break; case 'url': default: - return "news_item)."'>"; + return "news_item)."'>$alt_text"; break; } } @@ -482,4 +481,4 @@ class news_shortcodes extends e_shortcode } } -?> \ No newline at end of file +?> From 80f0a16a87dad55fb4b4f89031700ed9b3dd65ce Mon Sep 17 00:00:00 2001 From: Axeia Date: Thu, 26 Sep 2013 16:11:41 +0200 Subject: [PATCH 16/23] ID clash, IDs should be unique - solved by removing one of them. In no HTML version is or has it ever been allowed to use the same ID more than once. ID made unique as intended. --- e107_handlers/comment_class.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/e107_handlers/comment_class.php b/e107_handlers/comment_class.php index e09a37453..516474d99 100644 --- a/e107_handlers/comment_class.php +++ b/e107_handlers/comment_class.php @@ -261,7 +261,7 @@ class comment $indent = ($action == 'reply') ? " class='offset1' " : ""; $formid = ($action == 'reply') ? "e-comment-form-reply" : "e-comment-form"; - $text = "\n
    \n".e107::getMessage()->render('postcomment', true, false, false);//temporary here + $text = "\n\n".e107::getMessage()->render('postcomment', true, false, false);//temporary here // $text .= "Indent = ".$indent; $text .= "
    "; From c9284edcf3ea8f42f4e2d019419ac23af3a2e49c Mon Sep 17 00:00:00 2001 From: Cameron Date: Tue, 1 Oct 2013 12:19:29 -0700 Subject: [PATCH 17/23] #448 - Support for news avatar - requires testing. --- e107_core/shortcodes/batch/news_shortcodes.php | 6 ++++++ 1 file changed, 6 insertions(+) diff --git a/e107_core/shortcodes/batch/news_shortcodes.php b/e107_core/shortcodes/batch/news_shortcodes.php index c7adb86ca..1b7662330 100644 --- a/e107_core/shortcodes/batch/news_shortcodes.php +++ b/e107_core/shortcodes/batch/news_shortcodes.php @@ -181,6 +181,12 @@ class news_shortcodes extends e_shortcode } } + + function sc_newsavatar() + { + return vartrue($this->news_item['user_id']) ? e107::getParser()->parseTemplate("{USER_AVATAR=".$this->news_item['user_id']."}",true) : ''; + } + function sc_newscommentlink($parm) { return ($this->news_item['news_allow_comments'] ? $this->param['commentoffstring'] : " news_item)."'>".$this->param['commentlink'].''); From 3e043ab4e2f603a4fe44ae0a9a2d06089ddc364f Mon Sep 17 00:00:00 2001 From: SecretR Date: Thu, 3 Oct 2013 12:04:13 +0300 Subject: [PATCH 18/23] Adminstration Language navigation fix --- .../shortcodes/batch/admin_shortcodes.php | 24 +++++++++++++++---- 1 file changed, 20 insertions(+), 4 deletions(-) diff --git a/e107_core/shortcodes/batch/admin_shortcodes.php b/e107_core/shortcodes/batch/admin_shortcodes.php index e8e0e5398..ed02ed52e 100644 --- a/e107_core/shortcodes/batch/admin_shortcodes.php +++ b/e107_core/shortcodes/batch/admin_shortcodes.php @@ -1856,18 +1856,34 @@ Inverse 10 10 if($type == 'language') { - - $languages = e107::getLanguage()->installed();//array('English','French'); + $slng = e107::getLanguage(); + $languages = $slng->installed();//array('English','French'); if(count($languages) > 1) { $c = 0; foreach($languages as $lng) { - $checked = ($lng == e_LANGUAGE) ? " " : "  "; + $checked = "  "; + $code = $slng->convert($lng); + + if($lng == e_LANGUAGE) + { + $checked = " "; + $link = '#'; + } + elseif(e107::getPref('multilanguage_subdomain')) + { + $code = ($lng == e107::getPref('sitelanguage')) ? 'www' : $code; + $link = str_replace($_SERVER['HTTP_HOST'], $code.'.'.e_DOMAIN, e_REQUEST_URL); // includes query string + } + else + { + $link = e_REQUEST_URL.(e_QUERY ? '&elan='.$lng : '?elan='.$lng); + } $tmp[$c]['text'] = $lng; $tmp[$c]['description'] = ''; - $tmp[$c]['link'] = $lng == e_LANGUAGE ? '#' : e_SELF.'?elan='.$lng; + $tmp[$c]['link'] = $link; $tmp[$c]['image'] = $checked; $tmp[$c]['image_large'] = ''; $tmp[$c]['image_src'] = ''; From eff16357404bc0159121cb9b746d4bf2f88e329e Mon Sep 17 00:00:00 2001 From: SecretR Date: Thu, 3 Oct 2013 12:04:45 +0300 Subject: [PATCH 19/23] Admin template absolute image path fix --- e107_themes/bootstrap/admin_template.php | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/e107_themes/bootstrap/admin_template.php b/e107_themes/bootstrap/admin_template.php index da1dbdce5..b803c6a1c 100644 --- a/e107_themes/bootstrap/admin_template.php +++ b/e107_themes/bootstrap/admin_template.php @@ -167,7 +167,7 @@ $ADMIN_HEADER = '