materialPlan-search.vue 5.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190
  1. <!-- 搜索表单 -->
  2. <template>
  3. <el-form
  4. label-width="80px"
  5. class="ele-form-search"
  6. @keyup.enter.native="search"
  7. @submit.native.prevent
  8. >
  9. <el-row :gutter="15">
  10. <el-col v-bind="styleResponsive ? { lg: 5, md: 12 } : { span: 5 }">
  11. <el-form-item label="计划编码:">
  12. <el-input clearable v-model="where.code" placeholder="请输入" />
  13. </el-form-item>
  14. </el-col>
  15. <el-col v-bind="styleResponsive ? { lg: 5, md: 12 } : { span: 5 }">
  16. <el-form-item label="物料编码:">
  17. <el-input
  18. clearable
  19. v-model="where.materialCode"
  20. placeholder="请输入"
  21. />
  22. </el-form-item>
  23. </el-col>
  24. <el-col v-bind="styleResponsive ? { lg: 5, md: 12 } : { span: 5 }">
  25. <el-form-item label="牌号:" label-width="80px">
  26. <el-input clearable v-model="where.brandNo" placeholder="请输入" />
  27. </el-form-item>
  28. </el-col>
  29. <el-col v-bind="styleResponsive ? { lg: 9, md: 12 } : { span: 9 }">
  30. <el-form-item label="要求交付日期:" label-width="100px">
  31. <el-date-picker
  32. class="w100"
  33. v-model="where.deliveryTime"
  34. type="daterange"
  35. range-separator="至"
  36. start-placeholder="开始日期"
  37. end-placeholder="结束日期"
  38. value-format="yyyy-MM-dd"
  39. >
  40. </el-date-picker>
  41. </el-form-item>
  42. </el-col>
  43. <el-col v-bind="styleResponsive ? { lg: 5, md: 12 } : { span: 5 }">
  44. <el-form-item label="计划状态:" label-width="80px">
  45. <el-select
  46. v-model="where.statusList"
  47. placeholder="请选择"
  48. class="w100"
  49. >
  50. <el-option
  51. v-for="item in statusOpt[activeName]"
  52. :label="item.label"
  53. :value="item.value"
  54. :key="item.value"
  55. ></el-option>
  56. </el-select>
  57. </el-form-item>
  58. </el-col>
  59. <el-col v-bind="styleResponsive ? { lg: 7, md: 12 } : { span: 7 }">
  60. <el-form-item label="创建时间:">
  61. <el-date-picker
  62. class="w100"
  63. v-model="where.createTime"
  64. type="daterange"
  65. range-separator="至"
  66. start-placeholder="开始日期"
  67. end-placeholder="结束日期"
  68. value-format="yyyy-MM-dd HH:mm:ss"
  69. >
  70. </el-date-picker>
  71. </el-form-item>
  72. </el-col>
  73. <el-col
  74. v-bind="styleResponsive ? { lg: 7, md: 12 } : { span: 7 }"
  75. v-if="activeName == 'second'"
  76. >
  77. <el-form-item label="发布时间:">
  78. <el-date-picker
  79. class="w100"
  80. v-model="where.releaseTime"
  81. type="daterange"
  82. range-separator="至"
  83. start-placeholder="开始日期"
  84. end-placeholder="结束日期"
  85. value-format="yyyy-MM-dd"
  86. >
  87. </el-date-picker>
  88. </el-form-item>
  89. </el-col>
  90. <el-col
  91. v-bind="
  92. styleResponsive
  93. ? {
  94. lg: activeName == 'second' ? 5 : 12,
  95. md: activeName == 'second' ? 12 : 24
  96. }
  97. : { span: activeName == 'second' ? 5 : 12 }
  98. "
  99. >
  100. <div class="ele-form-actions">
  101. <el-button
  102. type="primary"
  103. icon="el-icon-search"
  104. class="ele-btn-icon"
  105. @click="search"
  106. >
  107. 查询
  108. </el-button>
  109. <el-button @click="reset" icon="el-icon-refresh-left" type="primary"
  110. >重置</el-button
  111. >
  112. </div>
  113. </el-col>
  114. </el-row>
  115. </el-form>
  116. </template>
  117. <script>
  118. export default {
  119. props: ['activeName', 'statusOpt', 'planType'],
  120. data () {
  121. // 默认表单数据
  122. const defaultWhere = {
  123. materialCode: '',
  124. brandNo: '',
  125. statusList: '',
  126. code: '',
  127. releaseTime: [],
  128. deliveryTime: [],
  129. createTime: []
  130. };
  131. return {
  132. // 表单数据
  133. where: { ...defaultWhere },
  134. treeData: []
  135. };
  136. },
  137. computed: {
  138. // 是否开启响应式布局
  139. styleResponsive () {
  140. return this.$store.state.theme.styleResponsive;
  141. }
  142. },
  143. watch: {
  144. activeName: {
  145. handler () {
  146. if (this.activeName) {
  147. this.where.statusList = this.statusOpt[this.activeName][0].value;
  148. this.reset();
  149. }
  150. },
  151. immediate: true
  152. }
  153. },
  154. created () {},
  155. methods: {
  156. /* 搜索 */
  157. search () {
  158. const where = { ...this.where };
  159. for (const key in where) {
  160. if (Array.isArray(where[key]) && where[key].length) {
  161. where[`${key}Start`] = where[key][0];
  162. where[`${key}End`] = where[key][1];
  163. }
  164. }
  165. delete where.releaseTime;
  166. delete where.deliveryTime;
  167. delete where.createTime;
  168. where.statusList = where.statusList.split(',');
  169. this.$emit('search', where);
  170. },
  171. /* 重置 */
  172. reset () {
  173. this.where = { ...this.defaultWhere };
  174. this.where.statusList = this.statusOpt[this.activeName][0].value;
  175. this.search();
  176. }
  177. }
  178. };
  179. </script>
  180. <style lang="scss" scoped>
  181. .ele-form-actions {
  182. display: flex;
  183. align-items: center;
  184. justify-content: flex-end;
  185. }
  186. </style>