]> git.mxchange.org Git - quix0rs-gnu-social.git/commitdiff
more information in subscription notices
authorEvan Prodromou <evan@prodromou.name>
Fri, 12 Dec 2008 17:11:35 +0000 (12:11 -0500)
committerEvan Prodromou <evan@prodromou.name>
Fri, 12 Dec 2008 17:11:35 +0000 (12:11 -0500)
darcs-hash:20081212171135-84dde-543176e3a8190699e44fc896ba90f6ea776057d4.gz

_darcs/inventory
_darcs/patches/20081212171135-84dde-543176e3a8190699e44fc896ba90f6ea776057d4.gz [new file with mode: 0644]
_darcs/pristine/lib/mail.php
_darcs/tentative_pristine
lib/mail.php

index 1acf0a386b2fddcc207b796972298477cafb7dc8..c8e2b1b21e554df558693175f056086fdc6f9204 100644 (file)
@@ -17,4 +17,6 @@ Sarven Capadisli <csarven@controlyourself.ca>**20081218003302
         
  Substitute your own ID in the user parameter.
  
-] 
\ No newline at end of file
+] 
+[more information in subscription notices
+Evan Prodromou <evan@prodromou.name>**20081212171135] 
\ No newline at end of file
diff --git a/_darcs/patches/20081212171135-84dde-543176e3a8190699e44fc896ba90f6ea776057d4.gz b/_darcs/patches/20081212171135-84dde-543176e3a8190699e44fc896ba90f6ea776057d4.gz
new file mode 100644 (file)
index 0000000..ae18dc6
Binary files /dev/null and b/_darcs/patches/20081212171135-84dde-543176e3a8190699e44fc896ba90f6ea776057d4.gz differ
index a7cbab8589665daa7343ce171d892e66d5947037..c90140d3c3a9128e23041a2cfdc8bd44ec7deaae 100644 (file)
@@ -112,16 +112,25 @@ function mail_subscribe_notify_profile($listenee, $other) {
                $recipients = $listenee->email;
                $headers['From'] = mail_notify_from();
                $headers['To'] = $name . ' <' . $listenee->email . '>';
-               $headers['Subject'] = sprintf(_('%1$s is now listening to your notices on %2$s.'), $other->getBestName(),
+               $headers['Subject'] = sprintf(_('%1$s is now listening to your notices on %2$s.'),
+                                      $other->getBestName(),
                                                                          common_config('site', 'name'));
                $body  = sprintf(_('%1$s is now listening to your notices on %2$s.'."\n\n".
                                                   "\t".'%3$s'."\n\n".
-                                                  'Faithfully yours,'."\n".'%4$s.'."\n"),
-                                                $long_name,
-                                                common_config('site', 'name'),
-                                                $other->profileurl,
-                                                common_config('site', 'name'));
-
+                                                  '%4$s'.
+                           '%5$s'.
+                           '%6$s'.
+                                                  "\n".'Faithfully yours,'."\n".'%7$s.'."\n\n".
+                           "----\n".
+                           "Change your email address or notification options at %8$s"),
+                         $long_name,
+                         common_config('site', 'name'),
+                         $other->profileurl,
+                         ($other->location) ? sprintf(_("Location: %s\n"), $other->location) : '',
+                         ($other->homepage) ? sprintf(_("Homepage: %s\n"), $other->homepage) : '',
+                         ($other->bio) ? sprintf(_("Bio: %s\n\n"), $other->bio) : '',
+                         common_config('site', 'name'),
+                         common_local_url('emailsettings'));
         // reset localization
         common_init_locale();
                mail_send($recipients, $headers, $body);
index 24dba4ff020da9e5de08d9b82a0e0ed4369ba170..a4efd27babc4b7b416615b95ad150c81e133f489 100644 (file)
-addfile ./js/identica-badge.js
-hunk ./js/identica-badge.js 1
-+// identica badge -- updated to work with the native API, 12-4-2008
-+// copyright Kent Brewster 2008
-+// see http://kentbrewster.com/identica-badge for info
-+( function() { 
-+   var trueName = '';
-+   for (var i = 0; i < 16; i++) { 
-+      trueName += String.fromCharCode(Math.floor(Math.random() * 26) + 97); 
-+   }
-+   window[trueName] = {};
-+   var $ = window[trueName];
-+   $.f = function() {
-+      return { 
-+         runFunction : [],
-+         init : function(target) {
-+            var theScripts = document.getElementsByTagName('SCRIPT');
-+            for (var i = 0; i < theScripts.length; i++) {
-+               if (theScripts[i].src.match(target)) {
-+                  $.a = {};
-+                  if (theScripts[i].innerHTML) {
-+                     $.a = $.f.parseJson(theScripts[i].innerHTML);
-+                  }
-+                  if ($.a.err) {
-+                     alert('bad json!');
-+                  }
-+                  $.f.loadDefaults();
-+                  $.f.buildStructure();
-+                  $.f.buildPresentation();
-+                  theScripts[i].parentNode.insertBefore($.s, theScripts[i]);
-+                  theScripts[i].parentNode.removeChild(theScripts[i]);
-+                  break;
-+               }
-+            }         
-+         },
-+         parseJson : function(json) {
-+            this.parseJson.data = json;
-+            if ( typeof json !== 'string') {
-+               return {"err":"trying to parse a non-string JSON object"};
-+            }
-+            try {
-+               var f = Function(['var document,top,self,window,parent,Number,Date,Object,Function,',
-+                  'Array,String,Math,RegExp,Image,ActiveXObject;',
-+                  'return (' , json.replace(/<\!--.+-->/gim,'').replace(/\bfunction\b/g,'function&shy;') , ');'].join(''));
-+               return f();
-+            } catch (e) {
-+               return {"err":"trouble parsing JSON object"};
-+            }
-+         },
-+         loadDefaults : function() {
-+            $.d = { 
-+               "user":"7000",
-+               "headerText" : "",
-+               "height" : 350,
-+               "width" : 300,
-+               "background" : "#193441",
-+               "border" : "1px solid black",
-+               "userFontSize" : "inherit",
-+               "userColor" : "inherit",
-+               "headerBackground" : "transparent", 
-+               "headerColor" : "white",
-+               "evenBackground" : "#fff",
-+               "oddBackground" : "#eee",
-+               "thumbnailBorder" : "1px solid black",
-+               "thumbnailSize" : 24,
-+               "padding" : 3,
-+               "server" : "identi.ca"
-+            };
-+            for (var k in $.d) { if ($.a[k] === undefined) { $.a[k] = $.d[k]; } }
-+         },
-+          buildPresentation : function () {
-+            var ns = document.createElement('style');
-+            document.getElementsByTagName('head')[0].appendChild(ns);
-+            if (!window.createPopup) {
-+               ns.appendChild(document.createTextNode(''));
-+               ns.setAttribute("type", "text/css");
-+            }
-+            var s = document.styleSheets[document.styleSheets.length - 1];
-+            var rules = {
-+               "" : "{zoom:1;margin:0;padding:0;width:" + $.a.width + "px;background:" + $.a.background + ";border:" + $.a.border + ";font:13px/1.2em tahoma, veranda, arial, helvetica, clean, sans-serif;*font-size:small;*font:x-small;}",
-+               "a" : "{cursor:pointer;text-decoration:none;}",
-+               "a:hover" : "{text-decoration:underline;}",
-+               "cite" : "{font-weight:bold;margin:0 0 0 4px;padding:0;display:block;font-style:normal;line-height:" + ($.a.thumbnailSize/2) + "px;}",
-+               "cite a" : "{color:#C15D42;}",
-+               "date":"{font-size:87%;margin:0 0 0 4px;padding:0;display:block;font-style:normal;line-height:" + ($.a.thumbnailSize/2) + "px;}",
-+               "date:after" : "{clear:both; content:\".\"; display:block; height:0; visibility:hidden; }",
-+               "date a" : "{color:#676;}",
-+               "h3" : "{margin:0;padding:" + $.a.padding + "px;font-weight:bold;background:" + $.a.headerBackground + " url('http://" + $.a.server + "/favicon.ico') " + $.a.padding + "px 50% no-repeat;text-indent:" + ($.a.padding + 16) + "px;}",
-+               "h3.loading" : "{background-image:url('http://l.yimg.com/us.yimg.com/i/us/my/mw/anim_loading_sm.gif');}",
-+               "h3 a" : "{font-size:92%; color:" + $.a.headerColor + ";}",
-+               "h4" : "{font-weight:normal; background:" + $.a.headerBackground + ";text-align:right;margin:0;padding:" + $.a.padding + "px;}",
-+               "h4 a" : "{font-size:92%; color:" + $.a.headerColor + ";}",
-+               "img":"{float:left; height:" + $.a.thumbnailSize + "px;width:" + $.a.thumbnailSize + "px;border:" + $.a.thumbnailBorder + ";margin-right:" + $.a.padding + "px;}",
-+               "p" : "{margin:0; padding:0;width:" + ($.a.width - 22) + "px;overflow:hidden;font-size:87%;}",
-+               "p a" : "{color:#C15D42;}",
-+               "ul":"{margin:0; padding:0; height:" + $.a.height + "px;width:" + $.a.width + "px;overflow:auto;}",
-+               "ul li":"{background:" + $.a.evenBackground + ";margin:0;padding:" + $.a.padding + "px;list-style:none;width:" + ($.a.width - 22) + "px;overflow:hidden;border-bottom:1px solid #D8E2D7;}",
-+               "ul li:hover":"{background:#f3f8ea;}"
-+            };
-+            var ieRules = "";
-+            // brute-force each and every style rule here to !important
-+            // sometimes you have to take off and nuke the site from orbit; it's the only way to be sure
-+            for (var z in rules) {
-+               var selector = '.' + trueName + ' ' + z;
-+               var rule = rules[z];
-+               if (typeof rule === 'string') {
-+                  var important = rule.replace(/;/gi, '!important;');
-+                  if (!window.createPopup) {
-+                     var theRule = document.createTextNode(selector + important);
-+                     ns.appendChild(theRule);
-+                  } else {
-+                     ieRules += selector + important;
-+                  }
-+               }
-+            }
-+            if (window.createPopup) { s.cssText = ieRules; }
-+         },
-+         buildStructure : function() {
-+            $.s = document.createElement('DIV');
-+            $.s.className = trueName;         
-+            $.s.h = document.createElement('H3');
-+            $.s.h.a = document.createElement('A');
-+            $.s.h.a.target = '_laconica';
-+            $.s.h.appendChild($.s.h.a);
-+            $.s.appendChild($.s.h);
-+            $.s.r = document.createElement('UL');
-+            $.s.appendChild($.s.r);
-+            $.s.f = document.createElement('H4');
-+            var a = document.createElement('A');
-+            a.innerHTML = 'get this';
-+            a.target = '_blank';
-+            a.href = 'http://kentbrewster.com/identica-badge';
-+            $.s.f.appendChild(a);
-+            $.s.appendChild($.s.f);
-+            $.f.getUser();
-+         },
-+         getUser : function() {
-+            if (!$.f.runFunction) { $.f.runFunction = []; }
-+            var n = $.f.runFunction.length;
-+            var id = trueName + '.f.runFunction[' + n + ']';
-+            $.f.runFunction[n] = function(r) {
-+               delete($.f.runFunction[n]);
-+               var a = document.createElement('A');
-+               a.rel = $.a.user;
-+               a.rev = r.name; 
-+               a.id = r.screen_name;
-+               $.f.removeScript(id);
-+               $.f.changeUserTo(a);
-+            };
-+            var url = 'http://' + $.a.server + '/api/users/show/' + $.a.user + '.json?callback=' + id;
-+            $.f.runScript(url, id);
-+         },
-+         changeUserTo : function(el) {
-+            $.a.user = el.rel;
-+            $.s.h.a.innerHTML = el.rev + $.a.headerText;
-+            $.s.h.a.href = 'http://' + $.a.server + '/' + el.id;
-+            $.f.runSearch(); 
-+         },
-+         runSearch : function() {
-+            $.s.h.className = 'loading';
-+            $.s.r.innerHTML = '';
-+            if (!$.f.runFunction) { $.f.runFunction = []; }
-+            var n = $.f.runFunction.length;
-+            var id = trueName + '.f.runFunction[' + n + ']';
-+            $.f.runFunction[n] = function(r) {
-+               delete($.f.runFunction[n]);
-+               $.f.removeScript(id);
-+               $.f.renderResult(r); 
-+            };
-+            var url = 'http://' + $.a.server + '/api/statuses/friends/' + $.a.user + '.json?callback=' + id;
-+            $.f.runScript(url, id);
-+         },
-+         renderResult: function(r) { 
-+            for (var i = 0; i < r.length; i++) {
-+               if (!r[i].status) {
-+                  r.splice(i, 1);
-+               } else {
-+                  r[i].status_id = parseInt(r[i].status.id);
-+               }
-+            }
-+            r = $.f.sortArray(r, "status_id", true);
-+            $.s.h.className = '';
-+            for (var i = 0; i < r.length; i++) {
-+               var li = document.createElement('LI');
-+               var icon = document.createElement('A');
-+               if (r[i] && r[i].url) {
-+                  icon.href = r[i].url;
-+                  icon.target = '_laconica'; 
-+                  icon.title = 'Visit ' + r[i].screen_name + ' at ' + r[i].url;
-+               } else {
-+                  icon.href = 'http://' + $.a.server + '/' + r[i].screen_name;
-+                  icon.target = '_laconica'; 
-+                  icon.title = 'Visit ' + r[i].screen_name + ' at http://' + $.a.server + '/' + r[i].screen_name;
-+               }
-+
-+               var img = document.createElement('IMG');
-+               img.src = r[i].profile_image_url;
-+               icon.appendChild(img);
-+               li.appendChild(icon); 
-+               
-+               var user = document.createElement('CITE');
-+               var a = document.createElement('A');
-+               a.rel = r[i].id;
-+               a.rev = r[i].name;
-+               a.id = r[i].screen_name;
-+               a.innerHTML = r[i].name; 
-+               a.href = 'http://' + $.a.server + '/' + r[i].screen_name;
-+               a.onclick = function() {
-+                  $.f.changeUserTo(this);
-+                  return false;
-+               };
-+               user.appendChild(a);
-+               li.appendChild(user);
-+               var updated = document.createElement('DATE');
-+               if (r[i].status && r[i].status.created_at) {
-+                  var date_link = document.createElement('A');
-+                  date_link.innerHTML = r[i].status.created_at.split(/\+/)[0];
-+                  date_link.href = 'http://' + $.a.server + '/notice/' + r[i].status.id;
-+                  date_link.target = '_laconica';
-+                  updated.appendChild(date_link);
-+                  if (r[i].status.in_reply_to_status_id) {
-+                     updated.appendChild(document.createTextNode(' in reply to '));
-+                     var in_reply_to = document.createElement('A');
-+                     in_reply_to.innerHTML = r[i].status.in_reply_to_status_id;
-+                     in_reply_to.href = 'http://' + $.a.server + '/notice/' + r[i].status.in_reply_to_status_id;
-+                     in_reply_to.target = '_laconica';
-+                     updated.appendChild(in_reply_to);
-+                  }
-+               } else {
-+                  updated.innerHTML = 'has not updated yet';
-+               }
-+               li.appendChild(updated);
-+               var p = document.createElement('P');
-+               if (r[i].status && r[i].status.text) {
-+                  var raw = r[i].status.text;
-+                  var cooked = raw;
-+                  cooked = cooked.replace(/http:\/\/([^ ]+)/g, "<a href=\"http://$1\" target=\"_laconica\">http://$1</a>");
-+                  cooked = cooked.replace(/@([\w*]+)/g, '@<a href="http://' + $.a.server + '/$1" target=\"_laconica\">$1</a>');
-+                  cooked = cooked.replace(/#([\w*]+)/g, '#<a href="http://' + $.a.server + '/tag/$1" target="_laconica">$1</a>');
-+                  p.innerHTML = cooked;
-+               }
-+               li.appendChild(p);
-+               var a = p.getElementsByTagName('A');
-+               for (var j = 0; j < a.length; j++) {
-+                  if (a[j].className == 'changeUserTo') {
-+                     a[j].className = '';
-+                     a[j].href = 'http://' + $.a.server + '/' + a[j].innerHTML;
-+                     a[j].rel = a[j].innerHTML;
-+                     a[j].onclick = function() { 
-+                        $.f.changeUserTo(this); 
-+                        return false;
-+                     } 
-+                  }
-+               }
-+               $.s.r.appendChild(li);
-+            }         
-+         },
-+         sortArray : function(r, k, x) {
-+            if (window.createPopup) { 
-+               return r; 
-+            }
-+            function s(a, b) {
-+               if (x === true) {
-+                   return b[k] - a[k];
-+               } else {
-+                   return a[k] - b[k];
-+               }
-+            }
-+            r = r.sort(s);
-+            return r;
-+         },         
-+         runScript : function(url, id) {
-+            var s = document.createElement('script');
-+            s.id = id;
-+            s.type ='text/javascript';
-+            s.src = url;
-+            document.getElementsByTagName('body')[0].appendChild(s);
-+         },
-+         removeScript : function(id) {
-+            if (document.getElementById(id)) {
-+               var s = document.getElementById(id);
-+               s.parentNode.removeChild(s);
-+            }
-+         }         
-+      };
-+   }();
-+//   var thisScript = /^https?:\/\/[^\/]*r8ar.com\/identica-badge.js$/;
-+   var thisScript = /identica-badge.js$/;
-+   if(typeof window.addEventListener !== 'undefined') {
-+      window.addEventListener('load', function() { $.f.init(thisScript); }, false);
-+   } else if(typeof window.attachEvent !== 'undefined') {
-+      window.attachEvent('onload', function() { $.f.init(thisScript); });
-+   }
-+} )();
-+
+hunk ./lib/mail.php 115
+-              $headers['Subject'] = sprintf(_('%1$s is now listening to your notices on %2$s.'), $other->getBestName(),
++              $headers['Subject'] = sprintf(_('%1$s is now listening to your notices on %2$s.'),
++                                      $other->getBestName(),
+hunk ./lib/mail.php 120
+-                                                 'Faithfully yours,'."\n".'%4$s.'."\n"),
+-                                               $long_name,
+-                                               common_config('site', 'name'),
+-                                               $other->profileurl,
+-                                               common_config('site', 'name'));
+-
++                                                 '%4$s'.
++                           '%5$s'.
++                           '%6$s'.
++                                                 "\n".'Faithfully yours,'."\n".'%7$s.'."\n\n".
++                           "----\n".
++                           "Change your email address or notification options at %8$s"),
++                         $long_name,
++                         common_config('site', 'name'),
++                         $other->profileurl,
++                         ($other->location) ? sprintf(_("Location: %s\n"), $other->location) : '',
++                         ($other->homepage) ? sprintf(_("Homepage: %s\n"), $other->homepage) : '',
++                         ($other->bio) ? sprintf(_("Bio: %s\n\n"), $other->bio) : '',
++                         common_config('site', 'name'),
++                         common_local_url('emailsettings'));
index a7cbab8589665daa7343ce171d892e66d5947037..c90140d3c3a9128e23041a2cfdc8bd44ec7deaae 100644 (file)
@@ -112,16 +112,25 @@ function mail_subscribe_notify_profile($listenee, $other) {
                $recipients = $listenee->email;
                $headers['From'] = mail_notify_from();
                $headers['To'] = $name . ' <' . $listenee->email . '>';
-               $headers['Subject'] = sprintf(_('%1$s is now listening to your notices on %2$s.'), $other->getBestName(),
+               $headers['Subject'] = sprintf(_('%1$s is now listening to your notices on %2$s.'),
+                                      $other->getBestName(),
                                                                          common_config('site', 'name'));
                $body  = sprintf(_('%1$s is now listening to your notices on %2$s.'."\n\n".
                                                   "\t".'%3$s'."\n\n".
-                                                  'Faithfully yours,'."\n".'%4$s.'."\n"),
-                                                $long_name,
-                                                common_config('site', 'name'),
-                                                $other->profileurl,
-                                                common_config('site', 'name'));
-
+                                                  '%4$s'.
+                           '%5$s'.
+                           '%6$s'.
+                                                  "\n".'Faithfully yours,'."\n".'%7$s.'."\n\n".
+                           "----\n".
+                           "Change your email address or notification options at %8$s"),
+                         $long_name,
+                         common_config('site', 'name'),
+                         $other->profileurl,
+                         ($other->location) ? sprintf(_("Location: %s\n"), $other->location) : '',
+                         ($other->homepage) ? sprintf(_("Homepage: %s\n"), $other->homepage) : '',
+                         ($other->bio) ? sprintf(_("Bio: %s\n\n"), $other->bio) : '',
+                         common_config('site', 'name'),
+                         common_local_url('emailsettings'));
         // reset localization
         common_init_locale();
                mail_send($recipients, $headers, $body);