<?php
/**
* This file implements the UI view for Central Antispam > Reportes
*
* This file is part of the evoCore framework - {@link http://evocore.net/}
* See also {@link http://sourceforge.net/projects/evocms/}.
*
* @copyright (c)2003-2020 by Francois Planque - {@link http://fplanque.com/}
*
* {@internal License choice
* - If you have received this file as part of a package, please find the license.txt file in
* the same folder or the closest folder above for complete license terms.
* - If you have received this file individually (e-g: from http://evocms.cvs.sourceforge.net/)
* then you must choose one of the following licenses before using the file:
* - GNU General Public License 2 (GPL) - http://www.opensource.org/licenses/gpl-license.php
* - Mozilla Public License 1.1 (MPL) - http://www.opensource.org/licenses/mozilla1.1.php
* }}
*
* {@internal Open Source relicensing agreement:
* }}
*
* @package admin
*/
if( !defined('EVO_MAIN_INIT') ) die( 'Please, do not access this page directly.' );
global $central_antispam_Module, $UserSettings, $admin_url;
// Create result set:
$SQL = new SQL();
$SQL->SELECT( 'casrc_ID, casrc_baseurl, casrc_status, COUNT( carpt_casrc_ID ) as report_num' );
$SQL->FROM( 'T_centralantispam__source' );
$SQL->FROM_add( 'LEFT JOIN T_centralantispam__report ON carpt_casrc_ID = casrc_ID' );
$SQL->GROUP_BY( 'casrc_ID' );
$CountSQL = new SQL();
$CountSQL->SELECT( 'SQL_NO_CACHE COUNT( casrc_ID )' );
$CountSQL->FROM( 'T_centralantispam__source' );
$Results = new Results( $SQL->get(), 'casrc_', '-A', $UserSettings->get( 'results_per_page' ), $CountSQL->get() );
$Results->title = T_('Reporters');
$Results->cols[] = array(
'th' => T_('ID'),
'order' => 'casrc_ID',
'th_class' => 'shrinkwrap',
'td_class' => 'right',
'td' => '$casrc_ID$',
);
$Results->cols[] = array(
'th' => T_('URL'),
'order' => 'casrc_baseurl',
'td' => '<a href="'.$admin_url.'?ctrl=central_antispam&tab=reporters&action=source_edit&casrc_ID=$casrc_ID$">$casrc_baseurl$</a>',
);
$Results->cols[] = array(
'th' => T_('Status'),
'order' => 'casrc_status',
'th_class' => 'shrinkwrap',
'td_class' => 'jeditable_cell casource_status_edit',
'td' => /* Check permission: */check_user_perm( 'centralantispam', 'edit' ) ?
/* Current user can edit source */'<a href="#" rel="$casrc_status$" style="color:#FFF">%ca_get_source_status_title( #casrc_status# )%</a>' :
/* No edit, only view the status */'%ca_get_keyword_status_title( #cakw_status# )%',
'extra' => array ( 'style' => 'background-color: %ca_get_source_status_color( "#casrc_status#" )%;color:#FFF', 'format_to_output' => false ),
);
$Results->cols[] = array(
'th' => T_('Reports'),
'order' => 'report_num',
'default_dir' => 'D',
'th_class' => 'shrinkwrap',
'td_class' => 'right',
'td' => '$report_num$',
);
function ac_results_source_actions( $casrc_ID )
{
global $central_antispam_Module, $admin_url;
return action_icon( T_('Edit this reporter...'), 'edit', $admin_url.'?ctrl=central_antispam&tab=reporters&action=source_edit&casrc_ID='.$casrc_ID );
}
$Results->cols[] = array(
'th' => T_('Actions'),
'td_class' => 'shrinkwrap',
'td' => '%ac_results_source_actions( #casrc_ID# )%'
);
// Display results:
$Results->display();
if( check_user_perm( 'centralantispam', 'edit' ) )
{ // Check permission to edit central antispam source:
// Print JS to edit status of central antispam source:
echo_editable_column_js( array(
'column_selector' => '.casource_status_edit',
'ajax_url' => get_htsrv_url().'action.php?mname=central_antispam&action=casource_status_edit&'.url_crumb( 'casource' ),
'options' => ca_get_source_statuses(),
'new_field_name' => 'new_status',
'ID_value' => 'jQuery( ":first", jQuery( this ).parent() ).text()',
'ID_name' => 'casrc_ID',
'colored_cells' => true,
) );
}
?>