index.vue 25 KB

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