sparepart-search.vue 7.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235
  1. <!-- 搜索表单 -->
  2. <template>
  3. <el-form
  4. label-width="77px"
  5. class="ele-form-search"
  6. @keyup.enter.native="search"
  7. @submit.native.prevent
  8. >
  9. <el-row type="flex" :gutter="15">
  10. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  11. <el-form-item label="编码:" label-width="100px">
  12. <el-input clearable v-model="where.code" placeholder="请输入" />
  13. </el-form-item>
  14. </el-col>
  15. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  16. <el-form-item label="名称:" label-width="100px">
  17. <el-input clearable v-model="where.name" placeholder="请输入" />
  18. </el-form-item>
  19. </el-col>
  20. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  21. <el-form-item label="固资编码:" label-width="100px">
  22. <el-input clearable v-model="where.fixCode" placeholder="请输入" />
  23. </el-form-item>
  24. </el-col>
  25. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  26. <el-form-item label="使用单位:" label-width="100px">
  27. <DeptSelect v-model="where.postId" @input="selectChange" />
  28. </el-form-item>
  29. </el-col>
  30. </el-row>
  31. <el-row type="flex" :gutter="15">
  32. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  33. <el-form-item label="型号:" label-width="100px">
  34. <el-input clearable v-model="where.module" placeholder="请输入" />
  35. </el-form-item>
  36. </el-col>
  37. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  38. <el-form-item label="编号:" label-width="100px">
  39. <el-input clearable v-model="where.codeNumber" placeholder="请输入" />
  40. </el-form-item>
  41. </el-col>
  42. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  43. <el-form-item label="网络状态:" label-width="100px">
  44. <DictSelection
  45. dictName="网络状态"
  46. clearable
  47. v-model="where.networkStatus"
  48. >
  49. </DictSelection>
  50. </el-form-item>
  51. </el-col>
  52. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  53. <el-form-item label="生命周期:" label-width="100px">
  54. <DictSelection
  55. dictName="生命周期"
  56. clearable
  57. v-model="where.runStatus"
  58. >
  59. </DictSelection>
  60. </el-form-item>
  61. </el-col>
  62. </el-row>
  63. <el-row type="flex" :gutter="15">
  64. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  65. <el-form-item label="有效期结束" label-width="100px">
  66. <el-date-picker
  67. style="width: 100%"
  68. v-model="where.endTime"
  69. value-format="yyyy-MM"
  70. type="month"
  71. placeholder="选择有效期结束时间"
  72. >
  73. </el-date-picker>
  74. </el-form-item>
  75. </el-col>
  76. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  77. <el-form-item label="状态" label-width="100px">
  78. <el-select v-model="where.status" size="small" style="width: 100%">
  79. <el-option
  80. v-for="(item, index) in businessStatus"
  81. :value="item.code"
  82. :label="item.label"
  83. ></el-option>
  84. </el-select>
  85. </el-form-item>
  86. </el-col>
  87. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  88. <el-form-item label="级别" label-width="100px">
  89. <el-select v-model="where.level" size="small" style="width: 100%">
  90. <el-option
  91. v-for="(item, index) in assetLevel"
  92. :value="item.id"
  93. :label="item.name"
  94. ></el-option>
  95. </el-select>
  96. </el-form-item>
  97. </el-col>
  98. <!-- <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  99. <el-form-item label="组织机构:" label-width="100px">
  100. <auth-selection data-type="Array" v-model="where.deptIds" style="width: 100%"></auth-selection>
  101. </el-form-item>
  102. </el-col> -->
  103. </el-row>
  104. <el-row type="flex" :gutter="15">
  105. <el-col v-bind="styleResponsive ? { lg: 24, md: 24 } : { span: 24 }">
  106. <div class="ele-form-actions">
  107. <el-button
  108. type="primary"
  109. icon="el-icon-search"
  110. class="ele-btn-icon"
  111. @click="search"
  112. size="small"
  113. >
  114. 查询
  115. </el-button>
  116. <el-button
  117. @click="reset"
  118. icon="el-icon-refresh-left"
  119. size="small"
  120. type="primary"
  121. >重置</el-button
  122. >
  123. </div>
  124. </el-col>
  125. </el-row>
  126. <!-- <el-row type="flex">
  127. <el-col v-bind="styleResponsive ? { lg: 24, md: 24 } : { span: 24 }">
  128. <div class="ele-status">
  129. <el-checkbox v-model="consumption">显示已消耗</el-checkbox>
  130. <span class="op"
  131. >在线:<span>{{ networkCounts.online }}</span></span
  132. >
  133. <span class="op"
  134. >离线:<span>{{ networkCounts.offline }}</span></span
  135. >
  136. </div>
  137. </el-col>
  138. </el-row> -->
  139. </el-form>
  140. </template>
  141. <script>
  142. import { getByCode } from '@/api/system/dictionary-data';
  143. import { businessStatus } from '@/utils/dict/warehouse';
  144. import DeptSelect from '@/components/CommomSelect/dept-select.vue';
  145. export default {
  146. props: ['networkCounts'],
  147. data() {
  148. // 默认表单数据
  149. const defaultWhere = {
  150. name: '',
  151. code: '',
  152. endTime: '',
  153. networkStatus: '',
  154. status: '',
  155. fixCode: '',
  156. runStatus: '',
  157. module: '',
  158. space: '',
  159. postId: ''
  160. };
  161. return {
  162. assetLevel: [],
  163. businessStatus,
  164. // 表单数据
  165. where: { ...defaultWhere },
  166. consumption: false
  167. };
  168. },
  169. components: {
  170. DeptSelect
  171. },
  172. computed: {
  173. // 是否开启响应式布局
  174. styleResponsive() {
  175. return this.$store.state.theme.styleResponsive;
  176. }
  177. },
  178. created() {
  179. this.getAssetLevelOptions();
  180. },
  181. methods: {
  182. // 获取资产级别下拉
  183. async getAssetLevelOptions() {
  184. let { data } = await getByCode('asset_level');
  185. this.assetLevel =
  186. data.length > 0
  187. ? data.map((item) => {
  188. return {
  189. name: Object.keys(item)[0],
  190. id: item[Object.keys(item)[0]]
  191. };
  192. })
  193. : [];
  194. },
  195. /* 清空 */
  196. selectChange(value) {
  197. if (!value) {
  198. this.where.postId = '';
  199. }
  200. },
  201. /* 搜索 */
  202. search() {
  203. if (!this.where.endTime) {
  204. this.where.endTime = '';
  205. }
  206. this.$emit('search', this.where);
  207. },
  208. /* 重置 */
  209. reset() {
  210. this.where = { ...this.defaultWhere };
  211. this.search();
  212. }
  213. }
  214. };
  215. </script>
  216. <style lang="scss" scoped>
  217. .ele-form-actions {
  218. text-align: right;
  219. }
  220. .ele-status {
  221. display: flex;
  222. align-content: center;
  223. justify-content: flex-end;
  224. padding: 0 10px 10px 10px;
  225. .op {
  226. margin-left: 20px;
  227. span {
  228. color: #0000ff;
  229. }
  230. }
  231. }
  232. </style>