fault-page.vue 8.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321
  1. <template>
  2. <div class="fault" v-if="faultDetails!=null">
  3. <div class="title-fault" >
  4. 产品名称:&nbsp;&nbsp;{{faultDetails.materialName}}
  5. </div>
  6. <div class="title-fault">
  7. 产品编码:&nbsp;&nbsp;{{faultDetails.materialCode}}
  8. </div>
  9. </div>
  10. <div class="mainContentBox">
  11. <avue-crud
  12. ref="crudRef"
  13. v-model:search="search"
  14. v-model="form"
  15. :data="data"
  16. :option="option"
  17. v-model:page="page"
  18. @row-save="createRow"
  19. @row-update="updateRow"
  20. @row-del="deleteRow"
  21. @search-change="searchChange"
  22. @search-reset="resetChange"
  23. @selection-change="selectionChange"
  24. >
  25. </avue-crud>
  26. </div>
  27. <div class="fault">
  28. <div class="image-title">图片</div>
  29. <div v-for="(image, index) in faultImg" :key="index" class="fault-image">
  30. <!-- 使用v-for循环渲染图片列表 -->
  31. <img :src="dictDataUtil.img_url+image.fileUrl" alt="图片" width="150px" class="fault-img">
  32. </div>
  33. </div>
  34. <div class="fault" v-if="faultDetails!=null">
  35. <div class="fault-detail" v-if="faultDetails.trackingNumber!=null">不合格审理单号 :&nbsp;&nbsp;{{faultDetails.trackingNumber}}</div>
  36. <div class="fault-detail" >序列号 :&nbsp;&nbsp;{{faultDetails.seqNo}}</div>
  37. <div class="fault-detail">故障描述 :&nbsp;&nbsp;{{faultDetails.remark}}</div>
  38. <div class="fault-detail" v-if="faultDetails.opinion!=null">线长意见 :&nbsp;&nbsp;{{faultDetails.opinion}}</div>
  39. <div class="title-fault" style="margin-top: 10px">
  40. 报故人:&nbsp;&nbsp;{{faultDetails.creator}}
  41. </div>
  42. <div class="title-fault" style="margin-top: 10px">
  43. 报故工位:&nbsp;&nbsp;{{faultDetails.stationName}}
  44. </div>
  45. <div class="title-fault" style="margin-top: 10px;margin-bottom: 10px">
  46. 报故数量:&nbsp;&nbsp;{{faultDetails.unqualifiedNum}}
  47. </div>
  48. <div class="title-fault" style="margin-top: 10px;margin-bottom: 10px" v-if="faultDetails.result!=undefined&&faultDetails.result!=null">
  49. 处理结果:&nbsp;&nbsp;{{faultDetails.result}}
  50. </div>
  51. </div>
  52. <div class="mainContentBox">
  53. <avue-crud
  54. ref="formRef"
  55. v-model="form"
  56. :data="data2"
  57. :option="option2"
  58. >
  59. <template #processInfo="{row,index,type}">
  60. <el-select v-model="value[row.$index]" placeholder="请选择" @click="getFaults(row)" @change="listData(row)">
  61. <el-option
  62. v-for="item in optionFault[row.$index]"
  63. :key="item.value"
  64. :label="item.operationName"
  65. :value="item.id"
  66. >
  67. </el-option>
  68. </el-select>
  69. </template>
  70. </avue-crud>
  71. </div>
  72. <div style="overflow: hidden">
  73. <div class="detail-footer">
  74. <el-button type="primary" @click="onHandle"> 确定 </el-button>
  75. <el-button @click="cancelWindow">取消</el-button>
  76. </div>
  77. </div>
  78. </template>
  79. <script setup>
  80. import { ref, getCurrentInstance } from "vue";
  81. import { useCrud } from "@/hooks/userCrud";
  82. import ButtonPermKeys from "@/common/configs/buttonPermission";
  83. import { useCommonStoreHook, useDictionaryStore } from "@/store";
  84. const { isShowTable, tableType } = toRefs(useCommonStoreHook());
  85. import {getFault,getFaultDetails,getSeqNoList,getProcessInfoList,rework} from "@/api/fault"
  86. import dictDataUtil from "@/common/configs/dictDataUtil";
  87. // 数据字典相关
  88. const { dicts } = useDictionaryStore();
  89. const test = () => {
  90. isShowTable.value = true;
  91. tableType.value = tableType.value == 1 ? 2 : 1;
  92. };
  93. const props = defineProps({
  94. faultId: {
  95. type: String,
  96. default: () => {
  97. return 0;
  98. }
  99. },
  100. dial:{
  101. type:Object,
  102. default:()=>{
  103. return {};
  104. }
  105. },
  106. workOrderCode: {
  107. type: String,
  108. default: () => {
  109. return 0;
  110. }
  111. },
  112. })
  113. // 传入一个url,后面不带/
  114. const { form, data, option, search, page, toDeleteIds, Methords, Utils } =
  115. useCrud({
  116. src: "/api/v1/process/escalationDefects",
  117. });
  118. const { dataNoPageList, createRow, updateRow, deleteRow, searchChange, resetChange } =
  119. Methords; //增删改查
  120. const { selectionChange, multipleDelete } = Methords; //选中和批量删除事件
  121. const { checkBtnPerm, downloadTemplate, exportData } = Utils; //按钮权限等工具
  122. // checkBtnPerm(ButtonPermKeys.PLAN.BTNS.order_add) :permission="permission"
  123. // const permission = reactive({
  124. // delBtn: checkPerm(buttonPermission.PLAN.BTNS.order_del),
  125. // addBtn: checkPerm(buttonPermission.PLAN.BTNS.order_add),
  126. // editBtn: checkPerm(buttonPermission.PLAN.BTNS.order_edit),
  127. // menu: true,
  128. // });
  129. const radio1=ref('repair');
  130. const crudRef = ref(null); //crudRef.value 获取avue-crud对象
  131. const router = useRouter();
  132. const formRef=ref(null);
  133. const data2=ref([]);
  134. const faultImg=ref(null);
  135. const formData=ref({});
  136. const formFault=ref({});
  137. const faultDetails=ref(null);
  138. const postDetail=ref([]);
  139. onMounted(() => {
  140. // console.log("crudRef", crudRef)
  141. search.value.escalationFaultId=props.faultId;
  142. dataNoPageList();
  143. formData.value.escalationFaultId=props.faultId;
  144. formFault.value.escalationFaultId=props.faultId;
  145. getFault(formData.value).then((data) => {
  146. faultImg.value=data.data;
  147. });
  148. getFaultDetails(props.faultId).then((data) => {
  149. faultDetails.value=data.data;
  150. for(let i=0;i<dicts.disposal_measures_type.length;i++){
  151. if(faultDetails.value.disposalMeasures===dicts.disposal_measures_type[i].dictValue){
  152. faultDetails.value.disposalMeasures=dicts.disposal_measures_type[i].dictLabel;
  153. }
  154. }
  155. });
  156. getSeqNoList(formFault.value).then((data) => {
  157. data2.value=data.data;
  158. for(let i=0;i<data2.value.length;i++){
  159. data2.value[i].$cellEdit=true;
  160. }
  161. postDetail.value=Array.from(data2.value);
  162. });
  163. });
  164. const listData=(row)=>{
  165. postDetail.value[row.$index].reworkProcessId=value.value[row.$index];
  166. postDetail.value[row.$index].workOrderCode=props.workOrderCode;
  167. for(let i=0;i<optionFault.value[row.$index].length;i++){
  168. if(value.value[row.$index]==optionFault.value[row.$index][i].id){
  169. postDetail.value[row.$index].reworkOperationName=optionFault.value[row.$index][i].operationName;
  170. }
  171. }
  172. console.info(postDetail.value[row.$index]);
  173. }
  174. const faultHandle=ref({});
  175. const onHandle=()=>{
  176. for(let i=0;i<postDetail.value.length;i++){
  177. if(undefined===postDetail.value[i].reworkProcessId){
  178. ElMessage({
  179. message:postDetail.value[i].seqNo+"没选择返工工序",
  180. type: "error",
  181. });
  182. return;
  183. }
  184. }
  185. faultHandle.value.reworkList=Array.from(postDetail.value);
  186. faultHandle.value.faultId=props.faultId;
  187. rework(faultHandle.value).then(
  188. (data)=> {
  189. if (data.code === "200") {
  190. ElMessage({
  191. message: data.msg,
  192. type: "success",
  193. });
  194. props.dial.visible = false;
  195. }
  196. else {
  197. ElMessage({
  198. message: data.msg,
  199. type: "error",
  200. });
  201. }
  202. }
  203. )
  204. }
  205. // 设置表格列或者其他自定义的option
  206. option.value = Object.assign(option.value, {
  207. addBtn: false,
  208. editBtn:false,
  209. delBtn:false,
  210. viewBtn:false,
  211. menu:false,
  212. column: [
  213. {
  214. label: "缺陷大类",
  215. prop: "bugType",
  216. dicData:dicts.defect_mana,
  217. props: { label: "dictLabel", value: "dictValue" },
  218. },
  219. {
  220. label: "缺陷小类",
  221. prop: "bugName",
  222. },
  223. ],
  224. });
  225. const optionFault=ref([]);
  226. const processFault=ref({});
  227. const getFaults=(row)=>{
  228. processFault.value.seqNo=row.seqNo;
  229. processFault.value.workOrderCode=props.workOrderCode;
  230. getProcessInfoList(processFault.value).then(
  231. (data)=>{
  232. optionFault.value[row.$index]=data.data;
  233. }
  234. )
  235. }
  236. const option2=ref(null);
  237. const value=ref([]);
  238. // 设置表格列或者其他自定义的option
  239. option2.value = {
  240. addBtn: false,
  241. editBtn:false,
  242. delBtn:false,
  243. viewBtn:false,
  244. submitBtn:false,
  245. emptyBtn:false,
  246. menu:false,
  247. slot:true,
  248. column: [
  249. {
  250. label: "跟踪卡号",
  251. prop: "seqNo",
  252. labelWidth:130,
  253. },
  254. {
  255. label: "返工工序",
  256. prop: "processInfo",
  257. labelWidth:130,
  258. type:"select",
  259. },
  260. ],
  261. };
  262. const cancelWindow=()=>{
  263. props.dial.visible=false;
  264. }
  265. </script>
  266. <style>
  267. .title-fault{
  268. float: left;
  269. width: 300px;
  270. }
  271. .fault{
  272. margin-left: 15px;
  273. margin-top: 10px;
  274. display: block;
  275. overflow: hidden;
  276. }
  277. .fault-image{
  278. width: 150px;
  279. float: left;
  280. margin-left: 10px;
  281. overflow: hidden;
  282. }
  283. .image-title{
  284. margin-bottom: 15px;
  285. }
  286. .fault-img{
  287. display: inline-block;
  288. }
  289. .fault-detail{
  290. margin-top: 20px;
  291. }
  292. .detail-footer{
  293. float: right;
  294. overflow: hidden;
  295. }
  296. </style>