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-07-03 | YEMblog
    • That ending was sick. Curfew’d #
    • #Peaceloveandpage #
    • encore: a day in the life #
    • A Day In the life #
    • Set #
    • Get Back as part of vocal jam #
    • Proud Mary as part of Vocal Jam #
    • Vocal Jam #
    • This jamming is sweet. I’ve really loved all the YEMs I’ve gotten this tour. #
    • This set’s MVP is Page #
    • Oooooooooohhhhhboy #
    • You Enjoy Myself #
    • Last Fuck Your Face 04/29/1987 [via @rowj] #phish #
    • 2001 #
    • I want to hear it every night #
    • Fuck your face imacustienoob #
    • Sick funkyasfunk new mike song #
    • Phish in Charlotte Set 2: Drowned, 46 Days, Twenty Years Later, Lizards, Carini http://bit.ly/b0nYt4 #phish #
    • Dirtydirty I love it #
    • Rock.The.Fuck.On. #
    • Carini #
    • Gooooo page #
    • Wilsonwilsonwilson #
    • Lizards!!! #
    • I love these east coast sheds #
    • Meh #
    • 20 years later #
    • Nice little vocal jam thing at the end of 46 days! #
    • I think this is the most underwhelming show of the 7 so far of this tour. #notahater #
    • 46 Days #
    • Nice jamming here #
    • Page loves us #
    • Finally found the perfect dancing spot #
    • Drowned #
    • Lights #
    • Cars, Trucks and Buses Lane, Because Cars Only Is For Fucking Suckers #phish #
    • Tonight’s NJ Turnpike Cars, Trucks and Buses Lane First Set MVP = Mike Gordon #phish #
    • Set #
    • Love those high notes #
    • Cdt #
    • 5th of tour? I was informed… #
    • Sparkle #
    • http://yfrog.com/0nn8amj #
    • The maybesomaybenot part has ethereal qualities,as usual #
    • Stash #
    • I wanna wanna kiss your oooh #
    • Mexican cousin #
    • Wedge!!! #
    • Pretty standard gbott jam #
    • Charlotte Set 1: Buried Alive > AC/DC Bag, Vultures, Wolfman’s Brother, Back On The Train http://bit.ly/b0nYt4 #phish #
    • Gbott #
    • Trey loves to read those request signs. #
    • Test #
    • Wolfmans #phish #
    • ed: We’re having some technical difficulties, bear with us as we set Gretchen’s phone up #
    • Sorry!!! #
    • Vultures #
    • Last Vultures: Albany 11/28/2009 – 25 Shows Ago #phish #
    • Set 1: Buried Alive > AC/DC Bag, Vultures #phish #
    • Set 1: Buried Alive > AC/DC Bag #phish #
    • Lights #
    • @assfaceinurface email Scotty B feedback@yemblog.com where in bmore? in reply to assfaceinurface #
    • Section 2, row k, seat 15. In front of mg. Normally a page side rage side moat dancer… #
    • @ryannichols7 are you up front with your sign? in reply to ryannichols7 #
    • Me and John Warner http://yfrog.com/1qi4yaj #
    • I dig this shirt http://yfrog.com/b8spvj #
    • Going up to shakedown to get a preshow meal. Not hungry for dinner but want to avoid buying food in the venue #
    • I wanna meet @phanart #
    • I love the sounds that the
      Twitter app makes. #nothingtodowithphish #ilovemyiphone #
    • You know…I really should have gotten that fanny pack from the American Apparel store before I left Baltimore. #
    • Sound check was full of songs I don’t know, except for a boogie on remix. Burn that Bridge was possibly the last one. #
    • @mbvisor there’s a blue flag with a boat behind us. We’re parked up along the trees/road in reply to mbvisor #
    • I’m in Lot E #
    • Anyone want to have a lot meet up? #
    • My phone is never going charge if I keep this up. At least we’re gonna hear the soundcheck from across the street. #
    • Hi again, this is Gretchen @charmcitymama guest tweeting for @yemblog tonight. #Phish #charlotte #littlefeat #
    • @tmwsiy I’ll take it in reply to tmwsiy #
    • Lots opened @ 3:30pm. Sitting in movie theater parking lot charging phone and obsessing about my new favorite little feat cover band #
    • Time to learn the words and practice your moves. Now I’m obsessed http://www.youtube.com/watch?v=Ns9jGWiF8d0&feature=youtube_gdata #
    • Look for her in the lot! “@ilovebeer32: @YEMblog how can I get isardora poster??” #shakedown #
    • I <3 the phish #
    • @ryannichols7 I’m standing next to you. We’re gonna do a 4 for 4 little feat run here in reply to ryannichols7 #
    • Check out Isadora and her ATL print http://yfrog.com/mslbhj #
    • It’s HOT (again)! We had a break from the heat for a few days. Nothing can be as bad as the humidity of
      Maryland and New Jersey last week. #
    • Going to fedex office in concord nc to pick up tix overnighted from rhode island #
    • @YEMblog I mean CHARLOTTE! in reply to YEMblog #
    • Hitting traffic and listening to Gangstarr on the way to Raleigh #phish #innohurry #
    • Skin It Back would be so rad! Apparently 3.0 phanners need some schoolin’ in southern/classic rock department @ryannichols7 #arewethatold #
    • The llama sign from last night was most excellent. Does anyone have a pic of it? Check out this one that didn’t (cont) http://tl.gd/29048i #
    • Totally. “@ryannichols7: so tonight: charloTTE’d #phish#
    • ~50 miles out. Had a spiritual awakening in WS one time with WSP. http://yfrog.com/3dd9sj #

    Post a Comment

    You must be logged in to post a comment.