<?php
use application\ESPCMS_AdminAuthority;
use application\ESPCMS_Core;
use modul_application\ESPCMS_MemberDB;
use modul_application\ESPCMS_OrderDB;
use admin_application\link\OrderLink;
class OrderExpress {
public function __construct() {
global $module_array;
$exclude_method = array('saveOrderExpress');
ESPCMS_AdminAuthority::authorityAdminVerify($exclude_method);
$order_app_config = ESPCMS_Core::get_app_config('order', false);
if (!$order_app_config['isetup']) {
espcms_message_err('public_pack-espcms_module_file_err', array($module_array['module']));
}
}
public static function listOrderExpress() {
global $espcms_admin_templates, $espcms_link_db;
$db_table = ESPCMS_DB_PREFIX . "order_shipreceipt";
$out_type = $_REQUEST['out_type'];
$oid = $_REQUEST['oid'];
if (espcms_ismatches($oid) && $oid) {
$db_where .= " AND oid=$oid";
}
if ($out_type == 'list') {
$limit = $_REQUEST['limit'] && espcms_ismatches($_REQUEST['limit']) ? $_REQUEST['limit'] : 0;
$per_page_num = $_REQUEST['per_page_num'] && espcms_ismatches($_REQUEST['per_page_num']) ? $_REQUEST['per_page_num'] : 10;
$search_keyname_array = array('shippingsn');
$search_keyname = $_REQUEST['search_keyname'] && in_array($_REQUEST['search_keyname'], $search_keyname_array) ? $_REQUEST['search_keyname'] : 'shippingsn';
$search_key = $_REQUEST['search_key'];
if (isset($search_key) && !empty($search_key)) {
$search_key = urldecode($search_key);
$db_where .= " AND $search_keyname LIKE '%$search_key%'";
}
$searchlist = $_GET['searchlist'];
if ($searchlist == 'true') {
exit(espcms_page_db($db_table, $db_where, true));
}
$sort_key = $_REQUEST['sort_key'];
$sort_key_array = array('osrid');
if (isset($sort_key) && in_array($sort_key, $sort_key_array)) {
$order_key = $sort_key;
} else {
$order_key = "osrid";
}
$sort_rank = $_REQUEST['sort_rank'];
$sort_rank_array = array('ASC', 'DESC');
if (isset($sort_rank) && in_array($sort_rank, $sort_rank_array)) {
$order_rank = $sort_rank;
} else {
$order_rank = "DESC";
}
$db_query = $espcms_link_db->db_query(espcms_db_list_out($db_table, $db_where, $order_key, $order_rank, $limit, $per_page_num));
while ($fetch_row = $espcms_link_db->db_array_list($db_query)) {
$order_read = ESPCMS_OrderDB::get_order_view($fetch_row['oid']);
$fetch_row['ordersn'] = $order_read['ordersn'];
$fetch_row['islock'] = $order_read['islock'];
$fetch_row['shippingname'] = ESPCMS_OrderDB::get_express_view($fetch_row['osid'], 'shippingname');
$fetch_row['username'] = ESPCMS_MemberDB::get_member_noatt_view($fetch_row['userid'], 'username');
$fetch_row['edit'] = OrderLink::OrderExpress_link_array('edit', $fetch_row);
$fetch_row['view'] = OrderLink::OrderExpress_link_array('view', $fetch_row);
$fetch_row['vieworder'] = OrderLink::Order_link_array('view', $fetch_row);
$array[] = $fetch_row;
}
$espcms_admin_templates->into('array', $array);
$templates = 'order/order_express_list';
} else {
$espcms_admin_templates->into('page_db', espcms_page_db($db_table, $db_where));
$espcms_admin_templates->into('link', OrderLink::OrderExpress_link_array(false, $_REQUEST));
$templates = 'order/order_express_index';
}
$espcms_admin_templates->output($templates);
}
public static function addOrderExpress() {
global $espcms_admin_templates;
$oid = $_GET['oid'];
if (!$oid || !espcms_ismatches($oid)) {
espcms_message_err('public_pack-espcms_input_parameter_fail', array($oid));
}
$read = ESPCMS_OrderDB::get_order_view($oid);
if (!$read) {
espcms_message_err('db_pack-espcms_db_read_fail', array($oid));
}
if ($read['userid'] && espcms_ismatches($read['userid'])) {
$user_read = ESPCMS_MemberDB::get_member_noatt_view($read['userid']);
if (!$user_read) {
espcms_message_err('db_pack-espcms_db_read_fail', array($read['userid']));
}
$espcms_admin_templates->into('user_read', $user_read);
}
$express_list = ESPCMS_OrderDB::get_express_list();
$espcms_admin_templates->into('express_list', $express_list);
$espcms_admin_templates->into('read', $read);
$espcms_admin_templates->into('link', OrderLink::OrderExpress_link_array());
$espcms_admin_templates->into('token', token());
$espcms_admin_templates->output('order/order_express_add');
}
public static function editOrderExpress() {
global $espcms_admin_templates;
$osrid = $_GET['osrid'];
if (!$osrid || !espcms_ismatches($osrid)) {
espcms_message_err('public_pack-espcms_input_parameter_fail', array($osrid));
}
$db_where = "WHERE osrid=$osrid";
$db_table = ESPCMS_DB_PREFIX . 'order_shipreceipt';
$talbe_field_array = espcms_field_out($db_table, false);
$read_info = espcms_db_read($db_table, $db_where, $talbe_field_array);
$oid = $read_info['oid'];
if (!$oid || !espcms_ismatches($oid)) {
espcms_message_err('public_pack-espcms_input_parameter_fail', array($oid));
}
$read = ESPCMS_OrderDB::get_order_view($oid);
if (!$read) {
espcms_message_err('db_pack-espcms_db_read_fail', array($oid));
}
if ($read_info['userid'] && espcms_ismatches($read_info['userid'])) {
$user_read = ESPCMS_MemberDB::get_member_noatt_view($read_info['userid']);
if (!$user_read) {
espcms_message_err('db_pack-espcms_db_read_fail', array($read_info['userid']));
}
$espcms_admin_templates->into('user_read', $user_read);
}
$express_list = ESPCMS_OrderDB::get_express_list($read_info['osid']);
$espcms_admin_templates->into('express_list', $express_list);
$espcms_admin_templates->into('read_info', $read_info);
$espcms_admin_templates->into('read', $read);
$espcms_admin_templates->into('link', OrderLink::OrderExpress_link_array());
$espcms_admin_templates->into('token', token());
$espcms_admin_templates->output('order/order_express_edit');
}
public static function viewOrderExpress() {
global $espcms_admin_templates;
$osrid = $_GET['osrid'];
if (!$osrid || !espcms_ismatches($osrid)) {
espcms_message_err('public_pack-espcms_input_parameter_fail', array($osrid));
}
$db_where = "WHERE osrid=$osrid";
$db_table = ESPCMS_DB_PREFIX . 'order_shipreceipt';
$talbe_field_array = espcms_field_out($db_table, false);
$read_info = espcms_db_read($db_table, $db_where, $talbe_field_array);
$oid = $read_info['oid'];
if (!$oid || !espcms_ismatches($oid)) {
espcms_message_err('public_pack-espcms_input_parameter_fail', array($oid));
}
$read = ESPCMS_OrderDB::get_order_view($oid);
if (!$read) {
espcms_message_err('db_pack-espcms_db_read_fail', array($oid));
}
$read_info['shippingname'] = ESPCMS_OrderDB::get_express_view($read_info['osid'], 'shippingname');
$espcms_admin_templates->into('read_info', $read_info);
$espcms_admin_templates->into('read', $read);
$espcms_admin_templates->into('link', OrderLink::OrderExpress_link_array());
$espcms_admin_templates->into('token', token());
$espcms_admin_templates->output('order/order_express_view');
}
public static function saveOrderExpress() {
if (!is_token($_POST['token_name'], $_POST['token_key'])) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_repeat_fail', 'false', array($_POST['token_name']));
}
$saveType = $_POST['savetype'] ? $_POST['savetype'] : 'add';
$db_table = ESPCMS_DB_PREFIX . "order_shipreceipt";
$talbe_field_array = espcms_field_out($db_table, true);
if (!espcms_ismatches($_POST['oid']) || !$_POST['oid']) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_parameter_fail', 'false');
}
$read = ESPCMS_OrderDB::get_order_view($_POST['oid']);
if (!$read) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_parameter_fail', 'false');
}
$_POST['userid'] = $read['userid'];
if (!espcms_ismatches($_POST['userid'])) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_parameter_fail', 'false');
}
if (!espcms_ismatches($_POST['osid'])) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_parameter_fail', 'false');
}
$_POST['sendtime'] = espcms_isdata($_POST['sendtime']) ? strtotime($_POST['sendtime']) : 0;
if ($saveType == 'add') {
if (!ESPCMS_AdminAuthority::authorityVerify('addOrderExpress')) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_authority_function_fail', 'false');
}
$_POST['addtime'] = time();
$postvalue = espcms_post($_POST, $talbe_field_array, true);
if (!$postvalue || !is_array($postvalue)) {
espcms_public_dialog('espcms_public_dialog', 'db_pack-espcms_db_install_fail', 'false');
}
$install_id = espcms_db_install_save($db_table, $postvalue);
if (!$install_id) {
espcms_public_dialog('espcms_public_dialog', 'db_pack-espcms_db_install_fail', 'false');
}
$update_post['ordertype'] = 2;
$update_post['isshipping'] = 1;
$update_post['osid'] = $_POST['osid'];
$update_post['shippingsn'] = $_POST['shippingsn'];
$update_post['shippingtime'] = $_POST['sendtime'];
ESPCMS_OrderDB::order_update_type($_POST['oid'], $update_post);
espcms_log_install('order_pack-espcms_order_button_add_shipreceipt', $read['ordersn']);
espcms_public_dialog('espcms_info_save_ok', 'order_pack-espcms_order_shipping_add_save_ok_message', 'true', array($read['ordersn']));
} elseif ($saveType == 'edit') {
if (!ESPCMS_AdminAuthority::authorityVerify('editOrderExpress')) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_authority_function_fail', 'false');
}
$osrid = $_POST['osrid'];
if (empty($osrid) || !espcms_ismatches($osrid)) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_parameter_fail', 'false', array($osrid));
}
$db_where = "WHERE osrid=$osrid";
$read = espcms_db_read($db_table, $db_where, $talbe_field_array);
if (!$read) {
espcms_public_dialog('espcms_public_dialog', 'public_pack-espcms_input_parameter_fail', 'false', array($osrid));
}
unset($_POST['userid'], $_POST['oid'], $_POST['isclass'], $_POST['addtime']);
$postvalue = espcms_post($_POST, $talbe_field_array, true);
if (!$postvalue || !is_array($postvalue)) {
espcms_public_dialog('espcms_public_dialog', 'db_pack-espcms_db_install_fail', 'false');
}
$update_id = espcms_db_update_save($db_table, $db_where, $postvalue);
if (!$update_id) {
espcms_public_dialog('espcms_public_dialog', 'db_pack-espcms_db_install_fail', 'false');
}
espcms_log_install('order_pack-espcms_order_button_edit_shipreceipt', $read['ordersn']);
espcms_public_dialog('espcms_info_save_ok', 'order_pack-espcms_order_shipping_edit_save_ok_message', 'true', array($read['ordersn']));
}
}
public static function delOrderExpress() {
$select_id = $_POST['select_id'];
if (!is_array($select_id) || count($select_id) <= 0) {
espcms_public_dialog('info_set_err', 'public_pack-espcms_select_err', 'false', array($select_id));
}
$delcount = 0;
foreach ($select_id as $value) {
$operate_result = self::delOrderExpressDB($value);
if ($operate_result['code'] == 'true') {
$delcount++;
}
}
$espcms_del_id = implode(', ', $select_id);
espcms_log_install('order_pack-espcms_order_button_del_shipreceipt', $espcms_del_id);
$return['count'] = $delcount;
espcms_public_dialog('espcms_public_dialog', 'order_pack-espcms_order_shipping_del_message', 'true', array(), 'json', $return);
}
private static function delOrderExpressDB($osrid = 0) {
if (!$osrid || !espcms_ismatches($osrid)) {
$return_array = array('lan' => 'public_pack-espcms_input_parameter_fail', 'code' => 'false', 'key' => $osrid);
return $return_array;
}
$db_table = ESPCMS_DB_PREFIX . "order_shipreceipt";
$del_query = espcms_db_del($db_table, 'osrid', $osrid);
if ($del_query) {
$return_array = array('lan' => 'public_pack-espcms_del_ok', 'code' => 'true', 'key' => $osrid);
return $return_array;
} else {
$return_array = array('lan' => 'public_pack-espcms_del_err', 'code' => 'false', 'key' => $osrid);
return $return_array;
}
}
}