materialPlan-search.vue 5.5 KB

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