order-search.vue 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392
  1. <!-- 搜索表单 -->
  2. <template>
  3. <el-form
  4. label-width="90px"
  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: 6, md: 12 } : { span: 6 }">
  11. <el-form-item label="销售订单号:">
  12. <el-input v-model="where.code" placeholder="请输入"></el-input>
  13. </el-form-item>
  14. </el-col>
  15. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  16. <el-form-item label="产品编码:">
  17. <el-input v-model="where.productCode" placeholder="请输入"></el-input>
  18. </el-form-item>
  19. </el-col>
  20. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  21. <el-form-item label="行号:">
  22. <el-input v-model="where.lineNumber" placeholder="请输入"></el-input>
  23. </el-form-item>
  24. </el-col>
  25. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  26. <el-form-item label="牌号:">
  27. <el-input v-model="where.brandNo" placeholder="请输入"></el-input>
  28. </el-form-item>
  29. </el-col>
  30. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  31. <el-form-item label="型号:">
  32. <el-input v-model="where.model" placeholder="请输入"></el-input>
  33. </el-form-item>
  34. </el-col>
  35. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  36. <el-form-item label="订单来源:">
  37. <DictSelection
  38. dictName="订单来源"
  39. clearable
  40. v-model="where.orderSource"
  41. >
  42. </DictSelection>
  43. </el-form-item>
  44. </el-col>
  45. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  46. <el-form-item label="客户名称:">
  47. <el-input
  48. v-model="where.customerName"
  49. placeholder="请输入"
  50. ></el-input>
  51. </el-form-item>
  52. </el-col>
  53. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  54. <el-form-item label="订单类型:">
  55. <DictSelection
  56. dictName="订单类型"
  57. clearable
  58. v-model="where.orderType"
  59. >
  60. </DictSelection>
  61. </el-form-item>
  62. </el-col>
  63. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  64. <el-form-item label="生产状态:">
  65. <el-select v-model="where.proStu" placeholder="请选择" class="w100">
  66. <el-option
  67. v-if="activeName == 'first'"
  68. v-for="item in awaitProcuct"
  69. :key="item.value"
  70. :label="item.label"
  71. :value="item.value"
  72. >
  73. </el-option>
  74. <el-option
  75. v-if="activeName == 'second'"
  76. v-for="item in alreadyProcuct"
  77. :key="item.value"
  78. :label="item.label"
  79. :value="item.value"
  80. >
  81. </el-option>
  82. </el-select>
  83. </el-form-item>
  84. </el-col>
  85. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  86. <el-form-item label="按单按库:">
  87. <el-select
  88. v-model="where.orderLibraryType"
  89. placeholder="请选择"
  90. class="w100"
  91. >
  92. <el-option
  93. v-for="item in orderTypeList"
  94. :key="item.value"
  95. :label="item.label"
  96. :value="item.value"
  97. >
  98. </el-option>
  99. </el-select>
  100. </el-form-item>
  101. </el-col>
  102. <el-col v-bind="styleResponsive ? { lg: 6, md: 12 } : { span: 6 }">
  103. <el-form-item label="业务员:">
  104. <el-input v-model="where.salesman" placeholder="请输入"></el-input>
  105. </el-form-item>
  106. </el-col>
  107. </el-row>
  108. <el-row :gutter="15">
  109. <el-col v-bind="styleResponsive ? { lg: 12, md: 12 } : { span: 12 }">
  110. <el-form-item label="交货日期:">
  111. <el-date-picker
  112. style="width: 100%"
  113. v-model="time"
  114. type="daterange"
  115. range-separator="至"
  116. start-placeholder="开始日期"
  117. end-placeholder="结束日期"
  118. value-format="yyyy-MM-dd HH:mm:ss"
  119. :default-time="['00:00:00', '23:59:59']"
  120. >
  121. </el-date-picker>
  122. </el-form-item>
  123. </el-col>
  124. <el-col v-bind="styleResponsive ? { lg: 12, md: 12 } : { span: 12 }">
  125. <div class="ele-form-actions">
  126. <el-button
  127. type="primary"
  128. icon="el-icon-search"
  129. class="ele-btn-icon"
  130. @click="search"
  131. >
  132. 查询
  133. </el-button>
  134. <el-button @click="reset" icon="el-icon-refresh-left" type="primary"
  135. >重置</el-button
  136. >
  137. </div>
  138. </el-col>
  139. <el-col v-bind="styleResponsive ? { lg: 24, md: 24 } : { span: 24 }">
  140. <el-form-item label-width="0px">
  141. <div class="btn-wrapper">
  142. <el-button @click="goProduct">转生产计划</el-button>
  143. <el-button type="primary" @click="orderRefresh">订单刷新</el-button>
  144. <el-button type="success" @click="toCreate">创建订单</el-button>
  145. <el-upload
  146. class="avatar-uploader"
  147. action="#"
  148. :show-file-list="false"
  149. :http-request="uploadFile"
  150. :before-upload="beforeUpload"
  151. :on-change="handleChange"
  152. ref="uploadFile"
  153. >
  154. <el-button type="warning">批量导入</el-button>
  155. </el-upload>
  156. <el-button type="info">
  157. <a
  158. :href="fileUrl"
  159. download="销售订单导入模板.xls"
  160. class="button-link"
  161. >下载模板</a
  162. >
  163. </el-button>
  164. <el-button type="danger" @click="batchDelete">批量删除</el-button>
  165. </div>
  166. </el-form-item>
  167. </el-col>
  168. </el-row>
  169. <!-- 导入异常 -->
  170. <import-exception ref="importDialog"> </import-exception>
  171. <!-- 创建订单 -->
  172. <create-order ref="createDialog" @refresh="search"> </create-order>
  173. <!-- 订单组合 -->
  174. <group-order ref="groupDialog"> </group-order>
  175. </el-form>
  176. </template>
  177. <script>
  178. import ImportException from '../components/import-exception.vue';
  179. import CreateOrder from '../components/create-order.vue';
  180. import GroupOrder from '../components/group-order.vue';
  181. import { importFile } from '@/api/saleOrder';
  182. import fileUrl from '@/assets/file/销售订单导入模板.xls';
  183. import { pullSalesOrder, deleteOrder } from '@/api/saleOrder';
  184. import { data } from 'ele-admin/lib/ele-pro-table';
  185. export default {
  186. props: {
  187. selection: Array,
  188. activeName: String
  189. },
  190. components: {
  191. ImportException,
  192. CreateOrder,
  193. GroupOrder
  194. },
  195. data () {
  196. // 默认表单数据
  197. const defaultWhere = {
  198. code: '',
  199. productCode: '',
  200. customerName: '',
  201. lineNumber: '',
  202. model: '',
  203. brandNo: '',
  204. orderSource: 0,
  205. orderType: 0,
  206. proStu: '',
  207. orderLibraryType: 0,
  208. salesman: ''
  209. };
  210. return {
  211. fileUrl,
  212. // 表单数据
  213. defaultWhere,
  214. where: { ...defaultWhere },
  215. time: [],
  216. fileList: [],
  217. awaitProcuct: [{ value: 1, label: '待排产' }],
  218. alreadyProcuct: [
  219. { value: 0, label: '所有状态' },
  220. { value: 2, label: '待发布' },
  221. { value: 3, label: '发布失败' },
  222. { value: 4, label: '待生产' },
  223. { value: 5, label: '生产中' },
  224. { value: 6, label: '已完成' },
  225. { value: 7, label: '已延期' }
  226. ],
  227. orderTypeList: [
  228. { value: 0, label: '所有' },
  229. { value: 1, label: '按单' },
  230. { value: 2, label: '按库' }
  231. ]
  232. };
  233. },
  234. computed: {
  235. // 是否开启响应式布局
  236. styleResponsive () {
  237. return this.$store.state.theme.styleResponsive;
  238. }
  239. },
  240. watch: {
  241. activeName: {
  242. handler () {
  243. if (this.activeName == 'first') {
  244. this.where.proStu = 1;
  245. } else {
  246. this.where.proStu = 0;
  247. }
  248. this.search();
  249. },
  250. immediate: true
  251. }
  252. },
  253. created () {},
  254. methods: {
  255. /* 搜索 */
  256. search () {
  257. if (this.time.length) {
  258. this.where.startTime = this.time[0];
  259. this.where.endTime = this.time[1];
  260. }
  261. this.$emit('search', this.where);
  262. },
  263. /* 重置 */
  264. reset () {
  265. this.time = [];
  266. this.where = { ...this.defaultWhere };
  267. if (this.activeName == 'first') {
  268. this.where.proStu = 1;
  269. } else {
  270. this.where.proStu = 0;
  271. }
  272. this.search();
  273. },
  274. toImport () {
  275. this.$refs.importDialog.open();
  276. },
  277. toCreate () {
  278. this.$refs.createDialog.open();
  279. },
  280. toGroup () {
  281. this.$refs.groupDialog.open();
  282. },
  283. goProduct () {
  284. if (!this.selection.length) {
  285. return this.$message.warning('请先勾选一个或多个订单!');
  286. }
  287. const productCode = this.selection[0].productCode;
  288. for (var i = 0; i < this.selection.length; i++) {
  289. if (productCode != this.selection[i].productCode) {
  290. return this.$message.warning('产品编码不一致!');
  291. }
  292. }
  293. const list = [];
  294. this.selection.map((item) => {
  295. list.push(item.id);
  296. });
  297. this.$router.push({
  298. path: '/saleOrder/salesToProduction',
  299. query: {
  300. selection: JSON.stringify(list)
  301. }
  302. });
  303. },
  304. // 刷新订单
  305. orderRefresh () {
  306. pullSalesOrder().then((res) => {});
  307. },
  308. // 点击批量删除
  309. batchDelete () {
  310. if (!this.selection.length) {
  311. return this.$message.warning('请先勾选一个或多个订单!');
  312. }
  313. let ids = [];
  314. this.selection.map((item) => {
  315. ids.push(item.id);
  316. });
  317. this.$confirm('此操作将永久删除所选择的订单, 是否继续?', '提示', {
  318. confirmButtonText: '确定',
  319. cancelButtonText: '取消',
  320. type: 'warning'
  321. })
  322. .then(() => {
  323. deleteOrder(ids).then((res) => {
  324. this.$message.success(res);
  325. this.search();
  326. });
  327. })
  328. .catch(() => {});
  329. },
  330. handleChange (file, fileList) {
  331. this.fileList = fileList;
  332. console.log(fileList);
  333. },
  334. //上传限制
  335. beforeUpload (file) {
  336. const isLt10M = file.size / 1024 / 1024 < 10;
  337. if (!isLt10M) {
  338. this.$message.error('上传文件大小不能超过 10MB!');
  339. }
  340. return isLt10M;
  341. },
  342. //文件上传
  343. uploadFile (param) {
  344. let fd = new FormData();
  345. this.fileList.forEach((item) => {
  346. fd.append('importExcel', item.raw);
  347. });
  348. importFile(fd)
  349. .then((res) => {
  350. this.$emit('search', this.where);
  351. this.$refs.uploadFile.clearFiles();
  352. })
  353. .catch((data) => {
  354. if (data.code != -1) {
  355. this.$message.error(data.message);
  356. }
  357. })
  358. .finally(() => {
  359. this.$refs.uploadFile.clearFiles();
  360. });
  361. }
  362. }
  363. };
  364. </script>
  365. <style lang="scss" scoped>
  366. .ele-form-actions {
  367. display: flex;
  368. align-items: center;
  369. justify-content: flex-end;
  370. }
  371. .btn-wrapper {
  372. display: flex;
  373. align-items: center;
  374. justify-content: flex-start;
  375. flex-wrap: wrap;
  376. }
  377. .avatar-uploader {
  378. display: inline-block;
  379. margin: 0 10px;
  380. }
  381. .button-link {
  382. color: #fff;
  383. }
  384. </style>