gongdanziliao.vue 75 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057
  1. <template>
  2. <div>
  3. <layout>
  4. <layout-header>
  5. <div class="">
  6. <!--按钮部分-->
  7. <el-form ref="elSearchFormRef" class="demo-form-inline" :rules="searchRule" >
  8. <el-form-item>
  9. <el-input v-model="searchInfo" placeholder="搜索订单号" style="width: 180px;" @keyup.enter="handleSearch"></el-input>
  10. <el-button type="primary" icon="search" @click="onSubmit" title="搜索" ></el-button>
  11. <el-button type="primary" class="bt" icon="edit" @click="jsfjClick">技术附件</el-button>
  12. <el-button type="primary" icon="edit" @click="addgd_onclick" class="bt" title="新增工单资料">新增</el-button>
  13. <el-button type="primary" icon="edit" @click="addgdyj_onclick" class="bt" title="新增颜色资料">新增颜色资料</el-button>
  14. <el-button type="primary" icon="edit" @click="addgdgy_onclick" class="bt" title="新增工序资料" >新增工序资料</el-button>
  15. <el-button type="primary" icon="edit" @click="cp_gdprintonClick" class="bt" title="打印生产订单" >订单打印</el-button>
  16. </el-form-item>
  17. </el-form>
  18. </div>
  19. </layout-header>
  20. <layout>
  21. <!-- 左侧树形结构 -->
  22. <layout-sider :resize-directions="['right']" :width="190" style="margin-right: 10px;">
  23. <div class="JKWTree-tree" style="height: 200px">
  24. <h3>工单管理</h3>
  25. <el-tree :data="treeData" class="treecolor" @node-click="handleNodeClick"></el-tree>
  26. </div>
  27. </layout-sider>
  28. <!-- 右侧内容区域 -->
  29. <layout-content >
  30. <el-main>
  31. <!-- 工单表格列表 -->
  32. <div class="gva-table-box">
  33. <el-table ref="multipleTable"
  34. style="width: 100%;height: 28vh"
  35. :row-style="{ height: '20px' }"
  36. :cell-style="{ padding: '0px' }" :header-row-style="{ height: '20px' }"
  37. :header-cell-style="{ padding: '0px' }"
  38. border
  39. tooltip-effect="dark"
  40. :data="tableData" row-key="ID"
  41. @row-click="tableRowClick"
  42. highlight-current-row="true"
  43. :cell-class-name="tableDataCellClass"
  44. @row-dblclick="updateCompanyFunc"
  45. @selection-change="handleSelectionChange"
  46. :show-overflow-tooltip="true">
  47. <el-table-column align="center" type="selection" width="30"/>
  48. <el-table-column align="left" sortable label="序号" prop="序号" width="80" />
  49. <el-table-column align="left" sortable label="订单号" prop="订单号" width="100" />
  50. <el-table-column align="left" sortable label="生产款号" prop="生产款号" width="110" />
  51. <el-table-column align="left" sortable label="客户" prop="客户" width="80" />
  52. <el-table-column align="left" sortable label="落货日期" prop="落货日期" width="110" />
  53. <el-table-column align="left" sortable label="款式" prop="款式" width="80"/>
  54. <el-table-column align="left" sortable label="箱唛要求" prop="箱唛要求" width="110" />
  55. <el-table-column align="left" sortable label="面料" prop="面料" width="110" />
  56. <el-table-column align="left" sortable label="要求" prop="要求" width="110" />
  57. <el-table-column align="left" sortable label="船样描述" prop="船样描述" width="110" />
  58. <el-table-column align="left" sortable label="船样合计" prop="船样合计" width="140" />
  59. <el-table-column align="left" sortable label="粘衬" prop="粘衬" width="80" />
  60. <el-table-column align="left" sortable label="订单数量" prop="订单数量" width="110" />
  61. <el-table-column align="left" sortable label="单位" prop="单位" width="80" />
  62. <el-table-column align="left" sortable label="审核" prop="审核" width="80" />
  63. <el-table-column align="left" sortable label="审核日期" prop="审核日期" width="110" />
  64. </el-table>
  65. <!-- 分页 -->
  66. <div class="gva-pagination">
  67. <el-pagination
  68. @size-change="handleSizeChange"
  69. @current-change="handleCurrentChange"
  70. :current-page="page"
  71. :page-sizes="[10, 30, 50, 100]"
  72. layout="total, sizes, prev, pager, next, jumper"
  73. :total="total">
  74. </el-pagination>
  75. </div>
  76. </div>
  77. <!-- 颜色资料列表、工艺资料列表、BOM资料列表 -->
  78. <el-tabs v-model="activeName" @tab-click="handleClick">
  79. <el-tab-pane label="颜色资料" @click="showTable('颜色资料')" name="first">
  80. <el-table ref="multipleTable"
  81. :row-style="{ height: '20px' }"
  82. :cell-style="{ padding: '0px' }" :header-row-style="{ height: '20px' }"
  83. :header-cell-style="{ padding: '0px' }"
  84. :show-overflow-tooltip="true"
  85. highlight-current-row="true"
  86. @row-dblclick="ysupdateCompanyFunc"
  87. @selection-change="selectionChange($event, '颜色资料')"
  88. style="width: 100%;height: 36vh" border show-summary
  89. :summary-method="getSummaries" tooltip-effect="dark" :data="ystableData" row-key="ID">
  90. <el-table-column type="selection" width="55" />
  91. <el-table-column align="left" sortable label="序号" prop="序号" width="100"/>
  92. <el-table-column align="left" sortable label="订单子编号" prop="订单子编号" width="120"/>
  93. <el-table-column align="left" sortable label="颜色名称" prop="颜色名称" width="110"/>
  94. <el-table-column align="left" sortable label="船样" prop="船样" width="110"/>
  95. <el-table-column align="left" sortable label="S" prop="S" width="70"/>
  96. <el-table-column align="left" sortable label="M" prop="M" width="70"/>
  97. <el-table-column align="left" sortable label="L" prop="L" width="70"/>
  98. <el-table-column align="left" sortable label="XL" prop="XL" width="70"/>
  99. <el-table-column align="left" sortable label="XXL" prop="XXL" width="80"/>
  100. <el-table-column align="left" sortable label="制单总数" prop="制单总数" width="110"/>
  101. <el-table-column align="left" sortable label="建档用户" prop="建档用户" width="110"/>
  102. <el-table-column align="left" sortable label="建档时间" prop="建档时间" width="110"/>
  103. <el-table-column align="left" sortable label="更新时间" prop="更新时间" width="110"/>
  104. </el-table>
  105. </el-tab-pane>
  106. <el-tab-pane label="工艺资料" @click="showTable('工艺资料')" name="second">
  107. <el-table ref="multipleTable"
  108. :row-style="{ height: '20px' }"
  109. :cell-style="{ padding: '0px' }" :header-row-style="{ height: '20px' }"
  110. :header-cell-style="{ padding: '0px' }"
  111. highlight-current-row="true"
  112. :show-overflow-tooltip="true"
  113. size="small"
  114. :cell-class-name="gysatusCellClass"
  115. @row-dblclick="gdgyupdateCompanyFunc"
  116. @row-click="clickybupdate2"
  117. :row-class-name="rowClassStyle2"
  118. @selection-change="selectionChange($event, '工艺资料')"
  119. style="width: 100%;height: 36vh" border tooltip-effect="dark" :data="gytableData" row-key="ID">
  120. <el-table-column type="selection" width="30" />
  121. <el-table-column align="left" label="完工状态" prop="完工状态" width="75"/>
  122. <el-table-column align="left" label="工序名称" prop="工序名称" width="280"/>
  123. <el-table-column align="left" label="计划产量" prop="计划产量" width="80"/>
  124. <el-table-column align="left" label="建档用户" prop="建档用户" width="90"/>
  125. <el-table-column align="left" label="建档日期" prop="建档日期" width="150"/>
  126. <el-table-column align="left" label="更新时间" prop="更新时间" width="150"/>
  127. </el-table>
  128. </el-tab-pane>
  129. <el-tab-pane label="订单资料附件" @click="showTable('订单资料附件')" name="third">
  130. <el-table ref="multipleTable"
  131. :row-style="{ height: '20px' }"
  132. :cell-style="{ padding: '0px' }" :header-row-style="{ height: '20px' }"
  133. :header-cell-style="{ padding: '0px' }"
  134. :show-overflow-tooltip="true"
  135. :cell-class-name="planUsageCellClass"
  136. highlight-current-row="true"
  137. @row-dblclick="gdbomupdateCompanyFunc"
  138. style="width: 100%;height: 36vh" border tooltip-effect="dark" :data="ddtableData" row-key="ID" @selection-change="handleSelectionChange">
  139. <!-- <el-table-column type="selection" width="30" /> -->
  140. <el-table-column align="left" label="序号" prop="序号" width="70"/>
  141. <el-table-column align="left" label="备注" prop="备注" width="70"/>
  142. <el-table-column align="left" label="文件类型" prop="文件类型" width="90"/>
  143. <el-table-column align="left" label="关联产品" prop="关联产品" width="90"/>
  144. <el-table-column align="left" label="建档用户" prop="建档用户" width="90"/>
  145. <el-table-column align="left" label="建档时间" prop="建档时间" width="90"/>
  146. <el-table-column align="left" label="更新时间" prop="更新时间" width="90"/>
  147. <el-table-column align="left" label="操作" prop="操作" width="70" />
  148. </el-table>
  149. </el-tab-pane>
  150. <el-tab-pane label="技术附件" @click="showTable('技术附件')" name="fourth">
  151. <el-table ref="multipleTable"
  152. :row-style="{ height: '20px' }"
  153. :cell-style="{ padding: '0px' }" :header-row-style="{ height: '20px' }"
  154. :header-cell-style="{ padding: '0px' }"
  155. :show-overflow-tooltip="true"
  156. :cell-class-name="planUsageCellClass"
  157. highlight-current-row="true"
  158. @row-dblclick="ExcelShow"
  159. style="width: 100%;height: 36vh" border tooltip-effect="dark" :data="jstableData" row-key="ID" @selection-change="handleSelectionChange">
  160. <!-- <el-table-column type="selection" width="55" /> -->
  161. <el-table-column align="left" label="序号" prop="序号" width="70"/>
  162. <el-table-column align="left" label="备注" prop="备注" width="70"/>
  163. <el-table-column align="left" label="文件类型" prop="文件类型" width="90"/>
  164. <el-table-column align="left" label="关联产品" prop="关联产品" width="90"/>
  165. <el-table-column align="left" label="建档用户" prop="建档用户" width="90"/>
  166. <el-table-column align="left" label="建档时间" prop="建档时间" width="90"/>
  167. <el-table-column align="left" label="更新时间" prop="更新时间" width="90"/>
  168. <el-table-column fixed="right" label="操作" width="100">
  169. <!-- <template v-slot="{ row }">
  170. <button @click="jsfj_del(row)">删除</button>
  171. </template> -->
  172. </el-table-column>
  173. </el-table>
  174. </el-tab-pane>
  175. </el-tabs>
  176. <!-- 弹窗 -->
  177. <el-dialog v-model="dialogFormVisible" :before-close="edit_closeDialog" title="颜色资料修改" destroy-on-close style="width: 40%; height: 45%;">
  178. <el-row :gutter="24">
  179. <el-col :span="10">
  180. <el-form-item label="订单子编号:" prop="deliveryDate" class="mab" label-width="120px" style="">
  181. <el-input v-model="edit_formData['订单子编号']" style="width: 100%;" id="订单子编号:" />
  182. </el-form-item>
  183. </el-col>
  184. <el-col :span="10">
  185. <el-form-item label="颜色名称:" prop="deliveryDate" class="mab" label-width="120px" style="">
  186. <el-input v-model="edit_formData['颜色名称']" style="width: 100%;" id="颜色名称" />
  187. </el-form-item>
  188. </el-col>
  189. </el-row>
  190. <el-row :gutter="24" >
  191. <el-col :span="10">
  192. <el-form-item label="船样:" prop="deliveryDate" class="mab" label-width="120px" style="">
  193. <el-input v-model="edit_formData['船样']" style="width: 100%;" id="船样" />
  194. </el-form-item>
  195. </el-col>
  196. <el-col :span="10">
  197. <el-form-item label="S:" prop="deliveryDate" class="mab" label-width="120px" style="">
  198. <el-input v-model="edit_formData['S']" style="width: 100%; height: 40px;" id="S" />
  199. </el-form-item>
  200. </el-col>
  201. </el-row>
  202. <el-row :gutter="24">
  203. <el-col :span="10">
  204. <el-form-item label="M:" prop="deliveryDate" class="mab" label-width="120px" style="">
  205. <el-input v-model="edit_formData['M']" style="width: 100%; height: 40px;" id="M" />
  206. </el-form-item>
  207. </el-col>
  208. <el-col :span="10">
  209. <el-form-item label="L:" prop="deliveryDate" class="mab" label-width="120px" style="">
  210. <el-input v-model="edit_formData['L']" style="width: 100%; height: 40px;" id="L" />
  211. </el-form-item>
  212. </el-col>
  213. </el-row>
  214. <el-row :gutter="24" >
  215. <el-col :span="10">
  216. <el-form-item label="XL:" prop="deliveryDate" class="mab" label-width="120px" style="">
  217. <el-input v-model="edit_formData['XL']" style="width: 100%; height: 40px;" id="XL" />
  218. </el-form-item>
  219. </el-col>
  220. <el-col :span="10">
  221. <el-form-item label="XXL:" prop="deliveryDate" class="mab" label-width="120px" style="">
  222. <el-input v-model="edit_formData['XXL']" style="width: 100%; height: 40px;" id="XXL" />
  223. </el-form-item>
  224. </el-col>
  225. </el-row>
  226. <el-row :gutter="24" >
  227. <el-col :span="10">
  228. <el-form-item label="制单总数:" prop="deliveryDate" class="mab" label-width="120px" style=" ">
  229. <el-input v-model="edit_formData['制单总数']" style="width: 100%; height: 40px;" id="制单总数" />
  230. </el-form-item>
  231. </el-col>
  232. <el-col :span="10">
  233. <el-form-item label="建档用户:" prop="deliveryDate" class="mab" label-width="120px" style=" ">
  234. <el-input v-model="edit_formData['建档用户']" style="width: 100%; height: 40px;" id="建档用户" />
  235. </el-form-item>
  236. </el-col>
  237. </el-row>
  238. <el-row :gutter="24" >
  239. <el-col :span="10">
  240. <el-form-item label="建档时间:" prop="deliveryDate" class="mab" label-width="120px" style="">
  241. <el-input v-model="edit_formData['建档时间']" style="width: 100%; height: 40px;" id="建档时间" />
  242. </el-form-item>
  243. </el-col>
  244. <el-col :span="10">
  245. <el-form-item label="更新时间:" prop="deliveryDate" class="mab" label-width="120px" style="">
  246. <el-input v-model="edit_formData['更新时间']" style="width: 100%; height: 40px;" id="更新时间" />
  247. </el-form-item>
  248. </el-col>
  249. </el-row>
  250. <template #footer>
  251. <div class="dialog-footer">
  252. <el-button @click="edit_closeDialog">取消</el-button>
  253. <el-button type="primary" @click="edit_Dialog">确认</el-button>
  254. </div>
  255. </template>
  256. </el-dialog>
  257. <!-- 新增工单资料 -->
  258. <el-dialog v-model="add_gddialogFormVisible" :before-close="add_gdcloseDialog" style="width: 35%;margin: 50px auto" :title="'新增'" destroy-on-close>
  259. <el-row>
  260. <el-form :model="add_gdscgdformData" label-position="right" ref="elFormRef" :rules="rule" >
  261. <el-row :gutter="24" >
  262. <el-form-item label="订单号:" prop="customerCode" class="mab" label-width="90" >
  263. <el-input v-model="add_gdscgdformData['订单号']" style="width: 150px;" id="订单号" @keydown="add_gdzlent($event, '审核日期', '订单号', '订单编号')" />
  264. </el-form-item>
  265. <el-form-item label="订单编号:" prop="customerCode" class="mab" label-width="90">
  266. <el-input v-model="add_gdscgdformData['订单编号']" style="width: 150px;" id="订单编号" @keydown="add_gdzlent($event, '订单号', '订单编号', '生产款号')" />
  267. </el-form-item>
  268. </el-row>
  269. <el-row :gutter="24">
  270. <el-form-item label="生产款号:" prop="customerCode" class="mab" label-width="90">
  271. <el-input v-model="add_gdscgdformData['生产款号']" style="width: 150px;" id="生产款号" @keydown="add_gdzlent($event, '订单编号', '生产款号', '款式')"/>
  272. </el-form-item>
  273. <el-form-item label="款式:" prop="customerCode" class="mab" label-width="90">
  274. <el-input v-model="add_gdscgdformData['款式']" style="width: 150px;" id="款式" @keydown="add_gdzlent($event, '生产款号', '款式', '客户')"/>
  275. </el-form-item>
  276. </el-row>
  277. <el-row :gutter="24">
  278. <el-form-item label="客户:" prop="customerCode" class="mab" label-width="90">
  279. <el-input v-model="add_gdscgdformData['客户']" style="width: 150px;" id="客户" @keydown="add_gdzlent($event, '款式', '客户', '落货日期')"/>
  280. </el-form-item>
  281. <el-form-item label="落货日期:" prop="deliveryDate" class="mab" label-width="90">
  282. <el-date-picker v-model="add_gdscgdformData['落货日期']" type="date" style="width: 150px;" id="落货日期" @keydown="add_gdzlent($event, '客户', '落货日期', '面料')"/>
  283. </el-form-item>
  284. </el-row>
  285. <el-row :gutter="24">
  286. <el-form-item label="面料:" prop="customerCode" class="mab" label-width="90">
  287. <el-input v-model="add_gdscgdformData['面料']" style="width: 150px;" id="面料" @keydown="add_gdzlent($event, '落货日期', '面料', '要求')"/>
  288. <el-form-item label="要求:" prop="customerCode" class="mab" label-width="90">
  289. <el-input v-model="add_gdscgdformData['要求']" p style="width: 150px;" id="要求" @keydown="add_gdzlent($event, '面料', '要求', '船样描述')"/>
  290. </el-form-item>
  291. </el-form-item>
  292. </el-row>
  293. <el-row :gutter="24">
  294. <el-form-item label="船样描述:" prop="customerCode" class="mab" label-width="90">
  295. <el-input v-model="add_gdscgdformData['船样描述']" style="width: 150px;" id="船样描述" @keydown="add_gdzlent($event, '要求', '船样描述', '船样合计')"/>
  296. </el-form-item>
  297. <el-form-item label="船样合计:" prop="customerCode" class="mab" label-width="90">
  298. <el-input v-model="add_gdscgdformData['船样合计']" style="width: 150px;" id="船样合计" @keydown="add_gdzlent($event, '船样描述', '船样合计', '箱唛要求')"/>
  299. </el-form-item>
  300. </el-row>
  301. <el-row :gutter="24">
  302. <el-form-item label="箱唛要求:" prop="customerCode" class="mab" label-width="90">
  303. <el-input v-model="add_gdscgdformData['箱唛要求']" style="width: 150px;" id="箱唛要求" @keydown="add_gdzlent($event, '船样合计', '箱唛要求', '粘朴')"/>
  304. </el-form-item>
  305. <el-form-item label="粘朴:" prop="customerCode" class="mab" label-width="90">
  306. <el-input v-model="add_gdscgdformData['粘朴']" style="width: 150px;" id="粘朴" @keydown="add_gdzlent($event, '箱唛要求', '粘朴', '订单数量')"/>
  307. </el-form-item>
  308. </el-row>
  309. <el-row :gutter="24">
  310. <el-form-item label="订单数量:" prop="customerCode" class="mab" label-width="90">
  311. <el-input v-model="add_gdscgdformData['订单数量']" style="width: 150px;" id="订单数量" @keydown="add_gdzlent($event, '粘朴', '订单数量', '单位')"/>
  312. </el-form-item>
  313. <el-form-item label="单位:" prop="customerCode" class="mab" label-width="90">
  314. <el-input v-model="add_gdscgdformData['单位']" style="width: 150px;" id="单位" @keydown="add_gdzlent($event, '订单数量', '单位', '制单人')"/>
  315. </el-form-item>
  316. </el-row>
  317. <el-row :gutter="24">
  318. <el-form-item label="制单人:" prop="customerCode" class="mab" label-width="90">
  319. <el-input v-model="add_gdscgdformData['制单人']" style="width: 150px;" id="制单人" @keydown="add_gdzlent($event, '单位', '制单人', '制单日期')"/>
  320. </el-form-item>
  321. <el-form-item label="制单日期:" prop="deliveryDate" class="mab" label-width="90">
  322. <el-date-picker v-model="add_gdscgdformData['制单日期']" type="date" style="width: 150px;" id="制单日期" @keydown="add_gdzlent($event, '制单人', '制单日期', '审核人')"/>
  323. </el-form-item>
  324. </el-row>
  325. <el-row :gutter="24">
  326. <el-form-item label="审核人:" prop="customerCode" class="mab" label-width="90">
  327. <el-input v-model="add_gdscgdformData['审核人']" style="width: 150px;" id="审核人" @keydown="add_gdzlent($event, '制单日期', '审核人', '审核日期')"/>
  328. </el-form-item>
  329. <el-form-item label="审核日期:" prop="deliveryDate" class="mab" label-width="90">
  330. <el-date-picker v-model="add_gdscgdformData['审核日期']" type="date" style="width: 150px;" id="审核日期" @keydown="add_gdzlent($event, '审核人', '审核日期', '订单号')"/>
  331. </el-form-item>
  332. </el-row>
  333. </el-form>
  334. </el-row>
  335. <template #footer>
  336. <div class="dialog-footer" style="text-align: right;">
  337. <el-button @click="add_gdcloseDialog">取 消</el-button>
  338. <el-button type="primary" @click="add_gdenterDialog">确 定</el-button>
  339. </div>
  340. </template>
  341. </el-dialog>
  342. <!-- 新增颜色资料 -->
  343. <el-dialog v-model="add_gdyjdialogFormVisible" :before-close="add_gdyjcloseDialog" style="width: 45%;" :title="'新增颜色资料'" destroy-on-close>
  344. <el-form label-width="100px" :model="add_yjzlformdata">
  345. <div style="display: flex; gap: 0px;">
  346. <h3 style="color:red;font-size: 24px;margin:-5px 0px 8px 12px;">订单号&nbsp;&nbsp;&nbsp;{{_ddhval}}</h3>
  347. </div>
  348. <div style="display: flex; gap: 0px;">
  349. <el-form-item label="订单子编号:" class="mab" prop="keyOrder">
  350. <el-input v-model="add_yjzlformdata.ddzbh" style="width: 150px;" id="订单子编号" @keydown="add_gdzlent($event, 'zds9', '订单子编号', '颜色')"/>
  351. </el-form-item>
  352. <el-form-item label="颜色:" class="mab" prop="keyOrder">
  353. <el-input v-model="add_yjzlformdata.ys" style="width: 150px;" id="颜色" @keydown="add_gdzlent($event, '订单子编号', '颜色', '尺码规格')"/>
  354. </el-form-item>
  355. </div>
  356. <div style="display: flex; gap: 0px;">
  357. <el-form-item label="尺码规格:" prop="joinDate" >
  358. <el-select v-model="add_yjzlformdata.cmgg" style="width: 150px;" id="尺码规格" @keydown="add_gdzlent($event, '颜色', '尺码规格', '是否船样')">
  359. <el-option label="32~46" @click="cmhandleSizeChange('尺码数')"></el-option>
  360. <el-option label="S~XXL" @click="cmhandleSizeChange('尺码')"></el-option>
  361. </el-select>
  362. </el-form-item>
  363. <el-form-item label="是否船样:" prop="joinDate" >
  364. <el-select v-model="add_yjzlformdata.sfcy" style="width: 150px;" id="是否船样" @keydown="add_gdzlent($event, '尺码规格', '是否船样', 'zds1')">
  365. <el-option label="是" value="是"></el-option>
  366. <el-option label="否" value="否"></el-option>
  367. </el-select>
  368. </el-form-item>
  369. </div>
  370. <div style="display: flex; gap: 0px;">
  371. <el-form-item label="尺码:" class="mab" prop="keyOrder">
  372. <el-input v-model="cmformdata.cm1" readonly style="width: 80px;"/>
  373. <el-input v-model="cmformdata.cm2" readonly style="width: 80px;"/>
  374. <el-input v-model="cmformdata.cm3" readonly style="width: 80px;"/>
  375. <el-input v-model="cmformdata.cm4" readonly style="width: 80px;"/>
  376. <el-input v-model="cmformdata.cm5" readonly style="width: 80px;"/>
  377. <el-input v-model="cmformdata.cm6" readonly style="width: 80px;"/>
  378. <el-input v-model="cmformdata.cm7" readonly style="width: 80px;"/>
  379. <el-input v-model="cmformdata.cm8" readonly style="width: 80px;"/>
  380. <el-input v-model="cmformdata.cm9" readonly style="width: 80px;"/>
  381. </el-form-item>
  382. </div>
  383. <div style="display: flex; gap: 0px;">
  384. <el-form-item label="制单数:" class="mab" prop="keyOrder">
  385. <el-input v-model="zdsformdata.zds1" style="width: 80px;" id="zds1" @keydown="add_gdzlent($event, '是否船样', 'zds1', 'zds2')"/>
  386. <el-input v-model="zdsformdata.zds2" style="width: 80px;" id="zds2" @keydown="add_gdzlent($event, 'zds1', 'zds2', 'zds3')"/>
  387. <el-input v-model="zdsformdata.zds3" style="width: 80px;" id="zds3" @keydown="add_gdzlent($event, 'zds2', 'zds3', 'zds4')"/>
  388. <el-input v-model="zdsformdata.zds4" style="width: 80px;" id="zds4" @keydown="add_gdzlent($event, 'zds3', 'zds4', 'zds5')"/>
  389. <el-input v-model="zdsformdata.zds5" style="width: 80px;" id="zds5" @keydown="add_gdzlent($event, 'zds4', 'zds5', 'zds6')"/>
  390. <el-input v-model="zdsformdata.zds6" style="width: 80px;" id="zds6" @keydown="add_gdzlent($event, 'zds5', 'zds6', 'zds7')"/>
  391. <el-input v-model="zdsformdata.zds7" style="width: 80px;" id="zds7" @keydown="add_gdzlent($event, 'zds6', 'zds7', 'zds8')"/>
  392. <el-input v-model="zdsformdata.zds8" style="width: 80px;" id="zds8" @keydown="add_gdzlent($event, 'zds7', 'zds8', 'zds9')"/>
  393. <el-input v-model="zdsformdata.zds9" style="width: 80px;" id="zds9" @keydown="add_gdzlent($event, 'zds8', 'zds9', '订单子编号')"/>
  394. </el-form-item>
  395. </div>
  396. <!-- 图片 -->
  397. <div style="display: flex; gap: 0px;">
  398. <el-form-item label="上传图片:" prop="image" class="mab" label-width="100px">
  399. <el-upload
  400. action="#"
  401. list-type="picture-card"
  402. :auto-upload="false">
  403. <i slot="default" class="el-icon-plus"></i>
  404. <div slot="file" slot-scope="{file}">
  405. <img
  406. class="el-upload-list__item-thumbnail"
  407. :src="file.url" alt=""
  408. >
  409. <span class="el-upload-list__item-actions">
  410. <span
  411. class="el-upload-list__item-preview"
  412. @click="handlePictureCardPreview(file)"
  413. >
  414. <i class="el-icon-zoom-in"></i>
  415. </span>
  416. <span
  417. v-if="!disabled"
  418. class="el-upload-list__item-delete"
  419. @click="handleDownload(file)"
  420. >
  421. <i class="el-icon-download"></i>
  422. </span>
  423. <span
  424. v-if="!disabled"
  425. class="el-upload-list__item-delete"
  426. @click="handleRemove(file)"
  427. >
  428. <i class="el-icon-delete"></i>
  429. </span>
  430. </span>
  431. </div>
  432. </el-upload>
  433. </el-form-item>
  434. </div>
  435. </el-form>
  436. <template #footer>
  437. <div class="dialog-footer" style="text-align: right;">
  438. <el-button @click="add_dyjcloseDialog">取消</el-button>
  439. <el-button @click="add_gdyjenterDialog">确定</el-button>
  440. </div>
  441. </template>
  442. </el-dialog>
  443. <el-dialog :visible.sync="dialogVisible">
  444. <img width="100%" :src="dialogImageUrl" alt="">
  445. </el-dialog>
  446. <!-- 新增工序资料-->
  447. <el-dialog v-model="visible" :before-close="()=> visible = false" style="width: 20%;margin: 10% auto" :title="'新增工序资料'" destroy-on-close>
  448. <el-form>
  449. <div>
  450. <div style="display: flex; gap: 0px;">
  451. <h3 style="color:red;font-size: 24px;margin:0px 0px 0px 15px;">订单号&nbsp;&nbsp;&nbsp;{{_ddhval}}</h3>
  452. </div>
  453. <div style="display: flex; gap: 0px;">
  454. <el-form-item label="仓库出库:" class="mab" prop="isBanciSelected" label-width=" 100">
  455. <el-checkbox v-model="form['仓库出库']"></el-checkbox>
  456. </el-form-item>
  457. </div>
  458. <div style="display: flex; gap: 0px;">
  459. <el-form-item label="裁切:" class="mab" prop="isBanciSelected" label-width=" 100">
  460. <el-checkbox v-model="form['裁切']"></el-checkbox>
  461. </el-form-item>
  462. </div>
  463. <div style="display: flex; gap: 0px;">
  464. <el-form-item label="车缝:" class="mab" prop="isBanciSelected" label-width=" 100">
  465. <el-checkbox v-model="form['车缝']"></el-checkbox>
  466. </el-form-item>
  467. </div>
  468. <div style="display: flex; gap: 0px;">
  469. <el-form-item label="后道收样:" class="mab" prop="isBanciSelected" label-width=" 100">
  470. <el-checkbox v-model="form['后道收样']"></el-checkbox>
  471. </el-form-item>
  472. </div>
  473. <div style="display: flex; gap: 0px;">
  474. <el-form-item label="大烫:" class="mab" prop="isBanciSelected" label-width=" 100">
  475. <el-checkbox v-model="form['大烫']"></el-checkbox>
  476. </el-form-item>
  477. </div>
  478. <div style="display: flex; gap: 0px;">
  479. <el-form-item label="总检:" class="mab" prop="isBanciSelected" label-width=" 100">
  480. <el-checkbox v-model="form['总检']"></el-checkbox>
  481. </el-form-item>
  482. </div>
  483. <div style="display: flex; gap: 0px;">
  484. <el-form-item label="包装:" class="mab" prop="isBanciSelected" label-width=" 100">
  485. <el-checkbox v-model="form['包装']"></el-checkbox>
  486. </el-form-item>
  487. </div>
  488. </div>
  489. </el-form>
  490. <template #footer>
  491. <div class="dialog-footer" style="text-align: right;top: auto;">
  492. <el-button @click="add_gxcloseDialog">取 消</el-button>
  493. <el-button type="primary" @click="add_gxenterDialog">确 定</el-button>
  494. </div>
  495. </template>
  496. </el-dialog>
  497. <!-- 技术附件 -->
  498. <el-dialog v-model="jsfjdialogFormVisible" :before-close="jsfjcloseDialog" :title="产品技术附件资料" style="margin-top: 40px" height="500px" width="800px" destroy-on-close>
  499. <el-form :model="jsfjformdata" label-position="right" ref="elFormRef" :rules="rule" label-width="75px">
  500. <el-row :gutter="24">
  501. <el-col :span="6">
  502. <el-form-item label="关联编号:" prop="address" class="mab">
  503. <el-input v-model="jsfjformdata.关联编号" id="关联编号" />
  504. </el-form-item>
  505. </el-col>
  506. </el-row>
  507. <el-row :gutter="24">
  508. <el-col :span="24">
  509. <el-form-item label="附件备注:" prop="address" class="mab">
  510. <el-input v-model="jsfjformdata.附件备注" id="附件备注" />
  511. </el-form-item>
  512. </el-col>
  513. </el-row>
  514. <el-row :gutter="24">
  515. <el-col :span="6"></el-col>
  516. <el-col :span="12">
  517. <input style="font-size:16px;" type="file" @change="uploadExcel" >
  518. </el-col>
  519. <el-col :span="6">
  520. <el-button @click="yulan">预览</el-button>
  521. </el-col>
  522. </el-row>
  523. </el-form>
  524. <template #footer>
  525. <div class="dialog-footer">
  526. <el-button @click="jsfjcloseDialog">取 消</el-button>
  527. <el-button type="primary" @click="jsfjenterDialog">确 定</el-button>
  528. </div>
  529. </template>
  530. </el-dialog>
  531. <!-- 技术附件弹窗 -->
  532. <el-dialog v-model="luckyexcelVisible" :before-close="luckyexcelCloseDialog" width="100%" top="0vh">
  533. <div id="luckyexcel" style="width: 100%;height: 90vh;"></div>
  534. </el-dialog>
  535. </el-main>
  536. </layout-content>
  537. </layout>
  538. </layout>
  539. <PrintPage ref="printPageRef" />
  540. </div>
  541. </template>
  542. <script>
  543. //点击按钮显示下方表格
  544. export default {
  545. data() {
  546. return {
  547. currentTable: '', // 当前展示的表格
  548. activeName: 'first',
  549. // imageUrl: '', //新增颜色资料图片
  550. _ddhval:'',
  551. };
  552. },
  553. methods: {
  554. showTable(tableName) {
  555. this.currentTable = tableName;
  556. },
  557. showTableChange() {
  558. // 处理表格选中事件
  559. },
  560. // //新增颜色资料图片
  561. // handlePreview(file) {
  562. // const reader = new FileReader();
  563. // reader.onload = (e) => {
  564. // this.imageUrl = e.target.result; // 将选择显示在页面上
  565. // };
  566. // reader.readAsDataURL(file); // 将文件读为Data URL
  567. // return false; // 阻止文件的默认上传行为
  568. // },
  569. // 对列进行合算
  570. getSummaries(param) {
  571. const { columns, data } = param;
  572. const sums = [];
  573. columns.forEach((column, index) => {
  574. if (index === 0) {
  575. sums[index] = '合计';
  576. return;
  577. }
  578. const values = data.map(item => Number(item[column.property]));
  579. // 选择需要合算的列进行合算。
  580. if (column.property === 'S'||column.property === 'M'||column.property === 'L'||column.property === 'XL'||column.property === 'XXL'||column.property === '制单总数') {
  581. if (!values.every(value => isNaN(value))) {
  582. sums[index] = values.reduce((prev, curr) => {
  583. const value = Number(curr);
  584. if (!isNaN(value)) {
  585. return prev + curr;
  586. }else {
  587. return prev;
  588. }
  589. }, 0);
  590. sums[index] += '';
  591. } else {
  592. sums[index] = '---'
  593. }
  594. }
  595. });
  596. return sums;
  597. },
  598. }
  599. };
  600. </script>
  601. <script setup>
  602. // 全量引入格式化工具 请按需保留
  603. import $script from 'scriptjs'
  604. import $ from 'jquery';
  605. import LuckyExcel from 'luckyexcel';
  606. import { Layout, LayoutSider, LayoutContent } from '@arco-design/web-vue';
  607. import { ElMessage, ElMessageBox } from 'element-plus'
  608. import { ref, reactive, computed, nextTick, watch } from 'vue'
  609. import { useUserStore } from '@/pinia/modules/user'
  610. import { DataList,WorkList, gdzl_MachineList,PrintCodeList,getProductYjList, getProductZzList,
  611. U8workOrder, ProcessDetailEdit, PrintedEdit, PrintJobOrder,WorkOrderAdd,PrintDetailAdd,
  612. WorkOrderEdit, ReferenceWorkOrder,getOrderProcessLeft,ClientList,ProductCodeList,
  613. editGyWaste, U8DataCorrection, AccountingParameterEdit,ProcessCopy,
  614. ProductInformation, TestCoefficient, capacityList,getOrderProcessRight,
  615. DataCorrection, U8Trial, ProcessFlow, AccountingParameter,setProductStatus,
  616. getProduct, getProductGy, ProductInformationEdit, workOrderListDetail, editProduct, getOrderProcessCount, StatusEdit,
  617. PrintDetailDel, ProcessDetailDel,WorkOrderDetailCope,getGdAnnexTable,WorkOrderData,WorkOrderDel,
  618. gdAnnexAdd,
  619. gdAnnexDel,
  620. } from "@/api/yunyin/yunying";
  621. import PrintPage from './components/print.vue'
  622. import AddGongYi from './components/addGongYi.vue'
  623. defineOptions({name: 'Company'})
  624. const printPageRef = ref()
  625. const userStore = useUserStore()
  626. const _username = ref('')
  627. _username.value = userStore.userInfo.userName + '/' + userStore.userInfo.nickName
  628. // =========== 左侧树侧形结构 ===========
  629. const treeData = ref({})
  630. const tableData = reactive([])
  631. const _Gd_khdh = ref(null)
  632. const DataListdata = async () => {
  633. try {
  634. // const data = await Datalist();
  635. const data =
  636. [{
  637. label : '客户编号',
  638. children : [
  639. {label : 'DC-1'},
  640. {label : 'DC-2'},
  641. {label : 'DC-3'},
  642. {label : 'DC-4'},
  643. {label : 'DC-5'},
  644. {label : 'DC-6'},
  645. {label : 'DC-7'},
  646. {label : 'DC-8'},
  647. {label : 'DC-9'},
  648. {label : 'DC-10'},
  649. {label : 'DC-11'},
  650. {label : 'DC-12'},
  651. {label : 'DC-13'},
  652. {label : 'DC-14'},
  653. {label : 'DC-15'}
  654. ]
  655. }];
  656. treeData.value = data
  657. } catch (error) {
  658. console.error(error);
  659. }
  660. };
  661. DataListdata();
  662. //点击左侧树形获取编号
  663. const handleNodeClick = async (node) => {
  664. // 取消所有节点的颜色
  665. const allNodes = document.querySelectorAll('.treecolor .el-tree-node');
  666. allNodes.forEach(node => {
  667. node.querySelector('.el-tree-node__label').style.color = '';
  668. });
  669. // 获取点击的节点 给当前点击的节点改变颜色【红色】
  670. const clickedNodeId = node['$treeNodeId'];
  671. const clickedNode = document.querySelector(`.treecolor .el-tree-node[data-key="${clickedNodeId}"]`);
  672. if (clickedNode) {
  673. clickedNode.querySelector('.el-tree-node__label').style.color = 'red';
  674. }
  675. searchInfo.value = '';
  676. if (node.label === '客户编号') {
  677. // console.log('点击了客户编号')
  678. }else{
  679. _Gd_khdh.value = 'J0031';
  680. _WorkList_page();
  681. }
  682. };
  683. //调用工单资料接口
  684. const _WorkList_page = async () => {
  685. console.log(_Gd_khdh.value)
  686. try {
  687. const WorkListdata = [
  688. {
  689. '序号':'1',
  690. '订单号':'2408001',
  691. '生产款号':'2401-1622款',
  692. '客户':'DC-7',
  693. '落货日期':'2024/7/20',
  694. '款式':'连衣裙',
  695. '箱唛要求':'折箱装修',
  696. '面料':'面布:乱麻复合布;拼布:AZ666雪纺…',
  697. '要求':'',
  698. '船样描述':'',
  699. '船样合计':'4',
  700. '粘衬':'',
  701. '订单数量':'174',
  702. '单位':'件',
  703. '审核':'裘志江',
  704. '审核日期':'2024/6/27'
  705. },
  706. {
  707. '序号':'2',
  708. '订单号':'2408002',
  709. '生产款号':'2403-1624款',
  710. '客户':'DC-7',
  711. '落货日期':'2024/7/20',
  712. '款式':'西服',
  713. '箱唛要求':'挂装出运',
  714. '面料':'面布:乱麻复合布;拼布:AZ666雪纺…',
  715. '要求':'',
  716. '船样描述':'',
  717. '船样合计':'5',
  718. '粘衬':'',
  719. '订单数量':'185',
  720. '单位':'件',
  721. '审核':'裘志江',
  722. '审核日期':'2024/6/27'
  723. },
  724. {
  725. '序号':'3',
  726. '订单号':'2408003',
  727. '生产款号':'2403-1625款',
  728. '客户':'DC-7',
  729. '落货日期':'2024/7/20',
  730. '款式':'裤子',
  731. '箱唛要求':'挂装出运',
  732. '面料':'面布:乱麻复合布;拼布:AZ666雪纺…',
  733. '要求':'',
  734. '船样描述':'',
  735. '船样合计':'5',
  736. '粘衬':'',
  737. '订单数量':'197',
  738. '单位':'件',
  739. '审核':'裘志江',
  740. '审核日期':'2024/6/27'
  741. },
  742. ];
  743. console.log("上方表格数据")
  744. console.log(WorkListdata)
  745. tableData.splice(0,tableData.length,...WorkListdata);//表格数据
  746. // total.value =WorkListdata.data.total;//共多少条
  747. } catch (error) {
  748. console.error(error);
  749. }
  750. };
  751. //双击修改颜色资料
  752. const dialogFormVisible = ref(false)
  753. const edit_formData = ref({})
  754. const ysupdateCompanyFunc = async (row) => {
  755. console.log(row)
  756. dialogFormVisible.value = true;
  757. Object.assign(edit_formData.value,row);
  758. };
  759. // 修改确认
  760. const edit_Dialog = async (row) => {
  761. dialogFormVisible.value = false;
  762. };
  763. // 修改取消
  764. const edit_closeDialog = async (row) => {
  765. dialogFormVisible.value = false;
  766. };
  767. // 分页
  768. const page = ref(1)
  769. const total = ref(0)
  770. const pageSize = ref(50)
  771. const handleCurrentChange = (val) => {
  772. page.value = val;
  773. _WorkList_page();
  774. };
  775. // 修改页面容量 点击多少条/页
  776. const handleSizeChange = (val) => {
  777. // page.value = 10;
  778. pageSize.value = val;
  779. _WorkList_page();
  780. };
  781. // =========== 新增 ===========
  782. const add_gddialogFormVisible = ref(false)
  783. // 获取当前日期
  784. const today = new Date();
  785. const year = today.getFullYear();
  786. const month = String(today.getMonth() + 1).padStart(2, '0'); // 月份从 0 开始,需要补零
  787. const day = String(today.getDate()).padStart(2, '0');
  788. const hours = String(today.getHours()).padStart(2, '0');
  789. const minutes = String(today.getMinutes()).padStart(2, '0');
  790. const seconds = String(today.getSeconds()).padStart(2, '0');
  791. const currentDate = `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`;
  792. const add_gdscgdformData = reactive({
  793. 订单编号: '',
  794. 生产款号: '',
  795. 款式: '',
  796. 客户: '',
  797. 落货日期: '',
  798. 箱唛要求: '',
  799. 面料: '',
  800. 要求: '',
  801. 船样描述: '',
  802. 船样合计: '',
  803. 粘朴: '',
  804. 订单数量: '',
  805. 单位: '',
  806. 制单人: '',
  807. 制单日期: '',
  808. 审核人: '',
  809. 审核日期: '',
  810. });
  811. //清空对象的属性值
  812. const gd_clearFormData = () => {
  813. Object.keys(add_gdscgdformData).forEach(key => {
  814. add_gdscgdformData[key] = '';
  815. });
  816. };
  817. //新增按钮
  818. const addgd_onclick = () => {
  819. add_gddialogFormVisible.value = true
  820. add_gdscgdformData['订单号'] = '';
  821. add_gdscgdformData['落货日期'] = currentDate;
  822. add_gdscgdformData['制单日期'] = currentDate;
  823. add_gdscgdformData['审核日期'] = currentDate;
  824. }
  825. //新增工单资料确定
  826. const add_gdenterDialog = async ()=>{
  827. if(add_gdscgdformData['订单编号'] === '' || add_gdscgdformData['订单编号'] === undefined){
  828. ElMessage({type: 'warning',message: '订单编号不能为空' })
  829. return false;
  830. }
  831. console.log("新增工单资料确定")
  832. console.log(add_gdscgdformData)
  833. const formattedData = {
  834. ddbh: add_gdscgdformData['订单编号'],
  835. sckh: add_gdscgdformData['生产款号'],
  836. khmc: add_gdscgdformData['款式'],
  837. khdh: add_gdscgdformData['客户'],
  838. cpdh: add_gdscgdformData['落货日期'],
  839. cpmc: add_gdscgdformData['箱唛要求'],
  840. ddsl: add_gdscgdformData['面料'],
  841. tll: add_gdscgdformData['要求'],
  842. jhtl: add_gdscgdformData['船样描述'],
  843. sjtl: add_gdscgdformData['船样合计'],
  844. jldw: add_gdscgdformData['粘朴'],
  845. tldx: add_gdscgdformData['订单数量'],
  846. xsddh: add_gdscgdformData['单位'],
  847. jymb: add_gdscgdformData['制单人'],
  848. bbh: add_gdscgdformData['制单日期'],
  849. erp: add_gdscgdformData['审核人'],
  850. ymsl: add_gdscgdformData['审核日期']
  851. };
  852. console.log(formattedData)
  853. // const edit_gdformdata_list = await 新增工单接口(formattedData);
  854. // if (edit_gdformdata_list.code === 0) {
  855. // add_gddialogFormVisible.value = false;
  856. // ElMessage({type: 'success',message: '新增成功'})
  857. // } else {
  858. // ElMessage({ type: 'error',message: '新增失败'})
  859. // }
  860. }
  861. //新增工单资料取消
  862. const add_gdcloseDialog = () => {
  863. add_gddialogFormVisible.value = false
  864. }
  865. // =========== 新增颜色资料 ===========
  866. //默认弹窗关闭
  867. const add_gdyjdialogFormVisible = ref(false)
  868. const add_yjzlformdata = reactive({
  869. ddh: '',
  870. ddzbh: '',
  871. ys: '',
  872. cmgg: '',
  873. sfcy: '',
  874. });
  875. const cmformdata = reactive({
  876. cm1:'32',
  877. cm2:'34',
  878. cm3:'36',
  879. cm4:'38',
  880. cm5:'40',
  881. cm6:'42',
  882. cm7:'44',
  883. cm8:'46',
  884. cm9:'总计',
  885. });
  886. const zdsformdata = reactive({
  887. zds1:'',
  888. zds2:'',
  889. zds3:'',
  890. zds4:'',
  891. zds5:'',
  892. zds6:'',
  893. zds7:'',
  894. zds8:'',
  895. zds9:'',
  896. });
  897. const cmhandleSizeChange = (value) => {
  898. // console.log(value)
  899. if (value === '尺码数') {
  900. cmformdata.cm1 = '32';
  901. cmformdata.cm2 = '34';
  902. cmformdata.cm3 = '36';
  903. cmformdata.cm4 = '38';
  904. cmformdata.cm5 = '40';
  905. cmformdata.cm6 = '42';
  906. cmformdata.cm7 = '44';
  907. cmformdata.cm8 = '46';
  908. cmformdata.cm9 = '总计';
  909. } else if (value === '尺码') {
  910. cmformdata.cm1 = 'S';
  911. cmformdata.cm2 = 'M';
  912. cmformdata.cm3 = 'L';
  913. cmformdata.cm4 = 'XL';
  914. cmformdata.cm5 = 'XXL';
  915. cmformdata.cm6 = '';
  916. cmformdata.cm7 = '';
  917. cmformdata.cm8 = '';
  918. cmformdata.cm9 = '总计';
  919. }
  920. };
  921. //清空对象的属性值
  922. const gdyj_clearFormData = () => {
  923. Object.keys(zdsformdata).forEach(key => {
  924. zdsformdata[key] = '';
  925. });
  926. add_yjzlformdata['ddh'] = _Gd_gdbh.value;
  927. add_yjzlformdata['ddzbh'] = '';
  928. add_yjzlformdata['ys'] = '';
  929. add_yjzlformdata['cmgg'] = '32~46';
  930. add_yjzlformdata['sfcy'] = '是';
  931. };
  932. //新增颜色资料按钮
  933. const addgdyj_onclick = () => {
  934. if(_Gd_gdbh.value === '' || _Gd_gdbh.value === null){
  935. ElMessage({type: 'warning',message: '请选择具体的工单后,再操作此功能'})
  936. return false;
  937. }else{
  938. add_gdyjdialogFormVisible.value = true
  939. gdyj_clearFormData();
  940. }
  941. }
  942. const dialogImageUrl = ref('')
  943. const dialogVisible = ref(false)
  944. const disabled = ref(false)
  945. const file =ref('')
  946. //新增颜色资料图片
  947. const handleRemove = (file) => {
  948. console.log(file);
  949. };
  950. const handlePictureCardPreview = (file) => {
  951. this.dialogImageUrl = file.url;
  952. this.dialogVisible = true;
  953. };
  954. const handleDownload = (file) => {
  955. console.log(file);
  956. };
  957. // const beforeUpload = (file) => {
  958. // return false; // 阻止自动上传
  959. // };
  960. // return {
  961. // fileList, // 注意:这里并没有直接使用 fileList,因为 el-upload 组件有自己的 file-list 属性
  962. // handleFileChange,
  963. // beforeUpload,
  964. // };
  965. // const handleSuccess = (response, file, fileList) => {
  966. // // 假设服务器返回了图片的URL
  967. // imageUrl.value = response.imageUrl; // 根据实际服务器响应调整
  968. // // 可以在这里做其他处理,比如更新表单数据等
  969. // }
  970. //新增颜色资料确定
  971. const add_gdyjenterDialog = async () => {
  972. console.log(previewFiles);
  973. // return false;
  974. // console.log(zdsformdata)
  975. const addyszltable = {
  976. 订单子编号: add_yjzlformdata['ddzbh'],
  977. 颜色: add_yjzlformdata['ys'],
  978. 尺码规格: add_yjzlformdata['cmgg'],
  979. 是否船样: add_yjzlformdata['sfcy'],
  980. 尺码1: zdsformdata['zds1'],
  981. 尺码2: zdsformdata['zds2'],
  982. 尺码3: zdsformdata['zds3'],
  983. 尺码4: zdsformdata['zds4'],
  984. 尺码5: zdsformdata['zds5'],
  985. 尺码6: zdsformdata['zds6'],
  986. 尺码7: zdsformdata['zds7'],
  987. 尺码8: zdsformdata['zds8'],
  988. 合计: zdsformdata['zds9'],
  989. 图片:previewFiles['value']['0']['name']
  990. };
  991. console.log(addyszltable)
  992. }
  993. //新增颜色资料取消
  994. const add_dyjcloseDialog = () => {
  995. add_gdyjdialogFormVisible.value = false
  996. }
  997. //新增工单资料弹窗 键盘input框跳转
  998. const add_gdzlent = async (event,id1,id2,id3,idx) => {
  999. if(event.keyCode === 40){
  1000. if(id3!=''){
  1001. document.getElementById(id3).focus()
  1002. }
  1003. }else if (event.keyCode === 13) { // Enter 或向下箭头
  1004. if(id3!=''){
  1005. document.getElementById(id3).focus()
  1006. }
  1007. } else if (event.keyCode === 38) { // 向上箭头
  1008. if(id1!=''){
  1009. document.getElementById(id1).focus()
  1010. }
  1011. }else if (event.keyCode === 8) { // 删除箭头
  1012. if(id1!='' && document.getElementById(id2).value==''){
  1013. document.getElementById(id1).focus()
  1014. }
  1015. }else if (event.keyCode === 37) { // 向左箭头
  1016. if(id1!='' && document.getElementById(id2).selectionStart==0){
  1017. document.getElementById(id1).focus()
  1018. }
  1019. }else if (event.keyCode === 39) { // 向右箭头
  1020. if(id3!='' && document.getElementById(id2).selectionStart == document.getElementById(id2).value.length){
  1021. document.getElementById(id3).focus()
  1022. }
  1023. }
  1024. }
  1025. // =========== 新增工序资料 ===========
  1026. const visible = ref(false)
  1027. const form = reactive({
  1028. '仓库出库':true,
  1029. '裁切':true,
  1030. '车缝':true,
  1031. '后道收样':true,
  1032. '大烫':true,
  1033. '总检':true,
  1034. '包装':true,
  1035. })
  1036. //新增工序资料按钮
  1037. const addgdgy_onclick = () => {
  1038. if(_Gd_gdbh.value === '' || _Gd_gdbh.value === null){
  1039. ElMessage({type: 'warning',message: '请选择具体的工单后,再操作此功能'})
  1040. return false;
  1041. }else{
  1042. visible.value = true;
  1043. }
  1044. }
  1045. //新增工序资料确定按钮
  1046. const add_gxenterDialog = () => {
  1047. console.log(form)
  1048. const formattedData = {
  1049. ckck: form['仓库出库'],
  1050. cq: form['裁切'],
  1051. cf: form['车缝'],
  1052. hdsy: form['后道收样'],
  1053. dt: form['大烫'],
  1054. zj: form['总检'],
  1055. bz: form['包装']
  1056. };
  1057. // true 选择 fasle 未选择
  1058. for (let key in formattedData) {
  1059. if (formattedData[key] === true) {
  1060. formattedData[key] = 1;
  1061. } else if (formattedData[key] === false) {
  1062. formattedData[key] = 2;
  1063. }
  1064. }
  1065. console.log(formattedData)
  1066. //1.2新增工序资接口
  1067. // const add_gxformdata_list = await 新增工序资料(formattedData);
  1068. // if (edit_gxformdata_list.code === 0) {
  1069. // visible.value = false;
  1070. // ElMessage({type: 'success',message: '新增成功'})
  1071. // } else {
  1072. // ElMessage({ type: 'error',message: '新增失败'})
  1073. // }
  1074. }
  1075. //新增工序资料取消按钮
  1076. const add_gxcloseDialog = () => {
  1077. visible.value = false;
  1078. }
  1079. // =========== 订单打印 ===========
  1080. const cp_gdprintonClick = () => {
  1081. if(_Gd_gdbh.value === '' || _Gd_gdbh.value === null){
  1082. ElMessage({type: 'warning',message: '请选择具体的工单后,再操作此功能'})
  1083. return false;
  1084. }else{
  1085. printPageRef.value.open(_Gd_gdbh.value)
  1086. }
  1087. }
  1088. //点击表格行获取下方表格数据列表
  1089. // =========== 颜色资料、工艺资料、技术资料附件 ===========
  1090. //全局调用订单号编号
  1091. const _Gd_gdbh = ref('')
  1092. const _ddhval = ref('')
  1093. //颜色资料
  1094. const ystableData = reactive([])
  1095. //工艺资料
  1096. const gytableData = reactive([])
  1097. //订单资料表
  1098. const ddtableData = reactive([])
  1099. //技术附件
  1100. const jstableData = reactive([])
  1101. // 点击工单行按钮
  1102. const tableRowClick = async (row) => {
  1103. console.log(row.订单号)
  1104. _Gd_gdbh.value = row.订单号
  1105. _ddhval.value = row.订单号
  1106. if(row.订单号 === '2408001' ){
  1107. ystableData.length = 0
  1108. try {
  1109. const ysData = [
  1110. {
  1111. '序号':'1',
  1112. '订单子编号':'2408001-1',
  1113. '颜色名称':'红色',
  1114. '船样':'否',
  1115. 'S':'10',
  1116. 'M':'20',
  1117. 'L':'30',
  1118. 'XL':'20',
  1119. 'XXL':'10',
  1120. '制单总数':'90',
  1121. '建档用户':'',
  1122. '建档日期':'',
  1123. '更新时间':'',
  1124. },
  1125. {
  1126. '序号':'2',
  1127. '订单子编号':'2408001-2',
  1128. '颜色名称':'蓝色',
  1129. '船样':'否',
  1130. 'S':'20',
  1131. 'M':'20',
  1132. 'L':'10',
  1133. 'XL':'20',
  1134. 'XXL':'10',
  1135. '制单总数':'80',
  1136. '建档用户':'',
  1137. '建档日期':'',
  1138. '更新时间':'',
  1139. },
  1140. {
  1141. '序号':'3',
  1142. '订单子编号':'2408001-船',
  1143. '颜色名称':'黑色',
  1144. '船样':'是',
  1145. 'S':'/',
  1146. 'M':'2',
  1147. 'L':'/',
  1148. 'XL':'2',
  1149. 'XXL':'/',
  1150. '制单总数':'2',
  1151. '建档用户':'',
  1152. '建档日期':'',
  1153. '更新时间':'',
  1154. },
  1155. ];
  1156. //工艺资料表
  1157. const gyData = [
  1158. {
  1159. '完工状态':'',
  1160. '工序名称':'仓库出库',
  1161. '计划产量':'/',
  1162. '建档用户':'',
  1163. '建档日期':'',
  1164. '更新时间':'',
  1165. },
  1166. {
  1167. '完工状态':'',
  1168. '工序名称':'裁切',
  1169. '计划产量':'按颜色显示总计数',
  1170. '建档用户':'',
  1171. '建档日期':'',
  1172. '更新时间':'',
  1173. },
  1174. {
  1175. '完工状态':'',
  1176. '工序名称':'车缝',
  1177. '计划产量':'按颜色显示总计数',
  1178. '建档用户':'',
  1179. '建档日期':'',
  1180. '更新时间':'',
  1181. },
  1182. {
  1183. '完工状态':'',
  1184. '工序名称':'后道收样',
  1185. '计划产量':'按颜色显示总计数',
  1186. '建档用户':'',
  1187. '建档日期':'',
  1188. '更新时间':'',
  1189. },
  1190. {
  1191. '完工状态':'',
  1192. '工序名称':'大烫',
  1193. '计划产量':'按颜色显示总计数',
  1194. '建档用户':'',
  1195. '建档日期':'',
  1196. '更新时间':'',
  1197. },
  1198. {
  1199. '完工状态':'',
  1200. '工序名称':'总检',
  1201. '计划产量':'按颜色显示总计数',
  1202. '建档用户':'',
  1203. '建档日期':'',
  1204. '更新时间':'',
  1205. },
  1206. {
  1207. '完工状态':'',
  1208. '工序名称':'包装',
  1209. '计划产量':'按颜色显示总计数',
  1210. '建档用户':'',
  1211. '建档日期':'',
  1212. '更新时间':'',
  1213. }
  1214. ];
  1215. //订单资料表
  1216. const ddData = [
  1217. {
  1218. '序号':'1',
  1219. '备注':'',
  1220. '文件类型':'',
  1221. '关联产品':'',
  1222. '建档日期':'',
  1223. '更新时间':'',
  1224. '建档用户':'',
  1225. '建档日期':'',
  1226. '更新时间':'',
  1227. '操作':'',
  1228. },
  1229. {
  1230. '序号':'2',
  1231. '备注':'',
  1232. '文件类型':'',
  1233. '关联产品':'',
  1234. '建档日期':'',
  1235. '更新时间':'',
  1236. '建档用户':'',
  1237. '建档日期':'',
  1238. '更新时间':'',
  1239. '操作':'',
  1240. },
  1241. ];
  1242. //技术附件
  1243. const jsData = [
  1244. {
  1245. '序号':'1',
  1246. '备注':'',
  1247. '文件类型':'',
  1248. '关联产品':'',
  1249. '建档日期':'',
  1250. '更新时间':'',
  1251. '建档用户':'',
  1252. '建档日期':'',
  1253. '更新时间':'',
  1254. '操作':'',
  1255. },
  1256. {
  1257. '序号':'2',
  1258. '备注':'',
  1259. '文件类型':'',
  1260. '关联产品':'',
  1261. '建档日期':'',
  1262. '更新时间':'',
  1263. '建档用户':'',
  1264. '建档日期':'',
  1265. '更新时间':'',
  1266. '操作':'',
  1267. },
  1268. ];
  1269. // console.log("下方表格数据")
  1270. // console.log(ysData)
  1271. // console.log(gyData)
  1272. // console.log(ddData)
  1273. // console.log(jsData)
  1274. ystableData.splice(0,ysData.length,...ysData);//表格数据
  1275. gytableData.splice(0,gyData.length,...gyData);//表格数据
  1276. ddtableData.splice(0,ddData.length,...ddData);//表格数据
  1277. jstableData.splice(0,jsData.length,...jsData);//表格数据
  1278. // console.log(ystableData)
  1279. } catch (error) {
  1280. console.error(error);
  1281. }
  1282. }else if(row.订单号 === '2408002' ){
  1283. ystableData.length = 0
  1284. try {
  1285. const ysData = [
  1286. {
  1287. '序号':'1',
  1288. '订单子编号':'2408002-2',
  1289. '颜色名称':'白色',
  1290. '船样':'否',
  1291. 'S':'10',
  1292. 'M':'20',
  1293. 'L':'30',
  1294. 'XL':'20',
  1295. 'XXL':'10',
  1296. '制单总数':'90',
  1297. '建档用户':'',
  1298. '建档日期':'',
  1299. '更新时间':'',
  1300. },
  1301. ];
  1302. //工艺资料表
  1303. const gyData = [
  1304. {
  1305. '完工状态':'',
  1306. '工序名称':'仓库出库',
  1307. '计划产量':'/',
  1308. '建档用户':'',
  1309. '建档日期':'',
  1310. '更新时间':'',
  1311. },
  1312. {
  1313. '完工状态':'',
  1314. '工序名称':'裁切',
  1315. '计划产量':'按颜色显示总计数',
  1316. '建档用户':'',
  1317. '建档日期':'',
  1318. '更新时间':'',
  1319. },
  1320. {
  1321. '完工状态':'',
  1322. '工序名称':'车缝',
  1323. '计划产量':'按颜色显示总计数',
  1324. '建档用户':'',
  1325. '建档日期':'',
  1326. '更新时间':'',
  1327. },
  1328. {
  1329. '完工状态':'',
  1330. '工序名称':'后道收样',
  1331. '计划产量':'按颜色显示总计数',
  1332. '建档用户':'',
  1333. '建档日期':'',
  1334. '更新时间':'',
  1335. },
  1336. {
  1337. '完工状态':'',
  1338. '工序名称':'大烫',
  1339. '计划产量':'按颜色显示总计数',
  1340. '建档用户':'',
  1341. '建档日期':'',
  1342. '更新时间':'',
  1343. },
  1344. {
  1345. '完工状态':'',
  1346. '工序名称':'总检',
  1347. '计划产量':'按颜色显示总计数',
  1348. '建档用户':'',
  1349. '建档日期':'',
  1350. '更新时间':'',
  1351. },
  1352. {
  1353. '完工状态':'',
  1354. '工序名称':'包装',
  1355. '计划产量':'按颜色显示总计数',
  1356. '建档用户':'',
  1357. '建档日期':'',
  1358. '更新时间':'',
  1359. }
  1360. ];
  1361. //订单资料表
  1362. const ddData = [
  1363. {
  1364. '序号':'1',
  1365. '备注':'',
  1366. '文件类型':'',
  1367. '关联产品':'',
  1368. '建档日期':'',
  1369. '更新时间':'',
  1370. '建档用户':'',
  1371. '建档日期':'',
  1372. '更新时间':'',
  1373. '操作':'',
  1374. },
  1375. {
  1376. '序号':'2',
  1377. '备注':'',
  1378. '文件类型':'',
  1379. '关联产品':'',
  1380. '建档日期':'',
  1381. '更新时间':'',
  1382. '建档用户':'',
  1383. '建档日期':'',
  1384. '更新时间':'',
  1385. '操作':'',
  1386. },
  1387. ];
  1388. //技术附件
  1389. const jsData = [
  1390. {
  1391. '序号':'1',
  1392. '备注':'',
  1393. '文件类型':'',
  1394. '关联产品':'',
  1395. '建档日期':'',
  1396. '更新时间':'',
  1397. '建档用户':'',
  1398. '建档日期':'',
  1399. '更新时间':'',
  1400. '操作':'',
  1401. },
  1402. {
  1403. '序号':'2',
  1404. '备注':'',
  1405. '文件类型':'',
  1406. '关联产品':'',
  1407. '建档日期':'',
  1408. '更新时间':'',
  1409. '建档用户':'',
  1410. '建档日期':'',
  1411. '更新时间':'',
  1412. '操作':'',
  1413. },
  1414. ];
  1415. // console.log("下方表格数据")
  1416. // console.log(ysData)
  1417. // console.log(gyData)
  1418. // console.log(ddData)
  1419. // console.log(jsData)
  1420. ystableData.splice(0,ysData.length,...ysData);//表格数据
  1421. gytableData.splice(0,gyData.length,...gyData);//表格数据
  1422. ddtableData.splice(0,ddData.length,...ddData);//表格数据
  1423. jstableData.splice(0,jsData.length,...jsData);//表格数据
  1424. } catch (error) {
  1425. console.error(error);
  1426. }
  1427. }else if(row.订单号 === '2408003'){
  1428. ystableData.length = 0
  1429. try {
  1430. const ysData = [
  1431. {
  1432. '序号':'1',
  1433. '订单子编号':'2408003-3',
  1434. '颜色名称':'黑色',
  1435. '船样':'否',
  1436. 'S':'10',
  1437. 'M':'20',
  1438. 'L':'30',
  1439. 'XL':'20',
  1440. 'XXL':'10',
  1441. '制单总数':'90',
  1442. '建档用户':'',
  1443. '建档日期':'',
  1444. '更新时间':'',
  1445. },
  1446. ];
  1447. //工艺资料表
  1448. const gyData = [
  1449. {
  1450. '完工状态':'',
  1451. '工序名称':'仓库出库',
  1452. '计划产量':'/',
  1453. '建档用户':'',
  1454. '建档日期':'',
  1455. '更新时间':'',
  1456. },
  1457. {
  1458. '完工状态':'',
  1459. '工序名称':'裁切',
  1460. '计划产量':'按颜色显示总计数',
  1461. '建档用户':'',
  1462. '建档日期':'',
  1463. '更新时间':'',
  1464. },
  1465. {
  1466. '完工状态':'',
  1467. '工序名称':'车缝',
  1468. '计划产量':'按颜色显示总计数',
  1469. '建档用户':'',
  1470. '建档日期':'',
  1471. '更新时间':'',
  1472. },
  1473. {
  1474. '完工状态':'',
  1475. '工序名称':'后道收样',
  1476. '计划产量':'按颜色显示总计数',
  1477. '建档用户':'',
  1478. '建档日期':'',
  1479. '更新时间':'',
  1480. },
  1481. {
  1482. '完工状态':'',
  1483. '工序名称':'大烫',
  1484. '计划产量':'按颜色显示总计数',
  1485. '建档用户':'',
  1486. '建档日期':'',
  1487. '更新时间':'',
  1488. },
  1489. {
  1490. '完工状态':'',
  1491. '工序名称':'总检',
  1492. '计划产量':'按颜色显示总计数',
  1493. '建档用户':'',
  1494. '建档日期':'',
  1495. '更新时间':'',
  1496. },
  1497. {
  1498. '完工状态':'',
  1499. '工序名称':'包装',
  1500. '计划产量':'按颜色显示总计数',
  1501. '建档用户':'',
  1502. '建档日期':'',
  1503. '更新时间':'',
  1504. }
  1505. ];
  1506. //订单资料表
  1507. const ddData = [
  1508. {
  1509. '序号':'1',
  1510. '备注':'',
  1511. '文件类型':'',
  1512. '关联产品':'',
  1513. '建档日期':'',
  1514. '更新时间':'',
  1515. '建档用户':'',
  1516. '建档日期':'',
  1517. '更新时间':'',
  1518. '操作':'',
  1519. },
  1520. {
  1521. '序号':'2',
  1522. '备注':'',
  1523. '文件类型':'',
  1524. '关联产品':'',
  1525. '建档日期':'',
  1526. '更新时间':'',
  1527. '建档用户':'',
  1528. '建档日期':'',
  1529. '更新时间':'',
  1530. '操作':'',
  1531. },
  1532. ];
  1533. //技术附件
  1534. const jsData = [
  1535. {
  1536. '序号':'1',
  1537. '备注':'',
  1538. '文件类型':'',
  1539. '关联产品':'',
  1540. '建档日期':'',
  1541. '更新时间':'',
  1542. '建档用户':'',
  1543. '建档日期':'',
  1544. '更新时间':'',
  1545. '操作':'',
  1546. },
  1547. {
  1548. '序号':'2',
  1549. '备注':'',
  1550. '文件类型':'',
  1551. '关联产品':'',
  1552. '建档日期':'',
  1553. '更新时间':'',
  1554. '建档用户':'',
  1555. '建档日期':'',
  1556. '更新时间':'',
  1557. '操作':'',
  1558. },
  1559. ];
  1560. // console.log("下方表格数据")
  1561. // console.log(ysData)
  1562. // console.log(gyData)
  1563. // console.log(ddData)
  1564. // console.log(jsData)
  1565. ystableData.splice(0,ysData.length,...ysData);//表格数据
  1566. gytableData.splice(0,gyData.length,...gyData);//表格数据
  1567. ddtableData.splice(0,ddData.length,...ddData);//表格数据
  1568. jstableData.splice(0,jsData.length,...jsData);//表格数据
  1569. } catch (error) {
  1570. console.error(error);
  1571. }
  1572. }
  1573. }
  1574. // console.log(row.工单编号)
  1575. // _Gd_gdbh.value = row.工单编号;
  1576. // _Gd_cpdh.value = row.产品代号;
  1577. // _Gd_cpmc.value = row.产品名称;
  1578. // const workOrderListDetail_data = await workOrderListDetail({Gd_gdbh:_Gd_gdbh.value});
  1579. // console.log(workOrderListDetail_data.data.processList)
  1580. // ystableData.value = workOrderListDetail_data.data.printList;
  1581. // gytableData.value = workOrderListDetail_data.data.processList;
  1582. // bomtableData.value = workOrderListDetail_data.data.BOM;
  1583. // jstableData.splice(0, jstableData.length, ...workOrderListDetail_data.data.jsData);
  1584. // // jstableData.value = workOrderListDetail_data.data.jsData;
  1585. // let tmp = yjtableData.value.map(item => item.印件号)
  1586. // tmp = tmp.sort((a,b)=>b-a)
  1587. // yjzuidahaoma.value = Number(tmp[0]) + 1
  1588. //=========查询========
  1589. const searchInfo = ref('')
  1590. //查询按钮
  1591. const onSubmit = () => {
  1592. if(searchInfo.value === ''){
  1593. ElMessage({type: 'warning',message: '请输入搜索的信息'})
  1594. return false;
  1595. }else{
  1596. console.log(searchInfo.value)
  1597. console.log("点击了搜索按钮");
  1598. }
  1599. // _cha_WorkList();
  1600. };
  1601. //回车查询
  1602. const handleSearch = (event) => {
  1603. if(searchInfo.value === ''){
  1604. ElMessage({type: 'warning',message: '请输入搜索的信息'})
  1605. return false;
  1606. }else{
  1607. console.log("回车了");
  1608. }
  1609. // _cha_WorkList();
  1610. };
  1611. // 调用查询数据接口
  1612. const _cha_WorkList = async (node) => {
  1613. if(searchInfo.value === ''){
  1614. ElMessage({type: 'warning',message: '请输入搜索的信息'})
  1615. return false;
  1616. }
  1617. const search = searchInfo.value;
  1618. var regex = /^[a-zA-Z0-9]+$/;
  1619. try {
  1620. if (regex.test(search)) {
  1621. // 符合条件,执行搜索操作
  1622. console.log('搜索内容为纯数字加字母');
  1623. // const WorkListdata = await WorkList({search:search,limit:100,page:1});//接口调用函数
  1624. if(WorkListdata.data.total === 0){
  1625. ElMessage({type: 'warning',message: '未搜索具体查询条件'})
  1626. }
  1627. tableData.splice(0,tableData.length,...WorkListdata.data.data);//表格数据
  1628. total.value = WorkListdata.data.total;//共多少条
  1629. } else {
  1630. // 不符合条件,给出提示
  1631. console.log('搜索内容包含非字母和数字的字符');
  1632. // const WorkListdata = await WorkList({Gd_khdh:'',search:search,limit:100,page:1});//接口调用函数
  1633. if(WorkListdata.data.total === 0){
  1634. ElMessage({type: 'warning',message: '未搜索具体查询条件'})
  1635. }
  1636. tableData.splice(0,tableData.length,...WorkListdata.data.data);//表格数据
  1637. total.value = WorkListdata.data.total;//共多少条
  1638. }
  1639. } catch (error) {
  1640. console.error(error);
  1641. }
  1642. };
  1643. //=========技术附件========
  1644. //点击技术附件按钮
  1645. const jsfjClick = () => {
  1646. if(_Gd_gdbh.value === '' || _Gd_gdbh.value === null){
  1647. ElMessage({type: 'warning',message: '请选择具体的工单后,再操作此功能'})
  1648. }else{
  1649. jsfjdialogFormVisible.value = true
  1650. initJsfjformdata();
  1651. jsfjformdata.value.关联编号 = _Gd_gdbh.value
  1652. }
  1653. }
  1654. //技术附件弹窗
  1655. const jsfjdialogFormVisible = ref(false)
  1656. const jsfjformdata = ref({
  1657. sys_id: _username.value,
  1658. 附件备注: '',
  1659. 附件内容: '',
  1660. 附件类型: '',
  1661. 关联编号: '',
  1662. });
  1663. //技术附件弹窗取消
  1664. const initJsfjformdata = () => {
  1665. jsfjformdata.value = {
  1666. sys_id: _username.value,
  1667. 附件备注: '',
  1668. 附件内容: '',
  1669. 附件类型: '',
  1670. 关联编号: '',
  1671. }
  1672. }
  1673. //技术附件弹窗取消
  1674. const jsfjcloseDialog = () => {
  1675. jsfjdialogFormVisible.value = false
  1676. }
  1677. const uploadExcel = (event) =>{
  1678. const files = event.target.files;
  1679. let suffixArr = name.split("."), suffix = suffixArr[suffixArr.length-1];
  1680. // if(suffix!="xlsx"){
  1681. // alert("Currently only supports the import of xlsx files");
  1682. // return;
  1683. // }
  1684. jsfjformdata.value.附件内容 = files[0]
  1685. jsfjformdata.value.附件类型 = 'XLSX'
  1686. }
  1687. //技术附件预览
  1688. const yulan = (event) =>{
  1689. if(!jsfjformdata.value.附件内容) return
  1690. $.getScript('/luckysheet/plugins/js/plugin.js', () => {
  1691. $script('/luckysheet/luckysheet.umd.js', () => {
  1692. luckyexcelVisible.value = true
  1693. LuckyExcel.transformExcelToLucky(jsfjformdata.value.附件内容, function(exportJson, luckysheetfile){
  1694. if(exportJson.sheets==null || exportJson.sheets.length==0){
  1695. alert("Failed to read the content of the excel file, currently does not support xls files!");
  1696. return;
  1697. }
  1698. if(luckyExcel) luckyExcel.destroy();
  1699. luckysheet.create({
  1700. container: 'luckyexcel', //容器的ID
  1701. data: exportJson.sheets,
  1702. title: exportJson.info.name, // 工作簿名称
  1703. lang: "zh", // 设定表格语言 国际化设置,允许设置表格的语言,支持中文("zh")和英文("en")
  1704. showtoolbar: false, // 是否显示工具栏
  1705. showinfobar: false, // 是否显示顶部信息栏
  1706. allowEdit: false, // 是否允许前台编辑
  1707. enableAddRow: false, // 允许增加行
  1708. enableAddCol: false, // 允许增加列
  1709. userInfo: false, // 右上角的用户信息展示样式
  1710. showRowBar: false, // 是否显示行号区域
  1711. showColumnBar: false, // 是否显示列号区域
  1712. sheetFormulaBar: false, // 是否显示公式栏
  1713. enableAddBackTop: false,//返回头部按钮
  1714. });
  1715. luckyExcel = luckysheet;
  1716. })
  1717. })
  1718. })
  1719. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/plugins/css/pluginsCss.css'));
  1720. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/plugins/plugins.css'));
  1721. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/css/luckysheet.css'));
  1722. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/assets/iconfont/iconfont.css'));
  1723. }
  1724. const jsfj_del = (row) =>{
  1725. ElMessageBox.confirm('确定要删除吗?', '提示', {
  1726. confirmButtonText: '确定',
  1727. cancelButtonText: '取消',
  1728. type: 'warning'
  1729. }).then(() => {
  1730. gdAnnexDel({'UniqId':row.UniqId,'gdbh':_Gd_gdbh.value}).then(response => {
  1731. if(response.code==0){
  1732. ElMessage({
  1733. type: 'success',
  1734. message: '删除成功',
  1735. })
  1736. let row = {
  1737. '工单编号':_Gd_gdbh.value,
  1738. '产品代号':_Gd_cpdh.value,
  1739. '产品名称':_Gd_cpmc.value,
  1740. }
  1741. tableRowClick (row)
  1742. }
  1743. })
  1744. })
  1745. }
  1746. //技术附件弹窗确定
  1747. const jsfjenterDialog = () => {
  1748. if(jsfjformdata.value.附件备注==''){
  1749. ElMessage({
  1750. type: 'error',
  1751. message: '请填写附件备注'
  1752. });
  1753. return;
  1754. }
  1755. if(jsfjformdata.value.附件内容==''){
  1756. ElMessage({
  1757. type: 'error',
  1758. message: '请上传文件'
  1759. });
  1760. return;
  1761. }
  1762. if(jsfjformdata.value.关联编号==''){
  1763. ElMessage({
  1764. type: 'error',
  1765. message: '请填写关联编号'
  1766. });
  1767. return;
  1768. }
  1769. let fr = new FileReader();
  1770. fr.readAsDataURL(jsfjformdata.value.附件内容);
  1771. fr.onload = function () {
  1772. const restoredData = new FormData();
  1773. restoredData.append('sys_id', jsfjformdata.value.sys_id);
  1774. restoredData.append('附件备注', jsfjformdata.value.附件备注);
  1775. restoredData.append('附件内容', fr.result);
  1776. restoredData.append('附件类型', jsfjformdata.value.附件类型);
  1777. restoredData.append('关联编号', jsfjformdata.value.关联编号);
  1778. gdAnnexAdd(restoredData).then(response => {
  1779. if(response.code==0){
  1780. ElMessage({
  1781. type: 'success',
  1782. message: '新增成功',
  1783. })
  1784. jsfjdialogFormVisible.value = false
  1785. let row = {
  1786. '工单编号':_Gd_gdbh.value,
  1787. '产品代号':_Gd_cpdh.value,
  1788. '产品名称':_Gd_cpmc.value,
  1789. }
  1790. tableRowClick (row)
  1791. }
  1792. })
  1793. }
  1794. }
  1795. //技术资料excel展示
  1796. const ExcelShow = (row) =>{
  1797. console.log("技术资料excel展示")
  1798. console.log(row)
  1799. if(!row.附件内容) return
  1800. $.getScript('/luckysheet/plugins/js/plugin.js', () => {
  1801. $script('/luckysheet/luckysheet.umd.js', () => {
  1802. function dataURLtoBlob(dataUrl) {
  1803. const byteString = atob(dataUrl.split(',')[1]);
  1804. const ab = new ArrayBuffer(byteString.length);
  1805. const ia = new Uint8Array(ab);
  1806. for (let i = 0; i < byteString.length; i++) {
  1807. ia[i] = byteString.charCodeAt(i);
  1808. }
  1809. return new Blob([ab], { type: 'application/octet-stream' });
  1810. }
  1811. const blob = dataURLtoBlob(row.附件内容);
  1812. luckyexcelVisible.value = true
  1813. LuckyExcel.transformExcelToLucky(blob, function(exportJson, luckysheetfile){
  1814. if(exportJson.sheets==null || exportJson.sheets.length==0){
  1815. alert("Failed to read the content of the excel file, currently does not support xls files!");
  1816. return;
  1817. }
  1818. if(luckyExcel) luckyExcel.destroy();
  1819. luckysheet.create({
  1820. container: 'luckyexcel', //容器的ID
  1821. data: exportJson.sheets,
  1822. title: exportJson.info.name, // 工作簿名称
  1823. lang: "zh", // 设定表格语言 国际化设置,允许设置表格的语言,支持中文("zh")和英文("en")
  1824. showtoolbar: false, // 是否显示工具栏
  1825. showinfobar: false, // 是否显示顶部信息栏
  1826. allowEdit: false, // 是否允许前台编辑
  1827. enableAddRow: false, // 允许增加行
  1828. enableAddCol: false, // 允许增加列
  1829. userInfo: false, // 右上角的用户信息展示样式
  1830. showRowBar: false, // 是否显示行号区域
  1831. showColumnBar: false, // 是否显示列号区域
  1832. sheetFormulaBar: false, // 是否显示公式栏
  1833. enableAddBackTop: false,//返回头部按钮
  1834. });
  1835. luckyExcel = luckysheet;
  1836. })
  1837. })
  1838. })
  1839. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/plugins/css/pluginsCss.css'));
  1840. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/plugins/plugins.css'));
  1841. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/css/luckysheet.css'));
  1842. $('head').append($('<link rel="stylesheet" type="text/css" />').attr('href', '/luckysheet/assets/iconfont/iconfont.css'));
  1843. }
  1844. let luckyExcel = null
  1845. const luckyexcelVisible = ref(false)
  1846. const luckyexcelCloseDialog = () => {
  1847. luckyexcelVisible.value = false
  1848. }
  1849. </script>
  1850. <style scoped>
  1851. /* 在样式表中使用媒体查询 */
  1852. @media (max-width: 768px) {
  1853. /* 在小屏幕下的样式设置 */
  1854. .dialog-footer {
  1855. text-align: center;
  1856. }
  1857. }
  1858. /*背景颜色*/
  1859. /*印件背景颜色变黄*/
  1860. :deep(.el-table__body .warning-row) {
  1861. background: #FFFF80 !important;
  1862. }
  1863. /*修正工单核算参数背景*/
  1864. :deep(.el-table__body .background-plan-usage-low div div div) {
  1865. background: #80FA80 !important;
  1866. }
  1867. /* 选中某行时的背景色 */
  1868. :deep(.el-table__body tr.current-row) > td {
  1869. background: #ff80ff !important;
  1870. }
  1871. :deep(.statusy-plan-usage-low div) {
  1872. color: #8c939d !important;
  1873. }
  1874. /* 在样式表中添加以下样式 */
  1875. .el-input__textarea {
  1876. resize: none; /* 禁止调整大小 */
  1877. }
  1878. .JKWTree-container {
  1879. display: flex;
  1880. }
  1881. .JKWTree-tree {
  1882. /*width: 300px;*/
  1883. background-color: #fff;
  1884. padding: 10px;
  1885. margin-right: 20px;
  1886. }
  1887. .JKWTree-tree h3 {
  1888. font-size: 15px;
  1889. font-weight: 700;
  1890. margin: 10px 0;
  1891. }
  1892. .JKWTree-content {
  1893. flex: 1;
  1894. }
  1895. /*关闭拖拽功能*/
  1896. .el-textarea textarea {
  1897. resize: none !important;
  1898. }
  1899. </style>
  1900. <style scoped>
  1901. :deep(.el-table td .cell) {
  1902. line-height: 20px !important;
  1903. }
  1904. :deep(.el-tabs__header){
  1905. margin-bottom: 0;
  1906. }
  1907. .search{
  1908. margin-left: 0px !important;
  1909. margin-right: 10px !important;
  1910. }
  1911. .bt{
  1912. margin-left: 2px !important;
  1913. padding: 3px !important;
  1914. font-size: 12px;
  1915. }
  1916. .el-tabs__header{
  1917. margin: 0px !important;
  1918. }
  1919. .gva-table-box{
  1920. padding: 0px !important;
  1921. }
  1922. .el-pagination{
  1923. margin-top: 0px !important;
  1924. }
  1925. .mab{
  1926. margin-bottom: 5px;
  1927. }
  1928. /* 图片 */
  1929. .avatar-uploader {
  1930. width: 500px;
  1931. height: 300px;
  1932. border: 1px dashed #d9d9d9;
  1933. display: flex;
  1934. justify-content: center;
  1935. align-items: center;
  1936. cursor: pointer;
  1937. overflow: hidden; /* 防止图片溢出容器 */
  1938. }
  1939. .avatar {
  1940. width: 50%;
  1941. height: 100%;
  1942. display: block;
  1943. object-fit: contain;
  1944. }
  1945. .avatar-uploader-icon {
  1946. font-size: 28px;
  1947. color: #8c939d;
  1948. }
  1949. .upload-placeholder {
  1950. display: flex;
  1951. flex-direction: column;
  1952. align-items: center;
  1953. justify-content: center;
  1954. height: 100%;
  1955. width: 100%;
  1956. }
  1957. .upload-text {
  1958. width: 50%;
  1959. height: 50%;
  1960. margin-top: 5px;
  1961. color: #8c939d;
  1962. font-size: 14px;
  1963. }
  1964. </style>