diff --git a/application/admin/controller/kpi/Item.php b/application/admin/controller/kpi/Item.php new file mode 100644 index 0000000..4cddfc2 --- /dev/null +++ b/application/admin/controller/kpi/Item.php @@ -0,0 +1,46 @@ +model = new \app\admin\model\kpi\Item; + $this->view->assign("typeList", $this->model->getTypeList()); + $this->view->assign("unitList", $this->model->getUnitList()); + } + + /** + * 下拉搜索 + */ + public function selectpage() + { + return parent::selectpage(); + } + + + + /** + * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法 + * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑 + * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 + */ + + +} diff --git a/application/admin/controller/kpi/Template.php b/application/admin/controller/kpi/Template.php new file mode 100644 index 0000000..e5f52f4 --- /dev/null +++ b/application/admin/controller/kpi/Template.php @@ -0,0 +1,246 @@ +model = new \app\admin\model\kpi\Template; + + } + + + + /** + * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法 + * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑 + * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 + */ + + public function index() + { + //设置过滤方法 + $this->request->filter(['strip_tags', 'trim']); + if (false === $this->request->isAjax()) { + return $this->view->fetch(); + } + //如果发送的来源是 Selectpage,则转发到 Selectpage + if ($this->request->request('keyField')) { + return $this->selectpage(); + } + [$where, $sort, $order, $offset, $limit] = $this->buildparams(); + $list = $this->model + ->where($where) + ->with('kpiitem') + ->order($sort, $order) + ->paginate($limit); + + $result = ['total' => $list->total(), 'rows' => $list->items()]; + return json($result); + } + + + /** + * 添加 + * + * @return string + * @throws \think\Exception + */ + public function add() + { + if (false === $this->request->isPost()) { + return $this->view->fetch(); + } + $params = $this->request->post('row/a'); + if (empty($params)) { + $this->error(__('Parameter %s can not be empty', '')); + } + $params = $this->preExcludeFields($params); + + if ($this->dataLimit && $this->dataLimitFieldAutoFill) { + $params[$this->dataLimitField] = $this->auth->id; + } + $result = false; + Db::startTrans(); + try { + //是否采用模型验证 + if ($this->modelValidate) { + $name = str_replace("\\model\\", "\\validate\\", get_class($this->model)); + $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.add' : $name) : $this->modelValidate; + $this->model->validateFailException()->validate($validate); + } + + + $params['create_time'] = date('Y-m-d H:i:s'); + $params['update_time'] = date('Y-m-d H:i:s'); + + + $result = $this->model->allowField(true)->save($params); + if($result!==false) { + $templateId = $this->model->id; //新插入数据的ID + } + + $templateItem = []; + $kpiItems = json_decode($params['kpiitem'], true); + + foreach ($kpiItems as $kpiItem) { + $templateItem[] = [ + 'admin_id' => $this->auth->id, + 'template_id' => $templateId, + 'item_id' => $kpiItem['id'], + 'rate' => $kpiItem['rate'], + ]; + } + + Db::name('kpi_template_item') + ->insertAll($templateItem); + + Db::commit(); + } catch (ValidateException|PDOException|Exception $e) { + Db::rollback(); + $this->error($e->getMessage()); + } + if ($result === false) { + $this->error(__('No rows were inserted')); + } + $this->success(); + } + + + public function edit($ids = null) + { + $row = $this->model->get($ids); + if (!$row) { + $this->error(__('No Results were found')); + } + $adminIds = $this->getDataLimitAdminIds(); + if (is_array($adminIds) && !in_array($row[$this->dataLimitField], $adminIds)) { + $this->error(__('You have no permission')); + } + if (false === $this->request->isPost()) { + + $kpiitem = Db::name('kpi_template_item') + ->join('kpi_item', 'item_id = kpi_item.id') + ->where('template_id', $row->id) + ->select(); + + $assignKpiitem = array_map(function ($item) { + return [ + 'id' => (string)$item['id'], + 'rate' => (string)$item['rate'], + ]; + }, $kpiitem); + $assignKpiitem = json_encode($assignKpiitem); + + $this->view->assign('assignkpiitem', $assignKpiitem); + $this->view->assign('row', $row); + return $this->view->fetch(); + } + $params = $this->request->post('row/a'); + if (empty($params)) { + $this->error(__('Parameter %s can not be empty', '')); + } + $params = $this->preExcludeFields($params); + $result = false; + Db::startTrans(); + try { + //是否采用模型验证 + if ($this->modelValidate) { + $name = str_replace("\\model\\", "\\validate\\", get_class($this->model)); + $validate = is_bool($this->modelValidate) ? ($this->modelSceneValidate ? $name . '.edit' : $name) : $this->modelValidate; + $row->validateFailException()->validate($validate); + } + + $params['update_time'] = date('Y-m-d H:i:s'); + $result = $row->allowField(true)->save($params); + + $templateId = $row->id; + + $templateItem = []; + $kpiItems = json_decode($params['kpiitem'], true); + + foreach ($kpiItems as $kpiItem) { + $templateItem[] = [ + 'admin_id' => $this->auth->id, + 'template_id' => $templateId, + 'item_id' => $kpiItem['id'], + 'rate' => $kpiItem['rate'], + ]; + } + + Db::name('kpi_template_item') + ->where('template_id', $templateId) + ->delete(); + + Db::name('kpi_template_item') + ->insertAll($templateItem); + + Db::commit(); + } catch (ValidateException| \think\exception\PDOException |Exception $e) { + Db::rollback(); + $this->error($e->getMessage()); + } + if (false === $result) { + $this->error(__('No rows were updated')); + } + $this->success(); + } + + + public function del($ids = null) + { + if (false === $this->request->isPost()) { + $this->error(__("Invalid parameters")); + } + $ids = $ids ?: $this->request->post("ids"); + if (empty($ids)) { + $this->error(__('Parameter %s can not be empty', 'ids')); + } + $pk = $this->model->getPk(); + $adminIds = $this->getDataLimitAdminIds(); + if (is_array($adminIds)) { + $this->model->where($this->dataLimitField, 'in', $adminIds); + } + $list = $this->model->where($pk, 'in', $ids)->select(); + + $count = 0; + Db::startTrans(); + try { + foreach ($list as $item) { + Db::name('kpi_template_item') + ->where('template_id', $item->id) + ->delete(); + $count += $item->delete(); + } + Db::commit(); + } catch (\think\exception\PDOException |Exception $e) { + Db::rollback(); + $this->error($e->getMessage()); + } + if ($count) { + $this->success(); + } + $this->error(__('No rows were deleted')); + } + +} diff --git a/application/admin/lang/zh-cn/kpi/item.php b/application/admin/lang/zh-cn/kpi/item.php new file mode 100644 index 0000000..02ac00d --- /dev/null +++ b/application/admin/lang/zh-cn/kpi/item.php @@ -0,0 +1,18 @@ + 'ID', + 'Admin_id' => '创建人id', + 'Type' => '指标类型', + 'Type 1' => '派单员', + 'Type 2' => '运营', + 'Type 3' => '售前', + 'Name' => '名称', + 'Desc' => '描述', + 'Target_value' => '目标值', + 'Unit' => '目标值单位', + 'Unit 1' => '固定值', + 'Unit 2' => '百分比', + 'Create_time' => '创建时间', + 'Update_time' => '编辑时间' +]; diff --git a/application/admin/lang/zh-cn/kpi/template.php b/application/admin/lang/zh-cn/kpi/template.php new file mode 100644 index 0000000..86306f6 --- /dev/null +++ b/application/admin/lang/zh-cn/kpi/template.php @@ -0,0 +1,10 @@ + 'ID', + 'Admin_id' => '创建人id', + 'Name' => '名称', + 'Desc' => '描述', + 'Create_time' => '创建时间', + 'Update_time' => '编辑时间' +]; diff --git a/application/admin/model/kpi/Item.php b/application/admin/model/kpi/Item.php new file mode 100644 index 0000000..03fb6ed --- /dev/null +++ b/application/admin/model/kpi/Item.php @@ -0,0 +1,63 @@ + __('Type 1'), '2' => __('Type 2'), '3' => __('Type 3')]; + } + + public function getUnitList() + { + return ['1' => __('Unit 1'), '2' => __('Unit 2')]; + } + + + public function getTypeTextAttr($value, $data) + { + $value = $value ?: ($data['type'] ?? ''); + $list = $this->getTypeList(); + return $list[$value] ?? ''; + } + + + public function getUnitTextAttr($value, $data) + { + $value = $value ?: ($data['unit'] ?? ''); + $list = $this->getUnitList(); + return $list[$value] ?? ''; + } + + + + +} diff --git a/application/admin/model/kpi/Template.php b/application/admin/model/kpi/Template.php new file mode 100644 index 0000000..8b5554d --- /dev/null +++ b/application/admin/model/kpi/Template.php @@ -0,0 +1,45 @@ +belongsToMany('app\admin\model\kpi\item', 'kpi_template_item', 'item_id', 'template_id'); + } + + + + + + +} diff --git a/application/admin/validate/kpi/Item.php b/application/admin/validate/kpi/Item.php new file mode 100644 index 0000000..0b3dad7 --- /dev/null +++ b/application/admin/validate/kpi/Item.php @@ -0,0 +1,27 @@ + [], + 'edit' => [], + ]; + +} diff --git a/application/admin/validate/kpi/Template.php b/application/admin/validate/kpi/Template.php new file mode 100644 index 0000000..4cc1923 --- /dev/null +++ b/application/admin/validate/kpi/Template.php @@ -0,0 +1,27 @@ + [], + 'edit' => [], + ]; + +} diff --git a/application/admin/view/kpi/item/add.html b/application/admin/view/kpi/item/add.html new file mode 100644 index 0000000..f8f7c1f --- /dev/null +++ b/application/admin/view/kpi/item/add.html @@ -0,0 +1,63 @@ +
diff --git a/application/admin/view/kpi/item/edit.html b/application/admin/view/kpi/item/edit.html new file mode 100644 index 0000000..34b8497 --- /dev/null +++ b/application/admin/view/kpi/item/edit.html @@ -0,0 +1,63 @@ + diff --git a/application/admin/view/kpi/item/index.html b/application/admin/view/kpi/item/index.html new file mode 100644 index 0000000..3c822bf --- /dev/null +++ b/application/admin/view/kpi/item/index.html @@ -0,0 +1,29 @@ +