| | |
| | | // 上传路径 |
| | | ftpUrl: 'https://yqzx.jinmingyuan.com/lowConsum',//开发 |
| | | // 接口请求地址 |
| | | // apiBaseURL: 'http://172.16.20.2:8083/lowConsum',//开发 |
| | | apiBaseURL: 'http://172.16.60.155:8083/lowConsum',//开发 |
| | | apiBaseURL: 'http://172.16.20.2:8083/lowConsum',//开发 |
| | | // apiBaseURL: 'http://172.16.60.155:8083/lowConsum',//开发 |
| | | // apiBaseURL: 'https://yqzx.jinmingyuan.com/lowConsum',//开发 |
| | | debug: false //调试开关 true时会输出请求日志 |
| | | }; |
New file |
| | |
| | | import request from '@/utils/request'; |
| | | |
| | | // 出库单导出 |
| | | export function outputExport(params) { |
| | | return request({ |
| | | url: '/pc/l/wh/form/output/list/export', |
| | | responseType: 'blob', // 指定响应数据类型为Blob |
| | | method: 'get', |
| | | params, |
| | | }); |
| | | } |
| | | // 采购单导出 |
| | | export function procureExport(params) { |
| | | return request({ |
| | | url: '/pc/l/wh/form/procure/list/export', |
| | | responseType: 'blob', // 指定响应数据类型为Blob |
| | | method: 'get', |
| | | params, |
| | | }); |
| | | } |
| | | // 调拨单导出 |
| | | export function transferExport(params) { |
| | | return request({ |
| | | url: '/pc/l/wh/form/transfer/list/export', |
| | | responseType: 'blob', // 指定响应数据类型为Blob |
| | | method: 'get', |
| | | params, |
| | | }); |
| | | } |
| | | |
| | | // 库存盘点单导出 |
| | | export function inventoryExport(params) { |
| | | return request({ |
| | | url: '/pc/l/wh/form/inventory/list/export', |
| | | responseType: 'blob', // 指定响应数据类型为Blob |
| | | method: 'get', |
| | | params, |
| | | }); |
| | | } |
| | | |
| | | // 库存报废单导出 |
| | | export function scrappedExport(params) { |
| | | return request({ |
| | | url: '/pc/l/wh/form/scrapped/list/export', |
| | | responseType: 'blob', // 指定响应数据类型为Blob |
| | | method: 'get', |
| | | params, |
| | | }); |
| | | } |
| | |
| | | } |
| | | |
| | | // 导出 |
| | | export function transferExport(params) { |
| | | return request({ |
| | | url: '/pc/l/wh/form/transfer/export', |
| | | method: 'get', |
| | | params, |
| | | }); |
| | | } |
| | | |
| | | // 导出 |
| | | export function transferDetailListApi(params) { |
| | | return '/pc/l/wh/form/transfer/detail/list' |
| | | } |
| | |
| | | {{ item }} |
| | | </div> |
| | | </div> |
| | | <el-form v-show="tabIndex == 0" ref="ruleForm" :model="formData" :rules="rules" class="demo-ruleForm"> |
| | | <el-form v-loading="loading" v-show="tabIndex == 0" ref="ruleForm" :model="formData" :rules="rules" class="demo-ruleForm"> |
| | | <div v-for="(item, index) in formData.list" :key="index"> |
| | | <el-row :gutter="20"> |
| | | <el-col :span="6"> |
| | |
| | | <el-divider v-if="index+1<formData.list.length"></el-divider> |
| | | </div> |
| | | </el-form> |
| | | |
| | | <el-form |
| | | v-show="tabIndex == 1" |
| | | ref="ruleForm" |
| | |
| | | <el-row :gutter="20" class="item-header"> |
| | | <el-col :span="6"> |
| | | <el-form-item label="修改时间:"> |
| | | {{ item.updateTime }} |
| | | {{ item.updateTime | formatTime }} |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | |
| | | <script> |
| | | import myButton from '@/components/myButton/myButton'; |
| | | import {useInfoUpdate, useRecord} from "@/api/stock/transfer"; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | |
| | | export default { |
| | | components: {myButton}, |
| | | mixins: [listPage], |
| | | props: { |
| | | setting: { |
| | | type: Object, |
| | |
| | | }, |
| | | data() { |
| | | return { |
| | | loading: true, |
| | | tabs: ['修改使用人', '使用记录'], |
| | | tabIndex: 0, |
| | | list: [], |
| | |
| | | </el-row> |
| | | <el-form> |
| | | <el-row class="card3" v-for="(mItem, mIndex) in goodsItem.models" :key="mIndex"> |
| | | <el-col :span="10"> |
| | | <el-form-item label="规格型号:" style="margin-bottom: 0"> |
| | | <el-col style="padding: 10px 0" :span="10"> |
| | | <el-form-item label="规格型号1:" style="margin-bottom: 0"> |
| | | {{ mItem.baseGoodsModelsName }} |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="4"> |
| | | <el-col style="padding: 10px 0" :span="4"> |
| | | <el-form-item label="单位:" style="margin-bottom: 0" label-width="80"> |
| | | {{mItem.unit}} |
| | | </el-form-item> |
| | |
| | | // 提交 |
| | | handleSubmit() { |
| | | console.log('formData', this.formData); |
| | | if(this.loading) return |
| | | this.$refs['ruleForm'].validate((valid) => { |
| | | if (valid) { |
| | | this.formData.transferGoods.map(goods => { |
| | |
| | | import myImport from '@/views/components/myImport'; |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import listPage from '../../../mixins/listPage'; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | import {getUserDetail} from "@/utils/auth"; |
| | | |
| | | export default { |
| | |
| | | import myImport from '@/views/components/myImport'; |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import listPage from '../../../mixins/listPage' |
| | | import listPage from '@/views/mixins/listPage' |
| | | |
| | | export default { |
| | | name: 'index', |
| | |
| | | import myImport from '@/views/components/myImport'; |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import listPage from '../../../mixins/listPage' |
| | | import listPage from '@/views/mixins/listPage' |
| | | |
| | | export default { |
| | | name: 'index', |
| | |
| | | import * as DateFormatter from '@/utils/DateFormatter'; |
| | | import {mapGetters} from 'vuex'; |
| | | import * as dataExport from "@/api/exportExcel" |
| | | |
| | | export default { |
| | | data() { |
| | | return { |
| | | loading: false, |
| | | list: [], |
| | | items:[], |
| | | filterFrom:{}, |
| | | items: [], |
| | | filterFrom: {}, |
| | | editSetting: { |
| | | title: '', |
| | | id: '', |
| | | orgId: '', |
| | | show: false, |
| | | title: '', |
| | | id: '', |
| | | orgId: '', |
| | | show: false, |
| | | }, |
| | | detailSetting: { |
| | | title: '详情', |
| | | id: '', |
| | | show: false, |
| | | title: '详情', |
| | | id: '', |
| | | show: false, |
| | | }, |
| | | pageNum: 1, |
| | | pageSize: 10, |
| | |
| | | } |
| | | }, |
| | | computed: { |
| | | ...mapGetters(['userInfo']), |
| | | clientHeight() { |
| | | return document.documentElement.clientHeight; |
| | | }, |
| | | ...mapGetters(['userInfo']), |
| | | clientHeight() { |
| | | return document.documentElement.clientHeight; |
| | | }, |
| | | }, |
| | | created() { |
| | | }, |
| | | filters: { |
| | | formatTime(time) { |
| | | if (!time) return '-'; |
| | | return DateFormatter.LongToDateTime(time); |
| | | }, |
| | | formatTime(time) { |
| | | if (!time) return '-'; |
| | | return DateFormatter.LongToDateTime(time); |
| | | }, |
| | | }, |
| | | methods:{ |
| | | fetchData() {}, |
| | | methods: { |
| | | // 导出 |
| | | handleExport() {}, |
| | | handleExport(api, fileName, params) { |
| | | console.log(fileName) |
| | | let loading = this.$loading({ |
| | | lock: true, |
| | | text: '导出中,请稍候...', |
| | | spinner: 'el-icon-loading', |
| | | background: 'rgba(0, 0, 0, 0.7)', |
| | | }); |
| | | // 判断总条数是否大于最大支持条数 |
| | | dataExport[api](params) |
| | | .then((res) => { |
| | | const blob = new Blob([res], {type: 'application/vnd.ms-excel'}); |
| | | if ('download' in document.createElement('a')) { |
| | | // 非IE下载 |
| | | const elink = document.createElement('a'); |
| | | elink.download = `${fileName}.xls`; |
| | | elink.style.display = 'none'; |
| | | elink.href = URL.createObjectURL(blob); |
| | | document.body.appendChild(elink); |
| | | elink.click(); |
| | | URL.revokeObjectURL(elink.href); |
| | | document.body.removeChild(elink); |
| | | } else { |
| | | // IE10+下载 |
| | | navigator.msSaveBlob(blob, `${fileName}.xls`); |
| | | } |
| | | this.$message.success('导出成功!'); |
| | | loading.close(); |
| | | }) |
| | | .catch(() => { |
| | | loading.close(); |
| | | }); |
| | | }, |
| | | // 新增 |
| | | handleAdd() { |
| | | this.editSetting.id = null; |
| | | this.editSetting.info = null; |
| | | this.editSetting.title = '新增'; |
| | | this.editSetting.show = true; |
| | | this.editSetting.id = null; |
| | | this.editSetting.info = null; |
| | | this.editSetting.title = '新增'; |
| | | this.editSetting.show = true; |
| | | }, |
| | | // 编辑 |
| | | handleEdit(row) { |
| | | this.editSetting.id = row.id; |
| | | this.editSetting.info = null; |
| | | this.editSetting.title = '编辑'; |
| | | this.editSetting.show = true; |
| | | this.editSetting.id = row.id; |
| | | this.editSetting.info = null; |
| | | this.editSetting.title = '编辑'; |
| | | this.editSetting.show = true; |
| | | }, |
| | | // 详情 |
| | | handleDetail(row) { |
| | | this.detailSetting.id = row.id; |
| | | this.detailSetting.title = '详情'; |
| | | this.detailSetting.show = true; |
| | | this.detailSetting.id = row.id; |
| | | this.detailSetting.title = '详情'; |
| | | this.detailSetting.show = true; |
| | | }, |
| | | // 分页 |
| | | handleSizeChange(pageSize) { |
| | | this.pageSize = pageSize; |
| | | this.search({ pageNum: 1 }); |
| | | this.pageSize = pageSize; |
| | | this.search({pageNum: 1}); |
| | | }, |
| | | handleCurrentChange(pageNum) { |
| | | this.pageNum = pageNum; |
| | | this.search(); |
| | | this.pageNum = pageNum; |
| | | this.search(); |
| | | }, |
| | | // 查询table列表 |
| | | search(pageNum) { |
| | | if(pageNum){ |
| | | this.pageNum = pageNum |
| | | } |
| | | this.fetchData(); |
| | | if (pageNum) { |
| | | this.pageNum = pageNum |
| | | } |
| | | this.fetchData(); |
| | | }, |
| | | refreshData() { |
| | | this.pageNum = 1; |
| | | this.pageSize = 10; |
| | | this.search(); |
| | | this.pageNum = 1; |
| | | this.pageSize = 10; |
| | | this.search(); |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | this.search(1); |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | this.search(1); |
| | | }, |
| | | } |
| | | } |
| | |
| | | <span class="value">{{ item.businessFormCode }}</span> |
| | | </div> |
| | | <div class="card-header-right"> |
| | | <el-button site="form" type="success" size="mini" @click="handleExport(item)" |
| | | <el-button site="form" type="success" size="mini" @click="handleExport('outputExport',`出库单-${item.businessFormCode}`,{id:item.id})" |
| | | >导出出库单</el-button |
| | | > |
| | | <el-button name="查看详情" site="form" type="info" size="mini" @click="handleDetail(item)" |
| | |
| | | import myImport from '@/views/components/myImport'; |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import listPage from '../../../mixins/listPage' |
| | | import listPage from '@/views/mixins/listPage' |
| | | import SettingIplatform from '@/utils/settingIplatform'; |
| | | |
| | | export default { |
| | |
| | | this.total = res.totalRows; |
| | | this.loading = false; |
| | | }); |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | if (this.filterFrom.startTime) { |
| | | this.filterFrom.startTime = this.filterFrom.startTime.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.endTime) { |
| | | this.filterFrom.endTime = this.filterFrom.endTime.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.agencyId&&this.filterFrom.agencyId.length) { |
| | | this.filterFrom.agencyId = this.filterFrom.agencyId[this.filterFrom.agencyId.length - 1]; |
| | | } |
| | | this.search(1); |
| | | }, |
| | | }, |
| | | }; |
| | |
| | | <el-row style="margin-top: 15px"> |
| | | <el-col> |
| | | <!--列表--> |
| | | <my-table-v2 ref="myTable" :filter="filterFrom" :table="table" /> |
| | | <my-table-v2 ref="myTable" :filter="filterFrom" :table="table"/> |
| | | </el-col> |
| | | </el-row> |
| | | <!--添加/编辑弹窗--> |
| | | <edit v-if="editSetting.show" :setting="editSetting" @close="editSetting.show = false" @search="search" /> |
| | | <edit v-if="editSetting.show" :setting="editSetting" @close="editSetting.show = false" @search="search"/> |
| | | <inventory |
| | | v-if="inventorySetting.show" |
| | | :setting="inventorySetting" |
| | | @close="inventorySetting.show = false" |
| | | @search="search" |
| | | v-if="inventorySetting.show" |
| | | :setting="inventorySetting" |
| | | @close="inventorySetting.show = false" |
| | | @search="search" |
| | | /> |
| | | <detail v-if="inventoryDetail.show" :setting="inventoryDetail" @close="inventoryDetail.show = false" @search="search" /> |
| | | <detail v-if="inventoryDetail.show" :setting="inventoryDetail" @close="inventoryDetail.show = false" |
| | | @search="search"/> |
| | | </el-card> |
| | | </el-container> |
| | | </el-container> |
| | | <my-import |
| | | :import-setting="importSetting" |
| | | :dialog-show="importSetting.dialogShow" |
| | | :dialog-title="importSetting.dialogTitle" |
| | | :import-setting="importSetting" |
| | | :dialog-show="importSetting.dialogShow" |
| | | :dialog-title="importSetting.dialogTitle" |
| | | /> |
| | | </div> |
| | | </template> |
| | |
| | | import {inventoryDel, inventoryListApi} from '@/api/stock/inventory'; |
| | | import * as DateFormatter from '@/utils/DateFormatter'; |
| | | import {mapGetters} from 'vuex'; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | |
| | | export default { |
| | | name: 'index', |
| | | components: { MyButton, MyTableV2, edit, myImport, inventory,detail }, |
| | | mixins: [listPage], |
| | | components: {MyButton, MyTableV2, edit, myImport, inventory, detail}, |
| | | data() { |
| | | return { |
| | | // 搜索框 |
| | |
| | | orgId: '', |
| | | show: false, |
| | | }, |
| | | inventoryDetail:{ |
| | | inventoryDetail: { |
| | | title: '', |
| | | id: '', |
| | | orgId: '', |
| | |
| | | }, |
| | | // 列信息 |
| | | columns: [ |
| | | { title: '盘点单号', field: 'businessFormCode', align: 'center', width: 130 }, |
| | | { title: '任务名称', field: 'businessFormName', align: 'left', minWidth: 140 }, |
| | | { title: '盘点仓库', field: 'warehouseName', align: 'left', minWidth: 130 }, |
| | | { title: '盘点人', field: 'operatorName', align: 'center', width: 120 }, |
| | | { title: '监盘人', field: 'operatorName2', align: 'center', width: 120 }, |
| | | {title: '盘点单号', field: 'businessFormCode', align: 'center', width: 130}, |
| | | {title: '任务名称', field: 'businessFormName', align: 'left', minWidth: 140}, |
| | | {title: '盘点仓库', field: 'warehouseName', align: 'left', minWidth: 130}, |
| | | {title: '盘点人', field: 'operatorName', align: 'center', width: 120}, |
| | | {title: '监盘人', field: 'operatorName2', align: 'center', width: 120}, |
| | | { |
| | | title: '盘点时间', |
| | | field: 'inventoryDate', |
| | | align: 'center', |
| | | width: 160, |
| | | formatter: (row) => { |
| | | return { value: row.inventoryDate ? DateFormatter.LongToDateTime(row.inventoryDate) : '-' }; |
| | | return {value: row.inventoryDate ? DateFormatter.LongToDateTime(row.inventoryDate) : '-'}; |
| | | }, |
| | | }, |
| | | { |
| | |
| | | align: 'center', |
| | | width: 160, |
| | | formatter: (row) => { |
| | | return { value: DateFormatter.LongToDateTime(row.createTime) }; |
| | | return {value: DateFormatter.LongToDateTime(row.createTime)}; |
| | | }, |
| | | }, |
| | | { |
| | |
| | | } |
| | | }, |
| | | events: (row) => { |
| | | this.showInventoryDetail(row); |
| | | this.handleExport('inventoryExport', `盘点表-${row.businessFormCode}`, {id: row.id}); |
| | | }, |
| | | }, |
| | | ], |
| | |
| | | ...mapGetters(['userInfo']), |
| | | }, |
| | | created() { |
| | | selectTenantWarehouse({ agencyId: this.userInfo.tenantId }).then((res) => { |
| | | selectTenantWarehouse({agencyId: this.userInfo.tenantId}).then((res) => { |
| | | this.items.forEach((v) => { |
| | | if (v.label == '盘点仓库') { |
| | | v.options = res.map((item) => { |
| | |
| | | }, |
| | | del(row) { |
| | | this.$modal |
| | | .confirm('是否确认删除单号为:' + row.businessFormCode + ' 的数据吗?') |
| | | .then(() => { |
| | | inventoryDel({ id: row.id }).then((res) => { |
| | | this.$message.success('删除成功!'); |
| | | this.search(); |
| | | .confirm('是否确认删除单号为:' + row.businessFormCode + ' 的数据吗?') |
| | | .then(() => { |
| | | inventoryDel({id: row.id}).then((res) => { |
| | | this.$message.success('删除成功!'); |
| | | this.search(); |
| | | }); |
| | | }) |
| | | .catch(() => { |
| | | }); |
| | | }) |
| | | .catch(() => {}); |
| | | }, |
| | | showAdd() { |
| | | this.editSetting.id = null; |
| | |
| | | } else { |
| | | this.$refs.myTable.search(); |
| | | } |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | |
| | | if (this.filterFrom.startTime) { |
| | | this.filterFrom.startTime = this.filterFrom.startTime.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.endTime) { |
| | | this.filterFrom.endTime = this.filterFrom.endTime.replace(/\-/g, ''); |
| | | } |
| | | this.search(1); |
| | | }, |
| | | }, |
| | | }; |
| | |
| | | > |
| | | </template> |
| | | <template v-if="item.states != 1"> |
| | | <el-button site="form" type="success" size="mini" @click="handleExport(item)" |
| | | <el-button site="form" type="success" size="mini" @click="handleExport('procureExport',`采购入库单-${item.businessFormCode}`,{id:item.id})" |
| | | >导出入库单</el-button |
| | | > |
| | | </template> |
| | |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import {getBaseUrl} from '@/utils/base'; |
| | | import listPage from '../../../mixins/listPage'; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | |
| | | export default { |
| | | name: 'index', |
| | |
| | | }, |
| | | { |
| | | type: 'date-picker', |
| | | dataIndex: 'incomeTimeStart', |
| | | dataIndex: 'startTime', |
| | | label: '入库时间', |
| | | defaultValue: '', |
| | | }, |
| | | { |
| | | type: 'date-picker', |
| | | dataIndex: 'incomeTimeEnd', |
| | | dataIndex: 'endTime', |
| | | label: '至', |
| | | defaultValue: '', |
| | | }, |
| | |
| | | }) |
| | | .catch(() => {}); |
| | | }); |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | if (this.filterFrom.incomeTimeStart) { |
| | | this.filterFrom.incomeTimeStart = this.filterFrom.incomeTimeStart.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.incomeTimeEnd) { |
| | | this.filterFrom.incomeTimeEnd = this.filterFrom.incomeTimeEnd.replace(/\-/g, ''); |
| | | } |
| | | this.search(1); |
| | | }, |
| | | }, |
| | | }; |
| | |
| | | <el-col> |
| | | <!--列表--> |
| | | <div class="table-tool-bar" style="margin-bottom: 15px"> |
| | | <my-button name="新增" @click="handleAdd" site="tools" size="medium" /> |
| | | <my-button name="新增" @click="handleAdd" site="tools" size="medium"/> |
| | | </div> |
| | | <div :style="{ 'overflow-y': 'auto', height: 'calc(100vh - 352px)' }"> |
| | | <el-row class="card" :gutter="5" v-loading="loading"> |
| | | <el-col v-for="(item, index) in list" :key="index" class="cm-item"> |
| | | <el-card class="card-data"> |
| | | <div class="card-container"> |
| | | <div class="card-header"> |
| | | <div class="card-header-left"> |
| | | <span>报废单号:</span> |
| | | <span class="value">{{ item.businessFormCode }}</span> |
| | | <div v-loading="loading"> |
| | | <div :style="{ 'overflow-y': 'auto', height: 'calc(100vh - 352px)' }"> |
| | | <el-row v-if="list.length" class="card" :gutter="5"> |
| | | <el-col v-for="(item, index) in list" :key="index" class="cm-item"> |
| | | <el-card class="card-data"> |
| | | <div class="card-container"> |
| | | <div class="card-header"> |
| | | <div class="card-header-left"> |
| | | <span>报废单号:</span> |
| | | <span class="value">{{ item.businessFormCode }}</span> |
| | | |
| | | </div> |
| | | <div class="card-header-right"> |
| | | <el-button site="form" type="success" size="mini" |
| | | @click="handleExport('scrappedExport',`报废单-${item.businessFormCode}`, {id:item.id})" |
| | | >导出报废单 |
| | | </el-button |
| | | > |
| | | <el-button name="查看详情" site="form" type="info" size="mini" @click="handleDetail(item)" |
| | | >查看详情 |
| | | </el-button |
| | | > |
| | | </div> |
| | | </div> |
| | | <div class="card-header-right"> |
| | | <el-button site="form" type="success" size="mini" @click="handleExport(item)" |
| | | >导出报废单</el-button |
| | | > |
| | | <el-button name="查看详情" site="form" type="info" size="mini" @click="handleDetail(item)" |
| | | >查看详情</el-button |
| | | > |
| | | <div class="one-hed"> |
| | | <div class="box"><span class="span-two">机构:</span>{{ item.agencyName }}</div> |
| | | <div class="box"><span class="span-two">操作人:</span>{{ item.operatorName }}</div> |
| | | <div class="box"> |
| | | <span class="span-two">报废时间:</span>{{ item.dealTime | formatTime }} |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="one-hed"> |
| | | <div class="box"><span class="span-two">机构:</span>{{ item.agencyName }}</div> |
| | | <div class="box"><span class="span-two">操作人:</span>{{ item.operatorName }}</div> |
| | | <div class="box"> |
| | | <span class="span-two">报废时间:</span>{{ item.dealTime | formatTime }} |
| | | </div> |
| | | </div> |
| | | <div class="card-end"> |
| | | <div v-for="(just, index) in item.goodTemplateInfo" :key="index" class="item"> |
| | | <div class="name">{{ just.goodsName }}</div> |
| | | <div class="value-box"> |
| | | <div class="value-box-item"> |
| | | <span class="label">数量:</span> |
| | | <span class="value">{{ just.count }}</span> |
| | | <span class="unit">{{ just.unit }}</span> |
| | | <div class="card-end"> |
| | | <div v-for="(just, index) in item.goodTemplateInfo" :key="index" class="item"> |
| | | <div class="name">{{ just.goodsName }}</div> |
| | | <div class="value-box"> |
| | | <div class="value-box-item"> |
| | | <span class="label">数量:</span> |
| | | <span class="value">{{ just.count }}</span> |
| | | <span class="unit">{{ just.unit }}</span> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | </el-card> |
| | | </el-col> |
| | | </el-row> |
| | | </el-card> |
| | | </el-col> |
| | | </el-row> |
| | | |
| | | <el-empty v-else description="暂无数据"></el-empty> |
| | | </div> |
| | | </div> |
| | | |
| | | <el-pagination |
| | | :small="false" |
| | | :current-page="pageNum" |
| | | :page-sizes="[5, 10, 20, 50, 100, 200, 300, 400, 500]" |
| | | :page-size="pageSize" |
| | | layout="total, sizes, prev, pager, next, jumper" |
| | | :total="total" |
| | | @size-change="handleSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | :small="false" |
| | | :current-page="pageNum" |
| | | :page-sizes="[5, 10, 20, 50, 100, 200, 300, 400, 500]" |
| | | :page-size="pageSize" |
| | | layout="total, sizes, prev, pager, next, jumper" |
| | | :total="total" |
| | | @size-change="handleSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | /> |
| | | </el-col> |
| | | </el-row> |
| | |
| | | </el-container> |
| | | <!--添加/编辑弹窗--> |
| | | <edit |
| | | v-if="editSetting.show" |
| | | :setting="editSetting" |
| | | ref="editRef" |
| | | @close="editSetting.show = false" |
| | | @search="refreshData" |
| | | v-if="editSetting.show" |
| | | :setting="editSetting" |
| | | ref="editRef" |
| | | @close="editSetting.show = false" |
| | | @search="refreshData" |
| | | ></edit> |
| | | <detail |
| | | v-if="detailSetting.show" |
| | | :setting="detailSetting" |
| | | @close="detailSetting.show = false" |
| | | ref="detailRef" |
| | | v-if="detailSetting.show" |
| | | :setting="detailSetting" |
| | | @close="detailSetting.show = false" |
| | | ref="detailRef" |
| | | ></detail> |
| | | </div> |
| | | </template> |
| | |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import * as DateFormatter from '@/utils/DateFormatter'; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | |
| | | export default { |
| | | name: 'index', |
| | | components: { MyButton, edit, detail }, |
| | | mixins: [listPage], |
| | | components: {MyButton, edit, detail}, |
| | | data() { |
| | | return { |
| | | loading: false, |
| | | adddialog: false, |
| | | list: [], |
| | | // 搜索框 |
| | | items: [ |
| | |
| | | dataIndex: 'agencyId', |
| | | label: '机构', |
| | | placeholder: '请选择', |
| | | optionsConfig: { url: '/pc/fin/sys/tenant/select/tree_fin_tenant', props: null }, |
| | | optionsConfig: {url: '/pc/fin/sys/tenant/select/tree_fin_tenant', props: null}, |
| | | defaultValue: '', |
| | | options: [], |
| | | }, |
| | |
| | | this.total = res.totalRows; |
| | | this.loading = false; |
| | | }); |
| | | }, |
| | | |
| | | //导入 |
| | | importOrg() { |
| | | this.importSetting.dialogShow = true; |
| | | this.importSetting.onSuccess = (response, callBack) => { |
| | | if (response.code === 1) { |
| | | this.$message.success(response.msg); |
| | | this.search(1); |
| | | } else { |
| | | this.$message.warning(response.msg); |
| | | } |
| | | callBack(); |
| | | }; |
| | | }, |
| | | // 导出 |
| | | handleExport() {}, |
| | | // 新增 |
| | | handleAdd() { |
| | | this.editSetting.id = null; |
| | | this.editSetting.info = null; |
| | | this.editSetting.title = '新增'; |
| | | this.editSetting.show = true; |
| | | }, |
| | | // 详情 |
| | | handleDetail(row) { |
| | | this.detailSetting.id = row.id; |
| | | this.detailSetting.show = true; |
| | | }, |
| | | // 分页 |
| | | handleSizeChange(pageSize) { |
| | | this.pageSize = pageSize; |
| | | this.search(1); |
| | | }, |
| | | handleCurrentChange(pageNum) { |
| | | this.pageNum = pageNum; |
| | | this.search(pageNum); |
| | | }, |
| | | // 查询table列表 |
| | | search(pageNum) { |
| | | if (pageNum) { |
| | | this.pageNum = pageNum; |
| | | } |
| | | this.fetchData(); |
| | | }, |
| | | refreshData() { |
| | | this.pageNum = 1; |
| | | this.pageSize = 10; |
| | | this.search(); |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | if (this.filterFrom.incomeTimeStart) { |
| | | this.filterFrom.incomeTimeStart = this.filterFrom.incomeTimeStart.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.incomeTimeEnd) { |
| | | this.filterFrom.incomeTimeEnd = this.filterFrom.incomeTimeEnd.replace(/\-/g, ''); |
| | | } |
| | | this.search(1); |
| | | }, |
| | | }, |
| | | }; |
| | |
| | | site="form" |
| | | type="primary" |
| | | size="mini" |
| | | @click="handleExport(item)" |
| | | @click="handleExport('transferExport',`调拨入库单-${item.businessFormCode}`,{id:item.id,type: 1})" |
| | | >导出调拨入库单</el-button |
| | | > |
| | | <el-button name="查看详情" site="form" type="info" size="mini" @click="handleDetail(item)" |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import {transfeIncome, transferExport, transferList, transferUpdStatus} from '@/api/stock/transfer'; |
| | | import {transfeIncome, transferList, transferUpdStatus} from '@/api/stock/transfer'; |
| | | import MyButton from '@/components/myButton/myButton'; |
| | | import myImport from '@/views/components/myImport'; |
| | | import edit from './edit'; |
| | | import detail from './detail'; |
| | | import listPage from '../../../mixins/listPage'; |
| | | import transfer from '../../../mixins/transfer'; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | import transfer from '@/views/mixins/transfer'; |
| | | import SettingIplatform from '@/utils/settingIplatform'; |
| | | |
| | | export default { |
| | |
| | | data() { |
| | | return { |
| | | loading: false, |
| | | adddialog: false, |
| | | list: [], |
| | | // 搜索框 |
| | | items: [ |
| | |
| | | this.list = res.datas; |
| | | this.total = res.totalRows; |
| | | this.loading = false; |
| | | console.log(this.list); |
| | | }); |
| | | }, |
| | | |
| | |
| | | }); |
| | | }, |
| | | |
| | | // 导出 |
| | | handleExport(row) { |
| | | transferExport({ id: row.id }).then((res) => {}); |
| | | }, |
| | | |
| | | // 撤销 |
| | | handleRevoke(row) { |
| | | this.$confirm(`您确定撤销单号为"${row.businessFormCode}" 的数据吗?`, '撤销').then(() => { |
| | |
| | | this.search(1); |
| | | }); |
| | | }); |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | if (this.filterFrom.createTimeStart) { |
| | | this.filterFrom.createTimeStart = this.filterFrom.createTimeStart.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.createTimeEnd) { |
| | | this.filterFrom.createTimeEnd = this.filterFrom.createTimeEnd.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.startTime) { |
| | | this.filterFrom.startTime = this.filterFrom.startTime.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.endTime) { |
| | | this.filterFrom.endTime = this.filterFrom.endTime.replace(/\-/g, ''); |
| | | } |
| | | this.search(1); |
| | | }, |
| | | }, |
| | | }; |
| | |
| | | <div v-if="item.states == 4" class="states states-info">已撤销</div> |
| | | </div> |
| | | <div class="card-header-right"> |
| | | <el-button v-if="item.states == 1" site="form" type="success" size="mini" |
| | | >导出调拨出库单</el-button |
| | | > |
| | | <!-- <el-button v-if="item.states == 1" site="form" type="success" size="mini" |
| | | >导出调拨出库单</el-button |
| | | >--> |
| | | <el-button |
| | | v-if="item.states == 0" |
| | | site="form" |
| | | type="success" |
| | | size="mini" |
| | | @click="handleOutput(item)" |
| | | >出库</el-button |
| | | v-if="item.states == 0" |
| | | site="form" |
| | | type="success" |
| | | size="mini" |
| | | @click="handleOutput(item)" |
| | | >出库 |
| | | </el-button |
| | | > |
| | | <el-button v-if="item.states == 2" site="form" type="primary" size="mini" |
| | | >导出调拨入库单</el-button |
| | | > |
| | | @click="handleExport('transferExport',`调拨出库单-${item.businessFormCode}`,{id:item.id,type: 2})"> |
| | | 导出调拨出库单 |
| | | </el-button> |
| | | <el-button name="查看详情" site="form" type="info" size="mini" @click="handleDetail(item)" |
| | | >查看详情</el-button |
| | | >查看详情 |
| | | </el-button |
| | | > |
| | | </div> |
| | | </div> |
| | |
| | | <el-empty v-else description="暂无数据"></el-empty> |
| | | </div> |
| | | <el-pagination |
| | | :small="false" |
| | | :current-page="pageNum" |
| | | :page-sizes="[5, 10, 20, 50, 100, 200, 300, 400, 500]" |
| | | :page-size="pageSize" |
| | | layout="total, sizes, prev, pager, next, jumper" |
| | | :total="total" |
| | | @size-change="handleSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | :small="false" |
| | | :current-page="pageNum" |
| | | :page-sizes="[5, 10, 20, 50, 100, 200, 300, 400, 500]" |
| | | :page-size="pageSize" |
| | | layout="total, sizes, prev, pager, next, jumper" |
| | | :total="total" |
| | | @size-change="handleSizeChange" |
| | | @current-change="handleCurrentChange" |
| | | /> |
| | | </el-col> |
| | | </el-row> |
| | | </el-card> |
| | | </el-container> |
| | | <detail |
| | | v-if="detailSetting.show" |
| | | :setting="detailSetting" |
| | | @close="detailSetting.show = false" |
| | | ref="detailRef" |
| | | v-if="detailSetting.show" |
| | | :setting="detailSetting" |
| | | @close="detailSetting.show = false" |
| | | ref="detailRef" |
| | | ></detail> |
| | | </div> |
| | | </template> |
| | |
| | | import MyButton from '@/components/myButton/myButton'; |
| | | import myImport from '@/views/components/myImport'; |
| | | import detail from './detail'; |
| | | import listPage from '../../../mixins/listPage'; |
| | | import transfer from '../../../mixins/transfer'; |
| | | import listPage from '@/views/mixins/listPage'; |
| | | import transfer from '@/views/mixins/transfer'; |
| | | import {commonsApi} from '@/api/commonsApi'; |
| | | import SettingIplatform from '@/utils/settingIplatform'; |
| | | |
| | | export default { |
| | | name: 'index', |
| | | mixins: [listPage, transfer], |
| | | components: { MyButton, myImport, detail }, |
| | | components: {MyButton, myImport, detail}, |
| | | data() { |
| | | return { |
| | | loading: false, |
| | | adddialog: false, |
| | | list: [], |
| | | // 搜索框 |
| | | items: [ |
| | |
| | | placeholder: '请输入', |
| | | defaultValue: '', |
| | | options: [], |
| | | cascader: [{ key: 'baseGoodsModelsId', queryKey: 'goodsTemplatesId' }], |
| | | cascader: [{key: 'baseGoodsModelsId', queryKey: 'goodsTemplatesId'}], |
| | | optionsConfig: { |
| | | label: 'goodsName', |
| | | value: 'id', |
| | |
| | | dataIndex: 'inAgencyId', |
| | | label: '接收机构', |
| | | placeholder: '请选择', |
| | | optionsConfig: { url: commonsApi.cascader_tree_fin_tenant, props: null }, |
| | | optionsConfig: {url: commonsApi.cascader_tree_fin_tenant, props: null}, |
| | | defaultValue: '', |
| | | options: [], |
| | | }, |
| | |
| | | this.list = res.datas; |
| | | this.total = res.totalRows; |
| | | this.loading = false; |
| | | console.log(this.list); |
| | | }); |
| | | }, |
| | | handleOutput(row) { |
| | |
| | | if (action == 'confirm') { |
| | | instance.confirmButtonLoading = true; |
| | | instance.confirmButtonText = '执行中...'; |
| | | transferOutput({ id: row.id }) |
| | | .then((res) => { |
| | | this.$message.success('调拨出库成功!'); |
| | | done(); |
| | | instance.confirmButtonLoading = false; |
| | | this.search(1); |
| | | }) |
| | | .catch(() => { |
| | | done(); |
| | | }); |
| | | transferOutput({id: row.id}) |
| | | .then((res) => { |
| | | this.$message.success('调拨出库成功!'); |
| | | done(); |
| | | instance.confirmButtonLoading = false; |
| | | this.search(1); |
| | | }) |
| | | .catch(() => { |
| | | done(); |
| | | }); |
| | | } else { |
| | | done(); |
| | | } |
| | | }, |
| | | }); |
| | | }, |
| | | fifterForm(params) { |
| | | this.filterFrom = Object.assign(this.filterFrom, params); |
| | | if (this.filterFrom.createTimeStart) { |
| | | this.filterFrom.createTimeStart = this.filterFrom.createTimeStart.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.createTimeEnd) { |
| | | this.filterFrom.createTimeEnd = this.filterFrom.createTimeEnd.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.startTime) { |
| | | this.filterFrom.startTime = this.filterFrom.startTime.replace(/\-/g, ''); |
| | | } |
| | | if (this.filterFrom.endTime) { |
| | | this.filterFrom.endTime = this.filterFrom.endTime.replace(/\-/g, ''); |
| | | } |
| | | this.search(1); |
| | | }, |
| | | }, |
| | | }; |