doubleHistoricalWeeklyDetils.vue 27 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792
  1. <template>
  2. <div>
  3. <!-- 顶部条-->
  4. <div class="navBarTOP">
  5. <van-nav-bar class="navBar" title="半月报详情" left-arrow @click-left="onClickLeft" />
  6. <!-- <p style="margin-left: 16px; font-size: 14px;">{{title}}</p>-->
  7. </div>
  8. <div class="lineGrey"></div>
  9. <div class="lineGrey"></div>
  10. <div class="lineGrey"></div>
  11. <div class="lineGrey"></div>
  12. <div class="lineGrey"></div>
  13. <!-- 主体内容-->
  14. <div class="container linep">
  15. <p style="font-size: 16px; margin: 10px 0">{{ title }}</p>
  16. <van-collapse v-model="activeNames">
  17. <van-collapse-item title="建店布机" name="2">
  18. <createStoreBJ :reportTargetAll="reportTargetAll"></createStoreBJ>
  19. </van-collapse-item>
  20. <van-collapse-item name="16" title="专业时时丽分销店下单">
  21. <ZYPlaceOrder :reportTargetAll="reportTargetAll"></ZYPlaceOrder>
  22. </van-collapse-item>
  23. <van-collapse-item title="业绩目标SAP(千元)" name="1" v-if="type != 3 && type != 4">
  24. <performanceSAP :reportTargetAll="reportTargetAll" :JZQuota="JZQuota"></performanceSAP>
  25. </van-collapse-item>
  26. <van-collapse-item name="27" title="内墙中高端SAP(千元)">
  27. <van-row>
  28. <van-col span="12"><span class="leftTitle">本月业绩</span></van-col>
  29. <van-col span="12"><span class="rightTitle">本季业绩</span></van-col>
  30. <van-col span="12"
  31. ><p>
  32. 实际:<span class="colorbalck">{{
  33. Micrometer(reportTargetAll.rjqSapMonthAct)
  34. }}</span>
  35. </p></van-col
  36. >
  37. <van-col span="12"
  38. ><p>
  39. 实际:<span class="colorbalck">{{
  40. Micrometer(reportTargetAll.rjqSapQuarterAct)
  41. }}</span>
  42. </p></van-col
  43. >
  44. <van-col span="12"
  45. ><p>
  46. 达成率:<span class="colorbalck">{{ reportTargetAll.rjqSapMonthSuccessRate }}%</span>
  47. </p></van-col
  48. >
  49. <van-col span="12"
  50. ><p>
  51. 达成率:<span class="colorbalck"
  52. >{{ reportTargetAll.rjqSapQuarterSuccessRate }}%</span
  53. >
  54. </p></van-col
  55. >
  56. <van-col span="12"
  57. ><p>
  58. 成长率:<span class="colorbalck">{{ reportTargetAll.rjqSapMonthGrowRate }}%</span>
  59. </p></van-col
  60. >
  61. <van-col span="12"
  62. ><p>
  63. 成长率:<span class="colorbalck">{{ reportTargetAll.rjqSapQuarterGrowRate }}%</span>
  64. </p></van-col
  65. >
  66. </van-row>
  67. </van-collapse-item>
  68. <!-- 内外墙平涂SAP -->
  69. <van-collapse-item name="2" title="内外墙平涂SAP(千元)">
  70. <neiwaiqiangpingtu :reportTargetAll="reportTargetAll"></neiwaiqiangpingtu>
  71. </van-collapse-item>
  72. <van-collapse-item name="11" title="专业时时丽SAP(千元)">
  73. <ZYSAP :reportTargetAll="reportTargetAll"></ZYSAP>
  74. </van-collapse-item>
  75. <van-collapse-item name="28" title="防水+背胶SAP(千元)">
  76. <van-row>
  77. <van-col span="12"><span class="leftTitle">本月业绩</span></van-col
  78. ><van-col span="12"><span class="rightTitle">本季业绩</span></van-col>
  79. <van-col span="12"
  80. ><p>
  81. 实际:<span class="colorbalck">{{
  82. Micrometer(reportTargetAll.fsbjSapMonthAct)
  83. }}</span>
  84. </p></van-col
  85. >
  86. <van-col span="12"
  87. ><p>
  88. 实际:<span class="colorbalck">{{
  89. Micrometer(reportTargetAll.fsbjSapQuarterAct)
  90. }}</span>
  91. </p></van-col
  92. >
  93. <van-col span="12"
  94. ><p>
  95. 达成率:<span class="colorbalck"
  96. >{{ reportTargetAll.fsbjSapMonthSuccessRate }}%</span
  97. >
  98. </p></van-col
  99. >
  100. <van-col span="12"
  101. ><p>
  102. 达成率:<span class="colorbalck"
  103. >{{ reportTargetAll.fsbjSapQuarterSuccessRate }}%</span
  104. >
  105. </p></van-col
  106. >
  107. <van-col span="12"
  108. ><p>
  109. 成长率:<span class="colorbalck">{{ reportTargetAll.fsbjSapMonthGrowRate }}%</span>
  110. </p></van-col
  111. >
  112. <van-col span="12"
  113. ><p>
  114. 成长率:<span class="colorbalck">{{ reportTargetAll.fsbjSapQuarterGrowRate }}%</span>
  115. </p></van-col
  116. >
  117. </van-row>
  118. </van-collapse-item>
  119. <van-collapse-item name="29" title="瓷砖胶SAP(千元)">
  120. <van-row>
  121. <van-col span="12"><span class="leftTitle">本月业绩</span></van-col
  122. ><van-col span="12"><span class="rightTitle">本季业绩</span></van-col>
  123. <van-col span="12"
  124. ><p>
  125. 实际:<span class="colorbalck">{{
  126. Micrometer(reportTargetAll.czjSapMonthAct)
  127. }}</span>
  128. </p></van-col
  129. >
  130. <van-col span="12"
  131. ><p>
  132. 实际:<span class="colorbalck">{{
  133. Micrometer(reportTargetAll.czjSapQuarterAct)
  134. }}</span>
  135. </p></van-col
  136. >
  137. <van-col span="12"
  138. ><p>
  139. 达成率:<span class="colorbalck">{{ reportTargetAll.czjSapMonthSuccessRate }}%</span>
  140. </p></van-col
  141. >
  142. <van-col span="12"
  143. ><p>
  144. 达成率:<span class="colorbalck"
  145. >{{ reportTargetAll.czjSapQuarterSuccessRate }}%</span
  146. >
  147. </p></van-col
  148. >
  149. <van-col span="12"
  150. ><p>
  151. 成长率:<span class="colorbalck">{{ reportTargetAll.czjSapMonthGrowRate }}%</span>
  152. </p></van-col
  153. >
  154. <van-col span="12"
  155. ><p>
  156. 成长率:<span class="colorbalck">{{ reportTargetAll.czjSapQuarterGrowRate }}%</span>
  157. </p></van-col
  158. >
  159. </van-row>
  160. </van-collapse-item>
  161. <van-collapse-item title="魔术漆SAP(千元)" name="3">
  162. <van-row>
  163. <van-col span="12"><span class="leftTitle">本月业绩</span></van-col>
  164. <van-col span="12"><span class="rightTitle">本季业绩</span></van-col>
  165. <van-col span="12"
  166. ><p>
  167. 实际:<span class="colorbalck">{{ Micrometer(reportTargetAll.ysqMonthAct) }}</span>
  168. </p></van-col
  169. >
  170. <van-col span="12"
  171. ><p>
  172. 实际:<span class="colorbalck">{{ Micrometer(reportTargetAll.ysqQuarterAct) }}</span>
  173. </p></van-col
  174. >
  175. <van-col span="12"
  176. ><p>
  177. 达成率:<span class="colorbalck">{{ reportTargetAll.ysqMonthSuccessRate }}%</span>
  178. </p></van-col
  179. >
  180. <van-col span="12"
  181. ><p>
  182. 达成率:<span class="colorbalck">{{ reportTargetAll.ysqQuarterSuccessRate }}%</span>
  183. </p></van-col
  184. >
  185. <van-col span="12"
  186. ><p>
  187. 成长率:<span class="colorbalck">{{ reportTargetAll.ysqMonthGrowRate }}%</span>
  188. </p></van-col
  189. >
  190. <van-col span="12"
  191. ><p>
  192. 成长率:<span class="colorbalck">{{ reportTargetAll.ysqQuarterGrowRate }}%</span>
  193. </p></van-col
  194. >
  195. </van-row>
  196. </van-collapse-item>
  197. <van-collapse-item title="质感外墙SAP(千元)" name="4">
  198. <zhiganwaiqiangSAP :reportTargetAll="reportTargetAll"></zhiganwaiqiangSAP>
  199. </van-collapse-item>
  200. <van-collapse-item name="17" title="超好贴分销店下单">
  201. <veryGoodPlaceOrder :reportTargetAll="reportTargetAll"></veryGoodPlaceOrder>
  202. </van-collapse-item>
  203. <van-collapse-item title="客户开拓" name="6">
  204. <van-row>
  205. <!-- <van-col span="12" v-if="powerGrade>=3"><span class="leftTitle">非片区经销商</span></van-col>-->
  206. <!-- v-if="powerGrade==2"-->
  207. <van-col span="24"><span class="leftTitle">非片客户开发</span></van-col>
  208. <!-- <van-col span="12" v-if="powerGrade>=3"><span class="rightTitle" >TOP70直营家装</span></van-col>-->
  209. <van-col span="24"
  210. ><p>
  211. 全年开发数:<span class="colorbalck">{{
  212. Micrometer(reportTargetAll.customerAct)
  213. }}</span>
  214. </p></van-col
  215. >
  216. <!-- <van-col span="12" v-if="powerGrade>=3"><p>全年目标:<span class="colorbalck">{{reportTargetAll.directCustomerYearTarget}}</span></p></van-col>-->
  217. <!-- <van-col span="24"><p>实际:<span class="colorbalck">{{ Micrometer(reportTargetAll.customerAct) }}</span></p></van-col>-->
  218. <!-- <van-col span="12" v-if="powerGrade>=3"><p>实际:<span class="colorbalck">{{reportTargetAll.directCustomerAct}}</span></p></van-col>-->
  219. <van-col span="24"
  220. ><p>
  221. 全年进度率:<span class="colorbalck">{{ reportTargetAll.customerYearRate }}%</span>
  222. </p></van-col
  223. >
  224. <!-- <van-col span="12" v-if="powerGrade>=3"><p>全年进度率:<span class="colorbalck">{{reportTargetAll.directCustomerYearRate}}%</span></p></van-col>-->
  225. </van-row>
  226. </van-collapse-item>
  227. <van-collapse-item title="上期工作成果" name="7">
  228. <div style="margin-top: -10px">
  229. <div v-for="(item, index) in reportContentsList2" :key="index">
  230. <!-- <p class="texttitle"><span class="opint"></span><span>{{selectDictLabel(weekType,item.doubleWeekType)}}</span></p>-->
  231. <p class="texttitle texttitle2">计划工作进度</p>
  232. <div style="padding: 10px 0; min-height: 32px" class="contentContainer">
  233. <van-field
  234. v-model="reportContentsList1[index].doubleWeekContent"
  235. rows="4"
  236. autosize
  237. readonly
  238. type="textarea" />
  239. </div>
  240. <p class="texttitle texttitle2">实际工作进度</p>
  241. <div style="padding: 10px 0; min-height: 32px" class="contentContainer">
  242. <van-field
  243. v-model="item.doubleWeekContent"
  244. rows="4"
  245. autosize
  246. readonly
  247. type="textarea" />
  248. </div>
  249. </div>
  250. </div>
  251. </van-collapse-item>
  252. <van-collapse-item title="本期工作规划" name="8">
  253. <div style="margin-top: -10px">
  254. <div v-for="(item2, index2) in reportContentsList3" :key="index2">
  255. <!-- <p class="texttitle"><span class="opint"></span><span>{{selectDictLabel(weekType,item2.doubleWeekType)}}</span></p>-->
  256. <div style="padding: 10px 0; min-height: 32px" class="contentContainer">
  257. <van-field
  258. v-model="item2.doubleWeekContent"
  259. rows="4"
  260. autosize
  261. readonly
  262. type="textarea" />
  263. </div>
  264. </div>
  265. </div>
  266. </van-collapse-item>
  267. </van-collapse>
  268. <div
  269. class="contentContainer"
  270. v-if="reportTarget.status > 1 || reportTarget.reportRemarks != null">
  271. <p class="texttitle texttitledaily">
  272. <span class="opint"></span>
  273. <span v-if="reportTarget.status == 1">待审批</span>
  274. <span v-if="reportTarget.status == 3">审批完成</span>
  275. <span v-if="reportTarget.status == 2">退回重写</span>
  276. <span v-if="reportTarget.status == -1">过期未汇报</span>
  277. <span v-if="reportTarget.status > 1"><{{ ptitle }}审批></span>
  278. </p>
  279. <div style="padding: 10px 0" v-if="reportTarget.status > 1">
  280. <van-rate
  281. v-model="reportTarget.number"
  282. :size="25"
  283. readonly
  284. color="#ffd21e"
  285. void-icon="star"
  286. void-color="#eee" /><span class="rateText"
  287. >&nbsp;&nbsp;&nbsp;&nbsp;{{ reportTarget.number }}分</span
  288. >
  289. </div>
  290. <div style="padding: 10px 0" v-if="reportTarget.status > 1">
  291. <van-field v-model="successContent" rows="4" autosize readonly type="textarea" />
  292. </div>
  293. </div>
  294. <div class="contentContainer" v-if="reportTarget.reportRemarks != null">
  295. <div>
  296. <div v-for="(item, index) in reportTarget.reportRemarks" :key="index">
  297. <p class="contentContainerTitle">
  298. <template v-if="item.deptName">{{ item.deptName }}-</template>{{ item.postName }}-{{
  299. item.nickName
  300. }}的点评
  301. </p>
  302. <div style="padding: 10px 0">
  303. <van-field v-model="item.remarkContent" rows="4" autosize readonly type="textarea" />
  304. </div>
  305. <!-- <p style="text-align: right">点评时间:{{ item.createTime }}</p> -->
  306. </div>
  307. </div>
  308. </div>
  309. <div class="contentContainer">
  310. <p class="contentContainerTitle">点评</p>
  311. <div style="padding: 10px 0">
  312. <van-field
  313. v-model="managerRemarkContent"
  314. rows="4"
  315. autosize
  316. maxlength="800"
  317. show-word-limit
  318. type="textarea"
  319. :formatter="formatter" />
  320. </div>
  321. </div>
  322. </div>
  323. <br />
  324. <div class="contentborder">
  325. <van-button type="info" size="small" plain class="Btn1" @click="submint">提交点评</van-button>
  326. </div>
  327. <br />
  328. <!-- <div class="envelopes" @click="openEnterpriseChat" >-->
  329. <!-- <img :src="envelopes">-->
  330. <!-- <p>红包奖励</p>-->
  331. <!-- </div>-->
  332. <br /><br />
  333. <br /><br />
  334. </div>
  335. </template>
  336. <script>
  337. import history from '@/assets/Icon/history.png';
  338. import {
  339. userTodayPlanNum,
  340. loginLog,
  341. homeImge,
  342. insertRemark,
  343. getDetailById,
  344. double_week_type,
  345. updateReport,
  346. } from '@/api/index';
  347. import envelopes from '@/assets/envelopes.png';
  348. import axios from 'axios';
  349. import createStoreBJ from '@/views/componentsTarget/createStoreBJ';
  350. import ZYPlaceOrder from '@/views/componentsTarget/ZYPlaceOrder';
  351. import performanceSAP from '@/views/componentsTarget/performanceSAP';
  352. import ZYSAP from '@/views/componentsTarget/ZYSAP';
  353. import veryGoodPlaceOrder from '@/views/componentsTarget/veryGoodPlaceOrder';
  354. import neiwaiqiangpingtu from '@/views/componentsTarget/neiwaiqiangpingtu';
  355. import zhiganwaiqiangSAP from '@/views/componentsTarget/zhiganwaiqiangSAP';
  356. export default {
  357. name: 'home',
  358. components: {
  359. createStoreBJ,
  360. ZYPlaceOrder,
  361. performanceSAP,
  362. ZYSAP,
  363. veryGoodPlaceOrder,
  364. neiwaiqiangpingtu,
  365. zhiganwaiqiangSAP,
  366. },
  367. data() {
  368. return {
  369. envelopes: envelopes,
  370. show: true,
  371. num: 0,
  372. todayGoal: {},
  373. title: '',
  374. ptitle: '',
  375. progressWidth: 0,
  376. history: history,
  377. imgArr: [],
  378. message: '89989880989890080989',
  379. activeNames: [
  380. '1',
  381. '2',
  382. '3',
  383. '4',
  384. '5',
  385. '6',
  386. '7',
  387. '8',
  388. '11',
  389. '12',
  390. '16',
  391. '17',
  392. '27',
  393. '28',
  394. '29',
  395. ],
  396. powerGrade: '',
  397. value: '2',
  398. reportTargetAll: {},
  399. reportTarget: {},
  400. reportContentsList1: [],
  401. reportContentsList2: [],
  402. reportContentsList3: [],
  403. weekType: [],
  404. successContent: '',
  405. managerRemarkContent: '',
  406. isDiy: false,
  407. type: '-1',
  408. //
  409. };
  410. },
  411. created() {
  412. this.powerGrade = localStorage.getItem('powerGrade');
  413. this.isDiy = localStorage.getItem('isDiy');
  414. this.getDetailById();
  415. double_week_type().then((res) => {
  416. this.weekType = res.data;
  417. });
  418. },
  419. watch: {
  420. $route(to, from) {
  421. this.powerGrade = localStorage.getItem('powerGrade');
  422. this.isDiy = localStorage.getItem('isDiy');
  423. // this.getReportInfo()
  424. if (to.path == '/doubleHistoricalWeeklyDetils') {
  425. this.getDetailById();
  426. }
  427. // &&from.path=="/myHistoricalDaily"
  428. // if(to.path=="/weeklyApprovalDetils"&&from.path=="/dailyApprovalList"){
  429. // this.getDetailById()
  430. // }
  431. },
  432. },
  433. // activated() {
  434. // this.num = 0;
  435. // this.homeImgeFn()
  436. // this.userTodayPlanNum()
  437. // this.loginLogFn()
  438. // },
  439. methods: {
  440. openEnterpriseChat(val) {
  441. let loading1 = this.$toast.loading({
  442. duration: 0,
  443. message: '加载中...',
  444. forbidClick: true,
  445. });
  446. let url = window.location.href;
  447. let that = this;
  448. let wx = this.wx;
  449. let qiyeData;
  450. var userIds = this.reportTarget.reportContents[0].createBy;
  451. const instance = axios.create();
  452. instance.defaults.headers.common['userId'] = localStorage.getItem('loginName');
  453. instance
  454. .get(process.env.VUE_APP_BASE_API + 'mobile/wx/ticket', {
  455. params: {
  456. url: url,
  457. },
  458. })
  459. .then((response) => {
  460. if (response.status == 200) {
  461. loading1.clear();
  462. qiyeData = response.data.data;
  463. wx.config({
  464. beta: true, // 必须这么写,否则wx.invoke调用形式的jsapi会有问题
  465. debug: false, // 开启调试模式,调用的所有api的返回值会在客户端alert出来,若要查看传入的参数,可以在pc端打开,参数信息会通过log打出,仅在pc端时才会打印。
  466. appId: qiyeData.appId, // 必填,企业微信的corpID
  467. timestamp: qiyeData.timestamp, // 必填,生成签名的时间戳
  468. nonceStr: qiyeData.nonceStr, // 必填,生成签名的随机串
  469. signature: qiyeData.signature, // 必填,签名,见 附录-JS-SDK使用权限签名算法
  470. jsApiList: ['ready', 'openEnterpriseChat'], // 必填,需要使用的JS接口列表,凡是要调用的接口都需要传进来
  471. });
  472. wx.ready(function () {
  473. wx.openEnterpriseChat({
  474. //localStorage.getItem("loginName")
  475. userIds: userIds,
  476. // externalUserIds:"dingxiaogai.sm",
  477. groupName: '我的红包群', // 会话名称。单聊时该参数传入空字符串""即可。localStorage.getItem("loginName")
  478. chatId: '', //CHATID 若要打开已有会话,需指定此参数。如果是新建会话,chatId必须为空串
  479. success: function (res) {
  480. var chatId = res.chatId; //返回当前群聊ID,仅当使用agentConfig注入该接口权限时才返回chatId
  481. },
  482. fail: function (res) {
  483. if (res.errMsg.indexOf('function not exist') > -1) {
  484. alert('版本过低请升级');
  485. }
  486. },
  487. });
  488. });
  489. } else {
  490. this.$toast.fail(dataList.msg);
  491. }
  492. });
  493. },
  494. formatter(value) {
  495. return value.replace(
  496. /[\uD83C|\uD83D|\uD83E][\uDC00-\uDFFF][\u200D|\uFE0F]|[\uD83C|\uD83D|\uD83E][\uDC00-\uDFFF]|[0-9|*|#]\uFE0F\u20E3|[0-9|#]\u20E3|[\u203C-\u3299]\uFE0F\u200D|[\u203C-\u3299]\uFE0F|[\u2122-\u2B55]|\u303D|[\A9|\AE]\u3030|\uA9|\uAE|\u3030/gi,
  497. ''
  498. );
  499. },
  500. submint() {
  501. let loading1 = this.$toast.loading({
  502. duration: 0,
  503. message: '数据提交中...',
  504. forbidClick: true,
  505. });
  506. if (this.managerRemarkContent.trim() == '') {
  507. this.$toast('点评内容未填写');
  508. return false;
  509. }
  510. if (this.managerRemarkContent.length > 800) {
  511. this.$toast('点评内容超过800字');
  512. return false;
  513. }
  514. var remak = {
  515. remarkContent: this.managerRemarkContent,
  516. reportId: this.$route.query.reportId,
  517. };
  518. insertRemark(remak).then((res) => {
  519. loading1.clear();
  520. if (res.code == 200) {
  521. this.$dialog
  522. .alert({
  523. title: '系统提示',
  524. message: '提交成功',
  525. })
  526. .then(() => {
  527. this.managerRemarkContent = '';
  528. this.getDetailById();
  529. });
  530. } else {
  531. this.$toast.fail(res.msg);
  532. }
  533. });
  534. },
  535. // submint(){
  536. // let loading1 = this.$toast.loading({
  537. // duration: 0,
  538. // message: '数据提交中...',
  539. // forbidClick: true,
  540. // });
  541. // if(this.managerRemarkContent.trim()==""){
  542. // this.$toast("点评内容未填写")
  543. // return false
  544. // }
  545. // this.reportTarget.managerRemarkContent=this.managerRemarkContent
  546. // this.reportTarget.status=4
  547. // updateReport(this.reportTarget).then(res=>{
  548. // loading1.clear()
  549. // if(res.code==200){
  550. // this.$dialog.alert({
  551. // title: '系统提示',
  552. // message: '提交成功',
  553. // }).then(() => {
  554. // this.getDetailById()
  555. // });
  556. // }else{
  557. // this.$toast.fail(res.msg)
  558. // }
  559. // })
  560. // },
  561. getDetailById() {
  562. let loading1 = this.$toast.loading({
  563. duration: 0,
  564. message: '加载中...',
  565. forbidClick: true,
  566. });
  567. getDetailById({ reportId: this.$route.query.reportId }).then((res) => {
  568. loading1.clear();
  569. this.title =
  570. res.data.deptName + '-' + res.data.postName + '-' + res.data.nickName + '的半月报';
  571. this.ptitle = res.data.pdeptName + '-' + res.data.ppostName + '-' + res.data.pnickName;
  572. this.reportTargetAll = res.data.reportTargetAll;
  573. this.reportTarget = res.data;
  574. this.type = res.data.userType;
  575. this.reportContents = res.data.reportContents;
  576. var reportContentsList1 = [];
  577. var reportContentsList2 = [];
  578. var reportContentsList3 = [];
  579. var reportContentsdata = res.data.reportContents;
  580. if (res.data.status == 3) {
  581. this.successContent = res.data.successContent;
  582. } else {
  583. this.successContent = res.data.failContent;
  584. }
  585. for (var i = 0; i < res.data.reportContents.length; i++) {
  586. if (res.data.reportContents[i].type == '1') {
  587. reportContentsList1.push(reportContentsdata[i]);
  588. }
  589. if (res.data.reportContents[i].type == '2') {
  590. reportContentsList2.push(reportContentsdata[i]);
  591. }
  592. if (res.data.reportContents[i].type == '3') {
  593. reportContentsList3.push(reportContentsdata[i]);
  594. }
  595. }
  596. var ln1 = reportContentsList1.length;
  597. var ln2 = reportContentsList2.length;
  598. if (reportContentsList1.length < reportContentsList2.length) {
  599. var len2 = ln2 - ln1;
  600. for (var x = 0; x < len2; x++) {
  601. reportContentsList1.push({
  602. doubleWeekContent: '',
  603. });
  604. }
  605. }
  606. this.reportContentsList1 = reportContentsList1;
  607. this.reportContentsList2 = reportContentsList2;
  608. this.reportContentsList3 = reportContentsList3;
  609. });
  610. },
  611. login() {
  612. if (this.num > 4) {
  613. this.$router.push('/login');
  614. } else {
  615. this.num = this.num + 1;
  616. }
  617. },
  618. homeImgeFn() {
  619. homeImge({}).then((res) => {
  620. var imgArr = res.msg;
  621. var imgReg = /<img.*?(?:>|\/>)/gi;
  622. var arr = imgArr.match(imgReg); // arr 为包含所有img标签的数组
  623. this.imgArr = arr;
  624. });
  625. },
  626. userTodayPlanNum() {
  627. userTodayPlanNum().then((res) => {
  628. if (res.code == 200) {
  629. this.todayGoal = res.data;
  630. this.progressWidth = (this.todayGoal.finishNum / this.todayGoal.planNum) * 100 + '%';
  631. localStorage.setItem('nickName', res.data.user.nickName);
  632. localStorage.setItem('storeType', res.data.user.type);
  633. } else {
  634. this.$toast.fail(res.msg);
  635. }
  636. });
  637. },
  638. loginLogFn() {
  639. // var ua="Mozilla/5.0 (Linux; Android 10; HRY-AL00Ta Build/HONORHRY-AL00Ta; wv) AppleWebKit/537.36 (KHTML, like Gecko) Version/4.0 Chrome/77.0.3865.120 MQQBrowser/6.2 TBS/045737 Mobile Safari/537.36 wxwork/4.0.2 ColorScheme/Light MicroMessenger/7.0.1 NetType/WIFI Language/zh Lang/zh".toLowerCase();
  640. // console.log(ua)
  641. // var ua= window.navigator.userAgent.toLowerCase();
  642. // // .toLowerCase();
  643. // if( (ua.match(/MicroMessenger/i) == 'micromessenger') && (ua.match(/wxwork/i) == 'wxwork') ){
  644. //
  645. // }else{
  646. // this.$router.push("/err")
  647. // }
  648. var appVersion = navigator.appVersion;
  649. var Logapp = appVersion.split('(')[1].split(';');
  650. var arrLog = '';
  651. if (Logapp[0] == 'Linux') {
  652. arrLog = {
  653. browser: navigator.appCodeName,
  654. os: Logapp[1],
  655. phoneBrand: Logapp[2].split('/')[1],
  656. phoneModel: Logapp[2].split('/')[0],
  657. };
  658. } else {
  659. arrLog = {
  660. browser: navigator.appCodeName,
  661. os: Logapp[0],
  662. phoneBrand: '',
  663. phoneModel: '',
  664. };
  665. }
  666. loginLog(arrLog).then((res) => {
  667. if (res.code == 200) {
  668. console.log('设备记录成功');
  669. }
  670. });
  671. },
  672. onClickLeft() {
  673. this.$router.go(-1);
  674. },
  675. configFn() {
  676. this.show = false;
  677. },
  678. },
  679. };
  680. </script>
  681. <style scoped>
  682. .container {
  683. margin: 10px;
  684. }
  685. .container .van-collapse-item {
  686. margin-bottom: 10px;
  687. border-radius: 6px;
  688. overflow: hidden;
  689. }
  690. .linep p {
  691. margin: 6px 0 0 0;
  692. font-size: 14px;
  693. color: #666;
  694. padding-left: 6px;
  695. }
  696. .linep .texttitle {
  697. color: #0057ba;
  698. position: relative;
  699. padding-left: 10px;
  700. }
  701. .linep .texttitledaily {
  702. color: #000;
  703. position: relative;
  704. padding-left: 10px;
  705. }
  706. .linep .texttitle2 {
  707. padding-left: 6px;
  708. }
  709. .linep .texttitle .opint {
  710. position: absolute;
  711. left: 0px;
  712. top: 6px;
  713. margin-right: 6px;
  714. display: inline-block;
  715. width: 6px;
  716. height: 6px;
  717. border-radius: 10px;
  718. background-color: #0057ba;
  719. }
  720. .linep .texttitledaily .opint {
  721. position: absolute;
  722. left: 0px;
  723. top: 6px;
  724. margin-right: 6px;
  725. display: inline-block;
  726. width: 6px;
  727. height: 6px;
  728. border-radius: 10px;
  729. background-color: #0057ba;
  730. }
  731. .leftTitle {
  732. background-color: #74a4d9;
  733. color: #fff;
  734. display: inline-block;
  735. padding: 0 4px;
  736. border-radius: 2px;
  737. }
  738. .rightTitle {
  739. background-color: #e7b4bb;
  740. color: #fff;
  741. display: inline-block;
  742. padding: 0 4px;
  743. border-radius: 2px;
  744. }
  745. </style>
  746. <style>
  747. .linep .van-cell__title {
  748. color: #1e5398;
  749. font-weight: 500;
  750. }
  751. .linep .contentContainer {
  752. background-color: white;
  753. border-radius: 8px;
  754. padding: 10px 16px;
  755. margin-bottom: 10px;
  756. }
  757. .linep .contentContainer .contentContainerTitle {
  758. color: #222;
  759. }
  760. .linep .contentContainer .contentContainerTitle span {
  761. font-size: 12px;
  762. color: #666;
  763. }
  764. .linep .contentContainer .van-field__control {
  765. background-color: #ebf4ff;
  766. padding: 10px;
  767. border-radius: 8px;
  768. }
  769. .linep .contentContainer .van-cell {
  770. padding: 0;
  771. }
  772. .van-dialog__confirm,
  773. .van-dialog__confirm:active {
  774. color: #0057ba;
  775. }
  776. </style>