| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112 | <?phpnamespace Cash\Lib;use Dever;class Order{	# 更新结算单    public function up($order, $jstype = 1, $audit = 1, $refund = false)    {        Dever::config('base')->hook = true;        if (!$order) {            return false;        }        if ($audit == 2) {            $status = 2;        } else {            $status = 1;        }        if ($jstype == 1) {            $audit_type = 1;        } else {            $audit_type = 2;        }        $where['source_order_id'] = $order['id'];        $where['jstype'] = $jstype;        if (!$refund) {            $where['refund_id'] = -1;        } else {            $where['refund_id'] = $refund['id'];        }        $where['clear'] = true;        $info = Dever::db('cash/order')->find($where);        $update = $where;        $update['type'] = $order['type'];        $update['type_id'] = $order['type_id'];        if ($order['source_type']) {            $update['source_type'] = $order['source_type'];            $update['source_id'] = $order['source_id'];        }                $update['status'] = $status;        $update['audit'] = $audit;        $update['audit_type'] = $audit_type;        if ($update['status'] == 2) {        	$update['operdate'] = time();            $update['fdate'] = $update['operdate'];            if (isset($order['fdate']) && $order['fdate'] && ($order['status'] == 5 || $order['status'] == 6)) {                $update['fdate'] = $order['fdate'];            }        }        $update['source_order_num'] = $order['order_num'];        $update['num'] = $order['num'];        if ($refund) {            $update['cash'] = $refund['cash'];            $update['p_cash'] = isset($refund['p_cash']) ? $refund['p_cash'] : 0;        } else {            $update['cash'] = $order['price'];            $update['p_cash'] = $order['p_price'];        }        if ($jstype == 2) {            $update['cash'] = -1*$update['cash'];            $update['p_cash'] = -1*$update['p_cash'];            $update['num'] = -1*$update['num'];        }        if ($info) {        	$update['where_id'] = $info['id'];        	$state = Dever::db('cash/order')->update($update);        } else {        	$update['order_num'] = $this->getOrderId();        	$state = Dever::db('cash/order')->insert($update);        }        if ($state && $jstype == 2 && $status == 2 && isset($order['status']) && $order['status'] == 8) {            # 如果是退款结算,同时要把主订单也结算            $where = array();            $where['source_order_id'] = $order['id'];            $where['jstype'] = 1;            $where['audit'] = 1;            $where['clear'] = true;            $info = Dever::db('cash/order')->find($where);            if ($info) {                $set['status'] = 2;                $set['audit'] = 2;                $set['where_id'] = $info['id'];                $set['operdate'] = time();                $set['fdate'] = time();                Dever::db('cash/order')->update($set);            }        }    }    # 生成订单号    public function getOrderId()    {        $where['order_num'] = Dever::order('JS');        $state = Dever::db('cash/order')->one($where);        if (!$state) {            return $where['order_num'];        } else {            return $this->getOrderId();        }    }}
 |