Michael Heilemann.
If you have Dunstan's Time Since installed, this plugin uses it for the title="" attributes on the comments and posts. (For WordPress 1.5) Author: Brian Meidell Author URI: http://meidell.dk/ Version 1.5: Now works without LOCK TABLE and CREATE TEMPORARY TABLE priviledges. Version 1.5.1: Can't remember what I did here Version 1.5.2: Fixed count select statement to not include spammy comments Version 1.5.3: Properly excludes track- and pingbacks Version 1.5.4: Excludes posts that are not published, even if they have comments Version 1.5.5: Fade old comments, fixed bug that wreaked havoc with Time Since Version 1.5.6: Bugfix from Jonas Rabbe (http://www.jonas.rabbe.com/) pertaining to timesince Version 1.5.7: Bugfix so old colors can be darker than new colors (stupid oversight), thanks to http://spiri.dk for spotting it. Bugfix where single digit hex would cause invalid colors, thanks to http://www.wereldkeuken.be/ for the fix. Version 1.5.8: Updated to work with WordPress 2.1 alpha by M. Heilemann. */ function blc_latest_comments($num_posts = 5, $num_comments = 6, $hide_pingbacks_and_trackbacks = true, $prefix = "
  • ", $postfix = "
  • ", $fade_old = true, $range_in_days = 10, $new_col = "#444444", $old_col = "#cccccc") { global $wpdb; function clamp($min, $max, $val) { return max($min,min($max,$val)); } $usetimesince = function_exists('time_since'); // Work nicely with Dunstan's Time Since plugin (adapted by Michael Heilemann) // This is compensating for the lack of subqueries in mysql 3.x // The approach used in previous versions needed the user to // have database lock and create tmp table priviledges. // This uses more queries and manual DISTINCT code, but it works with just select privs. if(!$hide_pingbacks_and_trackbacks) $ping = ""; else $ping = "AND comment_type<>'pingback' AND comment_type<>'trackback'"; $posts = $wpdb->get_results("SELECT comment_post_ID, post_title FROM ($wpdb->comments LEFT JOIN $wpdb->posts ON (comment_post_ID = ID)) WHERE comment_approved = '1' AND $wpdb->posts.post_status='publish' $ping ORDER BY comment_date DESC;"); $seen = array(); $num = 0; if($fade_old) { $max_time = $range_in_days * 24 * 60 * 60 ; $r_new = hexdec(substr($new_col, 1, 2)); $r_old = hexdec(substr($old_col, 1, 2)); //$r_min = min($min, $max); //$r_max = max($min, $max); $r_range = ($r_old-$r_new); $g_new = hexdec(substr($new_col, 3, 2)); $g_old = hexdec(substr($old_col, 3, 2)); //$g_min = min($min, $max); //$g_max = max($min, $max); $g_range = ($g_old-$g_new); $b_new = hexdec(substr($new_col, 5, 2)); $b_old = hexdec(substr($old_col, 5, 2)); //$b_min = min($min, $max); //$b_max = max($min, $max); $b_range = ($b_old-$b_new); } // print "ranges: $r_range, $g_range, $b_range
    "; // print "r: ".(0.5*$r_range+$r_new)."
    "; foreach($posts as $post) { // The following 5 lines is a manual DISTINCT and LIMIT, // since mysql 3.x doesn't allow you to control which way a DISTINCT // select merges multiple entries. if(array_key_exists($post->comment_post_ID, $seen)) continue; $seen[$post->comment_post_ID] = true; if($num++ > $num_posts) break; $commenters = $wpdb->get_results("SELECT *, UNIX_TIMESTAMP(comment_date) AS unixdate FROM $wpdb->comments WHERE comment_approved = '1' AND comment_post_ID = '".$post->comment_post_ID."' $ping ORDER BY comment_date DESC LIMIT $num_comments;"); $count = $wpdb->get_var("SELECT COUNT(comment_ID) AS c FROM $wpdb->comments WHERE comment_post_ID = $post->comment_post_ID AND comment_approved = '1' ".$ping); $i = 0; $link = get_permalink($post->comment_post_ID); if($usetimesince) $title = " title=\"Last comment was ".time_since($comment->unixdate)." ago\""; else $title = ""; echo $prefix."".stripslashes($post->post_title). "  ".$count."
    \n"; foreach($commenters as $commenter) { if($usetimesince) $title = " title=\"Posted ".time_since($commenter->unixdate)." ago\""; if($fade_old) { $diff = time() - $commenter->unixdate; $r = round($diff/$max_time*($r_range))+$r_new; $r = clamp(min($r_new, $r_old), max($r_new, $r_old), $r); $g = round($diff/$max_time*($g_range))+$g_new; $g = clamp(min($g_new, $g_old), max($g_new, $g_old), $g); $b = round($diff/$max_time*($b_range))+$b_new; $b = clamp(min($b_new, $b_old), max($b_new, $b_old), $b); $r_hex = str_pad(dechex($r), 2, '0', STR_PAD_LEFT); $g_hex = str_pad(dechex($g), 2, '0', STR_PAD_LEFT); $b_hex = str_pad(dechex($r), 2, '0', STR_PAD_LEFT); $colstr = " style=\"color: #".$r_hex.$g_hex.$b_hex.";\""; } if($i++ > 0) echo ", "; echo "comment_ID."\"$title>".stripslashes($commenter->comment_author).""; } if($count > $num_comments) echo " [...]"; echo "".$postfix."\n"; } } ?> @YEMblog Twitter Updates for 2010-06-30 | YEMblog
    • We’re up to two angles of I Am The Walrus videos http://bit.ly/99m4Ri #phish #
    • Great work by @dogoneblog Tweeting For Us Yesterday. Don’t forget to make http://dogoneblog.wordpress.com/ a regular stop #phish #
    • Quite a show in Hartford 10 Years Ago. FLACs – http://j.mp/9kQ4wo MP3s – http://j.mp/dmj046 First set is ridic, plenty o improv #phish #
    • Video: Phish Debuts a Cover of I Am The Walrus – Chris Kuroda Steals The Show http://bit.ly/99m4Ri #phish #
    • Tonight was great. No heavy jams, but all around a very played show. Phish continues to amaze… #phish #
    • End show. Thanks for following everyone. And thanks to Scotty B. For the privilege. This has been Dog Gone Blog…goodnight all #
    • Trey the jedi #phish #
    • Few bands command this kind of energy. #phish #
    • Trey leaning into the crowd, jam is erupting #phish #
    • Screeching loop on the boomerang #phish #
    • E: first tube #phish #
    • //End set #phish #
    • Golgi #phish #
    • Mike emerges as the hero of the second set, once again. #phish #
    • Total patience, allowing the jam to build #phish #
    • How far we’ve come since hampton…#phish #
    • Glowsticks emerge, kuroda turns on the day glos #phish #
    • Hood! #phish #
    • This solo has more to it than many would think #phish #
    • Minimal glowsticks considering @glowstickwars is here. #phish #
    • Limb by limb #phish #
    • Band fully locked in. Weekapaug is once again a highlight. Departing from the frame…#phish #
    • Page and mike riffing of each other #phish #
    • Mike bombs #phish #
    • Weekapaug groove #phish #
    • Screeching psychedelia #phish #
    • Ed. Note: 70 Volt Parade Covered I Am The Walrus 18 Times in 2005 http://bit.ly/cKGnDU #skeeto #
    • Light chaos #phish #
    • An absolutely epic moment #phish #
    • I am the walrus #phish #
    • Day glo lights… #phish #
    • Jam depart from the song, ambiance emerges..#phish #
    • Mike adds a waterfall of sound, taking the jam higher #phish #
    • SIMPLE!!! #phish #
    • Staying within the boundaries of the song, but pushing on with a heated jam. #
    • Meaning the groove…not the cover #phish #
    • And the heat goes on…#phish #
    • Mike’s songphish #
    • Kuroda shining at every peak #phish #
    • Possum #phish #
    • Reminder: @dogoneblog on tweets tonight http://dogoneblog.wordpress.com/ – a great blog with plenty of #phish analysis #
    • The sun has finally set. The light show begins…#phish #
    • Ocelot Car Service = “Don’t Be The Only Brah Left on the Lot” #phish #
    • Tonight’s Ocelot Car Service First Set MVP = Jon Fishman #phish #
    • End Set #phish #
    • SET 1: Connection, DWDisease, Sample, Ocelot, Reba, Horn, Funky Bitch, Undermind, Curtis Loew, David Bowie http://bit.ly/cwhNxM #phish #
    • /End set #phish #
    • Lots of energy in this jam. Trey whaling over the groove. Multiple themes #phish #
    • Bowie #phish #
    • Curtis lowe #phish #
    • This song echoes the phish style at the moment. Undecided, undefined. #
    • Page leading the jam. Dare to guess the time signature? #phish #
    • Undermind #phish #
    • Remember when this was a rarity? Fuck ya phish #phish #
    • Funky bitch #phish #
    • Horn #phish #
    • Band totally locked in. As coltrane would say, “sheets of sound” #phish #
    • Few songs grace a sunset better than reba #phish #
    • Reba #phish #
    • Trey showing patience in this jam #phish #
    • Banter>ocelot #phish #
    • I: The Connection, Down With Disease, Sample In A Jar #phish #
    • Reaching ‘that place’ early tonight. Energy building….#phish #
    • Set 1: The Connection, Down With Disease #phish #
    • Lots of talk before the opener. #phish #
    • The connection #phish #
    • DGB is on lot, the scene is very laxed where we are. Lots of fans, minimal wooks. A very good sign. #
    • @dogoneblog, testing for tonight. Get ready for a great show! #

    Post a Comment

    You must be logged in to post a comment.