index.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246
  1. <template>
  2. <div>
  3. <!-- Tab部分 使用 el-radio-group -->
  4. <el-radio-group v-model="currentTab" style="margin: 5px">
  5. <el-radio-button
  6. v-for="tab in tabs"
  7. :key="tab.dictValue"
  8. :label="tab.dictValue"
  9. >
  10. <template #default>
  11. <span v-if="tab.dictValue=='0'" class="el-icon-menu"></span>
  12. <span v-if="tab.dictValue=='1'" class="el-icon-folder-checked"></span>
  13. <span v-if="tab.dictValue=='2'" class="el-icon-sort"></span>
  14. <span v-if="tab.dictValue=='3'" class="el-icon-circle-check"></span>
  15. <span v-if="tab.dictValue=='4'" class="el-icon-question"></span>
  16. <span v-if="tab.dictValue=='5'" class="el-icon-warning"></span>
  17. {{ tab.dictLabel }} ({{ tab.sum }})
  18. </template>
  19. </el-radio-button>
  20. </el-radio-group>
  21. <!-- 表格部分 -->
  22. <div class="table-container">
  23. <table v-show="currentTab === '0' || currentTab === '1' || currentTab === '3'">
  24. <thead>
  25. <tr>
  26. <th>物资类型</th>
  27. <th v-for="cabinet in cabinets" :key="cabinet.cabinetId">{{ cabinet.cabinetName }}</th>
  28. </tr>
  29. </thead>
  30. <tbody>
  31. <tr v-for="(materialType, index) in materialTypes" :key="index">
  32. <td width="150">
  33. <img :src="materialType.materialsTypeIcon" alt="Material Icon" width="50" height="50"/><br>
  34. {{ materialType.materialsTypeName }}
  35. </td>
  36. <td style="font-size: 22px" v-for="cabinet in cabinets" :key="cabinet.cabinetId">
  37. {{ getCellData(materialType.materialsTypeId, cabinet.cabinetId) }}
  38. </td>
  39. </tr>
  40. </tbody>
  41. </table>
  42. <table v-show="currentTab === '2' || currentTab === '4' || currentTab === '5'">
  43. <thead>
  44. <tr>
  45. <th>物资类型</th>
  46. <th v-for="cabinet in cabinets" :key="cabinet.cabinetId">{{ cabinet.cabinetName }}</th>
  47. </tr>
  48. </thead>
  49. <tbody>
  50. <tr v-for="(materialType, index) in materialTypes" :key="index">
  51. <td width="150">
  52. <img :src="materialType.materialsTypeIcon" alt="Material Icon" width="50" height="50"/><br>
  53. {{ materialType.materialsTypeName }}
  54. </td>
  55. <td style="font-size: 22px" v-for="cabinet in cabinets" :key="cabinet.cabinetId"
  56. :style="getCellStyle(materialType.materialsTypeId, cabinet.cabinetId)"
  57. >
  58. {{ getCellData(materialType.materialsTypeId, cabinet.cabinetId) }}
  59. </td>
  60. </tr>
  61. </tbody>
  62. </table>
  63. </div>
  64. </div>
  65. </template>
  66. <script>
  67. import { getInventorySum, getMaterialInventory } from '@/api/mes/statisticians'
  68. import { getDicts } from '@/api/system/dict/data'
  69. export default {
  70. dicts: ['Inventory_type'],
  71. data() {
  72. return {
  73. currentTab: '0', // 当前选中的Tab
  74. tabs: [],
  75. tableData0: [],//各个物资柜数据
  76. tableData1: [],
  77. tableData2: [],//各个物资柜数据
  78. tableData3: [],
  79. tableData4: [],//各个物资柜数据
  80. tableData5: []
  81. }
  82. },
  83. watch: {
  84. currentTab(newVal) {
  85. getMaterialInventory(this.currentTab).then(response => {
  86. console.log(response, '物资盘点')
  87. switch (newVal) {
  88. case '0':
  89. this.tableData0 = response.data
  90. break;
  91. case '1':
  92. this.tableData1 = response.data
  93. break;
  94. case '2':
  95. this.tableData2 = response.data
  96. break;
  97. case '3':
  98. this.tableData3 = response.data
  99. break;
  100. case '4':
  101. this.tableData4 = response.data
  102. break;
  103. case '5':
  104. this.tableData5 = response.data
  105. break;
  106. }
  107. })
  108. }
  109. },
  110. computed: {
  111. cabinets() {
  112. return this.tableData0||this.tableData1||this.tableData2||this.tableData3||this.tableData4||this.tableData5
  113. },
  114. materialTypes() {
  115. // 假设我们只取第一个物资柜的所有物资类型
  116. if (this.tableData0.length > 0) {
  117. return this.tableData0[0].materialsTypeVOList
  118. }else if (this.tableData1.length > 0) {
  119. return this.tableData1[0].materialsTypeVOList
  120. }else if (this.tableData2.length > 0) {
  121. return this.tableData2[0].materialsTypeVOList
  122. }else if (this.tableData3.length > 0) {
  123. return this.tableData3[0].materialsTypeVOList
  124. }else if (this.tableData4.length > 0) {
  125. return this.tableData4[0].materialsTypeVOList
  126. }else if (this.tableData5.length > 0) {
  127. return this.tableData5[0].materialsTypeVOList
  128. }
  129. return []
  130. }
  131. },
  132. mounted() {
  133. this.getList()
  134. },
  135. methods: {
  136. getList() {
  137. getMaterialInventory(this.currentTab).then(response => {
  138. console.log(response, '物资盘点')
  139. // this.tableData = response.data
  140. switch (this.currentTab) {
  141. case '0':
  142. this.tableData0 = response.data
  143. break;
  144. case '1':
  145. this.tableData1 = response.data
  146. break;
  147. case '2':
  148. this.tableData2 = response.data
  149. break;
  150. case '3':
  151. this.tableData3 = response.data
  152. break;
  153. case '4':
  154. this.tableData4 = response.data
  155. break;
  156. case '5':
  157. this.tableData5 = response.data
  158. break;
  159. }
  160. })
  161. getInventorySum().then(response => {
  162. console.log(response, '总数')
  163. this.tabs = response.data
  164. })
  165. },
  166. getCellData(materialTypeId, cabinetId) {
  167. let tableData=null
  168. switch (this.currentTab) {
  169. case '0':
  170. tableData = this.tableData0
  171. break;
  172. case '1':
  173. tableData = this.tableData1
  174. break;
  175. case '2':
  176. tableData = this.tableData2
  177. break;
  178. case '3':
  179. tableData = this.tableData3
  180. break;
  181. case '4':
  182. tableData = this.tableData4
  183. break;
  184. case '5':
  185. tableData = this.tableData5
  186. break;
  187. }
  188. const cabinet = tableData.find(c => c.cabinetId === cabinetId)
  189. if (cabinet) {
  190. const materialType = cabinet.materialsTypeVOList.find(m => m.materialsTypeId === materialTypeId)
  191. if (materialType) {
  192. return materialType.number == null || materialType.number == 0 ? '-' : materialType.number
  193. }
  194. }
  195. return 0
  196. },
  197. getCellStyle(materialTypeId, cabinetId) {
  198. const number = this.getCellData(materialTypeId, cabinetId)
  199. if (number === null || number === 0) {
  200. return {}
  201. }
  202. if (this.currentTab === '2' && number > 0) {
  203. return { backgroundColor: 'yellow', color: 'black' }
  204. }
  205. if ((this.currentTab === '4' || this.currentTab === '5') && number > 0) {
  206. return { backgroundColor: 'red', color: 'black' }
  207. }
  208. return {}
  209. }
  210. }
  211. }
  212. </script>
  213. <style scoped>
  214. .table-container {
  215. width: 100%;
  216. overflow-x: auto;
  217. }
  218. table {
  219. width: 790px;
  220. border-collapse: collapse;
  221. table-layout: fixed;
  222. }
  223. th, td {
  224. border: 1px solid #ddd;
  225. padding: 8px;
  226. text-align: center;
  227. }
  228. th {
  229. background-color: #f2f2f2;
  230. }
  231. </style>