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-08-15 | YEMblog
    • programming note: justin of @ohkeepahblog on tweets tonight #phish #
    • stop yemblog #
    • mj's rock with you = post show music #
    • end show #phish #
    • apparently the audience likes the encore choice. everyone swaying hard in unison with lots of fist pumps #
    • #phish set II:sloth, dwd>what's the use, mule, mikes>dirt>sally>paug, bug e: Quinn the eskimo
      http://bit.ly/9va69J #
    • for jerry ;) #
    • encore: quinn the eskimo #phish #
    • end set #phish #
    • bug #phish #
    • rock version. all fast paced. just trey shredding #
    • #phish set II:sloth, dwd>what's the use, scent of mule, mikes>dirt>sally>paug
      http://bit.ly/9va69J #
    • weekapaug #phish #
    • vocal jam #phish #
    • trey likes one of the lines mike lays down and starts a solo by repeating it #
    • mike takes lead on funk jam #
    • sneakin sally #
    • #phish set II:sloth, dwd>what's the use, scent of mule, mikes>dirt
      http://bit.ly/9va69J #
    • into dirt #
    • short mike's #
    • mike and trey hook up on tasty descending lick #
    • sticking to script thus far aka trey wailing (not whaling) on the mike's jam chords #
    • mikes #phish #
    • trey struggles with final composed section before place of elegance but recovers nicely #
    • mule #phish #
    • really milking the outro for all its worth #
    • kuroda killin it. deep red hues like the stage is on fire #
    • i throw the perfunctory this is why i go see shows tweet at this moment #
    • #phish set II:sloth, dwd>what's the use
      http://bit.ly/9va69J #
    • great transition #
    • into wahts the use! #
    • page on synth #
    • boys settle in on a major based jam. pretty #
    • crowd goes nuts as interesting bit of improv hits peak #
    • mike kicks on new envelope filter. bassballs #
    • more of this please. permagroove style. trey adds peppy lick over top #
    • talking heads feel to this improv #
    • page milks clav fish bashes rock beat #
    • little funk breakdown #
    • trey plays a quick choppy rhythm #
    • back to more typical disease fireworks #
    • mike slows things down a bit as we start to get off the standard disease structure #
    • trey burning up the fretboard #
    • trey repeating quick hammers on over and over. pace = very quick #
    • all hands in air waving like they just dont care #
    • disease #phish #
    • sloth in answer to a sloth sign down low #
    • slotg #phish #
    • lights #
    • highlights = fuck your face antlope and reba #
    • end set #phish #
    • new jersey looks after their own #
    • powerful finish. "marco benevento" alternate lyric by trey! go marco #
    • all four listening to each other and feeding off each other. dissonance mixed with pretty melodies #
    • kuroda employs purple and yellows as tempo quickens #
    • using this intro to take it all in. what a massive place. everyone seems way into it everywhere you look #
    • #phish 8-14 set I: Tube,oh kee pah>suzy,bitch,Reba,fuck your face,alaska,bott,taste,circus,lawnboy,sparkle,gumbo, antelope ://bit.ly/9va69J #
    • antelope #phish #
    • weather is quite soupy. fitting tune #
    • #phish 8-14 set I: Tube,oh kee pah>suzy,bitch,Reba,fuck your face,alaska,bott,taste,circus,lawnboy,sparkle,gumbo://bit.ly/9va69J #
    • gumbo #phish #
    • sparkle #phish #
    • love @originalwyllys 's thoughts on cuss word song titles #
    • lawn boy #phish #
    • tender as fuck #
    • #phish 8-14 set I: Tube,oh kee pah>suzy,bitch,Reba,fuck your face,alaska,bott,taste,when the circus http://bit.ly/9va69J #
    • circus #phish #
    • back to the practice room w that one #
    • solid solo with some nice peaks followed by a few clams in outro #
    • trey a little lost in page's solo #
    • taste #phish #
    • trey really ripping into it with lots of inventive little blues licks #
    • straight forward rockin' bott solo #
    • #phish 8-14 set I: Tube,oh kee pah>suzy,bitch,Reba,fuck your face,alaska,gbott http://bit.ly/9va69J #
    • back on the train #phish #
    • #phish 8-14 set I: Tube,oh kee pah>suzy,bitch,Reba,fuck your face http://bit.ly/9va69J #
    • alaska #phish #
    • so tight and nasty so far. #
    • thhats what im talkin about. place goes nuts w first lyric #
    • fuck your face #phish #
    • trey drops the hammer with a few quickfire riffs of beauty #
    • mike and trey lock in and build with tnesion and release goodness. god bless reba jam #
    • like the sweetest of all choocolates here comes the reba jam #phish #
    • reba #phish #
    • mike throws an extra got nowhere to go in there #
    • funky bitch #phish #
    • arms pumping in the air everywhere u look #
    • aggressive slap work by mike #
    • page on moog for breakdown #
    • #phish set I: Tube,oh kee pah>suzy http://bit.ly/9va69J #
    • > suzy g #phish #
    • oh kee pah #phish #
    • smooth transition into zz top part of tube #
    • tube #phish #technical difficulties #
    • butterflies reaching fevered pitch. must be close to go time #
    • photographers take spots in pit #
    • people streaming in at a faster clip #
    • sun starts to fade as pavilion very slowly fills in #
    • i forgot how steep this venue is #sweptaway #phprediction #
    • List of those tweeting from Alpine http://twitter.com/YEMblog/tweeting-from-alpine #phish #
    • @MrChrisP That's a toughie, but I'd go night two. At least during Night One you'll be comforted by knowing you have a show the next night #
    • hasnt been any sound coming from the stage for about five minutes. gonna head back to lodge. fun doglog! please release it @phish #
    • mike toying with his new envelope filter #
    • band yells wheres my dog gone and brings log to a finish #
    • trey letting loose with some bluesy riffs #
    • its like the 46 days version of dog log. rock feel #
    • its a variation of dog log! #
    • rolled into a good spot to hear soundcheck. they are jamming a basic rock chord progression right now #
    • favorite alpine show that is #
    • driving to alpine thinking of past shows in the venue. 8/1/98 is among my favorite two set shows. wish i saw that one. what's your fav? #

    Post a Comment

    You must be logged in to post a comment.