From b740f4ad8fdf72111e0bc79bfa5cf8cdaaf1c6be Mon Sep 17 00:00:00 2001 From: zhuyu Date: Thu, 6 Mar 2025 16:37:44 +0800 Subject: [PATCH 01/21] feature: task --- application/admin/controller/Task.php | 37 ++++++++++++++++++ application/admin/lang/zh-cn/task.php | 12 ++++++ application/admin/model/Task.php | 49 +++++++++++++++++++++++ application/admin/validate/Task.php | 27 +++++++++++++ application/admin/view/task/add.html | 39 +++++++++++++++++++ application/admin/view/task/edit.html | 39 +++++++++++++++++++ application/admin/view/task/index.html | 46 ++++++++++++++++++++++ public/assets/js/backend/task.js | 54 ++++++++++++++++++++++++++ 8 files changed, 303 insertions(+) create mode 100644 application/admin/controller/Task.php create mode 100644 application/admin/lang/zh-cn/task.php create mode 100644 application/admin/model/Task.php create mode 100644 application/admin/validate/Task.php create mode 100644 application/admin/view/task/add.html create mode 100644 application/admin/view/task/edit.html create mode 100644 application/admin/view/task/index.html create mode 100644 public/assets/js/backend/task.js diff --git a/application/admin/controller/Task.php b/application/admin/controller/Task.php new file mode 100644 index 0000000..951601f --- /dev/null +++ b/application/admin/controller/Task.php @@ -0,0 +1,37 @@ +model = new \app\admin\model\Task; + $this->view->assign("statusList", $this->model->getStatusList()); + } + + + + /** + * 默认生成的控制器所继承的父类中有index/add/edit/del/multi五个基础方法、destroy/restore/recyclebin三个回收站方法 + * 因此在当前控制器中可不用编写增删改查的代码,除非需要自己控制这部分逻辑 + * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 + */ + + +} diff --git a/application/admin/lang/zh-cn/task.php b/application/admin/lang/zh-cn/task.php new file mode 100644 index 0000000..b108570 --- /dev/null +++ b/application/admin/lang/zh-cn/task.php @@ -0,0 +1,12 @@ + 'ID', + 'Status' => '状态', + 'Status 1' => '未完成', + 'Set status to 1'=> '设为未完成', + 'Status 2' => '已完成', + 'Set status to 2'=> '设为已完成', + 'Create_time' => '创建时间', + 'Update_time' => '编辑时间' +]; diff --git a/application/admin/model/Task.php b/application/admin/model/Task.php new file mode 100644 index 0000000..ec49dd9 --- /dev/null +++ b/application/admin/model/Task.php @@ -0,0 +1,49 @@ + __('Status 1'), '2' => __('Status 2')]; + } + + + public function getStatusTextAttr($value, $data) + { + $value = $value ?: ($data['status'] ?? ''); + $list = $this->getStatusList(); + return $list[$value] ?? ''; + } + + + + +} diff --git a/application/admin/validate/Task.php b/application/admin/validate/Task.php new file mode 100644 index 0000000..05f2c4c --- /dev/null +++ b/application/admin/validate/Task.php @@ -0,0 +1,27 @@ + [], + 'edit' => [], + ]; + +} diff --git a/application/admin/view/task/add.html b/application/admin/view/task/add.html new file mode 100644 index 0000000..93a9487 --- /dev/null +++ b/application/admin/view/task/add.html @@ -0,0 +1,39 @@ +
+ +
+ +
+ +
+ {foreach name="statusList" item="vo"} + + {/foreach} +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ +
diff --git a/application/admin/view/task/edit.html b/application/admin/view/task/edit.html new file mode 100644 index 0000000..9da9b12 --- /dev/null +++ b/application/admin/view/task/edit.html @@ -0,0 +1,39 @@ +
+ +
+ +
+ +
+ {foreach name="statusList" item="vo"} + + {/foreach} +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+
+ +
+ +
+
+ +
diff --git a/application/admin/view/task/index.html b/application/admin/view/task/index.html new file mode 100644 index 0000000..49a3519 --- /dev/null +++ b/application/admin/view/task/index.html @@ -0,0 +1,46 @@ +
+ +
+ {:build_heading(null,FALSE)} + +
+ + +
+
+
+
+
+ + {:__('Add')} + {:__('Edit')} + {:__('Delete')} + + + + + +
+ +
+
+
+ +
+
+
diff --git a/public/assets/js/backend/task.js b/public/assets/js/backend/task.js new file mode 100644 index 0000000..37d62fa --- /dev/null +++ b/public/assets/js/backend/task.js @@ -0,0 +1,54 @@ +define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefined, Backend, Table, Form) { + + var Controller = { + index: function () { + // 初始化表格参数配置 + Table.api.init({ + extend: { + index_url: 'task/index' + location.search, + add_url: 'task/add', + edit_url: 'task/edit', + del_url: 'task/del', + multi_url: 'task/multi', + import_url: 'task/import', + table: 'task', + } + }); + + var table = $("#table"); + + // 初始化表格 + table.bootstrapTable({ + url: $.fn.bootstrapTable.defaults.extend.index_url, + pk: 'id', + sortName: 'id', + columns: [ + [ + {checkbox: true}, + {field: 'id', title: __('Id')}, + {field: 'status', title: __('Status'), searchList: {"1":__('Status 1'),"2":__('Status 2')}, formatter: Table.api.formatter.status}, + {field: 'name', title: __('Name'), operate: 'LIKE'}, + {field: 'create_time', title: __('Create_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false}, + {field: 'update_time', title: __('Update_time'), operate:'RANGE', addclass:'datetimerange', autocomplete:false}, + {field: 'operate', title: __('Operate'), table: table, events: Table.api.events.operate, formatter: Table.api.formatter.operate} + ] + ] + }); + + // 为表格绑定事件 + Table.api.bindevent(table); + }, + add: function () { + Controller.api.bindevent(); + }, + edit: function () { + Controller.api.bindevent(); + }, + api: { + bindevent: function () { + Form.api.bindevent($("form[role=form]")); + } + } + }; + return Controller; +}); From bf23a696264e184732ac272d93271b0700b29f72 Mon Sep 17 00:00:00 2001 From: zhuyu Date: Mon, 10 Mar 2025 22:04:09 +0800 Subject: [PATCH 02/21] feature: task --- application/admin/controller/Task.php | 47 ++++++++++++++++++++++++ application/admin/lang/zh-cn/task.php | 31 +++++++++++----- application/admin/model/Task.php | 30 +++++++++++++++- application/admin/view/task/add.html | 32 ++++++++++------- application/admin/view/task/edit.html | 52 +++++++++++++++++++++++++-- public/assets/js/backend/task.js | 11 +++++- 6 files changed, 178 insertions(+), 25 deletions(-) diff --git a/application/admin/controller/Task.php b/application/admin/controller/Task.php index 951601f..87074da 100644 --- a/application/admin/controller/Task.php +++ b/application/admin/controller/Task.php @@ -3,6 +3,9 @@ namespace app\admin\controller; use app\common\controller\Backend; +use think\Db; +use think\exception\PDOException; +use think\exception\ValidateException; /** * 任务 @@ -22,7 +25,9 @@ class Task extends Backend { parent::_initialize(); $this->model = new \app\admin\model\Task; + $this->view->assign("typeList", $this->model->getTypeList()); $this->view->assign("statusList", $this->model->getStatusList()); + $this->view->assign("reviewStatusList", $this->model->getReviewStatusList()); } @@ -33,5 +38,47 @@ class Task extends Backend * 需要将application/admin/library/traits/Backend.php中对应的方法复制到当前控制器,然后进行修改 */ + 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['admin_id'] = $this->auth->id; + $params['status'] = 1; + $params['review_status'] = 1; + $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); + Db::commit(); + } catch (ValidateException|PDOException|Exception $e) { + Db::rollback(); + $this->error($e->getMessage()); + } + if ($result === false) { + $this->error(__('No rows were inserted')); + } + $this->success(); + } } diff --git a/application/admin/lang/zh-cn/task.php b/application/admin/lang/zh-cn/task.php index b108570..a629a6a 100644 --- a/application/admin/lang/zh-cn/task.php +++ b/application/admin/lang/zh-cn/task.php @@ -1,12 +1,27 @@ 'ID', - 'Status' => '状态', - 'Status 1' => '未完成', - 'Set status to 1'=> '设为未完成', - 'Status 2' => '已完成', - 'Set status to 2'=> '设为已完成', - 'Create_time' => '创建时间', - 'Update_time' => '编辑时间' + 'Id' => 'ID', + 'Admin_id' => '提交人ID', + 'Reviewer_id' => '审核人ID', + 'Type' => '任务类型', + 'Type 1' => '每日任务', + 'Type 2' => '每周任务', + 'Type 3' => '每月任务', + 'Title' => '任务标题', + 'Desc' => '任务描述', + 'Status' => '状态', + 'Status 1' => '待完成', + 'Set status to 1' => '设为待完成', + 'Status 2' => '已完成', + 'Set status to 2' => '设为已完成', + 'Review_status' => '状态', + 'Review_status 1' => '待审核', + 'Review_status 2' => '已通过', + 'Review_status 3' => '已驳回', + 'Review_status 4' => '未执行', + 'Expire_start_time' => '有效期开始时间', + 'Expire_end_time' => '有效期结束时间', + 'Create_time' => '创建时间', + 'Update_time' => '编辑时间' ]; diff --git a/application/admin/model/Task.php b/application/admin/model/Task.php index ec49dd9..40177df 100644 --- a/application/admin/model/Task.php +++ b/application/admin/model/Task.php @@ -25,16 +25,36 @@ class Task extends Model // 追加属性 protected $append = [ - 'status_text' + 'type_text', + 'status_text', + 'review_status_text' ]; + public function getTypeList() + { + return ['1' => __('Type 1'), '2' => __('Type 2'), '3' => __('Type 3')]; + } + public function getStatusList() { return ['1' => __('Status 1'), '2' => __('Status 2')]; } + public function getReviewStatusList() + { + return ['1' => __('Review_status 1'), '2' => __('Review_status 2'), '3' => __('Review_status 3'), '4' => __('Review_status 4')]; + } + + + public function getTypeTextAttr($value, $data) + { + $value = $value ?: ($data['type'] ?? ''); + $list = $this->getTypeList(); + return $list[$value] ?? ''; + } + public function getStatusTextAttr($value, $data) { @@ -44,6 +64,14 @@ class Task extends Model } + public function getReviewStatusTextAttr($value, $data) + { + $value = $value ?: ($data['review_status'] ?? ''); + $list = $this->getReviewStatusList(); + return $list[$value] ?? ''; + } + + } diff --git a/application/admin/view/task/add.html b/application/admin/view/task/add.html index 93a9487..ec8f8c3 100644 --- a/application/admin/view/task/add.html +++ b/application/admin/view/task/add.html @@ -1,33 +1,39 @@
- +
- -
- {foreach name="statusList" item="vo"} - - {/foreach} -
+ +
- +
- +
- +
- +
- +
- + +
+
+
+ +
+
-
- -
- -
- {foreach name="statusList" item="vo"} - - {/foreach} -
- -
-
-
- -
- -
-
- +
- -
-
-
- -
- -
-
-
- -
- -
-
-
- -
- +
diff --git a/public/assets/js/backend/oa/schedule.js b/public/assets/js/backend/oa/schedule.js index a54c578..43fc936 100644 --- a/public/assets/js/backend/oa/schedule.js +++ b/public/assets/js/backend/oa/schedule.js @@ -99,18 +99,51 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin // 为表格绑定事件 Table.api.bindevent(table); - // 指定搜索条件 $(document).on("click", ".btn-block", function () { - var timetype = $("#c-flag").val(); - let options = $table.bootstrapTable('getOptions'); - table.bootstrapTable('refreshOptions', { - columns: [{ + let selectedValue = $('#c-flag').val(); + + let changeColumn = []; + if (selectedValue == 2) { + changeColumn = [{ "title":"username", "field":"name", - }], - searchFormTemplate: options.searchFormTemplate + }]; + } else { + changeColumn = [{ + "title":"username", + "field":"name", + }]; + const startDate = new Date("2025-02-22"); + const endDate = new Date("2025-03-22"); + + for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) { + let tmpDate = d.toISOString().split('T')[0]; // 使用 d,而不是 date + changeColumn.push({ + "title": tmpDate, + "field": tmpDate, + }); + } + } + + var options = table.bootstrapTable('getOptions'); + var queryParams = options.queryParams; + options.queryParams = function (params) { + //这一行必须要存在,否则在点击下一页时会丢失搜索栏数据 + params = queryParams(params); + + var filter = params.filter ? JSON.parse(params.filter) : {}; + filter.timetype = selectedValue; + + params.filter = JSON.stringify(filter); + return params; + }; + + table.bootstrapTable('refreshOptions', { + columns: changeColumn, }); + + $('#c-flag').val(selectedValue).change(); return false; }); }, From a41e1e5408cc94066492728eeb87432991c90c96 Mon Sep 17 00:00:00 2001 From: zhuyu Date: Fri, 28 Mar 2025 11:11:22 +0800 Subject: [PATCH 15/21] feature: task --- application/admin/controller/oa/Schedule.php | 19 ++++++------ public/assets/js/backend/oa/schedule.js | 32 +++++++++++--------- 2 files changed, 28 insertions(+), 23 deletions(-) diff --git a/application/admin/controller/oa/Schedule.php b/application/admin/controller/oa/Schedule.php index d594740..b65b0ae 100644 --- a/application/admin/controller/oa/Schedule.php +++ b/application/admin/controller/oa/Schedule.php @@ -78,8 +78,16 @@ class Schedule extends Backend if ($this->request->isAjax()) { - $startDate = '2025-02-22'; - $endDate = '2025-03-22'; + $filter = $this->request->param('filter'); + $filter = json_decode($filter, true); + + $startDate = date('Y-m-01'); + $endDate = date('Y-m-t'); + + if (isset($filter['timetype']) && $filter['timetype'] == 2) { + $startDate = date('Y-m-d', strtotime('monday this week')); + $endDate = date('Y-m-d', strtotime('sunday this week')); + } $res = []; $admins = Db::name('admin')->field('id,nickname')->select(); @@ -127,13 +135,6 @@ class Schedule extends Backend $res = array_values($res); - - $filter = $this->request->param('filter'); - $filter = json_decode($filter, true); - if (isset($filter['timetype']) && $filter['timetype'] == 2) { - unset($res[2]); - } - $result = array("total" => count($res), "rows" => $res); return json($result); diff --git a/public/assets/js/backend/oa/schedule.js b/public/assets/js/backend/oa/schedule.js index 43fc936..0803dbd 100644 --- a/public/assets/js/backend/oa/schedule.js +++ b/public/assets/js/backend/oa/schedule.js @@ -71,18 +71,22 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin var table = $("#table"); - var columnArr = []; - columnArr.push({ + var defaultColumnArr = []; + defaultColumnArr.push({ "title":"username", "field":"name", }); - const startDate = new Date("2025-02-22"); - const endDate = new Date("2025-03-22"); + const startDate = new Date(new Date().setDate(1)); + const endDate = new Date(new Date().getFullYear(), new Date().getMonth() + 1, 0); + + console.log('Start Date:', startDate); + console.log('End Date:', endDate); for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) { - let tmpDate = d.toISOString().split('T')[0]; // 使用 d,而不是 date - columnArr.push({ + let tmpDate = d.toISOString().split('T')[0]; + console.log('Current Date:', tmpDate); + defaultColumnArr.push({ "title": tmpDate, "field": tmpDate, }); @@ -91,7 +95,7 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin // 初始化表格 table.bootstrapTable({ url: $.fn.bootstrapTable.defaults.extend.index_url, - columns: columnArr, + columns: defaultColumnArr, searchFormVisible: true, searchFormTemplate: 'customformtpl', }); @@ -109,13 +113,10 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin "title":"username", "field":"name", }]; - } else { - changeColumn = [{ - "title":"username", - "field":"name", - }]; - const startDate = new Date("2025-02-22"); - const endDate = new Date("2025-03-22"); + + const today = new Date(); + const startDate = new Date(today.setDate(today.getDate() - today.getDay() + 1)); // 星期一 + const endDate = new Date(today.setDate(today.getDate() - today.getDay() + 7)); // 星期天 for (let d = new Date(startDate); d <= endDate; d.setDate(d.getDate() + 1)) { let tmpDate = d.toISOString().split('T')[0]; // 使用 d,而不是 date @@ -124,6 +125,9 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form'], function ($, undefin "field": tmpDate, }); } + + } else { + changeColumn = defaultColumnArr; } var options = table.bootstrapTable('getOptions'); From 7e535c03b0072880789eaaf0f03b86cbf716f772 Mon Sep 17 00:00:00 2001 From: zhuyu Date: Sun, 30 Mar 2025 17:59:00 +0800 Subject: [PATCH 16/21] feature: task --- application/admin/controller/oa/Task.php | 66 ++++++++++++++ application/admin/lang/zh-cn/oa/task.php | 7 +- application/admin/model/oa/Task.php | 2 +- application/admin/view/oa/task/add.html | 43 ---------- application/admin/view/oa/task/edit.html | 66 -------------- public/assets/js/backend/oa/schedule.js | 18 +--- public/assets/js/backend/oa/task.js | 105 +++++++++++++++++++---- 7 files changed, 158 insertions(+), 149 deletions(-) diff --git a/application/admin/controller/oa/Task.php b/application/admin/controller/oa/Task.php index 7ed0e46..4465789 100644 --- a/application/admin/controller/oa/Task.php +++ b/application/admin/controller/oa/Task.php @@ -69,4 +69,70 @@ class Task extends Backend return $this->view->fetch(); } + public function complete($ids) + { + if (false === $this->request->isPost()) { + $this->error(__("Invalid parameters")); + } + + if (empty($ids)) { + $this->error(__('Parameter %s can not be empty', 'id')); + } + + $task = $this->model->where('id', '=', $ids)->where('status', 1)->find(); + + if (!$task) { + $this->error('任务状态已变更,请刷新后操作'); + } + $task->save(['status' => 3]); + + $this->success(); + } + + public function pass($ids) + { + if (false === $this->request->isPost()) { + $this->error(__("Invalid parameters")); + } + + if (empty($ids)) { + $this->error(__('Parameter %s can not be empty', 'id')); + } + + $task = $this->model->where('id', '=', $ids)->where('status', 3)->find(); + + if (!$task) { + $this->error('任务状态已变更,请刷新后操作'); + } + $task->save(['status' => 4]); + + $this->success(); + } + + public function abort($ids) + { + if (false === $this->request->isPost()) { + $this->error(__("Invalid parameters")); + } + + if (empty($ids)) { + $this->error(__('Parameter %s can not be empty', 'id')); + } + + $reason = $this->request->post('remark'); + if (empty($reason)) { + $this->error('驳回原因不能为空'); + } + + $task = $this->model->where('id', '=', $ids)->where('status', 3)->find(); + + if (!$task) { + $this->error('任务状态已变更,请刷新后操作'); + } + $task->save(['status' => 5, 'refuse_reason' => $reason]); + + $this->success(); + } + + } diff --git a/application/admin/lang/zh-cn/oa/task.php b/application/admin/lang/zh-cn/oa/task.php index 08c8b86..ba93a5b 100644 --- a/application/admin/lang/zh-cn/oa/task.php +++ b/application/admin/lang/zh-cn/oa/task.php @@ -3,7 +3,7 @@ return [ 'Id' => 'ID', 'Admin_id' => '创建人id', - 'Exec_admin_id' => '执行人id', + 'Review_admin_id' => '审核人id', 'Type' => '任务类型', 'Type 1' => '每日任务', 'Type 2' => '每周任务', @@ -21,8 +21,8 @@ return [ 'Set status to 4' => '设为已通过', 'Status 5' => '已驳回', 'Set status to 5' => '设为已驳回', - 'Status 6' => '未执行', - 'Set status to 6' => '设为未执行', + 'Status 6' => '待执行', + 'Set status to 6' => '设为待执行', 'Refuse_reason' => '驳回原因', 'Expire_start_time' => '有效期开始时间', 'Expire_end_time' => '有效期结束时间', @@ -34,6 +34,7 @@ return [ 'Admin.nickname' => '昵称', 'Admin.password' => '密码', 'Admin.salt' => '密码盐', + 'Admin.area_ids' => '地区ID,英文逗号分隔', 'Admin.avatar' => '头像', 'Admin.email' => '电子邮箱', 'Admin.mobile' => '手机号码', diff --git a/application/admin/model/oa/Task.php b/application/admin/model/oa/Task.php index 43fa03e..c536521 100644 --- a/application/admin/model/oa/Task.php +++ b/application/admin/model/oa/Task.php @@ -62,6 +62,6 @@ class Task extends Model public function admin() { - return $this->belongsTo('app\admin\model\Admin', 'exec_admin_id', 'id', [], 'LEFT')->setEagerlyType(0); + return $this->belongsTo('app\admin\model\Admin', 'admin_id', 'id', [], 'LEFT')->setEagerlyType(0); } } diff --git a/application/admin/view/oa/task/add.html b/application/admin/view/oa/task/add.html index 175f2ee..3ddd5c7 100644 --- a/application/admin/view/oa/task/add.html +++ b/application/admin/view/oa/task/add.html @@ -1,11 +1,4 @@
- -
- -
- -
-
@@ -30,24 +23,6 @@
-
- -
- -
- {foreach name="statusList" item="vo"} - - {/foreach} -
- -
-
-
- -
- -
-
@@ -60,24 +35,6 @@
-
- -
- -
-
-
- -
- -
-
-
- -
- -
-