imageAIVerifyErr.vue 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324
  1. <template>
  2. <div class="imageAIVerifyErr">
  3. <el-dialog
  4. title="提示"
  5. :visible.sync="vanPopup"
  6. width="80%"
  7. :append-to-body="true"
  8. custom-class="AIVerifyErrdialog">
  9. <div class="AIVerifyErrMask">
  10. <!-- <van-popup v-model="vanPopup" @close="close" :close-on-click-overlay="false"> -->
  11. <div class="title">图像识别结果</div>
  12. <div class="content">
  13. <div class="AIVerify">{{ contentMessage }}</div>
  14. <div class="uploadImg" @click="uploadImg" v-if="shopSignChange != 1">
  15. <div class="label"><span class="van-f-red">*</span>重新拍照上传</div>
  16. <div class="icon">
  17. <van-icon class="photo photos" name="photograph" size="22px" color="#969696" />
  18. </div>
  19. </div>
  20. </div>
  21. <div class="uploadBtn" v-if="shotsNum >= 3 && shopSignChange != 1">
  22. <div class="tips"><van-icon name="question-o" @click="openTips" />上传后会有何影响</div>
  23. <div class="confirmUpload" @click="confirmUpload">仍要上传</div>
  24. </div>
  25. <div class="uploadBtn" v-if="shopSignChange == 1">
  26. <div class="confirmUpload" @click="uploadImg">重新拍照</div>
  27. <div class="changeImage" @click="confirmUpload">更换门店照</div>
  28. </div>
  29. <div class="historyImage" v-if="shopSignChange == 1">
  30. <div class="initImage imageItem" v-if="imageAIVerifyData.createStoreUrl">
  31. <img
  32. :src="imageAIVerifyData.createStoreUrl"
  33. width="100px"
  34. height="100px"
  35. @click="previewsImg(imageAIVerifyData.createStoreUrl)" />
  36. <span>建店时店招</span>
  37. </div>
  38. <div class="newestImage imageItem" v-if="imageAIVerifyData.lastVisitUrl">
  39. <img
  40. :src="imageAIVerifyData.lastVisitUrl"
  41. width="100px"
  42. height="100px"
  43. @click="previewsImg(imageAIVerifyData.lastVisitUrl)" />
  44. <span>上次拜访店招</span>
  45. </div>
  46. <div class="presentImage imageItem" v-if="imageAIVerifyData.url">
  47. <img
  48. :src="imageAIVerifyData.url"
  49. width="100px"
  50. height="100px"
  51. @click="previewsImg(imageAIVerifyData.url)" />
  52. <span>本次拜访店招</span>
  53. </div>
  54. </div>
  55. <div class="tipsRemark" v-if="shopSignChange == 1">
  56. <p>若历史照片拍摄不规范,请选择<span style="color: #81b337">更新门店照</span></p>
  57. <p>本次拜访店招会作为本店标准店招,未来每次拜访时校验</p>
  58. </div>
  59. <!-- </van-popup> -->
  60. </div>
  61. </el-dialog>
  62. <!-- <div class="AIVerifyErrMask">
  63. <van-popup v-model="vanPopup" @close="close" :close-on-click-overlay="false">
  64. <div class="title">图像识别结果</div>
  65. <div class="content">
  66. <div class="AIVerify">{{ contentMessage }}</div>
  67. <div class="uploadImg" @click="uploadImg" v-if="shopSignChange != 1">
  68. <div class="label"><span class="van-f-red">*</span>重新拍照上传</div>
  69. <div class="icon">
  70. <van-icon class="photo photos" name="photograph" size="22px" color="#969696" />
  71. </div>
  72. </div>
  73. </div>
  74. <div class="uploadBtn" v-if="shotsNum >= 3 && shopSignChange != 1">
  75. <div class="tips"><van-icon name="question-o" @click="openTips" />上传后会有何影响</div>
  76. <div class="confirmUpload" @click="confirmUpload">仍要上传</div>
  77. </div>
  78. <div class="uploadBtn" v-if="shopSignChange == 1">
  79. <div class="confirmUpload" @click="uploadImg">重新拍照</div>
  80. <div class="changeImage" @click="confirmUpload">更换门店照</div>
  81. </div>
  82. <div class="historyImage" v-if="shopSignChange == 1">
  83. <div class="initImage imageItem" v-if="imageAIVerifyData.createStoreUrl">
  84. <img
  85. :src="imageAIVerifyData.createStoreUrl"
  86. width="100px"
  87. height="100px"
  88. @click="previewsImg(imageAIVerifyData.createStoreUrl)" />
  89. <span>建店时店招</span>
  90. </div>
  91. <div class="newestImage imageItem" v-if="imageAIVerifyData.lastVisitUrl">
  92. <img
  93. :src="imageAIVerifyData.lastVisitUrl"
  94. width="100px"
  95. height="100px"
  96. @click="previewsImg(imageAIVerifyData.lastVisitUrl)" />
  97. <span>上次拜访店招</span>
  98. </div>
  99. <div class="presentImage imageItem" v-if="imageAIVerifyData.url">
  100. <img
  101. :src="imageAIVerifyData.url"
  102. width="100px"
  103. height="100px"
  104. @click="previewsImg(imageAIVerifyData.url)" />
  105. <span>本次拜访店招</span>
  106. </div>
  107. </div>
  108. <div class="tipsRemark" v-if="shopSignChange == 1">
  109. <p>若历史照片拍摄不规范,请选择<span style="color: #81b337">更新门店照</span></p>
  110. <p>本次拜访店招会作为本店标准店招,未来每次拜访时校验</p>
  111. </div>
  112. </van-popup>
  113. </div> -->
  114. </div>
  115. </template>
  116. <script>
  117. import store from '@/store';
  118. import { mapState } from 'vuex';
  119. export default {
  120. props: {
  121. imageAIVerifyFlag: {
  122. type: Boolean,
  123. default: false,
  124. },
  125. imageAIVerifyData: {
  126. type: [Array, Object],
  127. },
  128. source: {
  129. // 新建店还是门店拜访 visit/newCreated
  130. type: String,
  131. },
  132. },
  133. computed: {
  134. ...mapState({
  135. shotsNum: (state) => state.otheStore.shotsNum,
  136. }),
  137. },
  138. watch: {
  139. imageAIVerifyFlag: {
  140. handler(val) {
  141. console.log('imageAIVerifyFlag=' + val);
  142. if (val) this.initData();
  143. },
  144. immediate: true,
  145. },
  146. },
  147. data() {
  148. return {
  149. contentMessage: '', //提示内容
  150. vanPopup: true,
  151. shopSignChange: 0,
  152. };
  153. },
  154. methods: {
  155. initData() {
  156. // 图匠识别目的(1:店招内容识别,2:门店代码识别,3:调色机识别,4:更换店招)
  157. // shopSignChange 是否更换店招(0:未更换,1:更换) 1不一致,0一致
  158. // checkInfo 图片检查结果
  159. // cheatState 是否作弊(0:未作弊,1:作弊)
  160. // cheatType 作弊类型
  161. // qualifiedState 是否合格(0:不合格,1:合格)
  162. // unqualifiedReason 不合格原因
  163. console.log('imageAIVerifyData=' + JSON.stringify(this.imageAIVerifyData));
  164. let npkpiData =
  165. this.source == 'visit'
  166. ? this.imageAIVerifyData.npkpiData
  167. : this.imageAIVerifyData[0].npkpiData;
  168. // 照片和历史照片是否一致
  169. this.shopSignChange = npkpiData.shopSignChange;
  170. this.shopSignMatchList = npkpiData.shopSignMatchList;
  171. if (npkpiData.shopSignChange == 1) {
  172. this.contentMessage = '与历史照片不一致,请确认店招是否更换?';
  173. return;
  174. }
  175. // 照片是否合格
  176. if (npkpiData.checkInfo) {
  177. if (npkpiData.checkInfo.qualifiedState == 0) {
  178. // 失败次数增加超过三次特殊处理
  179. store.dispatch('setShotsNum', this.shotsNum + 1);
  180. // 不合格
  181. this.contentMessage = this.contentMessage + npkpiData.checkInfo.unqualifiedReason;
  182. if (npkpiData.checkInfo.cheatState == 1) {
  183. // 作弊
  184. this.contentMessage = this.contentMessage + npkpiData.checkInfo.cheatType;
  185. }
  186. } else {
  187. this.close();
  188. this.$emit('normalFlow', { data: this.imageAIVerifyData });
  189. }
  190. }
  191. },
  192. // 重新拍照
  193. uploadImg() {
  194. this.$emit('close');
  195. this.$emit('uploadImgFun');
  196. },
  197. // 仍要上传
  198. confirmUpload() {
  199. this.$emit('close');
  200. this.$emit('confirmUpload', { data: this.imageAIVerifyData });
  201. },
  202. close() {
  203. this.$emit('close');
  204. },
  205. openTips() {
  206. this.$dialog
  207. .confirm({
  208. title: '系统提示',
  209. message: '不规范的照片上传后会更换本店标准店招,未来每次拜访时校验。',
  210. showCancelButton: false,
  211. })
  212. .then(() => {});
  213. },
  214. previewsImg(url) {
  215. ImagePreview({
  216. images: [url],
  217. });
  218. },
  219. },
  220. };
  221. </script>
  222. <style lang="scss">
  223. .el-dialog__wrapper {
  224. z-index: 99999999;
  225. .imageAIVerifyErr {
  226. .AIVerifyErrMask {
  227. width: 90%;
  228. padding: 8px;
  229. border-radius: 8px;
  230. overflow: hidden;
  231. }
  232. .van-popup {
  233. width: 90%;
  234. padding: 8px;
  235. border-radius: 8px;
  236. overflow: hidden;
  237. }
  238. .van-f-red {
  239. color: red;
  240. width: 8px;
  241. display: inline-block;
  242. line-height: 26px;
  243. }
  244. .photo {
  245. /*margin-top: 9px;*/
  246. float: right;
  247. }
  248. .title {
  249. font-size: 16px;
  250. font-weight: 600;
  251. text-align: center;
  252. padding: 5px;
  253. }
  254. .content {
  255. border-top: 1px solid #ccc;
  256. .AIVerify {
  257. padding: 6px;
  258. font-size: 14px;
  259. color: red;
  260. text-align: center;
  261. border-bottom: 1px solid #ccc;
  262. }
  263. .uploadImg {
  264. display: flex;
  265. align-items: center;
  266. justify-content: space-between;
  267. .label {
  268. font-size: 14px;
  269. }
  270. }
  271. }
  272. .uploadBtn {
  273. border-top: 1px solid #ccc;
  274. display: flex;
  275. align-items: center;
  276. justify-content: space-between;
  277. padding: 8px 0;
  278. div {
  279. width: 40%;
  280. display: flex;
  281. justify-content: center;
  282. align-items: center;
  283. font-size: 14px;
  284. color: #fff;
  285. border-radius: 6px;
  286. }
  287. .tips {
  288. font-size: 14px;
  289. color: #e7e734;
  290. }
  291. .confirmUpload {
  292. background-color: red;
  293. padding: 8px 0;
  294. }
  295. .changeImage {
  296. background-color: #81b337;
  297. padding: 8px 0;
  298. }
  299. }
  300. .historyImage {
  301. display: flex;
  302. justify-content: space-between;
  303. .imageItem {
  304. width: 30%;
  305. display: flex;
  306. flex-direction: column;
  307. align-items: center;
  308. justify-content: center;
  309. span {
  310. font-size: 12px;
  311. }
  312. }
  313. }
  314. .tipsRemark {
  315. border-top: 1px solid #ccc;
  316. p {
  317. font-size: 12px;
  318. padding: 3px 0;
  319. }
  320. }
  321. }
  322. }
  323. </style>