New file |
| | |
| | | // 采购状态 |
| | | const purchaseStatus=[ |
| | | { |
| | | name:'已下单', |
| | | id:1, |
| | | }, |
| | | { |
| | | name:'到货质检', |
| | | id:2, |
| | | }, |
| | | { |
| | | name:'已入库', |
| | | id:3, |
| | | }, |
| | | { |
| | | name:'已完成', |
| | | id:4, |
| | | }, |
| | | ] |
| | | |
| | | |
| | | export const getDataByType = type => { |
| | | if(type =='purchaseStatus'){ |
| | | return purchaseStatus; |
| | | } |
| | | } |
| | |
| | | // import request from "@/common/untils/request.js" |
| | | import request from "@/common/untils/request.js" |
| | | import axios from "axios" |
| | | // 销售线索列表 |
| | | export function getSalesLeadsList(data) { |
| | | return request({ |
| | | url: "/api/salesLeads/list", |
| | | method: "post", |
| | | data |
| | | }) |
| | | } |
| | | // 添加销售线索 |
| | | export function getAddSalesLeads(data) { |
| | | return request({ |
| | | url: "/api/salesLeads/add", |
| | | method: "post", |
| | | data |
| | | }) |
| | | } |
| | | // 删除销售线索 |
| | | export function getDeleteSalesLeads(data) { |
| | | return request({ |
| | | url: "/api/salesLeads/delete", |
| | | method: "delete", |
| | | data |
| | | }) |
| | | } |
| | | // 更新销售线索 |
| | | export function getUpdateSalesLeads(data) { |
| | | return request({ |
| | | url: "/api/salesLeads/update", |
| | | method: "put", |
| | | data |
| | | }) |
| | | } |
| | | |
| | | // 推进销售线索 |
| | | export function pushSalesSources(data) { |
| | | return request({ |
| | | url: "/api/salesLeads/push", |
| | | method: "post", |
| | | data |
| | | }) |
| | | } |
| | | |
| | | // 商机来源列表 |
| | | export function getSalesSourcesList() { |
| | | return request({ |
| | | url: "/api/salesSources/list", |
| | | method: "get" |
| | | }) |
| | | } |
| | | // 采购单列表 |
| | | export const getPurchaseList = async (data) => { |
| | | return await axios.get(`/api/purchase/purchaseList`, { |
| | | params: data |
| | | }) |
| | | } |
| | | // 创建采购单 |
| | | export function addPurchase(data) { |
| | | return request({ |
| | | url: "/api/purchase/purchase", |
| | | method: "post", |
| | | data |
| | | }) |
| | | } |
| | | // 更新采购单 |
| | | export function updatePurchase(data) { |
| | | return request({ |
| | | url: "/api/purchase/purchase", |
| | | method: "put", |
| | | data |
| | | }) |
| | | } |
| | | // 获取采购单信息 |
| | | export function getPurchaseInfo(data) { |
| | | return request({ |
| | | url: "/api/purchase/purchase/"+data.id, |
| | | method: "get", |
| | | data |
| | | }) |
| | | } |
| | | // 删除采购单信息 |
| | | export function deletePurchase(data) { |
| | | return request({ |
| | | url: "/api/purchase/purchase/"+data.id, |
| | | method: "delete", |
| | | data |
| | | }) |
| | | } |
| | | // 提交采购单 |
| | | export function submitPurchase(data) { |
| | | return request({ |
| | | url: "/api/purchase/submit/"+data.id, |
| | | method: "post", |
| | | data |
| | | }) |
| | | } |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import { getDeleteSalesLeads } from "@/api/client/salesLead"; |
| | | import { deletePurchase } from "@/api/purchaseManage/purchase"; |
| | | export default { |
| | | name: "DetailSupplier", |
| | | props: { |
| | |
| | | basicInfoList: [], |
| | | isDynamicExpand: true, // 账户信息 |
| | | dynamicInfoList: [], |
| | | addConfig: {}, |
| | | record: "", // 最新进展 |
| | | noContactDays: 0, |
| | | newContactDays: "", |
| | |
| | | }, |
| | | created() { |
| | | this.setData(this.detailConfig.infomation); |
| | | this.addConfig = { |
| | | id_name: "sales_leads_id", |
| | | id: this.detailConfig.infomation.id, |
| | | common_name: this.detailConfig.infomation.id, |
| | | sales_leads_name: this.detailConfig.infomation.name, |
| | | sales_leads_id: this.detailConfig.infomation.id, |
| | | }; |
| | | |
| | | }, |
| | | mounted() {}, |
| | | computed: {}, |
| | |
| | | type: "warning", |
| | | }) |
| | | .then(() => { |
| | | getDeleteSalesLeads({ ids: this.selValueList }).then((response) => { |
| | | deletePurchase({ id: this.commonDetail.infomation.ID }).then((response) => { |
| | | if (response.code === 200) { |
| | | this.$message.success("删除成功"); |
| | | this.getData(); |
| | | this.detailConfig.visible=false; |
| | | this.$parent.getData(); |
| | | } else { |
| | | this.$message.warning("删除失败"); |
| | | } |
| | |
| | | }, |
| | | setData(item) { |
| | | if (item.FollowRecord && item.FollowRecord.length > 0) { |
| | | this.record = item.FollowRecord[0].record; |
| | | console.log(item.FollowRecord[0].follow_time); |
| | | let follow_time = item.FollowRecord[0].follow_time; |
| | | this.newContactDays = follow_time.substring(0, 10); |
| | | this.noContactDays = this.getDiffDay(Date.now(), this.newContactDays); |
| | | } |
| | | this.record =item.record?item.record:'' |
| | | this.formInfoList = [ |
| | | { |
| | | str: "供应商名称", |
| | | value: "", |
| | | value: item.name, |
| | | }, |
| | | { |
| | | str: "合计", |
| | |
| | | }, |
| | | { |
| | | str: "签约日期", |
| | | value: "", |
| | | value:item.signingDate, |
| | | }, |
| | | { |
| | | str: "采购负责人", |
| | |
| | | }, |
| | | { |
| | | leftStr: "采购联系人", |
| | | leftValue: item.contact_phone, |
| | | leftValue: item.contact, |
| | | rightStr: "联系电话", |
| | | rightValue: "18513375588", |
| | | rightValue: item.phone, |
| | | }, |
| | | { |
| | | leftStr: "签约日期", |
| | | leftValue: item.sales_resources, |
| | | leftValue: item.signingDate, |
| | | rightStr: "交付日期", |
| | | rightValue: item.member_name, |
| | | rightValue: item.deliveryDate, |
| | | }, |
| | | { |
| | | leftStr: "到货仓库", |
| | |
| | | }, |
| | | ]; |
| | | this.tableList = { |
| | | tableInfomation: [ |
| | | { |
| | | number:1, |
| | | total:1, |
| | | } |
| | | ], |
| | | tableInfomation: item.productList?item.productList:[], |
| | | selectIndex: true, |
| | | tableColumn: [ |
| | | { label: "产品名称", prop: "number", min: 190, isCommonClick: true }, |
| | | { label: "产品编码", prop: "total", min: 130, isCommonClick: true }, |
| | | { label: "计量单位", prop: "contact_name", min: 130 }, |
| | | { label: "规格型号", prop: "contact_phone", min: 130 }, |
| | | { label: "数量", prop: "contact_phone", min: 130 }, |
| | | { label: "销售单价", prop: "sales_resources", min: 130 }, |
| | | { label: "价税合计", prop: "province", min: 130 }, |
| | | { label: "描述", prop: "province", min: 130 }, |
| | | { label: "产品名称", prop: "name", min: 190, isCommonClick: true }, |
| | | { label: "产品编码", prop: "number", min: 130, isCommonClick: true }, |
| | | { label: "计量单位", prop: "unit", min: 130 }, |
| | | { label: "规格型号", prop: "specifications", min: 130 }, |
| | | { label: "数量", prop: "amount", min: 130 }, |
| | | { label: "销售单价", prop: "price", min: 130 }, |
| | | { label: "价税合计", prop: "total", min: 130 }, |
| | | { label: "描述", prop: "remark", min: 130 }, |
| | | ], |
| | | }; |
| | | }, |
| | |
| | | <el-dialog |
| | | :title="editCommonConfig.title + '采购单'" |
| | | :visible.sync="editConfig.visible" |
| | | :width="dialogWidth" |
| | | width="50%" |
| | | :before-close="handleClose" |
| | | append-to-body |
| | | custom-class="iframe-dialog" |
| | |
| | | <el-col :span="12"> |
| | | <el-form-item |
| | | label="采购类型" |
| | | prop="brand" |
| | | prop="purchaseTypeId" |
| | | class="form-item float_left" |
| | | > |
| | | <el-select |
| | | placeholder="请选择采购类型" |
| | | v-model="editConfig.infomation.client_name" |
| | | v-model="editConfig.infomation.purchaseTypeId" |
| | | clearable |
| | | style="width: calc(100% - 30px)" |
| | | > |
| | |
| | | </el-col> |
| | | |
| | | <el-col :span="12"> |
| | | <el-form-item label="供应商名称" prop="client_name"> |
| | | <el-form-item label="供应商名称" prop="supplierName"> |
| | | <div class="custom-name"> |
| | | <el-autocomplete |
| | | style="width: calc(100% - 40px)" |
| | | v-model="editConfig.infomation.client_name" |
| | | v-model="editConfig.infomation.supplierName" |
| | | :fetch-suggestions=" |
| | | (queryString, callback) => { |
| | | querySearchAsync(queryString, callback, 'client'); |
| | |
| | | </div> |
| | | <div |
| | | v-if=" |
| | | editConfig.infomation.client_name && |
| | | editConfig.infomation.client_name.length > 0 |
| | | editConfig.infomation.supplierName && |
| | | editConfig.infomation.supplierName.length > 0 |
| | | " |
| | | class="common-select-btn" |
| | | @click="clearupClient('client')" |
| | |
| | | <el-form-item label="单据来源" prop="number"> |
| | | <el-input |
| | | v-model="editConfig.infomation.number" |
| | | disabled |
| | | placeholder="请填写" |
| | | ></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="采购单名称" prop="number"> |
| | | <el-form-item label="采购单名称" prop="name"> |
| | | <el-input |
| | | v-model="editConfig.infomation.number" |
| | | v-model="editConfig.infomation.name" |
| | | placeholder="请填写" |
| | | clearable |
| | | ></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="供应商联系人" prop="number"> |
| | | <el-form-item label="供应商联系人" prop="contact"> |
| | | <el-input |
| | | v-model="editConfig.infomation.number" |
| | | v-model="editConfig.infomation.contact" |
| | | placeholder="请填写" |
| | | clearable |
| | | ></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="联系电话" prop="contact_phone"> |
| | | <el-form-item label="联系电话" prop="phone"> |
| | | <el-input |
| | | v-model="editConfig.infomation.contact_phone" |
| | | v-model="editConfig.infomation.phone" |
| | | placeholder="请填写" |
| | | clearable |
| | | ></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="签约日期" prop="validity_date"> |
| | | <el-form-item label="签约日期" prop="signingDate"> |
| | | <el-date-picker |
| | | v-model="editConfig.infomation.validity_date" |
| | | v-model="editConfig.infomation.signingDate" |
| | | style="width: 100%" |
| | | type="date" |
| | | clearable |
| | | placeholder="选择日期" |
| | | value-format="yyyy-MM-dd" |
| | | > |
| | |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <el-form-item label="交付日期" prop="validity_date"> |
| | | <el-form-item label="交付日期" prop="deliveryDate"> |
| | | <el-date-picker |
| | | v-model="editConfig.infomation.validity_date" |
| | | v-model="editConfig.infomation.deliveryDate" |
| | | style="width: 100%" |
| | | type="date" |
| | | clearable |
| | | placeholder="选择日期" |
| | | value-format="yyyy-MM-dd" |
| | | > |
| | |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="24"> |
| | | <el-form-item label="备注信息" prop="member_id"> |
| | | <el-form-item label="备注信息" prop="remark"> |
| | | <el-input |
| | | type="textarea" |
| | | :autosize="{ minRows: 3, maxRows: 4 }" |
| | | maxlength="500" |
| | | clearable |
| | | v-model="editConfig.infomation.member_id" |
| | | v-model="editConfig.infomation.remark" |
| | | ></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | |
| | | @inputContent="inputContent" |
| | | @addProductClick="addProductClick" |
| | | @emptyProductClick="emptyProductClick" |
| | | @recalculateProductClick="recalculateProductClick" |
| | | @clearupProduct="clearupProduct" |
| | | /> |
| | | </div> |
| | |
| | | >取消</el-button |
| | | > |
| | | </div> |
| | | <!-- 选择客户 --> |
| | | <SelectClientDialog |
| | | v-if="editSelectClientConfig.editVisible" |
| | | :edit-common-config="editSelectClientConfig" |
| | | <!-- 选择供应商名称--> |
| | | <SelectSupplierDialog |
| | | v-if="editSelectSupplierConfig.editVisible" |
| | | :edit-common-config="editSelectSupplierConfig" |
| | | @selClient="selClient" |
| | | /> |
| | | </el-dialog> |
| | |
| | | <script> |
| | | import CommonFormTableView from "@/components/makepager/CommonFormTableView"; |
| | | import BomDialog from "@/components/makepager/BomDialog"; |
| | | |
| | | import { |
| | | getAddQuotation, |
| | | getUpdateQuotation, |
| | | getAllData, |
| | | addPurchase, |
| | | updatePurchase, |
| | | } from "@/api/purchaseManage/purchase"; |
| | | // import { |
| | | // postGetUnitDictList, |
| | | // postGetSaveSUnitDict, |
| | | // } from "@/api/purchaseManage/purchase"; |
| | | import SelectClientDialog from "@/views/purchaseManage/purchase/components/SelectClientDialog"; |
| | | import SelectSupplierDialog from "@/views/purchaseManage/purchase/components/SelectSupplierDialog"; |
| | | export default { |
| | | name: "QuotationDialog", |
| | | components: { SelectSupplierDialog, CommonFormTableView,BomDialog }, |
| | | props: { |
| | | editCommonConfig: { |
| | | type: Object, |
| | |
| | | }, |
| | | }, |
| | | }, |
| | | components: { SelectClientDialog, CommonFormTableView,BomDialog }, |
| | | computed: { |
| | | searchCommonHeight() { |
| | | return this.$refs.searchCommonView.offsetHeight; |
| | | }, |
| | | contactNamelist() { |
| | | return this.$store.state.getClientName.contactNamelist; |
| | | }, |
| | | }, |
| | | data() { |
| | | return { |
| | | dialogWidth: "50%", |
| | | editConfig: this.editCommonConfig, |
| | | rules: { |
| | | client_id: [{ required: true, message: "请输入", trigger: "blur" }], |
| | | number: [{ required: true, message: "请输入", trigger: "blur" }], |
| | | quotation_status_id: [ |
| | | { required: true, message: "请选择", trigger: "change" }, |
| | | ], |
| | | member_id: [ |
| | | { required: true, message: "请选择负责人", trigger: "change" }, |
| | | ], |
| | | contact_phone: [ |
| | | supplierName: [{ required: true, message: "请选择", trigger: "change" }], |
| | | phone: [ |
| | | { |
| | | required: true, |
| | | required: false, |
| | | message: "请填写", |
| | | trigger: "change", |
| | | }, |
| | | { validator: this.validatorPhone, trigger: "change" }, |
| | | ], |
| | | }, |
| | | memberOptions: [], |
| | | quotationStatusOptions: [{ id: 1, name: "不知道" }], // 报价单状态 |
| | | currencyOptions: [{ id: 1, name: "人民币" }], // 币种 |
| | | approvalWorkflowOptions: [], // 审批流程 |
| | | productTableList: {}, |
| | | showSummary: { |
| | | show: true, |
| | | total: false, |
| | | sumProp: ["Amount", "total"], |
| | | sumProp: ["price", "total"], |
| | | titleProp: [ |
| | | "编号", |
| | | "产品名称", |
| | |
| | | ], |
| | | mergeNumber: 4, |
| | | }, |
| | | editSelectClientConfig: { |
| | | editSelectSupplierConfig: { |
| | | editVisible: false, |
| | | title: "", |
| | | infomation: {}, |
| | | }, |
| | | clientId: this.editCommonConfig.infomation.client_id, |
| | | contactId: this.editCommonConfig.infomation.contact_id, |
| | | saleChanceId: this.editCommonConfig.infomation.sale_chance_id, |
| | | supplierId: this.editCommonConfig.infomation.supplierId, |
| | | tableData: [], |
| | | productId: 1, |
| | | isNoProduct: true, |
| | |
| | | }, |
| | | created() { |
| | | this.setTableForm(); |
| | | this.getCommonData(); |
| | | }, |
| | | computed: { |
| | | }, |
| | | watch:{ |
| | | 'editCommonConfig.visible':{ |
| | | immediate:true, |
| | | handler:function(){ |
| | | this.setTableForm(); |
| | | } |
| | | } |
| | | }, |
| | | methods: { |
| | | // PLC配置设置 |
| | |
| | | callback(); |
| | | } |
| | | }, |
| | | getCommonData() { |
| | | getAllData() |
| | | .then((res) => { |
| | | this.memberOptions = res.data.member; |
| | | this.quotationStatusOptions = res.data.quotationStatus; |
| | | }) |
| | | .catch((err) => { |
| | | console.log(err); |
| | | }); |
| | | }, |
| | | |
| | | // 保存 |
| | | saveClick(formName) { |
| | | this.$refs[formName].validate((valid) => { |
| | |
| | | const params = this.saveParams(); |
| | | console.log(params); |
| | | if (this.editConfig.title === "创建") { |
| | | getAddQuotation(params).then((res) => { |
| | | addPurchase(params).then((res) => { |
| | | console.log(res); |
| | | this.editConfig.visible = false; |
| | | if (res.code === 200) { |
| | |
| | | } |
| | | }); |
| | | } else { |
| | | getUpdateQuotation(params).then((res) => { |
| | | updatePurchase(params).then((res) => { |
| | | this.editConfig.visible = false; |
| | | if (res.code === 200) { |
| | | this.$message.success("编辑成功"); |
| | |
| | | }); |
| | | }, |
| | | saveParams() { |
| | | let data = this.editConfig.infomation; |
| | | debugger |
| | | let data =JSON.parse(JSON.stringify(this.editConfig.infomation)); |
| | | let params = { |
| | | id: this.editConfig.title === "创建" ? 0 : data.id, |
| | | client_id: this.clientId || 0, |
| | | conditions: data.conditions || "", |
| | | contact_id: this.contactId || 0, |
| | | file: data.file || "", |
| | | member_id: data.member_id || 0, |
| | | number: data.number || "", |
| | | quotation_status_id: data.quotation_status_id || 0, |
| | | sale_chance_id: this.saleChanceId || 0, |
| | | validity_date: data.validity_date || "", |
| | | products: this.tableData, |
| | | productList:this.tableData, |
| | | purchase:{ |
| | | supplierId:this.supplierId||0, |
| | | signingDate:data.signingDate||'', |
| | | remark:data.remark, |
| | | purchaseTypeId:this.purchaseTypeId||0, |
| | | phone:data.phone||'', |
| | | name:data.name||'', |
| | | deliveryDate:data.deliveryDate||'', |
| | | contact:data.contact |
| | | } |
| | | }; |
| | | if(data.ID){ |
| | | params.purchase.id=data.ID |
| | | } |
| | | return params; |
| | | }, |
| | | handleClose() { |
| | |
| | | var restaurants = []; |
| | | if (value === "client") { |
| | | restaurants = this.clientList; |
| | | } else if (value === "contact") { |
| | | restaurants = this.contactNamelist; |
| | | } |
| | | } |
| | | var results = queryString |
| | | ? restaurants.filter(this.createStateFilter(queryString)) |
| | | : restaurants; |
| | |
| | | handleSelectClient(value, item) { |
| | | console.log(value); |
| | | if (value === "client") { |
| | | this.clientId = item.id; |
| | | } else if (value === "chance") { |
| | | this.saleChanceId = item.id; |
| | | } else { |
| | | this.contactId = item.id; |
| | | this.supplierId = item.id; |
| | | } |
| | | }, |
| | | selClientClick() { |
| | | this.editSelectClientConfig.editVisible = true; |
| | | this.editSelectSupplierConfig.editVisible = true; |
| | | }, |
| | | selClient(row) { |
| | | this.editConfig.infomation.client_name = row.name; |
| | | this.clientId = row.id; |
| | | this.$set(this.editConfig.infomation,'supplierName',row.name) |
| | | this.editConfig.infomation.contact = row.contact; |
| | | this.editConfig.infomation.phone = row.phone; |
| | | this.supplierId = row.ID; |
| | | }, |
| | | // 清除已选择用户 |
| | | clearupClient(value) { |
| | | if (value == "client") { |
| | | this.editConfig.infomation.client_name = ""; |
| | | this.$set(this.editConfig.infomation, "client_name", ""); |
| | | this.clientId = null; |
| | | this.$set(this.editConfig.infomation, "supplierName", ""); |
| | | this.supplierId = null; |
| | | this.$forceUpdate(); |
| | | } |
| | | }, |
| | | // 添加附件 |
| | | addAnnexClick() {}, |
| | | // 设置允许上传文件格式 |
| | | setFormatClick() {}, |
| | | setTableForm() { |
| | | if ( |
| | | this.editConfig.title === "创建" || |
| | | this.editConfig.infomation.products.length === 0 |
| | | !this.editConfig.infomation.ID || |
| | | this.editConfig.infomation.productList.length === 0 |
| | | ) { |
| | | this.tableData = [ |
| | | { |
| | |
| | | }, |
| | | ]; |
| | | } else { |
| | | this.tableData = this.editConfig.infomation.products; |
| | | this.tableData.map((item, index) => { |
| | | item.productId = index + 1; |
| | | }); |
| | | this.tableData = this.editConfig.infomation.productList; |
| | | // this.tableData.map((item, index) => { |
| | | // item.productId = index + 1; |
| | | // }); |
| | | } |
| | | this.productTableList = { |
| | | tableData: this.tableData, |
| | | tableColumn: [ |
| | | { label: "编号", prop: "productId", width: 40 }, |
| | | { |
| | | label: "产品名称", |
| | | prop: "name", |
| | |
| | | isRequird: true, |
| | | }, |
| | | { label: "产品编号", prop: "number" }, |
| | | { label: "计量单位", prop: "number" }, |
| | | { label: "规格型号", prop: "number" }, |
| | | { label: "计量单位", prop: "unit" }, |
| | | { label: "规格型号", prop: "specifications" }, |
| | | { label: "数量", prop: "amount", inputNumber: true, isRequird: true }, |
| | | { |
| | | label: "采购单价", |
| | |
| | | isRequird: true, |
| | | }, |
| | | { label: "价税合计", prop: "total", inputFloat: true }, |
| | | { label: "描述", prop: "name", input: true }, |
| | | { label: "描述", prop: "remark", input: true }, |
| | | ], |
| | | }; |
| | | }, |
| | |
| | | name: "", |
| | | number: "", |
| | | price: 0, |
| | | total: 0, |
| | | total: 0 |
| | | }, |
| | | ]; |
| | | this.productTableList.tableData = this.tableData; |
| | | }, |
| | | // 产品重算 |
| | | recalculateProductClick() {}, |
| | | clearupProduct(data) { |
| | | this.tableData = data; |
| | | this.productTableList.tableData = this.tableData; |
File was renamed from src/views/purchaseManage/purchase/components/SelectClientDialog.vue |
| | |
| | | <template> |
| | | <div class="edit-selClient-box"> |
| | | <el-dialog |
| | | :title="'客户管理'" |
| | | :title="'供应商名称'" |
| | | :visible.sync="editConfig.editVisible" |
| | | :width="dialogWidth" |
| | | :before-close="handleClose" |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import { |
| | | getClientList |
| | | } from "@/api/purchaseManage/purchase"; |
| | | import { getSupplierList } from "@/api/supplierManage/supplier" |
| | | export default { |
| | | name: "EditSelClientDialog", |
| | | props: { |
| | |
| | | this.tableList = { |
| | | tableInfomation: [], |
| | | tableColumn: [ |
| | | { label: "客户名称", prop: "name", min: 100, isClick: true }, |
| | | { label: "客户编号", prop: "number" }, |
| | | { label: "客户状态", prop: "client_status" }, |
| | | { label: "销售负责人", prop: "member_name", min: 100 }, |
| | | { label: "法定代表人", prop: "representative", min: 100 }, |
| | | { label: "注册时间", prop: "registration_time" }, |
| | | { label: "经营范围", prop: "business_scope" }, |
| | | { label: "详细地址", prop: "detail_address" }, |
| | | { label: "备注", prop: "remark" } |
| | | { label: "供应商编号", prop: "number", min: 190, isCommonClick: true }, |
| | | { label: "供应商名称", prop: "name", min: 130 }, |
| | | { label: "供应商类型", prop: "supplierType", min: 130 }, |
| | | { label: "所属行业", prop: "industry", min: 130 }, |
| | | { label: "联系人", prop: "contact", min: 130 }, |
| | | { label: "联系电话", prop: "phone", min: 130 }, |
| | | { label: "状态", prop: "status_name", min: 130 }, |
| | | { label: "创建时间", prop: "member_name", min: 130 } |
| | | ] |
| | | } |
| | | this.searchOptions = [] |
| | |
| | | this.editConfig.editVisible = false |
| | | }, |
| | | // 请求数据 |
| | | async getData() { |
| | | async getData(val, content) { |
| | | this.loading = true |
| | | await getClientList({ |
| | | search_map: this.search_map, |
| | | page: 0, |
| | | pageSize: 0 |
| | | await getSupplierList({ |
| | | [val]: content, |
| | | page:1, |
| | | pageSize: 10 |
| | | }) |
| | | .then((res) => { |
| | | console.log(res) |
| | | if (res.code === 200) { |
| | | if (res.data.list && res.data.list.length > 0) { |
| | | const list = res.data.list.map((item) => { |
| | | if (res.data.code == 200) { |
| | | if (res.data.data.list && res.data.data.list.length > 0) { |
| | | const list = res.data.data.list.map((item) => { |
| | | return { |
| | | ...item, |
| | | client_status: item.client_status.name, |
| | | member_name: item.member.username |
| | | status_name: item.status === 0 ? "未启用" : "启用" |
| | | } |
| | | }) |
| | | this.tableList.tableInfomation = list.slice(0, 5) || [] |
| | |
| | | }) |
| | | .catch((err) => { |
| | | console.log(err) |
| | | this.this.tableList.tableInfomation = [] |
| | | this.tableList.tableInfomation = [] |
| | | this.loading = false |
| | | }) |
| | | }, |
| | |
| | | }, |
| | | // 搜索 |
| | | searchClick(val, content) { |
| | | console.log(val, content) |
| | | this.search_map = { |
| | | [val.value]: content |
| | | } |
| | | this.getData() |
| | | this.getData(val.value, content) |
| | | }, |
| | | resetClick() { |
| | | this.search_map = {} |
| | | this.getData() |
| | | } |
| | | } |
| | |
| | | <!-- 新建/编辑销售线索 --> |
| | | <!-- <AddSalesLeadDialog v-if="editSalesLeadConfig.visible" :edit-rightContent-config="editSalesLeadConfig" /> --> |
| | | <!-- 详情 --> |
| | | <DetailSupplier v-if="commonDetail.visible" :common-detail="commonDetail" @submitClick="submitClick" /> |
| | | <DetailSupplier v-if="commonDetail.visible" :common-detail="commonDetail" /> |
| | | <!-- 新建/编辑 --> |
| | | <AddPurchase v-if="editConfig.visible" :edit-common-config="editConfig" /> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | |
| | | import pageMixin from "@/components/makepager/pager/mixin/pageMixin" |
| | | import { |
| | | getSalesLeadsList, getDeleteSalesLeads |
| | | getPurchaseList,getPurchaseInfo,submitPurchase, |
| | | } from "@/api/purchaseManage/purchase"; |
| | | import DetailSupplier from "@/views/purchaseManage/purchase/DetailSupplier" |
| | | import AddPurchase from "@/views/purchaseManage/purchase/components/AddPurchase" |
| | | import { getDataByType } from "@/api/data"; |
| | | export default { |
| | | name: "SupplierManage", |
| | | props: {}, |
| | |
| | | title: "创建", |
| | | infomation: {} |
| | | }, |
| | | purchaseStatusList:getDataByType('purchaseStatus'), |
| | | } |
| | | }, |
| | | created() { |
| | |
| | | selectIndex: true, |
| | | tableColumn: [ |
| | | { label: "采购单号", prop: "number", min: 150, isCommonClick: true }, |
| | | { label: "采购单名称", prop: "name", min: 130,}, |
| | | { label: "采购单名称", prop: "name", min: 130, isCommonClick: true}, |
| | | { label: "单据类型", prop: "contact_name", min: 130 }, |
| | | { label: "供应商名称", prop: "contact_phone", min: 130 }, |
| | | { label: "供应商名称", prop: "contact", min: 130 }, |
| | | { label: "采购数量", prop: "sales_resources", min: 130 }, |
| | | { label: "收货仓库", prop: "province", min: 130 }, |
| | | { label: "经办人", prop: "city", min: 130 }, |
| | |
| | | }, |
| | | // 请求数据 |
| | | async getData() { |
| | | await getSalesLeadsList({ |
| | | search_map: this.search_map, |
| | | await getPurchaseList({ |
| | | keyword: this.search_map, |
| | | page: this.pagerOptions.currPage, |
| | | pageSize: this.pagerOptions.pageSize |
| | | }) |
| | | .then((res) => { |
| | | const list = res.data.list.map((item) => { |
| | | return { |
| | | ...item, |
| | | province: item.Province.name, |
| | | city: item.City.name, |
| | | sales_resources: item.sales_sources.name, |
| | | member_name: item.member.username |
| | | } |
| | | }) |
| | | this.tableList.tableInfomation = list || [] |
| | | this.pagerOptions.totalCount = res.data.count |
| | | if (res.data.code === 200) { |
| | | const list = res.data.data.list |
| | | this.tableList.tableInfomation = list || [] |
| | | this.pagerOptions.totalCount = res.data.data.total |
| | | } |
| | | }) |
| | | .catch((err) => { |
| | | console.log(err) |
| | |
| | | // this.$refs.add.islook = true; |
| | | this.editConfig.visible = true |
| | | this.editConfig.title = "创建" |
| | | this.editConfig.infomation = { } |
| | | this.editConfig.infomation = { |
| | | productList:[], |
| | | supplierId:'', |
| | | signingDate:'', |
| | | remark:'', |
| | | purchaseTypeId:'', |
| | | phone:'', |
| | | name:'', |
| | | deliveryDate:'', |
| | | contact:'' |
| | | } |
| | | }, |
| | | |
| | | // 编辑 |
| | | editClick(row){ |
| | | getPurchaseInfo({id:row.ID}).then((res) => { |
| | | if (res.code == 200) { |
| | | this.editConfig.visible = true |
| | | this.editConfig.title = "编辑" |
| | | this.editConfig.infomation = { |
| | | productList:res.data.productList, |
| | | ...res.data.purchase |
| | | } |
| | | }else{ |
| | | this.$message.error(res.msg?res.msg+',':''+'获取信息失败!') |
| | | } |
| | | }) |
| | | // this.editRow = row; |
| | | // this.$refs.add.islook = true; |
| | | this.editConfig.visible = true |
| | | this.editConfig.title = "编辑" |
| | | this.editConfig.infomation = { ...row } |
| | | |
| | | }, |
| | | // 确认发货 |
| | | submitClick() { |
| | | submitClick(row) { |
| | | this.$confirm("是否提交?", "提示", { |
| | | confirmButtonText: "确定", |
| | | cancelButtonText: "取消", |
| | |
| | | }) |
| | | .then(() => { |
| | | console.log("dddd") |
| | | getDeleteSalesLeads({ ids: this.selValueList }).then((response) => { |
| | | submitPurchase({ id: row.ID }).then((response) => { |
| | | if (response.code === 200) { |
| | | this.$message.success("提交成功") |
| | | this.getData() |
| | |
| | | // 详情 |
| | | selCommonClick(row) { |
| | | console.log(row) |
| | | this.commonDetail.visible = true |
| | | this.commonDetail.infomation = { ...row } |
| | | getPurchaseInfo({id:row.ID}).then((res) => { |
| | | if (res.code == 200) { |
| | | this.commonDetail.visible = true |
| | | this.commonDetail.infomation = { |
| | | productList:res.data.productList, |
| | | ...res.data.purchase |
| | | } |
| | | }else{ |
| | | this.$message.error(res.msg?res.msg+',':''+'获取信息失败!') |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | } |
| | |
| | | proxy: { |
| | | "/api": { |
| | | target: "http://192.168.20.118:8889", // http://192.168.20.119:8002 http://fai365.com:30150/ |
| | | // target: "http://192.168.20.120:8889", |
| | | // target: "http://192.168.20.119:8004", |
| | | ws: true, |
| | | changeOrigin: true |
| | | } |