HEX
Server: Apache/2.4.59 (Debian)
System: Linux keymana 4.19.0-21-cloud-amd64 #1 SMP Debian 4.19.249-2 (2022-06-30) x86_64
User: lijunjie (1003)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/html/wp-content/plugins/erp/includes/admin/class-audit-list-table.php
<?php

namespace WeDevs\ERP\Admin;

/**
 * List table class
 */
class Auditlog_List_Table extends \WP_List_Table {
    public function __construct() {
        global $status, $page;

        parent::__construct( [
            'singular' => 'audit_log',
            'plural'   => 'audit_logs',
            'ajax'     => false,
        ] );

        $this->table_css();
    }

    /**
     * Table column width css
     *
     * @return void
     */
    public function table_css() {
        echo '<style type="text/css">';
        echo '.audit-log-list-table .column-name { width: 10%; }';
        echo '.audit-log-list-table .column-sections { width: 12%; }';
        echo '.audit-log-list-table .column-message { width: 45%; }';
        echo '</style>';
    }

    public function get_table_classes() {
        return [ 'widefat', 'fixed', 'striped', 'audit-log-list-table', $this->_args['plural'] ];
    }

    /**
     * Render extra filtering option in
     * top of the table
     *
     * @since 0.1
     *
     * @param string $which
     *
     * @return void
     */
    public function extra_tablenav( $which ) {
        if ( $which != 'top' ) {
            return;
        }

        $modules           = erp_get_audit_log_modules();
        $sections          = erp_get_audit_log_sub_component();
        $types             = $this->erp_log_get_filters();
        
        $selected_module   = ( isset( $_GET['filter_module'] ) )   ? sanitize_text_field( wp_unslash( $_GET['filter_module'] ) )   : '';
        $selected_section  = ( isset( $_GET['filter_section'] ) )  ? sanitize_text_field( wp_unslash( $_GET['filter_section'] ) )  : '';
        $selected_duration = ( isset( $_GET['filter_duration'] ) ) ? sanitize_text_field( wp_unslash( $_GET['filter_duration'] ) ) : '';
        
        ?><div class="alignleft actions">
            <label class="screen-reader-text" for="filter_module"><?php esc_html_e( 'Filter by Module', 'erp' ); ?></label>
            <select name="filter_module" id="filter_module">
                <option value=""><?php esc_html_e( '&mdash; All Modules &mdash;', 'erp' ); ?></option>
                <?php foreach ( $modules as $module ) : ?>
                    <option value="<?php echo esc_html( $module['component'] ); ?>" <?php selected( $selected_module, $module['component'] ); ?>><?php echo esc_html( $module['component'] ); ?></option>
                <?php endforeach; ?>
            </select>

            <label class="screen-reader-text" for="filter_section"><?php esc_html_e( 'Filter by Section', 'erp' ); ?></label>
            <select name="filter_section" id="filter_section">
                <option value=""><?php esc_html_e( '&mdash; All Sections &mdash;', 'erp' ); ?></option>
                <?php foreach ( $sections as $section ) : ?>
                    <option value="<?php echo esc_attr( $section['sub_component'] ); ?>" <?php selected( $section['sub_component'], $selected_section ); ?>><?php echo esc_html( ucfirst( $section['sub_component'] ) ); ?></option>
                <?php endforeach; ?>
            </select>
            
            <label class="screen-reader-text" for="new_role"><?php esc_html_e( 'Filter by Duration', 'erp' ); ?></label>
            <select name="filter_duration" id="filter_duration">
                <option value="-1"><?php esc_html_e( '&mdash; All Times &mdash;', 'erp' ); ?></option>
                <?php foreach ( $types as $key => $type ) : ?>
                    <option value="<?php echo esc_attr( $key ); ?>" <?php selected( $selected_duration, $key, false ); ?>><?php echo esc_html( $type ); ?></option>
                <?php endforeach; ?>
            </select>

            <?php submit_button( __( 'Filter', 'erp' ), 'button', 'filter_audit_log', false ); ?>
        </div><?php
    }

    /**
     * Get Lists of months for attendance filter
     *
     * @since 1.0
     *
     * @return array
     */
    public function erp_log_get_filters() {
        $filters = [
            'today'        => __( 'Today', 'erp' ),
            'yesterday'    => __( 'Yesterday', 'erp' ),
            'this_month'   => __( 'This Month', 'erp' ),
            'last_month'   => __( 'Last Month', 'erp' ),
            'this_quarter' => __( 'This Quarter', 'erp' ),
            'last_quarter' => __( 'Last Quarter', 'erp' ),
            'this_year'    => __( 'This Year', 'erp' ),
            'last_year'    => __( 'Last Year', 'erp' ),
            'custom'       => __( 'Custom', 'erp' ),
        ];

        return $filters;
    }

    /**
     * Render current actions
     *
     * @return [type] [description]
     */
    public function current_action() {
        if ( isset( $_REQUEST['filter_audit_log'] ) ) {
            return 'filter_audit_log';
        }

        return parent::current_action();
    }

    /**
     * Message to show if no logs found
     *
     * @return void
     */
    public function no_items() {
        esc_html_e( 'No logs found.', 'erp' );
    }

    /**
     * Default column values if no callback found
     *
     * @param object $item
     * @param string $column_name
     *
     * @return string
     */
    public function column_default( $audit_log, $column_name ) {
        switch ( $column_name ) {
            case 'name':
                return ucfirst( $audit_log->component );

            case 'sections':
                return ucfirst( $audit_log->sub_component );

            case 'message':
                if ( $audit_log->changetype == 'edit' ) {
                    if ( !empty( $audit_log->old_value ) && !empty( $audit_log->new_value ) ) {
                        return sprintf( __( '%s. <a href="#" class="erp-audit-log-view-changes erp-tips" data-id="%d" title="%s"> (view changes)</a>', 'erp' ), htmlspecialchars_decode( $audit_log->message ), $audit_log->id, __( 'View what elements are changes', 'erp' ) );
                    } else {
                        return htmlspecialchars_decode( $audit_log->message );
                    }
                }

                return htmlspecialchars_decode( $audit_log->message );

            case 'created_by':
                return $audit_log->display_name;

            case 'created_at':
                return ! empty( $audit_log->created_at ) ? gmdate( erp_get_date_format() . ', h:i:s', strtotime( $audit_log->created_at ) ) : $audit_log->created_at;

            default:
                return isset( $audit_log->$column_name ) ? $audit_log->$column_name : '';
        }
    }

    /**
     * Get the column names
     *
     * @return array
     */
    public function get_columns() {
        $columns = [
            'cb'         => '',
            'name'       => __( 'Module', 'erp' ),
            'sections'   => __( 'Sections', 'erp' ),
            'message'    => __( 'Message', 'erp' ),
            'created_by' => __( 'Created By', 'erp' ),
            'created_at' => __( 'Created At', 'erp' ),
        ];

        return apply_filters( 'erp_hr_audit_table_cols', $columns );
    }

    /**
     * Render the checkbox column
     *
     * @param object $item
     *
     * @return string
     */
    public function column_cb( $item ) {
        return false;
    }

    /**
     * Prepare the class items
     *
     * @return void
     */
    public function prepare_items() {
        $columns               = $this->get_columns();
        $hidden                = [ ];
        $sortable              = $this->get_sortable_columns();
        $this->_column_headers = [ $columns, $hidden, $sortable ];

        $per_page              = 30;
        $current_page          = $this->get_pagenum();
        $offset                = ( $current_page - 1 ) * $per_page;
        $this->page_status     = isset( $_GET['status'] ) ? sanitize_text_field( wp_unslash( $_GET['status'] ) ) : '2';
        $args                  = [];

        // only ncessary because we have sample data
        $args = [
            'offset' => $offset,
            'number' => $per_page,
        ];

        if ( isset( $_REQUEST['filter_module'] ) && !empty( $_REQUEST['filter_module'] ) ) {
            $args['component'] = sanitize_text_field( wp_unslash( $_REQUEST['filter_module'] ) );
        }

        if ( isset( $_REQUEST['filter_section'] ) && !empty( $_REQUEST['filter_section'] ) ) {
            $args['sub_component'] = sanitize_text_field( wp_unslash( $_REQUEST['filter_section'] ) );
        }

        if ( isset( $_REQUEST['filter_duration'] ) && !empty( $_REQUEST['filter_duration'] ) ) {
            $args['filter_duration'] = sanitize_text_field( wp_unslash( $_REQUEST['filter_duration'] ) );

            if ( '-1' != $args['filter_duration'] ) {
                if ( $args['filter_duration'] == 'custom' ) {
                    $args['start'] = isset( $_REQUEST['start'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['start'] ) ) : '';
                    $args['end']   = isset( $_REQUEST['end'] ) ? sanitize_text_field( wp_unslash( $_REQUEST['end'] ) ) : '';
                } else {
                    $duration      = $this->erp_log_get_start_end_date( $args['filter_duration'] );
                    $args['start'] = $duration['start'];
                    $args['end']   = $duration['end'];
                }
            }
        }

        $this->items  = erp_log()->get( $args );
        $total_items  = erp_log()->get( $args, true );

        $this->set_pagination_args( [
            'total_items' => $total_items,
            'per_page'    => $per_page,
        ] );
    }

    /**
     * set timespan in wich the data should be fetched
     */
    public function erp_log_get_start_end_date( $time = '' ) {
        $duration = [];

        if ( $time ) {
            switch ( $time ) {

                case 'today':

                    $start_date = current_time( 'Y-m-d' );
                    $end_date   = $start_date;
                    break;

                case 'yesterday':

                    $today      = strtotime( current_time( 'Y-m-d' ) );
                    $start_date = date( 'Y-m-d', strtotime( '-1 days', $today ) );
                    $end_date   = $start_date;
                    break;

                case 'last_7_days':

                    $end_date   = current_time( 'Y-m-d' );
                    $start_date = date( 'Y-m-d', strtotime( '-6 days', strtotime( $end_date ) ) );
                    break;

                case 'this_month':

                    $start_date = date( 'Y-m-d', strtotime( 'first day of this month' ) );
                    $end_date   = date( 'Y-m-d', strtotime( 'last day of this month' ) );
                    break;

                case 'last_month':

                    $start_date = date( 'Y-m-d', strtotime( 'first day of previous month' ) );
                    $end_date   = date( 'Y-m-d', strtotime( 'last day of previous month' ) );
                    break;

                case 'this_quarter':

                    $current_month = date( 'm' );
                    $current_year  = date( 'Y' );

                    if ( $current_month >= 1 && $current_month <= 3 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-January-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '31-March-' . $current_year ) );
                    } elseif ( $current_month >= 4 && $current_month <= 6 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-April-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '30-June-' . $current_year ) );
                    } elseif ( $current_month >= 7 && $current_month <= 9 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-July-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '30-September-' . $current_year ) );
                    } elseif ( $current_month >= 10 && $current_month <= 12 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-October-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '31-December-' . $current_year ) );
                    }
                    break;

                case 'last_quarter':

                    $current_month = date( 'm' );
                    $current_year  = date( 'Y' );

                    if ( $current_month >= 1 && $current_month <= 3 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-October-' . ( $current_year - 1 ) ) );
                        $end_date   = date( 'Y-m-d', strtotime( '31-December-' . ( $current_year - 1 ) ) );
                    } elseif ( $current_month >= 4 && $current_month <= 6 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-January-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '31-March-' . $current_year ) );
                    } elseif ( $current_month >= 7 && $current_month <= 9 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-April-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '30-June-' . $current_year ) );
                    } elseif ( $current_month >= 10 && $current_month <= 12 ) {
                        $start_date = date( 'Y-m-d', strtotime( '1-July-' . $current_year ) );
                        $end_date   = date( 'Y-m-d', strtotime( '30-September-' . $current_year ) );
                    }
                    break;

                case 'last_year':

                    $start_date = date( 'Y-01-01', strtotime( '-1 year' ) );
                    $end_date   = date( 'Y-12-31', strtotime( '-1 year' ) );
                    break;

                case 'this_year':

                    $start_date = date( 'Y-01-01' );
                    $end_date   = date( 'Y-12-31' );
                    break;

                default:
                    break;
            }
        }

        $duration   = [
            'start' => $start_date,
            'end'   => $end_date,
        ];

        return $duration;
    }
}