officialblock 1.0.6 → 1.0.8
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/dist/index-Ch_ldWmA.js +1 -0
- package/dist/index-DXm2cqxo.mjs +485 -0
- package/dist/official-block.cjs.js +74 -74
- package/dist/official-block.es.js +13577 -10832
- package/dist/official-block.umd.js +78 -78
- package/dist/style.css +1 -1
- package/dist/swiper-JiLDDxAF.js +1 -0
- package/dist/swiper-acbnDJoL.mjs +2035 -0
- package/dist/utils-DD-vVZej.mjs +316 -0
- package/dist/utils-DOLLD0-F.js +1 -0
- package/package.json +2 -1
- package/src/components/ArticleList/article.vue +3 -3
- package/src/components/ArticleList/contact.vue +9 -9
- package/src/components/ArticleList/index.ts +1 -1
- package/src/components/ArticleList/index.vue +24 -82
- package/src/components/ArticleList/setting.vue +61 -71
- package/src/components/ArticleList/type.ts +12 -18
- package/src/components/BannerImage/index.ts +11 -0
- package/src/components/BannerImage/index.vue +153 -0
- package/src/components/BannerImage/setting.vue +55 -0
- package/src/components/BannerImage/type.ts +10 -0
- package/src/components/BannerPage/index.ts +11 -0
- package/src/components/BannerPage/index.vue +283 -0
- package/src/components/BannerPage/setting.vue +55 -0
- package/src/components/BannerPage/type.ts +10 -0
- package/src/components/BtnList/index.ts +11 -0
- package/src/components/BtnList/index.vue +588 -0
- package/src/components/BtnList/setting.vue +255 -0
- package/src/components/BtnList/type.ts +10 -0
- package/src/components/Button/index.vue +45 -33
- package/src/components/CustomSpace/index.ts +11 -0
- package/src/components/CustomSpace/index.vue +82 -0
- package/src/components/CustomSpace/setting.vue +89 -0
- package/src/components/CustomSpace/type.ts +10 -0
- package/src/components/GalleryList/index.ts +12 -0
- package/src/components/GalleryList/index.vue +311 -0
- package/src/components/GalleryList/setting.vue +268 -0
- package/src/components/GalleryList/type.ts +10 -0
- package/src/components/HeroSlide/index.ts +1 -1
- package/src/components/HeroSlide/index.vue +85 -133
- package/src/components/HeroSlide/setting.vue +435 -0
- package/src/components/HeroSlide/type.ts +5 -14
- package/src/components/LinkLIst/index.ts +11 -0
- package/src/components/LinkLIst/index.vue +317 -0
- package/src/components/LinkLIst/setting.vue +264 -0
- package/src/components/LinkLIst/type.ts +10 -0
- package/src/components/Media/index.vue +18 -18
- package/src/components/Operate/index.vue +17 -7
- package/src/components/Profile/index.vue +999 -0
- package/src/components/Profile/modal.vue +56 -0
- package/src/components/Profile/setting.vue +330 -0
- package/src/components/QuickLinks/index.vue +166 -0
- package/src/components/QuoteText/index.ts +11 -0
- package/src/components/QuoteText/index.vue +133 -0
- package/src/components/QuoteText/setting.vue +81 -0
- package/src/components/QuoteText/type.ts +10 -0
- package/src/components/ScrollKeyInfo/index.vue +0 -0
- package/src/components/Swiper/index.vue +538 -0
- package/src/components/index.ts +23 -5
- package/src/index.ts +56 -12
- package/src/main.ts +6 -3
- package/src/router/index.ts +6 -0
- package/src/style.css +17 -0
- package/src/styles/component-isolation.scss +256 -0
- package/src/styles/editor.scss +1 -1
- package/src/styles/layers.scss +256 -0
- package/src/styles/main.scss +21687 -0
- package/src/styles/mixins/style-isolation.scss +262 -0
- package/src/styles/smart-reset.scss +287 -0
- package/src/styles/test.scss +1 -1
- package/src/types/button.ts +10 -0
- package/src/views/StyleIsolationTest.vue +292 -0
- package/src/views/components/ArticleListDemo.vue +49 -10
|
@@ -0,0 +1,255 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<a-drawer :width="500" :visible="show" :footer="false" @cancel="handleCancel" unmountOnClose>
|
|
3
|
+
<template #title>
|
|
4
|
+
{{data.type}}组件编辑
|
|
5
|
+
</template>
|
|
6
|
+
<div class="setting-content">
|
|
7
|
+
<!-- 组件自身属性 -->
|
|
8
|
+
<div class="setting-header flex items-center">
|
|
9
|
+
<span class="header-title">组件宽度</span>
|
|
10
|
+
<a-select v-model="data.width" placeholder="请选择" allow-clear>
|
|
11
|
+
<a-option value="">默认</a-option>
|
|
12
|
+
<a-option value="small">小</a-option>
|
|
13
|
+
<a-option value="middle">中</a-option>
|
|
14
|
+
<a-option value="max">大</a-option>
|
|
15
|
+
</a-select>
|
|
16
|
+
</div>
|
|
17
|
+
<div class="setting-header flex items-center">
|
|
18
|
+
<span class="header-title">组件背景</span>
|
|
19
|
+
<a-select v-model="data.bgColor" placeholder="请选择" allow-clear>
|
|
20
|
+
<a-option value="#ffffff">白色</a-option>
|
|
21
|
+
<a-option value="#F7F7FA">灰色</a-option>
|
|
22
|
+
</a-select>
|
|
23
|
+
</div>
|
|
24
|
+
|
|
25
|
+
<a-button-group type="primary">
|
|
26
|
+
<a-button size="mini" @click="handleAdd('')"><template #icon><icon-plus /></template> 默认按钮 </a-button>
|
|
27
|
+
<a-button size="mini" @click="handleAdd('white')"><template #icon><icon-plus /></template> 白色按钮 </a-button>
|
|
28
|
+
<a-button size="mini" @click="handleAdd('light')"><template #icon><icon-plus /></template> 亮色按钮 </a-button>
|
|
29
|
+
<a-button size="mini" @click="handleAdd('blue')"><template #icon><icon-plus /></template> 蓝色按钮 </a-button>
|
|
30
|
+
</a-button-group>
|
|
31
|
+
|
|
32
|
+
<!-- 子组件属性 -->
|
|
33
|
+
<div class="setting-body">
|
|
34
|
+
<div class="setting-item">
|
|
35
|
+
<p class="item-name">按钮</p>
|
|
36
|
+
<draggable
|
|
37
|
+
v-model="data.data"
|
|
38
|
+
:component-data="{
|
|
39
|
+
tag: 'div',
|
|
40
|
+
type: 'transition-group',
|
|
41
|
+
name: !drag ? 'flip-list' : null
|
|
42
|
+
}"
|
|
43
|
+
v-bind="buttonDragOptions"
|
|
44
|
+
:disabled="!shouldShowDragHandle(data.data)"
|
|
45
|
+
@start="drag = true"
|
|
46
|
+
@end="drag = false"
|
|
47
|
+
item-key="id"
|
|
48
|
+
>
|
|
49
|
+
<template #item="{ element: button }">
|
|
50
|
+
<div
|
|
51
|
+
class="item-button draggable-item"
|
|
52
|
+
:class="{ 'sortable-disabled': !shouldShowDragHandle(data.data) }"
|
|
53
|
+
:key="button.id"
|
|
54
|
+
>
|
|
55
|
+
<div class="btn-group">
|
|
56
|
+
<div
|
|
57
|
+
v-if="shouldShowDragHandle(data.data)"
|
|
58
|
+
class="drag-handle"
|
|
59
|
+
>
|
|
60
|
+
<icon-drag-arrow class="drag-icon" />
|
|
61
|
+
</div>
|
|
62
|
+
<icon-delete class="btn-delete" @click="handleDelete(button.id)" />
|
|
63
|
+
</div>
|
|
64
|
+
<a-button type="primary">{{ button.text }}</a-button>
|
|
65
|
+
<div class="item-action flex items-center">
|
|
66
|
+
<a-input class="action-text" v-model="button.text" placeholder="按钮文本" allow-clear />
|
|
67
|
+
<a-input v-model="button.url" placeholder="按钮链接" allow-clear />
|
|
68
|
+
</div>
|
|
69
|
+
<a-checkbox :model-value="button.isExternal">是否外部链接</a-checkbox>
|
|
70
|
+
</div>
|
|
71
|
+
</template>
|
|
72
|
+
</draggable>
|
|
73
|
+
</div>
|
|
74
|
+
</div>
|
|
75
|
+
</div>
|
|
76
|
+
</a-drawer>
|
|
77
|
+
</template>
|
|
78
|
+
|
|
79
|
+
<script lang="ts" setup>
|
|
80
|
+
import { ref, computed } from 'vue'
|
|
81
|
+
import draggable from 'vuedraggable'
|
|
82
|
+
import { randomString } from '@/utils/common'
|
|
83
|
+
|
|
84
|
+
// 拖拽相关状态
|
|
85
|
+
const drag = ref(false)
|
|
86
|
+
|
|
87
|
+
// 不同类型的拖拽配置选项
|
|
88
|
+
const buttonDragOptions = computed(() => ({
|
|
89
|
+
animation: 200,
|
|
90
|
+
group: 'buttons', // 按钮专用分组
|
|
91
|
+
disabled: false,
|
|
92
|
+
ghostClass: 'ghost'
|
|
93
|
+
}))
|
|
94
|
+
|
|
95
|
+
// 检查是否应该显示拖拽图标
|
|
96
|
+
const shouldShowDragHandle = (list: any[]) => {
|
|
97
|
+
return list && list.length > 1
|
|
98
|
+
}
|
|
99
|
+
|
|
100
|
+
const props = defineProps({
|
|
101
|
+
show: {
|
|
102
|
+
type: Boolean,
|
|
103
|
+
default: false
|
|
104
|
+
},
|
|
105
|
+
|
|
106
|
+
data: {
|
|
107
|
+
type: Object,
|
|
108
|
+
default: () => {}
|
|
109
|
+
}
|
|
110
|
+
})
|
|
111
|
+
|
|
112
|
+
const emit = defineEmits(['update:show']);
|
|
113
|
+
|
|
114
|
+
const handleCancel = () => {
|
|
115
|
+
emit('update:show', false);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
const handleAdd = (type: string) => {
|
|
119
|
+
const detail = props.data;
|
|
120
|
+
detail.data.push({
|
|
121
|
+
id: randomString(),
|
|
122
|
+
type,
|
|
123
|
+
text: '查看更多',
|
|
124
|
+
url: undefined,
|
|
125
|
+
isExternal: false
|
|
126
|
+
})
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
const handleDelete = (id: string) => {
|
|
130
|
+
props.data.data = props.data.data.filter((item: any) => item.id !== id)
|
|
131
|
+
}
|
|
132
|
+
</script>
|
|
133
|
+
|
|
134
|
+
<style lang="scss" scoped>
|
|
135
|
+
.setting-content {
|
|
136
|
+
.setting-header {
|
|
137
|
+
padding-bottom: 12px;
|
|
138
|
+
|
|
139
|
+
.header-title {
|
|
140
|
+
width: 120px;
|
|
141
|
+
padding-right: 12px;
|
|
142
|
+
text-align: right;
|
|
143
|
+
}
|
|
144
|
+
}
|
|
145
|
+
|
|
146
|
+
.setting-body {
|
|
147
|
+
margin-top: 12px;
|
|
148
|
+
|
|
149
|
+
.setting-item {
|
|
150
|
+
position: relative;
|
|
151
|
+
padding: 16px 12px;
|
|
152
|
+
background: #f0f2f5;
|
|
153
|
+
border-radius: 8px;
|
|
154
|
+
margin-bottom: 20px;
|
|
155
|
+
|
|
156
|
+
.btn-group {
|
|
157
|
+
position: absolute;
|
|
158
|
+
right: 0;
|
|
159
|
+
top: 0;
|
|
160
|
+
display: flex;
|
|
161
|
+
align-items: center;
|
|
162
|
+
padding: 4px;
|
|
163
|
+
|
|
164
|
+
.btn-delete {
|
|
165
|
+
padding: 4px;
|
|
166
|
+
font-size: 24px;
|
|
167
|
+
cursor: pointer;
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
.item-name {
|
|
172
|
+
font-size: 16px;
|
|
173
|
+
font-weight: 600;
|
|
174
|
+
padding-bottom: 10px;
|
|
175
|
+
border-bottom: 1px solid #fff;
|
|
176
|
+
}
|
|
177
|
+
|
|
178
|
+
.item-button {
|
|
179
|
+
position: relative;
|
|
180
|
+
padding: 12px 8px 4px;
|
|
181
|
+
background: #fff;
|
|
182
|
+
border-radius: 4px;
|
|
183
|
+
margin: 4px 0;
|
|
184
|
+
transition: all 0.3s ease;
|
|
185
|
+
|
|
186
|
+
&.draggable-item {
|
|
187
|
+
cursor: move;
|
|
188
|
+
|
|
189
|
+
&:hover {
|
|
190
|
+
box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
|
|
191
|
+
transform: translateY(-1px);
|
|
192
|
+
}
|
|
193
|
+
|
|
194
|
+
// 当禁用拖拽时,不显示拖拽效果
|
|
195
|
+
&.sortable-disabled {
|
|
196
|
+
cursor: default;
|
|
197
|
+
|
|
198
|
+
&:hover {
|
|
199
|
+
box-shadow: none;
|
|
200
|
+
transform: none;
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
}
|
|
204
|
+
|
|
205
|
+
.arco-input-wrapper {
|
|
206
|
+
background: #f2f3f5;
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
// 拖拽相关样式
|
|
211
|
+
.flip-list-move {
|
|
212
|
+
transition: transform 0.5s;
|
|
213
|
+
}
|
|
214
|
+
|
|
215
|
+
.no-move {
|
|
216
|
+
transition: transform 0s;
|
|
217
|
+
}
|
|
218
|
+
|
|
219
|
+
.ghost {
|
|
220
|
+
opacity: 0.5;
|
|
221
|
+
background: #c8ebfb;
|
|
222
|
+
}
|
|
223
|
+
|
|
224
|
+
.item-action {
|
|
225
|
+
padding: 10px 0;
|
|
226
|
+
|
|
227
|
+
.action-text {
|
|
228
|
+
width: 150px;
|
|
229
|
+
margin-right: 8px;
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
|
|
235
|
+
.drag-handle {
|
|
236
|
+
padding: 4px;
|
|
237
|
+
cursor: grab;
|
|
238
|
+
padding: 4px;
|
|
239
|
+
border-radius: 4px;
|
|
240
|
+
|
|
241
|
+
&:hover {
|
|
242
|
+
background-color: #f0f2f5;
|
|
243
|
+
}
|
|
244
|
+
|
|
245
|
+
&:active {
|
|
246
|
+
cursor: grabbing;
|
|
247
|
+
}
|
|
248
|
+
|
|
249
|
+
.drag-icon {
|
|
250
|
+
font-size: 16px;
|
|
251
|
+
color: #86909c;
|
|
252
|
+
}
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
</style>
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<div v-if="type === 'button'" class="button-primary flex-inline flex-center" @click="handleButtonClick">
|
|
2
|
+
<div v-if="type === 'button'" class="button-primary flex-inline flex-center" :class="[hasHoverBg && 'button-hover-bg']" @click="handleButtonClick">
|
|
3
3
|
<span class="button-text">{{ data.text }}</span>
|
|
4
4
|
<span class="button-icon"></span>
|
|
5
5
|
</div>
|
|
@@ -20,6 +20,11 @@ const props = defineProps({
|
|
|
20
20
|
type: Object,
|
|
21
21
|
default: () => {},
|
|
22
22
|
},
|
|
23
|
+
|
|
24
|
+
hasHoverBg: {
|
|
25
|
+
type: Boolean,
|
|
26
|
+
default: true
|
|
27
|
+
},
|
|
23
28
|
})
|
|
24
29
|
|
|
25
30
|
// TODO: 内部跳转
|
|
@@ -40,7 +45,8 @@ const handleButtonClick = () => {
|
|
|
40
45
|
transition: background-color $transition-normal;
|
|
41
46
|
flex-shrink: 0;
|
|
42
47
|
|
|
43
|
-
&::before,
|
|
48
|
+
&::before,
|
|
49
|
+
&::after {
|
|
44
50
|
content: "";
|
|
45
51
|
width: 6px;
|
|
46
52
|
height: 9px;
|
|
@@ -52,22 +58,23 @@ const handleButtonClick = () => {
|
|
|
52
58
|
background-size: cover;
|
|
53
59
|
background-repeat: no-repeat;
|
|
54
60
|
background-color: hsla(0,0%,100%,0);
|
|
55
|
-
transition: transform .3s ease-in-out
|
|
61
|
+
transition: transform .3s ease-in-out;
|
|
56
62
|
}
|
|
57
63
|
|
|
58
64
|
&::before {
|
|
59
|
-
transform: translate(-260%,-50%)
|
|
65
|
+
transform: translate(-260%,-50%);
|
|
60
66
|
}
|
|
61
67
|
|
|
62
68
|
&::after {
|
|
63
|
-
transform: translate(-50%,-50%)
|
|
69
|
+
transform: translate(-50%,-50%);
|
|
64
70
|
}
|
|
65
71
|
}
|
|
66
72
|
|
|
67
73
|
.link-icon {
|
|
68
74
|
background-color: $primary-color;
|
|
69
75
|
|
|
70
|
-
&::before,
|
|
76
|
+
&::before,
|
|
77
|
+
&::after {
|
|
71
78
|
background-image: url();
|
|
72
79
|
}
|
|
73
80
|
}
|
|
@@ -100,24 +107,25 @@ const handleButtonClick = () => {
|
|
|
100
107
|
transition: all $transition-normal;
|
|
101
108
|
z-index: -1;
|
|
102
109
|
-webkit-clip-path: circle(100% at -80% 90%);
|
|
103
|
-
clip-path: circle(100% at -80% 90%)
|
|
110
|
+
clip-path: circle(100% at -80% 90%);
|
|
104
111
|
}
|
|
105
112
|
|
|
106
113
|
&:hover::before {
|
|
107
114
|
-webkit-clip-path: circle(100% at 50% 50%);
|
|
108
|
-
clip-path: circle(100% at 50% 50%)
|
|
115
|
+
clip-path: circle(100% at 50% 50%);
|
|
109
116
|
}
|
|
110
117
|
|
|
111
118
|
&:hover {
|
|
112
119
|
.button-icon:before {
|
|
113
|
-
transform: translate(-50%,-50%)
|
|
120
|
+
transform: translate(-50%,-50%);
|
|
114
121
|
}
|
|
115
122
|
|
|
116
123
|
.button-icon:after {
|
|
117
|
-
transform: translate(150%,-50%)
|
|
124
|
+
transform: translate(150%,-50%);
|
|
118
125
|
}
|
|
119
126
|
|
|
120
|
-
.button-icon:after,
|
|
127
|
+
.button-icon:after,
|
|
128
|
+
.button-icon:before {
|
|
121
129
|
background-image: url();
|
|
122
130
|
background-position: 50%;
|
|
123
131
|
background-size: cover;
|
|
@@ -142,58 +150,62 @@ const handleButtonClick = () => {
|
|
|
142
150
|
transition: color $transition-normal;
|
|
143
151
|
}
|
|
144
152
|
|
|
145
|
-
|
|
146
|
-
|
|
153
|
+
.button-icon:after,
|
|
154
|
+
.button-icon:before {
|
|
155
|
+
background-image: url() !important;
|
|
147
156
|
}
|
|
157
|
+
}
|
|
148
158
|
|
|
149
|
-
|
|
150
|
-
|
|
159
|
+
.button-hover-bg {
|
|
160
|
+
&::before {
|
|
161
|
+
background: $button-hover-bg;
|
|
151
162
|
}
|
|
152
163
|
}
|
|
153
164
|
|
|
154
|
-
@media(max-width: 1023.98px) {
|
|
165
|
+
@media (max-width: 1023.98px) {
|
|
155
166
|
.button-primary {
|
|
156
|
-
padding:11px 15px;
|
|
157
|
-
min-width: 100px
|
|
167
|
+
padding: 11px 15px;
|
|
168
|
+
min-width: 100px;
|
|
158
169
|
}
|
|
159
170
|
}
|
|
160
171
|
|
|
161
|
-
@media(max-width: 767.98px) {
|
|
172
|
+
@media (max-width: 767.98px) {
|
|
162
173
|
.button-primary {
|
|
163
|
-
padding:8px 12px;
|
|
164
|
-
min-width: 80px
|
|
174
|
+
padding: 8px 12px;
|
|
175
|
+
min-width: 80px;
|
|
165
176
|
}
|
|
166
177
|
}
|
|
167
178
|
|
|
168
|
-
@media(max-width: 1023.98px) {
|
|
179
|
+
@media (max-width: 1023.98px) {
|
|
169
180
|
.button-primary {
|
|
170
|
-
padding:11px 15px;
|
|
171
|
-
min-width: 100px
|
|
181
|
+
padding: 11px 15px;
|
|
182
|
+
min-width: 100px;
|
|
172
183
|
}
|
|
173
184
|
}
|
|
174
185
|
|
|
175
|
-
@media(max-width: 767.98px) {
|
|
186
|
+
@media (max-width: 767.98px) {
|
|
176
187
|
.button-primary {
|
|
177
|
-
padding:8px 12px;
|
|
178
|
-
min-width: 80px
|
|
188
|
+
padding: 8px 12px;
|
|
189
|
+
min-width: 80px;
|
|
179
190
|
}
|
|
180
191
|
}
|
|
181
192
|
|
|
182
|
-
@media(max-width: 767.98px) {
|
|
193
|
+
@media (max-width: 767.98px) {
|
|
183
194
|
.button-icon {
|
|
184
|
-
width:12px;
|
|
195
|
+
width: 12px;
|
|
185
196
|
height: 12px;
|
|
186
|
-
margin-left: 4px
|
|
197
|
+
margin-left: 4px;
|
|
187
198
|
}
|
|
188
199
|
|
|
189
|
-
.button-icon:after,
|
|
190
|
-
|
|
200
|
+
.button-icon:after,
|
|
201
|
+
.button-icon:before {
|
|
202
|
+
width: 4.7px;
|
|
191
203
|
height: 6px;
|
|
192
204
|
background-image: url();
|
|
193
205
|
background-position: 50%;
|
|
194
206
|
background-size: cover;
|
|
195
207
|
background-repeat: no-repeat;
|
|
196
|
-
background-color: hsla(0,0%,100%,0)
|
|
208
|
+
background-color: hsla(0,0%,100%,0);
|
|
197
209
|
}
|
|
198
210
|
}
|
|
199
211
|
</style>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { App, Plugin } from 'vue'
|
|
2
|
+
import CustomSpace from './index.vue'
|
|
3
|
+
|
|
4
|
+
export default {
|
|
5
|
+
install: (app: App) => {
|
|
6
|
+
app.component('CustomSpace', CustomSpace)
|
|
7
|
+
},
|
|
8
|
+
} satisfies Plugin
|
|
9
|
+
|
|
10
|
+
export { default as CustomSpace } from './index.vue'
|
|
11
|
+
export type { CustomSpaceProps, CustomSpaceEmits } from './type'
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div :id="modelValue?.data?.id" class="custom-space"
|
|
3
|
+
:style="{'--desktop-height': modelValue?.data?.desktopHeight + 'px', '--mobile-height': modelValue?.data?.mobileHeight + 'px', '--bg-color': modelValue?.data?.bgColor}"
|
|
4
|
+
@mouseenter="isHover = true" @mouseleave="isHover = false">
|
|
5
|
+
<Operate v-if="!modelValue?.readOnly" v-model:show="isHover" @handle-edit="showSetting = true" @handle-delete="handleDelete" @handle-copy="handleCopy"></Operate>
|
|
6
|
+
</div>
|
|
7
|
+
|
|
8
|
+
<Setting v-model:show="showSetting" :data="modelValue"></Setting>
|
|
9
|
+
</template>
|
|
10
|
+
|
|
11
|
+
<script lang="ts" setup>
|
|
12
|
+
import { ref } from 'vue'
|
|
13
|
+
import { randomString } from '@/utils/common'
|
|
14
|
+
import Operate from '@/components/Operate/index.vue'
|
|
15
|
+
import Setting from './setting.vue'
|
|
16
|
+
|
|
17
|
+
// 定义组件名称
|
|
18
|
+
defineOptions({
|
|
19
|
+
name: 'CustomSpace'
|
|
20
|
+
})
|
|
21
|
+
|
|
22
|
+
const props = defineProps({
|
|
23
|
+
modelValue: {
|
|
24
|
+
type: Object,
|
|
25
|
+
default: () => {}
|
|
26
|
+
},
|
|
27
|
+
|
|
28
|
+
// 是否预览
|
|
29
|
+
isPreview: {
|
|
30
|
+
type: Boolean,
|
|
31
|
+
default: false
|
|
32
|
+
}
|
|
33
|
+
})
|
|
34
|
+
|
|
35
|
+
const emit = defineEmits(['update:modelValue', 'handleDelete', 'handleCopy'])
|
|
36
|
+
|
|
37
|
+
const handleInit = () => {
|
|
38
|
+
if (props.modelValue && props.modelValue.data) return // 有数据不用初始化
|
|
39
|
+
const data = {
|
|
40
|
+
id: props.modelValue?.id || randomString(),
|
|
41
|
+
type: 'CustomSpace',
|
|
42
|
+
readOnly: props.modelValue?.readOnly || false,
|
|
43
|
+
data: {
|
|
44
|
+
id: '',
|
|
45
|
+
desktopHeight: '49',
|
|
46
|
+
mobileHeight: '24',
|
|
47
|
+
bgColor: ''
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
emit('update:modelValue', data)
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const isHover = ref<boolean>(false);
|
|
54
|
+
const showSetting = ref<boolean>(false);
|
|
55
|
+
|
|
56
|
+
const handleDelete = () => {
|
|
57
|
+
emit('handleDelete', props.modelValue.id)
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
const handleCopy = () => {
|
|
61
|
+
emit('handleCopy', props.modelValue)
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
handleInit()
|
|
65
|
+
</script>
|
|
66
|
+
|
|
67
|
+
<style scoped>
|
|
68
|
+
.custom-space {
|
|
69
|
+
position: relative;
|
|
70
|
+
width: 100%;
|
|
71
|
+
height: 160px;
|
|
72
|
+
height: var(--desktop-height, 0);
|
|
73
|
+
background-color: transparent;
|
|
74
|
+
background-color: var(--bg-color, transparent);
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
@media (max-width: 767.98px) {
|
|
78
|
+
.custom-space {
|
|
79
|
+
height: var(--mobile-height, 0);
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
</style>
|
|
@@ -0,0 +1,89 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<a-drawer :width="500" :visible="show" :footer="false" @cancel="handleCancel" unmountOnClose>
|
|
3
|
+
<template #title>
|
|
4
|
+
{{data.type}}组件编辑
|
|
5
|
+
</template>
|
|
6
|
+
<div class="setting-content">
|
|
7
|
+
<p class="item-title">背景颜色</p>
|
|
8
|
+
<a-select v-model="data.bgColor" placeholder="请选择" allow-clear>
|
|
9
|
+
<a-option value="#ffffff">白色</a-option>
|
|
10
|
+
<a-option value="#F7F7FA">灰色</a-option>
|
|
11
|
+
</a-select>
|
|
12
|
+
|
|
13
|
+
<p class="item-title">间距设置</p>
|
|
14
|
+
<a-select v-model="customSpace" placeholder="请选择" @change="handleChange" allow-clear>
|
|
15
|
+
<a-option :value="1">制表符起始间距(49px,24px)</a-option>
|
|
16
|
+
<a-option :value="2">部分间距(80px,40px)</a-option>
|
|
17
|
+
<a-option :value="3">组件间距(32px,40px)</a-option>
|
|
18
|
+
<a-option :value="4">链接间距(16px,16px)</a-option>
|
|
19
|
+
<a-option :value="5">页末间距(160px,80px)</a-option>
|
|
20
|
+
</a-select>
|
|
21
|
+
|
|
22
|
+
<p class="item-title">PC高度(单位:px)</p>
|
|
23
|
+
<a-input v-model="data.data.desktopHeight" disabled />
|
|
24
|
+
|
|
25
|
+
<p class="item-title">移动端高度(单位:px)</p>
|
|
26
|
+
<a-input v-model="data.data.mobileHeight" disabled />
|
|
27
|
+
|
|
28
|
+
<p class="item-title">唯一标识</p>
|
|
29
|
+
<a-input v-model="data.data.id" placeholder="请输入唯一标识" allow-clear />
|
|
30
|
+
</div>
|
|
31
|
+
</a-drawer>
|
|
32
|
+
</template>
|
|
33
|
+
|
|
34
|
+
<script lang="ts" setup>
|
|
35
|
+
import { ref } from 'vue'
|
|
36
|
+
const props = defineProps({
|
|
37
|
+
show: {
|
|
38
|
+
type: Boolean,
|
|
39
|
+
default: false
|
|
40
|
+
},
|
|
41
|
+
|
|
42
|
+
data: {
|
|
43
|
+
type: Object,
|
|
44
|
+
default: () => {}
|
|
45
|
+
}
|
|
46
|
+
})
|
|
47
|
+
|
|
48
|
+
const emit = defineEmits(['update:show']);
|
|
49
|
+
const handleCancel = () => {
|
|
50
|
+
emit('update:show', false);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
const customSpace = ref<number>(1);
|
|
54
|
+
const handleChange = (value: number) => {
|
|
55
|
+
if (value === 1) {
|
|
56
|
+
props.data.data.desktopHeight = 49;
|
|
57
|
+
props.data.data.mobileHeight = 24;
|
|
58
|
+
} else if (value === 2) {
|
|
59
|
+
props.data.data.desktopHeight = 80;
|
|
60
|
+
props.data.data.mobileHeight = 40;
|
|
61
|
+
} else if (value === 3) {
|
|
62
|
+
props.data.data.desktopHeight = 32;
|
|
63
|
+
props.data.data.mobileHeight = 40;
|
|
64
|
+
} else if (value === 4) {
|
|
65
|
+
props.data.data.desktopHeight = 16;
|
|
66
|
+
props.data.data.mobileHeight = 16;
|
|
67
|
+
} else if (value === 5) {
|
|
68
|
+
props.data.data.desktopHeight = 160;
|
|
69
|
+
props.data.data.mobileHeight = 80;
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
</script>
|
|
73
|
+
|
|
74
|
+
<style lang="scss" scoped>
|
|
75
|
+
.setting-content {
|
|
76
|
+
position: relative;
|
|
77
|
+
|
|
78
|
+
.item-title {
|
|
79
|
+
padding: 12px 0 8px 0;
|
|
80
|
+
font-size: 14px;
|
|
81
|
+
font-weight: 600;
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
.item-img {
|
|
85
|
+
margin-top: 12px;
|
|
86
|
+
height: 160px;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
</style>
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
|
|
2
|
+
import type { App, Plugin } from 'vue'
|
|
3
|
+
import GalleryList from './index.vue'
|
|
4
|
+
|
|
5
|
+
export default {
|
|
6
|
+
install: (app: App) => {
|
|
7
|
+
app.component('GalleryList', GalleryList)
|
|
8
|
+
},
|
|
9
|
+
} satisfies Plugin
|
|
10
|
+
|
|
11
|
+
export { default as GalleryList } from './index.vue'
|
|
12
|
+
export type { GalleryListProps, GalleryListEmits } from './type'
|