load->model('user_model'); } public function index($page) { $this->load->library('pagination'); include_once __DIR__ . '/../../view_models/Ticket_admin_list_paginate_view_model.php'; $session = $this->get_session(); $format = $this->input->get('format', TRUE) ?? 'view'; $order_by = $this->input->get('order_by', TRUE) ?? ''; $direction = $this->input->get('direction', TRUE) ?? 'ASC'; $per_page_sort = $this->input->get('per_page_sort', TRUE) ?? 25; $this->_data['view_model'] = new Ticket_admin_list_paginate_view_model( $this->ticket_model, $this->pagination, '/admin/ticket/0'); $this->_data['view_model']->set_heading('Ticket'); $this->_data['view_model']->set_order_id(($this->input->get('order_id', TRUE) != NULL) ? $this->input->get('order_id', TRUE) : NULL); $this->_data['view_model']->set_message(($this->input->get('message', TRUE) != NULL) ? $this->input->get('message', TRUE) : NULL); $this->_data['view_model']->set_status(($this->input->get('status', TRUE) != NULL) ? $this->input->get('status', TRUE) : NULL); $where = [ 'order_id' => $this->_data['view_model']->get_order_id(), 'message' => $this->_data['view_model']->get_message(), 'status' => $this->_data['view_model']->get_status(), ]; $this->_data['view_model']->set_total_rows($this->ticket_model->count($where)); $this->_data['view_model']->set_format_layout($this->_data['layout_clean_mode']); $this->_data['view_model']->set_per_page($per_page_sort); $this->_data['view_model']->set_order_by($order_by); $this->_data['view_model']->set_sort($direction); $this->_data['view_model']->set_sort_base_url('/admin/ticket/0'); $this->_data['view_model']->set_page($page); $this->_data['view_model']->set_list($this->ticket_model->get_paginated( $this->_data['view_model']->get_page(), $this->_data['view_model']->get_per_page(), $where, $order_by, $direction)); $user_id_array = $this->user_model->get_all(); if($user_id_array){ $user_id_array = array_column($user_id_array,'first_name','id'); } // print_r($user_id_array);exit; if($this->_data['view_model']->get_list() ){ foreach ( $this->_data['view_model']->get_list() as $key => &$value) { $value->user_id = $user_id_array[$value->user_id] ?? ''; } } if ($format == 'csv') { header('Content-Type: text/csv'); header('Content-Disposition: attachment; filename="export.csv"'); echo $this->_data['view_model']->to_csv(); exit(); } if ($format != 'view') { return $this->output->set_content_type('application/json') ->set_status_header(200) ->set_output(json_encode($this->_data['view_model']->to_json())); } return $this->render('Admin/Ticket', $this->_data); } public function resolve($id){ $this->ticket_model->update('ticket',['status'=>1],['id'=>$id]); $this->success('Resolved successfully'); return redirect('admin/ticket/0','refresh'); } }