Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
T
tianhongwxapp
Project
Project
Details
Activity
Releases
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
liuyuping
tianhongwxapp
Commits
55611f2f
Commit
55611f2f
authored
Mar 08, 2022
by
liuyuping
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
'2022-3-8'
parent
e70dd7a3
Changes
29
Hide whitespace changes
Inline
Side-by-side
Showing
29 changed files
with
1108 additions
and
514 deletions
+1108
-514
app.js
app.js
+18
-7
advice.js
pages/advice/advice.js
+4
-4
adviceItem.js
pages/adviceItem/adviceItem.js
+13
-7
course.js
pages/course/course.js
+10
-0
course.wxml
pages/course/course.wxml
+2
-2
dangeredit.js
pages/dangeredit/dangeredit.js
+10
-4
dangeredit.wxml
pages/dangeredit/dangeredit.wxml
+5
-2
dangeredit.wxss
pages/dangeredit/dangeredit.wxss
+10
-5
dangerregister.js
pages/dangerregister/dangerregister.js
+124
-2
dangerregister.wxml
pages/dangerregister/dangerregister.wxml
+86
-11
dangerregister.wxss
pages/dangerregister/dangerregister.wxss
+15
-0
evaluate.js
pages/evaluate/evaluate.js
+162
-2
evaluate.json
pages/evaluate/evaluate.json
+3
-1
evaluate.wxml
pages/evaluate/evaluate.wxml
+51
-13
evaluate.wxss
pages/evaluate/evaluate.wxss
+35
-0
exam.js
pages/exam/exam.js
+71
-10
exam.wxml
pages/exam/exam.wxml
+17
-4
exam.wxss
pages/exam/exam.wxss
+21
-1
home.js
pages/home/home.js
+25
-4
info.js
pages/info/info.js
+26
-25
info.wxml
pages/info/info.wxml
+4
-4
info.wxss
pages/info/info.wxss
+1
-1
law.js
pages/law/law.js
+1
-1
teach.js
pages/teach/teach.js
+56
-2
teach.wxml
pages/teach/teach.wxml
+1
-1
testpaper.js
pages/testpaper/testpaper.js
+243
-381
testpaper.wxml
pages/testpaper/testpaper.wxml
+40
-16
testpaper.wxss
pages/testpaper/testpaper.wxss
+49
-0
project.config.json
project.config.json
+5
-4
No files found.
app.js
View file @
55611f2f
...
@@ -43,20 +43,31 @@ App({
...
@@ -43,20 +43,31 @@ App({
// })
// })
},
},
globalData
:
{
globalData
:
{
appBaseUrl
:
'
https://safe.c-icc.cn:8035
'
,
// appBaseUrl: 'https://safe.c-icc.cn:8035',
appBaseUrlV2
:
'
https://safe.c-icc.cn:8036
'
,
// appBaseUrlV2: 'https://safe.c-icc.cn:8036',
appBaseUrlV3
:
'
https://safe.c-icc.cn:8030
'
,
// appBaseUrlV3: 'https://safe.c-icc.cn:8030',
appBaseUrl
:
'
https://www.kuangshanzhixing.cn:8035
'
,
appBaseUrlV2
:
'
https://www.kuangshanzhixing.cn:8036
'
,
appBaseUrlV3
:
'
https://www.kuangshanzhixing.cn:8030
'
,
// appBaseUrl: 'https://8.143.198.78:8035',
// appBaseUrlV2: 'https://8.143.198.78:8036',
// appBaseUrlV3: 'https://8.143.198.78:8030',
userInfo
:
null
,
userInfo
:
null
,
Authorization
:
''
,
Authorization
:
''
,
curRole
:
''
,
// 运营商 企业管理 企业员工 政府 超级管理员
curRole
:
''
,
// 运营商 企业管理 企业员工 政府 超级管理员
companyId
:
-
1
,
companyId
:
-
1
,
companyName
:
''
,
companyName
:
''
,
currentEnter
:
{
currentEnter
:
{},
},
currentHD
:
{},
currentHD
:
{},
currentLawItem
:
{},
currentLawItem
:
{},
currentAdviceItem
:
{},
currentAdviceItem
:
{},
currentCourse
:
{},
currentCourse
:
{},
currentTrainImg
:
{}
currentTrainImg
:
{},
curEvaluate
:
{},
testPaperId
:
-
1
,
singleScore
:
0
,
multiScore
:
0
,
justifyScore
:
0
,
isNeedNavigateTo
:
false
}
}
})
})
pages/advice/advice.js
View file @
55611f2f
...
@@ -25,8 +25,8 @@ Page({
...
@@ -25,8 +25,8 @@ Page({
},
},
data
:
{
data
:
{
page
:
this
.
data
.
curPage
,
page
:
this
.
data
.
curPage
,
size
:
this
.
data
.
curPageSize
,
size
:
this
.
data
.
curPageSize
sort
:
'
noticeId,desc
'
//
sort: 'noticeId,desc'
},
},
success
:
(
res
)
=>
{
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
app.globalData.appBaseUrlV2
'
)
console
.
log
(
res
,
'
app.globalData.appBaseUrlV2
'
)
...
@@ -122,8 +122,8 @@ Page({
...
@@ -122,8 +122,8 @@ Page({
},
},
data
:
{
data
:
{
page
:
this
.
data
.
curPage
,
page
:
this
.
data
.
curPage
,
size
:
this
.
data
.
curPageSize
,
size
:
this
.
data
.
curPageSize
sort
:
'
noticeId,desc
'
//
sort: 'noticeId,desc'
},
},
success
:
(
res
)
=>
{
success
:
(
res
)
=>
{
this
.
setData
({
this
.
setData
({
...
...
pages/adviceItem/adviceItem.js
View file @
55611f2f
...
@@ -34,6 +34,12 @@ Page({
...
@@ -34,6 +34,12 @@ Page({
},
},
success
:
(
res
)
=>
{
success
:
(
res
)
=>
{
console
.
log
(
res
)
console
.
log
(
res
)
this
.
setData
({
title
:
res
.
data
.
noticeTitle
,
depart
:
res
.
data
.
noticePublisher
,
time
:
res
.
data
.
createTime
,
content
:
res
.
data
.
noticeContent
})
/**
/**
* createBy
* createBy
* createTIme
* createTIme
...
@@ -50,14 +56,14 @@ Page({
...
@@ -50,14 +56,14 @@ Page({
strips: [],
strips: [],
content
content
*/
*/
this
.
setData
({
//
this.setData({
title
:
res
.
noticeTitle
,
// title: res.data
.noticeTitle,
depart
:
res
.
noticePublisher
,
// depart: res.data
.noticePublisher,
time
:
res
.
updateTime
,
// time: res.data
.updateTime,
content
:
res
.
noticeContent
// content: res.data
.noticeContent
})
//
})
wx
.
setNavigationBarTitle
({
wx
.
setNavigationBarTitle
({
title
:
res
.
noticeTitle
title
:
res
.
data
.
noticeTitle
})
})
},
},
fail
:
()
=>
{},
fail
:
()
=>
{},
...
...
pages/course/course.js
View file @
55611f2f
...
@@ -54,6 +54,7 @@ Page({
...
@@ -54,6 +54,7 @@ Page({
* 页面的初始数据
* 页面的初始数据
*/
*/
data
:
{
data
:
{
isShowVideo
:
true
,
curCourse
:
app
.
globalData
.
currentCourse
.
courseBriefIntroduction
,
curCourse
:
app
.
globalData
.
currentCourse
.
courseBriefIntroduction
,
curCoursePic
:
'
https://img0.baidu.com/it/u=2265254049,1802113800&fm=26&fmt=auto&gp=0.jpg
'
,
curCoursePic
:
'
https://img0.baidu.com/it/u=2265254049,1802113800&fm=26&fmt=auto&gp=0.jpg
'
,
courseVideoSrc
:
'
http://39.102.232.151:8030/video/8.mp4
'
,
courseVideoSrc
:
'
http://39.102.232.151:8030/video/8.mp4
'
,
...
@@ -75,6 +76,15 @@ Page({
...
@@ -75,6 +76,15 @@ Page({
curCourse
:
app
.
globalData
.
currentCourse
.
courseBriefIntroduction
,
curCourse
:
app
.
globalData
.
currentCourse
.
courseBriefIntroduction
,
courses
:
app
.
globalData
.
currentCourse
.
coursehour
courses
:
app
.
globalData
.
currentCourse
.
coursehour
})
})
console
.
log
(
app
.
globalData
.
currentCourse
.
coursehour
,
'
app.globaldata.currentCourse.coursehour app.globaldata.currentCourse.coursehour
'
)
const
arr1
=
app
.
globalData
.
currentCourse
.
coursehour
.
filter
(
item
=>
{
return
item
.
lessonFilePath
.
indexOf
(
"
.pdf
"
)
>
-
1
})
if
(
arr1
.
length
===
app
.
globalData
.
currentCourse
.
coursehour
.
length
)
{
this
.
setData
({
isShowVideo
:
false
})
}
},
},
/**
/**
...
...
pages/course/course.wxml
View file @
55611f2f
<!--pages/course/course.wxml-->
<!--pages/course/course.wxml-->
<view class="course-wrapper">
<view class="course-wrapper">
<view class="course-title">当前课程: {{curCourse}}</view>
<view class="course-title">当前课程: {{curCourse}}</view>
<view class="video-wrapper">
<view class="video-wrapper"
wx:if="{{isShowVideo}}"
>
<video id="course" show-center-play-btn="{{false}}" src="{{courseVideoSrc}}" bindtimeupdate="videoUpdate"></video>
<video id="course" show-center-play-btn="{{false}}" src="{{courseVideoSrc}}" bindtimeupdate="videoUpdate"
></video>
<!-- <image class="video-cover" mode="scaleToFill" src="{{curCoursePic}}" animation="{{animationDisappear}}"></image>
<!-- <image class="video-cover" mode="scaleToFill" src="{{curCoursePic}}" animation="{{animationDisappear}}"></image>
<view class="mask-video" animation="{{animationDisappear}}">
<view class="mask-video" animation="{{animationDisappear}}">
<image class="paly-video-btn" src="{{courseVideoPlay}}" bindtap="playvideo">
<image class="paly-video-btn" src="{{courseVideoPlay}}" bindtap="playvideo">
...
...
pages/dangeredit/dangeredit.js
View file @
55611f2f
...
@@ -10,6 +10,8 @@ Page({
...
@@ -10,6 +10,8 @@ Page({
companyId
:
app
.
globalData
.
currentEnter
.
companyId
,
companyId
:
app
.
globalData
.
currentEnter
.
companyId
,
// 隐患验收人
// 隐患验收人
hdAcceptancePerson
:
""
,
hdAcceptancePerson
:
""
,
// 备注
comment
:
''
,
// 隐患id
// 隐患id
hdId
:
-
1
,
hdId
:
-
1
,
// 隐患描述
// 隐患描述
...
@@ -42,7 +44,8 @@ Page({
...
@@ -42,7 +44,8 @@ Page({
rectFilePath
:
''
,
rectFilePath
:
''
,
// 放大图片的路径
// 放大图片的路径
enlargeUrl
:
''
,
enlargeUrl
:
''
,
topAnimation
:
{}
topAnimation
:
{},
isToEnLarge
:
false
},
},
/**
/**
...
@@ -295,7 +298,8 @@ Page({
...
@@ -295,7 +298,8 @@ Page({
this
.
animation
.
bottom
(
0
).
step
()
this
.
animation
.
bottom
(
0
).
step
()
this
.
setData
({
this
.
setData
({
topAnimation
:
this
.
animation
.
export
(),
topAnimation
:
this
.
animation
.
export
(),
enlargeUrl
:
this
.
data
.
imgsrcurl
enlargeUrl
:
this
.
data
.
imgsrcurl
,
isToEnLarge
:
true
})
})
// toEnlargePicByRectPic
// toEnlargePicByRectPic
},
},
...
@@ -303,13 +307,15 @@ Page({
...
@@ -303,13 +307,15 @@ Page({
this
.
animation
.
bottom
(
0
).
step
()
this
.
animation
.
bottom
(
0
).
step
()
this
.
setData
({
this
.
setData
({
topAnimation
:
this
.
animation
.
export
(),
topAnimation
:
this
.
animation
.
export
(),
enlargeUrl
:
this
.
data
.
imgrecturl
enlargeUrl
:
this
.
data
.
imgrecturl
,
isToEnLarge
:
true
})
})
},
},
toCancelEnlargePic
()
{
toCancelEnlargePic
()
{
this
.
animation
.
bottom
(
'
-100%
'
).
step
()
this
.
animation
.
bottom
(
'
-100%
'
).
step
()
this
.
setData
({
this
.
setData
({
topAnimation
:
this
.
animation
.
export
()
topAnimation
:
this
.
animation
.
export
(),
isToEnLarge
:
false
})
})
}
}
})
})
\ No newline at end of file
pages/dangeredit/dangeredit.wxml
View file @
55611f2f
...
@@ -25,7 +25,10 @@
...
@@ -25,7 +25,10 @@
<text>隐患名称:</text>
<text>隐患名称:</text>
<textarea type="text" disabled="true" placeholder="请输入隐患名称" value="{{hdName}}" bindinput="" maxlength="-1" />
<textarea type="text" disabled="true" placeholder="请输入隐患名称" value="{{hdName}}" bindinput="" maxlength="-1" />
</view>
</view>
<view class="danger-expert">
<text>备注: </text>
<input type="text" disabled="true" placeholder="请输入备注" value="{{comment}}" bindinput="" />
</view>
<!-- <view class="danger-type">
<!-- <view class="danger-type">
<text>隐患类型:</text>
<text>隐患类型:</text>
<radio-group bindchange="">
<radio-group bindchange="">
...
@@ -84,7 +87,7 @@
...
@@ -84,7 +87,7 @@
<button type="primary" bindtap="submitEdit" style="background-color: #1d2089;">提交修改</button>
<button type="primary" bindtap="submitEdit" style="background-color: #1d2089;">提交修改</button>
</view>
</view>
</scroll-view>
</scroll-view>
<view class="enlarge-pic-wrapper
" animation="{{topAnimation
}}">
<view class="enlarge-pic-wrapper
{{isToEnLarge? 'enlarge-pic-show': ''
}}">
<image
<image
src="{{enlargeUrl}}"
src="{{enlargeUrl}}"
mode="aspectFit"
mode="aspectFit"
...
...
pages/dangeredit/dangeredit.wxss
View file @
55611f2f
...
@@ -160,15 +160,20 @@
...
@@ -160,15 +160,20 @@
}
}
.enlarge-pic-wrapper {
.enlarge-pic-wrapper {
position: absolute;
position: fixed;
bottom: -100%;
display: none;
width: 100vw;
z-index: 999;
height: 100vh;
left: 0;
top: 0;
bottom: 0;
right: 0;
background-color: black;
background-color: black;
display: flex;
align-items: center;
align-items: center;
justify-content: center;
justify-content: center;
}
}
.enlarge-pic-show {
display: flex;
}
.enlarge-pic {
.enlarge-pic {
width: 100vw;
width: 100vw;
height: 100vh;
height: 100vh;
...
...
pages/dangerregister/dangerregister.js
View file @
55611f2f
...
@@ -6,6 +6,33 @@ Page({
...
@@ -6,6 +6,33 @@ Page({
* 页面的初始数据
* 页面的初始数据
*/
*/
data
:
{
data
:
{
// 总的安全类别
secType
:
[
{
name
:
'
安全资料类
'
},
{
name
:
'
现场检查类
'
}
],
//
curSelectSecType
:
''
,
// 安全检查类别
secCheckType
:
[],
// 安全检查类别替代
secCheckTypeReplace
:
[],
// 当前选择的安全检查类别
curSelectSecCheckTypeReplace
:
''
,
// 安全检查内容
secCheckContent
:
[],
// 当前选择的安全检查内容
curSelectCheckContent
:
''
,
// 发现问题
secCheckDiscover
:
[],
// 整改建议
suggestion
:
''
,
// 检查依据
basis
:
''
,
// 企业id
// 企业id
companyId
:
app
.
globalData
.
currentEnter
.
companyId
,
companyId
:
app
.
globalData
.
currentEnter
.
companyId
,
// 隐患验收人
// 隐患验收人
...
@@ -37,7 +64,10 @@ Page({
...
@@ -37,7 +64,10 @@ Page({
// 隐患图片文件路径
// 隐患图片文件路径
hdFilePath
:
''
,
hdFilePath
:
''
,
// 整改图片文件路径
// 整改图片文件路径
rectFilePath
:
''
rectFilePath
:
''
,
// 备注
comment
:
''
,
//
},
},
/**
/**
...
@@ -65,6 +95,24 @@ Page({
...
@@ -65,6 +95,24 @@ Page({
backgroundColor
:
'
#090D9C
'
,
backgroundColor
:
'
#090D9C
'
,
frontColor
:
'
#ffffff
'
,
frontColor
:
'
#ffffff
'
,
})
})
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrl
+
'
/api/enterpriseSafetyInspectionContent
'
,
method
:
'
GET
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
level
:
1
,
page
:
0
,
size
:
9999
},
success
:
res
=>
{
console
.
log
(
res
,
'
企业安全检查类别 企业安全检查类别
'
)
this
.
setData
({
secCheckType
:
res
.
data
.
content
})
}
})
},
},
/**
/**
...
@@ -102,6 +150,58 @@ Page({
...
@@ -102,6 +150,58 @@ Page({
},
},
chooseSecCheckType
(
event
)
{
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrl
+
'
/api/enterpriseSafetyInspectionContent
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
level
:
2
,
page
:
0
,
size
:
9999
,
pid
:
this
.
data
.
secCheckType
[
event
.
detail
.
value
].
id
},
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
chooseSecCheckType chooseSecCheckType chooseSecCheckType
'
)
this
.
setData
({
secCheckContent
:
[...
res
.
data
.
content
],
curSelectSecCheckTypeReplace
:
this
.
data
.
secCheckType
[
event
.
detail
.
value
].
name
})
}
})
},
chooseSecCheckContent
(
event
)
{
console
.
log
(
this
.
data
.
secCheckContent
[
event
.
detail
.
value
],
'
chooseSecCheckContent chooseSecCheckContent chooseSecCheckContent
'
)
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrl
+
'
/api/enterpriseSafetyMatter
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
inspectionContentId
:
this
.
data
.
secCheckContent
[
event
.
detail
.
value
].
id
,
page
:
0
,
size
:
9999
},
success
:
(
res
)
=>
{
this
.
setData
({
secCheckDiscover
:
res
.
data
.
content
,
curSelectCheckContent
:
this
.
data
.
secCheckContent
[
event
.
detail
.
value
].
name
})
}
})
},
chooseSecCheckDiscover
(
event
)
{
this
.
data
.
hdName
=
this
.
data
.
secCheckDiscover
[
event
.
detail
.
value
].
name
this
.
setData
({
hdName
:
this
.
data
.
hdName
,
basis
:
this
.
data
.
secCheckDiscover
[
event
.
detail
.
value
].
basis
,
suggestion
:
this
.
data
.
secCheckDiscover
[
event
.
detail
.
value
].
suggestion
})
},
/**
/**
* 拍照
* 拍照
*/
*/
...
@@ -162,6 +262,10 @@ Page({
...
@@ -162,6 +262,10 @@ Page({
inputHdInspectExpert
(
event
)
{
inputHdInspectExpert
(
event
)
{
this
.
data
.
hdInspectExpert
=
event
.
detail
.
value
this
.
data
.
hdInspectExpert
=
event
.
detail
.
value
},
},
//
inputHdComment
(
event
)
{
this
.
data
.
comment
=
event
.
detail
.
value
},
// 输入隐患名称
// 输入隐患名称
inputHdName
(
event
)
{
inputHdName
(
event
)
{
this
.
data
.
hdName
=
event
.
detail
.
value
this
.
data
.
hdName
=
event
.
detail
.
value
...
@@ -171,10 +275,17 @@ Page({
...
@@ -171,10 +275,17 @@ Page({
console
.
log
(
event
,
'
hdTypeInput
'
)
console
.
log
(
event
,
'
hdTypeInput
'
)
this
.
data
.
hdLevel
=
event
.
detail
.
value
this
.
data
.
hdLevel
=
event
.
detail
.
value
},
},
// 输入检查依据
inpoutBasis
(
event
)
{
this
.
data
.
basis
=
event
.
detail
.
value
},
// 输入整改建议
// 输入整改建议
inputRectSug
(
event
)
{
inputRectSug
(
event
)
{
console
.
log
(
event
,
'
请输入整改建议
'
)
console
.
log
(
event
,
'
请输入整改建议
'
)
this
.
data
.
hdRectificationSug
=
event
.
detail
.
value
// this.data.hdRectificationSug = event.detail.value
this
.
data
.
suggestion
=
event
.
detail
.
value
},
},
// 输入整改日期
// 输入整改日期
inputRectDate
(
event
)
{
inputRectDate
(
event
)
{
...
@@ -306,5 +417,16 @@ Page({
...
@@ -306,5 +417,16 @@ Page({
dataString
+=
`\r\nContent-Disposition: form-data; name="
${
key
}
"\r\n\r\n
${
formdata
[
key
]}
\r\n--XXX`
dataString
+=
`\r\nContent-Disposition: form-data; name="
${
key
}
"\r\n\r\n
${
formdata
[
key
]}
\r\n--XXX`
}
}
return
dataString
return
dataString
},
chooseSecType
(
event
)
{
console
.
log
(
event
,
'
chooseSecType chooseSecType chooseSecType
'
)
// this.setData({
// secCheckTypeReplace:
// })
this
.
setData
({
secCheckTypeReplace
:
this
.
data
.
secCheckType
.
filter
(
item
=>
item
.
type
===
this
.
data
.
secType
[
event
.
detail
.
value
].
name
),
curSelectSecType
:
this
.
data
.
secType
[
event
.
detail
.
value
].
name
})
}
}
})
})
\ No newline at end of file
pages/dangerregister/dangerregister.wxml
View file @
55611f2f
<!--pages/dangerregister/dangerregister.wxml-->
<!--pages/dangerregister/dangerregister.wxml-->
<view class="danger-register-wrapper">
<view class="danger-register-wrapper">
<view class="danger-form-wrapper">
<view class="danger-form-wrapper">
<!-- <view class="danger-order">
<text>序号:</text>
<input type="text" disabled="true" />
</view> -->
<view class="danger-check-date">
<view class="danger-check-date">
<text>检查日期:</text>
<text>检查日期:</text>
<picker class="danger-pick-date" mode="date" value="{{hdInspectDate}}" bindchange="selectCheckDate">
<picker class="danger-pick-date" mode="date" value="{{hdInspectDate}}" bindchange="selectCheckDate">
...
@@ -19,29 +15,108 @@
...
@@ -19,29 +15,108 @@
<input type="text" placeholder="请输入专家名称" bindinput="inputHdInspectExpert" />
<input type="text" placeholder="请输入专家名称" bindinput="inputHdInspectExpert" />
</view>
</view>
<view class="danger-name">
<text>隐患名称:</text>
<textarea type="text" placeholder="请输入隐患名称" bindinput="inputHdName" maxlength="-1"/>
</view>
<view class="danger-type">
<view class="danger-type">
<text>隐患
类型
:</text>
<text>隐患
等级
:</text>
<radio-group bindchange="inputHDType">
<radio-group bindchange="inputHDType">
<radio checked="{{true}}" value="1" color="#1d2089">一般隐患</radio>
<radio checked="{{true}}" value="1" color="#1d2089">一般隐患</radio>
<radio checked="{{false}}" value="2" color="#1d2089">重大隐患</radio>
<radio checked="{{false}}" value="2" color="#1d2089">重大隐患</radio>
</radio-group>
</radio-group>
</view>
</view>
<view class="c11-1">
<text>安全类别:</text>
<view>
<picker
header-text="安全类别"
mode="selector"
range="{{secType}}"
range-key="name"
bindchange="chooseSecType"
>
当前选择: {{curSelectSecType}}
</picker>
</view>
</view>
<view class="c11-1">
<text>安全检查类别</text>
<view>
<picker
header-text="安全检查类别"
mode="selector"
range="{{secCheckTypeReplace}}"
range-key="name"
bindchange="chooseSecCheckType"
>
当前选择: {{curSelectSecCheckTypeReplace}}
</picker>
</view>
</view>
<view class="c11-1">
<text>安全检查内容</text>
<view>
<picker
header-text="安全检查内容"
mode="selector"
range="{{secCheckContent}}"
range-key="name"
bindchange="chooseSecCheckContent"
>当前选择: {{curSelectCheckContent}}</picker>
</view>
</view>
<view class="c11-1">
<text>发现问题</text>
<view>
<picker
header-text="发现问题"
mode="selector"
range="{{secCheckDiscover}}"
range-key="name"
bindchange="chooseSecCheckDiscover"
>当前选择:{{hdName}}</picker>
</view>
</view>
<view class="c11-1">
<text>检查依据</text>
<view>
<textarea maxlength="-1" bindinput="inpoutBasis" value="{{basis}}"/>
</view>
</view>
<view class="danger-rect">
<view class="danger-rect">
<text>整改建议:</text>
<text>整改建议:</text>
<textarea maxlength="-1" bindinput="inputRectSug" value="{{}}"></textarea>
<textarea maxlength="-1" bindinput="inputRectSug" value="{{
suggestion
}}"></textarea>
</view>
</view>
<!--<view class="c11-1">
<text>整改建议</text>
<view>
<textarea value="{{suggestion}}" />
</view>
</view>-->
<view class="danger-img">
<view class="danger-img">
<text>隐患照片</text>
<text>隐患照片</text>
<!-- <camera device-position="back" flash="off" style="width:100%;height:300px;"></camera> -->
<!-- <camera device-position="back" flash="off" style="width:100%;height:300px;"></camera> -->
<image mode="aspectFit" src="{{imgsrcurl}}"></image>
<image mode="aspectFit" src="{{imgsrcurl}}"></image>
<button type="primary" bindtap="takePhoto">拍照</button>
<button type="primary" bindtap="takePhoto">拍照</button>
</view>
</view>
<view class="danger-expert">
<text>备注</text>
<input type="text" placeholder="备注"
bindinput="inputHdComment" />
</view>
<!-- <view class="danger-preview">
<!-- <view class="danger-preview">
<text>隐患照片预览:</text>
<text>隐患照片预览:</text>
...
...
pages/dangerregister/dangerregister.wxss
View file @
55611f2f
...
@@ -59,6 +59,12 @@
...
@@ -59,6 +59,12 @@
border-radius: 5px;
border-radius: 5px;
box-shadow: 1rpx 1rpx 0.5rpx 0.5rpx #eee, -1rpx -1rpx 0.5rpx 0.5rpx #eee;
box-shadow: 1rpx 1rpx 0.5rpx 0.5rpx #eee, -1rpx -1rpx 0.5rpx 0.5rpx #eee;
}
}
.child-hdname {
padding: 20rpx;
border-radius: 5rpx;
box-shadow: 1rpx 1rpx 0.5rpx 0.5rpx #eee, -1rpx -1rpx 0.5rpx 0.5rpx #eee;
margin: 10rpx 10rpx;
}
.danger-type {
.danger-type {
display: flex;
display: flex;
...
@@ -149,4 +155,13 @@
...
@@ -149,4 +155,13 @@
.danger-submit button {
.danger-submit button {
background-color: #1d2089!important;
background-color: #1d2089!important;
}
.c11-1 {
display: flex;
background-color: white;
margin: 3vh 5vw;
justify-content: space-between;
padding: 1vh 2vw;
border-radius: 5px;
box-shadow: 1rpx 1rpx 0.5rpx 0.5rpx #eee, -1rpx -1rpx 0.5rpx 0.5rpx #eee;
}
}
\ No newline at end of file
pages/evaluate/evaluate.js
View file @
55611f2f
// pages/evaluate/evaluate.js
// pages/evaluate/evaluate.js
import
*
as
echarts
from
'
../ec-canvas/echarts
'
const
app
=
getApp
();
function
initChart
(
canvas
,
width
,
height
,
dpr
)
{
const
chart
=
echarts
.
init
(
canvas
,
null
,
{
width
:
width
,
height
:
height
,
devicePixelRatio
:
dpr
// new
});
canvas
.
setChart
(
chart
);
var
option
=
{
backgroundColor
:
"
#ffffff
"
,
series
:
[{
label
:
{
normal
:
{
fontSize
:
14
}
},
type
:
'
pie
'
,
center
:
[
'
50%
'
,
'
50%
'
],
radius
:
[
'
20%
'
,
'
40%
'
],
data
:
[{
value
:
app
.
globalData
.
curEvaluate
.
lessThan60PeopleNum
,
name
:
'
低于60分人数
'
},
{
value
:
app
.
globalData
.
curEvaluate
.
between60And70PeopleNum
,
name
:
'
60到70分之间的人数
'
},
{
value
:
app
.
globalData
.
curEvaluate
.
between70And80PeopleNum
,
name
:
'
70到80分之间的人数
'
},
{
value
:
app
.
globalData
.
curEvaluate
.
between80And90PeopleNum
,
name
:
'
80到90分之间的人数
'
},
{
value
:
app
.
globalData
.
curEvaluate
.
moreThan90PeopleNum
,
name
:
'
高于90分的人数
'
}]
}]
};
chart
.
setOption
(
option
);
return
chart
;
}
/**
* avgScore integer($int32)
企业平均考试成绩
lessThan60PeopleNum integer($int32)
低于60分人数
moreThan90PeopleNum integer($int32)
高于90分的人数
between60And70PeopleNum integer($int32)
60到70分之间的人数
between70And80PeopleNum integer($int32)
70到80分之间的人数
between80And90PeopleNum integer($int32)
80到90分之间的人数
courseCompletedLearnerNum integer($int32)
完成全部课程人数
courseCompletedLearnerRate string
完成全部课程比例(%)
courseLearnerNum integer($int32)
参与学习人数
courseLearnerRate string
学习比例(%)
courseStarLevel integer($int32)
课程评价星级
examCompletedExamineeNum integer($int32)
完成全部考试人数
examCompletedExamineeRate string
完成全部考试比例(%)
examStarLevel integer($int32)
考试评价星级
examineeNum integer($int32)
参与考试人数
examineeRate string
参与考试比例(%)
totalPeopleNum integer($int32)
总人数
*/
Page
({
Page
({
/**
/**
...
@@ -7,14 +105,76 @@ Page({
...
@@ -7,14 +105,76 @@ Page({
data
:
{
data
:
{
grayStar
:
'

'
,
grayStar
:
'

'
,
yelloStar
:
'

'
,
yelloStar
:
'

'
,
headPotraitPic
:
'

'
headPotraitPic
:
''
,
completedCourseNum
:
0
,
completedCourseRate
:
"
0%
"
,
completedPaperNum
:
0
,
completedPaperRate
:
"
0%
"
,
courseStarLevel
:
0
,
paperStarLevel
:
0
,
totalCourseNum
:
0
,
totalPaperNum
:
0
,
isManager
:
false
,
isStaff
:
false
,
avgScore
:
0
,
lessThan60PeopleNum
:
0
,
between60And70PeopleNum
:
0
,
between70And80PeopleNum
:
0
,
between80And90PeopleNum
:
0
,
moreThan90PeopleNum
:
0
,
courseCompletedLearnerNum
:
0
,
courseCompletedLearnerRate
:
0
,
courseLearnerNum
:
0
,
courseLearnerRate
:
0
,
courseStarLevel1
:
0
,
examCompletedExamineeNum
:
0
,
examCompletedExamineeRate
:
0
,
examStarLevel
:
0
,
examineeNum
:
0
,
examineeRate
:
0
,
totalPeopleNum
:
0
,
ec
:
{
onInit
:
initChart
}
},
},
/**
/**
* 生命周期函数--监听页面加载
* 生命周期函数--监听页面加载
*/
*/
onLoad
:
function
(
options
)
{
onLoad
:
function
(
options
)
{
console
.
log
(
app
.
globalData
,
'
app.globalData app.globalData
'
)
if
(
app
.
globalData
.
curRole
===
'
企业管理
'
)
{
this
.
setData
({
isManager
:
true
,
...
app
.
globalData
.
curEvaluate
})
}
if
(
app
.
globalData
.
curRole
===
'
企业员工
'
)
{
this
.
setData
({
isStaff
:
true
})
}
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/learningEvaluation/evaluatePerson
'
,
method
:
'
GET
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
app.globalData
'
)
this
.
setData
({
completedCourseNum
:
res
.
data
.
completedCourseNum
,
completedCourseRate
:
res
.
data
.
completedCourseRate
,
completedPaperNum
:
res
.
data
.
completedPaperNum
,
completedPaperRate
:
res
.
data
.
completedPaperRate
,
courseStarLevel
:
res
.
data
.
courseStarLevel
,
paperStarLevel
:
res
.
data
.
paperStarLevel
,
totalCourseNum
:
res
.
data
.
totalCourseNum
,
totalPaperNum
:
res
.
data
.
totalPaperNum
})
}
})
console
.
log
(
app
.
globalData
.
curRole
,
'
app.globalData.curRole
'
)
},
},
/**
/**
...
...
pages/evaluate/evaluate.json
View file @
55611f2f
{
{
"usingComponents"
:
{}
"usingComponents"
:
{
"ec-canvas"
:
"../ec-canvas/ec-canvas"
}
}
}
\ No newline at end of file
pages/evaluate/evaluate.wxml
View file @
55611f2f
<!--pages/evaluate/evaluate.wxml-->
<!--pages/evaluate/evaluate.wxml-->
<view class="evaluate-wrapper">
<view class="evaluate-wrapper">
<view class="card-wrapper">
<view class="card-wrapper">
<view class="nickname-wrapper">相善若水</view>
<
!-- <
view class="nickname-wrapper">相善若水</view>
<view class="nickname-interface">当前用户名称</view>
<view class="nickname-interface">当前用户名称</view>
-->
<view class="person-image-wrapper">
<
!-- <
view class="person-image-wrapper">
<image class="person-image" src="{{headPotraitPic}}"></image>
<image class="person-image" src="{{headPotraitPic}}"></image>
</view> -->
<!-- <view class="entry-belong-to">所属企业</view>
<view class="entry-name">威海华发房地产开发有限公司</view> -->
<view wx:if="{{ isStaff }}">
<view class="study-info">学习情况</view>
<view class="complete-class">完成<span class="complete-degree">{{completedCourseNum}}</span>课程/共<span class="complete-degree">{{totalCourseNum}}</span>课程</view>
<view class="complete-percent">完成百分比: <span class="complete-degree">{{completedCourseRate}}</span></view>
<view class="evaluate-star">评价: <image wx:for="{{courseStarLevel}}" class="star-for-evaluate" src="{{yelloStar}}"></image><image wx:for="{{5 - courseStarLevel}}" class="star-for-evaluate"src="{{grayStar}}"></image></view>
<view class="study-info to-top-margin">考试情况</view>
<view class="complete-class">完成<span class="complete-degree">{{completedPaperNum}}</span>课程/共<span class="complete-degree">{{totalPaperNum}}</span>课程</view>
<view class="complete-percent">完成百分比: <span class="complete-degree">{{completedPaperRate}}</span></view>
<view class="evaluate-star">评价: <image wx:for="{{courseStarLevel}}"class="star-for-evaluate" src="{{yelloStar}}"></image><image wx:for="{{5 - courseStarLevel}}" class="star-for-evaluate"src="{{grayStar}}"></image></view>
</view>
<view wx:if="{{ isManager }}">
<view>
<view class="class1-0">参与学习情况</view>
<view class="class2-0">
<span class="class2-2">参与<text class="class2-1">{{courseLearnerNum}}</text>人</span>
<span class="class2-2">参与度<text class="class2-1">{{courseLearnerRate}}</text></span>
</view>
<view class="class2-0">
<span class="class2-2">完成全部课程<text class="class2-1">{{courseCompletedLearnerNum}}</text>人</span>
<span class="class2-2">共<text class="class2-1">{{totalPeopleNum}}</text>人</span>
<span class="class2-2">完成度<text class="class2-1">{{courseCompletedLearnerRate}}</text></span>
</view>
</view>
<view>
<view class="class1-0">参与考试情况</view>
<view class="class2-0">
<span class="class2-2">参与<text class="class2-1">{{examineeNum}}</text>人</span>
<span class="class2-2">共<text class="class2-1">{{totalPeopleNum}}</text>人</span>
</view>
<view class="class2-0">
<span class="class2-2">完成全部考试<text class="class2-1">{{examCompletedExamineeNum}}</text>人</span>
<span class="class2-2">共<text class="class2-1">{{totalPeopleNum}}</text>人</span>
<span class="class2-2">完成度<text class="class2-1">{{examCompletedExamineeRate}}</text></span>
</view>
</view>
<view>
<view class="class1-0">成绩统计情况</view>
<view class="class2-0" wx:if="{{avgScore !== null}}">
<span class="class2-2">企业平均成绩<text class="class2-1">{{avgScore}}</text>分</span>
</view>
<view class="evaluate-star">评价: <image wx:for="{{courseStarLevel}}" class="star-for-evaluate" src="{{yelloStar}}"></image><image wx:for="{{5 - courseStarLevel}}" class="star-for-evaluate"src="{{grayStar}}"></image></view>
<view class="container" style="width: 500rpx;height: 500rpx;display: flex;justify-content: center;margin: 0 auto;" wx:if="{{avgScore !== null}}">
<ec-canvas style="width: 700rpx;height: 500rpx;" id="mychart-dom-pie" canvas-id="mychart-pie" ec="{{ ec }}"></ec-canvas>
</view>
</view>
</view>
</view>
<view class="entry-belong-to">所属企业</view>
<view class="entry-name">威海华发房地产开发有限公司</view>
<view class="study-info">学习情况</view>
<view class="complete-class">完成<span class="complete-degree">2</span>课程/共<span class="complete-degree">10</span>课程</view>
<view class="complete-percent">完成百分比: <span class="complete-degree">20%</span></view>
<view class="evaluate-star">评价: <image class="star-for-evaluate" src="{{yelloStar}}"></image><image class="star-for-evaluate" src="{{yelloStar}}"></image><image class="star-for-evaluate"src="{{yelloStar}}"></image><image class="star-for-evaluate"src="{{yelloStar}}"></image><image class="star-for-evaluate"src="{{grayStar}}"></image></view>
<view class="study-info to-top-margin">考试情况</view>
<view class="complete-class">完成<span class="complete-degree">2</span>课程/共<span class="complete-degree">10</span>课程</view>
<view class="complete-percent">完成百分比: <span class="complete-degree">20%</span></view>
<view class="evaluate-star">评价: <image class="star-for-evaluate" src="{{yelloStar}}"></image><image class="star-for-evaluate" src="{{yelloStar}}"></image><image class="star-for-evaluate"src="{{yelloStar}}"></image><image class="star-for-evaluate"src="{{yelloStar}}"></image><image class="star-for-evaluate"src="{{grayStar}}"></image></view>
</view>
</view>
<view class="bgcolor-cover"></view>
<view class="bgcolor-cover"></view>
</view>
</view>
\ No newline at end of file
pages/evaluate/evaluate.wxss
View file @
55611f2f
...
@@ -121,4 +121,39 @@
...
@@ -121,4 +121,39 @@
background-color: #090D9C;
background-color: #090D9C;
z-index: -1;
z-index: -1;
border-radius: 0 0 70rpx 70rpx;
border-radius: 0 0 70rpx 70rpx;
}
.class1-0 {
position: relative;
font-size: 34rpx;
font-family: 'PingFang SC';
font-weight: bold;
color: #333333;
line-height: 39rpx;
margin: 10rpx 38rpx;
}
.class1-0::before {
content: '';
display: block;
position: absolute;
left: -20rpx;
top: 50%;
width: 11rpx;
height: 29rpx;
background: #090D9C;
transform: translatey(-50%);
}
.class2-0 {
margin-left: 38rpx;
font-family: 'PingFang-SC-Medium';
font-size: 30rpx;
}
.class2-1 {
color: #090D9C;
font-family: 'PingFang-SC-Medium';
font-size: 38rpx;
margin: 0 10rpx;
}
.class2-2 {
margin-right: 30rpx;
}
}
\ No newline at end of file
pages/exam/exam.js
View file @
55611f2f
// pages/exam/exam.js
// pages/exam/exam.js
const
app
=
getApp
();
Page
({
Page
({
/**
/**
...
@@ -27,11 +28,37 @@ Page({
...
@@ -27,11 +28,37 @@ Page({
* 生命周期函数--监听页面加载
* 生命周期函数--监听页面加载
*/
*/
onLoad
:
function
(
options
)
{
onLoad
:
function
(
options
)
{
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/onlineExamPaper/page
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
page
:
0
,
size
:
999
},
success
:
(
res
)
=>
{
if
(
res
.
statusCode
===
200
)
{
console
.
log
(
res
.
data
.
content
,
'
res.data.content res.data.content
'
)
res
.
data
.
content
.
forEach
(
item
=>
{
if
(
!
item
.
score
)
{
item
.
isExamed
=
false
item
.
score
=
0
}
else
{
item
.
isExamed
=
true
}
})
this
.
setData
({
examList
:
res
.
data
.
content
})
}
}
})
},
},
/**
/**
* 生命周期函数--监听页面初次渲染完成
* 生命周期函数--监听页面初次渲染完成
*/
*/
onReady
:
function
()
{
onReady
:
function
()
{
...
@@ -48,6 +75,13 @@ Page({
...
@@ -48,6 +75,13 @@ Page({
backgroundColor
:
'
#090D9C
'
,
backgroundColor
:
'
#090D9C
'
,
frontColor
:
'
#ffffff
'
,
frontColor
:
'
#ffffff
'
,
})
})
if
(
app
.
globalData
.
isNeedNavigateTo
)
{
app
.
globalData
.
isNeedNavigateTo
=
false
wx
.
navigateTo
({
url
:
'
/pages/testpaper/testpaper?id=
'
+
app
.
globalData
.
testPaperId
+
'
&singleScore=
'
+
app
.
globalData
.
singleScore
+
'
&multiScore=
'
+
app
.
globalData
.
multiScore
+
'
&justifyScore=
'
+
app
.
globalData
.
justifyScore
,
success
:
function
(
event
)
{}
})
}
},
},
/**
/**
...
@@ -97,20 +131,47 @@ Page({
...
@@ -97,20 +131,47 @@ Page({
this
.
setData
({
this
.
setData
({
animationSearch
:
repAnimation
.
export
()
animationSearch
:
repAnimation
.
export
()
})
})
},
/**
* 搜索考试内容
*/
searchExam
()
{
},
},
/**
/**
* 跳转到考试试题
* 跳转到考试试题
*/
*/
LinkToTestPaper
()
{
LinkToTestPaper
(
event
)
{
wx
.
navigateTo
({
wx
.
navigateTo
({
url
:
'
/pages/testpaper/testpaper
'
,
url
:
'
/pages/testpaper/testpaper
?id=
'
+
event
.
currentTarget
.
dataset
.
index
.
id
+
'
&singleScore=
'
+
event
.
currentTarget
.
dataset
.
index
.
singleChoiceScore
+
'
&multiScore=
'
+
event
.
currentTarget
.
dataset
.
index
.
multipleChoiceScore
+
'
&justifyScore=
'
+
event
.
currentTarget
.
dataset
.
index
.
judgmentScore
,
success
:
function
(
event
)
{}
success
:
function
(
event
)
{}
})
})
},
/**
* 搜索考试内容
*/
searchExam
(
event
)
{
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/onlineExamPaper/page
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
page
:
0
,
size
:
999
,
name
:
event
.
detail
.
value
},
success
:
(
res
)
=>
{
if
(
res
.
statusCode
===
200
)
{
console
.
log
(
res
.
data
.
content
,
'
res.data.content res.data.content
'
)
res
.
data
.
content
.
forEach
(
item
=>
{
if
(
!
item
.
score
)
{
item
.
isExamed
=
false
item
.
score
=
0
}
else
{
item
.
isExamed
=
true
}
})
this
.
setData
({
examList
:
res
.
data
.
content
})
}
}
})
}
}
})
})
\ No newline at end of file
pages/exam/exam.wxml
View file @
55611f2f
...
@@ -11,18 +11,31 @@
...
@@ -11,18 +11,31 @@
</input>
</input>
</view>
</view>
<scroll-view scroll-y="true" class="exam-scroll-wrapper">
<scroll-view scroll-y="true" class="exam-scroll-wrapper">
<view wx:for="{{examList}}" class="exam-list-wrapper">
<view wx:for="{{examList}}" class="class1-0">
<view class="class1-1">{{item.name}}</view>
<view class="class1-2">
<view class="class1-3">
<view class="exam-score" wx:if="{{item.isExamed}}">
已考试: {{item.score}}分
</view>
<view wx:else class="no-exam">还未考试</view>
</view>
<button class="startExamBtn" data-index="{{item}}"
bindtap="LinkToTestPaper">开始考试</button>
</view>
</view>
<!-- <view wx:for="{{examList}}" class="exam-list-wrapper">
<image src="{{item.coverPic}}" class="exam-cover"></image>
<image src="{{item.coverPic}}" class="exam-cover"></image>
<view class="down-wrapper">
<view class="down-wrapper">
<view class="down-title">{{item.
examN
ame}}</view>
<view class="down-title">{{item.
n
ame}}</view>
<view class="exam-score-wrapper">
<view class="exam-score-wrapper">
<view class="exam-score" wx:if="{{item.isExamed}}">
<view class="exam-score" wx:if="{{item.isExamed}}">
已考试: {{item.score}}分
已考试: {{item.score}}分
</view>
</view>
<view wx:else class="no-exam">还未考试</view>
<view wx:else class="no-exam">还未考试</view>
</view>
</view>
<button class="startExamBtn" bindtap="LinkToTestPaper">开始考试</button>
<button class="startExamBtn"
data-index="{{item}}"
bindtap="LinkToTestPaper">开始考试</button>
</view>
</view>
</view>
</view>
-->
</scroll-view>
</scroll-view>
</view>
</view>
\ No newline at end of file
pages/exam/exam.wxss
View file @
55611f2f
...
@@ -110,4 +110,24 @@
...
@@ -110,4 +110,24 @@
/* line-height: 43rpx!important; */
/* line-height: 43rpx!important; */
/* display: flex;
/* display: flex;
align-items: center; */
align-items: center; */
}
}
\ No newline at end of file
.class1-0 {
width: 710rpx;
margin: 20rpx auto;
box-shadow: 2rpx 2rpx 2rpx 2rpx #eee, -1rpx -1rpx 1rpx 1rpx #eee;
border-radius: 20rpx;
overflow: hidden;
padding-top: 10rpx;
}
.class1-1 {
margin-top: 20rpx;
margin-left: 20rpx;
}
.class1-2 {
margin-top: 30rpx;
display: flex;
align-items: center;
justify-content: space-between;
padding: 5rpx 20rpx;
}
pages/home/home.js
View file @
55611f2f
...
@@ -165,10 +165,31 @@ Page({
...
@@ -165,10 +165,31 @@ Page({
* 跳转到学习评价
* 跳转到学习评价
*/
*/
LinkToEvaluate
()
{
LinkToEvaluate
()
{
wx
.
navigateTo
({
if
(
app
.
globalData
.
curRole
===
'
企业管理
'
)
{
url
:
'
/pages/evaluate/evaluate
'
,
wx
.
request
({
success
:
function
(
event
)
{}
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/learningEvaluation/evaluateEnterprise
'
,
})
method
:
'
GET
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
app.globalData.curRole>>>>>>>>>>>>>>>>>>
'
)
app
.
globalData
.
curEvaluate
=
{
...
res
.
data
}
wx
.
navigateTo
({
url
:
'
/pages/evaluate/evaluate
'
,
success
:
function
(
event
)
{}
})
}
})
}
else
{
wx
.
navigateTo
({
url
:
'
/pages/evaluate/evaluate
'
,
success
:
function
(
event
)
{}
})
}
},
},
/**
/**
* 跳转到隐患管理
* 跳转到隐患管理
...
...
pages/info/info.js
View file @
55611f2f
// pages/info/info.js
// pages/info/info.js
const
app
=
getApp
();
Page
({
Page
({
/**
/**
...
@@ -6,30 +7,6 @@ Page({
...
@@ -6,30 +7,6 @@ Page({
*/
*/
data
:
{
data
:
{
infoList
:
[
infoList
:
[
{
title
:
'
[隐患预警] 贵公司“重大隐患”—“联动台紧急停止按钮无效”整改即将到期,请及时整改
'
,
isRead
:
false
,
time
:
'
2020-05-19 19:25
'
,
infoId
:
'
11
'
},
{
title
:
'
[隐患预警] 贵公司“一般隐患”—“力矩限位不灵敏”整改即将到期,请及时整改
'
,
isRead
:
false
,
time
:
'
2020-05-19 19:24
'
,
infoId
:
'
22
'
},
{
title
:
'
[隐患预警] 贵公司“一般隐患”—“起升钢丝绳排布不均匀”整改已超期,请及时整改
'
,
isRead
:
true
,
time
:
'
2020-05-18 17:23
'
,
infoId
:
'
33
'
},
{
title
:
'
[隐患预警] 贵公司“一般隐患”—“脚手架外架与脚手架内架相连,拉接点较少”整改已超期,请及时整改
'
,
isRead
:
true
,
time
:
'
2020-05-18 13:34
'
,
infoId
:
'
44
'
}
]
]
},
},
...
@@ -37,7 +14,29 @@ Page({
...
@@ -37,7 +14,29 @@ Page({
* 生命周期函数--监听页面加载
* 生命周期函数--监听页面加载
*/
*/
onLoad
:
function
(
options
)
{
onLoad
:
function
(
options
)
{
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/infoPush/page
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
method
:
'
get
'
,
data
:
{
page
:
0
,
size
:
999
},
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
info 推送
'
)
this
.
setData
({
infoList
:
res
.
data
.
content
.
map
(
item
=>
{
return
{
title
:
item
.
content
,
isRead
:
false
,
time
:
item
.
createTime
}
})
})
}
})
},
},
/**
/**
...
@@ -58,6 +57,8 @@ Page({
...
@@ -58,6 +57,8 @@ Page({
backgroundColor
:
'
#090D9C
'
,
backgroundColor
:
'
#090D9C
'
,
frontColor
:
'
#ffffff
'
,
frontColor
:
'
#ffffff
'
,
})
})
},
},
/**
/**
...
...
pages/info/info.wxml
View file @
55611f2f
...
@@ -2,12 +2,12 @@
...
@@ -2,12 +2,12 @@
<view class="info-page-wrapper">
<view class="info-page-wrapper">
<scroll-view scroll-y="true" class="info-list-scroll">
<scroll-view scroll-y="true" class="info-list-scroll">
<view wx:for="{{infoList}}" class="info-item-wrapper" wx:key="infoId">
<view wx:for="{{infoList}}" class="info-item-wrapper" wx:key="infoId">
<view wx:if="{{item.isRead}}" class="read-icon">已读</view>
<
!--<
view wx:if="{{item.isRead}}" class="read-icon">已读</view>
<view wx:else class="unread-icon">未读</view>
<view wx:else class="unread-icon">未读</view>
-->
<view wx:if="{{item.isRead}}" class="read-time">{{item.time}}</view>
<view wx:if="{{item.isRead}}" class="read-time">{{item.time}}</view>
<view wx:else class="unread-time">{{item.time}}</view>
<view wx:else class="unread-time">{{item.time}}</view>
<view wx:if="{{item.isRead}}" class="read-point-icon"></view>
<
!--<
view wx:if="{{item.isRead}}" class="read-point-icon"></view>
<view wx:else class="unread-point-icon"></view>
<view wx:else class="unread-point-icon"></view>
-->
<view wx:if="{{item.isRead}}" class="info-item-read-title">{{item.title}}</view>
<view wx:if="{{item.isRead}}" class="info-item-read-title">{{item.title}}</view>
<view wx:else class="info-item-title">{{item.title}}</view>
<view wx:else class="info-item-title">{{item.title}}</view>
</view>
</view>
...
...
pages/info/info.wxss
View file @
55611f2f
...
@@ -17,7 +17,7 @@
...
@@ -17,7 +17,7 @@
box-sizing: border-box;
box-sizing: border-box;
margin: 30rpx auto;
margin: 30rpx auto;
padding-top: 45rpx;
padding-top: 45rpx;
padding-left:
6
0rpx;
padding-left:
2
0rpx;
padding-right: 8rpx;
padding-right: 8rpx;
border-radius: 10rpx;
border-radius: 10rpx;
box-shadow: 2rpx 2rpx 2rpx 2rpx #eee, -1.5rpx -1.5rpx 1.5rpx 1.5rpx #eee;
box-shadow: 2rpx 2rpx 2rpx 2rpx #eee, -1.5rpx -1.5rpx 1.5rpx 1.5rpx #eee;
...
...
pages/law/law.js
View file @
55611f2f
...
@@ -29,7 +29,7 @@ Page({
...
@@ -29,7 +29,7 @@ Page({
data
:
{
data
:
{
page
:
this
.
data
.
curPage
,
page
:
this
.
data
.
curPage
,
size
:
this
.
data
.
curPageSize
,
size
:
this
.
data
.
curPageSize
,
sort
:
'
law
D
ate,desc
'
sort
:
'
law
_d
ate,desc
'
},
},
success
:
(
res
)
=>
{
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
wx.request
'
)
console
.
log
(
res
,
'
wx.request
'
)
...
...
pages/teach/teach.js
View file @
55611f2f
...
@@ -144,6 +144,7 @@ Page({
...
@@ -144,6 +144,7 @@ Page({
console
.
log
(
res
,
'
authorization authorization authorizatoin
'
)
console
.
log
(
res
,
'
authorization authorization authorizatoin
'
)
let
courses
=
[]
let
courses
=
[]
courses
=
[...
res
.
data
.
content
]
courses
=
[...
res
.
data
.
content
]
console
.
log
(
courses
,
'
courses courses courses courses
'
)
for
(
let
i
=
0
;
i
<
courses
.
length
;
i
++
)
{
for
(
let
i
=
0
;
i
<
courses
.
length
;
i
++
)
{
courses
[
i
].
coursehour
=
[]
courses
[
i
].
coursehour
=
[]
courses
[
i
].
sum
=
0
courses
[
i
].
sum
=
0
...
@@ -230,8 +231,61 @@ Page({
...
@@ -230,8 +231,61 @@ Page({
/**
/**
* 用户搜索课程
* 用户搜索课程
*/
*/
searchTeachCourse
()
{
searchTeachCourse
(
event
)
{
console
.
log
(
event
,
'
search______________>>>>>>course
'
)
// 获取所有课程
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/onlineTraining/pageCourse
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
page
:
0
,
size
:
9999
,
courseTitle
:
event
.
detail
.
value
},
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
authorization authorization authorizatoin
'
)
let
courses
=
[]
courses
=
[...
res
.
data
.
content
]
console
.
log
(
courses
,
'
courses courses courses courses
'
)
for
(
let
i
=
0
;
i
<
courses
.
length
;
i
++
)
{
courses
[
i
].
coursehour
=
[]
courses
[
i
].
sum
=
0
courses
[
i
].
isLearnedSum
=
0
courses
[
i
].
validDate
=
6
}
for
(
let
i
=
0
;
i
<
courses
.
length
;
i
++
)
{
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/onlineTraining/findLesson
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
page
:
0
,
size
:
9999
,
pid
:
courses
[
i
].
id
},
success
:
(
res1
)
=>
{
console
.
log
(
res1
,
'
coursehour coursehour
'
)
courses
[
i
].
coursehour
=
[...
res1
.
data
]
courses
[
i
].
sum
=
courses
[
i
].
coursehour
.
length
courses
[
i
].
isLearnedSum
=
courses
[
i
].
coursehour
.
filter
(
item
=>
parseInt
(
item
.
speed
)
>
98
).
length
courses
[
i
].
cover
=
app
.
globalData
.
appBaseUrlV3
+
'
/online-training/cover/
'
+
courses
[
i
].
courseCoverFilePath
.
split
(
'
\\
online-training
\\
cover
\\
'
)[
1
]
courses
[
i
].
introduce
=
courses
[
i
].
courseBriefIntroduction
this
.
setData
({
teachList
:
courses
})
},
fail
:
()
=>
{}
})
}
},
fail
:
()
=>
{}
})
},
},
/**
/**
* 获取焦点
* 获取焦点
...
...
pages/teach/teach.wxml
View file @
55611f2f
...
@@ -21,7 +21,7 @@
...
@@ -21,7 +21,7 @@
<view data-index="{{index}}">{{item.introduce}}</view>
<view data-index="{{index}}">{{item.introduce}}</view>
</view>
</view>
</view>
</view>
<view class="course-subject">课程题目: {{item.
t
itle}}</view>
<view class="course-subject">课程题目: {{item.
courseT
itle}}</view>
<view class="sum-price-wrapper">
<view class="sum-price-wrapper">
<view class="course-sum-wrapper">课程数量: <span>{{item.sum}}</span>课时, 已经学习了<span>{{item.isLearnedSum}}</span>课时</view>
<view class="course-sum-wrapper">课程数量: <span>{{item.sum}}</span>课时, 已经学习了<span>{{item.isLearnedSum}}</span>课时</view>
<view class="price-wrapper">
<view class="price-wrapper">
...
...
pages/testpaper/testpaper.js
View file @
55611f2f
// pages/testpaper/testpaper.js
// pages/testpaper/testpaper.js
const
app
=
getApp
();
Page
({
Page
({
/**
/**
...
@@ -6,385 +7,10 @@ Page({
...
@@ -6,385 +7,10 @@ Page({
*/
*/
data
:
{
data
:
{
singleQuestions
:
[
singleQuestions
:
[
{
questionType
:
'
single
'
,
questionOutline
:
'
生产经营单位的( )是本单位安全生产第一责任人,对本单位的安全生产工作全面负责。
'
,
questionList
:
[
'
主要负责人
'
,
'
董事长
'
,
'
总经理
'
,
'
分管负责人
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《安全生产法》规定:( )发现危及从业人员生命安全的情况时,有权向生产经营单位建议组织从业人员撤离危险场所。
'
,
questionList
:
[
'
工会
'
,
'
从业人员
'
,
'
团队管理方面
'
,
'
安全管理人员
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《安全生产法》规定:事故调查报告应当依法及时向( )公布。
'
,
questionList
:
[
'
社会
'
,
'
从业人员
'
,
'
调查人员
'
,
'
政府有关部门
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《安全生产事故隐患排查治理暂行规定》,生产经营单位对承包、承租单位的事故隐患排查治理负有( )的职责。
'
,
questionList
:
[
'
监督
'
,
'
检查
'
,
'
协调
'
,
'
统一协调和监督管理
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《安全生产违法行为行政处罚办法(2015修正)》,( )以上人民政府安全生产监督管理部门对生产经营单位及其有关人员在生产经营活动中违反有关安全生产的法律、行政法规、部门规章、国家标准、行业标准和规程的违法行为实施行政处罚。
'
,
questionList
:
[
'
国务院
'
,
'
省、自治区、直辖市
'
,
'
设区的市级
'
,
'
县级
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《安全生产违法行为行政处罚办法(2015修正)》,行政处罚案件应当自立案之日起( )日内作出行政处罚决定;由于客观原因不能完成的,经安全监管监察部门负责人同意,可以延长。
'
,
questionList
:
[
'
10日
'
,
'
30日
'
,
'
60日
'
,
'
90日
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《安全生产违法行为行政处罚办法(2015修正)》,进行案件调查时,安全生产行政执法人员不得少于( )。
'
,
questionList
:
[
'
一名
'
,
'
两名
'
,
'
三名
'
,
'
五名
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《关于开展安全生产驻点监管工作的通知》要求,驻点监管时间。暂定为2年,分批次进行,每半年轮换一次。驻点人员进驻到位后,要设置办公地点,日常化开展监管工作;要制定监管工作计划,明确任务完成节点,至少( )向派出单位报告一次驻点监管工作情况。
'
,
questionList
:
[
'
每周
'
,
'
每半月
'
,
'
每月
'
,
'
每半年
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《国务院关于坚持科学发展安全发展促进安全生产形势持续稳定好转的意见》(国发〔2011〕40号)提出:加强安全知识普及和技能培训。全面开展安全生产、应急避险知识进学校、进乡村、进社区、进家庭活动,努力提升( )。
'
,
questionList
:
[
'
全民安全水平
'
,
'
全民安全素质
'
,
'
全民安全知识
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《国务院关于坚持科学发展安全发展促进安全生产形势持续稳定好转的意见》(国发〔2011〕40号)提出:认真落实企业安全生产主体责任,强化企业( )和指挥权,注重发挥注册安全工程师对企业安全状况诊断、评估、整改方面的作用。
'
,
questionList
:
[
'
生产负责人领导决策
'
,
'
主要负责人指挥决策
'
,
'
技术负责人技术决策
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《国务院关于坚持科学发展安全发展促进安全生产形势持续稳定好转的意见》(国发〔2011〕40号)提出:严格危险化学品安全管理。全面开展危险化学品安全管理现状( ),建立危险化学品安全管理信息系统。
'
,
questionList
:
[
'
普查评估
'
,
'
安全评估
'
,
'
风险评估
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《国务院关于进一步加强企业安全生产工作的通知》(国发〔2010〕23号)提出:进一步规范企业生产经营行为。加强对生产现场监督检查,凡( )组织生产的,要责令停产停工整顿,并对企业和企业主要负责人依法给予规定上限的经济处罚。
'
,
questionList
:
[
'
超水平、超强度、超定员
'
,
'
超能力、超强度、超定员
'
,
'
超能力、超强度、超范围
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《国务院关于进一步加强企业安全生产工作的通知》要求,建立完善企业安全生产预警机制。企业要建立完善安全生产动态监控及预警预报体系,每( )进行一次安全生产风险分析。
'
,
questionList
:
[
'
周
'
,
'
月
'
,
'
季度
'
,
'
年
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《山东省人民政府关于贯彻落实国发[2010]23号文件进一步加强企业安全生产工作的意见》(鲁政发[2010]77号)提出:严格执行建设项目安全设施核准审批制度。对项目建设生产经营单位存在违法分包、转包等行为的,立即依法停工停产整顿,并追究项目业主、承包方及( )等各方责任。
'
,
questionList
:
[
'
设计、施工、监理、监管
'
,
'
建设、设计、施工、监管
'
,
'
建设、设计、施工、监理、监管
'
]
},
{
questionType
:
'
single
'
,
questionOutline
:
'
《山东省生产安全事故应急办法》,高危和人员密集单位应当( )对所有专项应急预案至少组织1次演练。
'
,
questionList
:
[
'
每半年
'
,
'
每年
'
,
'
每2年
'
,
'
每3年
'
]
}
],
],
multiQuestions
:
[
multiQuestions
:
[
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《山东省安全生产条例》规定,主要负责人包括对本单位生产经营负有全面领导责任的( )。
'
,
questionList
:
[
'
法定代表人
'
,
'
实际控制人
'
,
'
以及其他主要决策人
'
,
'
技术负责人
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
( ),在遇到险情时第一时间享有下达停产撤人命令的直接决策权和指挥权。
'
,
questionList
:
[
'
生产现场带班人员
'
,
'
班组长
'
,
'
调度人员
'
,
'
主要负责人
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《安全生产法》规定:从业人员有权对本单位安全生产工作中存在的问题提出( )。
'
,
questionList
:
[
'
批评
'
,
'
检举
'
,
'
控告
'
,
'
报告
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《山东省生产经营单位安全生产主体责任规定》第四条,生产经营单位是安全生产的责任主体,对本单位的安全生产承担主体责任。主体责任主要包括( )、安全管理保障责任、事故报告和应急救援责任。
'
,
questionList
:
[
'
组织机构保障责任
'
,
'
规章制度保障责任
'
,
'
物质资金保障责任
'
,
'
教育培训保障责任
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《生产安全事故报告和调查处理条例》,根据生产安全事故造成的人员伤亡或者直接经济损失,事故一般分为( )。
'
,
questionList
:
[
'
一般事故
'
,
'
较大事故
'
,
'
重大事故
'
,
'
特别重大事故
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《中共中央国务院关于推进安全生产领域改革发展的意见》,大力推进企业安全生产标准化建设,实现( )的标准化。
'
,
questionList
:
[
'
安全管理
'
,
'
操作行为
'
,
'
设备设施
'
,
'
作业环境
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《中华人民共和国安全生产法》第二十四条 ( )和危险物品的生产、经营、储存、装卸单位,应当设置安全生产管理机构或者配备专职安全生产管理人员。
'
,
questionList
:
[
'
矿山
'
,
'
金属冶炼
'
,
'
运输单位
'
,
'
建筑施工
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
安全设备的设计、制造、( )、改造和报废,应当符合国家标准或者行业标准。
'
,
questionList
:
[
'
安装
'
,
'
使用
'
,
'
检测
'
,
'
维修
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
按照《生产安全事故报告和调查处理条例》规定,报告事故应当包括下列内容:( )
'
,
questionList
:
[
'
事故发生单位概况
'
,
'
事故发生的时间、地点以及事故现场情况
'
,
'
事故的简要经过
'
,
'
事故已经造成或者可能造成的伤亡人数
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
从业人员有权对本单位安全生产工作中存在的问题提出批评、检举、控告,有权拒绝( )。
'
,
questionList
:
[
'
违章指挥
'
,
'
领导指令
'
,
'
不合理安排
'
,
'
强令冒险作业
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
任何单位和个人对事故不得( )
'
,
questionList
:
[
'
迟报
'
,
'
谎报
'
,
'
漏报
'
,
'
瞒报
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
生产经营单位对重大危险源应当登记建档,进行定期( ),并制定应急预案,告知从业人员和相关人员在紧急情况下应当采取的应急措施。
'
,
questionList
:
[
'
评价
'
,
'
检测
'
,
'
评估
'
,
'
监控
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《全省安全生产大排查大整治行动方案》,创新检查方式,重点采取( )等方式开展检查,确保查实查深。
'
,
questionList
:
[
'
双随机一公开
'
,
'
四不两直
'
,
'
异地交互
'
,
'
驻点检查
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
《山东省生产经营单位安全生产主体责任规定》要求,生产经营单位应当按照国家有关规定,开展以( )为主要内容的安全生产标准化建设。
'
,
questionList
:
[
'
岗位达标
'
,
'
班组达标
'
,
'
专业达标
'
,
'
企业达标
'
]
},
{
questionType
:
'
multiple
'
,
questionOutline
:
'
安全生产工作应当以人为本,坚持( ),坚持安全第一、预防为主、综合治理的方针,从源头上防范化解重大安全风险。
'
,
questionList
:
[
'
安全发展理念
'
,
'
人民至上、生命至上
'
,
'
把保护人民生命安全摆在首位
'
,
'
树牢安全发展理念
'
]
}
],
],
checkQuestions
:
[
checkQuestions
:
[
{
questionType
:
'
check
'
,
questionOutline
:
'
购买和发放劳动防护用品的情况应当记录在案。可以货币或者其他物品替代劳动防护用品。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
生产经营单位使用劳务派遣人员从事作业的,劳务派遣人员不计入该生产经营单位的从业人员人数。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
生产经营单位应当按照国家标准、行业标准或者地方标准为从业人员有偿提供合格的劳动防护用品,并督促、检查、教育从业人员正确佩戴和使用。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
事故隐患分为一般事故隐患和较大事故隐患。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
《安全生产法》规定:国家实行生产安全事故责任追溯制度。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
《安全生产法》规定的行政处罚,由应急管理部门和其他负有安全生产监督管理职责的部门按照职责分工决定。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
《国务院关于坚持科学发展安全发展促进安全生产形势持续稳定好转的意见》(国发〔2011〕40号)提出:解决安全生产问题的根本途径是坚持科学发展安全发展。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
《山东省生产经营单位安全生产主体责任规定》要求,安全总监协助本单位主要负责人履行安全生产管理职责,专业分管本单位安全生产管理工作。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
《中共中央国务院关于推进安全生产领域改革发展的意见》提出加强新材料、新工艺、新业态安全风险评估和管控。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
},
{
questionType
:
'
check
'
,
questionOutline
:
'
安全监管监察部门不得因当事人陈述或者申辩而加重处罚。( )
'
,
questionList
:
[
'
是
'
,
'
否
'
]
}
],
],
questions
:
[
questions
:
[
{
{
...
@@ -416,19 +42,124 @@ Page({
...
@@ -416,19 +42,124 @@ Page({
]
]
}
}
],
],
singleScore
:
0
,
multiScore
:
0
,
justifyScore
:
0
,
singleQuestionNum
:
0
,
multiQuestionNum
:
0
,
justifyQuestionNum
:
0
,
isShowExamPage
:
false
,
resultScore
:
0
,
isToScroll
:
true
,
isToScroll
:
true
,
closeBtnImage
:
'

'
id
:
-
1
,
isExam
:
false
,
closeBtnImage
:
'

'
,
shuImg
:
'
https://8.143.198.78/fonts/shu.png
'
},
},
/**
/**
* 生命周期函数--监听页面加载
* 生命周期函数--监听页面加载
*/
*/
onLoad
:
function
(
options
)
{
onLoad
:
function
(
options
)
{
setTimeout
(()
=>
{
console
.
log
(
options
,
'
options options
'
)
this
.
setData
({
// singleScore: 0,
isToScroll
:
false
// multiScore: 0,
})
// justifyScore: 0,
},
100
)
// this.data.singleScore = parseInt(options.singleScore)
// this.data.multiScore = parseInt(options.multiScore)
// this.data.justifyScore = parseInt(options.justifyScore)
this
.
setData
({
singleScore
:
parseInt
(
options
.
singleScore
),
multiScore
:
parseInt
(
options
.
multiScore
),
justifyScore
:
parseInt
(
options
.
justifyScore
)
})
this
.
data
.
id
=
options
.
id
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/onlineExamPaper/findSubject
'
,
method
:
'
get
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
id
:
options
.
id
},
success
:
(
res
)
=>
{
console
.
log
(
res
,
'
wx.request wx.request
'
)
res
.
data
.
forEach
(
item
=>
{
item
.
result
=
''
})
this
.
setData
({
singleQuestions
:
res
.
data
.
filter
(
item
=>
item
.
type
===
'
单选题
'
).
map
(
item
=>
{
const
questionItem
=
[]
if
(
item
.
optiona
)
{
questionItem
.
push
(
item
.
optiona
)
}
if
(
item
.
optionb
)
{
questionItem
.
push
(
item
.
optionb
)
}
if
(
item
.
optionc
)
{
questionItem
.
push
(
item
.
optionc
)
}
if
(
item
.
optiond
)
{
questionItem
.
push
(
item
.
optiond
)
}
if
(
item
.
optione
)
{
questionItem
.
push
(
item
.
optione
)
}
if
(
item
.
optionf
)
{
questionItem
.
push
(
item
.
optionf
)
}
return
{
...
item
,
questionOutline
:
item
.
question
,
questionList
:
questionItem
}
}),
multiQuestions
:
res
.
data
.
filter
(
item
=>
item
.
type
===
'
多选题
'
).
map
(
item
=>
{
const
questionItem
=
[]
if
(
item
.
optiona
)
{
questionItem
.
push
(
item
.
optiona
)
}
if
(
item
.
optionb
)
{
questionItem
.
push
(
item
.
optionb
)
}
if
(
item
.
optionc
)
{
questionItem
.
push
(
item
.
optionc
)
}
if
(
item
.
optiond
)
{
questionItem
.
push
(
item
.
optiond
)
}
if
(
item
.
optione
)
{
questionItem
.
push
(
item
.
optione
)
}
if
(
item
.
optionf
)
{
questionItem
.
push
(
item
.
optionf
)
}
return
{
...
item
,
questionOutline
:
item
.
question
,
questionList
:
questionItem
}
}),
checkQuestions
:
res
.
data
.
filter
(
item
=>
item
.
type
===
'
判断题
'
).
map
(
item
=>
{
return
{
...
item
,
questionOutline
:
item
.
question
,
questionList
:
[
item
.
optiona
,
item
.
optionb
]
}
}),
singleQuestionNum
:
res
.
data
.
filter
(
item
=>
item
.
type
===
'
单选题
'
).
length
,
multiQuestionNum
:
res
.
data
.
filter
(
item
=>
item
.
type
===
'
多选题
'
).
length
,
justifyQuestionNum
:
res
.
data
.
filter
(
item
=>
item
.
type
===
'
判断题
'
).
length
})
}
})
// setTimeout(() => {
// this.setData({
// isToScroll: false
// })
// }, 100)
},
},
/**
/**
...
@@ -502,6 +233,37 @@ Page({
...
@@ -502,6 +233,37 @@ Page({
*/
*/
submitTestPaper
(
event
)
{
submitTestPaper
(
event
)
{
// 提交考卷
// 提交考卷
this
.
setData
({
isExam
:
true
,
singleQuestions
:
this
.
data
.
singleQuestions
,
multiQuestions
:
this
.
data
.
multiQuestions
,
checkQuestions
:
this
.
data
.
checkQuestions
,
isShowExamPage
:
true
,
resultScore
:
this
.
data
.
singleQuestions
.
filter
(
item
=>
item
.
isAnswer
).
length
*
this
.
data
.
singleScore
+
this
.
data
.
multiQuestions
.
filter
(
item
=>
item
.
isAnswer
).
length
*
this
.
data
.
multiScore
+
this
.
data
.
checkQuestions
.
filter
(
item
=>
item
.
isAnswer
).
length
*
this
.
data
.
justifyScore
})
// wx.showModal({
// title: '您的考试分数',
// content: this.data.resultScore + ' 分'
// })
console
.
log
(
app
.
globalData
.
userInfo
,
'
app.globalData.userInfo
'
)
wx
.
request
({
url
:
app
.
globalData
.
appBaseUrlV2
+
'
/api/onlineExamPaper/recordScore
'
,
method
:
'
post
'
,
header
:
{
Authorization
:
app
.
globalData
.
Authorization
},
data
:
{
paperId
:
this
.
data
.
id
,
score
:
this
.
data
.
resultScore
,
userId
:
app
.
globalData
.
userInfo
.
id
},
success
:
(
res
)
=>
{
console
.
log
(
'
上传成功 api/onlineExamPaper/recordScore
'
)
}
})
console
.
log
(
this
.
data
.
singleQuestions
,
'
this.singleQuestions
'
)
console
.
log
(
this
.
data
.
multiQuestions
,
'
this.multiQuestions
'
)
console
.
log
(
this
.
data
.
checkQuestions
,
'
this.checkQuestions
'
)
},
},
/**
/**
*
*
...
@@ -510,5 +272,105 @@ Page({
...
@@ -510,5 +272,105 @@ Page({
console
.
log
(
event
)
console
.
log
(
event
)
// return false
// return false
// return true
// return true
},
chooseSingle
(
event
)
{
//event.detail.value
const
index
=
event
.
detail
.
value
.
split
(
'
|
'
)[
0
]
const
index1
=
event
.
detail
.
value
.
split
(
'
|
'
)[
1
]
if
(
index1
===
'
0
'
)
{
this
.
data
.
singleQuestions
[
index
].
result
=
'
A
'
}
else
if
(
index1
===
'
1
'
)
{
this
.
data
.
singleQuestions
[
index
].
result
=
'
B
'
}
else
if
(
index1
===
'
2
'
)
{
this
.
data
.
singleQuestions
[
index
].
result
=
'
C
'
}
else
if
(
index1
===
'
3
'
)
{
this
.
data
.
singleQuestions
[
index
].
result
=
'
D
'
}
else
if
(
index1
===
'
4
'
)
{
this
.
data
.
singleQuestions
[
index
].
result
=
'
E
'
}
else
if
(
index1
===
'
5
'
)
{
this
.
data
.
singleQuestions
[
index
].
result
=
'
F
'
}
if
(
this
.
data
.
singleQuestions
[
index
].
result
===
this
.
data
.
singleQuestions
[
index
].
answer
)
{
this
.
data
.
singleQuestions
[
index
].
isAnswer
=
true
}
else
{
this
.
data
.
singleQuestions
[
index
].
isAnswer
=
false
}
},
chooseMulti
(
event
)
{
//event.detail.value
console
.
log
(
event
,
'
chooseMulti
'
)
if
(
!
event
.
detail
.
value
||
event
.
detail
.
value
.
length
===
0
)
{
return
}
let
result
=
[]
let
index
=
-
1
event
.
detail
.
value
.
forEach
(
item
=>
{
index
=
item
.
split
(
'
|
'
)[
0
]
const
index1
=
item
.
split
(
'
|
'
)[
1
]
if
(
index1
===
'
0
'
)
{
result
.
push
(
'
A
'
)
}
else
if
(
index1
===
'
1
'
)
{
result
.
push
(
'
B
'
)
}
else
if
(
index1
===
'
2
'
)
{
result
.
push
(
'
C
'
)
}
else
if
(
index1
===
'
3
'
)
{
result
.
push
(
'
D
'
)
}
else
if
(
index1
===
'
4
'
)
{
result
.
push
(
'
E
'
)
}
else
if
(
index1
===
'
5
'
)
{
result
.
push
(
'
F
'
)
}
})
result
=
result
.
sort
()
console
.
log
(
result
,
'
result___________________________
'
)
console
.
log
(
result
,
'
result___________________________
'
)
if
(
result
.
length
>
0
)
{
this
.
data
.
multiQuestions
[
index
].
result
=
result
.
join
(
'
、
'
)
}
else
{
this
.
data
.
multiQuestions
[
index
].
result
=
''
}
if
(
this
.
data
.
multiQuestions
[
index
].
result
===
this
.
data
.
multiQuestions
[
index
].
answer
)
{
this
.
data
.
multiQuestions
[
index
].
isAnswer
=
true
}
else
{
this
.
data
.
multiQuestions
[
index
].
isAnswer
=
false
}
},
chooseJustify
(
event
)
{
console
.
log
(
event
,
'
chooseJustify chooseJustify
'
)
const
index
=
event
.
detail
.
value
.
split
(
'
|
'
)[
0
]
const
index1
=
event
.
detail
.
value
.
split
(
'
|
'
)[
1
]
if
(
index1
===
'
0
'
)
{
this
.
data
.
checkQuestions
[
index
].
result
=
'
对
'
}
else
if
(
index1
===
'
1
'
)
{
this
.
data
.
checkQuestions
[
index
].
result
=
'
错
'
}
console
.
log
(
this
.
data
.
checkQuestions
[
index
],
'
this.data.checkQuestions
'
)
if
(
this
.
data
.
checkQuestions
[
index
].
result
===
this
.
data
.
checkQuestions
[
index
].
answer
)
{
this
.
data
.
checkQuestions
[
index
].
isAnswer
=
true
}
else
{
this
.
data
.
checkQuestions
[
index
].
isAnswer
=
false
}
},
closeMySelf
(
event
)
{
console
.
log
(
event
,
'
cloiseMySelf closeMySelf
'
)
this
.
setData
({
isShowExamPage
:
false
})
},
viewWrong
()
{
this
.
setData
({
isExam
:
true
,
isShowExamPage
:
false
})
},
quitTest
()
{
app
.
globalData
.
isNeedNavigateTo
=
true
app
.
globalData
.
testPaperId
=
this
.
data
.
id
app
.
globalData
.
singleScore
=
this
.
data
.
singleScore
app
.
globalData
.
multiScore
=
this
.
data
.
multiScore
app
.
globalData
.
justifyScore
=
this
.
data
.
justifyScore
wx
.
navigateBack
({
delta
:
1
,
})
}
}
})
})
\ No newline at end of file
pages/testpaper/testpaper.wxml
View file @
55611f2f
<!--pages/testpaper/testpaper.wxml-->
<!--pages/testpaper/testpaper.wxml-->
<view class="testpaper-wrapper">
<view class="testpaper-wrapper">
<scroll-view scroll-y="{{false}}" class="scroll-wrapper">
<scroll-view scroll-y="{{false}}" class="scroll-wrapper">
<view class="class0-0" wx:if="{{singleQuestionNum > 0 }}">
<span class="class1-0">单选题数量: <text class="class1-1">{{singleQuestionNum}}</text></span>
<span class="class2-0">单选题分值: <text class="class2-1">{{singleScore}}</text></span>
</view>
<view wx:for="{{singleQuestions}}" class="test-question-wrapper">
<view wx:for="{{singleQuestions}}" class="test-question-wrapper">
<view class="test-question-outline-wrapper">
<view class="test-question-outline-wrapper">
{{(index + 1) < 10 ? '0' + (index + 1) : (index + 1 + '')}}
{{(index + 1) < 10 ? '0' + (index + 1) : (index + 1 + '')}}
...
@@ -9,23 +13,30 @@
...
@@ -9,23 +13,30 @@
<text class="decorate-must">*</text>
<text class="decorate-must">*</text>
</view>
</view>
<view class="test-question-body-wrapper">
<view class="test-question-body-wrapper">
<radio-group>
<radio-group
bindchange="chooseSingle"
>
<view wx:for="{{item.questionList}}"
<view wx:for="{{item.questionList}}"
wx:for-item="item1"
wx:for-item="item1"
wx:for-index="index1"
wx:for-index="index1"
class="test-question-line">{{index1 === 0? 'A、' : (index1 === 1? 'B、' : (index1 === 2? 'C、': (index1 === 3? 'D、' : 'E、')))}}{{item1}}</view>
class="test-question-line">{{index1 === 0? 'A、' : (index1 === 1? 'B、' : (index1 === 2? 'C、': (index1 === 3? 'D、' : (index1 === 4 ? 'E、' : (index1 === 5 ? 'F、' : 'G、')))))}}{{item1}}</view>
<view wx:if="{{isExam&&(!item.isAnswer)}}" class="question-answer"><text class="right-answer">正确答案: </text><text class="answer">{{item.answer}}</text></view>
<view wx:if="{{isExam&&(!item.isAnswer)}}" class="question-analysis"><text class="right-answer">答案解析: </text><text class="answer">{{item.analysis}}</text></view>
<view class="select-optoin-wrapper">
<view class="select-optoin-wrapper">
<radio wx:for="{{item.questionList}}"
<radio wx:for="{{item.questionList}}"
wx:for-index="index1"
wx:for-index="index1"
class="one-option"
class="one-option"
color="#090D9C"
color="#090D9C"
value="{{index+'|'+index1}}"
>
>
{{index1 === 0? 'A' : (index1 === 1? 'B' : (index1 === 2? 'C': (index1 === 3? 'D' :
'E'
)))}}
{{index1 === 0? 'A' : (index1 === 1? 'B' : (index1 === 2? 'C': (index1 === 3? 'D' :
(index1 === 4 ? 'E' : (index1 === 5 ? 'F' : 'G'))
)))}}
</radio>
</radio>
</view>
</view>
</radio-group>
</radio-group>
</view>
</view>
</view>
</view>
<view class="class0-0" wx:if="{{multiQuestionNum > 0}}">
<span class="class1-0">多选题数量: <text class="class1-1">{{multiQuestionNum}}</text></span>
<span class="class2-0">多选题分值: <text class="class2-1">{{multiScore}}</text></span>
</view>
<view wx:for="{{multiQuestions}}" class="test-question-wrapper">
<view wx:for="{{multiQuestions}}" class="test-question-wrapper">
<view class="test-question-outline-wrapper">
<view class="test-question-outline-wrapper">
{{(index + 1) < 10 ? '0' + (index + 1) : (index + 1 + '')}}
{{(index + 1) < 10 ? '0' + (index + 1) : (index + 1 + '')}}
...
@@ -34,23 +45,30 @@
...
@@ -34,23 +45,30 @@
<text class="decorate-must">*</text>
<text class="decorate-must">*</text>
</view>
</view>
<view class="test-question-body-wrapper">
<view class="test-question-body-wrapper">
<checkbox-group>
<checkbox-group
bindchange="chooseMulti"
>
<view wx:for="{{item.questionList}}"
<view wx:for="{{item.questionList}}"
wx:for-item="item1"
wx:for-item="item1"
wx:for-index="index1"
wx:for-index="index1"
class="test-question-line">{{index1 === 0? 'A、' : (index1 === 1? 'B、' : (index1 === 2? 'C、': (index1 === 3? 'D、' : 'E、')))}}{{item1}}</view>
class="test-question-line">{{index1 === 0? 'A、' : (index1 === 1? 'B、' : (index1 === 2? 'C、': (index1 === 3? 'D、' : (index1 === 4 ? 'E、' : (index1 === 5 ? 'F、' : 'G、')))))}}{{item1}}</view>
<view wx:if="{{isExam&&(!item.isAnswer)}}" class="question-answer"><text class="right-answer">正确答案: </text><text class="answer">{{item.answer}}</text></view>
<view wx:if="{{isExam&&(!item.isAnswer)}}" class="question-analysis"><text class="right-answer">答案解析: </text><text class="answer">{{item.analysis}}</text></view>
<view class="select-optoin-wrapper">
<view class="select-optoin-wrapper">
<checkbox wx:for="{{item.questionList}}"
<checkbox wx:for="{{item.questionList}}"
wx:for-index="index1"
wx:for-index="index1"
class="one-option"
class="one-option"
color="#090D9C"
color="#090D9C"
value="{{index + '|' + index1}}"
>
>
{{index1 === 0? 'A' : (index1 === 1? 'B' : (index1 === 2? 'C': (index1 === 3? 'D' :
'E'
)))}}
{{index1 === 0? 'A' : (index1 === 1? 'B' : (index1 === 2? 'C': (index1 === 3? 'D' :
(index1 === 4 ? 'E' : (index1 === 5 ? 'F' : 'G、'))
)))}}
</checkbox>
</checkbox>
</view>
</view>
</checkbox-group>
</checkbox-group>
</view>
</view>
</view>
</view>
<view class="class0-0" wx:if="{{justifyQuestionNum > 0}}">
<span class="class1-0">判断题数量: <text class="class1-1">{{justifyQuestionNum}}</text></span>
<span class="class2-0">判断题分值: <text class="class2-1">{{justifyScore}}</text></span>
</view>
<view wx:for="{{checkQuestions}}" class="test-question-wrapper">
<view wx:for="{{checkQuestions}}" class="test-question-wrapper">
<view class="test-question-outline-wrapper">
<view class="test-question-outline-wrapper">
{{(index + 1) < 10 ? '0' + (index + 1) : (index + 1 + '')}}
{{(index + 1) < 10 ? '0' + (index + 1) : (index + 1 + '')}}
...
@@ -59,18 +77,21 @@
...
@@ -59,18 +77,21 @@
<text class="decorate-must">*</text>
<text class="decorate-must">*</text>
</view>
</view>
<view class="test-question-body-wrapper">
<view class="test-question-body-wrapper">
<radio-group>
<radio-group
bindchange="chooseJustify"
>
<view wx:for="{{item.questionList}}"
<
!-- <
view wx:for="{{item.questionList}}"
wx:for-item="item1"
wx:for-item="item1"
wx:for-index="index1"
wx:for-index="index1"
class="test-question-line">{{item1}}</view>
class="test-question-line">{{item1}}</view> -->
<view wx:if="{{isExam&&(!item.isAnswer)}}" class="question-answer"><text class="right-answer">正确答案: </text><text class="answer">{{item.answer}}</text></view>
<view wx:if="{{isExam&&(!item.isAnswer)}}" class="question-analysis"><text class="right-answer">答案解析: </text><text class="answer">{{item.analysis}}</text></view>
<view class="select-optoin-wrapper">
<view class="select-optoin-wrapper">
<radio wx:for="{{item.questionList}}"
<radio wx:for="{{item.questionList}}"
wx:for-index="index1"
wx:for-index="index1"
class="one-option"
class="one-option"
color="#090D9C"
color="#090D9C"
value="{{index + '|' + index1}}"
>
>
{{index1 === 0? '
是' : (index1 === 1? '否' : (index1 === 2? '是': (index1 === 3? '否' : '否
')))}}
{{index1 === 0? '
对' : (index1 === 1? '错' : (index1 === 2? '对': (index1 === 3? '错' : '错
')))}}
</radio>
</radio>
</view>
</view>
</radio-group>
</radio-group>
...
@@ -78,19 +99,22 @@
...
@@ -78,19 +99,22 @@
</view>
</view>
<view class="submit-row"><button class="submit-btn" bindtap="submitTestPaper">提交考卷</button></view>
<view class="submit-row"><button class="submit-btn" bindtap="submitTestPaper">提交考卷</button></view>
</scroll-view>
</scroll-view>
<view class="score-wrapper" catchtouchmove="cancelmove">
<view class="score-wrapper
{{isShowExamPage?'' : ' score-hide'}}
" catchtouchmove="cancelmove">
<view class="real-score-outline">
<view class="real-score-outline">
<view class="real-score-outline-title">您的考试得分为</view>
<view class="real-score-outline-title">您的考试得分为</view>
<view class="real-score">
90
</view>
<view class="real-score">
{{resultScore}}
</view>
<view class="score-slogan">恭喜您顺利通过考试</view>
<view class="score-slogan">恭喜您顺利通过考试</view>
<view class="wrong-test-wrapper">
<view class="wrong-test-wrapper">
<view class="wrong-btn">查看错题</view>
<view class="wrong-btn"
bindtap="viewWrong"
>查看错题</view>
<view class="test-btn">重新考试</view>
<view class="test-btn"
bindtap="quitTest"
>重新考试</view>
</view>
</view>
<view class="close-score-outline">
<view class="close-score-outline"
bindtap="closeMySelf"
>
<image class="close-score-image" mode="aspectFill" src="{{closeBtnImage}}"></image>
<image class="close-score-image" mode="aspectFill" src="{{closeBtnImage}}"></image>
</view>
</view>
<view class="real-score-book">
<image class="real-score-book-img" mode="aspectFill"
src="{{shuImg}}"></image>
</view>
</view>
</view>
</view>
</view>
</view>
</view>
\ No newline at end of file
pages/testpaper/testpaper.wxss
View file @
55611f2f
...
@@ -173,6 +173,8 @@
...
@@ -173,6 +173,8 @@
top: 0;
top: 0;
bottom: 0;
bottom: 0;
background-color: rgba(0, 0, 0, .3);
background-color: rgba(0, 0, 0, .3);
}
.score-hide {
display: none;
display: none;
}
}
.real-score-outline {
.real-score-outline {
...
@@ -260,3 +262,50 @@
...
@@ -260,3 +262,50 @@
width: 100%;
width: 100%;
height: 100%;
height: 100%;
}
}
.question-answer {
border-top: 1rpx solid #eee;
}
.right-answer {
color: #1f208c;
}
.answer {
color: #ff0000;
}
.question-analysis {
border-top: 1rpx solid #eee;
color: #ff0000;
}
.class0-0 {
padding: 15rpx;
margin: 15rpx 10rpx;
background-color: #fff;
border-radius: 5rpx;
}
.class1-0 {
margin: 0 20rpx;
}
.class1-1 {
margin: 0 20rpx;
color: #090d9c;
font-size: 30rpx;
}
.class2-0 {
margin: 0 20rpx;
}
.class2-1 {
margin: 0 20rpx;
color: #090d9c;
font-size: 30rpx;
}
.real-score-book {
position: absolute;
left: 50%;
top: 0;
transform: translate(-50%, -50%);
width: 360rpx;
height: 220rpx;
}
.real-score-book-img {
width: 100%;
height: 100%;
}
\ No newline at end of file
project.config.json
View file @
55611f2f
...
@@ -21,6 +21,7 @@
...
@@ -21,6 +21,7 @@
"checkSiteMap"
:
true
,
"checkSiteMap"
:
true
,
"uploadWithSourceMap"
:
true
,
"uploadWithSourceMap"
:
true
,
"compileHotReLoad"
:
false
,
"compileHotReLoad"
:
false
,
"lazyloadPlaceholderEnable"
:
false
,
"useMultiFrameRuntime"
:
true
,
"useMultiFrameRuntime"
:
true
,
"useApiHook"
:
true
,
"useApiHook"
:
true
,
"useApiHostProcess"
:
true
,
"useApiHostProcess"
:
true
,
...
@@ -29,15 +30,15 @@
...
@@ -29,15 +30,15 @@
"disablePlugins"
:
[],
"disablePlugins"
:
[],
"outputPath"
:
""
"outputPath"
:
""
},
},
"enableEngineNative"
:
false
,
"useIsolateContext"
:
true
,
"useIsolateContext"
:
true
,
"useCompilerModule"
:
true
,
"userConfirmedUseCompilerModuleSwitch"
:
false
,
"userConfirmedBundleSwitch"
:
false
,
"userConfirmedBundleSwitch"
:
false
,
"packNpmManually"
:
false
,
"packNpmManually"
:
false
,
"packNpmRelationList"
:
[],
"packNpmRelationList"
:
[],
"minifyWXSS"
:
true
,
"minifyWXSS"
:
true
,
"minifyWXML"
:
true
"disableUseStrict"
:
false
,
"minifyWXML"
:
true
,
"showES6CompileOption"
:
false
,
"useCompilerPlugins"
:
false
},
},
"compileType"
:
"miniprogram"
,
"compileType"
:
"miniprogram"
,
"libVersion"
:
"2.18.0"
,
"libVersion"
:
"2.18.0"
,
...
...
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