index.vue 28 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001
  1. <template>
  2. <div>
  3. <layout>
  4. <layout-header>
  5. <!-- 按钮 -->
  6. <el-form inline>
  7. <el-form-item>
  8. <el-input
  9. v-model="searchInfo"
  10. placeholder="搜索产品编号或产品名称"
  11. clearable
  12. style="width: 180px;"
  13. />
  14. <el-button
  15. type="primary"
  16. icon="Search"
  17. class="search"
  18. @click="handleSearch"
  19. />
  20. <el-button
  21. type="primary"
  22. icon="edit"
  23. class="bt"
  24. @click="handleShowDetail"
  25. ><i class="el-icon-edit" />查改
  26. </el-button>
  27. <el-button
  28. type="primary"
  29. icon="edit"
  30. class="bt"
  31. @click="handleShowAdd"
  32. >新增
  33. </el-button>
  34. <el-button
  35. type="primary"
  36. icon="delete"
  37. class="bt"
  38. @click="handleDelete"
  39. >删除
  40. </el-button>
  41. </el-form-item>
  42. </el-form>
  43. <!-- 弹出框 -->
  44. <div>
  45. <el-dialog v-model="dialogFormVisible" :title="type" destroy-on-close width="1200px" >
  46. <el-form id="detail-form" :model="detailData" inline label-position="left" @keyup="moveFocus" >
  47. <el-form-item label="日期" >
  48. <el-input type="date" max="9999-12-31" @focus="rqHandleFocus()" v-model="detailData.sczl_rq" style="width: 120px;"/>
  49. </el-form-item>
  50. <el-form-item label="员工编号" >
  51. <el-input v-model="detailData.sczl_bh" style="width: 100px;" placeholder="Enter回车" />
  52. <el-input v-model="detailData.name" style="width: 100px; padding-left: 5px;" @click="selectvalue($event)" readonly />
  53. </el-form-item>
  54. <el-form-item label="组别">
  55. <el-select v-model="detailData.sczl_bzdh" placeholder=" " style="width: 80px" >
  56. <el-option label="A班" value="A班" />
  57. <el-option label="B班" value="B班" />
  58. </el-select>
  59. </el-form-item>
  60. <br>
  61. <el-form-item label="计时时数" style="padding-left: 195px;" >
  62. <el-input v-model="detailData.sczl_jsss" style="width: 100px;" @click="selectvalue($event)" />
  63. </el-form-item>
  64. <el-form-item label="冲月定额">
  65. <el-select v-model="detailData.sczl_冲定额" placeholder=" " style="width: 100px" >
  66. <el-option label="" value="" />
  67. <el-option label="是" value="是" />
  68. </el-select>
  69. </el-form-item>
  70. <el-table
  71. :data="detailData.table"
  72. border
  73. tooltip-effect="dark"
  74. :row-style="{ height: '20px' }"
  75. :cell-style="{ padding: '0px' }"
  76. :header-row-style="{ height: '20px' }"
  77. :header-cell-style="{ padding: '0px' }" >
  78. <el-table-column label="工单编号" width="100" >
  79. <template #default="{ row, $index }">
  80. <el-input v-model="row.sczl_gdbh" placeholder="Enter回车" @keyup.enter="handleEnter($index, row)" />
  81. </template>
  82. </el-table-column>
  83. <el-table-column label="印件工序" width="100" >
  84. <template #default="{ row }">
  85. <el-input v-model="row.sczl_yjGx" readonly />
  86. </template>
  87. </el-table-column>
  88. <el-table-column label="工序名称" width="100" >
  89. <template #default="{ row }">
  90. <el-input v-model="row.sczl_gxmc" readonly />
  91. </template>
  92. </el-table-column>
  93. <el-table-column label="印件名称">
  94. <template #default="{ row }">
  95. <el-input v-model="row.Gd_cpmc" readonly />
  96. </template>
  97. </el-table-column>
  98. <el-table-column label="包装产量" width="100" >
  99. <template #default="{ row }">
  100. <el-input v-model="row.sczl_cl" />
  101. </template>
  102. </el-table-column>
  103. <el-table-column label="返工产量" width="100" >
  104. <template #default="{ row }">
  105. <el-input v-model="row.sczl_返工产量" />
  106. </template>
  107. </el-table-column>
  108. <el-table-column label="每箱数量" width="100" >
  109. <template #default="{ row }">
  110. <el-input v-model="row.sczl_PgCl" />
  111. </template>
  112. </el-table-column>
  113. <el-table-column label="计产系数" width="100" >
  114. <template #default="{ row }">
  115. <el-input v-model="row.sczl_计产系数" />
  116. </template>
  117. </el-table-column>
  118. <el-table-column label="来源" width="100" >
  119. <template #default="{ row }">
  120. <el-input v-model="row.sczl_Jtbh1" />
  121. </template>
  122. </el-table-column>
  123. <el-table-column label="定额代号" width="130" >
  124. <template #default="{ row, $index }">
  125. <el-input v-model="row.sczl_dedh" @keyup.enter="getDedhsubmit($index, row)" />
  126. </template>
  127. </el-table-column>
  128. </el-table>
  129. <el-form-item label="其他备注" style="margin-top: 10px;" >
  130. <el-input v-model="detailData.sczl_desc" />
  131. </el-form-item>
  132. </el-form>
  133. <template #footer>
  134. <div class="dialog-footer">
  135. <el-button @click="dialogFormVisible = false">取 消</el-button>
  136. <el-button type="primary" @click="enterDialog" >确 定
  137. </el-button>
  138. </div>
  139. </template>
  140. </el-dialog>
  141. <!-- 新增定额代号 -->
  142. <el-dialog v-model="dedhsearchModel" :before-close="() => dedhsearchModel = false">
  143. <el-form>
  144. <div>
  145. <el-form-item label="定额代号 :" class="mab" prop="keyOrder">
  146. </el-form-item>
  147. <div style="border:1px solid #eee; width:100%; height: 400px; overflow-y: auto">
  148. <el-tree
  149. :data="dedhtreeData"
  150. :props="{
  151. children: 'children',
  152. label: 'label'
  153. }"
  154. @node-click="dedhhandleNodeClick"
  155. ></el-tree>
  156. </div>
  157. </div>
  158. </el-form>
  159. </el-dialog>
  160. <!-- 弹出选项框 -->
  161. <el-dialog
  162. v-model="dialogSelectVisible"
  163. title="选择"
  164. destroy-on-close
  165. width="600px"
  166. @keydown="selectCP($event)"
  167. >
  168. <el-table
  169. tooltip-effect="dark"
  170. :data="selectData"
  171. row-key="ID"
  172. highlight-current-row
  173. border
  174. style="width:100%"
  175. @row-dblclick="handleSelectClick"
  176. ref="table2"
  177. >
  178. <el-table-column
  179. prop="Gd_cpmc"
  180. label="产品名称"
  181. width="300"
  182. />
  183. <el-table-column
  184. prop="Gy0_gxmc"
  185. label="产品名称"
  186. width="100"
  187. />
  188. <el-table-column
  189. prop="jyGx"
  190. label="产品名称"
  191. width="100"
  192. />
  193. </el-table>
  194. </el-dialog>
  195. </div>
  196. </layout-header>
  197. <layout>
  198. <!-- 左侧树侧形结构-->
  199. <layout-sider
  200. :resize-directions="['right']"
  201. :width="220"
  202. style="margin-right: 10px;"
  203. >
  204. <div
  205. class="JKWTree-tree"
  206. style="height: 70vh;"
  207. >
  208. <h3>包装计件单据维护</h3>
  209. <el-tree
  210. :data="treeData"
  211. highlight-current
  212. @node-click="handleNodeClick"
  213. />
  214. </div>
  215. </layout-sider>
  216. <layout-content>
  217. <!-- 数据展示 -->
  218. <div class="gva-table-box">
  219. <el-table
  220. ref="table"
  221. style="width: 100%"
  222. :data="tableData"
  223. row-key="ID"
  224. highlight-current-row
  225. border
  226. show-overflow-tooltip
  227. :row-style="{ height: '20px' }"
  228. :cell-style="{ padding: '0px' }"
  229. :header-row-style="{ height: '20px' }"
  230. :header-cell-style="{ padding: '0px' }"
  231. @row-dblclick="handleShowDetail"
  232. @current-change="(row, oldRow) => { currentRow = row}"
  233. >
  234. <el-table-column
  235. type="selection"
  236. width="55"
  237. />
  238. <!-- 循环渲染列 -->
  239. <el-table-column
  240. v-for=" column in tableColumns "
  241. :key="column.prop"
  242. :prop="column.prop"
  243. :label="column.label"
  244. width="110"
  245. sortable
  246. />
  247. </el-table>
  248. <!-- 分页 -->
  249. <div class="gva-pagination">
  250. <el-pagination
  251. v-model:current-page="page"
  252. v-model:page-size="limit"
  253. layout="total, sizes, prev, pager, next, jumper"
  254. :page-sizes="[10, 30, 50, 100]"
  255. :total="total"
  256. @current-change="handleCurrentChange"
  257. @size-change="handleSizeChange"
  258. />
  259. </div>
  260. </div>
  261. </layout-content>
  262. </layout>
  263. </layout>
  264. </div>
  265. </template>
  266. <script setup>
  267. import { Layout, LayoutContent, LayoutHeader, LayoutSider } from '@arco-design/web-vue'
  268. import { ElMessage, ElMessageBox, dayjs } from 'element-plus'
  269. // import { Download, Search, Delete } from '@element-plus/icons-vue'
  270. import { reactive, ref } from 'vue'
  271. import { getGxMc, getInfo, getLocate, getPackingSideTable, getPackingTable, updatePackingTable, getYg, DeletePackingTable, addPackingTable, getDedh } from '@/api/mes_api_gty/myapi'
  272. import { useUserStore } from '@/pinia/modules/user'
  273. const userStore = useUserStore()
  274. const sys_id='['+userStore.userInfo.userName+'/'+userStore.userInfo.nickName+']'
  275. defineOptions({
  276. name: '06PackingDocuments',
  277. })
  278. // 侧边栏功能
  279. const treeData = reactive([])
  280. const getSideData = async() => {
  281. try {
  282. const response = await getPackingSideTable()
  283. if (response.code === 0) {
  284. const transformedData = response.data.map(item => ({
  285. label: `${item.date.replace(/-/g, '.')}【单据数: ${item.counts}张】`,
  286. children: item.sys.map(sysItem => ({
  287. label: `${sysItem.sys_id} 【记录数: ${sysItem.count}张】`,
  288. params: {
  289. date: item.date.replace(/\./g, '-'),
  290. sys_id: sysItem.sys_id,
  291. },
  292. })),
  293. }))
  294. treeData.splice(0, treeData.length, ...transformedData)
  295. }
  296. } catch (e) {
  297. console.log(e)
  298. }
  299. }
  300. getSideData()
  301. // 表格功能
  302. const tableColumns = [
  303. { label: '员工编号', prop: 'sczl_bh', width: '100' },
  304. { label: '员工姓名', prop: 'name', width: '100' },
  305. { label: '生产日期', prop: 'sczl_rq', width: '100' },
  306. { label: '班组', prop: 'sczl_bzdh', width: '100' },
  307. { label: '包装产量', prop: 'sczl_cl', width: '100' },
  308. { label: '返工产量', prop: 'sczl_fgsl', width: '100' },
  309. { label: '计件产量', prop: 'sczl_jjcl', width: '100' },
  310. { label: '相关工单', prop: 'sczl_gdbh1', width: '100' },
  311. { label: '创建用户', prop: 'sys_id', width: '120' },
  312. { label: '创建时间', prop: 'sys_rq', width: '180' },
  313. { label: '修改时间', prop: 'mod_rq', width: '180' },
  314. { label: 'UNIQID', prop: 'UniqId', width: '100' },
  315. ]
  316. const tableData = reactive([])
  317. const params = {
  318. type: '',
  319. date: '',
  320. sys_id: '',
  321. gdbh: '',
  322. }
  323. const total = ref(0)
  324. const page = ref(1)
  325. const limit = ref(10)
  326. const type = ref('')
  327. const searchInfo = ref('')
  328. const currentRow = ref({})
  329. // const multipleSelection = ref([])
  330. // 获取列表数据
  331. const getTableData = async() => {
  332. try {
  333. const response = await getPackingTable({
  334. date: params.date, sys_id: params.sys_id,
  335. page: page.value.toString(), limit: limit.value.toString(),
  336. })
  337. if (response.code === 0) {
  338. total.value = response.data.total
  339. tableData.splice(0, tableData.length, ...response.data.rows)
  340. setCurrent(tableData[0])
  341. }
  342. } catch (e) {
  343. console.log(e)
  344. }
  345. }
  346. // 获取定位数据
  347. const getLocateTable = async() => {
  348. try {
  349. const response = await getLocate({
  350. gdbh: params.gdbh,
  351. page: page.value.toString(), limit: limit.value.toString(),
  352. })
  353. if (response.code === 0) {
  354. total.value = response.data.total
  355. tableData.splice(0, tableData.length, ...response.data.rows)
  356. }
  357. } catch (e) {
  358. console.log(e)
  359. }
  360. }
  361. // 删除数据
  362. const deleteTableData = async(id) => {
  363. try {
  364. const res = await DeletePackingTable({ UniqId: id })
  365. if (res.code === 0) {
  366. return 0
  367. }
  368. } catch (e) {
  369. console.log(e)
  370. }
  371. }
  372. const handleNodeClick = (node, check) => {
  373. if (node.params) {
  374. params.date = node.params.date
  375. params.sys_id = node.params.sys_id
  376. params.type = 'getTableData'
  377. page.value = 1
  378. getTableData()
  379. }
  380. }
  381. const selectvalue = (e) => {
  382. console.log(e)
  383. e.currentTarget.select();
  384. }
  385. // 定位
  386. const handleSearch = () => {
  387. params.gdbh = searchInfo.value
  388. params.type = 'getLocateTable'
  389. page.value = 1
  390. getLocateTable()
  391. }
  392. // 查改
  393. const handleShowDetail = () => {
  394. type.value = '查改'
  395. console.log(currentRow.value)
  396. if(currentRow.value.UniqId==undefined){
  397. ElMessage({
  398. type: 'warning',
  399. message: '未选中记录',
  400. })
  401. return
  402. }else{
  403. getTableInfo(currentRow.value?.UniqId)
  404. }
  405. }
  406. // 删除
  407. const handleDelete = () => {
  408. if(currentRow.value.UniqId==undefined){
  409. ElMessage({
  410. type: 'warning',
  411. message: '未选中记录',
  412. })
  413. return
  414. }
  415. ElMessageBox.confirm(
  416. `确认删除这条数据么?`,
  417. '警告',
  418. {
  419. confirmButtonText: '确认',
  420. cancelButtonText: '取消',
  421. type: 'warning',
  422. }
  423. )
  424. .then(async() => {
  425. const ret = await deleteTableData(currentRow.value?.UniqId)
  426. if (ret === 0) {
  427. ElMessage({
  428. type: 'success',
  429. message: '删除成功',
  430. })
  431. getSideData()
  432. getTableData()
  433. } else {
  434. ElMessage({
  435. type: 'error',
  436. message: '删除失败',
  437. })
  438. }
  439. })
  440. .catch(() => {
  441. ElMessage({
  442. type: 'info',
  443. message: '取消删除',
  444. })
  445. })
  446. }
  447. // 分页
  448. // #region
  449. const handleSizeChange = () => {
  450. switch (params.type) {
  451. case 'getTableData':
  452. getTableData()
  453. break
  454. case 'getLocateTable':
  455. getLocateTable()
  456. break
  457. default:
  458. break
  459. }
  460. }
  461. const handleCurrentChange = () => {
  462. switch (params.type) {
  463. case 'getTableData':
  464. getTableData()
  465. break
  466. case 'getLocateTable':
  467. getLocateTable()
  468. break
  469. default:
  470. break
  471. }
  472. }
  473. // #endregion
  474. // 详情界面
  475. const detailData = reactive({
  476. UniqId: '',
  477. selectIndex: 0,
  478. sczl_rq: '',
  479. sczl_bh: '',
  480. name: '',
  481. sczl_bzdh: '',
  482. sczl_jsss: '',
  483. sczl_冲定额: '',
  484. sczl_desc: '',
  485. table: [],
  486. })
  487. const selectData = reactive([])
  488. const table = ref()
  489. // 弹窗控制标记
  490. const dialogFormVisible = ref(false)
  491. const dialogSelectVisible = ref(false)
  492. const setCurrent = (row) => {
  493. table.value?.setCurrentRow(row)
  494. }
  495. // 获取详细信息
  496. const getTableInfo = async(id) => {
  497. try {
  498. const response = await getInfo({ UniqId: id })
  499. if (response.code === 0) {
  500. const { sczl_rq, sczl_bh, name, sczl_bzdh, sczl_jsss, sczl_冲定额, sczl_desc, ...rest } = response.data
  501. Object.assign(detailData, { sczl_rq, sczl_bh, name, sczl_bzdh, sczl_jsss, sczl_冲定额, sczl_desc })
  502. detailData.table = Array.from({ length: 6 }, (_, i) => i + 1)
  503. .map(num => {
  504. return {
  505. sczl_gdbh: rest[`sczl_gdbh${num}`],
  506. sczl_yjGx: rest[`sczl_yjGx${num}`],
  507. sczl_gxmc: rest[`sczl_gxmc${num}`],
  508. Gd_cpmc: rest[`Gd_cpmc${num}`],
  509. sczl_cl: rest[`sczl_cl${num}`],
  510. sczl_返工产量: rest[`sczl_返工产量${num}`],
  511. sczl_PgCl: rest[`sczl_PgCl${num}`],
  512. sczl_计产系数: rest[`sczl_计产系数${num}`],
  513. sczl_Jtbh1: rest[`sczl_Jtbh${num}`],
  514. sczl_dedh: rest[`sczl_dedh${num}`],
  515. }
  516. })
  517. if (type.value === '新增') {
  518. console.log(detailData)
  519. detailData.name=''
  520. detailData.sczl_bh=''
  521. detailData.sczl_bzdh=''
  522. detailData.sczl_desc=''
  523. detailData.sczl_jsss=''
  524. detailData.sczl_rq=''
  525. detailData.table.forEach(row => {
  526. for (const key in row) {
  527. row[key] = '' // 清空每行的内容
  528. }
  529. })
  530. }else{
  531. detailData.UniqId = id
  532. dialogFormVisible.value = true
  533. }
  534. if (type.value === '新增' || type.value === '编辑') {
  535. detailData.UniqId = id
  536. dialogFormVisible.value = true
  537. // 在 setTimeout 中获取元素,确保在 DOM 渲染完毕后执行
  538. setTimeout(() => {
  539. formElements = document.getElementById('detail-form').elements
  540. formElements[0].focus()
  541. }, 0)
  542. }
  543. }
  544. } catch (e) {
  545. console.log(e)
  546. }
  547. }
  548. //日期获得焦点事件
  549. const rqHandleFocus = () =>{
  550. if(detailData.sczl_rq==''){
  551. detailData.sczl_rq = new Date().toISOString().split('T')[0]
  552. }
  553. }
  554. // 获取工序名称
  555. const getTableGxMc = async(index, row) => {
  556. try {
  557. const response = await getGxMc({ gdbh: row.sczl_gdbh })
  558. if (response.code === 0) {
  559. const { Gd_cpmc, Gy0_gxmc, jyGx } = response.data[0]
  560. if (response.data.length === 1) {
  561. detailData.table[index].Gd_cpmc = Gd_cpmc
  562. detailData.table[index].sczl_yjGx = jyGx
  563. detailData.table[index].sczl_gxmc = Gy0_gxmc
  564. } else {
  565. selectData.splice(0, selectData.length, ...response.data)
  566. setCPCurrent(selectData[0])
  567. detailData.selectIndex = index
  568. dialogSelectVisible.value = true
  569. }
  570. }
  571. } catch (e) {
  572. console.log(e)
  573. }
  574. }
  575. // 更新数据
  576. const updateDetailData = async() => {
  577. const restoredData = {
  578. UniqId: detailData.UniqId,
  579. sczl_rq: detailData.sczl_rq,
  580. sczl_bh: detailData.sczl_bh,
  581. name: detailData.name,
  582. sczl_bzdh: detailData.sczl_bzdh,
  583. sczl_jsss: detailData.sczl_jsss,
  584. sczl_冲定额: detailData.sczl_冲定额,
  585. sczl_desc: detailData.sczl_desc,
  586. }
  587. detailData.table.forEach((item, index, array) => {
  588. const num = index + 1
  589. restoredData[`sczl_gdbh${num}`] = item.sczl_gdbh
  590. restoredData[`sczl_yjGx${num}`] = item.sczl_yjGx
  591. restoredData[`sczl_gxmc${num}`] = item.sczl_gxmc
  592. restoredData[`Gd_cpmc${num}`] = item.Gd_cpmc
  593. restoredData[`sczl_cl${num}`] = item.sczl_cl
  594. restoredData[`sczl_返工产量${num}`] = item.sczl_返工产量
  595. restoredData[`sczl_PgCl${num}`] = item.sczl_PgCl
  596. restoredData[`sczl_计产系数${num}`] = item.sczl_计产系数
  597. restoredData[`sczl_Jtbh${num}`] = item.sczl_Jtbh1
  598. restoredData[`sczl_dedh${num}`] = item.sczl_dedh
  599. })
  600. const res = await updatePackingTable(restoredData)
  601. if (res.code === 0) {
  602. ElMessage({
  603. type: 'success',
  604. message: '更新成功',
  605. })
  606. dialogFormVisible.value = false
  607. }
  608. }
  609. // 新增数据
  610. const handleShowAdd = async() => {
  611. type.value = '新增'
  612. if(currentRow.value.UniqId==null){
  613. detailData.table = Array.from({ length: 6 }, (_, i) => i + 1)
  614. .map(num => {
  615. return {
  616. sczl_gdbh: '',
  617. sczl_yjGx: '',
  618. sczl_gxmc: '',
  619. Gd_cpmc: '',
  620. sczl_cl: '',
  621. sczl_返工产量: '',
  622. sczl_PgCl: '',
  623. sczl_计产系数: '',
  624. sczl_Jtbh1: '',
  625. sczl_dedh: '',
  626. }
  627. })
  628. setTimeout(() => {
  629. formElements = document.getElementById('detail-form').elements
  630. formElements[0].focus()
  631. }, 0)
  632. dialogFormVisible.value = true
  633. }else{
  634. await getTableInfo(currentRow.value?.UniqId)
  635. // 默认日期为前一天的日期
  636. const date = dayjs().subtract(1, 'day').format('YYYY-MM-DD')
  637. detailData.sczl_rq = date
  638. }
  639. }
  640. const addDetailData = async() => {
  641. const restoredData = {
  642. sys_id:sys_id,
  643. sczl_rq: detailData.sczl_rq,
  644. sczl_bh: detailData.sczl_bh,
  645. // name: detailData.name,
  646. sczl_bzdh: detailData.sczl_bzdh,
  647. sczl_jsss: detailData.sczl_jsss,
  648. sczl_冲定额: detailData.sczl_冲定额,
  649. sczl_desc: detailData.sczl_desc,
  650. }
  651. detailData.table.forEach((item, index, array) => {
  652. const num = index + 1
  653. restoredData[`sczl_gdbh${num}`] = item.sczl_gdbh
  654. restoredData[`sczl_yjGx${num}`] = item.sczl_yjGx
  655. restoredData[`sczl_gxmc${num}`] = item.sczl_gxmc
  656. // restoredData[`Gd_cpmc${num}`] = item.Gd_cpmc
  657. restoredData[`sczl_cl${num}`] = item.sczl_cl
  658. restoredData[`sczl_返工产量${num}`] = item.sczl_返工产量
  659. restoredData[`sczl_PgCl${num}`] = item.sczl_PgCl
  660. restoredData[`sczl_计产系数${num}`] = item.sczl_计产系数
  661. restoredData[`sczl_Jtbh${num}`] = item.sczl_Jtbh1
  662. restoredData[`sczl_dedh${num}`] = item.sczl_dedh
  663. })
  664. const res = await addPackingTable(restoredData)
  665. if (res.code === 0) {
  666. ElMessage({
  667. type: 'success',
  668. message: '新增成功',
  669. })
  670. dialogFormVisible.value = false
  671. if(params.date!=''){
  672. getTableData()
  673. }
  674. getSideData()
  675. }
  676. }
  677. const handleGetYg = async() => {
  678. if(detailData.sczl_bh==''){
  679. return
  680. }
  681. try {
  682. const res = await getYg({ sczl_bh: detailData.sczl_bh })
  683. if (res.code === 0) {
  684. detailData.sczl_bh = res.data[0].员工编号
  685. detailData.name = res.data[0].ygxm
  686. } else {
  687. detailData.name = ''
  688. }
  689. } catch (e) {
  690. console.log(e)
  691. }
  692. }
  693. // 处理选择框回车操作
  694. const handleEnter = (index, row) => {
  695. if (row.sczl_gdbh === '') {
  696. detailData.table[index].sczl_yjGx = ''
  697. detailData.table[index].sczl_gxmc = ''
  698. detailData.table[index].Gd_cpmc = ''
  699. } else {
  700. getTableGxMc(index, row)
  701. }
  702. }
  703. // 处理选择框
  704. const handleSelectClick = (row, column, event) => {
  705. const { Gd_cpmc, Gy0_gxmc, jyGx } = row
  706. const index = detailData.selectIndex
  707. detailData.table[index].Gd_cpmc = Gd_cpmc
  708. detailData.table[index].sczl_yjGx = jyGx
  709. detailData.table[index].sczl_gxmc = Gy0_gxmc
  710. dialogSelectVisible.value = false
  711. }
  712. const table2=ref()
  713. const setCPCurrent = (row) => {
  714. setTimeout(()=>{
  715. table2.value?.setCurrentRow(row)
  716. const { Gd_cpmc, Gy0_gxmc, jyGx } = row
  717. const index = detailData.selectIndex
  718. detailData.table[index].Gd_cpmc = Gd_cpmc
  719. detailData.table[index].sczl_yjGx = jyGx
  720. detailData.table[index].sczl_gxmc = Gy0_gxmc
  721. })
  722. }
  723. const CPIndex = ref(0);
  724. const JYCurrent = ref(0);
  725. const selectCP = (event) => {
  726. if (event.keyCode === 40) { // 向下箭头
  727. if (CPIndex.value < selectData.length - 1) {
  728. CPIndex.value++;
  729. setCPCurrent(selectData[CPIndex.value]);
  730. } else {
  731. CPIndex.value = 0;
  732. setCPCurrent(selectData[CPIndex.value]); // 到达最后一行时回到第一行
  733. }
  734. } else if (event.keyCode === 38) { // 向上箭头
  735. if (CPIndex.value > 0) {
  736. CPIndex.value--;
  737. setCPCurrent(selectData[CPIndex.value]);
  738. } else {
  739. CPIndex.value = selectData.length - 1;
  740. setCPCurrent(selectData[CPIndex.value]); // 到达第一行时回到最后一行
  741. }
  742. } else if (event.keyCode === 13) { // 回车键
  743. dialogSelectVisible.value = false
  744. }
  745. }
  746. // 弹窗确定
  747. const enterDialog = () => {
  748. if (type.value === '查改') {
  749. updateDetailData()
  750. } else if (type.value === '新增') {
  751. addDetailData()
  752. }
  753. }
  754. //新增定额代号
  755. const dedhsearchModel = ref(false)
  756. const dedhtreeData=ref([])
  757. const _index=ref(null)
  758. // 定额代号回车事件
  759. const getDedhsubmit = async (index, row) => {
  760. console.log(index)
  761. _index.value = index
  762. dedhsearchModel.value = true;
  763. const getPieceWorks = await getDedh();
  764. console.log(getPieceWorks);
  765. if (getPieceWorks.code === 0) {
  766. const transformedData2 = getPieceWorks.data.bh_mc.map(item => ({
  767. label: `${item.sys_mc}【${item.sys_bh}】`,
  768. params: { code: item.sys_bh },
  769. children: item.bh_mc?.map(sysItem => ({
  770. label: `${sysItem.sys_mc}【${sysItem.sys_bh}】`,
  771. params: { code: sysItem.sys_bh },
  772. children: sysItem.bh_mc?.map(syssItem => ({
  773. label: `${syssItem.sys_mc}【${syssItem.sys_bh}】`,
  774. params: { code: syssItem.sys_bh }
  775. })) || []
  776. })) || []
  777. }));
  778. dedhtreeData.value = transformedData2;
  779. }
  780. };
  781. // 点击定额代号
  782. const dedhhandleNodeClick = (node,check) => {
  783. console.log(node.params.code);
  784. detailData.table[_index.value].sczl_dedh = node.params.code
  785. }
  786. let formElements
  787. const moveFocus = (event) => {
  788. const index = Array.from(formElements).indexOf(event.target)
  789. const key = event.key
  790. event.preventDefault()
  791. switch (index) {
  792. case 0:
  793. if (key === 'ArrowDown') {
  794. formElements[1].focus()
  795. formElements[1].select()
  796. } else if (key === 'ArrowUp') {
  797. formElements[formElements.length - 1].focus()
  798. formElements[formElements.length - 1].select()
  799. } else if (key === 'Enter') {
  800. formElements[1].focus()
  801. formElements[1].select()
  802. }
  803. break
  804. case 1:
  805. if (key === 'ArrowDown') {
  806. formElements[3].focus()
  807. formElements[3].select()
  808. handleGetYg()
  809. } else if (key === 'ArrowUp') {
  810. formElements[0].focus()
  811. formElements[0].select()
  812. handleGetYg()
  813. } else if (key === 'Enter') {
  814. formElements[3].focus()
  815. formElements[3].select()
  816. handleGetYg()
  817. }
  818. break
  819. case 3:
  820. if (key === 'ArrowDown') {
  821. formElements[4].focus()
  822. formElements[4].select()
  823. } else if (key === 'ArrowUp') {
  824. formElements[1].focus()
  825. formElements[1].select()
  826. } else if (key === 'Enter') {
  827. formElements[4].focus()
  828. formElements[4].select()
  829. }
  830. break
  831. case formElements.length - 1 :
  832. if (key === 'ArrowDown') {
  833. formElements[0].focus()
  834. formElements[0].select()
  835. } else if (key === 'ArrowUp') {
  836. formElements[index - 1].focus()
  837. formElements[index - 1].select()
  838. } else if (key === 'Enter') {
  839. formElements[0].focus()
  840. formElements[0].select()
  841. }
  842. break
  843. default:
  844. if (key === 'ArrowDown') {
  845. formElements[index + 1].focus()
  846. formElements[index + 1].select()
  847. } else if (key === 'ArrowUp') {
  848. formElements[index - 1].focus()
  849. formElements[index - 1].select()
  850. } else if (key === 'Enter') {
  851. formElements[index + 1].focus()
  852. formElements[index + 1].select()
  853. }
  854. break
  855. }
  856. }
  857. </script>
  858. <style scoped>
  859. :deep(.plan-usage-low div) {
  860. color: red !important;
  861. }
  862. .JKWTree-container {
  863. display: flex;
  864. }
  865. .JKWTree-tree {
  866. width: 100%;
  867. background-color: #fff;
  868. /*background-color: rgba(241, 224, 224, 0.99);*/
  869. padding: 10px;
  870. margin-right: 20px;
  871. }
  872. .JKWTree-tree h3 {
  873. font-size: 15px;
  874. font-weight: 700;
  875. margin: 10px 0;
  876. }
  877. .JKWTree-content {
  878. flex: 1;
  879. }
  880. :deep(.el-table__body .warning-row) {
  881. background: #FFFF80 !important;
  882. }
  883. /* 选中某行时的背景色 */
  884. :deep(.el-table__body tr.current-row) > td {
  885. background: #ff80ff !important;
  886. }
  887. :deep(.el-table .bg-yellow) {
  888. background: yellow;
  889. }
  890. </style>
  891. <style scoped>
  892. :deep(.el-table td .cell) {
  893. line-height: 25px !important;
  894. }
  895. :deep(.el-tabs__header) {
  896. margin-bottom: 0;
  897. }
  898. .search {
  899. margin-left: 0px !important;
  900. margin-right: 10px !important;
  901. }
  902. .bt {
  903. margin-left: 2px !important;
  904. padding: 3px !important;
  905. font-size: 12px;
  906. }
  907. .el-tabs__header {
  908. margin: 0px !important;
  909. }
  910. .gva-table-box {
  911. padding: 0px !important;
  912. }
  913. .mab {
  914. margin-bottom: 5px;
  915. }
  916. </style>