weeklyApprovalDetils.vue 18 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527
  1. <template>
  2. <div>
  3. <!-- 顶部条-->
  4. <div class="navBarTOP">
  5. <van-nav-bar class="navBar" title="周报详情" left-arrow @click-left="onClickLeft" />
  6. </div>
  7. <!-- 主体内容-->
  8. <div class="container linep">
  9. <div class="lineGrey"></div>
  10. <div class="lineGrey"></div>
  11. <div class="lineGrey"></div>
  12. <div style="height: 4px"></div>
  13. <van-collapse v-model="activeNames">
  14. <template v-if="!YFQuota">
  15. <!-- YFQuota:应用服务平台 不显示各项指标 -->
  16. <van-collapse-item title="业绩目标SAP(千元)" name="1" v-if="type != 3 && type != 4">
  17. <performanceSAP :reportTargetAll="reportTargetAll" :JZQuota="JZQuota"></performanceSAP>
  18. </van-collapse-item>
  19. <van-collapse-item title="质感外墙SAP(千元)" name="4">
  20. <zhiganwaiqiangSAP :reportTargetAll="reportTargetAll"></zhiganwaiqiangSAP>
  21. </van-collapse-item>
  22. <van-collapse-item v-if="powerGrade != 1" name="3" title="魔术漆SAP(千元)">
  23. <moshouqiSAP :reportTargetAll="reportTargetAll"></moshouqiSAP>
  24. </van-collapse-item>
  25. <van-collapse-item v-if="powerGrade != 1" name="28" title="防水+背胶SAP(千元)">
  26. <fangshuiSAP :reportTargetAll="reportTargetAll"></fangshuiSAP>
  27. </van-collapse-item>
  28. <van-collapse-item
  29. v-if="powerGrade != 1 && !JZQuota && !GZdata"
  30. name="27"
  31. title="内墙中高端SAP(千元)">
  32. <neiqiangzhonggaoduanSAP :reportTargetAll="reportTargetAll"></neiqiangzhonggaoduanSAP>
  33. </van-collapse-item>
  34. <!-- 内外墙平涂SAP -->
  35. <van-collapse-item v-if="powerGrade != 1" name="2" title="内外墙平涂SAP(千元)">
  36. <neiwaiqiangpingtu :reportTargetAll="reportTargetAll"></neiwaiqiangpingtu>
  37. </van-collapse-item>
  38. <van-collapse-item
  39. v-if="[1, 4, 5].indexOf(powerGrade) !== -1"
  40. name="11"
  41. title="专业时时丽SAP(千元)">
  42. <ZYSAP :reportTargetAll="reportTargetAll"></ZYSAP>
  43. </van-collapse-item>
  44. <van-collapse-item
  45. v-if="[1, 4, 5].indexOf(powerGrade) !== -1"
  46. name="29"
  47. :title="'瓷砖胶SAP(千元)'">
  48. <cizhuanjiaoSAP :reportTargetAll="reportTargetAll"></cizhuanjiaoSAP>
  49. </van-collapse-item>
  50. <van-collapse-item title="建店布机" name="2">
  51. <createStoreBJ :reportTargetAll="reportTargetAll"></createStoreBJ>
  52. </van-collapse-item>
  53. <van-collapse-item name="16" title="专业时时丽分销店下单">
  54. <ZYPlaceOrder :reportTargetAll="reportTargetAll"></ZYPlaceOrder>
  55. </van-collapse-item>
  56. <van-collapse-item name="17" title="超好贴分销店下单">
  57. <veryGoodPlaceOrder :reportTargetAll="reportTargetAll"></veryGoodPlaceOrder>
  58. </van-collapse-item>
  59. <van-collapse-item title="客户开拓" name="6">
  60. <van-row>
  61. <van-col span="24"><span class="leftTitle">非片客户开发</span></van-col>
  62. <van-col span="24"
  63. ><p>
  64. 全年开发数:<span class="colorbalck">{{
  65. Micrometer(reportTargetAll.customerAct)
  66. }}</span>
  67. </p></van-col
  68. >
  69. <van-col span="24"
  70. ><p>
  71. 全年进度率:<span class="colorbalck">{{ reportTargetAll.customerYearRate }}%</span>
  72. </p></van-col
  73. >
  74. </van-row>
  75. </van-collapse-item>
  76. </template>
  77. <van-collapse-item title="上周工作成果" name="8">
  78. <div style="margin-top: -10px">
  79. <div v-for="(item2, index2) in reportContentsList2" :key="index2">
  80. <div v-if="index2 < 7">
  81. <p class="texttitle">
  82. <span class="opint"></span
  83. ><span v-if="!reportTarget.hideWeekDate">{{
  84. weeklyTimeDivision(item2.contentTime, 0)
  85. }}</span
  86. ><span>{{ weeklyTimeDivision(item2.contentTime, 1) }}</span>
  87. </p>
  88. <p>
  89. <span class="colorbalck">上午:</span
  90. >{{ reportContentsList1[index2].weekContentAm }}
  91. </p>
  92. <p>
  93. <span class="colorbalck">下午:</span
  94. >{{ reportContentsList1[index2].weekContentPm }}
  95. </p>
  96. <p class="texttitle texttitle2">实际工作进度</p>
  97. <p><span class="colorbalck">上午:</span>{{ item2.weekContentAm }}</p>
  98. <p><span class="colorbalck">下午:</span>{{ item2.weekContentPm }}</p>
  99. </div>
  100. <p v-if="index2 == 7" class="texttitle"><span class="opint"></span>上周工作重点</p>
  101. <div v-if="index2 == 7" style="padding: 10px 0" class="contentContainer">
  102. <van-field
  103. v-model="reportContentsList1[index2].weekContentSummary"
  104. rows="4"
  105. autosize
  106. readonly
  107. type="textarea" />
  108. </div>
  109. <p v-if="index2 == 7" class="texttitle"><span class="opint"></span>上周工作成果</p>
  110. <div v-if="index2 == 7" style="padding: 10px 0" class="contentContainer">
  111. <van-field
  112. v-model="item2.weekContentSummary"
  113. rows="4"
  114. autosize
  115. readonly
  116. type="textarea" />
  117. </div>
  118. </div>
  119. </div>
  120. </van-collapse-item>
  121. <van-collapse-item title="本周工作规划" name="9">
  122. <div style="margin-top: -10px">
  123. <div v-for="(item, index) in reportContentsList3" :key="index">
  124. <p v-if="index < 7" class="texttitle">
  125. <span class="opint"></span
  126. ><span v-if="!reportTarget.hideWeekDate">{{
  127. weeklyTimeDivision(item.contentTime, 0)
  128. }}</span
  129. ><span>{{ weeklyTimeDivision(item.contentTime, 1) }}</span>
  130. </p>
  131. <p v-if="index < 7"><span class="colorbalck">上午:</span>{{ item.weekContentAm }}</p>
  132. <p v-if="index < 7"><span class="colorbalck">下午:</span>{{ item.weekContentPm }}</p>
  133. <p v-if="index == 7" class="texttitle"><span class="opint"></span>本周工作重点</p>
  134. <div v-if="index == 7" style="padding: 10px 0" class="contentContainer">
  135. <van-field
  136. v-model="item.weekContentSummary"
  137. rows="4"
  138. autosize
  139. readonly
  140. type="textarea" />
  141. </div>
  142. </div>
  143. </div>
  144. </van-collapse-item>
  145. <div
  146. class="contentContainer"
  147. v-if="reportTarget.status > 1 || reportTarget.reportRemarks != null">
  148. <p class="texttitle texttitledaily">
  149. <span class="opint"></span>
  150. <span v-if="reportTarget.status == 1">待审批</span>
  151. <span v-if="reportTarget.status == 3">审批完成</span>
  152. <span v-if="reportTarget.status == 2">退回重写</span>
  153. <span v-if="reportTarget.status == -1">过期未汇报</span>
  154. <span v-if="reportTarget.status > 1"><{{ ptitle }}审批></span>
  155. </p>
  156. <div style="padding: 10px 0" v-if="reportTarget.status > 1">
  157. <van-rate
  158. v-model="reportTarget.number"
  159. :size="25"
  160. color="#ffd21e"
  161. void-icon="star"
  162. void-color="#eee"
  163. readonly />
  164. <span class="rateText">&nbsp;&nbsp;&nbsp;&nbsp;{{ reportTarget.number }}分</span>
  165. </div>
  166. <p class="contentContainerTitle" v-if="reportTarget.status > 1">评语</p>
  167. <div style="padding: 10px 0" v-if="reportTarget.status > 1">
  168. <van-field v-model="successContent" rows="4" autosize readonly type="textarea" />
  169. </div>
  170. </div>
  171. <div
  172. class="contentContainer"
  173. v-if="reportTarget.status > 1 || reportTarget.reportRemarks != null">
  174. <div>
  175. <div v-for="(item, index) in reportTarget.reportRemarks" :key="index">
  176. <p class="contentContainerTitle">
  177. <template v-if="item.deptName">{{ item.deptName }}-</template>{{ item.postName }}-{{
  178. item.nickName
  179. }}点评
  180. </p>
  181. <div style="padding: 10px 0">
  182. <van-field
  183. v-model="item.remarkContent"
  184. rows="4"
  185. autosize
  186. readonly
  187. type="textarea" />
  188. </div>
  189. <!-- <p style="text-align: right">点评时间:{{ item.createTime }}</p> -->
  190. </div>
  191. </div>
  192. </div>
  193. </van-collapse>
  194. </div>
  195. <br />
  196. <div class="lineGrey"></div>
  197. <div class="contentborder" v-if="reportTarget.status == 2">
  198. <van-button type="info" size="small" plain class="Btn1" @click="submint">重新填写</van-button>
  199. </div>
  200. <br /><br />
  201. </div>
  202. </template>
  203. <script>
  204. import history from '@/assets/Icon/history.png';
  205. import { userTodayPlanNum, loginLog, homeImge, getDetailById } from '@/api/index';
  206. import createStoreBJ from '@/views/componentsTarget/createStoreBJ';
  207. import ZYPlaceOrder from '@/views/componentsTarget/ZYPlaceOrder';
  208. import performanceSAP from '@/views/componentsTarget/performanceSAP';
  209. import ZYSAP from '@/views/componentsTarget/ZYSAP';
  210. import veryGoodPlaceOrder from '@/views/componentsTarget/veryGoodPlaceOrder';
  211. import neiwaiqiangpingtu from '@/views/componentsTarget/neiwaiqiangpingtu';
  212. import zhiganwaiqiangSAP from '@/views/componentsTarget/zhiganwaiqiangSAP';
  213. import cizhuanjiaoSAP from '@/views/componentsTarget/cizhuanjiaoSAP';
  214. import neiqiangzhonggaoduanSAP from '@/views/componentsTarget/neiqiangzhonggaoduanSAP';
  215. import moshouqiSAP from '@/views/componentsTarget/moshouqiSAP';
  216. import fangshuiSAP from '@/views/componentsTarget/fangshuiSAP';
  217. export default {
  218. name: 'home',
  219. components: {
  220. createStoreBJ,
  221. ZYPlaceOrder,
  222. performanceSAP,
  223. ZYSAP,
  224. veryGoodPlaceOrder,
  225. neiwaiqiangpingtu,
  226. zhiganwaiqiangSAP,
  227. cizhuanjiaoSAP,
  228. neiqiangzhonggaoduanSAP,
  229. moshouqiSAP,
  230. fangshuiSAP,
  231. },
  232. data() {
  233. return {
  234. show: true,
  235. num: 0,
  236. todayGoal: {},
  237. progressWidth: 0,
  238. history: history,
  239. imgArr: [],
  240. message: '8d98s90d890s8d',
  241. activeNames: [
  242. '1',
  243. '2',
  244. '3',
  245. '4',
  246. '5',
  247. '6',
  248. '7',
  249. '8',
  250. '9',
  251. '11',
  252. '12',
  253. '16',
  254. '17',
  255. '27',
  256. '28',
  257. '29',
  258. ],
  259. powerGrade: '',
  260. value: 2,
  261. timeList: [],
  262. reportTargetAll: {},
  263. Content: '',
  264. number: '',
  265. successContent: '',
  266. reportContentsList1: [],
  267. reportContentsList2: [],
  268. reportContentsList3: [],
  269. updateReport: {},
  270. reportTarget: {},
  271. type: '-1',
  272. ptitle: '',
  273. JZQuota: false,
  274. YFQuota: false, //应用服务
  275. };
  276. },
  277. created() {
  278. this.powerGrade = localStorage.getItem('powerGrade');
  279. this.getDetailById();
  280. },
  281. watch: {
  282. $route(to, from) {
  283. this.powerGrade = localStorage.getItem('powerGrade');
  284. if (to.path == '/weeklyApprovalDetils') {
  285. this.getDetailById();
  286. }
  287. },
  288. },
  289. methods: {
  290. submint() {
  291. this.$router.push({
  292. path: '/weekly',
  293. query: { reportId: this.$route.query.reportId, temporaryShow: 'N' },
  294. });
  295. },
  296. getDetailById() {
  297. let loading1 = this.$toast.loading({
  298. duration: 0,
  299. message: '加载中...',
  300. forbidClick: true,
  301. });
  302. getDetailById({ reportId: this.$route.query.reportId }).then((res) => {
  303. loading1.clear();
  304. if (res.code == 200) {
  305. this.YFQuota = res.data.postType == 'YF' ? true : false;
  306. this.JZQuota = false;
  307. if (res.data.postType == 'JZ') {
  308. this.JZQuota = true;
  309. }
  310. var dayTime = res.data.date;
  311. this.type = res.data.userType;
  312. this.ptitle = res.data.pdeptName + '-' + res.data.ppostName + '-' + res.data.pnickName;
  313. this.timeList = this.parseTimeParagraph(
  314. dayTime.slice(0, 4) + '-' + dayTime.slice(4, 6) + '-' + dayTime.slice(6, 8)
  315. );
  316. this.reportTargetAll = res.data.reportTargetAll;
  317. this.reportTarget = res.data;
  318. this.reportContents = res.data.reportContents;
  319. var reportContentsList1 = [];
  320. var reportContentsList2 = [];
  321. var reportContentsList3 = [];
  322. var reportContentsdata = res.data.reportContents;
  323. if (res.data.status == 3) {
  324. this.successContent = res.data.successContent;
  325. } else {
  326. this.successContent = res.data.failContent;
  327. }
  328. for (var i = 0; i < reportContentsdata.length; i++) {
  329. if (
  330. reportContentsdata[i].type == '1' &&
  331. reportContentsdata[i].contentTime.split(' ')[1] != undefined
  332. ) {
  333. reportContentsList1.push(reportContentsdata[i]);
  334. }
  335. if (
  336. reportContentsdata[i].type == '2' &&
  337. reportContentsdata[i].contentTime.split(' ')[1] != undefined
  338. ) {
  339. reportContentsList2.push(reportContentsdata[i]);
  340. }
  341. if (
  342. reportContentsdata[i].type == '3' &&
  343. reportContentsdata[i].contentTime.split(' ')[1] != undefined
  344. ) {
  345. reportContentsList3.push(reportContentsdata[i]);
  346. }
  347. }
  348. for (var p = 0; p < reportContentsdata.length; p++) {
  349. if (
  350. reportContentsdata[p].type == '2' &&
  351. reportContentsdata[p].contentTime.split(' ')[1] == undefined
  352. ) {
  353. reportContentsList2.push(reportContentsdata[p]);
  354. }
  355. if (
  356. reportContentsdata[p].type == '1' &&
  357. reportContentsdata[p].contentTime.split(' ')[1] == undefined
  358. ) {
  359. reportContentsList1.push(reportContentsdata[p]);
  360. }
  361. if (
  362. reportContentsdata[p].type == '3' &&
  363. reportContentsdata[p].contentTime.split(' ')[1] == undefined
  364. ) {
  365. reportContentsList3.push(reportContentsdata[p]);
  366. }
  367. }
  368. var ln1 = reportContentsList1.length;
  369. var ln2 = reportContentsList2.length;
  370. if (reportContentsList1.length < reportContentsList2.length) {
  371. var len2 = ln2 - ln1;
  372. for (var x = 0; x < len2; x++) {
  373. reportContentsList1.push({
  374. contentTime: '',
  375. weekContentAm: '',
  376. weekContentPm: '',
  377. weekContentSummary: null,
  378. });
  379. }
  380. }
  381. if (reportContentsList1.length == 7) {
  382. reportContentsList1.push({
  383. contentTime: this.parseTime(new Date(), '{y}-{m}-{d}'),
  384. weekContentAm: '',
  385. weekContentPm: '',
  386. weekContentSummary: null,
  387. type: 1,
  388. });
  389. }
  390. if (reportContentsList2.length == 7) {
  391. reportContentsList2.push({
  392. contentTime: this.parseTime(new Date(), '{y}-{m}-{d}'),
  393. weekContentAm: '',
  394. weekContentPm: '',
  395. weekContentSummary: null,
  396. type: 2,
  397. });
  398. }
  399. if (reportContentsList3.length == 7) {
  400. reportContentsList3.push({
  401. contentTime: this.parseTime(new Date(), '{y}-{m}-{d}'),
  402. weekContentAm: '',
  403. weekContentPm: '',
  404. weekContentSummary: null,
  405. type: 3,
  406. });
  407. }
  408. this.reportContentsList1 = reportContentsList1;
  409. this.reportContentsList2 = reportContentsList2;
  410. this.reportContentsList3 = reportContentsList3;
  411. }
  412. });
  413. },
  414. onClickLeft() {
  415. this.$router.go(-1);
  416. },
  417. },
  418. };
  419. </script>
  420. <style scoped>
  421. .container {
  422. margin: 10px;
  423. }
  424. .container .van-collapse-item {
  425. margin-bottom: 10px;
  426. border-radius: 6px;
  427. overflow: hidden;
  428. }
  429. .linep p {
  430. margin: 14px 0 0 0;
  431. font-size: 14px;
  432. color: #666;
  433. padding-left: 6px;
  434. }
  435. .linep .texttitle {
  436. color: #0057ba;
  437. position: relative;
  438. padding-left: 10px;
  439. margin-top: 16px;
  440. }
  441. .linep .texttitledaily {
  442. color: #000;
  443. position: relative;
  444. padding-left: 10px;
  445. }
  446. .linep .texttitle2 {
  447. padding-left: 6px;
  448. }
  449. .linep .texttitle .opint {
  450. position: absolute;
  451. left: 0px;
  452. top: 6px;
  453. margin-right: 6px;
  454. display: inline-block;
  455. width: 6px;
  456. height: 6px;
  457. border-radius: 10px;
  458. background-color: #0057ba;
  459. }
  460. .linep .texttitledaily .opint {
  461. position: absolute;
  462. left: 0px;
  463. top: 6px;
  464. margin-right: 6px;
  465. display: inline-block;
  466. width: 6px;
  467. height: 6px;
  468. border-radius: 10px;
  469. background-color: #0057ba;
  470. }
  471. .leftTitle {
  472. background-color: #a6c9f1;
  473. color: #fff;
  474. display: inline-block;
  475. padding: 0 4px;
  476. border-radius: 2px;
  477. }
  478. .Btn1 {
  479. display: block;
  480. width: 100%;
  481. border-radius: 6px;
  482. color: #fff !important;
  483. background-color: #0057ba;
  484. border: 1px solid #0057ba;
  485. height: 44px;
  486. }
  487. .rightTitle {
  488. background-color: #ffb5bb;
  489. color: #fff;
  490. display: inline-block;
  491. padding: 0 4px;
  492. border-radius: 2px;
  493. }
  494. </style>
  495. <style>
  496. .linep .van-cell__title {
  497. color: #1e5398;
  498. font-weight: 500;
  499. }
  500. .linep .contentContainer {
  501. background-color: white;
  502. border-radius: 8px;
  503. padding: 10px 16px;
  504. margin-bottom: 10px;
  505. }
  506. .linep .contentContainer .contentContainerTitle {
  507. color: #222;
  508. margin-top: 10px;
  509. }
  510. .linep .contentContainer .contentContainerTitle span {
  511. font-size: 12px;
  512. color: #333;
  513. }
  514. .linep .contentContainer .van-field__control {
  515. background-color: #ebf4ff;
  516. padding: 10px;
  517. border-radius: 8px;
  518. }
  519. .linep .contentContainer .van-cell {
  520. padding: 0;
  521. }
  522. </style>