| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203 | <?phpnamespace Agent\Lib;use Dever;# 批量设置商品class Set{	public function __construct()    {        Dever::load('manage/auth.init');    }    # 获取名额和体验卡    public function getData($id)    {        $order_id = Dever::input('order_id');        $mid = Dever::input('mid');        $total = Dever::input('total', 1);        $col = 'role_id';        $table = 'setting/role_goods';        $value = $id;        if ($mid) {            $col = 'mid';            $table = 'agent/member_goods';            $value = $mid;        } elseif ($order_id) {            $check = Dever::db('agent/order_goods')->find(array('order_id' => $order_id));            if ($check) {                $col = 'order_id';                $table = 'agent/order_goods';                $value = $order_id;            }        }        $data = array();        $prize = Dever::db('setting/prize')->select();        if ($prize) {            $data[0]['id'] = -1;            $data[0]['name'] = '名额';            $data[0]['price'] = 0;            $data[0]['price_type'] = 2;            $data[0]['select'] = 2;            $data[0]['del'] = 1;            $data[0]['total'] = 0;            foreach ($prize as $k => $v) {                $data[0]['children'][$k]['id'] = $v['id'] . '_3';                $data[0]['children'][$k]['name'] = $v['name'];                $data[0]['children'][$k]['price'] = $v['price'];                $data[0]['children'][$k]['price_type'] = 2;                $data[0]['children'][$k]['select'] = 2;                $data[0]['children'][$k]['del'] = 1;                $data[0]['children'][$k]['total'] = 0;                $data[0]['children'][$k]['end'] = true;                $info = Dever::db($table)->find(array('type' => 3, 'type_id' => $v['id'], $col => $value));                if ($info) {                    if ($table == 'agent/member_goods') {                        //$info['num'] = $info['total_num'] - $info['sell_num'];                        $info['num'] = $info['total_num'];                    }                    $data[0]['children'][$k]['select'] = 1;                    $data[0]['children'][$k]['total'] = $info['num'] * $total;                }            }        }        $card = Dever::db('card/info')->getDataByType(array('type_id' => '1,4,6'));        if ($card) {            $data[1]['id'] = -2;            $data[1]['name'] = '厨人E卡';            $data[1]['price'] = 0;            $data[1]['price_type'] = 2;            $data[1]['select'] = 2;            $data[1]['del'] = 1;            $data[1]['total'] = 0;            foreach ($card as $k => $v) {                $data[1]['children'][$k]['id'] = $v['id'] . '_2';                $data[1]['children'][$k]['name'] = $v['name'];                $data[1]['children'][$k]['price'] = $v['price'];                $data[1]['children'][$k]['price_type'] = 2;                $data[1]['children'][$k]['select'] = 2;                $data[1]['children'][$k]['del'] = 1;                $data[1]['children'][$k]['total'] = 0;                $data[1]['children'][$k]['end'] = true;                if ($table == 'agent/member_goods') {                    $info = Dever::db($table)->select(array('type' => 2, 'type_id' => $v['id'], $col => $value));                    if ($info) {                        $num = 0;                        $data[1]['children'][$k]['price'] = 0;                        $sku_id = array();                        foreach ($info as $k1 => $v1) {                            $num += $v1['total_num'];                            if ($v1['sku_id'] > 0) {                                $code = Dever::db('card/code')->find($v1['sku_id']);                                $data[1]['children'][$k]['price'] += $code['total_cash'];                                $sku_id[] = $v1['sku_id'];                            }                        }                        $data[1]['children'][$k]['id'] = $v['id'] . '-' . implode(',', $sku_id) . '_2';;                        $data[1]['children'][$k]['select'] = 1;                        $data[1]['children'][$k]['total'] = $num;                    }                } else {                    $info = Dever::db($table)->find(array('type' => 2, 'type_id' => $v['id'], $col => $value));                    if ($info) {                        $data[1]['children'][$k]['select'] = 1;                        $data[1]['children'][$k]['total'] = $info['num'] * $total;                    }                }            }        }        $data = array_merge($data, Dever::load('goods/lib/set.getGoodsList', $value, $col, $table, 'type_id'));        return Dever::outDiy($data);    }    # 获取商品列表    public function goods_api()    {        $id = Dever::input('id', 1);        return $this->getData($id);    }    # 设置商品    public function home_api()    {        $data = array();        $data['role_id'] = Dever::input('id', 1);        $data['give'] = Dever::input('give', 1);        $data['host'] = Dever::url('lib/set.home?id=' . $data['role_id'], 'agent');        $data['url'] = Dever::url('lib/set.goods?id=' . $data['role_id'] . '&give=' . $data['give'], 'agent');        $data['search'] = Dever::db('setting/role_goods')->config['set']['give'];        $data['submit'] = Dever::url('lib/set.action_commit?json=1', 'agent');        return Dever::render('setGoods', $data);    }    # 设置生产能力    public function action_commit_api()    {        $goods = Dever::input('goods');        if (!$goods) {            Dever::alert('请传入商品');        }        $goods = Dever::json_decode($goods);        $role_id = Dever::input('role_id');        $give = Dever::input('give');        $where['option_role_id'] = $role_id;        $where['option_give'] = $give;        $where['set_state'] = 2;        Dever::db('setting/role_goods')->updates($where);        foreach ($goods as $k => $v) {            $type = 1;            $type_id = $k;            $sku_id = -1;            if (strstr($k, '_')) {                $temp = explode('_', $k);                $type_id = $temp[0];                $type = $temp[1];            } elseif (strstr($k, '-')) {                $temp = explode('-', $k);                $type_id = $temp[0];                $sku_id = $temp[1];            }                        if ($v['total'] <= 0) {            	continue;            }            $w = array();            $w['type'] = $type;            $w['type_id'] = $type_id;            $w['role_id'] = $role_id;            $w['sku_id'] = $sku_id;            $w['give'] = $give;            $info = Dever::db('setting/role_goods')->one($w);            if ($v['del'] == 2) {                if ($info) {                    Dever::db('setting/role_goods')->update(array('where_id' => $info['id'], 'state' => 2));                }            } else {            	$w['num'] = $v['total'];                                if (!$info) {                    Dever::db('setting/role_goods')->insert($w);                } else {                    $w['where_id'] = $info['id'];                    $w['state'] = 1;                    Dever::db('setting/role_goods')->update($w);                }            }        }        return 'reload';    }}
 |