feature: 添加排班
This commit is contained in:
parent
1ae192cf69
commit
962177d12e
|
|
@ -152,35 +152,53 @@ class CustomSchedule extends Backend
|
|||
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);
|
||||
|
||||
$dates = [];
|
||||
|
||||
if ($params['period'] == 'month') {
|
||||
$daysInMonth = date('t'); // 本月天数
|
||||
$month = date('Y-m'); // 当前年月
|
||||
for ($i = 1; $i <= $daysInMonth; $i++) {
|
||||
$dates[] = $month . '-' . str_pad($i, 2, '0', STR_PAD_LEFT);
|
||||
}
|
||||
} elseif ($params['period'] == 'week') {
|
||||
$start = strtotime('monday this week');
|
||||
for ($i = 0; $i < 7; $i++) {
|
||||
$dates[] = date('Y-m-d', strtotime("+$i day", $start));
|
||||
}
|
||||
} else {
|
||||
$dates = [date('Y-m-d')];
|
||||
}
|
||||
$type = $params['type'];
|
||||
$execAdminIds = explode(',', $params['exec_admin_id']);
|
||||
|
||||
$schedules = [];
|
||||
foreach ($execAdminIds as $execAdminId) {
|
||||
foreach ($dates as $date) {
|
||||
$schedules[] = [
|
||||
'exec_admin_id' => $execAdminId,
|
||||
'date' => $date,
|
||||
'type' => $type,
|
||||
];
|
||||
}
|
||||
}
|
||||
|
||||
Db::name('schedule')
|
||||
->whereIn('exec_admin_id', $execAdminIds)
|
||||
->whereIn('date', $dates)
|
||||
->delete();
|
||||
|
||||
$params['create_time'] = date('Y-m-d H:i:s');
|
||||
$params['update_time'] = date('Y-m-d H:i:s');
|
||||
Db::name('schedule')
|
||||
->insertAll($schedules);
|
||||
|
||||
|
||||
$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();
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -3,7 +3,17 @@
|
|||
<div class="form-group">
|
||||
<label class="control-label col-xs-12 col-sm-2">{:__('Exec_admin_id')}:</label>
|
||||
<div class="col-xs-12 col-sm-8">
|
||||
<input id="c-exec_admin_id" data-rule="required" data-source="auth/admin/norightselectpage" data-field="nickname" class="form-control selectpage" name="row[exec_admin_id]" type="text" value="">
|
||||
<input id="c-exec_admin_id" data-rule="required" data-multiple="multiple" data-source="auth/admin/norightselectpage" data-field="nickname" class="form-control selectpage" name="row[exec_admin_id]" type="text" value="">
|
||||
</div>
|
||||
</div>
|
||||
<div class="form-group">
|
||||
<label class="control-label col-xs-12 col-sm-2">周期</label>
|
||||
<div class="col-xs-12 col-sm-8">
|
||||
<select id="c-period" data-rule="required" class="form-control selectpicker" name="row[period]">
|
||||
<option value="day">当天</option>
|
||||
<option value="week">本周</option>
|
||||
<option value="month">本月</option>
|
||||
</select>
|
||||
</div>
|
||||
</div>
|
||||
<div class="form-group">
|
||||
|
|
@ -18,12 +28,6 @@
|
|||
|
||||
</div>
|
||||
</div>
|
||||
<div class="form-group">
|
||||
<label class="control-label col-xs-12 col-sm-2">{:__('Date')}:</label>
|
||||
<div class="col-xs-12 col-sm-8">
|
||||
<input id="c-date" data-rule="required" class="form-control datetimepicker" data-date-format="YYYY-MM-DD" data-use-current="true" name="row[date]" type="text" value="{:date('Y-m-d')}">
|
||||
</div>
|
||||
</div>
|
||||
<div class="form-group layer-footer">
|
||||
<label class="control-label col-xs-12 col-sm-2"></label>
|
||||
<div class="col-xs-12 col-sm-8">
|
||||
|
|
|
|||
|
|
@ -6,6 +6,12 @@
|
|||
<div class="tab-pane fade active in" id="one">
|
||||
<div class="widget-body no-padding">
|
||||
<div id="toolbar" class="toolbar">
|
||||
<a href="javascript:;" class="btn btn-primary btn-refresh" title="{:__('Refresh')}" ><i class="fa fa-refresh"></i> </a>
|
||||
<a href="javascript:;" class="btn btn-success btn-add {:$auth->check('oa/custom_schedule/edit')?'':'hide'}" title="{:__('Add')}" ><i class="fa fa-plus"></i> {:__('Add')}</a>
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
</div>
|
||||
<table id="table" class="table table-striped table-bordered table-hover table-nowrap"
|
||||
|
|
|
|||
|
|
@ -6,7 +6,7 @@ define(['jquery', 'bootstrap', 'backend', 'table', 'form', 'editable'], function
|
|||
Table.api.init({
|
||||
extend: {
|
||||
index_url: 'oa/custom_schedule/index' + location.search,
|
||||
// add_url: 'oa/schedule/add',
|
||||
add_url: 'oa/custom_schedule/add',
|
||||
editable: 'oa/custom_schedule/editable',
|
||||
// del_url: 'oa/schedule/del',
|
||||
// multi_url: 'oa/schedule/multi',
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user