search.vue 5.1 KB

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