index.vue 8.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198
  1. <!-- 采购订单修订—— 查看 -->
  2. <script>
  3. import {
  4. initColumns,
  5. initDicts,
  6. initRules,
  7. initParams,
  8. } from "@/utils/init";
  9. import { Columns, TabColumns } from "../add/column";
  10. import orderApi from "@/api/business/purchase/purchase-order";
  11. const NewColumns = initColumns(Columns);
  12. const NewTabColumns = TabColumns.map((element) => ({
  13. ...element,
  14. tableColumns: initColumns(element.tableColumns),
  15. }));
  16. //
  17. const SelectColumns = NewColumns.filter(column => column.inputType === 'Select')
  18. NewTabColumns.forEach(column => {
  19. SelectColumns.push(...column.tableColumns.filter(cColumn => cColumn.inputType === 'Select'))
  20. });
  21. export default {
  22. name: "SeePurchaseOrderDrawer",
  23. dicts: initDicts(SelectColumns),
  24. components: {
  25. FileUploadCenter: () => import('../components/FileUploadCenter/index.vue'),
  26. },
  27. data() {
  28. return {
  29. visible: false,
  30. columns: NewColumns,
  31. rules: initRules(NewColumns),
  32. params: {
  33. ...initParams(NewColumns),
  34. puOrderItemList: [],
  35. puOrderExecuteList: [],
  36. },
  37. tabColumns: NewTabColumns,
  38. tabName: "puOrderItemList",
  39. };
  40. },
  41. computed: {},
  42. watch: {},
  43. methods: {
  44. setVisible(prop) {
  45. this.visible = prop;
  46. },
  47. //查询详情
  48. async fetchItem(prop) {
  49. try {
  50. this.loading = true;
  51. const { code, msg, data } = await orderApi.details(prop);
  52. if (code === 200) {
  53. this.params = data;
  54. }
  55. } catch (err) {
  56. //
  57. } finally {
  58. this.loading = false;
  59. }
  60. },
  61. // 取 消
  62. handleCancel() {
  63. this.setVisible(false);
  64. this.params = initParams(Columns);
  65. },
  66. beforeOpen() { },
  67. },
  68. created() { },
  69. mounted() { },
  70. destroyed() { },
  71. };
  72. </script>
  73. <template>
  74. <el-drawer direction="btt" size="100%" :with-header="false" :visible.sync="visible" @open="beforeOpen"
  75. @close="$emit('close')">
  76. <el-form size="mini" label-position="right" label-width="140px" :model="params" :rules="rules">
  77. <el-card :body-style="{
  78. padding: '20px',
  79. display: 'flex',
  80. 'flex-wrap': 'wrap',
  81. }" style="margin: 10px">
  82. <div slot="header" style="
  83. display: flex;
  84. justify-content: space-between;
  85. align-items: center;
  86. ">
  87. <h3>查看</h3>
  88. <div style="text-align: right">
  89. <el-button size="mini" @click="handleCancel">取 消</el-button>
  90. </div>
  91. </div>
  92. <el-row style="display:flex; flex-wrap: wrap;">
  93. <el-col v-for="(column, index) in columns" :key="index" :span="column.span || 6">
  94. <el-form-item :prop="column.key" :label="column.title">
  95. <el-input v-if="column.inputType === 'Input'" v-model="params[column.key]" :placeholder="column.placeholder"
  96. :clearable="column.clearable" readonly style="width: 100%">
  97. </el-input>
  98. <dr-popover-select v-if="column.inputType === 'PopoverSelect'" v-model="params[column.key]" disabled
  99. :value-key="column.valueKey" :source.sync="params" :title="column.title" :type="column.referName"
  100. :multiple="column.multiple" :placeholder="column.placeholder" :data-mapping="column.dataMapping"
  101. :query-params="column.queryParams(params)">
  102. </dr-popover-select>
  103. <el-input v-if="column.inputType === 'Textarea'" v-model="params[column.key]" type="textarea"
  104. :placeholder="column.placeholder" :clearable="column.clearable" readonly style="width: 100%">
  105. </el-input>
  106. <el-input-number v-if="column.inputType === 'InputNumber'" v-model="params[column.key]"
  107. :controls-position="column.controlsPosition" :placeholder="column.placeholder"
  108. :clearable="column.clearable" disabled style="width: 100%">
  109. </el-input-number>
  110. <el-select v-if="column.inputType === 'Select'" v-model="params[column.key]" disabled size="mini"
  111. :clearable="column.clearable" :placeholder="column.placeholder" style="width: 100%">
  112. <el-option v-for="item in dict.type[column.referName]" :key="item.value" :label="item.label"
  113. :value="item.value">
  114. </el-option>
  115. </el-select>
  116. <el-select v-if="column.inputType === 'TagSelect'" v-model="params[column.key]" multiple clearable
  117. collapse-tags :placeholder="column.placeholder" :clearable="column.clearable" disabled
  118. style="width: 100%">
  119. <template #prefix>
  120. <el-icon class="el-icon-view" style="cursor: pointer" @click.stop="$message.info(234)"></el-icon>
  121. </template>
  122. <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
  123. </el-option>
  124. </el-select>
  125. <el-date-picker v-if="column.inputType === 'DatePicker'" v-model="params[column.key]" :type="column.type"
  126. :placeholder="column.placeholder" :clearable="column.clearable" readonly
  127. :picker-options="column.pickerOptions" style="width: 100%">
  128. </el-date-picker>
  129. <el-checkbox v-if="column.inputType === 'Checkbox'" v-model="params[column.key]" disabled true-label="Y"
  130. false-label="N">
  131. </el-checkbox>
  132. <file-upload-center v-if="column.inputType === 'Upload'" v-model="params[column.key]"
  133. :file-type="column.fileType" :disabled="true">
  134. </file-upload-center>
  135. </el-form-item>
  136. </el-col>
  137. </el-row>
  138. </el-card>
  139. <el-card :body-style="{
  140. padding: '20px',
  141. display: 'flex',
  142. 'flex-wrap': 'wrap',
  143. position: 'relative',
  144. }" style="margin: 10px">
  145. <el-tabs v-model="tabName" style="width: 100%">
  146. <el-tab-pane v-for="(column, index) in tabColumns" :key="index" :label="column.title" :name="column.key">
  147. <el-table :data="params[column.key]" style="width: 100%">
  148. <el-table-column v-for="(cColumn, cIndex) in column.tableColumns" :key="cIndex" :prop="cColumn.key"
  149. :label="cColumn.title" :width="cColumn.width || 80">
  150. <template slot-scope="scope">
  151. <el-tag v-if="cColumn.key === 'index'">
  152. {{ scope.$index + 1 }}
  153. </el-tag>
  154. <el-input v-if="cColumn.inputType === 'Input'" v-model="scope.row[cColumn.key]"
  155. :placeholder="cColumn.placeholder" :clearable="cColumn.clearable" readonly size="mini"
  156. style="width: 100%"></el-input>
  157. <!-- -->
  158. <dr-popover-select v-if="cColumn.inputType === 'PopoverSelect'" v-model="scope.row[cColumn.key]"
  159. :source.sync="scope.row" :title="cColumn.title" :value-key="cColumn.valueKey" disabled
  160. :type="cColumn.referName" :multiple="cColumn.multiple" :placeholder="cColumn.placeholder"
  161. :data-mapping="cColumn.dataMapping" :query-params="cColumn.queryParams(scope.row)" size="mini">
  162. </dr-popover-select>
  163. <el-input-number v-if="cColumn.inputType === 'InputNumber'" v-model="scope.row[cColumn.key]"
  164. :controls-position="cColumn.controlsPosition" :placeholder="cColumn.placeholder"
  165. :clearable="cColumn.clearable" disabled size="mini" style="width: 100%">
  166. </el-input-number>
  167. <el-select v-if="cColumn.inputType === 'Select'" v-model="scope.row[cColumn.key]" disabled size="mini"
  168. :clearable="cColumn.clearable" :placeholder="cColumn.placeholder" style="width: 100%">
  169. <el-option v-for="item in dict.type[cColumn.referName]" :key="item.value" :label="item.label"
  170. :value="item.value">
  171. </el-option>
  172. </el-select>
  173. <el-checkbox v-if="cColumn.inputType === 'Checkbox'" v-model="scope.row[cColumn.key]" disabled
  174. true-label="Y" false-label="N">
  175. </el-checkbox>
  176. </template>
  177. </el-table-column>
  178. </el-table>
  179. </el-tab-pane>
  180. </el-tabs>
  181. </el-card>
  182. </el-form>
  183. </el-drawer>
  184. </template>