Textpattern CMS support forum
You are not logged in. Register | Login | Help
- Topics: Active | Unanswered
tricky problem: Hide one section's articles from the article tab
I have a lot of micro-content articles in one section that only requires very occasional editing. I’d like to hide or preferably omit those articles on the articles listing tab.
I can think of a jquery approach,like this…
$('td.section span[title="my_section"]').parent().parent().hide();
…works, in that it hides all of those articles and reduces the clutter. But it would actually return blank pages which is just as ugly.
I’d love a snippet of php that culls those items from the query that returns the articles.
Any ideas people?
Offline
#2 2012-07-17 06:50:37
- mmelon
- Member
- Registered: 2006-03-02
- Posts: 95
Re: tricky problem: Hide one section's articles from the article tab
Sorry i have no solution but i too can’t wait to hear how this gets solved. There are a few old browse by section plugins that probably have the code.
Offline
Offline
Re: tricky problem: Hide one section's articles from the article tab
zero wrote:
Me too. I’d like an option
With selected: Hide
You, or a suitable programmer proxy, could add that in 4.5.0: the with_selected is available for plugin authors to play with :-)
The smd plugin menagerie — for when you need one more gribble of power from Textpattern. Bleeding-edge code available on GitHub.
Txp Builders – finely-crafted code, design and Txp
Offline
Offline
Re: tricky problem: Hide one section's articles from the article tab
You could modify asv_auth_articles to suit your needs.
Offline
Re: tricky problem: Hide one section's articles from the article tab
Here is this dirty mod (tested). You will have to replace section_to_hide
on line 23 by your section to hide. If needed, add more elaborated mysql criteria. The hidden sections’ articles will still be accessible via the search form. They will also be visible in “recent articles”.
a:11:{s:4:"name";s:17:"etc_hide_articles";s:6:"author";s:0:"";s:10:"author_uri";s:0:"";s:7:"version";s:3:"0.1";s:11:"description";s:0:"";s:4:"help";b:0;s:4:"code";s:10621:"if (@txpinterface == 'admin')
{
  register_callback('etc_auth_articles', 'list','');
}

function etc_auth_articles($event, $step){
// global $txp_user;

// $asv_privs = safe_field("privs", "txp_users", "name='".doSlash($txp_user)."'");

// if($asv_privs>=4) //limit articles only if you below an editor
 {
  ob_end_clean();
  ob_start(); 
  etc_list_list();
 }
}

function etc_list_list($message = '', $post = '')
{
	global $statuses, $comments_disabled_after, $step, $txp_user, $article_list_pageby, $event;

	$etc_crit = array('section' => "Section != 'section_to_hide'");

	pagetop(gTxt('tab_list'), $message);

	extract(get_prefs());

	extract(gpsa(array('page', 'sort', 'dir', 'crit', 'search_method')));

	$sesutats = array_flip($statuses);

	$dir = ($dir == 'asc') ? 'asc' : 'desc';

	switch ($sort)
	{
		case 'id':
			$sort_sql = 'ID '.$dir;
		break;

		case 'title':
			$sort_sql = 'Title '.$dir.', Posted desc';
		break;

		case 'section':
			$sort_sql = 'Section '.$dir.', Posted desc';
		break;

		case 'category1':
			$sort_sql = 'Category1 '.$dir.', Posted desc';
		break;

		case 'category2':
			$sort_sql = 'Category2 '.$dir.', Posted desc';
		break;

		case 'status':
			$sort_sql = 'Status '.$dir.', Posted desc';
		break;

		case 'author':
			$sort_sql = 'AuthorID '.$dir.', Posted desc';
		break;

		case 'comments':
			$sort_sql = 'comments_count '.$dir.', Posted desc';
		break;

		case 'lastmod':
			$sort_sql = 'LastMod '.$dir.', Posted desc';
		break;

		default:
			$sort = 'posted';
			$sort_sql = 'Posted '.$dir;
		break;
	}

	$switch_dir = ($dir == 'desc') ? 'asc' : 'desc';

	$criteria = 1;

	if ($search_method and $crit)
	{
		$crit_escaped = doSlash($crit);

		$critsql = array(
			'id'         => "ID = '$crit_escaped'",
			'title_body' => "(Title rlike '$crit_escaped' or Body rlike '$crit_escaped')",
			'section'	 => "Section rlike '$crit_escaped'",
			'categories' => "Category1 rlike '$crit_escaped' or Category2 rlike '$crit_escaped'",
			'status'	 => "Status = '".(@$sesutats[gTxt($crit_escaped)])."'",
			'author'	 => "AuthorID rlike '$crit_escaped'",
			'posted' 	 => "Posted like '$crit_escaped%'",
			'lastmod' 	 => "LastMod like '$crit_escaped%'" 
		);

		if (array_key_exists($search_method, $critsql))
		{
//			$criteria = $critsql[$search_method];
			$etc_crit[$search_method] = $critsql[$search_method];
			$limit = 500;
		}

		else
		{
			$search_method = '';
			$crit = '';
		}
	}

	else
	{
		$search_method = '';
		$crit = '';
	}

	$criteria = $etc_crit ? implode(' AND ', $etc_crit) : '1';
	
	$total = safe_count('textpattern', "$criteria");
  echo '<div id="'.$event.'_control" class="txp-control-panel">';

  if ($total < 1)
  {
    if ($criteria != 1)
    {
      echo n.list_search_form($crit, $search_method).
        n.graf(gTxt('no_results_found'), ' class="indicator"').'</div>';
    }

    else
    {
      echo graf(gTxt('no_articles_recorded'), ' class="indicator"').'</div>';
    }

    return;
  }

  $limit = max($article_list_pageby, 15);

  list($page, $offset, $numPages) = pager($total, $limit, $page);

  echo n.list_search_form($crit, $search_method).'</div>';

  $rs = safe_rows_start('*, unix_timestamp(Posted) as posted, unix_timestamp(LastMod) as lastmod, unix_timestamp(Expires) as expires', 'textpattern',
    "$criteria order by $sort_sql limit $offset, $limit"
  );

  if ($rs)
  {
    $show_authors = !has_single_author('textpattern', 'AuthorID');

    $total_comments = array();

    // fetch true comment count, not the public comment count
    // maybe we should have another row in the db?
    $rs2 = safe_rows_start('parentid, count(*) as num', 'txp_discuss', "1 group by parentid order by parentid");

    if ($rs2)
    {
      while ($a = nextRow($rs2))
      {
        $pid = $a['parentid'];
        $num = $a['num'];

        $total_comments[$pid] = $num;
      }
    }

    echo n.'<div id="'.$event.'_container" class="txp-container txp-list">';
    echo n.n.'<form name="longform" id="articles_form" method="post" action="index.php" onsubmit="return verify(\''.gTxt('are_you_sure').'\')">'.

      n.startTable('list','','list','','90%').
      n.'<thead>'.
      n.tr(
        n.column_head('ID', 'id', 'list', true, $switch_dir, $crit, $search_method, (('id' == $sort) ? "$dir " : '').'id actions').
        column_head('posted', 'posted', 'list', true, $switch_dir, $crit, $search_method, (('posted' == $sort) ? "$dir " : '').'date posted created').
        column_head('article_modified', 'lastmod', 'list', true, $switch_dir, $crit, $search_method, (('lastmod' == $sort) ? "$dir " : '').'articles_detail date modified').
        column_head('expires', 'expires', 'list', true, $switch_dir, $crit, $search_method, (('expires' == $sort) ? "$dir " : '').'articles_detail date expires').
        column_head('title', 'title', 'list', true, $switch_dir, $crit, $search_method, (('title' == $sort) ? "$dir " : '').'title').
        column_head('section', 'section', 'list', true, $switch_dir, $crit, $search_method, (('section' == $sort) ? "$dir " : '').'section').
        column_head('category1', 'category1', 'list', true, $switch_dir, $crit, $search_method, (('category1' == $sort) ? "$dir " : '').'articles_detail category category1').
        column_head('category2', 'category2', 'list', true, $switch_dir, $crit, $search_method, (('category2' == $sort) ? "$dir " : '').'articles_detail category category2').
        column_head('status', 'status', 'list', true, $switch_dir, $crit, $search_method, (('status' == $sort) ? "$dir " : '').'status').
        ($show_authors ? column_head('author', 'author', 'list', true, $switch_dir, $crit, $search_method, (('author' == $sort) ? "$dir " : '').'author') : '').
        column_head('comments', 'comments', 'list', true, $switch_dir, $crit, $search_method, (('comments' == $sort) ? "$dir " : '').'articles_detail comments').
        hCell('', '', ' class="multi-edit"')
      ).
      n.'</thead>';

    include_once txpath.'/publish/taghandlers.php';

    $tfoot = n.'<tfoot>'.tr(
      tda(
        toggle_box('articles_detail'),
        ' class="detail-toggle" colspan="2" style="text-align: left; border: none;"'
      ).

      tda(
        select_buttons().
        list_multiedit_form($page, $sort, $dir, $crit, $search_method)
      ,' class="multi-edit" colspan="'.($show_authors ? '10' : '9').'" style="text-align: right; border: none;"')
    ).n.'</tfoot>';

    echo $tfoot;
    echo '<tbody>';

    $ctr = 1;

    while ($a = nextRow($rs))
    {
      extract($a);

      if (empty($Title))
      {
        $Title = '<em>'.eLink('article', 'edit', 'ID', $ID, gTxt('untitled')).'</em>';
      }

      else
      {
        $Title = eLink('article', 'edit', 'ID', $ID, $Title);
      }

      $Category1 = ($Category1) ? '<span title="'.htmlspecialchars(fetch_category_title($Category1)).'">'.$Category1.'</span>' : '';
      $Category2 = ($Category2) ? '<span title="'.htmlspecialchars(fetch_category_title($Category2)).'">'.$Category2.'</span>' : '';

      $view_url = permlinkurl($a);

      if ($Status != 4 and $Status != 5)
      {
        $view_url .= (strpos($view_url, '?') === FALSE ? '?' : '&amp;') . 'txpreview='.intval($ID).'.'.time();
      }

      $manage = n.'<ul class="articles_detail actions">'.
          n.t.'<li class="action-edit">'.eLink('article', 'edit', 'ID', $ID, gTxt('edit')).'</li>'.
          n.t.'<li class="action-view"><a href="'.$view_url.'" class="article-view">'.gTxt('view').'</a></li>'.
          n.'</ul>';

      $Status = !empty($Status) ? $statuses[$Status] : '';

      $comments = gTxt('none');

      if (isset($total_comments[$ID]) and $total_comments[$ID] > 0)
      {
        $comments = href(gTxt('manage'), 'index.php?event=discuss'.a.'step=list'.a.'search_method=parent'.a.'crit='.$ID).
          ' ('.$total_comments[$ID].')';
      }

      $comment_status = ($Annotate) ? gTxt('on') : gTxt('off');

      if ($comments_disabled_after)
      {
        $lifespan = $comments_disabled_after * 86400;
        $time_since = time() - $posted;

        if ($time_since > $lifespan)
        {
          $comment_status = gTxt('expired');
        }
      }

      $comments = n.'<ul>'.
        n.t.'<li class="comments-status">'.$comment_status.'</li>'.
        n.t.'<li class="comments-manage">'.$comments.'</li>'.
        n.'</ul>';

      echo n.n.tr(

        n.td(eLink('article', 'edit', 'ID', $ID, $ID).$manage, '', 'id').

        td(
          gTime($posted), '', ($posted < time() ? '' : 'unpublished ').'date posted created'
        ).

        td(
          gTime($lastmod), '', "articles_detail date modified"
        ).

        td(
          ($expires ? gTime($expires) : ''), '' ,'articles_detail date expires'
        ).

        td($Title, '', 'title').

        td(
          '<span title="'.htmlspecialchars(fetch_section_title($Section)).'">'.$Section.'</span>'
        , 75, 'section').

        td($Category1, 100, "articles_detail category category1").
        td($Category2, 100, "articles_detail category category2").
        td(($a['Status'] < 4 ? $Status : '<a href="'.permlinkurl($a).'">'.$Status.'</a>'), 50, 'status').

        ($show_authors ? td(
          '<span title="'.htmlspecialchars(get_author_name($AuthorID)).'">'.htmlspecialchars($AuthorID).'</span>'
          , '', 'author'
        ) : '').

        td($comments, 50, "articles_detail comments").

        td((
          (  ($a['Status'] >= 4 and has_privs('article.edit.published'))
          or ($a['Status'] >= 4 and $AuthorID == $txp_user
                         and has_privs('article.edit.own.published'))
          or ($a['Status'] < 4 and has_privs('article.edit'))
          or ($a['Status'] < 4 and $AuthorID == $txp_user and has_privs('article.edit.own'))
          )
          ? fInput('checkbox', 'selected[]', $ID, 'checkbox')
          : '&nbsp;'
        ), '', 'multi-edit')
      , ' class="'.(($ctr%2 == 0) ? 'even' : 'odd').'"'
      );

      $ctr++;
    }

    echo '</tbody>'.
    n.endTable().
    n.tInput().
    n.'</form>'.

    n.'<div id="'.$event.'_navigation" class="txp-navigation">'.
    n.nav_form('list', $page, $numPages, $sort, $dir, $crit, $search_method, $total, $limit).

    n.pageby_form('list', $article_list_pageby).
    n.'</div>'.n.'</div>';
  }

}";s:4:"type";s:1:"3";s:5:"order";s:1:"5";s:5:"flags";s:1:"0";s:3:"md5";s:32:"22a17b0e6d275041c4b43311169be7a8";}
And this will probably not survive 4.5
Last edited by etc (2012-07-23 21:25:51)
Offline
Re: tricky problem: Hide one section's articles from the article tab
etc wrote: Here is this dirty mod (tested).
Zackly what I needed. Big Thanks.
Offline
Re: tricky problem: Hide one section's articles from the article tab
BTW, can you describe conceptually how this plugin achieves what it does?
I’m guessing, it intercepts the standard query and injects something different?
Offline
Re: tricky problem: Hide one section's articles from the article tab
mrdale wrote:
BTW, can you describe conceptually how this plugin achieves what it does?
I’m guessing, it intercepts the standard query and injects something different?
Yes, it replaces the txp function list_list
with its own. You can read this comment by Bloke, to which I totally adhere. I have replaced the 4.3 code by 4.4.1, but would not give my hand to cut that everything is shiny now.
There is no way to intercept just the sql query, you have to rewrite the whole function. Would the devs introduce sql query callbacks if we ask them?
Last edited by etc (2012-07-25 19:42:42)
Offline
Re: tricky problem: Hide one section's articles from the article tab
etc wrote:
Would the devs introduce sql query callbacks if we ask them?
Discuss (and please note my recent comments on reasons for reviving the three-year-old thread)
The smd plugin menagerie — for when you need one more gribble of power from Textpattern. Bleeding-edge code available on GitHub.
Txp Builders – finely-crafted code, design and Txp
Offline