master
fengtianyangyang 2022-09-02 10:46:41 +08:00
commit ba91d7c26d
17 changed files with 935 additions and 240 deletions

View File

@ -1,16 +1,26 @@
<template> <template>
<div class="wrapper"> <div class="wrapper">
<Tabs :value="wap[0].title" class="tabs"> <Tabs :value="wap[0].title" class="tabs">
<TabPane :label="item.title" :name="item.title" @click="clickTag(item, i)" v-for="(item, i) in wap" :key="i"> <!-- <template v-for="(item, i) in wap"> -->
<component ref="lili-component" :is="templateWay[item.name]" @selected=" <TabPane
v-for="(item, i) in wap"
:label="item.title"
:name="item.title"
@click="clickTag(item, i)"
:key="i"
>
<component
ref="lili-component"
:is="templateWay[item.name]"
@selected="
(val) => { (val) => {
changed = val; changed = val;
} }
" /> "
/>
</TabPane> </TabPane>
<!-- </template> -->
</Tabs> </Tabs>
</div> </div>
</template> </template>
<script> <script>
@ -19,7 +29,7 @@ import goodsDialog from "./goods-dialog";
import templateWay from "./template/index"; import templateWay from "./template/index";
export default { export default {
components: { components: {
goodsDialog, goodsDialog
}, },
data() { data() {
return { return {
@ -35,19 +45,32 @@ export default {
handler(val) { handler(val) {
this.$emit("selectedLink", val[0]); // this.$emit("selectedLink", val[0]); //
}, },
deep: true, deep: true
}, }
}, },
mounted() { mounted() {
this.$nextTick(() => { this.$nextTick(() => {
this.$refs["lili-component"][0].type = "single"; // this.$refs["lili-component"][0].type = "single"; //
}); });
this.wap.forEach((item) => { this.wap.forEach(item => {
if (item) {
item.selected = false; item.selected = false;
}
}); });
}, },
methods: {}, methods: {
// isVisible(item) {
// const type = this.$route.query.pagetype;
// if (type == "INDEX" && [ "discover"].includes(item.name)) {
// return false;
// }else if(type == "DISCOVER" && item.name == 'special'){
// return false;
// }else{
// return true
// }
// },
}
}; };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">

View File

@ -5,6 +5,7 @@ import marketing from './marketing.vue'
import pages from './pages.vue' import pages from './pages.vue'
import goods from '../goods-dialog.vue' import goods from '../goods-dialog.vue'
import other from './other.vue' import other from './other.vue'
import special from './special.vue'
export default { export default {
pages, pages,
marketing, marketing,
@ -12,4 +13,5 @@ export default {
category, category,
goods, goods,
other, other,
special
} }

View File

@ -0,0 +1,169 @@
<template>
<div class="wrapper">
<div class="content">
<div >
<div class="tables">
<Table
border
height="350"
tooltip
:loading="loading"
:columns="columns"
:data="data"
>
</Table>
<Page
@on-change="
(val) => {
params.pageNumber = val;
}
"
:current="params.pageNumber"
:page-size="params.pageSize"
class="mt_10"
:total="Number(totals)"
size="small"
show-elevator
/>
</div>
</div>
</div>
</div>
</template>
<script>
import {
getAllPromotion,
} from "@/api/promotion";
import { getHomeList } from "@/api/other.js";
export default {
data() {
return {
loading: true, //true
promotionList: "", //
selectedIndex: 0, //
promotions: "", //key
index: 999, //
data:[],
params: {
sort: "createTime",
order: "desc",
pageClientType: "H5",
pageNumber: 1,
pageSize: 10,
pageType: "SPECIAL",
},
total: 0, //
columns: [
{
title: "专题名称",
key: "name",
tooltip: true,
// slot: 'name'
// width: 200,
},
{
title: "操作",
key: "action",
fixed: "right",
width: 100,
render: (h, params) => {
return h("div", [
h(
"Button",
{
props: {
type: this.index == params.index ? "primary" : "",
size: "small",
},
on: {
click: () => {
this.index = params.index;
this.$emit("selected", [params.row]);
},
},
},
this.index == params.index ? "已选" : "选择"
),
]);
},
},
],
};
},
mounted() {
this.init();
},
methods: {
//
async init() {
let res = await getHomeList(this.params);
if (res.success) {
this.loading = false;
this.data= res.result.records
} else {
this.loading = false;
}
},
},
};
</script>
<style lang="scss" scoped>
img {
max-width: 100% !important;
}
.search {
width: 300px;
}
.page {
margin-top: 2vh;
text-align: right;
}
.time {
font-size: 12px;
}
.tables {
height: 400px;
margin-top: 20px;
overflow: auto;
width: 100%;
}
/deep/ .ivu-table-wrapper {
width: 100%;
}
.list {
margin: 0 1.5%;
height: 400px;
overflow: auto;
> .list-item {
padding: 10px;
transition: 0.35s;
cursor: pointer;
}
.list-item:hover {
background: #ededed;
}
}
.list {
flex: 1;
width: auto;
}
.content {
overflow: hidden;
flex: 4;
}
.active {
background: #ededed;
}
.wrapper {
overflow: hidden;
}
.search-views {
display: flex;
> * {
margin: 0 4px;
}
}
</style>

View File

@ -29,5 +29,10 @@ export default [
title: "其他", title: "其他",
url: "3", url: "3",
name: "other" name: "other"
} },
{
title: "专题",
url: "4",
name: "special"
},
]; ];

View File

@ -82,7 +82,9 @@ export default {
pageNumber:1, pageNumber:1,
pageSize:10, pageSize:10,
sort: 'createTime', sort: 'createTime',
order: 'desc' order: 'desc',
pageType:"INDEX",
pageClientType:"PC",
}, },
columns: [ columns: [
// column // column
@ -106,10 +108,10 @@ export default {
type: "INDEX", type: "INDEX",
title: "首页", title: "首页",
}, },
// { {
// type: "SPECIAL", type: "SPECIAL",
// title: "", title: "专题",
// }, }
], ],
list: [], // list: [], //
}; };
@ -125,7 +127,8 @@ export default {
const data = this.formData; const data = this.formData;
data.status ? (data.pageShow = "OPEN") : (data.pageShow = "CLOSE"); data.status ? (data.pageShow = "OPEN") : (data.pageShow = "CLOSE");
delete data.status; delete data.status;
(data.pageType = "INDEX"), (data.pageClientType = "PC"); // (data.pageType = "INDEX"), (data.pageClientType = "PC");
(data.pageType = this.searchForm.pageType), (data.pageClientType = "PC");
if (data.id) { if (data.id) {
API_floor.updateHome(data.id, data).then((res) => { API_floor.updateHome(data.id, data).then((res) => {
this.$Message.success("编辑模板成功"); this.$Message.success("编辑模板成功");
@ -145,6 +148,13 @@ export default {
}); });
}, },
clickType(type,index){
this.searchForm.pageNumber = 1
this.searchForm.pageType = type;
this.selectedIndex = index;
this.getTemplateList();
},
createTemp() { createTemp() {
// //
this.$refs.form.resetFields(); this.$refs.form.resetFields();

View File

@ -1,8 +1,8 @@
<template> <template>
<div class="box"> <div class="box">
<!-- 顶部栏 --> <!-- 顶部栏 -->
<navbar @selected="selected" /> <!-- <navbar @selected="selected" /> -->
<navbar @selected="selected" :pagetype="pagetype"/>
<component :is="layout[name]"></component> <component :is="layout[name]"></component>
</div> </div>
</template> </template>
@ -11,16 +11,21 @@ import layout from "./index";
import navbar from "./navbar"; import navbar from "./navbar";
export default { export default {
components: { components: {
navbar, navbar
},
mounted() {
this.pagetype = this.$route.query.pagetype;
}, },
data() { data() {
return { return {
layout, // layout, //
name: "index", // name: "index", //
pagetype: "INDEX"
}; };
}, },
methods: { methods: {
selected(val) { // selected(val) {
//
this.name = val; this.name = val;
} }
} }

View File

@ -9,9 +9,7 @@
v-for="(item, index) in way" v-for="(item, index) in way"
:key="index" :key="index"
:type="item.selected ? 'primary' : ''" :type="item.selected ? 'primary' : ''"
> >{{ item.title }}</Button>
{{ item.title }}
</Button>
</div> </div>
<div class="model-title-view-btn"> <div class="model-title-view-btn">
<!-- TODO 后期会补全 目前版本暂无 --> <!-- TODO 后期会补全 目前版本暂无 -->
@ -21,7 +19,7 @@
<div>临时预览</div> <div>临时预览</div>
<div ref="qrCodeUrl"></div> <div ref="qrCodeUrl"></div>
</div> </div>
</Poptip> --> </Poptip>-->
<Button size="default" type="primary" @click="handleSpinShow"></Button> <Button size="default" type="primary" @click="handleSpinShow"></Button>
<Modal <Modal
@ -33,7 +31,8 @@
> >
<div v-if="progress"> <div v-if="progress">
<div class="model-item"> <div class="model-item">
模板名称 <Input style="width: 200px" v-model="submitWay.name" /> 模板名称
<Input style="width: 200px" v-model="submitWay.name"/>
</div> </div>
<div class="model-item"> <div class="model-item">
是否立即发布 是否立即发布
@ -45,7 +44,7 @@
<Button type="primary" @click="save()"></Button> <Button type="primary" @click="save()"></Button>
</div> </div>
<Progress v-else :percent="num" status="active" /> <Progress v-else :percent="num" status="active"/>
</Modal> </Modal>
</div> </div>
</div> </div>
@ -54,6 +53,7 @@
import * as API_Other from "@/api/other.js"; import * as API_Other from "@/api/other.js";
export default { export default {
props: ["pagetype"],
data() { data() {
return { return {
progress: true, // progress: true, //
@ -61,11 +61,11 @@ export default {
saveDialog: false, // saveDialog: false, //
way: [ way: [
// tab // tab
{ // {
title: "首页", // title: "",
name: "index", // name: "index",
selected: true, // selected: true,
}, // },
// { // {
// title: "广", // title: "广",
// name: "advertising", // name: "advertising",
@ -82,11 +82,23 @@ export default {
// //
pageShow: this.$route.query.type || false, pageShow: this.$route.query.type || false,
name: this.$route.query.name || "模板名称", name: this.$route.query.name || "模板名称",
pageClientType: "H5", pageClientType: "H5"
}, }
}; };
}, },
watch: {}, watch: {
pagetype: {
handler(val) {
this.way.length = 0;
if (val == "INDEX") {
this.way.push({ title: "首页", name: "index", selected: true });
} else if (val == "SPECIAL") {
this.way.push({ title: "专题", name: "special", selected: true });
}
},
immediate: true
}
},
mounted() {}, mounted() {},
methods: { methods: {
clickBtn(val) { clickBtn(val) {
@ -116,7 +128,8 @@ export default {
: (this.submitWay.pageShow = "CLOSE"); : (this.submitWay.pageShow = "CLOSE");
this.submitWay.pageData = JSON.stringify(this.$store.state.styleStore); this.submitWay.pageData = JSON.stringify(this.$store.state.styleStore);
this.submitWay.pageType = "INDEX"; // this.submitWay.pageType = "INDEX";
this.submitWay.pageType = this.pagetype;
this.$route.query.id ? this.update() : this.submit(this.submitWay); this.$route.query.id ? this.update() : this.submit(this.submitWay);
}, },
@ -128,10 +141,11 @@ export default {
pageData: JSON.stringify(this.$store.state.styleStore), pageData: JSON.stringify(this.$store.state.styleStore),
name: this.submitWay.name, name: this.submitWay.name,
pageShow: this.submitWay.pageShow, pageShow: this.submitWay.pageShow,
pageType: "INDEX", // pageType: "INDEX",
pageClientType: "H5", pageType: this.pagetype,
pageClientType: "H5"
}) })
.then((res) => { .then(res => {
this.num = 50; this.num = 50;
if (res.success) { if (res.success) {
this.num = 80; this.num = 80;
@ -147,13 +161,13 @@ export default {
} }
console.log(res); console.log(res);
}) })
.catch((error) => {}); .catch(error => {});
}, },
// //
goback() { goback() {
this.$router.push({ this.$router.push({
path: "/wapList", path: "/wapList"
}); });
}, },
@ -161,7 +175,7 @@ export default {
submit(submitWay) { submit(submitWay) {
this.progress = false; this.progress = false;
API_Other.setHomeSetup(submitWay) API_Other.setHomeSetup(submitWay)
.then((res) => { .then(res => {
this.num = 50; this.num = 50;
if (res.success) { if (res.success) {
this.num = 80; this.num = 80;
@ -178,9 +192,9 @@ export default {
} }
console.log(res); console.log(res);
}) })
.catch((error) => {}); .catch(error => {});
}, }
}, }
}; };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">

View File

@ -1,7 +1,12 @@
<template> <template>
<div class="wrapper"> <div class="wrapper">
<Card class="category"> <Card class="category">
<div :class="{active:i == selectedIndex}" class="category-item" v-for="(typeItem,i) in pageTypes" :key="typeItem.type"> <div
:class="{active:i == selectedIndex}"
class="category-item"
v-for="(typeItem,i) in pageTypes"
:key="typeItem.type"
>
<div @click="clickType(typeItem.type,i)">{{typeItem.title}}</div> <div @click="clickType(typeItem.type,i)">{{typeItem.title}}</div>
</div> </div>
</Card> </Card>
@ -9,7 +14,7 @@
<Button type="primary" @click="handleAdd()"></Button> <Button type="primary" @click="handleAdd()"></Button>
<div class="list"> <div class="list">
<Spin size="large" fix v-if="loading"></Spin> <Spin size="large" fix v-if="loading"></Spin>
<div class="item item-title" > <div class="item item-title">
<div>页面名称</div> <div>页面名称</div>
<div class="item-config"> <div class="item-config">
<div>状态</div> <div>状态</div>
@ -25,19 +30,25 @@
<span slot="close"></span> <span slot="close"></span>
</i-switch> </i-switch>
<Button type="info" placement="right" @click="handleEdit(item)" size="small">修改</Button> <Button type="info" placement="right" @click="handleEdit(item)" size="small">修改</Button>
<Poptip confirm title="删除此模板?" @on-ok="handleDel(item)" > <Poptip confirm title="删除此模板?" @on-ok="handleDel(item)">
<Button type="error" size="small">删除</Button> <Button type="error" size="small">删除</Button>
</Poptip> </Poptip>
</div> </div>
</div> </div>
<div class="no-more" v-if="list.length ==0"></div> <div class="no-more" v-if="list.length ==0"></div>
</div> </div>
<Page :total="total" size="small" @on-change="(val) => {params.pageNumber = val; } " :current="params.pageNumber" :page-size="params.pageSize" show-sizer :page-size-opts="[10, 20, 50]" @on-page-size-change="changePageSize"/> <Page
:total="total"
size="small"
@on-change="(val) => {params.pageNumber = val; } "
:current="params.pageNumber"
:page-size="params.pageSize"
show-sizer
:page-size-opts="[10, 20, 50]"
@on-page-size-change="changePageSize"
/>
</Card> </Card>
</div> </div>
</template> </template>
<script> <script>
import * as API_Other from "@/api/other.js"; import * as API_Other from "@/api/other.js";
@ -46,66 +57,70 @@ export default {
data() { data() {
return { return {
selectedIndex: 0, // selectedIndex: 0, //
columns: [ // columns: [
//
{ {
title: "页面名称", title: "页面名称",
key: "name", key: "name"
}, },
{ {
title: "状态", title: "状态"
}, },
{ {
title: "操作", title: "操作",
key: "action", key: "action"
}, }
], ],
loading: false, // loading: false, //
pageTypes: [ // pageTypes: [
//
{ {
type: "INDEX", type: "INDEX",
title: "首页", title: "首页"
}, },
{ {
type: "SPECIAL", type: "SPECIAL",
title: "专题", title: "专题"
}, }
], ],
params: { // params: {
//
pageNumber: 1, pageNumber: 1,
pageSize: 10, pageSize: 10,
sort: "createTime", sort: "createTime",
order: "desc", order: "desc",
pageType: "INDEX", pageType: "INDEX",
pageClientType: "H5", pageClientType: "H5"
}, },
total: 0, // total: 0, //
list: [], // list: [] //
}; };
}, },
watch: { watch: {
params: { // params: {
handler(val) { // handler(val) {
// this.pageNumber++; // // this.pageNumber++;
this.init(); // this.init();
}, // },
deep: true, // deep: true,
}, // },
}, },
mounted() { mounted() {
this.init(); this.init();
}, },
methods: { methods: {
// tab // tab
clickType(val,index) { clickType(val, index) {
this.params.pageNumber = 1 this.params.pageNumber = 1;
this.selectedIndex = index this.selectedIndex = index;
this.params.pageType = val; this.params.pageType = val;
this.init();
}, },
// //
changeSwitch(item) { changeSwitch(item) {
this.loading = true; this.loading = true;
API_Other.releasePageHome(item.id).then((res) => { API_Other.releasePageHome(item.id).then(res => {
if (res.result) { if (res.result) {
this.loading = false; this.loading = false;
this.$Message.success("发布成功"); this.$Message.success("发布成功");
@ -120,10 +135,10 @@ export default {
// //
init() { init() {
this.loading = true; this.loading = true;
API_Other.getHomeList(this.params).then((res) => { API_Other.getHomeList(this.params).then(res => {
if (!res.result) return false; if (!res.result) return false;
this.loading = false; this.loading = false;
res.result.records.forEach((item) => { res.result.records.forEach(item => {
if (item.pageShow == "OPEN") { if (item.pageShow == "OPEN") {
item.pageShow = true; item.pageShow = true;
} else { } else {
@ -139,13 +154,20 @@ export default {
handleEdit(val) { handleEdit(val) {
this.$router.push({ this.$router.push({
path: "/floorList/main", path: "/floorList/main",
query: { id: val.id, name: val.name, type: val.pageShow }, // query: { id: val.id, name: val.name, type: val.pageShow },
query: {
id: val.id,
name: val.name,
type: val.pageShow,
pagetype: this.params.pageType
}
}); });
}, },
// //
handleAdd() { handleAdd() {
this.$router.push({ this.$router.push({
path: "/floorList/main", path: "/floorList/main",
query: { pagetype: this.params.pageType }
}); });
}, },
// //
@ -157,7 +179,7 @@ export default {
// //
handleDel(val) { handleDel(val) {
this.loading = true; this.loading = true;
API_Other.removePageHome(val.id).then((res) => { API_Other.removePageHome(val.id).then(res => {
if (res.result) { if (res.result) {
this.loading = false; this.loading = false;
this.init(); this.init();
@ -166,8 +188,8 @@ export default {
this.loading = false; this.loading = false;
}); });
}, }
}, }
}; };
</script> </script>
<style scoped lang="scss"> <style scoped lang="scss">
@ -179,7 +201,7 @@ export default {
background: #ededed; background: #ededed;
} }
.item-title { .item-title {
background: #d7e7f5!important; background: #d7e7f5 !important;
height: 54px; height: 54px;
} }
.no-more { .no-more {
@ -223,7 +245,7 @@ export default {
align-items: center; align-items: center;
} }
} }
.item:nth-of-type(2n+1) { .item:nth-of-type(2n + 1) {
background: #f5f7fa; background: #f5f7fa;
} }
</style> </style>

View File

@ -10,6 +10,9 @@
<FormItem label="reqURL" prop="reqURL"> <FormItem label="reqURL" prop="reqURL">
<Input v-model="formValidate.reqURL" /> <Input v-model="formValidate.reqURL" />
</FormItem> </FormItem>
<FormItem label="电子面单URL" prop="sheetReqURL">
<Input v-model="formValidate.sheetReqURL" />
</FormItem>
<div class="label-btns"> <div class="label-btns">
<Button type="primary" @click="submit('formValidate')"></Button> <Button type="primary" @click="submit('formValidate')"></Button>
@ -24,7 +27,7 @@ export default {
data() { data() {
return { return {
ruleValidate: {}, // ruleValidate: {}, //
formValidate: { ebusinessID: "", reqURL: "", appKey: "" }, // formValidate: { ebusinessID: "", reqURL: "", appKey: "" ,sheetReqURL: "" ,}, //
}; };
}, },
props: ["res",'type'], props: ["res",'type'],

View File

@ -13,11 +13,15 @@ var BASE = {
// buyer: "http://localhost:8888", // buyer: "http://localhost:8888",
// seller: "http://localhost:8889", // seller: "http://localhost:8889",
// manager: "http://localhost:8887" // manager: "http://localhost:8887"
common:"http://192.168.0.113:8890", common:"http://127.0.0.1:8890",
buyer:"http://192.168.0.113:8888", buyer:"http://192.168.0.113:8888",
manager:"http://192.168.0.113:8887", manager:"http://192.168.0.113:8887",
<<<<<<< HEAD
seller:"http://192.168.0.113:8889" seller:"http://192.168.0.113:8889"
>>>>>>> 32336decc6e9e0ae8a0e67033f8ca66a89bbd372 >>>>>>> 32336decc6e9e0ae8a0e67033f8ca66a89bbd372
=======
seller:"http://127.0.0.1:8889"
>>>>>>> 4ea142ea086a3f534419a31b595de80497e16d90
}, },
API_PROD: { API_PROD: {
common: "https://common-api.pickmall.cn", common: "https://common-api.pickmall.cn",

View File

@ -31,4 +31,8 @@ export const updateLogistics = (id,params) => {
return putRequest(`/other/logistics/${id}`,params); return putRequest(`/other/logistics/${id}`,params);
}; };
export const getCheckedOn = params =>{
return getRequest(`/other/logistics/getCheckedFaceSheet`,params);
}

View File

@ -17,6 +17,10 @@ export const queryExportOrder = params => {
return getRequest(`/order/order/queryExportOrder`, params); return getRequest(`/order/order/queryExportOrder`, params);
}; };
//获取电子面单
export const getOrderFaceSheet= (orderSn,params) =>{
return postRequest(`/order/order/${orderSn}/createElectronicsFaceSheet`,params)
}
// 上传待发货的订单列表 // 上传待发货的订单列表
export const uploadDeliverExcel = params => { export const uploadDeliverExcel = params => {

View File

@ -41,10 +41,24 @@ export const getBillDetail = (id, params) => {
export const getLogistics = (id, params) => { export const getLogistics = (id, params) => {
return getRequest(`/other/logistics`, params) return getRequest(`/other/logistics`, params)
} }
//返回信息
export const getIsCheck =(logisticsId) =>{
return getRequest(`other/logistics/${logisticsId}/getStoreLogistics`)
}
// 开启物流公司 // 开启物流公司
export const logisticsChecked = (id, params) => { export const logisticsChecked = (id, params) => {
return postRequest(`/other/logistics/${id}`, params) return postRequest(`/other/logistics/${id}`, params, {
"Content-type": "application/json"
})
}
//获取发货地址
export const getDeliverAddress = () =>{
return getRequest(`/settings/storeSettings/storeDeliverGoodsAddress`)
}
//修改发货地址
export const editDeliverAddress = (params) =>{
return putRequest(`/settings/storeSettings/storeDeliverGoodsAddress`,params)
} }
// 关闭开启物流公司 // 关闭开启物流公司
@ -117,4 +131,9 @@ export const editShipTemplate = (id, params, headers) => {
return putRequest(`/setting/freightTemplate/${id}`, params, headers) return putRequest(`/setting/freightTemplate/${id}`, params, headers)
} }
//修改电子面单等信息
export const editChecked = (logisticsId,params) => {
return putRequest(`/other/logistics/${logisticsId}/updateStoreLogistics`,params)
}

View File

@ -56,6 +56,7 @@
</Row> </Row>
<Row class="operation padding-row"> <Row class="operation padding-row">
<Button @click="addGoods" type="primary">添加商品</Button> <Button @click="addGoods" type="primary">添加商品</Button>
<Button @click="openImportGoods" type="primary">导入商品</Button>
<Dropdown @on-click="handleDropdown"> <Dropdown @on-click="handleDropdown">
<Button type="default"> <Button type="default">
批量操作 批量操作
@ -179,6 +180,20 @@
<Button type="primary" @click="saveShipTemplate"></Button> <Button type="primary" @click="saveShipTemplate"></Button>
</div> </div>
</Modal> </Modal>
<Modal title="导入商品信息" v-model="importModal" :mask-closable="false">
<div>
<Upload :before-upload="handleUpload" name="files" accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-excel"
multiple type="drag" :action="action" :headers="accessToken">
<div style="padding: 50px 0">
<Icon type="ios-cloud-upload" size="102" style="color: #3399ff"></Icon>
<h2>选择或拖拽文件上传</h2>
</div>
</Upload>
</div>
<div slot="footer">
<Button type="text" @click="importModal = false">确定</Button>
</div>
</Modal>
</div> </div>
</template> </template>
@ -192,12 +207,16 @@ import {
deleteGoods, deleteGoods,
batchShipTemplate, batchShipTemplate,
} from "@/api/goods"; } from "@/api/goods";
import { baseUrl } from "@/libs/axios.js";
import * as API_Shop from "@/api/shops"; import * as API_Shop from "@/api/shops";
export default { export default {
name: "goods", name: "goods",
data() { data() {
return { return {
accessToken: {}, // token
importModal: false,
action: baseUrl + "/goods/import/import", //
id: "", //id id: "", //id
loading: true, // loading: true, //
shipTemplateForm: {}, // shipTemplateForm: {}, //
@ -486,6 +505,15 @@ export default {
} }
}); });
}, },
//
handleUpload(file) {
this.file = file;
this.upload();
return false;
},
openImportGoods(){
this.importModal = true
},
// //
updateStock() { updateStock() {
let updateStockList = this.stockList.map((i) => { let updateStockList = this.stockList.map((i) => {
@ -727,9 +755,7 @@ export default {
}, },
mounted() { mounted() {
this.init(); this.init();
}, this.accessToken.accessToken = this.getStore("accessToken");
mounted() {
this.init();
}, },
}; };
</script> </script>

View File

@ -27,6 +27,7 @@
<Button v-if="allowOperation.ship" @click="orderDeliver" type="primary" <Button v-if="allowOperation.ship" @click="orderDeliver" type="primary"
>发货</Button >发货</Button
> >
<Button @click="Toprint" type="primary" ghost v-if="allowOperation.ship"></Button>
</div> </div>
</Card> </Card>
@ -439,13 +440,31 @@
<span>订单发货</span> <span>订单发货</span>
</p> </p>
<div> <div>
<Form :model="faceSheetForm" ref="faceSheetForm" v-if="facesheetFlag" :rules="faceSheetFormValidate">
<FormItem label="物流公司" prop="logisticsId" style="position: relative" :label-width="90">
<Select
v-model="faceSheetForm.logisticsId"
placeholder="请选择"
style="width: 250px"
>
<Option
v-for="(item, i) in checkedLogistics"
:key="i"
:value="item.logisticsId"
>{{ item.name }}
</Option>
</Select>
</FormItem>
</Form>
<Form <Form
v-else
ref="orderDeliveryForm" ref="orderDeliveryForm"
:model="orderDeliveryForm" :model="orderDeliveryForm"
:label-width="90" :label-width="90"
:rules="orderDeliverFormValidate" :rules="orderDeliverFormValidate"
style="position: relative" style="position: relative"
> >
<FormItem label="物流公司" prop="logisticsId"> <FormItem label="物流公司" prop="logisticsId">
<Select <Select
v-model="orderDeliveryForm.logisticsId" v-model="orderDeliveryForm.logisticsId"
@ -455,12 +474,13 @@
<Option <Option
v-for="(item, i) in checkedLogistics" v-for="(item, i) in checkedLogistics"
:key="i" :key="i"
:value="item.id" :value="item.logisticsId"
>{{ item.name }} >{{ item.name }}
</Option> </Option>
</Select> </Select>
</FormItem> </FormItem>
<FormItem label="物流单号" prop="logisticsNo"> <!-- v-if="showOrder" -->
<FormItem label="物流单号" prop="logisticsNo" >
<Input <Input
v-model="orderDeliveryForm.logisticsNo" v-model="orderDeliveryForm.logisticsNo"
style="width: 250px" style="width: 250px"
@ -479,6 +499,7 @@
<script> <script>
import * as API_Order from "@/api/order"; import * as API_Order from "@/api/order";
import * as API_Logistics from "@/api/logistics";
import liliMap from "@/views/my-components/map/index"; import liliMap from "@/views/my-components/map/index";
import * as RegExp from "@/libs/RegExp.js"; import * as RegExp from "@/libs/RegExp.js";
import region from "@/views/lili-components/region"; import region from "@/views/lili-components/region";
@ -495,6 +516,16 @@ export default {
region: [], // region: [], //
regionId: [], //id regionId: [], //id
showRegion: false, showRegion: false,
someJSONdata: '',
faceSheetForm: {
logisticsId: '',
},
faceSheetFormValidate: {
logisticsId: [
{ required: true, message: "请选择物流公司"},
],
},
facesheetFlag: false, //
orderLogModal: false, // orderLogModal: false, //
logisticsModal: false, // logisticsModal: false, //
orderDeliverModal: false, // orderDeliverModal: false, //
@ -716,6 +747,15 @@ export default {
} }
}); });
}, },
Toprint(){
this.facesheetFlag = true;
API_Logistics.getCheckedOn().then(res => {
if (res.success) {
this.checkedLogistics = res.result;
this.orderDeliverModal = true;
}
});
},
// //
modifyPrice() { modifyPrice() {
// //
@ -754,6 +794,7 @@ export default {
}, },
// //
orderDeliver() { orderDeliver() {
this.facesheetFlag = false
API_Order.getLogisticsChecked().then((res) => { API_Order.getLogisticsChecked().then((res) => {
if (res.success) { if (res.success) {
this.checkedLogistics = res.result; this.checkedLogistics = res.result;
@ -761,11 +802,29 @@ export default {
} }
}); });
}, },
Toprints(){
if(this.form.logisticsId != null && this.form.logisticsId != ''){
this.orderDeliverModal = false;
this.modalPrint = true;
}
},
// //
orderDeliverySubmit() { orderDeliverySubmit() {
this.$refs.orderDeliveryForm.validate((valid) => { if(this.facesheetFlag){
this.$refs['faceSheetForm'].validate((valid) => {
if (valid) { if (valid) {
API_Order.orderDelivery(this.sn, this.orderDeliveryForm).then( API_Order.getOrderFaceSheet(this.sn, this.faceSheetForm).then(res => {
if (res.success) {
this.someJSONdata = res.result;
this.Toprints();
}
})
}
})
}else{
this.$refs['orderDeliveryForm'].validate((valid) => {
if (valid) {
API_Order.orderDelivery(this.sn,this.orderDeliveryForm).then(
(res) => { (res) => {
if (res.success) { if (res.success) {
this.$Message.success("订单发货成功"); this.$Message.success("订单发货成功");
@ -776,6 +835,7 @@ export default {
); );
} }
}); });
}
}, },
// //
editAddress() { editAddress() {

View File

@ -9,16 +9,94 @@
ref="table" ref="table"
></Table> ></Table>
</Card> </Card>
<Modal v-model="openModal" :title="openModalTitle" @on-ok="submit">
<h3 style="color: #ff3c2a; margin-bottom: 10px">是否需要电子面单</h3>
<RadioGroup
v-model="faceSheetForm.faceSheetFlag"
style="margin-bottom: 20px"
@on-change="getfaceSheetFlag($event)"
>
<Radio :label="true">
<span>需要</span>
</Radio>
<Radio :label="false">
<span>不需要</span>
</Radio>
</RadioGroup>
<Card v-if="onpenText" class="modalStyle">
<h3 style="color: #ff3c2a; margin-bottom: 10px">请输入详细信息</h3>
<Form ref="formValidate" :label-width="150" label-position="right" :model="faceSheetForm" :rules="ruleValidate">
<FormItem label="customerName" prop="customerName">
<Input
v-model="faceSheetForm.customerName"
type="text"
class="faceSheetInput"
></Input
></FormItem>
<FormItem label="customerPwd" prop="customerPwd">
<Input
v-model="faceSheetForm.customerPwd"
type="text"
class="faceSheetInput"
></Input>
</FormItem>
<FormItem label="customerPwd" prop="monthCode">
<Input
v-model="faceSheetForm.monthCode"
type="text"
class="faceSheetInput"
></Input
></FormItem>
<FormItem label="customerPwd" prop="sendSite">
<Input
v-model="faceSheetForm.sendSite"
type="text"
class="faceSheetInput"
></Input
></FormItem>
<FormItem label="customerPwd" prop="sendStaff">
<Input
v-model="faceSheetForm.sendStaff"
type="text"
class="faceSheetInput"
></Input
></FormItem>
<FormItem label="支付方式" prop="payType">
<Select
v-model="faceSheetForm.payType"
class="faceSheetInput">
<Option value="1">现付</Option>
<Option value="2">到付</Option>
<Option value="3">月结</Option>
<Option value="4">第三方支付(仅SF支持)</Option>
</Select
></FormItem>
<FormItem label="快递类型" prop="expType">
<Input
v-model="faceSheetForm.expType"
type="text"
class="faceSheetInput"/>
</FormItem>
<div style="width:100%;text-align:center;">
<a style="padding-right: 20px" @click="frontDownload('use')">使</a>
<a @click="frontDownload('type')"></a>
</div>
</Form>
</Card>
<br/>
</Modal>
</div> </div>
</template> </template>
<script> <script>
import * as API_Shop from "@/api/shops"; import * as API_Shop from "@/api/shops";
export default { export default {
name: "logistics", name: "logistics",
data() { data() {
return { return {
row: {},
openModal: false,
loading: true, // loading: true, //
searchForm: { searchForm: {
// //
@ -27,6 +105,27 @@
sort: "createTime", // sort: "createTime", //
order: "desc", // order: "desc", //
}, },
openModalTitle: '开启信息',
ruleValidate: {
customerName: [{ required: true, message: "请填写必填项" ,trigger: "blur" }],
payType: [{ required: true, message: "请填写必填项" ,trigger: "change" }],
expType: [{ required: true, message: "请填写必填项" ,trigger: "blur" }],
customerPwd: [{ required: true, message: "请填写必填项" ,trigger: "blur" }],
monthCode: [{ required: true, message: "请填写必填项" ,trigger: "blur" }],
sendSite: [{ required: true, message: "请填写必填项" ,trigger: "blur" }],
sendStaff: [{ required: true, message: "请填写必填项" ,trigger: "blur" }],
},
faceSheetForm: {
faceSheetFlag: false,
customerName: "",
payType: '1',
expType: '1',
customerPwd: "",
monthCode: "",
sendSite: "",
sendStaff: "",
},
columns: [ columns: [
{ {
title: "物流公司", title: "物流公司",
@ -40,9 +139,9 @@
minWidth: 120, minWidth: 120,
sortable: true, sortable: true,
render: (h, params) => { render: (h, params) => {
if(params.row.selected === null || params.row.selected === ""){ if (params.row.selected === null || params.row.selected === "") {
return h("div", [h("tag", {props: {color: "volcano"}}, "关闭")]); return h("div", [h("tag", {props: {color: "volcano"}}, "关闭")]);
}else{ } else {
return h("div", [h("tag", {props: {color: "green"}}, "开启")]); return h("div", [h("tag", {props: {color: "green"}}, "开启")]);
} }
} }
@ -53,7 +152,7 @@
align: "center", align: "center",
width: 200, width: 200,
render: (h, params) => { render: (h, params) => {
if(params.row.selected === null){ if (params.row.selected === null) {
return h("div", [ return h("div", [
h( h(
"Button", "Button",
@ -74,7 +173,7 @@
"开启" "开启"
), ),
]); ]);
}else{ } else {
return h("div", [ return h("div", [
h( h(
"Button", "Button",
@ -94,6 +193,21 @@
}, },
"关闭" "关闭"
), ),
h(
"Button",
{
props: {
type: "info",
size: "small",
},
on: {
click: () => {
this.getFaceSheetInfo(params.row);
},
},
},
"修改"
),
]); ]);
} }
@ -101,9 +215,21 @@
}, },
], ],
data: [], // data: [], //
onpenText: false,
}; };
}, },
methods: { methods: {
//
getfaceSheetFlag(e) {
console.log(e);
if (e === true) {
console.log("打开");
this.onpenText = true;
} else {
console.log("关闭");
this.onpenText = false;
}
},
// //
init() { init() {
this.getDataList(); this.getDataList();
@ -121,24 +247,79 @@
}, },
// //
open(v) { open(v) {
this.$Modal.confirm({ this.row = v;
title: "确认开启", this.openModal = true;
// this.searchForm.faceSheetFlag = "false"; // v
content: "您确认开启此物流公司?", if (this.searchForm.faceSheetFlag == "true") {
loading: true, this.onpenText = true;
onOk: () => { } else {
API_Shop.logisticsChecked(v.id).then((res) => { this.onpenText = false;
}
},
//
getFaceSheetInfo(v) {
this.row = v;
this.logisticsId = v.logisticsId;
this.openModalTitle = '修改信息';
API_Shop.getIsCheck(this.logisticsId).then((res) => {
if (res.success) {
// this.searchForm = res.result.recordes;
this.faceSheetForm.faceSheetFlag = res.result.faceSheetFlag; // v
if (this.faceSheetForm.faceSheetFlag === true) {
this.onpenText = true;
} else {
this.faceSheetForm.faceSheetFlag = false
this.onpenText = false;
}
this.faceSheetForm.customerName = res.result.customerName;
this.faceSheetForm.customerPwd = res.result.customerPwd;
this.faceSheetForm.monthCode = res.result.monthCode;
this.faceSheetForm.sendSite = res.result.sendSite;
this.faceSheetForm.sendStaff = res.result.sendStaff;
}
});
this.openModal = true;
},
frontDownload(val) {
var a = document.createElement("a"); //<a></a>
//
if (val === 'use') {
a.href = "static/open.xlsx"; // ahref .
a.download = "使用说明.xlsx"; //.xlsxpdf.fpd
} else if (val === 'type') {
a.href = "static/logisticsType.xlsx"; // ahref .
a.download = "快递类型.xlsx"; //.xlsxpdf.fpd
}
a.style.display = "none"; // a
document.body.appendChild(a); // a
a.click(); // aahref
a.remove(); // a
},
submit() {
if ( this.row.selected === null || this.row.selected === "") {
API_Shop.logisticsChecked(
this.row.logisticsId,
this.faceSheetForm
).then((res) => {
this.openModal = false;
this.$Modal.remove(); this.$Modal.remove();
if (res.success) { if (res.success) {
this.$Message.success("物流公司开启成功"); this.$Message.success("物流公司开启成功");
this.init(); this.init();
} }
}); });
} else {
API_Shop.editChecked(this.logisticsId, this.faceSheetForm).then((res) => {
if (res.success) {
this.$Message.success("修改成功");
this.init();
} }
}); });
}
}, },
// //
close(v){ close(v) {
this.$Modal.confirm({ this.$Modal.confirm({
title: "确认关闭", title: "确认关闭",
content: "您确认关闭此物流公司?", content: "您确认关闭此物流公司?",
@ -158,5 +339,11 @@
mounted() { mounted() {
this.init(); this.init();
}, },
}; };
</script> </script>
<style lang="scss" scoped>
.faceSheetInput{
width: 300px;
}
</style>

View File

@ -61,6 +61,77 @@
</Form-item> </Form-item>
</Form> </Form>
</TabPane> </TabPane>
<TabPane label="发货地址">
<Form
ref="addressGoods"
:model="addressGoods"
:label-width="100"
:rules="addressGoodsValidate"
>
<FormItem label="发货人姓名" prop="salesConsignorName">
<Input
v-model="addressGoods.salesConsignorName"
maxlength="11"
clearable
style="width: 20%"
>
</Input>
</FormItem>
<FormItem label="发货人手机号" prop="salesConsignorMobile">
<Input
v-model="addressGoods.salesConsignorMobile"
maxlength="11"
clearable
style="width: 20%"
>
</Input>
</FormItem>
<FormItem label="地址" prop="salesConsignorAddressId">
<Input
v-model="regionGoods"
clearable
disabled
style="width: 20%"
v-if="showRegion == false"
>
</Input>
<regionMap
style="width: 20%"
@selected="selectedRegionGoods"
v-if="showRegion == true"
/>
<Button
v-if="showRegion == false"
@click="regionClicks"
type="primary"
style="margin-left: 8px"
>修改
</Button>
</FormItem>
<!-- <FormItem label="地址名称" prop="salesConsignorAddressPath">
<Input
v-model="addressGoods.salesConsignorAddressPath"
clearable
style="width: 20%"
>
</Input>
</FormItem> -->
<FormItem label="详细地址" prop="salesConsignorDetail">
<Input
v-model="addressGoods.salesConsignorDetail"
clearable
style="width: 20%"
>
</Input>
</FormItem>
<Button
@click="SetAddressGoods"
type="primary"
style="margin-left: 8px"
>确认
</Button>
</Form>
</TabPane>
<TabPane label="退货地址" name="REFUND_GOODS_ADDRESS"> <TabPane label="退货地址" name="REFUND_GOODS_ADDRESS">
<Form <Form
ref="addressForm" ref="addressForm"
@ -194,6 +265,7 @@ import liliMap from "@/views/my-components/map/index";
import regionMap from "@/views/lili-components/region"; import regionMap from "@/views/lili-components/region";
import * as RegExp from "@/libs/RegExp.js"; import * as RegExp from "@/libs/RegExp.js";
import Cookies from "js-cookie"; import Cookies from "js-cookie";
import {editDeliverAddress, getDeliverAddress} from "../../api/shops";
export default { export default {
name: "shopSetting", name: "shopSetting",
@ -306,12 +378,64 @@ export default {
], ],
}, },
submitLoading: false, // submitLoading: false, //
//
addressGoods: {
salesConsignorName:" ",
salesConsignorMobile:" ",
salesConsignorAddressId: " ",
salesConsignorAddressPath: " ",
salesConsignorDetail: " ",
},
regionGoods:"",//
addressGoodsValidate: {
salesConsignorName: [
{ required: true, message: "请输入发货人姓名", trigger: "blur" },
],
salesConsignorMobile: [
{ required: true, message: "手机号不能为空", trigger: "blur" },
{
pattern: RegExp.mobile,
trigger: "blur",
message: "请输入正确的手机号",
},
],
salesConsignorDetail: [
{ required: true, message: "请输入详细地址", trigger: "blur" },
],
},
}; };
}, },
methods: { methods: {
// //
init() { init() {
this.getShopInfo(); this.getShopInfo();
this.getDeliverAddress()
},
selectedRegionGoods(val){
this.regionGoods = val[1];
this.regionIdS = val[0];
},
regionClicks(){
this.showRegion = true;
this.regionIdS = "";
},
SetAddressGoods(){
console.log(this.$refs.addressGoods)
if (this.regionIdS == "") {
this.$Message.error("请选择地址");
return;
}
this.$refs.addressGoods.validate((valid) => {
if (valid) {
this.addressGoods.salesConsignorAddressPath = this.regionGoods;
this.addressGoods.salesConsignorAddressId = this.regionIdS;
API_Shop.editDeliverAddress(this.addressGoods).then(res=>{
if(res.success){
this.$Message.success("修改成功")
}
})
}
});
}, },
// //
getShopInfo() { getShopInfo() {
@ -335,8 +459,22 @@ export default {
} }
}); });
}, },
<<<<<<< HEAD
pageShow(type){ pageShow(type){
this.form.pageShow = type this.form.pageShow = type
=======
getDeliverAddress(){
API_Shop.getDeliverAddress().then(res=>{
if(res.success){
if(res.result!= '' && res.result != null){
console.log(89898999998)
this.addressGoods = res.result;
this.regionGoods = res.result.salesConsignorAddressPath;
this.regionIdS = res.result.salesConsignorAddressId;
}
}
})
>>>>>>> 4ea142ea086a3f534419a31b595de80497e16d90
}, },
// //
regionClick() { regionClick() {