Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
A
attendance-performance-platform
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
赵啸非
attendance-performance-platform
Commits
c34a1512
Commit
c34a1512
authored
Jul 18, 2023
by
赵啸非
Browse files
Options
Browse Files
Download
Plain Diff
Merge remote-tracking branch 'origin/master'
parents
6f9308d0
6e924bf4
Changes
5
Hide whitespace changes
Inline
Side-by-side
Showing
5 changed files
with
484 additions
and
367 deletions
+484
-367
attendance-performance-manager-ui/admin/src/views/attendance/class/detail/drawershow.vue
...ui/admin/src/views/attendance/class/detail/drawershow.vue
+154
-117
attendance-performance-manager-ui/admin/src/views/attendance/class/dialogshow.vue
...anager-ui/admin/src/views/attendance/class/dialogshow.vue
+17
-17
attendance-performance-manager-ui/admin/src/views/attendance/class/drawershow.vue
...anager-ui/admin/src/views/attendance/class/drawershow.vue
+309
-228
attendance-performance-manager-ui/admin/src/views/homeCharts/record/list.vue
...nce-manager-ui/admin/src/views/homeCharts/record/list.vue
+3
-3
attendance-performance-manager-ui/admin/src/views/perform/rules/attend/components/AttendIndex.vue
...src/views/perform/rules/attend/components/AttendIndex.vue
+1
-2
No files found.
attendance-performance-manager-ui/admin/src/views/attendance/class/detail/drawershow.vue
View file @
c34a1512
<
template
>
<
template
>
<!-- 弹出框表单 -->
<!-- 弹出框表单 -->
<el-drawer
<el-drawer
:title=
"title"
:title=
"title"
:visible.sync=
"open"
:visible.sync=
"open"
:direction=
"direction"
:direction=
"direction"
size=
"50%"
>
size=
"50%"
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"120px"
>
>
<el-row>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"120px"
>
<Field
label=
"班次ID"
prop=
"shiftsId"
v-model=
"form.shiftsId"
placeholder=
"请输入班次ID"
/>
<el-row>
<Field
label=
"班次名称"
prop=
"shiftsName"
v-model=
"form.shiftsName"
placeholder=
"请输入班次名称"
/>
<Field
<Field
label=
"上班打卡时间"
prop=
"goWorkDate"
v-model=
"form.goWorkDate"
type=
"date"
/>
label=
"班次ID"
<Field
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateBefore"
v-model=
"form.goWorkDateBefore"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
prop=
"shiftsId"
<Field
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateAfter"
v-model=
"form.goWorkDateAfter"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
v-model=
"form.shiftsId"
<Field
label=
"下班打卡时间"
prop=
"offWorkDate"
v-model=
"form.offWorkDate"
type=
"date"
/>
placeholder=
"请输入班次ID"
<Field
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateBefore"
v-model=
"form.offWorkDateBefore"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
/>
<Field
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateAfter"
v-model=
"form.offWorkDateAfter"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
<Field
<Field
label=
"备注"
prop=
"remark"
v-model=
"form.remark"
type=
"textarea"
placeholder=
"请输入备注"
/>
label=
"班次名称"
prop=
"shiftsName"
v-model=
"form.shiftsName"
placeholder=
"请输入班次名称"
/>
<Field
label=
"上班打卡时间"
prop=
"goWorkDate"
v-model=
"form.goWorkDate"
type=
"date"
/>
<Field
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateBefore"
v-model=
"form.goWorkDateBefore"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
<Field
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateAfter"
v-model=
"form.goWorkDateAfter"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
<Field
label=
"下班打卡时间"
prop=
"offWorkDate"
v-model=
"form.offWorkDate"
type=
"date"
/>
<Field
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateBefore"
v-model=
"form.offWorkDateBefore"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
<Field
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateAfter"
v-model=
"form.offWorkDateAfter"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
<Field
label=
"备注"
prop=
"remark"
v-model=
"form.remark"
type=
"textarea"
placeholder=
"请输入备注"
/>
</el-row>
</el-row>
<form-buttons
@
submit=
"submitForm"
noCancelBtn
/>
</el-form>
<form-buttons
@
submit=
'submitForm'
noCancelBtn
/>
</el-drawer>
</el-form>
</el-drawer>
</
template
>
</
template
>
<
script
>
<
script
>
import
form
from
"
@/assets/mixins/formdialog
"
;
import
form
from
"
@/assets/mixins/formdialog
"
;
export
default
{
export
default
{
name
:
"
AttendanceClassDetailDetail
"
,
name
:
"
AttendanceClassDetailDetail
"
,
mixins
:
[
form
],
mixins
:
[
form
],
components
:
{
components
:
{},
created
()
{
},
this
.
changePath
(
"
attendance/class/detail
"
);
created
()
{
},
this
.
changePath
(
"
attendance/class/detail
"
)
data
()
{
},
return
{
data
()
{
// 遮罩层
return
{
loading
:
true
,
// 遮罩层
// 弹出层标题
loading
:
true
,
title
:
"
考勤班次详细信息
"
,
// 弹出层标题
// 是否显示弹出层
title
:
"
考勤班次详细信息
"
,
open
:
false
,
// 是否显示弹出层
direction
:
"
rtl
"
,
open
:
false
,
toString
:
[],
direction
:
"
rtl
"
,
toDate
:
[
"
goWorkDate
"
,
"
offWorkDate
"
],
toString
:[
// 表单校验
],
rules
:
{
toDate
:[
createTime
:
[{
required
:
true
,
message
:
"
请选择创建时间
"
}],
"
goWorkDate
"
,
},
"
offWorkDate
"
,
};
],
},
// 表单校验
rules
:
{
createTime
:
[
{
required
:
true
,
message
:
"
请选择创建时间
"
},
],
}
};
},
methods
:
{
methods
:
{
/** 编辑 */
/** 编辑 */
edit
(
row
)
{
edit
(
row
)
{
this
.
reset
()
this
.
reset
();
this
.
query
=
{
id
:
row
.
id
};
this
.
query
=
{
id
:
row
.
id
};
this
.
urls
.
currUrl
=
"
attendance/class/detail/edit
"
;
this
.
urls
.
currUrl
=
"
attendance/class/detail/edit
"
;
this
.
getData
();
this
.
getData
();
this
.
pageInfo
.
type
=
"
edit
"
this
.
pageInfo
.
type
=
"
edit
"
;
this
.
title
=
"
修改考勤班次详细信息
"
;
this
.
title
=
"
修改考勤班次详细信息
"
;
},
},
/** 新增 */
/** 新增 */
add
(
row
)
{
add
(
row
)
{
this
.
reset
()
this
.
reset
();
this
.
urls
.
currUrl
=
"
attendance/class/detail/add
"
;
this
.
urls
.
currUrl
=
"
attendance/class/detail/add
"
;
this
.
getData
();
this
.
getData
();
this
.
pageInfo
.
type
=
"
add
"
this
.
pageInfo
.
type
=
"
add
"
;
this
.
title
=
"
新增考勤班次详细信息
"
;
this
.
title
=
"
新增考勤班次详细信息
"
;
},
},
/** 查看*/
/** 查看*/
view
(
row
)
{
view
(
row
)
{
this
.
reset
()
this
.
reset
();
this
.
query
=
{
id
:
row
.
id
};
this
.
query
=
{
id
:
row
.
id
};
this
.
urls
.
currUrl
=
"
attendance/class/detail/view
"
;
this
.
urls
.
currUrl
=
"
attendance/class/detail/view
"
;
this
.
getData
();
this
.
getData
();
this
.
pageInfo
.
type
=
"
view
"
this
.
pageInfo
.
type
=
"
view
"
;
this
.
title
=
"
考勤班次详细信息详细
"
;
this
.
title
=
"
考勤班次详细信息详细
"
;
},
},
/**取消按钮 */
/**取消按钮 */
cancel
()
{
cancel
()
{
this
.
open
=
false
;
this
.
open
=
false
;
},
},
/**获取数据后弹框 */
/**获取数据后弹框 */
afterRender
(
data
)
{
afterRender
(
data
)
{
this
.
open
=
true
;
this
.
open
=
true
;
},
},
afterSubmit
(
data
)
{
afterSubmit
(
data
)
{
this
.
open
=
false
;
this
.
open
=
false
;
this
.
$emit
(
"
ok
"
);
this
.
$emit
(
"
ok
"
);
},
},
// 表单重置
// 表单重置
reset
()
{
reset
()
{
this
.
form
=
{
this
.
form
=
{
shiftsId
:
null
,
shiftsId
:
null
,
shiftsName
:
""
,
shiftsName
:
""
,
goWorkDate
:
null
,
goWorkDate
:
null
,
goWorkDateBefore
:
null
,
goWorkDateBefore
:
null
,
goWorkDateAfter
:
null
,
goWorkDateAfter
:
null
,
offWorkDate
:
null
,
offWorkDate
:
null
,
offWorkDateBefore
:
null
,
offWorkDateBefore
:
null
,
offWorkDateAfter
:
null
,
offWorkDateAfter
:
null
,
remark
:
""
,
remark
:
""
,
};
};
this
.
resetForm
(
"
form
"
);
this
.
resetForm
(
"
form
"
);
},
},
resetForm
(
refName
)
{
resetForm
(
refName
)
{
if
(
this
.
$refs
[
refName
])
{
if
(
this
.
$refs
[
refName
])
{
this
.
$refs
[
refName
].
resetFields
();
this
.
$refs
[
refName
].
resetFields
();
}
}
},
},
},
},
};
};
</
script
>
</
script
>
attendance-performance-manager-ui/admin/src/views/attendance/class/dialogshow.vue
View file @
c34a1512
...
@@ -7,7 +7,7 @@
...
@@ -7,7 +7,7 @@
<Field
label=
"班次负责人"
prop=
"classResponsiblePersonId"
type=
"select"
:enumData=
"dict.workManId"
<Field
label=
"班次负责人"
prop=
"classResponsiblePersonId"
type=
"select"
:enumData=
"dict.workManId"
v-model=
"form.classResponsiblePersonId"
placeholder=
"请选择班次负责人"
/>
v-model=
"form.classResponsiblePersonId"
placeholder=
"请选择班次负责人"
/>
</el-row>
</el-row>
<el-form-item
label=
"上下班时间"
prop=
"attendanceClassDetailList"
>
<el-form-item
label=
"上下班
考勤
时间"
prop=
"attendanceClassDetailList"
>
<el-button
type=
"text"
@
click=
"handleAddAttendanceClassDetail"
>
添加
</el-button>
<el-button
type=
"text"
@
click=
"handleAddAttendanceClassDetail"
>
添加
</el-button>
<div
class=
"bancifor"
v-for=
"(item,index) in attendanceClassDetailList"
:key=
"index"
>
<div
class=
"bancifor"
v-for=
"(item,index) in attendanceClassDetailList"
:key=
"index"
>
<div
class=
"title flex flex-align-center flex-pack-justify"
>
<div
class=
"title flex flex-align-center flex-pack-justify"
>
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
<el-button
type=
"danger"
size=
"mini"
@
click=
"handleDeleteAttendanceClassDetail(index)"
>
删除
</el-button>
<el-button
type=
"danger"
size=
"mini"
@
click=
"handleDeleteAttendanceClassDetail(index)"
>
删除
</el-button>
</div>
</div>
<div>
<div>
<span>
上班时间
</span>
<span>
上班
考勤
时间
</span>
<el-time-picker
<el-time-picker
size=
"mini"
size=
"mini"
style=
"width:150px"
style=
"width:150px"
...
@@ -25,12 +25,12 @@
...
@@ -25,12 +25,12 @@
value-format=
"HH:mm"
value-format=
"HH:mm"
format=
"HH:mm"
format=
"HH:mm"
v-model=
"item.goWorkDate"
v-model=
"item.goWorkDate"
placeholder=
"上班时间"
>
placeholder=
"上班
考勤
时间"
>
</el-time-picker>
</el-time-picker>
</div>
</div>
<div>
<div>
<span>
打开时段:
</span>
<span>
打开时段:
</span>
<span>
上班前
</span>
<span>
上班前
签到
</span>
<el-time-picker
<el-time-picker
size=
"mini"
size=
"mini"
style=
"width:150px"
style=
"width:150px"
...
@@ -41,7 +41,7 @@
...
@@ -41,7 +41,7 @@
placeholder=
"未设置"
>
placeholder=
"未设置"
>
</el-time-picker>
</el-time-picker>
<span
class=
"ml20"
>
——
</span>
<span
class=
"ml20"
>
——
</span>
<span
class=
"ml20"
>
上班后
</span>
<span
class=
"ml20"
>
上班后
签到
</span>
<el-time-picker
<el-time-picker
size=
"mini"
size=
"mini"
style=
"width:150px"
style=
"width:150px"
...
@@ -53,7 +53,7 @@
...
@@ -53,7 +53,7 @@
</el-time-picker>
</el-time-picker>
</div>
</div>
<div>
<div>
<span>
下班时间
</span>
<span>
下班
考勤
时间
</span>
<el-time-picker
<el-time-picker
size=
"mini"
size=
"mini"
style=
"width:150px"
style=
"width:150px"
...
@@ -61,12 +61,12 @@
...
@@ -61,12 +61,12 @@
format=
"HH:mm"
format=
"HH:mm"
value-format=
"HH:mm"
value-format=
"HH:mm"
v-model=
"item.offWorkDate"
v-model=
"item.offWorkDate"
placeholder=
"下班时间"
>
placeholder=
"下班
考勤
时间"
>
</el-time-picker>
</el-time-picker>
</div>
</div>
<div>
<div>
<span>
打开时段:
</span>
<span>
打开时段:
</span>
<span>
下班前
</span>
<span>
下班前
签退
</span>
<el-time-picker
<el-time-picker
size=
"mini"
size=
"mini"
style=
"width:150px"
style=
"width:150px"
...
@@ -77,7 +77,7 @@
...
@@ -77,7 +77,7 @@
placeholder=
"未设置"
>
placeholder=
"未设置"
>
</el-time-picker>
</el-time-picker>
<span
class=
"ml20"
>
——
</span>
<span
class=
"ml20"
>
——
</span>
<span
class=
"ml20"
>
下班后
</span>
<span
class=
"ml20"
>
下班后
签退
</span>
<el-time-picker
<el-time-picker
size=
"mini"
size=
"mini"
style=
"width:150px"
style=
"width:150px"
...
@@ -189,40 +189,40 @@
...
@@ -189,40 +189,40 @@
this
.
attendanceClassDetailList
.
push
(
obj
);
this
.
attendanceClassDetailList
.
push
(
obj
);
},
},
// 判断添加上下班时间
// 判断添加上下班
考勤
时间
judgeStatus
(
arr
,
index
){
judgeStatus
(
arr
,
index
){
console
.
log
(
arr
,
index
,
'
ces
'
)
console
.
log
(
arr
,
index
,
'
ces
'
)
let
status
=
true
let
status
=
true
if
(
arr
.
length
==
0
){
if
(
arr
.
length
==
0
){
}
else
{
}
else
{
if
(
arr
[
index
].
goWorkDate
===
''
){
if
(
arr
[
index
].
goWorkDate
===
''
){
this
.
$message
.
error
(
'
请选择上班时间
'
)
this
.
$message
.
error
(
'
请选择上班
考勤
时间
'
)
status
=
false
status
=
false
return
return
}
}
if
(
arr
[
index
].
goWorkDateBefore
===
''
){
if
(
arr
[
index
].
goWorkDateBefore
===
''
){
this
.
$message
.
error
(
'
请选择允许上班前打卡时间
'
)
this
.
$message
.
error
(
'
请选择允许上班前
签到
打卡时间
'
)
status
=
false
status
=
false
return
return
}
}
if
(
arr
[
index
].
goWorkDateAfter
===
''
){
if
(
arr
[
index
].
goWorkDateAfter
===
''
){
this
.
$message
.
error
(
'
请选择允许上班后打卡时间
'
)
this
.
$message
.
error
(
'
请选择允许上班后
签到
打卡时间
'
)
status
=
false
status
=
false
return
return
}
}
if
(
arr
[
index
].
offWorkDate
===
''
){
if
(
arr
[
index
].
offWorkDate
===
''
){
this
.
$message
.
error
(
'
请选择下班时间
'
)
this
.
$message
.
error
(
'
请选择下班
考勤
时间
'
)
status
=
false
status
=
false
return
return
}
}
if
(
arr
[
index
].
offWorkDateBefore
===
''
){
if
(
arr
[
index
].
offWorkDateBefore
===
''
){
this
.
$message
.
error
(
'
请选择允许下班前打卡时间
'
)
this
.
$message
.
error
(
'
请选择允许下班前
签退
打卡时间
'
)
status
=
false
status
=
false
return
return
}
}
if
(
arr
[
index
].
offWorkDateAfter
===
''
){
if
(
arr
[
index
].
offWorkDateAfter
===
''
){
this
.
$message
.
error
(
'
请选择允许下班后打卡时间
'
)
this
.
$message
.
error
(
'
请选择允许下班后
签退
打卡时间
'
)
status
=
false
status
=
false
return
return
}
}
...
@@ -248,7 +248,7 @@
...
@@ -248,7 +248,7 @@
transFormMinut
(
arr
[
index
].
goWorkDateBefore
)
transFormMinut
(
arr
[
index
].
goWorkDateBefore
)
if
(
currentwokeTime
<=
lastoffTime
){
if
(
currentwokeTime
<=
lastoffTime
){
this
.
$message
.
error
(
`第
${
index
}
上班
时间需大于第
${
index
-
1
}
上班
时间`
)
this
.
$message
.
error
(
`第
${
index
}
上班
考勤时间需大于第
${
index
-
1
}
上班考勤
时间`
)
status
=
false
status
=
false
return
return
}
}
...
...
attendance-performance-manager-ui/admin/src/views/attendance/class/drawershow.vue
View file @
c34a1512
<
template
>
<
template
>
<!-- 弹出框表单 -->
<!-- 弹出框表单 -->
<el-drawer
<el-drawer
:title=
"title"
:title=
"title"
:visible.sync=
"open"
:visible.sync=
"open"
:direction=
"direction"
:direction=
"direction"
size=
"50%"
>
size=
"50%"
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"120px"
>
>
<el-row>
<el-form
ref=
"form"
:model=
"form"
:rules=
"rules"
label-width=
"120px"
>
<Field
label=
"班次名称"
prop=
"className"
v-model=
"form.className"
placeholder=
"请输入班次名称"
/>
<el-row>
<Field
label=
"班次负责人ID"
prop=
"classResponsiblePersonId"
v-model=
"form.classResponsiblePersonId"
placeholder=
"请输入班次负责人ID"
/>
<Field
<Field
label=
"班次负责人名称"
prop=
"classResponsiblePersonName"
v-model=
"form.classResponsiblePersonName"
placeholder=
"请输入班次负责人名称"
/>
label=
"班次名称"
<Field
label=
"备注"
prop=
"remark"
v-model=
"form.remark"
type=
"textarea"
placeholder=
"请输入备注"
/>
prop=
"className"
v-model=
"form.className"
placeholder=
"请输入班次名称"
/>
<Field
label=
"班次负责人ID"
prop=
"classResponsiblePersonId"
v-model=
"form.classResponsiblePersonId"
placeholder=
"请输入班次负责人ID"
/>
<Field
label=
"班次负责人名称"
prop=
"classResponsiblePersonName"
v-model=
"form.classResponsiblePersonName"
placeholder=
"请输入班次负责人名称"
/>
<Field
label=
"备注"
prop=
"remark"
v-model=
"form.remark"
type=
"textarea"
placeholder=
"请输入备注"
/>
</el-row>
<el-divider
content-position=
"center"
>
考勤班次详细信息信息
</el-divider>
<br
/>
<el-row
:gutter=
"10"
class=
"mb8"
>
<el-col
:span=
"1.5"
>
<el-button
type=
"primary"
icon=
"el-icon-plus"
size=
"mini"
@
click=
"handleAddAttendanceClassDetail"
>
添加
</el-button
>
</el-col>
<el-col
:span=
"1.5"
>
<el-button
type=
"danger"
icon=
"el-icon-delete"
size=
"mini"
@
click=
"handleDeleteAttendanceClassDetail"
>
删除
</el-button
>
</el-col>
</el-row>
</el-row>
<el-table
<el-divider
content-position=
"center"
>
考勤班次详细信息信息
</el-divider>
:data=
"attendanceClassDetailList"
<br/>
:row-class-name=
"rowAttendanceClassDetailIndex"
<el-row
:gutter=
"10"
class=
"mb8"
>
@
selection-change=
"handleAttendanceClassDetailSelectionChange"
<el-col
:span=
"1.5"
>
ref=
"attendanceClassDetail"
<el-button
type=
"primary"
icon=
"el-icon-plus"
size=
"mini"
@
click=
"handleAddAttendanceClassDetail"
>
添加
</el-button>
>
</el-col>
<el-table-column
type=
"selection"
width=
"50"
align=
"center"
/>
<el-col
:span=
"1.5"
>
<el-table-column
label=
"序号"
align=
"center"
prop=
"index"
width=
"50"
/>
<el-button
type=
"danger"
icon=
"el-icon-delete"
size=
"mini"
@
click=
"handleDeleteAttendanceClassDetail"
>
删除
</el-button>
<el-table-column
label=
"班次名称"
prop=
"shiftsName"
>
</el-col>
<template
slot-scope=
"scope"
>
</el-row>
<el-input
v-model=
"scope.row.shiftsName"
placeholder=
"请输入班次名称"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"上班打卡时间"
prop=
"goWorkDate"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.goWorkDate"
placeholder=
"请输入上班打卡时间"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateBefore"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.goWorkDateBefore"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateAfter"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.goWorkDateAfter"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"下班打卡时间"
prop=
"offWorkDate"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.offWorkDate"
placeholder=
"请输入下班打卡时间"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateBefore"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.offWorkDateBefore"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateAfter"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.offWorkDateAfter"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"备注"
prop=
"remark"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.remark"
placeholder=
"请输入备注"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"创建用户"
prop=
"createUserId"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.createUserId"
placeholder=
"请输入创建用户"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"创建时间"
prop=
"createTime"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.createTime"
placeholder=
"请输入创建时间"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"更新用户"
prop=
"updateUserId"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.updateUserId"
placeholder=
"请输入更新用户"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"更新时间"
prop=
"updateTime"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.updateTime"
placeholder=
"请输入更新时间"
/>
</
template
>
</el-table-column>
</el-table>
<el-table
:data=
"attendanceClassDetailList"
:row-class-name=
"rowAttendanceClassDetailIndex"
@
selection-change=
"handleAttendanceClassDetailSelectionChange"
ref=
"attendanceClassDetail"
>
<form-buttons
@
submit=
"submitForm"
noCancelBtn
/>
<el-table-column
type=
"selection"
width=
"50"
align=
"center"
/>
</el-form>
<el-table-column
label=
"序号"
align=
"center"
prop=
"index"
width=
"50"
/>
</el-drawer>
<el-table-column
label=
"班次名称"
prop=
"shiftsName"
>
<template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.shiftsName"
placeholder=
"请输入班次名称"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"上班打卡时间"
prop=
"goWorkDate"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.goWorkDate"
placeholder=
"请输入上班打卡时间"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateBefore"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.goWorkDateBefore"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"上班打卡前时间段,单位分钟"
prop=
"goWorkDateAfter"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.goWorkDateAfter"
placeholder=
"请输入上班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"下班打卡时间"
prop=
"offWorkDate"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.offWorkDate"
placeholder=
"请输入下班打卡时间"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateBefore"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.offWorkDateBefore"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"下班打卡前时间段,单位分钟"
prop=
"offWorkDateAfter"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.offWorkDateAfter"
placeholder=
"请输入下班打卡前时间段,单位分钟"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"备注"
prop=
"remark"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.remark"
placeholder=
"请输入备注"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"创建用户"
prop=
"createUserId"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.createUserId"
placeholder=
"请输入创建用户"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"创建时间"
prop=
"createTime"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.createTime"
placeholder=
"请输入创建时间"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"更新用户"
prop=
"updateUserId"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.updateUserId"
placeholder=
"请输入更新用户"
/>
</
template
>
</el-table-column>
<el-table-column
label=
"更新时间"
prop=
"updateTime"
>
<
template
slot-scope=
"scope"
>
<el-input
v-model=
"scope.row.updateTime"
placeholder=
"请输入更新时间"
/>
</
template
>
</el-table-column>
</el-table>
<form-buttons
@
submit=
'submitForm'
noCancelBtn
/>
</el-form>
</el-drawer>
</template>
</template>
<
script
>
<
script
>
import
form
from
"
@/assets/mixins/formdialog
"
;
import
form
from
"
@/assets/mixins/formdialog
"
;
export
default
{
export
default
{
name
:
"
AttendanceClassDetail
"
,
name
:
"
AttendanceClassDetail
"
,
mixins
:
[
form
],
mixins
:
[
form
],
components
:
{
components
:
{},
created
()
{
},
this
.
changePath
(
"
attendance/class
"
);
created
()
{
},
this
.
changePath
(
"
attendance/class
"
)
data
()
{
},
return
{
data
()
{
// 子表选中数据
return
{
checkedAttendanceClassDetail
:
[],
// 子表选中数据
// 考勤班次详细信息表格数据
checkedAttendanceClassDetail
:
[],
attendanceClassDetailList
:
[],
// 考勤班次详细信息表格数据
// 遮罩层
attendanceClassDetailList
:
[],
loading
:
true
,
// 遮罩层
// 弹出层标题
loading
:
true
,
title
:
"
考勤班次信息
"
,
// 弹出层标题
// 是否显示弹出层
title
:
"
考勤班次信息
"
,
open
:
false
,
// 是否显示弹出层
direction
:
"
rtl
"
,
open
:
false
,
toString
:
[],
direction
:
"
rtl
"
,
toDate
:
[],
toString
:[
// 表单校验
],
rules
:
{
toDate
:[
createTime
:
[{
required
:
true
,
message
:
"
请选择创建时间
"
}],
],
},
// 表单校验
};
rules
:
{
},
createTime
:
[
{
required
:
true
,
message
:
"
请选择创建时间
"
},
],
}
};
},
methods
:
{
methods
:
{
/** 考勤班次详细信息序号 */
/** 考勤班次详细信息序号 */
rowAttendanceClassDetailIndex
({
row
,
rowIndex
})
{
rowAttendanceClassDetailIndex
({
row
,
rowIndex
})
{
row
.
index
=
rowIndex
+
1
;
row
.
index
=
rowIndex
+
1
;
},
},
/** 考勤班次详细信息添加按钮操作 */
/** 考勤班次详细信息添加按钮操作 */
handleAddAttendanceClassDetail
()
{
handleAddAttendanceClassDetail
()
{
let
obj
=
{};
let
obj
=
{};
obj
.
shiftsName
=
""
;
obj
.
shiftsName
=
""
;
obj
.
goWorkDate
=
""
;
obj
.
goWorkDate
=
""
;
obj
.
goWorkDateBefore
=
""
;
obj
.
goWorkDateBefore
=
""
;
obj
.
goWorkDateAfter
=
""
;
obj
.
goWorkDateAfter
=
""
;
obj
.
offWorkDate
=
""
;
obj
.
offWorkDate
=
""
;
obj
.
offWorkDateBefore
=
""
;
obj
.
offWorkDateBefore
=
""
;
obj
.
offWorkDateAfter
=
""
;
obj
.
offWorkDateAfter
=
""
;
obj
.
remark
=
""
;
obj
.
remark
=
""
;
obj
.
createUserId
=
""
;
obj
.
createUserId
=
""
;
obj
.
createTime
=
""
;
obj
.
createTime
=
""
;
obj
.
updateUserId
=
""
;
obj
.
updateUserId
=
""
;
obj
.
updateTime
=
""
;
obj
.
updateTime
=
""
;
this
.
attendanceClassDetailList
.
push
(
obj
);
this
.
attendanceClassDetailList
.
push
(
obj
);
},
},
/** 考勤班次详细信息删除按钮操作 */
/** 考勤班次详细信息删除按钮操作 */
handleDeleteAttendanceClassDetail
()
{
handleDeleteAttendanceClassDetail
()
{
if
(
this
.
checkedAttendanceClassDetail
.
length
==
0
)
{
if
(
this
.
checkedAttendanceClassDetail
.
length
==
0
)
{
this
.
$alert
(
"
请先选择要删除的考勤班次详细信息数据
"
,
"
提示
"
,
{
confirmButtonText
:
"
确定
"
,
});
this
.
$alert
(
"
请先选择要删除的考勤班次详细信息数据
"
,
"
提示
"
,
{
}
else
{
confirmButtonText
:
"
确定
"
,
this
.
attendanceClassDetailList
.
splice
(
this
.
checkedAttendanceClassDetail
[
0
].
index
-
1
,
1
);
});
}
}
else
{
},
this
.
attendanceClassDetailList
.
splice
(
/** 单选框选中数据 */
this
.
checkedAttendanceClassDetail
[
0
].
index
-
1
,
handleAttendanceClassDetailSelectionChange
(
selection
)
{
1
if
(
selection
.
length
>
1
)
{
);
this
.
$refs
.
attendanceClassDetail
.
clearSelection
();
}
this
.
$refs
.
attendanceClassDetail
.
toggleRowSelection
(
selection
.
pop
());
},
}
else
{
/** 单选框选中数据 */
this
.
checkedAttendanceClassDetail
=
selection
;
handleAttendanceClassDetailSelectionChange
(
selection
)
{
}
if
(
selection
.
length
>
1
)
{
},
this
.
$refs
.
attendanceClassDetail
.
clearSelection
();
// 渲染前置处理
this
.
$refs
.
attendanceClassDetail
.
toggleRowSelection
(
selection
.
pop
());
beforeRender
(
data
)
{
}
else
{
if
(
data
.
entity
.
attendanceClassDetailList
)
{
this
.
checkedAttendanceClassDetail
=
selection
;
this
.
attendanceClassDetailList
=
data
.
entity
.
attendanceClassDetailList
;
}
}
},
return
data
// 渲染前置处理
},
beforeRender
(
data
)
{
/** 编辑 */
if
(
data
.
entity
.
attendanceClassDetailList
)
{
edit
(
row
)
{
this
.
attendanceClassDetailList
=
data
.
entity
.
attendanceClassDetailList
;
this
.
reset
()
}
this
.
query
=
{
id
:
row
.
id
};
return
data
;
this
.
urls
.
currUrl
=
"
attendance/class/edit
"
;
},
this
.
getData
();
/** 编辑 */
this
.
pageInfo
.
type
=
"
edit
"
edit
(
row
)
{
this
.
title
=
"
修改考勤班次信息
"
;
this
.
reset
();
},
this
.
query
=
{
id
:
row
.
id
};
/** 新增 */
this
.
urls
.
currUrl
=
"
attendance/class/edit
"
;
add
(
row
)
{
this
.
getData
();
this
.
reset
()
this
.
pageInfo
.
type
=
"
edit
"
;
this
.
urls
.
currUrl
=
"
attendance/class/add
"
;
this
.
title
=
"
修改考勤班次信息
"
;
this
.
getData
();
},
this
.
pageInfo
.
type
=
"
add
"
/** 新增 */
this
.
title
=
"
新增考勤班次信息
"
;
add
(
row
)
{
},
this
.
reset
();
/** 查看*/
this
.
urls
.
currUrl
=
"
attendance/class/add
"
;
view
(
row
)
{
this
.
getData
();
this
.
reset
()
this
.
pageInfo
.
type
=
"
add
"
;
this
.
query
=
{
id
:
row
.
id
};
this
.
title
=
"
新增考勤班次信息
"
;
this
.
urls
.
currUrl
=
"
attendance/class/view
"
;
},
this
.
getData
();
/** 查看*/
this
.
pageInfo
.
type
=
"
view
"
view
(
row
)
{
this
.
title
=
"
考勤班次信息详细
"
;
this
.
reset
();
},
this
.
query
=
{
id
:
row
.
id
};
/**取消按钮 */
this
.
urls
.
currUrl
=
"
attendance/class/view
"
;
cancel
()
{
this
.
getData
();
this
.
open
=
false
;
this
.
pageInfo
.
type
=
"
view
"
;
},
this
.
title
=
"
考勤班次信息详细
"
;
/**获取数据后弹框 */
},
afterRender
(
data
)
{
/**取消按钮 */
this
.
open
=
true
;
cancel
()
{
},
this
.
open
=
false
;
},
/**获取数据后弹框 */
afterRender
(
data
)
{
this
.
open
=
true
;
},
afterSubmit
(
data
)
{
afterSubmit
(
data
)
{
this
.
open
=
false
;
this
.
open
=
false
;
this
.
$emit
(
"
ok
"
);
this
.
$emit
(
"
ok
"
);
},
},
// 表单重置
// 表单重置
reset
()
{
reset
()
{
this
.
form
=
{
this
.
form
=
{
className
:
""
,
className
:
""
,
classResponsiblePersonId
:
null
,
classResponsiblePersonId
:
null
,
classResponsiblePersonName
:
""
,
classResponsiblePersonName
:
""
,
remark
:
""
,
remark
:
""
,
};
};
this
.
resetForm
(
"
form
"
);
this
.
resetForm
(
"
form
"
);
},
},
resetForm
(
refName
)
{
resetForm
(
refName
)
{
if
(
this
.
$refs
[
refName
])
{
if
(
this
.
$refs
[
refName
])
{
this
.
$refs
[
refName
].
resetFields
();
this
.
$refs
[
refName
].
resetFields
();
}
}
},
},
},
},
};
};
</
script
>
</
script
>
attendance-performance-manager-ui/admin/src/views/homeCharts/record/list.vue
View file @
c34a1512
...
@@ -712,7 +712,7 @@ export default {
...
@@ -712,7 +712,7 @@ export default {
indicator
:
names
.
map
((
v
)
=>
{
indicator
:
names
.
map
((
v
)
=>
{
return
{
return
{
name
:
v
,
name
:
v
,
max
:
150
,
max
:
Math
.
max
(...[...
add
,
...
sub
])
,
};
};
}),
}),
center
:
[
"
45%
"
,
"
50%
"
],
center
:
[
"
45%
"
,
"
50%
"
],
...
@@ -734,10 +734,10 @@ export default {
...
@@ -734,10 +734,10 @@ export default {
value
:
add
,
value
:
add
,
name
:
"
加分
"
,
name
:
"
加分
"
,
symbol
:
"
rect
"
,
symbol
:
"
rect
"
,
symbolSize
:
12
,
//
symbolSize: 12,
areaStyle
:
{
color
:
"
#56A3F1
"
},
//雷达覆盖区域背景颜色
areaStyle
:
{
color
:
"
#56A3F1
"
},
//雷达覆盖区域背景颜色
label
:
{
label
:
{
show
:
tru
e
,
show
:
fals
e
,
formatter
:
function
(
params
)
{
formatter
:
function
(
params
)
{
return
params
.
value
;
return
params
.
value
;
},
},
...
...
attendance-performance-manager-ui/admin/src/views/perform/rules/attend/components/AttendIndex.vue
View file @
c34a1512
...
@@ -95,7 +95,6 @@ export default {
...
@@ -95,7 +95,6 @@ export default {
data
()
{
data
()
{
return
{
return
{
switchValue
:
"
0
"
,
switchValue
:
"
0
"
,
searchValue
:
""
,
searchValue
:
""
,
index
:
-
1
,
index
:
-
1
,
dataArr
:
[],
dataArr
:
[],
...
@@ -227,7 +226,7 @@ export default {
...
@@ -227,7 +226,7 @@ export default {
type
:
this
.
activeName
,
type
:
this
.
activeName
,
page
:
this
.
query
.
page
,
page
:
this
.
query
.
page
,
orderColList
:
this
.
typeArr
,
orderColList
:
this
.
typeArr
,
name
:
this
.
searchValue
,
name
:
`%
${
this
.
searchValue
}
%`
,
}).
then
((
res
)
=>
{
}).
then
((
res
)
=>
{
if
(
res
.
code
==
1
)
{
if
(
res
.
code
==
1
)
{
this
.
tableData
=
res
.
data
;
this
.
tableData
=
res
.
data
;
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment