Bez popisu
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

Home2.vue 17KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507
  1. <!-- 首页 -->
  2. <template>
  3. <!-- 主要内容区域 -->
  4. <div class="body-bg">
  5. <div class="card">
  6. <div class="title">常用应用</div>
  7. <van-grid :border="false" :column-num="4">
  8. <van-grid-item v-for="(item,idx) in functionList" :key="idx" :to="item.jumpPath">
  9. <img :src="item.img" width="45rpx" />
  10. <span class="vanicon_text">{{ item.title }}</span>
  11. </van-grid-item>
  12. </van-grid>
  13. </div>
  14. <div class="card">
  15. <div class="title">制度管理</div>
  16. <van-grid :border="false" :column-num="4">
  17. <van-grid-item to="/institution/law">
  18. <img src="../../public/images/fl.png" width="45rpx" />
  19. <span class="vanicon_text">法律法规</span>
  20. </van-grid-item>
  21. <van-grid-item to="/institution/institutionRegime">
  22. <img src="../../public/images/aqzd.png" width="45rpx" />
  23. <span class="vanicon_text">安全制度管理</span>
  24. </van-grid-item>
  25. <van-grid-item to="/institution/institutionRule">
  26. <img src="../../public/images/zd.png" width="45rpx" />
  27. <span class="vanicon_text">安全操作规程</span>
  28. </van-grid-item>
  29. </van-grid>
  30. </div>
  31. <div class="card">
  32. <div class="title">安全责任履职</div>
  33. <van-grid :border="false" :column-num="4">
  34. <van-grid-item to="/lvzhi">
  35. <img src="../../public/images/lz.png" width="45rpx" />
  36. <span class="vanicon_text">履职记录</span>
  37. </van-grid-item>
  38. <van-grid-item to="/lvzhicx">
  39. <img src="../../public/images/lzcx.png" width="45rpx" />
  40. <span class="vanicon_text">履职查询</span>
  41. </van-grid-item>
  42. <van-grid-item v-if='false'>
  43. <img src="../../public/images/zj.png" width="45rpx" @click="handleClick" />
  44. <span class="vanicon_text">站内信推送</span>
  45. </van-grid-item>
  46. </van-grid>
  47. </div>
  48. <div class="card">
  49. <div class="title">风险分级管理</div>
  50. <van-grid :border="false" :column-num="4">
  51. <van-grid-item to="/institution/riskList">
  52. <img src="../../public/images/fx.png" width="45rpx" />
  53. <span class="vanicon_text">风险分级管控记录</span>
  54. </van-grid-item>
  55. </van-grid>
  56. </div>
  57. <div class="card">
  58. <div class="title">隐患排查治理</div>
  59. <van-grid :border="false" :column-num="4">
  60. <van-grid-item to="/yinhuan/registration">
  61. <img src="../../public/images/yhdj.png" width="45rpx" />
  62. <span class="vanicon_text">隐患登记</span>
  63. </van-grid-item>
  64. <van-grid-item to="/yinhuan/todo">
  65. <img src="../../public/images/yhdb.png" width="45rpx" />
  66. <span class="vanicon_text">隐患待办</span>
  67. </van-grid-item>
  68. <van-grid-item to="/yinhuan/hdLedger">
  69. <img src="../../public/images/yh.png" width="45rpx" />
  70. <span class="vanicon_text">隐患台账</span>
  71. </van-grid-item>
  72. <van-grid-item to="/yinhuan/riskChecklist">
  73. <img src="../../public/images/riskChecklist.png" width="45rpx" />
  74. <span class="vanicon_text">隐患排查清单</span>
  75. </van-grid-item>
  76. <van-grid-item to="/yinhuan/riskChecklistRecords">
  77. <img src="../../public/images/riskChecklistRecords.png" width="45rpx" />
  78. <span class="vanicon_text">隐患排查记录</span>
  79. </van-grid-item>
  80. <van-grid-item to="/yinhuan/hdRwardReporting">
  81. <img src="../../public/images/yhdb.png" width="45rpx" />
  82. <span class="vanicon_text">隐患有奖举报</span>
  83. </van-grid-item>
  84. <van-grid-item to="/yinhuan/hdLedgerJuBao">
  85. <img src="../../public/images/yh.png" width="45rpx" />
  86. <span class="vanicon_text">隐患有奖举报台账</span>
  87. </van-grid-item>
  88. </van-grid>
  89. </div>
  90. <div class="card">
  91. <div class="title">安全检查</div>
  92. <van-grid :border="false" :column-num="4">
  93. <van-grid-item to="/safeCheck/task">
  94. <img src="../../public/images/aq.png" width="45rpx" />
  95. <span class="vanicon_text">安全检查任务</span>
  96. </van-grid-item>
  97. </van-grid>
  98. </div>
  99. <div class="card">
  100. <div class="title">教育培训</div>
  101. <van-grid :border="false" :column-num="4">
  102. <van-grid-item to="/dailyproblem">
  103. <img src="../../public/images/dt.png" width="45rpx" />
  104. <span class="vanicon_text">每日答题</span>
  105. </van-grid-item>
  106. <van-grid-item to="/cardManager">
  107. <img src="../../public/images/zj.png" width="45rpx" />
  108. <span class="vanicon_text">证件管理</span>
  109. </van-grid-item>
  110. <van-grid-item to="/checkTake">
  111. <img src="../../public/images/dt.png" width="45rpx" />
  112. <span class="vanicon_text">逢查必考</span>
  113. </van-grid-item>
  114. <van-grid-item to="/examtask" v-if="showCheckTake">
  115. <img src="../../public/images/zyqk.png" width="45rpx" />
  116. <span class="vanicon_text">考试任务</span>
  117. </van-grid-item>
  118. </van-grid>
  119. </div>
  120. <div class="card">
  121. <div class="title">应急管理</div>
  122. <van-grid :border="false" :column-num="4">
  123. <van-grid-item to="/institution/emergencyPlan">
  124. <img src="../../public/images/yjya.png" width="45rpx" />
  125. <span class="vanicon_text">应急预案</span>
  126. </van-grid-item>
  127. <van-grid-item to="/emergencyResources">
  128. <img src="../../public/images/yj.png" width="45rpx" />
  129. <span class="vanicon_text">应急物资</span>
  130. </van-grid-item>
  131. <van-grid-item to="/emergencyDrillPlan">
  132. <img src="../../public/images/yjyl.png" width="45rpx" />
  133. <span class="vanicon_text">应急演练</span>
  134. </van-grid-item>
  135. <van-grid-item to="/drillProcess">
  136. <img src="../../public/images/drillProcess.png" width="45rpx" />
  137. <span class="vanicon_text">掌上演练</span>
  138. </van-grid-item>
  139. </van-grid>
  140. </div>
  141. <div class="card">
  142. <div class="title">项目管理</div>
  143. <van-grid :border="false" :column-num="4">
  144. <van-grid-item to="/projectManage/taiZhang">
  145. <img src="../../public/images/xm.png" width="45rpx" />
  146. <span class="vanicon_text">项目台账</span>
  147. </van-grid-item>
  148. <van-grid-item to="/projectManage/projectConstructionOperation">
  149. <img src="../../public/images/xm.png" width="45rpx" />
  150. <span class="vanicon_text">项目施工作业管理</span>
  151. </van-grid-item>
  152. <van-grid-item to="/projectManage/projectWorkLedger">
  153. <img src="../../public/images/xm.png" width="45rpx" />
  154. <span class="vanicon_text">项目作业台账</span>
  155. </van-grid-item>
  156. <van-grid-item to="/projectManage/todo">
  157. <img src="../../public/images/yhdb.png" width="45rpx" />
  158. <span class="vanicon_text">项目作业待办</span>
  159. </van-grid-item>
  160. </van-grid>
  161. </div>
  162. <div class="card">
  163. <div class="title">作业现场管控</div>
  164. <van-grid :border="false" :column-num="4">
  165. <van-grid-item to="/safeClient">
  166. <img src="../../public/images/zdgl.png" width="45rpx" />
  167. <span class="vanicon_text">终端管理</span>
  168. </van-grid-item>
  169. <van-grid-item to="/jobCondition">
  170. <img src="../../public/images/zyqk.png" width="45rpx" />
  171. <span class="vanicon_text">作业情况</span>
  172. </van-grid-item>
  173. </van-grid>
  174. </div>
  175. <div class="card">
  176. <div class="title">事务汇报</div>
  177. <van-grid :border="false" :column-num="4">
  178. <van-grid-item to="/keyMatters">
  179. <img src="../../public/images/keyMatters.png" width="45rpx" />
  180. <span class="vanicon_text">重点事项</span>
  181. </van-grid-item>
  182. <van-grid-item to="/planManagement">
  183. <img src="../../public/images/planManagement.png" width="45rpx" />
  184. <span class="vanicon_text">计划任务</span>
  185. </van-grid-item>
  186. </van-grid>
  187. </div>
  188. <div class="card">
  189. <div class="title">考核管理</div>
  190. <van-grid :border="false" :column-num="4" v-if="showCheckTakeN">
  191. <van-grid-item to="/assRec">
  192. <img src="../../public/images/zdgl.png" width="45rpx" />
  193. <span class="vanicon_text">考核登记</span>
  194. </van-grid-item>
  195. <van-grid-item to="/assRecN" v-if="showCheckTakeN">
  196. <img src="../../public/images/lzcx.png" width="45rpx" />
  197. <span class="vanicon_text">考核记录</span>
  198. </van-grid-item>
  199. </van-grid>
  200. </div>
  201. <div class="card">
  202. <div class="title">通知公告</div>
  203. <van-grid :border="false" :column-num="4" v-if="showCheckTakeN">
  204. <van-grid-item to="/annex">
  205. <img src="../../public/images/zyqk.png" width="45rpx" />
  206. <span class="vanicon_text">文件发布</span>
  207. </van-grid-item>
  208. <van-grid-item to="/notice" v-if="showCheckTakeN">
  209. <img src="../../public/images/yj.png" width="45rpx" />
  210. <span class="vanicon_text">通知公告</span>
  211. </van-grid-item>
  212. </van-grid>
  213. </div>
  214. </div>
  215. </template>
  216. <script setup>
  217. import { ref, getCurrentInstance, onMounted } from 'vue';
  218. import { onBeforeRouteLeave } from 'vue-router';
  219. import { showFailToast, showSuccessToast } from 'vant';
  220. const {
  221. proxy
  222. } = getCurrentInstance();
  223. const showCheckTake = ref(false);
  224. const showCheckTakeN = ref(false);
  225. const userDesc = localStorage.getItem('userDesc');
  226. const role = localStorage.getItem('role')[0].roleCode;
  227. if (role == 'SX0201' || role == 'SX0201' || role == 'SX0302' || role == 'SX0303') {
  228. showCheckTake.value = true;
  229. }
  230. if (userDesc == '贾俊臣' || userDesc == '张瑞楠') {
  231. showCheckTake.value = true;
  232. showCheckTakeN.value=true
  233. }
  234. /**
  235. * 修改最近使用的页面记录
  236. */
  237. const recentlyUsed = ref({
  238. userCode: localStorage.getItem('userCode'),
  239. menuIcon: '',
  240. menuName: '',
  241. jumpPath: ''
  242. });
  243. const userCode = localStorage.getItem('userCode');
  244. const handleClick = () => {
  245. console.log('111');
  246. const url = '/sgsafe/RecordMaster/tuisong';
  247. const param = {
  248. userCode: userCode
  249. };
  250. proxy.$axios.get(url, param).then(response => {
  251. if (response.data.code == 0) {
  252. showSuccessToast('已推送');
  253. } else {
  254. showFailToast(response.data.msg);
  255. }
  256. }, 500);
  257. };
  258. const getRecentlyUsed = () => {
  259. const url = '/sgsafe/MenuRecentlyUsedMobile/updateMenuRecentlyUsedStatus';
  260. const param = {
  261. json: JSON.stringify(recentlyUsed.value)
  262. };
  263. proxy.$axios.post(url, param).then(res => {
  264. if (res.data.code !== 0) {
  265. console.log('执行失败');
  266. }
  267. });
  268. };
  269. onBeforeRouteLeave((to, from) => {
  270. recentlyUsed.value.jumpPath = to.path;
  271. recentlyUsed.value.menuIcon = getPicPathByPath(to.path);
  272. recentlyUsed.value.menuName = getNameByPath(to.path);
  273. if (recentlyUsed.value.menuIcon) {
  274. getRecentlyUsed();
  275. }
  276. });
  277. /**
  278. * 获取最近使用页面记录
  279. */
  280. const functionList = ref([]);
  281. const coincideNotList = ref([]);
  282. const queryMenuRecently = () => {
  283. const url = '/sgsafe/MenuRecentlyUsedMobile/queryRecentlyUsed';
  284. const param = {
  285. userCode: localStorage.getItem('userCode')
  286. };
  287. proxy.$axios.get(url, param).then(res => {
  288. functionList.value = res.data.data.map(item => ({
  289. title: item.menuName,
  290. img: item.menuIcon,
  291. jumpPath: item.jumpPath
  292. }));
  293. if (functionList.value.length < 4) {
  294. coincideNotList.value = defaultPageList.value;
  295. for (let item of functionList.value) {
  296. coincideNotList.value = coincideNotList.value.filter(info => info.jumpPath !== item.jumpPath);
  297. }
  298. coincideNotList.value = coincideNotList.value.slice(0, 4 - functionList.value.length);
  299. functionList.value = [...functionList.value, ...coincideNotList.value];
  300. } else {
  301. functionList.value = functionList.value.slice(0, 4);
  302. }
  303. });
  304. };
  305. onMounted(() => {
  306. queryMenuRecently();
  307. });
  308. /**
  309. * 默认页面
  310. */
  311. const defaultPageList = ref([
  312. { title: '隐患登记', img: 'images/yhdj.png', jumpPath: '/yinhuan/registration' },
  313. { title: '隐患台账', img: 'images/yh.png', jumpPath: '/yinhuan/hdLedger' },
  314. { title: '每日答题', img: 'images/dt.png', jumpPath: '/dailyproblem' },
  315. { title: '履职记录', img: 'images/lz.png', jumpPath: '/lvzhi' },
  316. { title: '安全制度管理', img: 'images/aqzd.png', jumpPath: '/institution/institutionRegime' },
  317. { title: '证件管理', img: 'images/zj.png', jumpPath: '/cardManager' },
  318. { title: '隐患待办', img: 'images/yhdb.png', jumpPath: '/yinhuan/todo' }
  319. ]);
  320. /**
  321. * 根据路由获取名称
  322. */
  323. const getNameByPath = (path) => {
  324. const recentlyUsedMapping = {
  325. '/institution/law': '法律法规',
  326. '/institution/institutionRegime': '安全制度管理',
  327. '/institution/institutionRule': '安全操作规程',
  328. '/lvzhi': '履职记录',
  329. '/lvzhicx': '履职查询',
  330. '/institution/riskList': '风险分级管控记录',
  331. '/yinhuan/registration': '隐患登记',
  332. '/yinhuan/todo': '隐患待办',
  333. '/yinhuan/hdLedger': '隐患台账',
  334. '/safeCheck/task': '安全检查任务',
  335. '/dailyproblem': '每日答题',
  336. '/cardManager': '证件管理',
  337. '/institution/emergencyPlan': '应急预案',
  338. '/emergencyResources': '应急物资',
  339. '/emergencyDrillPlan': '应急演练',
  340. '/projectManage/taiZhang': '项目台账',
  341. '/safeClient': '终端管理',
  342. '/jobCondition': '作业情况',
  343. '/yinhuan/riskChecklist': '隐患排查清单',
  344. '/yinhuan/riskChecklistRecords': '隐患排查记录',
  345. '/drillProcess': '掌上演练',
  346. '/checkTake': '逢查必考',
  347. '/projectManage/projectConstructionOperation': '项目施工作业管理',
  348. '/projectManage/projectWorkLedger': '项目作业台账',
  349. '/keyMatters': '重点事项',
  350. '/planManagement': '计划任务'
  351. };
  352. return recentlyUsedMapping[path];
  353. };
  354. /**
  355. * 根据路由获取图片路径
  356. */
  357. const getPicPathByPath = (path) => {
  358. const recentlyUsedMapping = {
  359. '/institution/law': 'images/fl.png',
  360. '/institution/institutionRegime': 'images/aqzd.png',
  361. '/institution/institutionRule': 'images/zd.png',
  362. '/lvzhi': 'images/lz.png',
  363. '/lvzhicx': 'images/lzcx.png',
  364. '/institution/riskList': 'images/fx.png',
  365. '/yinhuan/registration': 'images/yhdj.png',
  366. '/yinhuan/todo': 'images/yhdb.png',
  367. '/yinhuan/hdLedger': 'images/yh.png',
  368. '/safeCheck/task': 'images/aq.png',
  369. '/dailyproblem': 'images/dt.png',
  370. '/cardManager': 'images/zj.png',
  371. '/institution/emergencyPlan': 'images/yjya.png',
  372. '/emergencyResources': 'images/yj.png',
  373. '/emergencyDrillPlan': 'images/yjyl.png',
  374. '/projectManage/taiZhang': 'images/xm.png',
  375. '/safeClient': 'images/zdgl.png',
  376. '/jobCondition': 'images/zyqk.png',
  377. '/yinhuan/riskChecklist': 'images/riskChecklist.png',
  378. '/yinhuan/riskChecklistRecords': 'images/riskChecklistRecords.png',
  379. '/drillProcess': 'images/drillProcess.png',
  380. '/checkTake': 'images/dt.png',
  381. '/projectManage/projectConstructionOperation': 'images/xm.png',
  382. '/projectManage/projectWorkLedger': 'images/xm.png',
  383. '/keyMatters': 'images/keyMatters.png',
  384. '/planManagement': 'images/planManagement.png'
  385. };
  386. return recentlyUsedMapping[path];
  387. };
  388. /**
  389. * 测试消息
  390. */
  391. const getAccessToken = () => {
  392. const url = '/sgsafe/MobileMessage/getAccessToken';
  393. const params = {};
  394. proxy.$axios.get(url, params).then(response => {
  395. if (response.data.code === 0) {
  396. console.log('accessToken操作成功', response.data.data);
  397. } else {
  398. console.log('accessToken操作失败操作失败', response.data.fullMsg);
  399. }
  400. });
  401. };
  402. const sendMobileMsg = () => {
  403. const url = '/sgsafe/MobileMessage/sendMsg';
  404. const params = {};
  405. proxy.$axios.get(url, params).then(response => {
  406. if (response.data.code === 0) {
  407. console.log('accessToken操作成功', response.data.data);
  408. } else {
  409. showFailToast('操作失败', response.data.msg);
  410. console.log('accessToken操作失败操作失败', response.data.fullMsg);
  411. }
  412. });
  413. };
  414. </script>
  415. <style scoped>
  416. /* 固定在顶部的标题栏样式 */
  417. .header-title {
  418. background-color: #3875c6;
  419. height: 50px;
  420. padding: 15px 20px;
  421. box-shadow: 0 2px 4px rgba(0, 0, 0, 0.1);
  422. z-index: 100;
  423. }
  424. .title-text {
  425. margin-top: 12px;
  426. color: white;
  427. font-size: 18px;
  428. /* font-weight: 600; */
  429. text-align: center;
  430. font-family: 'PingFang SC', 'Microsoft YaHei', sans-serif;
  431. letter-spacing: 1px;
  432. }
  433. .body-bg {
  434. background-color: #ffffff;
  435. padding-top: 10px;
  436. }
  437. :deep(.van-grid-item__text) {
  438. font-size: var(--van-font-size-lg0);
  439. }
  440. .dbTitle {
  441. margin-top: 10px;
  442. }
  443. .daiban_titile_img {
  444. vertical-align: middle;
  445. width: 20px;
  446. height: 20px;
  447. }
  448. .custom-title {
  449. font-size: var(--van-font-size-lg);
  450. font-weight: bold;
  451. color: var(--van-gray-9);
  452. }
  453. .vanicon_text {
  454. font-size: var(--van-font-size-lg0);
  455. color: var(--van-grid-item-text-color);
  456. margin-top: var(--van-padding-xs);
  457. line-height: 1.5;
  458. word-break: break-all;
  459. text-align: center;
  460. height: 40px;
  461. }
  462. .card {
  463. margin: 10px;
  464. border-radius: 8px;
  465. overflow: hidden;
  466. box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
  467. background-color: #fff;
  468. }
  469. .title {
  470. padding-left: 20px;
  471. padding-top: 20px;
  472. font-weight: bold;
  473. font-size: 20px;
  474. }
  475. </style>