index.vue 8.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202
  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. data() {
  25. return {
  26. visible: false,
  27. columns: NewColumns,
  28. rules: initRules(NewColumns),
  29. params: {
  30. ...initParams(NewColumns),
  31. puOrderItemList: [],
  32. puOrderExecuteList: [],
  33. },
  34. tabColumns: NewTabColumns,
  35. tabName: "puOrderItemList",
  36. };
  37. },
  38. computed: {},
  39. watch: {},
  40. methods: {
  41. setVisible(prop) {
  42. this.visible = prop;
  43. },
  44. //查询详情
  45. async fetchItem(prop) {
  46. try {
  47. this.loading = true;
  48. const { code, msg, data } = await orderApi.details(prop);
  49. if (code === 200) {
  50. this.params = data;
  51. }
  52. } catch (err) {
  53. //
  54. } finally {
  55. this.loading = false;
  56. }
  57. },
  58. // 取 消
  59. handleCancel() {
  60. this.setVisible(false);
  61. this.params = initParams(Columns);
  62. },
  63. beforeOpen() { },
  64. },
  65. created() { },
  66. mounted() { },
  67. destroyed() { },
  68. };
  69. </script>
  70. <template>
  71. <el-drawer direction="btt" size="100%" :with-header="false" :visible.sync="visible" @open="beforeOpen"
  72. @close="$emit('close')">
  73. <el-form size="mini" label-position="right" label-width="140px" :model="params" :rules="rules">
  74. <el-card :body-style="{
  75. padding: '20px',
  76. display: 'flex',
  77. 'flex-wrap': 'wrap',
  78. }" style="margin: 10px">
  79. <div slot="header" style="
  80. display: flex;
  81. justify-content: space-between;
  82. align-items: center;
  83. ">
  84. <h3>查看</h3>
  85. <div style="text-align: right">
  86. <el-button size="mini" @click="handleCancel">取 消</el-button>
  87. </div>
  88. </div>
  89. <el-row style="display:flex; flex-wrap: wrap;">
  90. <el-col v-for="(column, index) in columns" :key="index" :span="column.span || 6">
  91. <el-form-item :prop="column.key" :label="column.title">
  92. <el-input v-if="column.inputType === 'Input'" v-model="params[column.key]" :placeholder="column.placeholder"
  93. :clearable="column.clearable" readonly style="width: 100%">
  94. </el-input>
  95. <dr-popover-select v-if="column.inputType === 'PopoverSelect'" v-model="params[column.key]" disabled
  96. :value-key="column.valueKey" :source.sync="params" :title="column.title" :type="column.referName"
  97. :multiple="column.multiple" :placeholder="column.placeholder" :data-mapping="column.dataMapping"
  98. :query-params="column.queryParams(params)">
  99. </dr-popover-select>
  100. <el-input v-if="column.inputType === 'Textarea'" v-model="params[column.key]" type="textarea"
  101. :placeholder="column.placeholder" :clearable="column.clearable" readonly style="width: 100%">
  102. </el-input>
  103. <el-input-number v-if="column.inputType === 'InputNumber'" v-model="params[column.key]"
  104. :controls-position="column.controlsPosition" :placeholder="column.placeholder"
  105. :clearable="column.clearable" disabled style="width: 100%">
  106. </el-input-number>
  107. <el-select v-if="column.inputType === 'Select'" v-model="params[column.key]" disabled size="mini"
  108. :clearable="column.clearable" :placeholder="column.placeholder" style="width: 100%">
  109. <el-option v-for="item in dict.type[column.referName]" :key="item.value" :label="item.label"
  110. :value="item.value">
  111. </el-option>
  112. </el-select>
  113. <el-select v-if="column.inputType === 'TagSelect'" v-model="params[column.key]" multiple clearable
  114. collapse-tags :placeholder="column.placeholder" :clearable="column.clearable" disabled
  115. style="width: 100%">
  116. <template #prefix>
  117. <el-icon class="el-icon-view" style="cursor: pointer" @click.stop="$message.info(234)"></el-icon>
  118. </template>
  119. <el-option v-for="item in options" :key="item.value" :label="item.label" :value="item.value">
  120. </el-option>
  121. </el-select>
  122. <el-date-picker v-if="column.inputType === 'DatePicker'" v-model="params[column.key]" :type="column.type"
  123. :placeholder="column.placeholder" :clearable="column.clearable" readonly
  124. :picker-options="column.pickerOptions" style="width: 100%">
  125. </el-date-picker>
  126. <el-checkbox v-if="column.inputType === 'Checkbox'" v-model="params[column.key]" disabled true-label="Y"
  127. false-label="N">
  128. </el-checkbox>
  129. <el-upload v-if="column.inputType === 'Upload'" :file-list="params[column.key]" disabled drag
  130. action="https://jsonplaceholder.typicode.com/posts/" multiple>
  131. <i class="el-icon-upload"></i>
  132. <div class="el-upload__text">
  133. 将文件拖到此处,或<em>点击上传</em>
  134. </div>
  135. <div class="el-upload__tip" slot="tip">
  136. 只能上传jpg/png文件,且不超过500kb
  137. </div>
  138. </el-upload>
  139. </el-form-item>
  140. </el-col>
  141. </el-row>
  142. </el-card>
  143. <el-card :body-style="{
  144. padding: '20px',
  145. display: 'flex',
  146. 'flex-wrap': 'wrap',
  147. position: 'relative',
  148. }" style="margin: 10px">
  149. <el-tabs v-model="tabName" style="width: 100%">
  150. <el-tab-pane v-for="(column, index) in tabColumns" :key="index" :label="column.title" :name="column.key">
  151. <el-table :data="params[column.key]" style="width: 100%">
  152. <el-table-column v-for="(cColumn, cIndex) in column.tableColumns" :key="cIndex" :prop="cColumn.key"
  153. :label="cColumn.title" :width="cColumn.width || 80">
  154. <template slot-scope="scope">
  155. <el-tag v-if="cColumn.key === 'index'">
  156. {{ scope.$index + 1 }}
  157. </el-tag>
  158. <el-input v-if="cColumn.inputType === 'Input'" v-model="scope.row[cColumn.key]"
  159. :placeholder="cColumn.placeholder" :clearable="cColumn.clearable" readonly size="mini"
  160. style="width: 100%"></el-input>
  161. <!-- -->
  162. <dr-popover-select v-if="cColumn.inputType === 'PopoverSelect'" v-model="scope.row[cColumn.key]"
  163. :source.sync="scope.row" :title="cColumn.title" :value-key="cColumn.valueKey" disabled
  164. :type="cColumn.referName" :multiple="cColumn.multiple" :placeholder="cColumn.placeholder"
  165. :data-mapping="cColumn.dataMapping" :query-params="cColumn.queryParams(scope.row)" size="mini">
  166. </dr-popover-select>
  167. <el-input-number v-if="cColumn.inputType === 'InputNumber'" v-model="scope.row[cColumn.key]"
  168. :controls-position="cColumn.controlsPosition" :placeholder="cColumn.placeholder"
  169. :clearable="cColumn.clearable" disabled size="mini" style="width: 100%">
  170. </el-input-number>
  171. <el-select v-if="cColumn.inputType === 'Select'" v-model="scope.row[cColumn.key]" disabled size="mini"
  172. :clearable="cColumn.clearable" :placeholder="cColumn.placeholder" style="width: 100%">
  173. <el-option v-for="item in dict.type[cColumn.referName]" :key="item.value" :label="item.label"
  174. :value="item.value">
  175. </el-option>
  176. </el-select>
  177. <el-checkbox v-if="cColumn.inputType === 'Checkbox'" v-model="scope.row[cColumn.key]" disabled
  178. true-label="Y" false-label="N">
  179. </el-checkbox>
  180. </template>
  181. </el-table-column>
  182. </el-table>
  183. </el-tab-pane>
  184. </el-tabs>
  185. </el-card>
  186. </el-form>
  187. </el-drawer>
  188. </template>