Seditio Source
Root |
./othercms/ips_4.3.4/applications/nexus/modules/admin/reports/purchases.php
<?php
/**
 * @brief        Purchases Reports
 * @author        <a href='https://www.invisioncommunity.com'>Invision Power Services, Inc.</a>
 * @copyright    (c) Invision Power Services, Inc.
 * @license        https://www.invisioncommunity.com/legal/standards/
 * @package        Invision Community
 * @subpackage    Nexus
 * @since        14 Aug 2014
 */

namespace IPS\nexus\modules\admin\reports;

/* To prevent PHP errors (extending class does not exist) revealing path */
if ( !defined( '\IPS\SUITE_UNIQUE_KEY' ) )
{
   
header( ( isset( $_SERVER['SERVER_PROTOCOL'] ) ? $_SERVER['SERVER_PROTOCOL'] : 'HTTP/1.0' ) . ' 403 Forbidden' );
    exit;
}

/**
 * Purchases Reports
 */
class _purchases extends \IPS\Dispatcher\Controller
{
   
/**
     * Execute
     *
     * @return    void
     */
   
public function execute()
    {
        \
IPS\Dispatcher::i()->checkAcpPermission( 'purchases_manage' );
       
parent::execute();
    }

   
/**
     * View Chart
     *
     * @return    void
     */
   
protected function manage()
    {
       
$chart = new \IPS\Helpers\Chart\Database(
            \
IPS\Http\Url::internal('app=nexus&module=reports&controller=purchases'),
           
'nexus_purchases',
           
'ps_start',
           
'',
            array(
               
'backgroundColor'     => '#ffffff',
               
'colors'            => array( '#10967e', '#ea7963', '#de6470', '#6b9dde', '#b09be4', '#eec766', '#9fc973', '#e291bf', '#55c1a6', '#5fb9da' ),
               
'hAxis'                => array( 'gridlines' => array( 'color' => '#f5f5f5' ) ),
               
'lineWidth'            => 1,
               
'areaOpacity'        => 0.4,
            )
        );
       
$chart->where[] = array( 'ps_app=? AND ps_type=?', 'nexus', 'package' );
       
$chart->groupBy = 'ps_item_id';
       
$chart->tableInclude    = array( 'ps_id', 'ps_member', 'ps_name', 'ps_start', 'ps_expire' );
       
$chart->tableParsers    = array(
           
'ps_member' => function( $val ) {
                return \
IPS\Theme::i()->getTemplate('global', 'nexus')->userLink( \IPS\Member::load( $val ) );
            },
           
'ps_start'    => function( $val ) {
                return \
IPS\DateTime::ts( $val );
            },
           
'ps_expire'    => function( $val ) {
                return
$val ? \IPS\DateTime::ts( $val ) : '';
            }
        );
       
       
$packages = array();
        foreach ( \
IPS\Db::i()->select( 'p_id', 'nexus_packages' ) as $packageId )
        {
           
$packages[ $packageId ] = \IPS\Member::loggedIn()->language()->get( 'nexus_package_' . $packageId );
        }
       
       
asort( $packages );
        foreach (
$packages as $id => $name )
        {
           
$chart->addSeries( $name, 'number', 'COUNT(*)', TRUE, $id );
        }

        \
IPS\Output::i()->title = \IPS\Member::loggedIn()->language()->addToStack('menu__nexus_reports_purchases');
        \
IPS\Output::i()->output = (string) $chart;
    }
}