index.vue 63 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299
  1. <template>
  2. <div class="app-container" style="width: 100%;">
  3. <el-tabs type="border-card" @tab-click="tabClick" v-model="selectedWorkshop">
  4. <!--南车间-->
  5. <el-tab-pane label="南车间计划" name="南车间">
  6. <!--表格-->
  7. <el-table
  8. :data="tableData"
  9. ref="tableRef"
  10. :span-method="spanMethod2">
  11. <el-table-column prop="machineId" fixed label="机台号" header-align="center" align="center" width="111px" ></el-table-column>
  12. <el-table-column prop="productType" fixed label="产品类别" header-align="center" align="center" width="111.2px"></el-table-column>
  13. <el-table-column label="在机产品" header-align="center" >
  14. <el-table-column prop="currentColorCode" label="色号" header-align="center" width="90px" align="center"></el-table-column>
  15. <el-table-column prop="currentSpecification" label="规格" header-align="center" width="90px" align="center"></el-table-column>
  16. <el-table-column prop="currentLotNumber" label="批号" header-align="center" width="90px" align="center"></el-table-column>
  17. <el-table-column prop="currentSpindleCount" label="锭数" header-align="center" width="90px" align="center"></el-table-column>
  18. <el-table-column prop="startTime" label="上机时间" header-align="center" width="90px" align="center"></el-table-column>
  19. <el-table-column prop="plannedEndTime" label="下机时间" header-align="center" width="90px" align="center"></el-table-column>
  20. </el-table-column>
  21. <!-- <el-table-column label="待上机产品" header-align="center" align="center">-->
  22. <!-- <el-table-column prop="djCurrentColorCode" label="色号" header-align="center" align="center"></el-table-column>-->
  23. <!-- <el-table-column prop="djCurrentSpecification" label="规格" header-align="center" align="center"></el-table-column>-->
  24. <!-- <el-table-column prop="djNumber" label="数量" header-align="center" align="center"></el-table-column>-->
  25. <!-- <el-table-column prop="djCurrentLotNumber" label="原丝批号" header-align="center" align="center"></el-table-column>-->
  26. <!-- </el-table-column>-->
  27. <el-table-column prop="listOfPendingProduction" label="待生产产品列表" header-align="center" align="center" >
  28. <template slot-scope="scope">
  29. <div v-if="scope.row.listOfPendingProduction">
  30. <span v-for="(item, index) in scope.row.listOfPendingProduction.split(',')">
  31. {{ item }},
  32. <br v-if="(index + 1) % 5 === 0 && index !== scope.row.listOfPendingProduction.split(',').length - 1" />
  33. </span>
  34. </div>
  35. </template>
  36. </el-table-column>
  37. <el-table-column fixed="right" label="操作" header-align="center" align="center" width="150px" >
  38. <template slot-scope="scope">
  39. <el-dropdown>
  40. <el-button type="primary">
  41. 操作
  42. <i class="el-icon-arrow-down el-icon--right"></i>
  43. </el-button>
  44. <el-dropdown-menu slot="dropdown">
  45. <el-dropdown-item @click.native.prevent="handleAddPlan(scope.row)">新增计划</el-dropdown-item>
  46. <el-dropdown-item @click.native.prevent="handleEditPlan(scope.row)">修改计划</el-dropdown-item>
  47. <el-dropdown-item @click.native.prevent="handleStopProductionLine(scope.row)">机台状态</el-dropdown-item>
  48. </el-dropdown-menu>
  49. </el-dropdown>
  50. </template>
  51. </el-table-column>
  52. </el-table>
  53. <!--新增计划弹窗-->
  54. <el-dialog title="南车间新增计划" :visible.sync="nanInsertDialogTableVisible" width="1200px">
  55. <el-table :data="tableData2" @row-click.self="handleRowClick">
  56. <!-- <el-table-column prop="salesmanId" label="业务员" header-align="center" align="center" width="100px">-->
  57. <!-- <template v-slot:default="scope">-->
  58. <!-- <el-select v-model="scope.row.salesmanId" placeholder="请选择业务员" @change="selectedSalesmanItem(scope.row,scope.row.salesmanId)">-->
  59. <!-- <el-option v-for="salesmanItem in salesmanInfo" :key="salesmanItem.saleNo" :label="salesmanItem.salesman" :value="salesmanItem.saleNo" ></el-option>-->
  60. <!-- </el-select>-->
  61. <!-- </template>-->
  62. <!-- </el-table-column>-->
  63. <el-table-column prop="productId" label="产品" header-align="center" align="center" width="150px">
  64. <template v-slot:default="scope">
  65. <el-select v-model="scope.row.productId" placeholder="请选择待排产产品" @change="selectedChangeDate(scope.row,scope.row.productId)">
  66. <el-option v-for="product in productsInfo" :key="product.id" :label="product.productName" :value="product.id" ></el-option>
  67. </el-select>
  68. </template>
  69. </el-table-column>
  70. <el-table-column prop="currentColorCode" label="色号" header-align="center" align="center">
  71. <template v-slot:default="scope">
  72. <!-- 如果当前行正在编辑,则显示输入框 -->
  73. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentColorCode" placeholder="请输入色号" @blur.stop.prevent="handleInputBlur(scope.row)" ></el-input>
  74. <!-- 否则显示普通文本 -->
  75. <span v-else>{{ scope.row.currentColorCode }}</span>
  76. </template>
  77. </el-table-column>
  78. <el-table-column prop="currentSpecification" label="规格" header-align="center" align="center">
  79. <template v-slot:default="scope">
  80. <!-- 如果当前行正在编辑,则显示输入框 -->
  81. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentSpecification" placeholder="请输入规格" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  82. <!-- 否则显示普通文本 -->
  83. <span v-else>{{ scope.row.currentSpecification }}</span>
  84. </template>
  85. </el-table-column>
  86. <el-table-column prop="productType" label="产品类别" header-align="center" align="center" width="100px">
  87. <template v-slot:default="scope">
  88. <el-select v-model="scope.row.productType" placeholder="请选择产品类别" >
  89. <el-option v-for="product in productTypeList" :key="product.value" :label="product.lable" :value="product.value" ></el-option>
  90. </el-select>
  91. </template>
  92. </el-table-column>
  93. <el-table-column prop="currentLotNumber" label="批号" header-align="center" align="center">
  94. <template v-slot:default="scope">
  95. <el-input v-if="scope.row.isEditing" :disabled="isDisabled" v-model="scope.row.currentLotNumber" placeholder="请输入批号" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  96. <span v-else>{{ scope.row.currentLotNumber }}</span>
  97. </template>
  98. </el-table-column>
  99. <el-table-column prop="currentSpindleCount" label="锭数" header-align="center" align="center">
  100. <template v-slot:default="scope">
  101. <el-input v-if="scope.row.isEditing" v-model="scope.row.currentSpindleCount" placeholder="请输入锭数" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  102. <span v-else>{{ scope.row.currentSpindleCount }}</span>
  103. </template>
  104. </el-table-column>
  105. <el-table-column prop="djNumber" label="数量" header-align="center" align="center">
  106. <template v-slot:default="scope">
  107. <el-input v-if="scope.row.isEditing" v-model="scope.row.number" placeholder="请输入数量" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  108. <span v-else>{{ scope.row.number }}</span>
  109. </template>
  110. </el-table-column>
  111. <el-table-column prop="startTime" label="上机时间" header-align="center" align="center">
  112. <template v-slot:default="scope">
  113. <el-input v-if="scope.row.isEditing" v-model="scope.row.startTime" placeholder="请输入上机时间" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  114. <span v-else>{{ scope.row.startTime }}</span>
  115. </template>
  116. </el-table-column>
  117. <el-table-column prop="plannedEndTime" label="计划下机时间" header-align="center" align="center">
  118. <template v-slot:default="scope">
  119. <el-input v-if="scope.row.isEditing" :ref="'input'+scope.$index" v-model="scope.row.plannedEndTime" placeholder="请输入计划下机时间" @blur="handleInputBlur(scope.row)">></el-input>
  120. <span v-else>{{ scope.row.plannedEndTime }}</span>
  121. </template>
  122. </el-table-column>
  123. <el-table-column prop="planStatus" label="计划状态" header-align="center" align="center" width="100px">
  124. <template v-slot:default="scope">
  125. <el-select v-model="scope.row.planStatus" placeholder="计划状态">
  126. <el-option v-for="stateItem in stateList0" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  127. </el-select>
  128. </template>
  129. </el-table-column>
  130. <el-table-column label="操作">
  131. <template slot-scope="scope">
  132. <el-button
  133. size="mini"
  134. type="danger"
  135. @click.stop.prevent="handleDelete(scope.$index, scope.row)">删除</el-button>
  136. </template>
  137. </el-table-column>
  138. </el-table>
  139. <el-button type="primary" style="width: 100%;margin-top: 30px" @click="addEditableRow">新增计划产品</el-button>
  140. <span slot="footer" class="dialog-footer">
  141. <el-button @click="nanInsertDialogTableVisible = false">取 消</el-button>
  142. <el-button type="primary" @click="addPlanInfo">确 定</el-button>
  143. </span>
  144. </el-dialog>
  145. <!--修改计划弹窗-->
  146. <el-dialog title="修改计划" :visible.sync="nanUpdateDialogTableVisible" width="1400px">
  147. <!--查询条件-->
  148. <el-form ref="form" :model="formData" label-width="80px" :inline="true">
  149. <el-form-item label="产品类别:">
  150. <el-select v-model="formData.productType" placeholder="请选择产品类别">
  151. <el-option v-for="product in productTypeList" :key="product.value" :label="product.lable" :value="product.value" ></el-option>
  152. </el-select>
  153. </el-form-item>
  154. <el-form-item label="计划状态:">
  155. <el-select v-model="formData.planStatus" placeholder="请选择计划状态">
  156. <el-option v-for="stateListItem in stateList2" :key="product.id" :label="stateListItem.name" :value="stateListItem.id" ></el-option>
  157. </el-select>
  158. </el-form-item>
  159. <el-form-item>
  160. <el-button type="primary" @click="onSubmit">查询</el-button>
  161. <el-button @click="reset">重置</el-button>
  162. </el-form-item>
  163. </el-form>
  164. <!--表格-->
  165. <el-table :data="tableData2" @row-click.self="handleRowClick">
  166. <!-- <el-table-column prop="salesmanId" label="业务员" header-align="center" align="center" width="100px">-->
  167. <!-- <template v-slot:default="scope">-->
  168. <!-- <el-select :ref="'salesmanSelect'+scope.$index" v-model="scope.row.salesmanId" placeholder="请选择业务员" @change="selectedSalesmanItem(scope.row,scope.row.salesmanId,scope.$index)">-->
  169. <!-- <el-option v-for="salesmanItem in salesmanInfo" :key="salesmanItem.saleNo" :label="salesmanItem.salesman" :value="salesmanItem.saleNo" ></el-option>-->
  170. <!-- </el-select>-->
  171. <!-- </template>-->
  172. <!-- </el-table-column>-->
  173. <el-table-column prop="productId" label="产品" header-align="center" align="center" width="150px">
  174. <template v-slot:default="scope">
  175. <el-select :ref="'productSelected'+scope.$index" v-model="scope.row.productId" placeholder="请选择待排产产品" @change="selectedChangeDate(scope.row,scope.row.productId)">
  176. <el-option v-for="product in productsInfo" :key="product.id" :label="product.productName" :value="product.id" ></el-option>
  177. </el-select>
  178. </template>
  179. </el-table-column>
  180. <el-table-column prop="currentColorCode" label="色号" header-align="center" align="center">
  181. <template v-slot:default="scope">
  182. <!-- 如果当前行正在编辑,则显示输入框 -->
  183. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentColorCode" placeholder="请输入色号" @blur.stop.prevent="handleInputBlur(scope.row)" ></el-input>
  184. <!-- 否则显示普通文本 -->
  185. <span v-else>{{ scope.row.currentColorCode }}</span>
  186. </template>
  187. </el-table-column>
  188. <el-table-column prop="currentSpecification" label="规格" header-align="center" align="center">
  189. <template v-slot:default="scope">
  190. <!-- 如果当前行正在编辑,则显示输入框 -->
  191. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentSpecification" placeholder="请输入规格" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  192. <!-- 否则显示普通文本 -->
  193. <span v-else>{{ scope.row.currentSpecification }}</span>
  194. </template>
  195. </el-table-column>
  196. <el-table-column prop="currentSpecification" label="产品类别" header-align="center" align="center" width="100px">
  197. <template v-slot:default="scope">
  198. <el-select v-model="scope.row.productType" placeholder="请选择产品类别" @change="selectedChangeDate(scope.row,scope.row.product)">
  199. <el-option v-for="product in productTypeList" :key="product.value" :label="product.lable" :value="product.value" ></el-option>
  200. </el-select>
  201. </template>
  202. </el-table-column>
  203. <el-table-column prop="currentLotNumber" label="批号" header-align="center" align="center">
  204. <template v-slot:default="scope">
  205. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentLotNumber" placeholder="请输入批号" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  206. <span v-else>{{ scope.row.currentLotNumber }}</span>
  207. </template>
  208. </el-table-column>
  209. <el-table-column prop="currentSpindleCount" label="锭数" header-align="center" align="center">
  210. <template v-slot:default="scope">
  211. <el-input v-if="scope.row.isEditing" v-model="scope.row.currentSpindleCount" placeholder="请输入锭数" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  212. <span v-else>{{ scope.row.currentSpindleCount }}</span>
  213. </template>
  214. </el-table-column>
  215. <el-table-column prop="djNumber" label="数量" header-align="center" align="center">
  216. <template v-slot:default="scope">
  217. <el-input v-if="scope.row.isEditing" v-model="scope.row.number" placeholder="请输入数量" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  218. <span v-else>{{ scope.row.number }}</span>
  219. </template>
  220. </el-table-column>
  221. <el-table-column prop="startTime" label="上机时间" header-align="center" align="center">
  222. <template v-slot:default="scope">
  223. <el-input v-if="scope.row.isEditing" v-model="scope.row.startTime" placeholder="请输入上机时间" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  224. <span v-else>{{ scope.row.startTime }}</span>
  225. </template>
  226. </el-table-column>
  227. <el-table-column prop="plannedEndTime" label="计划下机时间" header-align="center" align="center">
  228. <template v-slot:default="scope">
  229. <el-input v-if="scope.row.isEditing" :ref="'input'+scope.$index" v-model="scope.row.plannedEndTime" placeholder="请输入计划下机时间" @blur="handleInputBlur(scope.row)">></el-input>
  230. <span v-else>{{ scope.row.plannedEndTime }}</span>
  231. </template>
  232. </el-table-column>
  233. <el-table-column prop="planStatus" label="计划状态" header-align="center" align="center" width="100px">
  234. <template v-slot:default="scope">
  235. <!--上机变停机待机-->
  236. <el-select v-if="scope.row.planStatus==1" v-model="scope.row.planStatus" placeholder="计划状态">
  237. <el-option v-for="stateItem in stateList1" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  238. </el-select>
  239. <!--待机可以上机-->
  240. <el-select v-if="scope.row.planStatus==0" v-model="scope.row.planStatus" placeholder="计划状态" >
  241. <el-option v-for="stateItem in stateList0" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  242. </el-select>
  243. <!--停机变上机-->
  244. <el-select v-if="scope.row.planStatus==2" v-model="scope.row.planStatus" placeholder="计划状态" >
  245. <el-option v-for="stateItem in stateList2" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  246. </el-select>
  247. </template>
  248. </el-table-column>
  249. <el-table-column label="操作" align="center" width="200px">
  250. <template slot-scope="scope">
  251. <el-button
  252. size="mini"
  253. type="danger"
  254. @click.stop.prevent="updateStatus(scope.$index, scope.row)">更新状态</el-button>
  255. <el-button
  256. size="mini"
  257. type="danger"
  258. @click.stop.prevent="deletePlan(scope.$index, scope.row)">删除</el-button>
  259. </template>
  260. </el-table-column>
  261. </el-table>
  262. <!--操作按钮-->
  263. <span slot="footer" class="dialog-footer">
  264. <el-button @click="nanUpdateDialogTableVisible = false">取 消</el-button>
  265. <el-button type="primary" @click="nanUpdateDialogTableVisible = false">确 定</el-button>
  266. </span>
  267. </el-dialog>
  268. </el-tab-pane>
  269. <!--北车间-->
  270. <el-tab-pane label="北车间计划" name="北车间">
  271. <!--表格-->
  272. <el-table
  273. :data="tableData"
  274. ref="tableRef"
  275. :span-method="spanMethod2">
  276. <el-table-column prop="machineId" fixed label="机台号" header-align="center" align="center" width="111px" ></el-table-column>
  277. <el-table-column prop="productType" fixed label="产品类别" header-align="center" align="center" width="111.2px"></el-table-column>
  278. <el-table-column label="在机产品" header-align="center" >
  279. <el-table-column prop="currentColorCode" label="色号" header-align="center" width="90px" align="center"></el-table-column>
  280. <el-table-column prop="currentSpecification" label="规格" header-align="center" width="90px" align="center"></el-table-column>
  281. <el-table-column prop="currentLotNumber" label="批号" header-align="center" width="90px" align="center"></el-table-column>
  282. <el-table-column prop="currentSpindleCount" label="锭数" header-align="center" width="90px" align="center"></el-table-column>
  283. <el-table-column prop="startTime" label="上机时间" header-align="center" width="90px" align="center"></el-table-column>
  284. <el-table-column prop="plannedEndTime" label="下机时间" header-align="center" width="90px" align="center"></el-table-column>
  285. </el-table-column>
  286. <!-- <el-table-column label="待上机产品" header-align="center" align="center">-->
  287. <!-- <el-table-column prop="djCurrentColorCode" label="色号" header-align="center" align="center"></el-table-column>-->
  288. <!-- <el-table-column prop="djCurrentSpecification" label="规格" header-align="center" align="center"></el-table-column>-->
  289. <!-- <el-table-column prop="djNumber" label="数量" header-align="center" align="center"></el-table-column>-->
  290. <!-- <el-table-column prop="djCurrentLotNumber" label="原丝批号" header-align="center" align="center"></el-table-column>-->
  291. <!-- </el-table-column>-->
  292. <el-table-column prop="listOfPendingProduction" label="待生产产品列表" header-align="center" align="center" >
  293. <template slot-scope="scope">
  294. <div v-if="scope.row.listOfPendingProduction">
  295. <div v-for="(item, index) in scope.row.listOfPendingProduction.split(',')">
  296. {{ item }}
  297. <span v-if="(index + 1) % 5 === 0 && index !== scope.row.listOfPendingProduction.split(',').length - 1">,</span>
  298. <br v-if="(index + 1) % 5 === 0 && index !== scope.row.listOfPendingProduction.split(',').length - 1" />
  299. </div>
  300. </div>
  301. </template>
  302. </el-table-column>
  303. <el-table-column fixed="right" label="操作" header-align="center" align="center" width="150px" >
  304. <template slot-scope="scope">
  305. <el-dropdown>
  306. <el-button type="primary">
  307. 操作
  308. <i class="el-icon-arrow-down el-icon--right"></i>
  309. </el-button>
  310. <el-dropdown-menu slot="dropdown">
  311. <el-dropdown-item @click.native.prevent="handleAddPlan(scope.row)">新增计划</el-dropdown-item>
  312. <el-dropdown-item @click.native.prevent="handleEditPlan(scope.row)">修改计划</el-dropdown-item>
  313. <el-dropdown-item @click.native.prevent="handleStopProductionLine(scope.row)">机台状态</el-dropdown-item>
  314. </el-dropdown-menu>
  315. </el-dropdown>
  316. </template>
  317. </el-table-column>
  318. </el-table>
  319. <!--新增计划弹窗-->
  320. <el-dialog title="北车间新增计划" :visible.sync="beiInsertDialogTableVisible" width="1200px">
  321. <el-table :data="tableData2" @row-click.self="handleRowClick">
  322. <!-- <el-table-column prop="salesmanId" label="业务员" header-align="center" align="center" width="100px">-->
  323. <!-- <template v-slot:default="scope">-->
  324. <!-- <el-select v-model="scope.row.salesmanId" placeholder="请选择业务员" @change="selectedSalesmanItem(scope.row,scope.row.salesmanId)">-->
  325. <!-- <el-option v-for="salesmanItem in salesmanInfo" :key="salesmanItem.saleNo" :label="salesmanItem.salesman" :value="salesmanItem.saleNo" ></el-option>-->
  326. <!-- </el-select>-->
  327. <!-- </template>-->
  328. <!-- </el-table-column>-->
  329. <el-table-column prop="productId" label="产品" header-align="center" align="center" width="150px">
  330. <template v-slot:default="scope">
  331. <el-select v-model="scope.row.productId" placeholder="请选择待排产产品" @change="selectedChangeDate(scope.row,scope.row.productId)">
  332. <el-option v-for="product in productsInfo" :key="product.id" :label="product.productName" :value="product.id" ></el-option>
  333. </el-select>
  334. </template>
  335. </el-table-column>
  336. <el-table-column prop="currentColorCode" label="色号" header-align="center" align="center">
  337. <template v-slot:default="scope">
  338. <!-- 如果当前行正在编辑,则显示输入框 -->
  339. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentColorCode" placeholder="请输入色号" @blur.stop.prevent="handleInputBlur(scope.row)" ></el-input>
  340. <!-- 否则显示普通文本 -->
  341. <span v-else>{{ scope.row.currentColorCode }}</span>
  342. </template>
  343. </el-table-column>
  344. <el-table-column prop="currentSpecification" label="规格" header-align="center" align="center">
  345. <template v-slot:default="scope">
  346. <!-- 如果当前行正在编辑,则显示输入框 -->
  347. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentSpecification" placeholder="请输入规格" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  348. <!-- 否则显示普通文本 -->
  349. <span v-else>{{ scope.row.currentSpecification }}</span>
  350. </template>
  351. </el-table-column>
  352. <el-table-column prop="productType" label="产品类别" header-align="center" align="center" width="100px">
  353. <template v-slot:default="scope">
  354. <el-select v-model="scope.row.productType" placeholder="请选择产品类别" >
  355. <el-option v-for="product in productTypeList" :key="product.value" :label="product.lable" :value="product.value" ></el-option>
  356. </el-select>
  357. </template>
  358. </el-table-column>
  359. <el-table-column prop="currentLotNumber" label="批号" header-align="center" align="center">
  360. <template v-slot:default="scope">
  361. <el-input v-if="scope.row.isEditing" :disabled="isDisabled" v-model="scope.row.currentLotNumber" placeholder="请输入批号" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  362. <span v-else>{{ scope.row.currentLotNumber }}</span>
  363. </template>
  364. </el-table-column>
  365. <el-table-column prop="currentSpindleCount" label="锭数" header-align="center" align="center">
  366. <template v-slot:default="scope">
  367. <el-input v-if="scope.row.isEditing" v-model="scope.row.currentSpindleCount" placeholder="请输入锭数" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  368. <span v-else>{{ scope.row.currentSpindleCount }}</span>
  369. </template>
  370. </el-table-column>
  371. <el-table-column prop="djNumber" label="数量" header-align="center" align="center">
  372. <template v-slot:default="scope">
  373. <el-input v-if="scope.row.isEditing" v-model="scope.row.number" placeholder="请输入数量" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  374. <span v-else>{{ scope.row.number }}</span>
  375. </template>
  376. </el-table-column>
  377. <el-table-column prop="startTime" label="上机时间" header-align="center" align="center">
  378. <template v-slot:default="scope">
  379. <el-input v-if="scope.row.isEditing" v-model="scope.row.startTime" placeholder="请输入上机时间" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  380. <span v-else>{{ scope.row.startTime }}</span>
  381. </template>
  382. </el-table-column>
  383. <el-table-column prop="plannedEndTime" label="计划下机时间" header-align="center" align="center">
  384. <template v-slot:default="scope">
  385. <el-input v-if="scope.row.isEditing" :ref="'input'+scope.$index" v-model="scope.row.plannedEndTime" placeholder="请输入计划下机时间" @blur="handleInputBlur(scope.row)">></el-input>
  386. <span v-else>{{ scope.row.plannedEndTime }}</span>
  387. </template>
  388. </el-table-column>
  389. <el-table-column prop="planStatus" label="计划状态" header-align="center" align="center" width="100px">
  390. <template v-slot:default="scope">
  391. <el-select v-model="scope.row.planStatus" placeholder="计划状态" >
  392. <el-option v-for="stateItem in stateList0" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  393. </el-select>
  394. </template>
  395. </el-table-column>
  396. <el-table-column label="操作" >
  397. <template slot-scope="scope">
  398. <el-button
  399. size="mini"
  400. type="danger"
  401. @click.stop.prevent="handleDelete(scope.$index, scope.row)">删除</el-button>
  402. </template>
  403. </el-table-column>
  404. </el-table>
  405. <el-button type="primary" style="width: 100%;margin-top: 30px" @click="addEditableRow">新增计划产品</el-button>
  406. <span slot="footer" class="dialog-footer">
  407. <el-button @click="beiInsertDialogTableVisible = false">取 消</el-button>
  408. <el-button type="primary" @click="addPlanInfo">确 定</el-button>
  409. </span>
  410. </el-dialog>
  411. <!--修改计划弹窗-->
  412. <el-dialog title="北车间修改计划" :visible.sync="beiUpdateDialogTableVisible" width="1200px">
  413. <!--查询条件-->
  414. <el-form ref="form" :model="formData" label-width="80px" :inline="true">
  415. <el-form-item label="产品类别:">
  416. <el-select v-model="formData.productType" placeholder="请选择产品类别">
  417. <el-option v-for="product in productTypeList" :key="product.value" :label="product.lable" :value="product.value" ></el-option>
  418. </el-select>
  419. </el-form-item>
  420. <el-form-item label="计划状态:">
  421. <el-select v-model="formData.planStatus" placeholder="请选择计划状态">
  422. <el-option v-for="stateListItem in stateList2" :key="product.id" :label="stateListItem.name" :value="stateListItem.id" ></el-option>
  423. </el-select>
  424. </el-form-item>
  425. <el-form-item>
  426. <el-button type="primary" @click="onSubmit">查询</el-button>
  427. <el-button @click="reset">重置</el-button>
  428. </el-form-item>
  429. </el-form>
  430. <!--表格-->
  431. <el-table :data="tableData2" @row-click.self="handleRowClick">
  432. <!-- <el-table-column prop="salesmanId" label="业务员" header-align="center" align="center" width="100px">-->
  433. <!-- <template v-slot:default="scope">-->
  434. <!-- <el-select :ref="'salesmanSelect'+scope.$index" v-model="scope.row.salesmanId" placeholder="请选择业务员" @change="selectedSalesmanItem(scope.row,scope.row.salesmanId,scope.$index)">-->
  435. <!-- <el-option v-for="salesmanItem in salesmanInfo" :key="salesmanItem.saleNo" :label="salesmanItem.salesman" :value="salesmanItem.saleNo" ></el-option>-->
  436. <!-- </el-select>-->
  437. <!-- </template>-->
  438. <!-- </el-table-column>-->
  439. <el-table-column prop="productId" label="产品" header-align="center" align="center" width="150px">
  440. <template v-slot:default="scope">
  441. <el-select :ref="'productSelected'+scope.$index" v-model="scope.row.productId" placeholder="请选择待排产产品" @change="selectedChangeDate(scope.row,scope.row.productId)">
  442. <el-option v-for="product in productsInfo" :key="product.id" :label="product.productName" :value="product.id" ></el-option>
  443. </el-select>
  444. </template>
  445. </el-table-column>
  446. <el-table-column prop="currentColorCode" label="色号" header-align="center" align="center">
  447. <template v-slot:default="scope">
  448. <!-- 如果当前行正在编辑,则显示输入框 -->
  449. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentColorCode" placeholder="请输入色号" @blur.stop.prevent="handleInputBlur(scope.row)" ></el-input>
  450. <!-- 否则显示普通文本 -->
  451. <span v-else>{{ scope.row.currentColorCode }}</span>
  452. </template>
  453. </el-table-column>
  454. <el-table-column prop="currentSpecification" label="规格" header-align="center" align="center">
  455. <template v-slot:default="scope">
  456. <!-- 如果当前行正在编辑,则显示输入框 -->
  457. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentSpecification" placeholder="请输入规格" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  458. <!-- 否则显示普通文本 -->
  459. <span v-else>{{ scope.row.currentSpecification }}</span>
  460. </template>
  461. </el-table-column>
  462. <el-table-column prop="currentSpecification" label="产品类别" header-align="center" align="center" width="100px">
  463. <template v-slot:default="scope">
  464. <el-select v-model="scope.row.productType" placeholder="请选择产品类别" @change="selectedChangeDate(scope.row,scope.row.product)">
  465. <el-option v-for="product in productTypeList" :key="product.value" :label="product.lable" :value="product.value" ></el-option>
  466. </el-select>
  467. </template>
  468. </el-table-column>
  469. <el-table-column prop="currentLotNumber" label="批号" header-align="center" align="center">
  470. <template v-slot:default="scope">
  471. <el-input v-if="scope.row.isEditing" disabled="disabled" v-model="scope.row.currentLotNumber" placeholder="请输入批号" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  472. <span v-else>{{ scope.row.currentLotNumber }}</span>
  473. </template>
  474. </el-table-column>
  475. <el-table-column prop="currentSpindleCount" label="锭数" header-align="center" align="center">
  476. <template v-slot:default="scope">
  477. <el-input v-if="scope.row.isEditing" v-model="scope.row.currentSpindleCount" placeholder="请输入锭数" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  478. <span v-else>{{ scope.row.currentSpindleCount }}</span>
  479. </template>
  480. </el-table-column>
  481. <el-table-column prop="djNumber" label="数量" header-align="center" align="center">
  482. <template v-slot:default="scope">
  483. <el-input v-if="scope.row.isEditing" v-model="scope.row.number" placeholder="请输入数量" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  484. <span v-else>{{ scope.row.number }}</span>
  485. </template>
  486. </el-table-column>
  487. <el-table-column prop="startTime" label="上机时间" header-align="center" align="center">
  488. <template v-slot:default="scope">
  489. <el-input v-if="scope.row.isEditing" v-model="scope.row.startTime" placeholder="请输入上机时间" @blur.stop.prevent="handleInputBlur(scope.row)">></el-input>
  490. <span v-else>{{ scope.row.startTime }}</span>
  491. </template>
  492. </el-table-column>
  493. <el-table-column prop="plannedEndTime" label="计划下机时间" header-align="center" align="center">
  494. <template v-slot:default="scope">
  495. <el-input v-if="scope.row.isEditing" :ref="'input'+scope.$index" v-model="scope.row.plannedEndTime" placeholder="请输入计划下机时间" @blur="handleInputBlur(scope.row)">></el-input>
  496. <span v-else>{{ scope.row.plannedEndTime }}</span>
  497. </template>
  498. </el-table-column>
  499. <el-table-column prop="planStatus" label="计划状态" header-align="center" align="center" width="100px">
  500. <template v-slot:default="scope">
  501. <!--上机变停机待机-->
  502. <el-select v-if="scope.row.planStatus==1" v-model="scope.row.planStatus" placeholder="计划状态" >
  503. <el-option v-for="stateItem in stateList1" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  504. </el-select>
  505. <!--待机可以上机-->
  506. <el-select v-if="scope.row.planStatus==0" v-model="scope.row.planStatus" placeholder="计划状态" >
  507. <el-option v-for="stateItem in stateList0" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  508. </el-select>
  509. <!--停机变上机-->
  510. <el-select v-if="scope.row.planStatus==2" v-model="scope.row.planStatus" placeholder="计划状态" >
  511. <el-option v-for="stateItem in stateList2" :key="stateItem.id" :label="stateItem.name" :value="stateItem.id" ></el-option>
  512. </el-select>
  513. </template>
  514. </el-table-column>
  515. <el-table-column label="操作" align="center" width="200px">
  516. <template slot-scope="scope">
  517. <el-button
  518. size="mini"
  519. type="danger"
  520. @click.stop.prevent="updateStatus(scope.$index, scope.row)">更新状态</el-button>
  521. <el-button
  522. size="mini"
  523. type="danger"
  524. @click.stop.prevent="deletePlan(scope.$index, scope.row)">删除</el-button>
  525. </template>
  526. </el-table-column>
  527. </el-table>
  528. <span slot="footer" class="dialog-footer">
  529. <el-button @click="beiUpdateDialogTableVisible = false">取 消</el-button>
  530. <el-button type="primary" @click="beiUpdateDialogTableVisible = false">确 定</el-button>
  531. </span>
  532. </el-dialog>
  533. </el-tab-pane>
  534. <!--停机弹窗-->
  535. <el-dialog title="修改机台状态" :visible.sync="modifyMachineStatus" width="500px">
  536. <el-form :model="modifyMachineStatusFrom" ref="modifyMachineStatusFrom" label-width="100px" class="demo-ruleForm">
  537. <el-form-item label="机台状态" prop="type">
  538. <el-checkbox-group v-model="modifyMachineStatusFrom.type">
  539. <el-checkbox label="1" name="type">A面停机</el-checkbox>
  540. <el-checkbox label="2" name="type">B面停机</el-checkbox>
  541. </el-checkbox-group>
  542. </el-form-item>
  543. <el-form-item>
  544. <el-button type="primary" @click="confirmStopProductionLine">确定</el-button>
  545. <el-button>取消</el-button>
  546. </el-form-item>
  547. </el-form>
  548. </el-dialog>
  549. </el-tabs>
  550. </div>
  551. </template>
  552. <script>
  553. import {
  554. ammunitionPlanInfo,
  555. getProductsInfo,
  556. removeBombLoadingPlan,
  557. getMaterielInfo,
  558. addMaterielInfo,
  559. getSalesman,
  560. getAllPlanListByMachineId,
  561. getAllPlanListByProductTypeAndStatus, updatePlanOne, whetherTheFeederIsShutDown, updateLineStates
  562. } from "@/api/plan/paln.js";
  563. export default {
  564. data() {
  565. return {
  566. modifyMachineStatusFrom:{
  567. type: [],
  568. },
  569. modifyMachineStatus:false,
  570. //选中的是那个车间
  571. selectedWorkshop:"南车间",
  572. tableData:[],
  573. isDisabled:true,
  574. form: {
  575. product:"",
  576. },
  577. previousMachineId: undefined,
  578. currentRowspan: 1,
  579. prevRow: {},
  580. tableData2: [],
  581. nanInsertDialogTableVisible:false,
  582. nanUpdateDialogTableVisible:false,
  583. beiInsertDialogTableVisible:false,
  584. beiUpdateDialogTableVisible:false,
  585. editingRowIndex: -1,
  586. lastEditLine:0,
  587. queryParams:{ productionLineDepartment:"加弹部",
  588. productionLineWorkshop:"南车间"},
  589. isEditLine:false,
  590. productsInfo:[],
  591. salesmanInfo:[],
  592. product:{},
  593. materiel:{},
  594. // 机台号
  595. machineId:"",
  596. // 待机/上机/停产
  597. stateList0:[
  598. {"id":0,"name":"待机"},
  599. {"id":1,"name":"上机"},
  600. ],
  601. stateList1:[
  602. {"id":0,"name":"待机"},
  603. {"id":2,"name":"停机"},
  604. {"id":1,"name":"上机"},
  605. {"id":3,"name":"已完成"},
  606. ],
  607. stateList2:[
  608. {"id":0,"name":"待机"},
  609. {"id":2,"name":"停机"},
  610. {"id":1,"name":"上机"},
  611. ],
  612. formData:{
  613. updateSelectedProductCategory:"",
  614. updateSelectedProductState:""
  615. },
  616. // 产品类别
  617. productTypeList:[{value:"A面",lable:"A面"},{value:"B面",lable:"B面"}],
  618. }
  619. },
  620. mounted() {
  621. // 得到排产计划信息
  622. this.getAmmunitionPlanInfo();
  623. // 得到业务员信息
  624. // this.getSalesman();
  625. this.getProductsInfo();
  626. },
  627. methods: {
  628. //删除计划
  629. deletePlan($index,row){
  630. console.log(row)
  631. removeBombLoadingPlan(row.id).then(res=>{
  632. if(res.code==200){
  633. this.$message({
  634. message: '删除成功',
  635. type: 'success'
  636. });
  637. }else{
  638. this.$message({message:"删除失败",type: 'error'})
  639. }
  640. this.onSubmit();
  641. this.getAmmunitionPlanInfo();
  642. })
  643. },
  644. //打开修改机台信息
  645. handleStopProductionLine(row){
  646. this.modifyMachineStatus=true;
  647. console.log("停机");
  648. this.machineId=row.machineId;
  649. // this.modifyMachineStatusFrom.type=[];
  650. // this.modifyMachineStatusFrom.type.push("1")
  651. // this.modifyMachineStatusFrom.type.push("2")
  652. //当前操作机台号
  653. this.machineId=row.machineId;
  654. //查询当前机台A、面B面的状态
  655. whetherTheFeederIsShutDown(this.machineId).then(res=>{
  656. this.modifyMachineStatusFrom.type=res.data;
  657. })
  658. },
  659. //确认修改产线信息
  660. confirmStopProductionLine(){
  661. console.log(this.modifyMachineStatusFrom.type);
  662. if(this.modifyMachineStatusFrom.type.length==0){
  663. this.modifyMachineStatusFrom.type.push("3")
  664. }
  665. //更改状态
  666. updateLineStates(this.machineId,this.modifyMachineStatusFrom.type.join(",")).then(res=>{
  667. if(res.code==200){
  668. this.$message({
  669. message: '修改状态成功',
  670. type: 'success'
  671. });
  672. }else{
  673. this.$message({message:"修改状态成功",type: 'error'})
  674. }
  675. this.modifyMachineStatus=false;
  676. this.getAmmunitionPlanInfo();
  677. })
  678. // //如果为空代表都不停机
  679. // if(this.modifyMachineStatusFrom.type.length<=0){
  680. // this.modifyMachineStatus=false;
  681. // //发送请求删除,A面-timestampRandomCode="停机" B-timestampRandomCode="停机"的数据、并把所有上机产品的状态改为上机
  682. // return;
  683. // }
  684. // // 包含1A停机---插入一条 timestampRandomCode=停机,状态为停机的数据
  685. // if (this.modifyMachineStatusFrom.type.includes("1")) {
  686. // //查询当前机台A、面B面的状态
  687. // whetherTheFeederIsShutDown(this.machineId).then(res=>{
  688. // //后台没有虚拟的假数据,就插入
  689. // if(!res.data.includes("1")){
  690. // console.log('数组中不包含数字 1');
  691. // //新增一条数据,
  692. // let aStopInfo= {
  693. // currentColorCode: '1',
  694. // //产品规格
  695. // currentSpecification: '1',
  696. // currentLotNumber: '1',
  697. // currentSpindleCount: '1',
  698. // number: '1',
  699. // productType:'A面',
  700. // startTime: '1',
  701. // plannedEndTime:'1',
  702. // planStatus:2,
  703. // productId:'1',
  704. // machineId:this.machineId,
  705. // salesmanId:'1',
  706. // timestampRandomCode:"停机",
  707. // }
  708. // let aStoptableList=[];
  709. // aStoptableList.push(aStopInfo)
  710. // //时间戳
  711. // let data={
  712. // //机台号
  713. // machineId: this.machineId,
  714. // //计划信息
  715. // detailsOfTheRefuelingPlans: aStoptableList
  716. // }
  717. // //添加计划信息
  718. // addMaterielInfo(data).then(response => {
  719. // if (response.code == 200) {
  720. // this.$message({
  721. // message: '停机成功',
  722. // type: 'success'
  723. // });
  724. // this.getAmmunitionPlanInfo();
  725. // //最后把弹窗关掉
  726. // this.nanInsertDialogTableVisible=false
  727. // //更改订单投产信息的批号,
  728. // } else {
  729. // this.$message({
  730. // message: '停机失败,请联系管理员',
  731. // type: 'error'
  732. // });
  733. // //最后把弹窗关掉
  734. // this.nanInsertDialogTableVisible=false
  735. // }
  736. // });
  737. // }
  738. // })
  739. // }
  740. // if(this.modifyMachineStatusFrom.type.includes("2")) {
  741. // whetherTheFeederIsShutDown(this.machineId).then(res=>{
  742. // if(!res.data.includes("2")) {
  743. // console.log('数组中不包含数字2');
  744. // //新增一条数据,
  745. // let aStopInfo= {
  746. // currentColorCode: '1',
  747. // //产品规格
  748. // currentSpecification: '1',
  749. // currentLotNumber: '1',
  750. // currentSpindleCount: '1',
  751. // number: '1',
  752. // productType:'B面',
  753. // startTime: '1',
  754. // plannedEndTime:'1',
  755. // planStatus:2,
  756. // productId:'1',
  757. // machineId:this.machineId,
  758. // salesmanId:'1',
  759. // timestampRandomCode:"停机",
  760. // }
  761. // let aStoptableList=[];
  762. // aStoptableList.push(aStopInfo)
  763. // //时间戳
  764. // let data={
  765. // //机台号
  766. // machineId: this.machineId,
  767. // //计划信息
  768. // detailsOfTheRefuelingPlans: aStoptableList
  769. // }
  770. // //添加计划信息
  771. // addMaterielInfo(data).then(response => {
  772. // if (response.code == 200) {
  773. // this.$message({
  774. // message: '停机成功',
  775. // type: 'success'
  776. // });
  777. // this.getAmmunitionPlanInfo();
  778. // //最后把弹窗关掉
  779. // this.nanInsertDialogTableVisible=false
  780. // //更改订单投产信息的批号,
  781. // } else {
  782. // this.$message({
  783. // message: '停机失败,请联系管理员',
  784. // type: 'error'
  785. // });
  786. // //最后把弹窗关掉
  787. // this.nanInsertDialogTableVisible=false
  788. // }
  789. // });
  790. // }
  791. // })
  792. // }
  793. },
  794. // 查询排产信息
  795. getAmmunitionPlanInfo() {
  796. ammunitionPlanInfo(this.queryParams).then((response) => {
  797. this.tableData = response.data
  798. });
  799. },
  800. // 合并单元格
  801. spanMethod2({ row, column, rowIndex, columnIndex }) {
  802. //第二列合并
  803. if (columnIndex === 1) {
  804. if(row.productType == null) {
  805. return;
  806. }
  807. const prevRow2 = this.tableData[rowIndex - 1]; // 上一行数据
  808. let nextRow2 = this.tableData[rowIndex + 1]; // 下一行数据
  809. // 当上一行的数据(machineId和productType)等于当前行数据时,当前行单元格隐藏
  810. if (
  811. prevRow2 &&
  812. prevRow2.machineId === row.machineId &&
  813. prevRow2.productType === row.productType
  814. ) {
  815. return { rowspan: 0, colspan: 0 };
  816. } else {
  817. // 反之,则循环判断若下一行数据(machineId和productType)等于当前行数据,则当前行开始进行合并单元格
  818. let countRowspan2 = 1; // 用于合并计数多少单元格
  819. while (
  820. nextRow2 &&
  821. nextRow2.machineId === row.machineId &&
  822. nextRow2.productType === row.productType
  823. ) {
  824. nextRow2 = this.tableData[++countRowspan2 + rowIndex];
  825. }
  826. if (countRowspan2 > 1) {
  827. return { rowspan: countRowspan2, colspan: 1 };
  828. }
  829. }
  830. }
  831. //待生产列表
  832. if (columnIndex === 8) {
  833. const prevRow2 = this.tableData[rowIndex - 1] //上一行数据
  834. let nextRow2 = this.tableData[rowIndex + 1] //下一行数据
  835. // 当上一行的数据等于当前行数据时,当前行单元格隐藏
  836. if(row.listOfPendingProduction==null||row.listOfPendingProduction==undefined|| row.listOfPendingProduction==""){
  837. return;
  838. }
  839. if (prevRow2 &&
  840. prevRow2.machineId === row.machineId &&
  841. prevRow2.productType === row.productType
  842. ) {
  843. return { rowspan: 0, colspan: 0 }
  844. } else {
  845. // 反之,则循环判断若下一行数据等于当前行数据,则当前行开始进行合并单元格
  846. let countRowspan2 = 1 //用于合并计数多少单元格
  847. while (nextRow2 &&
  848. nextRow2.listOfPendingProduction === row.listOfPendingProduction&&
  849. nextRow2.machineId === row.machineId &&
  850. nextRow2.productType === row.productType
  851. ) {
  852. nextRow2 = this.tableData[++countRowspan2 + rowIndex]
  853. }
  854. if (countRowspan2 > 1) {
  855. return { rowspan: countRowspan2, colspan: 1 }
  856. }
  857. }
  858. }
  859. //合并最后一列操作列
  860. const lastColumnIndex = this.$refs.tableRef.store.states.columns.length - 1; // 获取表格最后一列的索引
  861. if (columnIndex === lastColumnIndex && column.label === '操作') { // 判断是否为最后一列且标签为'操作'
  862. const machineIdColumnIndex = 0; // 机台号列的索引假定为0
  863. const currentMachineId = row.machineId;
  864. let countRowspan = 1;
  865. const prevRow = this.tableData[rowIndex - 1];
  866. if (prevRow && prevRow.machineId === currentMachineId) {
  867. return { rowspan: 0, colspan: 0 };
  868. } else {
  869. let nextRow = this.tableData[rowIndex + 1];
  870. while (
  871. nextRow &&
  872. nextRow.machineId === currentMachineId
  873. ) {
  874. nextRow = this.tableData[++countRowspan + rowIndex];
  875. }
  876. if (countRowspan > 1) {
  877. return { rowspan: countRowspan, colspan: 1 };
  878. }
  879. }
  880. }
  881. //第一列机台号合并
  882. if (columnIndex === 0) {
  883. //定义需要合并的列字段,有哪些列需要合并,就自定义添加字段即可
  884. const fields = ['machineId']
  885. // 当前行的数据
  886. const cellValue = row[column.property]
  887. let countRowspan = 1 //用于合并计数多少单元格
  888. // 判断只合并定义字段的列数据
  889. if (cellValue && fields.includes(column.property)) {
  890. const prevRow = this.tableData[rowIndex - 1] //上一行数据
  891. let nextRow = this.tableData[rowIndex + 1] //下一行数据
  892. // 当上一行的数据等于当前行数据时,当前行单元格隐藏
  893. if (prevRow && prevRow[column.property] === cellValue) {
  894. return { rowspan: 0, colspan: 0 }
  895. } else {
  896. // 反之,则循环判断若下一行数据等于当前行数据,则当前行开始进行合并单元格
  897. let countRowspan = 1 //用于合并计数多少单元格
  898. while (nextRow && nextRow[column.property] === cellValue) {
  899. nextRow = this.tableData[++countRowspan + rowIndex]
  900. }
  901. if (countRowspan > 1) {
  902. return { rowspan: countRowspan, colspan: 1 }
  903. }
  904. }
  905. }
  906. }
  907. },
  908. //查询产品的业务员信息
  909. // getSalesman() {
  910. // getSalesman().then((response) => {
  911. // this.salesmanInfo = response.data;
  912. // })
  913. // },
  914. // //业务员下拉框切换调用的函数
  915. // selectedSalesmanItem(row,saleNo,index){
  916. // this.getProductsInfo(saleNo,index);
  917. // },
  918. // //待投产的产品数据
  919. // getProductsInfo(saleNo,sy) {
  920. // getProductsInfo(saleNo,sy).then((response) => {
  921. // this.productsInfo = response.data;
  922. // this.productsInfo.forEach(item => {
  923. // item.productName = item.productName+"—"+item.materieEncoding+item.materieColorNumber
  924. // });
  925. // })
  926. // },
  927. getProductsInfo() {
  928. getProductsInfo().then((response) => {
  929. this.productsInfo = response.data;
  930. this.productsInfo.forEach(item => {
  931. item.productName = item.productName+"—"+item.materieEncoding+item.materieColorNumber
  932. });
  933. })
  934. },
  935. // 下拉框数据改变查询色号批号信息
  936. selectedChangeDate(row,selectedProduct) {
  937. //选择的那个销售产品
  938. this.product = this.productsInfo.find(product => product.id === selectedProduct);
  939. this.form.product=selectedProduct;
  940. //通过母粒编码查询到对应的母粒信息
  941. let queryParams = {
  942. "materielCode": this.product.colourNumber
  943. }
  944. //得到对应的母粒信息
  945. getMaterielInfo(queryParams).then((response) => {
  946. if (response.data!=null) {
  947. this.materiel = response.data;
  948. //色号 母粒编码+色号
  949. row.currentColorCode = this.materiel.materieEncoding+"("+this.materiel.materieColorNumber+")";
  950. }
  951. });
  952. //isDisabled(有批号就用,没批号就自己输入)
  953. if(this.product.lotNumber!=undefined&&this.product.lotNumber!=""){
  954. row.currentLotNumber=this.product.lotNumber;
  955. this.isDisabled=true;
  956. }else {
  957. this.isDisabled=false;
  958. }
  959. //产品规格
  960. row.currentSpecification= this.product.productSpecifications;
  961. //销售单编号(以前打算存的是业务员信息后来存的是销售单编号)
  962. row.salesmanId=this.product.saleOrderNo;
  963. },
  964. // 新增计划产品信息
  965. handleAddPlan(row) {
  966. //查询当前机台A、面B面的状态
  967. whetherTheFeederIsShutDown(row.machineId).then(res=>{
  968. this.modifyMachineStatusFrom.type=res.data;
  969. if(this.modifyMachineStatusFrom.type.includes("2")&&this.modifyMachineStatusFrom.type.includes("1")){
  970. this.$message({
  971. message: 'AB都已停机请更改机台状态',
  972. type: 'warning'
  973. });
  974. return;
  975. }else {
  976. if(this.modifyMachineStatusFrom.type.includes("1")){
  977. this.productTypeList=[]
  978. this.productTypeList.push({value:"B面",lable:"B面"})
  979. }
  980. if(this.modifyMachineStatusFrom.type.includes("2")){
  981. this.productTypeList=[]
  982. this.productTypeList.push({value:"A面",lable:"A面"})
  983. }
  984. if(this.modifyMachineStatusFrom.type.length<=0){
  985. this.productTypeList=[]
  986. this.productTypeList.push({value:"A面",lable:"A面"})
  987. this.productTypeList.push({value:"B面",lable:"B面"})
  988. }
  989. //否则就打开弹窗添加计划
  990. if(this.selectedWorkshop=="南车间"){
  991. this.nanInsertDialogTableVisible = true
  992. }else{
  993. this.beiInsertDialogTableVisible = true
  994. }
  995. this.tableData2=[]
  996. //先清空
  997. this.machineId=""
  998. //当前操作机台号
  999. this.machineId=row.machineId;
  1000. }
  1001. })
  1002. },
  1003. // tab栏点击切换
  1004. tabClick(tab, event) {
  1005. // console.log('当前点击的标签名称:', tab.name);
  1006. this.selectedWorkshop = tab.name;
  1007. // productionLineName getProductionLineNo productionLineDepartment productionLineWorkshop
  1008. this.queryParams.productionLineWorkshop = tab.name;
  1009. this.getAmmunitionPlanInfo();
  1010. },
  1011. // 删除行
  1012. handleDelete(index, row) {
  1013. // console.log(index,row)
  1014. // this.tableData2[a];
  1015. this.tableData2.splice(index, 1);
  1016. // 把上一编辑行置回-1
  1017. this.editingRowIndex = -1;
  1018. },
  1019. // 点击编辑行
  1020. handleRowClick(row) {
  1021. this.isEditLine = true;
  1022. // alert(this.lastEditLine+"编辑行")
  1023. //找到当前行的编辑索引
  1024. var rowIndex = this.tableData2.indexOf(row);
  1025. if (this.lastEditLine != 0 &&
  1026. this.editingRowIndex !== rowIndex &&
  1027. this.editingRowIndex !== -1 &&
  1028. !this.isRowFilled(this.tableData2[this.lastEditLine])) {
  1029. this.$message({
  1030. message: '请先完成上一条数据的填写',
  1031. type: 'warning'
  1032. });
  1033. return;
  1034. }
  1035. //编辑索引不等于当前编辑行索引
  1036. if (this.editingRowIndex !== rowIndex) {
  1037. // alert(this.editingRowIndex);
  1038. if (this.editingRowIndex !== -1) {
  1039. //把当前行变成不可编辑的
  1040. this.tableData2[this.editingRowIndex].isEditing = false;
  1041. }
  1042. //把当前行变成可编辑的
  1043. row.isEditing = true;
  1044. this.editingRowIndex = rowIndex;
  1045. }
  1046. },
  1047. // 光标失去焦点变成不可编辑
  1048. handleInputBlur(row) {
  1049. let rowIndex = this.tableData2.indexOf(row);
  1050. //编辑索引不等于当前编辑行索引
  1051. if (this.editingRowIndex !== rowIndex) {
  1052. if (this.isRowFilled(row)) {
  1053. row.isEditing = false;
  1054. //对于整个表格来说
  1055. this.isEditLine = false;
  1056. //当前编辑行置为-1
  1057. this.editingRowIndex = -1;
  1058. }
  1059. }
  1060. },
  1061. // 检查行是否填写完毕的示例方法
  1062. isRowFilled(row) {
  1063. return row.currentSpecification && row.currentSpindleCount && row.number && row.startTime && row.plannedEndTime;
  1064. },
  1065. // 新增一行标记为可编辑
  1066. addEditableRow() {
  1067. // 检查当前编辑行是否已填写完毕
  1068. if(this.tableData2.length!=0){
  1069. if (this.editingRowIndex !== -1 && !this.isRowFilled(this.tableData2[this.editingRowIndex])) {
  1070. this.$message({
  1071. message: '请先完成上一条数据的填写',
  1072. type: 'warning'
  1073. });
  1074. return;
  1075. }
  1076. //新增行之前先让以前的行不能编辑
  1077. this.tableData2.forEach(item => {
  1078. item.isEditing = false;
  1079. })
  1080. }
  1081. this.tableData2.push({
  1082. currentColorCode: '',
  1083. currentSpecification: '',
  1084. currentLotNumber: '',
  1085. currentSpindleCount: '',
  1086. number: '',
  1087. startTime: '',
  1088. plannedEndTime:'',
  1089. planStatus:0,
  1090. productId:'',
  1091. salesmanId:'',
  1092. isEditing: true // 标记为正在编辑状态
  1093. });
  1094. this.editingRowIndex = this.tableData2.length - 1; // 更新当前编辑的行索引
  1095. this.lastEditLine = this.tableData2.length - 1
  1096. },
  1097. // 添加计划
  1098. addPlanInfo(){
  1099. if(this.tableData2.length<=0){
  1100. this.$message({
  1101. message: '请先添加表格数据',
  1102. type: 'warning'
  1103. });
  1104. return;
  1105. }
  1106. const datatime=Date.now()+this.machineId;
  1107. //处理表格数据
  1108. this.tableData2.forEach(item=>{
  1109. item.timestampRandomCode=datatime;
  1110. item.machineId=this.machineId;
  1111. })
  1112. //时间戳
  1113. let data={
  1114. //机台号
  1115. machineId: this.machineId,
  1116. timestampRandomCode:datatime,
  1117. //计划信息
  1118. detailsOfTheRefuelingPlans: this.tableData2
  1119. }
  1120. //添加计划信息
  1121. addMaterielInfo(data).then(response => {
  1122. if (response.code == 200) {
  1123. this.$message({
  1124. message: '添加成功',
  1125. type: 'success'
  1126. });
  1127. this.getAmmunitionPlanInfo();
  1128. //最后把弹窗关掉
  1129. this.nanInsertDialogTableVisible=false
  1130. //更改订单投产信息的批号,
  1131. } else {
  1132. this.$message({
  1133. message: '添加失败',
  1134. type: 'error'
  1135. });
  1136. //最后把弹窗关掉
  1137. this.nanInsertDialogTableVisible=false
  1138. }
  1139. });
  1140. },
  1141. // 修改产品计划
  1142. handleEditPlan(row) {
  1143. this.tableData2=[];
  1144. //弹窗
  1145. if(this.selectedWorkshop=="南车间"){
  1146. this.nanUpdateDialogTableVisible = true
  1147. }else{
  1148. this.beiUpdateDialogTableVisible = true
  1149. }
  1150. //先清空
  1151. this.machineId=""
  1152. //当前操作机台号
  1153. this.machineId=row.machineId;
  1154. getAllPlanListByMachineId(row.machineId).then((response) => {
  1155. //得到生产中,停产的,待产的
  1156. response.data.forEach(item => {
  1157. item.isEditing=false;
  1158. item.planStatus=parseInt(item.planStatus);
  1159. item.productId=parseInt(item.productId)
  1160. })
  1161. this.tableData2=response.data;
  1162. // console.log( this.tableData2)
  1163. // 在数据加载完成后,手动触发每个行的第一个下拉框的 change 事件
  1164. this.$nextTick(() => {
  1165. // 获取第一个业务员选择框(假设表格只有一行)
  1166. for (let i = 0; i < this.tableData2.length; i++) {
  1167. const firstSalesmanSelect = this.$refs['salesmanSelect'+i];
  1168. // 触发 change 事件
  1169. if (firstSalesmanSelect) {
  1170. firstSalesmanSelect.$emit('change', {
  1171. target: {value: "ddd"},
  1172. });
  1173. }
  1174. }
  1175. });
  1176. })
  1177. },
  1178. //重置按钮
  1179. reset(){
  1180. this.tableData2=[];
  1181. //弹窗
  1182. if(this.selectedWorkshop=="南车间"){
  1183. this.nanUpdateDialogTableVisible = true
  1184. }else{
  1185. this.beiUpdateDialogTableVisible = true
  1186. }
  1187. console.log(this.machineId,"dddd")
  1188. getAllPlanListByMachineId(this.machineId).then((response) => {
  1189. //得到生产中,停产的,待产的
  1190. response.data.forEach(item => {
  1191. item.isEditing=false;
  1192. item.planStatus=parseInt(item.planStatus);
  1193. item.productId=parseInt(item.productId)
  1194. })
  1195. this.tableData2=response.data;
  1196. // console.log( this.tableData2)
  1197. // 在数据加载完成后,手动触发每个行的第一个下拉框的 change 事件
  1198. this.$nextTick(() => {
  1199. // 获取第一个业务员选择框(假设表格只有一行)
  1200. for (let i = 0; i < this.tableData2.length; i++) {
  1201. const firstSalesmanSelect = this.$refs['salesmanSelect'+i];
  1202. // 触发 change 事件
  1203. if (firstSalesmanSelect) {
  1204. firstSalesmanSelect.$emit('change', {
  1205. target: {value: "ddd"},
  1206. });
  1207. }
  1208. }
  1209. });
  1210. })
  1211. },
  1212. //弹窗里边的点击查询
  1213. onSubmit(){
  1214. this.formData.machineId=this.machineId;
  1215. getAllPlanListByProductTypeAndStatus(this.formData).then(response => {
  1216. //得到生产中,停产的,待产的
  1217. response.data.forEach(item => {
  1218. item.isEditing=false;
  1219. item.planStatus=parseInt(item.planStatus);
  1220. })
  1221. this.tableData2=response.data;
  1222. });
  1223. },
  1224. //更新状态
  1225. updateStatus(ind, row){
  1226. // console.log(row);
  1227. updatePlanOne(row).then(response=>{
  1228. if (response.code == 200) {
  1229. this.$message({
  1230. message: '修改成功',
  1231. type: 'success'
  1232. });
  1233. this.getAmmunitionPlanInfo();
  1234. //最后把弹窗关掉
  1235. this.nanInsertDialogTableVisible=false
  1236. } else {
  1237. this.$message({
  1238. message: '修改失败',
  1239. type: 'error'
  1240. });
  1241. //最后把弹窗关掉
  1242. this.nanInsertDialogTableVisible=false
  1243. }
  1244. })
  1245. }
  1246. },
  1247. computed: {
  1248. },
  1249. }
  1250. </script>
  1251. <style scoped>
  1252. .el-tabs--border-card >>> .el-tabs__content {
  1253. padding: 0 !important;
  1254. }
  1255. .el-table__body-wrapper {
  1256. cursor: grab;
  1257. }
  1258. .el-table__body-wrapper.grabbing {
  1259. cursor: grabbing;
  1260. }
  1261. </style>