doubleHistoricalWeeklyDetils.vue 28 KB

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