123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245 |
- <?php
- namespace Scm\Lib;
- use Dever;
- class Order
- {
- public function updateGoods($id, $name, $data)
- {
- $table = Dever::input('table');
- $goods = Dever::param('goods', $data);
- $cash = Dever::param('cash', $data);
- if ($table && $goods) {
- $temp = explode('-', $goods);
- $update = array();
- $update['where_id'] = $id;
- $update['goods_id'] = $temp[0];
- $update['sku_id'] = $temp[1];
- $batch = Dever::param('batch', $data);
- if (!$batch) {
- $update['batch'] = date('Ymd');
- }
- if (isset($temp[2]) && !$cash) {
- //$update['cash'] = $temp[2];
- }
-
- Dever::db($table)->update($update);
- Dever::config('base')->hook = false;
- }
- }
- public function updateOrderNum($id, $name, $data)
- {
- $table = Dever::input('table');
- $prefix = Dever::input('prefix');
- if ($table && $prefix) {
- $update['order_num'] = $this->getOrderNum($table, $prefix);
- $update['where_id'] = $id;
- Dever::db($table)->update($update);
- Dever::config('base')->hook = false;
- }
- }
- # 生成订单号
- public function getOrderNum($table, $prefix = 'C')
- {
- $prefix = $prefix . ucfirst(substr($table, 0, 1));
- $where['order_num'] = Dever::order($prefix);
- $state = Dever::db($table)->one($where);
- if (!$state) {
- return $where['order_num'];
- } else {
- return $this->getOrderNum($table);
- }
- }
- # 查看订单详情
- public function show($order_table)
- {
- $id = Dever::input('order_id');
- $order_db = Dever::db($order_table);
- $order = $order_db->one($id);
- $order['config'] = $order_db->config['set'];
- $content = array();
- if (isset($order['type'])) {
- $type = Dever::db($order_table . '_type')->one($order['type']);
- $content[0][] = array('订单类型', $type['name']);
- }
- $content[0][] = array('订单状态', Dever::status($order['config']['status'], $order['status']));
- $content[0][] = array('下单时间', date('Y-m-d H:i', $order['cdate']));
- $order['info'] && $content[0][] = array('订单备注', $order['info']);
- $content[1] = $content[2] = array();
- $role = $this->show_role(array
- (
- 'seller' => '经销商',
- 'servicer' => '配送商',
- 'servicer_store' => '仓库',
- 'supplier' => '供应商',
- ), $order, $content[1]);
- $this->show_audit($order, $content[2]);
- $result = array();
- $result[$order['order_num']] = array
- (
- 'type' => 'info',
- 'content' => $content
- );
- $this->show_address($order, $role, $result);
- $this->show_goods($order, $order_table, $result);
- $head = array
- (
- 'name' => '基本信息',
- 'btn' => $this->show_button($order, $order_table),
- );
- $html = Dever::show($head, $result);
- return $html;
- }
- # 显示订单角色
- private function show_role($role, $order, &$data)
- {
- $result = array();
- foreach ($role as $k => $v) {
- $col = $k . '_id';
- if (isset($order[$col]) && $order[$col] > 0) {
- $project = $k;
- $name = 'info';
- if (strstr($k, '_')) {
- $temp = explode('_', $k);
- $project = $temp[0];
- $name = $temp[1];
- }
- $table = 'scm_' . $project . '/' . $name;
- $result[$k] = Dever::db($table)->one($order[$col]);
- if ($result[$k]) {
- $data[] = array($v, $result[$k]['name']);
- }
- }
- }
- return $result;
- }
- # 显示审核信息
- private function show_audit($order, &$data)
- {
- if (isset($order['audit_admin']) && $order['audit_admin']) {
- $admin = Dever::db('manage/admin')->find($order['audit_admin']);
- $data = array
- (
- array('审核人', $admin['username']),
- array('审核状态', Dever::status($order['config']['audit'], $order['audit'])),
- array('审核备注', $order['audit_desc']),
- );
- }
- }
- # 显示订单地址
- private function show_address($order, $role, &$result)
- {
- if (!$order['address'] && isset($role['servicer_store']['address'])) {
- $order['address'] = $role['servicer_store']['address'];
- }
- if ($order['address']) {
- $temp = explode('、', $order['address']);
- $result['收货信息'] = array
- (
- 'type' => 'info',
- 'content' => array
- (
- array
- (
- array('联系人', $temp[1]),
- array('联系电话', $temp[2]),
- array('收货地址', $temp[0]),
- ),
- ),
- );
- }
- }
- # 显示订单商品清单
- private function show_goods($order, $order_table, &$result)
- {
- $data = Dever::db($order_table . '_goods')->select(array('order_id' => $order['id']));
- if ($data) {
- $table['head'] = array('商品编码', '商品名称', '商品规格', '批次', '单价', '数量', '总价', '状态');
- $table['body'] = array();
- $total_price = $total_num = 0;
- $status = Dever::db($order_table . '_goods')->config['status'];
- foreach ($data as $k => $v) {
- $goods_info = Dever::load('scm_product/lib/info')->getBaseInfo($v['goods_id'], $v['sku_id'], $v['unit_id']);
- $status_name = Dever::status($status, $v['status']);
- $num = $v['num'];
- if ($v['status'] == 2 && $v['unit_id'] != $goods_info['base_unit_id']) {
- if (!isset($order['supplier_id'])) {
- $order['supplier_id'] = false;
- }
- $unit = Dever::load('scm/lib/unit')->convertBase($v['goods_id'], $v['sku_id'], $v['unit_id'], $v['num'], $v['cash'], 0, $order['supplier_id']);
- if ($unit) {
- $base_unit = Dever::db('scm/unit')->find($unit['unit_id']);
- $goods_info['unit'] .= ' => '.$unit['num'].''.$base_unit['name'].'';
- $num = $unit['num'];
- }
- }
- $sdate = isset($v['sdate']) && $v['sdate'] ? '[' . date('Y-m-d', $v['sdate']) . '生产]' : '';
- $cash = Dever::number($v['cash'] * $v['num']);
- $detail = array
- (
- $goods_info['code'],
- $goods_info['name'],
- $goods_info['spec_name'],
- $v['batch'] . $sdate,
- $v['cash'],
- $v['num'] . $goods_info['unit'],
- $cash,
- $status_name,
- );
- if ($goods_info['goods']) {
- $detail['goods'] = $goods_info['goods'];
- }
- $table['body'][] = $detail;
- $total_price += $cash;
- $total_num += $num;
- }
- $result['商品清单'] = array
- (
- 'type' => 'table',
- 'head' => array('name' => '', 'btn' => ''),
- 'content' => $table,
- 'total' => '合计金额:' . Dever::number($total_price) . ',合计数量:' . $total_num
- );
- }
- }
- # 显示按钮
- private function show_button($order, $order_table)
- {
- $button = array();
- if ($order['status'] == 1) {
- list($project, $table) = explode('/', $order_table);
- $url = Dever::url('project/database/update?project='.$project.'&table='.$table.'&where_id='.$order['id'].'&col=audit,audit_desc', 'manage');
- $button[] = array
- (
- 'type' => 'edit',
- 'link' => $url,
- 'name' => '审核',
- );
- }
- return $button;
- }
- }
|