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-10-21 | YEMblog
    • Guest Tweeters: Friday = @ericwyman Saturday = @CGlush Sunday = S. Marks Manchester = DaveO AC1 = @adamedelman AC2 = @jraras AC3 = ScottyB #
    • Thanks to Scott Marks for tweeting about two tough to describe #phish sets tonight! #
    • Big thanks to scottyb for letting me be the guest tweeter. I'll be back on sunday #
    • Phish Blows The Roof off The Memorial Auditorium in Utica: Setlist and Recap http://j.mp/bRChGz #phish #
    • End show #
    • Good times bad times #
    • End set #
    • Return to Melt finished the song #
    • Set 2: Drowned -> Sand > Theme, Axilla, Birds, Tela, Split > Have Mercy > Piper -> Melt > Slave http://j.mp/bRChGz #phish #
    • > slave #
    • Wow. #
    • -> melt #
    • Felt like it for a second #
    • Ambience gone… birds jam? #
    • This went type II quickly #
    • > piper #
    • "Utica Jam" #
    • Nice groove #
    • Melt unfinished #
    • Set 2: Drowned -> Sand > Theme, Axilla, Birds, Tela, Split > Have Mercy http://j.mp/bRChGz #phish #
    • -> have mercy!!!! #
    • Melodic. Type II #
    • Melt #
    • Set 2: Drowned -> Sand > Theme, Axilla, Birds, Tela http://j.mp/bRChGz #phish #
    • Tela #
    • > birds #
    • Axilla I #
    • Set 2: Drowned -> Sand > Theme, Axilla http://j.mp/bRChGz #phish #
    • > theme #
    • Back in the jam #
    • Back home #
    • Some great jamming from trey here. A bunch of mini riffs #
    • Nice little bass fill #
    • Set 2: Drowned -> Sand http://j.mp/bRChGz #phish #
    • -> sand #
    • Dark and bass driven now #
    • Melodic #
    • Drowned #
    • Lights #
    • End set. #
    • Correction. Guyute teased instead of marco esquandolas lyric #
    • Guyute teased by trey after rye rye rocco #
    • And back. Wow #
    • Dark! #
    • Veering drasticly off course #
    • Phish hasn't played a first set this good in a loooong time. believe the hype and go listen for yourself #
    • Guyute teases from trey in antelope intro #
    • Should be > antelope #
    • My Soul, Stealing Time, Vultures, Wolfman's > Cities, Guyute, Bowie*, Wilson > McGrupp -> Saw It Again -> Antelope http://j.mp/bRChGz #phish #
    • -> antelope #
    • Guyute teases from trey at outro with saw it again spoken #
    • - > saw it again! #
    • Series of off notes from trey. They WERE nailing it #
    • They're nailing mcgrupp #
    • Utica S1: My Soul, Stealing Time, Vultures, Wolfman's > Cities, Guyute, Bowie*, Wilson > McGrupp http://j.mp/bRChGz #phish #
    • > mcgrupp. no blat boom #
    • Extended guyute tease from trey… I must inquire guyute? #
    • Guyute tease by trey in wilson #
    • Setlist recap: guyute, bowie (with lots of show notes), wilson #
    • Wilson #
    • Second wilson jam. Back to bowie. #
    • Phish is raising the bar with each show this tour. Awesome #
    • Wilson jam with guyute lyrics. Back to bowie. Crowd was chanting wilson #
    • Guyute teased again by trey #
    • Trey adding something to the ub40 lyric. Can't make it out #
    • End intro. Guyute teased through almost all of it #
    • Utica S1: My Soul, Stealing Time, Vultures, Wolfman's > Cities, Guyute, Bowie http://j.mp/bRChGz #phish #
    • Bowie. With guyute teases in intro #
    • Crowd going nuts during build #
    • > guyute #
    • Possible lyric change from "dry ice" lyric of dry ice factory? #
    • Utica S1: My Soul, Stealing Time, Vultures, Wolfman's > Cities http://j.mp/bRChGz #phish #
    • -> cities. maybe a > #
    • Broken down again. FUNK! #
    • Funky. Streets of cairo tease from trey #
    • Nice breakdown #
    • Wolfmans #
    • Utica S1: My Soul, Stealing Time, Vultures http://j.mp/bRChGz #phish #
    • Vultures #
    • Stealing time #
    • My soul #
    • Lights #
    • Energy feels a lot stronger than last night in crowd preshow #
    • Floor filling in nicely #
    • These #
    • In the crowd: 2 guy forget signs, "…wait," multi part manteca, can you see the real me?, and dog log signs. would be happy with any of … #
    • Saw oysterhead here in 2001 and trey in 05 (or 06?) never thought i'd be back here for phish. 3 rows off the floor page side #
    • Great shakedown…. Much better than augusta #
    • At the hotel. Apparently tickets are avail at the box office. Poster has phish written on some buildings #
    • A number of fans have been added to the Utica list http://twitter.com/#!/YEMblog/tweeting-from-utica #
    • Last night's guest tweeter, @ericwyman , wrote up his thoughts on Augusta http://bit.ly/ccm8PQ #phish #
    • List of twibers tweeting from Utica http://twitter.com/#!/list/YEMblog/tweeting-from-utica Let us know if you're tweeting from Providence #
    • Caption Contest: Trey Meets Some Fans Before a TAB Show http://bit.ly/a7x1Db #phish #
    • A cool look at Phish's current rotation http://www.thebarnpresents.com/InfoGraphics/Setlists/Phish/ Gives an idea of what to expect in Utica #
    • Today on YEMblog: UMASS Police Prepare For Phish, Local News Covers Augusta Show, Charleston Vids and more http://yemblog.com #phish #
    • Video: Exceptional Playlist of Charleston Videos, Great View of Kuroda's Lights http://bit.ly/cdwktP #phish #
    • See you tonight! #
    • Testing… 6 hours from utica – amazing show last night. gin, mikes, reba all highlights #
    • Scott Marks of the @phishnet crew will be on guest tweets tonight. Thanks again to @ericwyman for letting us all share in last night's show #

    Post a Comment

    You must be logged in to post a comment.