123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264 |
- <?php
- namespace app\admin\controller;
- use think\facade\Db;
- use think\facade\Validate;
- class CompanyCatProfit extends Base
- {
-
- public function getList()
- {
- $param = $this->request->only(['page' => 1, 'size' => 10, 'companyNo' => '', 'cat_name' => '', 'pid' => 0], 'post', 'trim');
- if ($param['companyNo'] == '') return json_show(1004, '业务公司编号不能为空');
- $where = [['a.is_del', '=', 0], ['a.pid', '=', $param['pid']]];
- if ($param['cat_name'] !== '') $where[] = ['a.cat_name', 'like', '%' . $param['cat_name'] . '%'];
- $count = Db::name('cat')
- ->alias('a')
- ->leftJoin('company_cat_profit b', 'b.cat_id=a.id AND companyNo=\'' . $param['companyNo'] . '\'')
- ->where($where)
- ->count('a.id');
- $list = Db::name('cat')
- ->alias('a')
- ->field('a.id cat_id,a.cat_name,a.level,b.rate,b.order_rate,b.money_rate,b.low_rate,b.sale_rate,b.status')
- ->leftJoin('company_cat_profit b', 'b.is_del=0 AND b.cat_id=a.id AND companyNo=\'' . $param['companyNo'] . '\'')
- ->where($where)
- ->withAttr('status', function ($val) {
- return (int)$val;
- })
- ->order('a.id', 'desc')
- ->page($param['page'], $param['size'])
- ->select()
- ->toArray();
- return json_show(0, '获取列表成功', ['count' => $count, 'list' => $list]);
- }
-
- public function set()
- {
- $param = $this->request->only(['cat_id', 'companyNo', 'rate', 'order_rate', 'money_rate', 'low_rate', 'sale_rate'], 'post', 'trim');
- $val = Validate::rule([
- 'cat_id|分类id' => 'require|number|gt:0',
- 'companyNo|公司编码' => 'require|length:18',
- 'rate|主管利率' => 'require|float|between:0,100',
- 'order_rate|预算成本' => 'require|float|between:0,100',
- 'money_rate|财务利率' => 'require|float|between:0,100',
- 'low_rate|最低利率' => 'require|float|between:0,100',
- 'sale_rate|成本售价' => 'require|float|between:0,100',
- ]);
- if (!$val->check($param)) return json_show(1004, $val->getError());
- $tmp = Db::name('company_cat_profit')
- ->field('id')
- ->where(['is_del' => 0, 'companyNo' => $param['companyNo'], 'cat_id' => $param['cat_id']])
- ->findOrEmpty();
- $date = date('Y-m-d H:i:s');
- if (empty($tmp)) {
- $rs = Db::name('company_cat_profit')
- ->insert([
- 'companyNo' => $param['companyNo'],
- 'cat_id' => $param['cat_id'],
- 'rate' => $param['rate'],
- 'order_rate' => $param['order_rate'],
- 'money_rate' => $param['money_rate'],
- 'low_rate' => $param['low_rate'],
- 'sale_rate' => $param['sale_rate'],
- 'status' => 0,
- 'is_del' => 0,
- 'addtime' => $date,
- 'updatetime' => $date
- ]);
- } else {
- $rs = Db::name('company_cat_profit')
- ->where(['is_del' => 0, 'id' => $tmp['id']])
- ->update([
- 'rate' => $param['rate'],
- 'order_rate' => $param['order_rate'],
- 'money_rate' => $param['money_rate'],
- 'low_rate' => $param['low_rate'],
- 'sale_rate' => $param['sale_rate'],
- 'updatetime' => $date
- ]);
- }
- return $rs ? json_show(0, '设置成功') : json_show(1004, '设置失败');
- }
-
- public function status()
- {
- $param = $this->request->only(['cat_id', 'companyNo', 'status'], 'post', 'trim');
- $val = Validate::rule([
- 'cat_id|分类id' => 'require|number|gt:0',
- 'companyNo|公司编码' => 'require|length:18',
- 'status|状态' => 'require|number|in:0,1',
- ]);
- if ($val->check($param) == false) return json_show(1004, $val->getError());
- $cat = Db::name('cat')
- ->field('id,level')
- ->where(['id' => $param['cat_id'], 'is_del' => 0])
- ->findOrEmpty();
- if (empty($cat)) return json_show(1005, '该分类不存在');
- $tmp = Db::name('company_cat_profit')
- ->field('id,status')
- ->where(['is_del' => 0, 'companyNo' => $param['companyNo'], 'cat_id' => $param['cat_id']])
- ->findOrEmpty();
- if (empty($tmp)) return json_show(1004, '该分类尚未设置毛利,无法操作');
- if ($tmp['status'] == $param['status']) return json_show(1004, '重复操作');
-
- switch ($cat['level']) {
- case 1:
- $first_ids = Db::name('cat')
- ->where(['is_del' => 0, 'pid' => $param['cat_id']])
- ->column('id');
- $second_ids = Db::name('cat')
- ->where('is_del', 0)
- ->whereIn('pid', $first_ids)
- ->column('id');
- $cat_ids = array_merge($first_ids, $second_ids);
- break;
- case 2:
- $cat_ids = Db::name('cat')
- ->where(['is_del' => 0, 'pid' => $param['cat_id']])
- ->column('id');
- break;
- }
- $cat_ids[] = $param['cat_id'];
- $rs = Db::name('company_cat_profit')
- ->where(['is_del' => 0, 'companyNo' => $param['companyNo']])
- ->whereIn('cat_id', $cat_ids)
- ->where('status', '<>', $param['status'])
- ->update([
- 'status' => $param['status'],
- 'updatetime' => date('Y-m-d H:i:s')
- ]);
- return $rs ? json_show(0, '操作成功') : json_show(1004, '操作失败,该记录不存在或重复操作');
- }
-
- public function delete()
- {
- $param = $this->request->only(['cat_id', 'companyNo'], 'post', 'trim');
- $val = Validate::rule([
- 'cat_id|分类id' => 'require|number|gt:0',
- 'companyNo|公司编码' => 'require|length:18',
- ]);
- if ($val->check($param) == false) return json_show(1004, $val->getError());
- $rs = Db::name('company_cat_profit')
- ->where(['is_del' => 0, 'companyNo' => $param['companyNo'], 'cat_id' => $param['cat_id']])
- ->update([
- 'is_del' => 1,
- 'updatetime' => date('Y-m-d H:i:s')
- ]);
- return $rs ? json_show(0, '删除成功') : json_show(1004, '删除失败');
- }
-
- public function getListByCompany()
- {
- $param = $this->request->only(['companyNo', 'cat_name' => '', 'page' => 1, 'size' => 10], 'post', 'trim');
- $val = Validate::rule([
- 'companyNo|公司编码' => 'require|length:18',
- 'cat_name|分类名称' => 'max:255'
- ]);
- if ($val->check($param) == false) return json_show(1004, $val->getError());
- $where = [
- ['a.companyNo', '=', $param['companyNo']],
- ['a.is_del', '=', 0],
- ['b.level', '=', 3],
- ];
- if ($param['cat_name'] !== '') $where[] = ['b.search', 'like', '%' . $param['cat_name'] . '%'];
-
- $count = Db::name('company_cat_profit')
- ->alias('a')
- ->leftJoin('cat b', 'b.id=a.cat_id')
- ->where($where)
- ->count('a.id');
- $list = Db::name('company_cat_profit')
- ->alias('a')
- ->leftJoin('cat b', 'b.id=a.cat_id')
- ->field('a.id,b.search cat_name,a.cat_id,a.rate,a.order_rate,a.money_rate,a.low_rate,a.sale_rate,a.status')
- ->where($where)
- ->order(['a.id' => 'desc'])
- ->page($param['page'], $param['size'])
- ->select()
- ->toArray();
- return json_show(0, '获取成功', ['count' => $count, 'list' => $list]);
- }
- }
|