collapse

* Simple Portal Archived Forum

This is an Archive Forum.

The content in this forum may be out-of-date or have been superseded by newer information, and links in forum pages to other sites may not work.
This forum contains archives for future reference.

Visit our thread at Simple Machines Forum for current support.

SMF 2.1 users: EhPortal is a ported version of Simple Portal specifically designed for the SMF 2.1 branch.
Please visit web-develop.ca to download EhPortal and for its support.

* User Info

 
 
Welcome, Guest. Please login or register.

* Who's Online

  • Dot Guests: 407
  • Dot Hidden: 0
  • Dot Users: 0

There aren't any users online.

* Shoutbox

Refresh History
  • Shoutbox is not for support!
  • {OCS}MasterSeal: Yup, Still adore SP
    April 21, 2019, 07:08:06 PM
  • {OCS}MasterSeal: STILL love SP :)
    November 24, 2018, 05:05:50 AM
  • ♦ Ninja ZX-10RR ♦: <3 aegersz
    September 13, 2018, 03:36:09 PM
  • aegersz: I STILL <3 LOVE SimplePortal
    September 13, 2018, 07:11:39 AM
  • aegersz: o LOVE you guys - Simple Portal rocks !
    May 09, 2018, 05:18:59 AM
  • Chen Zhen: our apologies for the site being down.. please read server issues topic
    March 22, 2018, 05:32:38 AM
  • {OCS}MasterSeal: LOL PLEASE forget I just posted that. I found the answer in my own dang post back in 2015. lol sorry!
    July 04, 2017, 10:47:55 PM
  • {OCS}MasterSeal: I know this SB isnt' for support, but I just have a general question. Who would I contact to find out where SP stores its block info? Is it DB driven or files? I searched the site but came up with nothing. probably my fault any insight is appreciated.
    July 04, 2017, 10:43:36 PM
  • ♦ Ninja ZX-10RR ♦: Excuse me but what does Simpleportal have to deal with that?
    February 05, 2017, 08:21:14 PM
  • WhiteEagle: of course IMHO that site appears to be dead :(
    February 04, 2017, 01:08:05 PM
  • WhiteEagle: If I can get that, then I'll use it for that site...
    February 04, 2017, 01:07:35 PM
  • WhiteEagle: decided to not use SMF for any projects, unless I can get a copy of the premium version of the fanfiction archive plugin
    February 04, 2017, 01:06:54 PM
  • expertdecisions: cloudflare
    January 28, 2017, 08:01:47 AM
  • aegersz: SM release 2.0.13 !
    January 12, 2017, 06:00:13 AM
  • raffo: Tks Emanuele, even if I didn't understand the fix :D
    November 07, 2016, 02:01:20 AM
  • emanuele: [link]
    November 01, 2016, 12:43:50 PM
  • emanuele: raffo: the English support board is a good place. ;)
    November 01, 2016, 12:43:38 PM
  • raffo: Where can I find the fix for the shoutbox?
    November 01, 2016, 05:06:09 AM
  • {OCS}MasterSeal: To the SP team, I make a point to come here and thank you as much as possible for your work.  so again, THANK YOU!
    October 28, 2016, 10:38:05 AM
  • emanuele: That's indeed funny, the limit is present only in the patch and not the full install.
    October 22, 2016, 06:14:58 PM

* Recent Posts

Adding Forums Button to Nav bar by jirapon
[August 01, 2019, 09:07:12 AM]


Re: Board Icons by ♦ Ninja ZX-10RR ♦
[July 30, 2019, 04:03:41 PM]


MOVED: Czech translation???? by ♦ Ninja ZX-10RR ♦
[July 30, 2019, 03:04:51 PM]


Board Icons by jirapon
[July 30, 2019, 07:28:44 AM]


Re: Thankyou Simpleportal, by ♦ Ninja ZX-10RR ♦
[July 29, 2019, 09:41:29 AM]

Blocks speak! Do you have an interest in getting more blocks - or even making your own? The Blocks Board is for you!

Author Topic: Block For Most Replies in X Hours  (Read 8157 times)

0 Members and 1 Guest are viewing this topic.

Offline stanyy

  • Semi Newbie
  • *
  • Posts: 17
  • SMF Version: 2.0.2
  • SP Version: 2.3.4
Block For Most Replies in X Hours
« on: July 21, 2013, 11:46:56 AM »
Very much like the TopTopics block, but instead of measuring total replies, it should only measure from last x hours.

My first thought was that this could be achieved by tweaking the toptopics block a little. I posted a topic in feature requests and Blue says this can be achieved with a custom block. If anyone can help, I would be grateful.
« Last Edit: July 31, 2013, 05:58:32 PM by stanyy »

Offline stanyy

  • Semi Newbie
  • *
  • Posts: 17
  • SMF Version: 2.0.2
  • SP Version: 2.3.4
Re: Block For Most Replies in X Hours
« Reply #1 on: August 01, 2013, 04:16:50 AM »
BUMP

Offline [SiNaN]

  • Mr. SimplePortal
  • Developer
  • *
  • Posts: 6782
  • SMF Version: 2.0.15
  • SP Version: 2.3.7
Re: Block For Most Replies in X Hours
« Reply #2 on: August 01, 2013, 06:14:45 AM »
Hope the following works for you. Use it in a Custom PHP block.

Code: [Select]
global $smcFunc, $scripturl, $txt;

$limit = 5;
$hours = 2;

$request = $smcFunc['db_query']('', '
SELECT id_topic, subject, COUNT(id_msg) AS posts
FROM {db_prefix}messages
WHERE poster_time > {int:start_time}
GROUP BY id_topic
ORDER BY posts DESC
LIMIT {int:limit}',
array(
'start_time' => forum_time(false, mktime(0, 0, 0, date("n"), date("j"), date("Y")) - (date("N") * 3600 * $hours)),
'limit' => $limit,
)
);
while ($row = $smcFunc['db_fetch_assoc']($request))
{
$row['subject'] = str_replace('Re: ', '', $row['subject']);

$topics[] = array(
'id' => $row['id_topic'],
'subject' => $row['subject'],
'href' => $scripturl . '?topic=' . $row['id_topic'] . '.0',
'link' => '<a href="' . $scripturl . '?topic=' . $row['id_topic'] . '.0">' . $row['subject'] . '</a>',
'replies' => comma_format($row['posts']),
);
}
$smcFunc['db_free_result']($request);

if (empty($topics))
{
echo $txt['error_sp_no_topics_found'];
return;
}
else
$topics[count($topics) - 1]['is_last'] = true;

echo '
<ul class="sp_list">';

foreach ($topics as $topic)
echo '
<li class="sp_list_top">', sp_embed_image('topic'), ' ', $topic['link'], '</li>
<li class="sp_list_indent', empty($topic['is_last']) ? ' sp_list_bottom' : '', ' smalltext">Replies in last ', $hours, ' hours: ', $topic['replies'], '</li>';

echo '
</ul>';
And slowly, you come to realize... It's all as it should be...

Offline Vaughn

  • Semi Newbie
  • *
  • Posts: 8
  • SMF Version: 2 RC3
  • SP Version: 2.3.2
Re: Block For Most Replies in X Hours
« Reply #3 on: August 01, 2013, 06:34:47 AM »
Nice code, but can you make it so threads from restricted boards are excluded from the list for guests/regular members without the right permissions?

Offline [SiNaN]

  • Mr. SimplePortal
  • Developer
  • *
  • Posts: 6782
  • SMF Version: 2.0.15
  • SP Version: 2.3.7
Re: Block For Most Replies in X Hours
« Reply #4 on: August 01, 2013, 01:04:19 PM »
Opps. Sorry about that. Please use this one:

Code: [Select]
global $smcFunc, $scripturl, $txt;

$limit = 5;
$hours = 2;

$request = $smcFunc['db_query']('', '
SELECT m.id_topic, m.subject, COUNT(m.id_msg) AS posts
FROM {db_prefix}messages AS m
INNER JOIN {db_prefix}boards AS b ON (b.id_board = m.id_board)
WHERE m.poster_time > {int:start_time}
AND {query_see_board}
GROUP BY m.id_topic
ORDER BY posts DESC
LIMIT {int:limit}',
array(
'start_time' => forum_time(false, mktime(0, 0, 0, date("n"), date("j"), date("Y")) - (date("N") * 3600 * $hours)),
'limit' => $limit,
)
);
while ($row = $smcFunc['db_fetch_assoc']($request))
{
$row['subject'] = str_replace('Re: ', '', $row['subject']);

$topics[] = array(
'id' => $row['id_topic'],
'subject' => $row['subject'],
'href' => $scripturl . '?topic=' . $row['id_topic'] . '.0',
'link' => '<a href="' . $scripturl . '?topic=' . $row['id_topic'] . '.0">' . $row['subject'] . '</a>',
'replies' => comma_format($row['posts']),
);
}
$smcFunc['db_free_result']($request);

if (empty($topics))
{
echo $txt['error_sp_no_topics_found'];
return;
}
else
$topics[count($topics) - 1]['is_last'] = true;

echo '
<ul class="sp_list">';

foreach ($topics as $topic)
echo '
<li class="sp_list_top">', sp_embed_image('topic'), ' ', $topic['link'], '</li>
<li class="sp_list_indent', empty($topic['is_last']) ? ' sp_list_bottom' : '', ' smalltext">Replies in last ', $hours, ' hours: ', $topic['replies'], '</li>';

echo '
</ul>';
And slowly, you come to realize... It's all as it should be...

Offline Vaughn

  • Semi Newbie
  • *
  • Posts: 8
  • SMF Version: 2 RC3
  • SP Version: 2.3.2
Re: Block For Most Replies in X Hours
« Reply #5 on: August 02, 2013, 06:55:45 AM »
Brilliant, thanks

Offline [SiNaN]

  • Mr. SimplePortal
  • Developer
  • *
  • Posts: 6782
  • SMF Version: 2.0.15
  • SP Version: 2.3.7
Re: Block For Most Replies in X Hours
« Reply #6 on: August 14, 2013, 11:31:06 AM »
Glad that it worked for you. ;)
And slowly, you come to realize... It's all as it should be...

Offline Tarista

  • Semi Newbie
  • *
  • Posts: 37
  • SMF Version: 2.0.10
  • SP Version: 2.3.5
Re: Block For Most Replies in X Hours
« Reply #7 on: October 20, 2013, 05:39:08 AM »
Hi,

I added this code to my site on a block and got really strange results. I choose 24 hours and got much more than that, when i added something like 1 hour instead i could easily see it didn't work as intended. Posts written earlier was included. Not all post but more then an hour, perhaps 5-6 or so (but i'm just guessing).

For me, post marked "Today" would be enough, or ofcourse 24 hours. But i cannot get that to work correctly.

Offline Tarista

  • Semi Newbie
  • *
  • Posts: 37
  • SMF Version: 2.0.10
  • SP Version: 2.3.5
Re: Block For Most Replies in X Hours
« Reply #8 on: October 30, 2013, 10:23:57 AM »
Could it be possible this (mentioned above) has something to do with how date is determined in the code, using forum_time and then a conversion on top of that? :)

Offline Vaughn

  • Semi Newbie
  • *
  • Posts: 8
  • SMF Version: 2 RC3
  • SP Version: 2.3.2
Re: Block For Most Replies in X Hours
« Reply #9 on: May 18, 2014, 03:34:11 AM »
I've noticed strange behaviour of this, like reply count wrong and time wrong. Does anyone have a fix? Or new code that does the same thing?

Offline AngelinaBelle

  • Comrade
  • *
  • Posts: 4870
  • Gender: Female
  • SMF Version: 2 RC3
  • SP Version: 2.3.2
Re: Block For Most Replies in X Hours
« Reply #10 on: May 19, 2014, 12:20:17 PM »
I am not sure.  I can suggest some very simplistic code to use for the start_time:
Code: [Select]
'start_time' => forum_time(false, time() - 3600 * $hours),I have not tested this, and am not certain it will work; please feel free to test it and see if it works for you on your forum.
Please to keep this website running, if you like SimplePortal, make a
one-time subscription. Thank you for your support.

Have you tried the SimplePortal documentation?