leisure-core 0.4.51 → 0.4.53
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/index.js +19 -72
- package/le-button/src/main.vue +6 -12
- package/le-button-msg/src/main.vue +9 -5
- package/le-button-select-media/src/main.vue +4 -2
- package/le-button-upload/src/main.vue +6 -2
- package/le-common-page/src/main.vue +27 -75
- package/le-common-page/src/sub.vue +122 -0
- package/le-form/index.js +7 -0
- package/le-form/src/main.vue +13 -0
- package/le-form-item/index.js +7 -0
- package/le-form-item/src/main.vue +13 -0
- package/le-help/src/main.vue +6 -2
- package/le-input/index.js +7 -0
- package/le-input/src/main.vue +17 -0
- package/le-input-number/index.js +7 -0
- package/le-input-number/src/main.vue +16 -0
- package/le-media-list/src/main.vue +1 -1
- package/le-role/src/main.vue +5 -5
- package/le-select/index.js +7 -0
- package/le-select/src/main.vue +27 -0
- package/le-select-search/index.js +7 -0
- package/le-select-search/src/main.vue +46 -0
- package/le-user/src/main.vue +1 -1
- package/package.json +5 -7
- package/le-ad/index.js +0 -7
- package/le-ad/src/main.vue +0 -137
- package/le-ad/src/sub.vue +0 -180
- package/le-ad-space/index.js +0 -7
- package/le-ad-space/src/main.vue +0 -135
- package/le-ad-space/src/sub.vue +0 -119
- package/le-commission/index.js +0 -7
- package/le-commission/src/main.vue +0 -175
- package/le-commission/src/sub.vue +0 -213
- package/le-commission-cp/index.js +0 -7
- package/le-commission-cp/src/main.vue +0 -170
- package/le-company/index.js +0 -7
- package/le-company/src/main.vue +0 -101
- package/le-company/src/sub.vue +0 -111
- package/le-coupon/index.js +0 -17
- package/le-coupon/src/details.vue +0 -196
- package/le-coupon/src/main.vue +0 -193
- package/le-coupon/src/sub.vue +0 -362
- package/le-coupon-give/index.js +0 -7
- package/le-coupon-give/src/main.vue +0 -110
- package/le-cp/index.js +0 -7
- package/le-cp/src/main.vue +0 -166
- package/le-cp/src/sub.vue +0 -174
- package/le-depart/index.js +0 -7
- package/le-depart/src/main.vue +0 -162
- package/le-distribution/index.js +0 -7
- package/le-distribution/src/main.vue +0 -85
- package/le-distribution-category/index.js +0 -7
- package/le-distribution-category/src/main.vue +0 -106
- package/le-distribution-category/src/sub.vue +0 -112
- package/le-integral/index.js +0 -7
- package/le-integral/src/main.vue +0 -198
- package/le-member/index.js +0 -7
- package/le-member/src/main.vue +0 -494
- package/le-member/src/other.vue +0 -240
- package/le-member-level/index.js +0 -7
- package/le-member-level/src/main.vue +0 -93
- package/le-member-level/src/sub.vue +0 -112
- package/le-promotions/index.js +0 -9
- package/le-promotions/src/main.vue +0 -220
- package/le-promotions/src/sub.vue +0 -248
- package/le-promotions-activities/index.js +0 -7
- package/le-promotions-activities/src/main.vue +0 -208
- package/le-promotions-activities/src/sub.vue +0 -212
- package/le-rate/index.js +0 -7
- package/le-rate/src/main.vue +0 -194
- package/le-rate/src/qrinfo.vue +0 -32
- package/le-rate/src/sub.vue +0 -183
- package/le-seting/index.js +0 -7
- package/le-seting/src/main.vue +0 -154
- package/le-user-type/index.js +0 -7
- package/le-user-type/src/main.vue +0 -39
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<el-input
|
|
3
|
+
v-bind="$attrs"
|
|
4
|
+
v-on="$listeners"
|
|
5
|
+
:class="['customClass', $attrs.class]"
|
|
6
|
+
:style="$attrs.style"
|
|
7
|
+
clearable
|
|
8
|
+
></el-input>
|
|
9
|
+
</template>
|
|
10
|
+
<script>
|
|
11
|
+
export default {
|
|
12
|
+
name: "le-button",
|
|
13
|
+
inheritAttrs: false,
|
|
14
|
+
props: {},
|
|
15
|
+
methods: {},
|
|
16
|
+
};
|
|
17
|
+
</script>
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<el-input-number
|
|
3
|
+
v-bind="$attrs"
|
|
4
|
+
v-on="$listeners"
|
|
5
|
+
:class="['customClass', $attrs.class]"
|
|
6
|
+
:style="$attrs.style"
|
|
7
|
+
></el-input-number>
|
|
8
|
+
</template>
|
|
9
|
+
<script>
|
|
10
|
+
export default {
|
|
11
|
+
name: "le-input-number",
|
|
12
|
+
inheritAttrs: false,
|
|
13
|
+
props: {},
|
|
14
|
+
methods: {},
|
|
15
|
+
};
|
|
16
|
+
</script>
|
|
@@ -87,7 +87,7 @@
|
|
|
87
87
|
</template>
|
|
88
88
|
<script>
|
|
89
89
|
import { systemMaterialList } from "@/api/media";
|
|
90
|
-
import leMixins from "
|
|
90
|
+
import leMixins from "../../le-libs/mixins/main"; //
|
|
91
91
|
export default {
|
|
92
92
|
name: "le-media-list",
|
|
93
93
|
mixins: [leMixins],
|
package/le-role/src/main.vue
CHANGED
|
@@ -75,11 +75,11 @@
|
|
|
75
75
|
</template>
|
|
76
76
|
<script>
|
|
77
77
|
import { roleDel, roleList, listUserOfRole } from "@/api/role";
|
|
78
|
-
import LeButton from "
|
|
79
|
-
import LeButtonMsg from "
|
|
80
|
-
import LeDialogContainer from "
|
|
81
|
-
import LeMenu from "
|
|
82
|
-
import leMixins from "
|
|
78
|
+
import LeButton from "../../le-button/index";
|
|
79
|
+
import LeButtonMsg from "../../le-button-msg/index";
|
|
80
|
+
import LeDialogContainer from "../..//le-dialog-container/index";
|
|
81
|
+
import LeMenu from "../../le-menu/index";
|
|
82
|
+
import leMixins from "../../le-libs/mixins/main";
|
|
83
83
|
import LeRoleSub from "./sub.vue";
|
|
84
84
|
export default {
|
|
85
85
|
name: "le-role",
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<el-select
|
|
3
|
+
v-bind="$attrs"
|
|
4
|
+
v-on="$listeners"
|
|
5
|
+
:class="['customClass', $attrs.class]"
|
|
6
|
+
:style="$attrs.style"
|
|
7
|
+
>
|
|
8
|
+
<slot></slot>
|
|
9
|
+
</el-select>
|
|
10
|
+
</template>
|
|
11
|
+
<script>
|
|
12
|
+
export default {
|
|
13
|
+
name: "le-select",
|
|
14
|
+
props: {
|
|
15
|
+
// options: {
|
|
16
|
+
// type: Array,
|
|
17
|
+
// default: () => [],
|
|
18
|
+
// },
|
|
19
|
+
},
|
|
20
|
+
inheritAttrs: false,
|
|
21
|
+
data() {
|
|
22
|
+
return {};
|
|
23
|
+
},
|
|
24
|
+
methods: {},
|
|
25
|
+
};
|
|
26
|
+
</script>
|
|
27
|
+
<style lang="scss" scoped></style>
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<le-select
|
|
3
|
+
v-bind="$attrs"
|
|
4
|
+
v-on="$listeners"
|
|
5
|
+
remote
|
|
6
|
+
multiple
|
|
7
|
+
filterable
|
|
8
|
+
reserve-keyword
|
|
9
|
+
placeholder="请输入搜索关键字"
|
|
10
|
+
:remote-method="remoteMethod"
|
|
11
|
+
:loading="loading"
|
|
12
|
+
>
|
|
13
|
+
<slot></slot>
|
|
14
|
+
</le-select>
|
|
15
|
+
</template>
|
|
16
|
+
<script>
|
|
17
|
+
import LeSelect from "../../le-select/index";
|
|
18
|
+
export default {
|
|
19
|
+
name: "le-select-search",
|
|
20
|
+
components: { LeSelect },
|
|
21
|
+
props: {
|
|
22
|
+
remote: {
|
|
23
|
+
type: Boolean,
|
|
24
|
+
default: false,
|
|
25
|
+
},
|
|
26
|
+
},
|
|
27
|
+
inheritAttrs: false,
|
|
28
|
+
data() {
|
|
29
|
+
return {
|
|
30
|
+
loading: false,
|
|
31
|
+
selectValue: "",
|
|
32
|
+
};
|
|
33
|
+
},
|
|
34
|
+
methods: {
|
|
35
|
+
remoteMethod(params) {
|
|
36
|
+
if (params !== "") {
|
|
37
|
+
this.loading = true;
|
|
38
|
+
this.$emit("remoteMethod", params, () => {
|
|
39
|
+
this.loading = false;
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
},
|
|
44
|
+
};
|
|
45
|
+
</script>
|
|
46
|
+
<style lang="scss" scoped></style>
|
package/le-user/src/main.vue
CHANGED
|
@@ -185,7 +185,7 @@ import {
|
|
|
185
185
|
close,
|
|
186
186
|
userChangePwd,
|
|
187
187
|
} from "@/api/user";
|
|
188
|
-
import leMixins from "
|
|
188
|
+
import leMixins from "../../le-libs/mixins/main"; //
|
|
189
189
|
import guid from "leisure-js/common/util";
|
|
190
190
|
import moment from "moment";
|
|
191
191
|
import LeUserSub from "./sub.vue";
|
package/package.json
CHANGED
|
@@ -1,12 +1,13 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "leisure-core",
|
|
3
|
-
"version": "0.4.
|
|
4
|
-
"description": "leisure-core
|
|
3
|
+
"version": "0.4.53",
|
|
4
|
+
"description": "leisure-core是京心数据基于vue2.x开发的一套桌面端组件库,封装了大量实用的UI控件模板,非常方便开发者快速搭建前端应用",
|
|
5
5
|
"private": false,
|
|
6
6
|
"author": "北方乐逍遥(zcx7878)",
|
|
7
7
|
"keywords": [
|
|
8
8
|
"leisure",
|
|
9
|
-
"leisure-core"
|
|
9
|
+
"leisure-core",
|
|
10
|
+
"京心数据"
|
|
10
11
|
],
|
|
11
12
|
"publishConfig": {
|
|
12
13
|
"registry": "https://registry.npmjs.org/"
|
|
@@ -15,7 +16,6 @@
|
|
|
15
16
|
"axios": "^0.27.2",
|
|
16
17
|
"core-js": "^3.8.3",
|
|
17
18
|
"dayjs": "^1.11.7",
|
|
18
|
-
"echarts": "^5.4.2",
|
|
19
19
|
"element-ui": "^2.15.14",
|
|
20
20
|
"leisure-js": "^0.2.3",
|
|
21
21
|
"html2canvas": "^1.4.1",
|
|
@@ -28,7 +28,5 @@
|
|
|
28
28
|
"vxe-table": "^3.6.11",
|
|
29
29
|
"xe-utils": "^3.5.7"
|
|
30
30
|
},
|
|
31
|
-
"devDependencies": {
|
|
32
|
-
|
|
33
|
-
}
|
|
31
|
+
"devDependencies": {}
|
|
34
32
|
}
|
package/le-ad/index.js
DELETED
package/le-ad/src/main.vue
DELETED
|
@@ -1,137 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div>
|
|
3
|
-
<el-form :inline="true" :model="searchData">
|
|
4
|
-
<el-form-item label="终端">
|
|
5
|
-
<el-select
|
|
6
|
-
v-model="searchData.dtype"
|
|
7
|
-
placeholder="请选择终端类型"
|
|
8
|
-
clearable
|
|
9
|
-
>
|
|
10
|
-
<el-option label="PC" value="0" key="0"></el-option>
|
|
11
|
-
<el-option label="移动" value="1" key="1"></el-option>
|
|
12
|
-
</el-select>
|
|
13
|
-
</el-form-item>
|
|
14
|
-
<el-form-item>
|
|
15
|
-
<el-button type="primary" @click="searData">查询</el-button>
|
|
16
|
-
<el-button type="primary" @click="addAd()">新增广告</el-button>
|
|
17
|
-
</el-form-item>
|
|
18
|
-
</el-form>
|
|
19
|
-
<el-table :data="tableData" border row-key="id" stripe style="width: 100%">
|
|
20
|
-
<el-table-column prop="dtype" label="终端">
|
|
21
|
-
<template slot-scope="scope">
|
|
22
|
-
<span v-if="scope.row.dtype == 0">PC端</span>
|
|
23
|
-
<span v-if="scope.row.dtype == 1">移动端</span>
|
|
24
|
-
</template>
|
|
25
|
-
</el-table-column>
|
|
26
|
-
<el-table-column prop="title" label="广告标题"> </el-table-column>
|
|
27
|
-
<el-table-column prop="title" label="广告图片" width="100" align="center">
|
|
28
|
-
<template slot-scope="scope">
|
|
29
|
-
<el-image style="width: 50px; height: 50px" :src="scope.row.imgsrc">
|
|
30
|
-
</el-image>
|
|
31
|
-
</template>
|
|
32
|
-
</el-table-column>
|
|
33
|
-
<el-table-column prop="linktype" label="导航类型">
|
|
34
|
-
<template slot-scope="scope">
|
|
35
|
-
<span v-if="scope.row.linktype == 0">不导航</span>
|
|
36
|
-
<span v-if="scope.row.linktype == 1">商城页面</span>
|
|
37
|
-
<span v-if="scope.row.linktype == 2">商品页面</span>
|
|
38
|
-
<span v-if="scope.row.linktype == 3">自定义链接</span>
|
|
39
|
-
</template>
|
|
40
|
-
</el-table-column>
|
|
41
|
-
<el-table-column prop="link_address" label="导航地址"> </el-table-column>
|
|
42
|
-
<el-table-column prop="note" label="备注"> </el-table-column>
|
|
43
|
-
<el-table-column fixed="right" label="操作" align="center" row>
|
|
44
|
-
<template slot-scope="scope">
|
|
45
|
-
<le-button
|
|
46
|
-
id="btnEdit"
|
|
47
|
-
text="编辑"
|
|
48
|
-
@click="openEditWindow(scope.row)"
|
|
49
|
-
></le-button>
|
|
50
|
-
<le-button-msg @click="del(scope.row)"></le-button-msg>
|
|
51
|
-
</template>
|
|
52
|
-
</el-table-column>
|
|
53
|
-
</el-table>
|
|
54
|
-
<div style="text-align: center; margin-top: 30px">
|
|
55
|
-
<el-pagination
|
|
56
|
-
background
|
|
57
|
-
layout="prev, pager, next"
|
|
58
|
-
:total="searchData.total"
|
|
59
|
-
:page-size="10"
|
|
60
|
-
@current-change="current_change"
|
|
61
|
-
></el-pagination>
|
|
62
|
-
</div>
|
|
63
|
-
<le-dialog-container
|
|
64
|
-
:showDialog="showDialog"
|
|
65
|
-
@close="closeDialog"
|
|
66
|
-
title="广告详情"
|
|
67
|
-
>
|
|
68
|
-
<le-ad-sub
|
|
69
|
-
@close="closeDialog"
|
|
70
|
-
@rowRefresh="list"
|
|
71
|
-
:rowitem="currentRow"
|
|
72
|
-
></le-ad-sub>
|
|
73
|
-
</le-dialog-container>
|
|
74
|
-
</div>
|
|
75
|
-
</template>
|
|
76
|
-
<script>
|
|
77
|
-
import { list, del } from "@/api/system-ad";
|
|
78
|
-
import LeAdSub from "./sub.vue";
|
|
79
|
-
export default {
|
|
80
|
-
name: "le-ad",
|
|
81
|
-
components: {
|
|
82
|
-
LeAdSub,
|
|
83
|
-
},
|
|
84
|
-
data() {
|
|
85
|
-
return {
|
|
86
|
-
searchData: {
|
|
87
|
-
pageNo: 1,
|
|
88
|
-
total: 1,
|
|
89
|
-
dtype: null,
|
|
90
|
-
},
|
|
91
|
-
tableData: [],
|
|
92
|
-
showDialog: false,
|
|
93
|
-
currentRow: {},
|
|
94
|
-
};
|
|
95
|
-
},
|
|
96
|
-
mounted() {
|
|
97
|
-
this.list();
|
|
98
|
-
},
|
|
99
|
-
methods: {
|
|
100
|
-
list() {
|
|
101
|
-
let params = JSON.parse(JSON.stringify(this.searchData));
|
|
102
|
-
list(params).then((res) => {
|
|
103
|
-
let data = res.data.data;
|
|
104
|
-
if (data) this.tableData = data.list;
|
|
105
|
-
});
|
|
106
|
-
},
|
|
107
|
-
del(id) {
|
|
108
|
-
let param = {};
|
|
109
|
-
param.id = id;
|
|
110
|
-
del(id).then((response) => {
|
|
111
|
-
this.list();
|
|
112
|
-
this.$message.success(response.data.info);
|
|
113
|
-
});
|
|
114
|
-
},
|
|
115
|
-
searData() {
|
|
116
|
-
this.searchData.pageNo = 1;
|
|
117
|
-
this.list();
|
|
118
|
-
},
|
|
119
|
-
current_change(currentPage) {
|
|
120
|
-
this.searchData.pageNo = currentPage;
|
|
121
|
-
this.list();
|
|
122
|
-
},
|
|
123
|
-
addAd() {
|
|
124
|
-
this.currentRow = null;
|
|
125
|
-
this.showDialog = true;
|
|
126
|
-
},
|
|
127
|
-
openEditWindow(item) {
|
|
128
|
-
this.currentRow = item;
|
|
129
|
-
this.showDialog = true;
|
|
130
|
-
},
|
|
131
|
-
closeDialog() {
|
|
132
|
-
this.currentRow = null;
|
|
133
|
-
this.showDialog = false;
|
|
134
|
-
},
|
|
135
|
-
},
|
|
136
|
-
};
|
|
137
|
-
</script>
|
package/le-ad/src/sub.vue
DELETED
|
@@ -1,180 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<el-form ref="form" :model="form" :rules="rules" label-width="80px">
|
|
3
|
-
<el-form-item label="广告标题" prop="title">
|
|
4
|
-
<el-input v-model="form.title"></el-input>
|
|
5
|
-
</el-form-item>
|
|
6
|
-
<el-form-item label="终端类型" prop="dtype">
|
|
7
|
-
<el-select
|
|
8
|
-
v-model="form.dtype"
|
|
9
|
-
placeholder="请选择终端类型"
|
|
10
|
-
clearable
|
|
11
|
-
@change="changeDType"
|
|
12
|
-
>
|
|
13
|
-
<el-option label="PC" :value="0" :key="0"></el-option>
|
|
14
|
-
<el-option label="移动" :value="1" :key="1"></el-option>
|
|
15
|
-
</el-select>
|
|
16
|
-
</el-form-item>
|
|
17
|
-
<el-form-item label="广告位" prop="sid">
|
|
18
|
-
<el-select v-model="form.sid" placeholder="请选择广告位" clearable>
|
|
19
|
-
<el-option
|
|
20
|
-
v-for="option in sidOptions"
|
|
21
|
-
:key="option.id"
|
|
22
|
-
:label="option.title + option.code"
|
|
23
|
-
:value="option.id"
|
|
24
|
-
>
|
|
25
|
-
</el-option>
|
|
26
|
-
</el-select>
|
|
27
|
-
</el-form-item>
|
|
28
|
-
<el-form-item label="图片" prop="imgsrc">
|
|
29
|
-
<le-image
|
|
30
|
-
:images="initPrimaryImages"
|
|
31
|
-
:limit="1"
|
|
32
|
-
@getImages="getPrimaryImages"
|
|
33
|
-
></le-image>
|
|
34
|
-
</el-form-item>
|
|
35
|
-
<el-form-item label="链接类型" prop="linktype">
|
|
36
|
-
<el-select v-model="form.linktype" placeholder="请选择链接类型" clearable>
|
|
37
|
-
<el-option label="不导航" :value="0" :key="0"></el-option>
|
|
38
|
-
<el-option label="商城页面" :value="1" :key="1"></el-option>
|
|
39
|
-
<el-option label="商品页面" :value="2" :key="2"></el-option>
|
|
40
|
-
<el-option label="自定义链接" :value="3" :key="3"></el-option>
|
|
41
|
-
</el-select>
|
|
42
|
-
</el-form-item>
|
|
43
|
-
<el-form-item label="链接地址">
|
|
44
|
-
<el-input v-model="form.link_address"></el-input>
|
|
45
|
-
</el-form-item>
|
|
46
|
-
<el-form-item label="排序">
|
|
47
|
-
<el-input v-model="form.seq"></el-input>
|
|
48
|
-
</el-form-item>
|
|
49
|
-
<el-form-item label="备注" prop="note">
|
|
50
|
-
<el-input v-model="form.note"></el-input>
|
|
51
|
-
</el-form-item>
|
|
52
|
-
<el-form-item v-rfooter>
|
|
53
|
-
<el-button type="primary" @click="onSubmit">保存</el-button>
|
|
54
|
-
<el-button @click="close()">取消</el-button>
|
|
55
|
-
</el-form-item>
|
|
56
|
-
</el-form>
|
|
57
|
-
</template>
|
|
58
|
-
<script>
|
|
59
|
-
import { add, edit } from "@/api/system-ad";
|
|
60
|
-
import { options as listOptions } from "@/api/system-ad-space";
|
|
61
|
-
export default {
|
|
62
|
-
name: "le-ad-sub",
|
|
63
|
-
props: {
|
|
64
|
-
rowitem: {},
|
|
65
|
-
},
|
|
66
|
-
data() {
|
|
67
|
-
return {
|
|
68
|
-
form: {
|
|
69
|
-
id: "",
|
|
70
|
-
sid: "",
|
|
71
|
-
dtype: 0,
|
|
72
|
-
title: "",
|
|
73
|
-
imgsrc: "",
|
|
74
|
-
linktype: 0,
|
|
75
|
-
link_address: "",
|
|
76
|
-
seq: 1,
|
|
77
|
-
status: 0,
|
|
78
|
-
note: "",
|
|
79
|
-
},
|
|
80
|
-
|
|
81
|
-
initPrimaryImages: [],
|
|
82
|
-
|
|
83
|
-
sidOptions: [],
|
|
84
|
-
|
|
85
|
-
rules: {
|
|
86
|
-
sid: [{ required: true, message: "广告位置必须选择", trigger: "blur" }],
|
|
87
|
-
dtype: [
|
|
88
|
-
{ required: true, message: "终端类型必须选择", trigger: "blur" },
|
|
89
|
-
],
|
|
90
|
-
title: [
|
|
91
|
-
{ required: true, message: "请输入标题名称", trigger: "blur" },
|
|
92
|
-
{
|
|
93
|
-
min: 1,
|
|
94
|
-
max: 80,
|
|
95
|
-
message: "长度在 1 到 80 个字符",
|
|
96
|
-
trigger: "blur",
|
|
97
|
-
},
|
|
98
|
-
],
|
|
99
|
-
imgsrc: [
|
|
100
|
-
{ required: true, message: "图片地址必须定义", trigger: "blur" },
|
|
101
|
-
],
|
|
102
|
-
linktype: [
|
|
103
|
-
{ required: true, message: "链接类型必须选择", trigger: "blur" },
|
|
104
|
-
],
|
|
105
|
-
note: [
|
|
106
|
-
{
|
|
107
|
-
max: 200,
|
|
108
|
-
message: "长度在 0 到 200个字符",
|
|
109
|
-
trigger: "blur",
|
|
110
|
-
},
|
|
111
|
-
],
|
|
112
|
-
},
|
|
113
|
-
};
|
|
114
|
-
},
|
|
115
|
-
watch: {
|
|
116
|
-
rowitem: {
|
|
117
|
-
handler(newValue) {
|
|
118
|
-
if (newValue && newValue.id && newValue.id.length > 0) {
|
|
119
|
-
this.form = newValue;
|
|
120
|
-
if (this.form.imgsrc && this.form.imgsrc.length > 0) {
|
|
121
|
-
this.initPrimaryImages = [];
|
|
122
|
-
this.initPrimaryImages.push(this.form.imgsrc);
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
},
|
|
126
|
-
immediate: true,
|
|
127
|
-
},
|
|
128
|
-
},
|
|
129
|
-
mounted() {
|
|
130
|
-
let params = {};
|
|
131
|
-
params.dtype = null;
|
|
132
|
-
this.getSidOptions();
|
|
133
|
-
},
|
|
134
|
-
methods: {
|
|
135
|
-
onSubmit() {
|
|
136
|
-
this.$refs["form"].validate((valid) => {
|
|
137
|
-
if (valid) {
|
|
138
|
-
let params = JSON.parse(JSON.stringify(this.form));
|
|
139
|
-
if (params.id && params.id.length > 0) {
|
|
140
|
-
edit(params).then((res) => {
|
|
141
|
-
this.$message(res.data.info);
|
|
142
|
-
this.$emit("rowRefresh");
|
|
143
|
-
this.close();
|
|
144
|
-
});
|
|
145
|
-
} else {
|
|
146
|
-
add(params).then((response) => {
|
|
147
|
-
this.$emit("rowRefresh");
|
|
148
|
-
this.$message(response.data.info);
|
|
149
|
-
this.close();
|
|
150
|
-
});
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
});
|
|
154
|
-
},
|
|
155
|
-
close() {
|
|
156
|
-
this.$emit("close");
|
|
157
|
-
},
|
|
158
|
-
changeDType(e) {
|
|
159
|
-
let params = {};
|
|
160
|
-
params.dtype = e;
|
|
161
|
-
this.getSidOptions(params);
|
|
162
|
-
},
|
|
163
|
-
getSidOptions(params) {
|
|
164
|
-
listOptions(params).then((res) => {
|
|
165
|
-
let data = res.data.data;
|
|
166
|
-
if (data) {
|
|
167
|
-
this.sidOptions = data;
|
|
168
|
-
} else this.sidOptions = [];
|
|
169
|
-
});
|
|
170
|
-
},
|
|
171
|
-
getPrimaryImages(images) {
|
|
172
|
-
if (images && images.length > 0) {
|
|
173
|
-
this.form.imgsrc = images[0];
|
|
174
|
-
} else {
|
|
175
|
-
this.form.imgsrc = "";
|
|
176
|
-
}
|
|
177
|
-
},
|
|
178
|
-
},
|
|
179
|
-
};
|
|
180
|
-
</script>
|
package/le-ad-space/index.js
DELETED
package/le-ad-space/src/main.vue
DELETED
|
@@ -1,135 +0,0 @@
|
|
|
1
|
-
<template>
|
|
2
|
-
<div>
|
|
3
|
-
<el-form :inline="true" :model="searchData">
|
|
4
|
-
<el-form-item label="终端">
|
|
5
|
-
<el-select
|
|
6
|
-
v-model="searchData.dtype"
|
|
7
|
-
placeholder="请选择终端类型"
|
|
8
|
-
clearable
|
|
9
|
-
>
|
|
10
|
-
<el-option label="PC" value="0" key="0"></el-option>
|
|
11
|
-
<el-option label="移动" value="1" key="1"></el-option>
|
|
12
|
-
</el-select>
|
|
13
|
-
</el-form-item>
|
|
14
|
-
<el-form-item>
|
|
15
|
-
<el-button type="primary" @click="searData">查询</el-button>
|
|
16
|
-
<el-button type="primary" @click="addAd()">新增广告位</el-button>
|
|
17
|
-
</el-form-item>
|
|
18
|
-
</el-form>
|
|
19
|
-
<el-table :data="tableData" border row-key="id" stripe style="width: 100%">
|
|
20
|
-
<el-table-column prop="dtype" label="终端">
|
|
21
|
-
<template slot-scope="scope">
|
|
22
|
-
<span v-if="scope.row.dtype == 0">PC端</span>
|
|
23
|
-
<span v-if="scope.row.dtype == 1">移动端</span>
|
|
24
|
-
</template>
|
|
25
|
-
</el-table-column>
|
|
26
|
-
<el-table-column prop="title" label="广告位"> </el-table-column>
|
|
27
|
-
<el-table-column prop="code" label="编码"> </el-table-column>
|
|
28
|
-
<el-table-column prop="status" label="状态">
|
|
29
|
-
<template slot-scope="scope">
|
|
30
|
-
<span v-if="scope.row.status == 0">未启用</span>
|
|
31
|
-
<span v-if="scope.row.status == 1">已经启用</span>
|
|
32
|
-
</template>
|
|
33
|
-
</el-table-column>
|
|
34
|
-
<el-table-column prop="note" label="备注"> </el-table-column>
|
|
35
|
-
<el-table-column
|
|
36
|
-
fixed="right"
|
|
37
|
-
label="操作"
|
|
38
|
-
align="center"
|
|
39
|
-
width="160"
|
|
40
|
-
row
|
|
41
|
-
>
|
|
42
|
-
<template slot-scope="scope">
|
|
43
|
-
<le-button
|
|
44
|
-
id="btnEdit"
|
|
45
|
-
text="编辑"
|
|
46
|
-
@click="openEditWindow(scope.row)"
|
|
47
|
-
></le-button>
|
|
48
|
-
<le-button-msg @click="del(scope.row)"></le-button-msg>
|
|
49
|
-
</template>
|
|
50
|
-
</el-table-column>
|
|
51
|
-
</el-table>
|
|
52
|
-
<div style="text-align: center; margin-top: 30px">
|
|
53
|
-
<el-pagination
|
|
54
|
-
background
|
|
55
|
-
layout="prev, pager, next"
|
|
56
|
-
:total="searchData.total"
|
|
57
|
-
:page-size="10"
|
|
58
|
-
@current-change="current_change"
|
|
59
|
-
></el-pagination>
|
|
60
|
-
</div>
|
|
61
|
-
<le-dialog-container
|
|
62
|
-
:showDialog="showDialog"
|
|
63
|
-
@close="closeDialog"
|
|
64
|
-
title="广告位详情"
|
|
65
|
-
>
|
|
66
|
-
<le-ad-space-sub
|
|
67
|
-
@close="closeDialog"
|
|
68
|
-
@rowRefresh="list"
|
|
69
|
-
:rowitem="currentRow"
|
|
70
|
-
></le-ad-space-sub>
|
|
71
|
-
</le-dialog-container>
|
|
72
|
-
</div>
|
|
73
|
-
</template>
|
|
74
|
-
<script>
|
|
75
|
-
import { list, del } from "@/api/system-ad-space";
|
|
76
|
-
import LeAdSpaceSub from "./sub.vue";
|
|
77
|
-
export default {
|
|
78
|
-
name: "le-ad-space",
|
|
79
|
-
components: {
|
|
80
|
-
LeAdSpaceSub,
|
|
81
|
-
},
|
|
82
|
-
data() {
|
|
83
|
-
return {
|
|
84
|
-
searchData: {
|
|
85
|
-
pageNo: 1,
|
|
86
|
-
total: 1,
|
|
87
|
-
dtype: null,
|
|
88
|
-
},
|
|
89
|
-
tableData: [],
|
|
90
|
-
showDialog: false,
|
|
91
|
-
currentRow: {},
|
|
92
|
-
};
|
|
93
|
-
},
|
|
94
|
-
computed: {},
|
|
95
|
-
mounted() {
|
|
96
|
-
this.list();
|
|
97
|
-
},
|
|
98
|
-
methods: {
|
|
99
|
-
list() {
|
|
100
|
-
let params = JSON.parse(JSON.stringify(this.searchData));
|
|
101
|
-
list(params).then((res) => {
|
|
102
|
-
let data = res.data.data;
|
|
103
|
-
if (data) {
|
|
104
|
-
this.tableData = data.list;
|
|
105
|
-
}
|
|
106
|
-
});
|
|
107
|
-
},
|
|
108
|
-
del(id) {
|
|
109
|
-
del(id).then((response) => {
|
|
110
|
-
this.list();
|
|
111
|
-
this.$message.success(response.data.info);
|
|
112
|
-
});
|
|
113
|
-
},
|
|
114
|
-
searData() {
|
|
115
|
-
this.searchData.pageNo = 1;
|
|
116
|
-
this.list();
|
|
117
|
-
},
|
|
118
|
-
current_change(currentPage) {
|
|
119
|
-
this.searchData.pageNo = currentPage;
|
|
120
|
-
this.list();
|
|
121
|
-
},
|
|
122
|
-
addAd() {
|
|
123
|
-
this.currentRow = null;
|
|
124
|
-
this.showDialog = true;
|
|
125
|
-
},
|
|
126
|
-
openEditWindow(item) {
|
|
127
|
-
this.currentRow = item;
|
|
128
|
-
this.showDialog = true;
|
|
129
|
-
},
|
|
130
|
-
closeDialog() {
|
|
131
|
-
this.showDialog = false;
|
|
132
|
-
},
|
|
133
|
-
},
|
|
134
|
-
};
|
|
135
|
-
</script>
|