search.vue 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224
  1. <!-- 搜索表单 -->
  2. <template>
  3. <el-form
  4. label-width="100px"
  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: 10 } : { span: 5 }">
  11. <el-form-item label="工位编码:">
  12. <el-input clearable v-model.trim="where.code" placeholder="请输入" />
  13. </el-form-item>
  14. <el-form-item label="所属区域:">
  15. <area-select
  16. v-model.trim="where.areaId"
  17. :data="areaTreeList"
  18. ref="tree"
  19. />
  20. </el-form-item>
  21. </el-col>
  22. <el-col v-bind="styleResponsive ? { lg: 5, md: 10 } : { span: 5 }">
  23. <el-form-item label="工位名称:">
  24. <el-input clearable v-model.trim="where.name" placeholder="请输入" />
  25. </el-form-item>
  26. </el-col>
  27. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  28. <el-form-item label="所属工作中心:" prop="extInfo.workCenterId">
  29. <el-select
  30. v-model="where.workCenterId"
  31. filterable
  32. placeholder="请选择"
  33. style="width: 100%"
  34. clearable
  35. >
  36. <el-option
  37. v-for="item in workCenterList"
  38. :key="item.id"
  39. :label="item.name"
  40. :value="item.id"
  41. >
  42. </el-option>
  43. </el-select>
  44. </el-form-item>
  45. </el-col>
  46. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  47. <el-form-item label="工序:" prop="where.sourceTaskId">
  48. <el-select
  49. v-model="where.sourceTaskId"
  50. filterable
  51. placeholder="请选择"
  52. style="width: 100%"
  53. clearable
  54. >
  55. <el-option
  56. v-for="item in sourceTaskList"
  57. :key="item.id"
  58. :label="item.name"
  59. :value="item.id"
  60. >
  61. </el-option>
  62. </el-select>
  63. </el-form-item>
  64. </el-col>
  65. <el-col v-bind="styleResponsive ? { lg: 5, md: 10 } : { span: 5 }">
  66. <el-form-item label="负责人:">
  67. <el-select
  68. v-model.trim="where.leaderId"
  69. filterable
  70. placeholder="请选择"
  71. style="width: 100%"
  72. clearable
  73. >
  74. <el-option
  75. v-for="item in options.leaderId"
  76. :key="item.id"
  77. :label="item.name"
  78. :value="item.id"
  79. >
  80. </el-option>
  81. </el-select>
  82. </el-form-item>
  83. </el-col>
  84. <!-- <el-col v-bind="styleResponsive ? { lg: 5, md: 12 } : { span: 6 }">
  85. <el-form-item label="组织机构:">
  86. <auth-selection v-model.trim="where.deptIds" style="width: 100%"></auth-selection>
  87. </el-form-item>
  88. </el-col> -->
  89. <el-col v-bind="styleResponsive ? { lg: 4, md: 12 } : { span: 4 }">
  90. <div class="ele-form-actions">
  91. <el-button
  92. type="primary"
  93. icon="el-icon-search"
  94. class="ele-btn-icon"
  95. @click="search"
  96. >
  97. 查询
  98. </el-button>
  99. <el-button @click="reset">重置</el-button>
  100. </div>
  101. </el-col>
  102. </el-row>
  103. </el-form>
  104. </template>
  105. <script>
  106. import { getUserPage } from '@/api/system/organization';
  107. import AreaSelect from '@/views/enterpriseModel/regionalManage/components/area-cascader.vue';
  108. import { basicAreaPageAPI } from '@/api/regionalManage';
  109. import work from '@/api/technology/work';
  110. import producetask from '@/api/technology/production';
  111. export default {
  112. components: { AreaSelect },
  113. props: {
  114. options_groupId: {
  115. type: Array,
  116. default() {
  117. return [];
  118. }
  119. },
  120. options_factory: {
  121. type: Array,
  122. default() {
  123. return [];
  124. }
  125. }
  126. },
  127. watch: {
  128. options_groupId(nval) {
  129. this.toTreeData(nval);
  130. }
  131. },
  132. data() {
  133. // 默认表单数据
  134. const defaultWhere = {
  135. code: '',
  136. name: '',
  137. leaderId: '',
  138. workCenterId: '',
  139. sourceTaskId: ''
  140. };
  141. return {
  142. defaultWhere,
  143. // 表单数据
  144. where: { ...defaultWhere },
  145. options: {
  146. groupId: [],
  147. leaderId: []
  148. },
  149. workCenterList: [],
  150. areaTreeList: [],
  151. sourceTaskList: []
  152. };
  153. },
  154. computed: {
  155. // 是否开启响应式布局
  156. styleResponsive() {
  157. return this.$store.state.theme.styleResponsive;
  158. }
  159. },
  160. created() {
  161. this.getUserPage();
  162. this.getBasicAreaList();
  163. this.getListWorkCenter();
  164. this.getListProduce();
  165. },
  166. methods: {
  167. /* 获取区域集合 */
  168. async getBasicAreaList() {
  169. this.areaList = await basicAreaPageAPI({
  170. pageNum: 1,
  171. size: 9999
  172. });
  173. this.areaTreeList = this.$util.toTreeData({
  174. data: this.areaList,
  175. idField: 'id',
  176. parentIdField: 'parentId'
  177. });
  178. },
  179. async getListWorkCenter() {
  180. await work.list({ pageNum: 1, size: -1 }).then((res) => {
  181. this.workCenterList = res.list;
  182. });
  183. },
  184. getListProduce() {
  185. producetask.list({ pageNum: 1, size: -1 }).then((res) => {
  186. console.log(res.list, '工序列表');
  187. this.sourceTaskList = res.list || [];
  188. });
  189. },
  190. /* 搜索 */
  191. search() {
  192. this.$emit('search', this.where);
  193. },
  194. /* 重置 */
  195. reset() {
  196. console.log(this.defaultWhere);
  197. this.where = { ...this.defaultWhere };
  198. this.search();
  199. },
  200. // 格式化公司数据
  201. toTreeData(val) {
  202. this.options.groupId = this.$util.toTreeData({
  203. data: val,
  204. idField: 'id',
  205. parentIdField: 'parentId'
  206. });
  207. },
  208. // 获取人员
  209. getUserPage() {
  210. let par = {
  211. size: 999
  212. };
  213. getUserPage(par).then((res) => {
  214. console.log(res);
  215. this.options.leaderId = res.list;
  216. });
  217. }
  218. }
  219. };
  220. </script>