@10yun/cv-mobile-ui 0.5.4 → 0.5.6
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/package.json +1 -1
- package/ui-cv/cv-code-sms/cv-code-sms.vue +30 -22
- package/ui-cv/cv-datetime-base/cv-datetime-base.vue +17 -3
- package/ui-cv/cv-editor-quill/cv-editor-quill.vue +13 -13
- package/ui-cv/cv-input-digit/cv-input-digit.vue +0 -7
- package/ui-cv/cv-input-idcard/cv-input-idcard.vue +0 -7
- package/ui-cv/cv-input-number/cv-input-number.vue +0 -7
- package/ui-cv/cv-input-password/cv-input-password.vue +0 -7
- package/ui-cv/cv-load-empty/cv-load-empty.vue +57 -0
- package/ui-cv/cv-load-more2/cv-load-more2.vue +44 -0
- package/ui-cv/cv-load-more2/load-more.vue +189 -0
- package/ui-cv/cv-rate/cv-rate.vue +16 -12
- package/ui-cv/cv-specs/cv-specs.vue +13 -13
- package/ui-cv/cv-switch/cv-switch.vue +0 -7
- package/ui-cv/cv-tabs-box/cv-tabs-box.vue +96 -0
- package/ui-cv/cv-tabs-item/cv-tabs-item.vue +82 -0
- package/ui-cv/cv-textarea/cv-textarea.vue +0 -7
- package/ui-cv/cv-upload-image/cv-upload-image.vue +3 -3
package/package.json
CHANGED
|
@@ -13,6 +13,7 @@
|
|
|
13
13
|
</view>
|
|
14
14
|
<view class="cv-code-button-area">
|
|
15
15
|
<button
|
|
16
|
+
size="mini"
|
|
16
17
|
class="cv-code-button-item"
|
|
17
18
|
:class="btnDisabled ? 'cv-code-button-wait' : ''"
|
|
18
19
|
:disabled="btnDisabled"
|
|
@@ -26,19 +27,15 @@
|
|
|
26
27
|
<script>
|
|
27
28
|
export default {
|
|
28
29
|
name: 'cvCodeSms',
|
|
29
|
-
inject: {
|
|
30
|
-
cvFormGroup: {
|
|
31
|
-
default() {
|
|
32
|
-
return null;
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
|
-
},
|
|
36
30
|
props: {
|
|
37
31
|
value: {
|
|
38
32
|
type: [Number, String],
|
|
39
33
|
default: ''
|
|
40
34
|
},
|
|
41
|
-
modelValue: {
|
|
35
|
+
modelValue: {
|
|
36
|
+
type: [Number, String],
|
|
37
|
+
default: ''
|
|
38
|
+
},
|
|
42
39
|
maxlength: {
|
|
43
40
|
type: [Number, String],
|
|
44
41
|
default: -1
|
|
@@ -51,15 +48,11 @@ export default {
|
|
|
51
48
|
type: String,
|
|
52
49
|
default: 'mobile'
|
|
53
50
|
},
|
|
54
|
-
codeUrl: {
|
|
55
|
-
type: String,
|
|
56
|
-
default: ''
|
|
57
|
-
},
|
|
58
51
|
codeSign: {
|
|
59
52
|
type: Boolean,
|
|
60
53
|
default: false
|
|
61
54
|
},
|
|
62
|
-
|
|
55
|
+
apiFunc: {
|
|
63
56
|
type: Function,
|
|
64
57
|
default: null
|
|
65
58
|
},
|
|
@@ -75,12 +68,15 @@ export default {
|
|
|
75
68
|
},
|
|
76
69
|
value(newVal) {
|
|
77
70
|
this.localVal = newVal;
|
|
71
|
+
},
|
|
72
|
+
modelValue(newVal) {
|
|
73
|
+
this.localVal = newVal;
|
|
78
74
|
}
|
|
79
75
|
},
|
|
80
76
|
data() {
|
|
81
77
|
return {
|
|
82
78
|
// 验证码
|
|
83
|
-
localVal:
|
|
79
|
+
localVal: '',
|
|
84
80
|
localMobile: '',
|
|
85
81
|
nextTime: 0,
|
|
86
82
|
diyPlaceholder: '短信验证码',
|
|
@@ -93,9 +89,16 @@ export default {
|
|
|
93
89
|
};
|
|
94
90
|
},
|
|
95
91
|
created() {
|
|
92
|
+
this.localVal = this.doValueGet();
|
|
96
93
|
this.localMobile = this.mobile;
|
|
94
|
+
console.log(this.apiFunc);
|
|
97
95
|
},
|
|
98
96
|
methods: {
|
|
97
|
+
doValueGet() {
|
|
98
|
+
if (this.value === '') return this.modelValue;
|
|
99
|
+
if (this.modelValue === '') return this.value;
|
|
100
|
+
return this.value;
|
|
101
|
+
},
|
|
99
102
|
showDiyMsg(msg) {
|
|
100
103
|
uni.showToast({
|
|
101
104
|
title: msg,
|
|
@@ -115,8 +118,8 @@ export default {
|
|
|
115
118
|
return;
|
|
116
119
|
}
|
|
117
120
|
|
|
118
|
-
if (!this.
|
|
119
|
-
this.showDiyMsg('
|
|
121
|
+
if (!this.apiFunc) {
|
|
122
|
+
this.showDiyMsg('短信接口方法不能为空');
|
|
120
123
|
return;
|
|
121
124
|
}
|
|
122
125
|
|
|
@@ -130,9 +133,8 @@ export default {
|
|
|
130
133
|
|
|
131
134
|
if (this.btnDisabled) {
|
|
132
135
|
this.btnText = '请稍后...';
|
|
133
|
-
if (this.
|
|
134
|
-
this.
|
|
135
|
-
postType: 'sendSms',
|
|
136
|
+
if (this.apiFunc) {
|
|
137
|
+
this.apiFunc({
|
|
136
138
|
cto_sms_type: 'alterMobile',
|
|
137
139
|
sendCode: '发送验证码',
|
|
138
140
|
[this.mobileParam]: this.localMobile
|
|
@@ -159,7 +161,7 @@ export default {
|
|
|
159
161
|
this.btnText = '获取验证码';
|
|
160
162
|
});
|
|
161
163
|
} else {
|
|
162
|
-
console.warn('url请求未完善,请使用:
|
|
164
|
+
console.warn('url请求未完善,请使用:apiFunc');
|
|
163
165
|
this.btnDisabled = false;
|
|
164
166
|
this.btnText = '重新获取验证码';
|
|
165
167
|
}
|
|
@@ -193,6 +195,14 @@ export default {
|
|
|
193
195
|
height: 35px;
|
|
194
196
|
line-height: 35px;
|
|
195
197
|
font-size: 14px;
|
|
198
|
+
width: 100%;
|
|
199
|
+
padding-right: 10px;
|
|
200
|
+
|
|
201
|
+
display: flex;
|
|
202
|
+
flex-direction: row;
|
|
203
|
+
justify-content: space-between;
|
|
204
|
+
width: 100%;
|
|
205
|
+
padding-right: 10px;
|
|
196
206
|
}
|
|
197
207
|
.cv-code-input-area {
|
|
198
208
|
width: calc(100% - 120px - 10px);
|
|
@@ -206,14 +216,12 @@ export default {
|
|
|
206
216
|
font-size: 14px;
|
|
207
217
|
}
|
|
208
218
|
.cv-code-button-area {
|
|
209
|
-
width: 120px;
|
|
210
219
|
float: right;
|
|
211
220
|
height: 35px;
|
|
212
221
|
}
|
|
213
222
|
.cv-code-button-item {
|
|
214
223
|
height: 35px;
|
|
215
224
|
line-height: 35px;
|
|
216
|
-
font-size: 14px;
|
|
217
225
|
background-color: #007aff;
|
|
218
226
|
color: #ffffff;
|
|
219
227
|
}
|
|
@@ -25,7 +25,7 @@
|
|
|
25
25
|
@cancel="bindPickerCancel"
|
|
26
26
|
>
|
|
27
27
|
<view class="cv-time-base-text" v-if="localVal_time != ''">{{ localVal_time }}</view>
|
|
28
|
-
<view class="cv-picker-item-placeholder" v-else>{{
|
|
28
|
+
<view class="cv-picker-item-placeholder" v-else>{{ placeholder2 }}</view>
|
|
29
29
|
</picker>
|
|
30
30
|
</view>
|
|
31
31
|
</template>
|
|
@@ -38,6 +38,10 @@ export default {
|
|
|
38
38
|
type: String,
|
|
39
39
|
default: ''
|
|
40
40
|
},
|
|
41
|
+
modelValue: {
|
|
42
|
+
type: String,
|
|
43
|
+
default: ''
|
|
44
|
+
},
|
|
41
45
|
startDate: {
|
|
42
46
|
type: String,
|
|
43
47
|
default: ''
|
|
@@ -61,7 +65,12 @@ export default {
|
|
|
61
65
|
// 占位符
|
|
62
66
|
placeholder: {
|
|
63
67
|
type: String,
|
|
64
|
-
default: '
|
|
68
|
+
default: '请选择日期'
|
|
69
|
+
},
|
|
70
|
+
// 占位符
|
|
71
|
+
placeholder2: {
|
|
72
|
+
type: String,
|
|
73
|
+
default: '请选择时间'
|
|
65
74
|
}
|
|
66
75
|
},
|
|
67
76
|
watch: {
|
|
@@ -81,11 +90,16 @@ export default {
|
|
|
81
90
|
};
|
|
82
91
|
},
|
|
83
92
|
created() {
|
|
84
|
-
this.localVal = this.
|
|
93
|
+
this.localVal = this.doValueGet();
|
|
85
94
|
this.localVal_date = this.localVal.split(' ')[0] || '';
|
|
86
95
|
this.localVal_time = this.localVal.split(' ')[1] || '';
|
|
87
96
|
},
|
|
88
97
|
methods: {
|
|
98
|
+
doValueGet() {
|
|
99
|
+
if (this.value === '') return this.modelValue;
|
|
100
|
+
if (this.modelValue === '') return this.value;
|
|
101
|
+
return this.value;
|
|
102
|
+
},
|
|
89
103
|
bindTimeChange: function (e) {
|
|
90
104
|
let value = e.detail.value;
|
|
91
105
|
this.localVal_time = value;
|
|
@@ -149,28 +149,19 @@ export default {
|
|
|
149
149
|
components: {
|
|
150
150
|
helangCompress
|
|
151
151
|
},
|
|
152
|
-
name: '
|
|
153
|
-
inject: {
|
|
154
|
-
cvFormGroup: {
|
|
155
|
-
default() {
|
|
156
|
-
return null;
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
},
|
|
152
|
+
name: 'cvEditorQuill',
|
|
160
153
|
props: {
|
|
161
154
|
value: {
|
|
162
155
|
type: String,
|
|
163
156
|
default: ''
|
|
164
157
|
},
|
|
165
|
-
|
|
158
|
+
modelValue: {
|
|
166
159
|
type: String,
|
|
167
160
|
default: ''
|
|
168
161
|
},
|
|
169
162
|
placeholder: {
|
|
170
163
|
type: String,
|
|
171
|
-
default
|
|
172
|
-
return '开始输入...';
|
|
173
|
-
}
|
|
164
|
+
default: '开始输入...'
|
|
174
165
|
},
|
|
175
166
|
upload: {
|
|
176
167
|
type: Object,
|
|
@@ -196,10 +187,14 @@ export default {
|
|
|
196
187
|
value(newVal) {
|
|
197
188
|
this.localVal = newVal;
|
|
198
189
|
this.setContents();
|
|
190
|
+
},
|
|
191
|
+
modelValue(newVal) {
|
|
192
|
+
this.localVal = newVal;
|
|
193
|
+
this.setContents();
|
|
199
194
|
}
|
|
200
195
|
},
|
|
201
196
|
created() {
|
|
202
|
-
this.localVal = this.
|
|
197
|
+
this.localVal = this.doValueGet();
|
|
203
198
|
/* uni.loadFontFace({
|
|
204
199
|
family: 'Pacifico',
|
|
205
200
|
source: 'url("https://sungd.github.io/Pacifico.ttf")'
|
|
@@ -207,6 +202,11 @@ export default {
|
|
|
207
202
|
// console.log(this.upload)
|
|
208
203
|
},
|
|
209
204
|
methods: {
|
|
205
|
+
doValueGet() {
|
|
206
|
+
if (this.value === '') return this.modelValue;
|
|
207
|
+
if (this.modelValue === '') return this.value;
|
|
208
|
+
return this.value;
|
|
209
|
+
},
|
|
210
210
|
onBlur(e) {
|
|
211
211
|
this.getContents();
|
|
212
212
|
},
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<view class="cv-empty-box">
|
|
3
|
+
<image class="cv-empty-image" :src="localImg" mode="aspectFit"></image>
|
|
4
|
+
<view class="cv-empty-text">{{ localDesc }}</view>
|
|
5
|
+
</view>
|
|
6
|
+
</template>
|
|
7
|
+
<script>
|
|
8
|
+
export default {
|
|
9
|
+
name: 'cvLoadEmpty',
|
|
10
|
+
props: ['src', 'des', 'show'],
|
|
11
|
+
watch: {
|
|
12
|
+
src(newVal) {
|
|
13
|
+
this.localImg = newVal;
|
|
14
|
+
},
|
|
15
|
+
des(newVal) {
|
|
16
|
+
this.localDesc = newVal;
|
|
17
|
+
}
|
|
18
|
+
},
|
|
19
|
+
data() {
|
|
20
|
+
return {
|
|
21
|
+
localDesc: '暂无数据',
|
|
22
|
+
localImg:
|
|
23
|
+
''
|
|
24
|
+
};
|
|
25
|
+
},
|
|
26
|
+
created() {
|
|
27
|
+
this.localDesc = this.des || this.localDesc;
|
|
28
|
+
this.localImg = this.src || this.localImg;
|
|
29
|
+
},
|
|
30
|
+
methods: {}
|
|
31
|
+
};
|
|
32
|
+
</script>
|
|
33
|
+
<style>
|
|
34
|
+
.cv-empty-box {
|
|
35
|
+
display: flex;
|
|
36
|
+
align-items: center;
|
|
37
|
+
justify-content: center;
|
|
38
|
+
flex-direction: column;
|
|
39
|
+
/* position: fixed; */
|
|
40
|
+
left: 0;
|
|
41
|
+
/* top: 100rpx; */
|
|
42
|
+
padding-top: 100px;
|
|
43
|
+
right: 0;
|
|
44
|
+
bottom: 0;
|
|
45
|
+
/* background: #FFFFFF; */
|
|
46
|
+
padding-bottom: 60px;
|
|
47
|
+
}
|
|
48
|
+
.cv-empty-image {
|
|
49
|
+
width: 100px;
|
|
50
|
+
height: 100px;
|
|
51
|
+
}
|
|
52
|
+
.cv-empty-text {
|
|
53
|
+
color: #999999;
|
|
54
|
+
margin-top: 8px;
|
|
55
|
+
font-size: 13px;
|
|
56
|
+
}
|
|
57
|
+
</style>
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<view class="cv-load-more-wrap">
|
|
3
|
+
<load-more :loadingType="loadingType" :contentText="contentText"></load-more>
|
|
4
|
+
</view>
|
|
5
|
+
</template>
|
|
6
|
+
<script>
|
|
7
|
+
import loadMore from './load-more.vue';
|
|
8
|
+
export default {
|
|
9
|
+
name: 'cvLoadMore',
|
|
10
|
+
components: { loadMore },
|
|
11
|
+
props: {
|
|
12
|
+
loadingType: {
|
|
13
|
+
type: [Number, String],
|
|
14
|
+
default: 0
|
|
15
|
+
},
|
|
16
|
+
contentText: {
|
|
17
|
+
type: [Object],
|
|
18
|
+
default: {
|
|
19
|
+
contentdown: '上拉显示更多',
|
|
20
|
+
contentrefresh: '正在加载...',
|
|
21
|
+
contentnomore: '没有更多数据了'
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
},
|
|
25
|
+
data() {
|
|
26
|
+
return {};
|
|
27
|
+
}
|
|
28
|
+
};
|
|
29
|
+
</script>
|
|
30
|
+
<style>
|
|
31
|
+
.cv-load-more-wrap {
|
|
32
|
+
flex-direction: column;
|
|
33
|
+
position: relative;
|
|
34
|
+
display: block;
|
|
35
|
+
box-sizing: border-box;
|
|
36
|
+
|
|
37
|
+
display: block;
|
|
38
|
+
width: 100%;
|
|
39
|
+
float: left;
|
|
40
|
+
-webkit-box-flex: 0;
|
|
41
|
+
-ms-flex: 0 0 auto;
|
|
42
|
+
flex: 0 0 auto;
|
|
43
|
+
}
|
|
44
|
+
</style>
|
|
@@ -0,0 +1,189 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<view class="load-more">
|
|
3
|
+
<view class="loading-img" v-show="loadingType === 1 && showImage">
|
|
4
|
+
<view class="load1">
|
|
5
|
+
<view :style="{ background: color }"></view>
|
|
6
|
+
<view :style="{ background: color }"></view>
|
|
7
|
+
<view :style="{ background: color }"></view>
|
|
8
|
+
<view :style="{ background: color }"></view>
|
|
9
|
+
</view>
|
|
10
|
+
<view class="load2">
|
|
11
|
+
<view :style="{ background: color }"></view>
|
|
12
|
+
<view :style="{ background: color }"></view>
|
|
13
|
+
<view :style="{ background: color }"></view>
|
|
14
|
+
<view :style="{ background: color }"></view>
|
|
15
|
+
</view>
|
|
16
|
+
<view class="load3">
|
|
17
|
+
<view :style="{ background: color }"></view>
|
|
18
|
+
<view :style="{ background: color }"></view>
|
|
19
|
+
<view :style="{ background: color }"></view>
|
|
20
|
+
<view :style="{ background: color }"></view>
|
|
21
|
+
</view>
|
|
22
|
+
</view>
|
|
23
|
+
<text class="loading-text" :style="{ color: color }">
|
|
24
|
+
{{
|
|
25
|
+
loadingType === 0 ? contentText.contentdown : loadingType === 1 ? contentText.contentrefresh : contentText.contentnomore
|
|
26
|
+
}}
|
|
27
|
+
</text>
|
|
28
|
+
</view>
|
|
29
|
+
</template>
|
|
30
|
+
|
|
31
|
+
<script>
|
|
32
|
+
export default {
|
|
33
|
+
name: 'load-more',
|
|
34
|
+
props: {
|
|
35
|
+
loadingType: {
|
|
36
|
+
//上拉的状态:0-loading前;1-loading中;2-没有更多了
|
|
37
|
+
type: Number,
|
|
38
|
+
default: 0
|
|
39
|
+
},
|
|
40
|
+
showImage: {
|
|
41
|
+
type: Boolean,
|
|
42
|
+
default: true
|
|
43
|
+
},
|
|
44
|
+
color: {
|
|
45
|
+
type: String,
|
|
46
|
+
default: '#777777'
|
|
47
|
+
},
|
|
48
|
+
contentText: {
|
|
49
|
+
type: Object,
|
|
50
|
+
default: {
|
|
51
|
+
contentdown: '上拉显示更多',
|
|
52
|
+
contentrefresh: '正在加载...',
|
|
53
|
+
contentnomore: '没有更多数据了'
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
},
|
|
57
|
+
data() {
|
|
58
|
+
return {};
|
|
59
|
+
}
|
|
60
|
+
};
|
|
61
|
+
</script>
|
|
62
|
+
|
|
63
|
+
<style>
|
|
64
|
+
.load-more {
|
|
65
|
+
display: flex;
|
|
66
|
+
flex-direction: row;
|
|
67
|
+
height: 80rpx;
|
|
68
|
+
align-items: center;
|
|
69
|
+
justify-content: center;
|
|
70
|
+
}
|
|
71
|
+
.loading-img {
|
|
72
|
+
height: 48rpx;
|
|
73
|
+
width: 48rpx;
|
|
74
|
+
margin-right: 20rpx;
|
|
75
|
+
}
|
|
76
|
+
.loading-text {
|
|
77
|
+
font-size: 30rpx;
|
|
78
|
+
color: #777777;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
.loading-img > view {
|
|
82
|
+
position: absolute;
|
|
83
|
+
}
|
|
84
|
+
.load1,
|
|
85
|
+
.load2,
|
|
86
|
+
.load3 {
|
|
87
|
+
height: 50rpx;
|
|
88
|
+
width: 50rpx;
|
|
89
|
+
}
|
|
90
|
+
.load2 {
|
|
91
|
+
transform: rotate(30deg);
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
.load3 {
|
|
95
|
+
transform: rotate(60deg);
|
|
96
|
+
}
|
|
97
|
+
|
|
98
|
+
.loading-img > view view {
|
|
99
|
+
width: 12rpx;
|
|
100
|
+
height: 4rpx;
|
|
101
|
+
border-top-left-radius: 1px;
|
|
102
|
+
border-bottom-left-radius: 1px;
|
|
103
|
+
background: #777;
|
|
104
|
+
position: absolute;
|
|
105
|
+
opacity: 0.2;
|
|
106
|
+
transform-origin: 50%;
|
|
107
|
+
-webkit-animation: load 1.56s ease infinite;
|
|
108
|
+
}
|
|
109
|
+
|
|
110
|
+
.loading-img > view view:nth-child(1) {
|
|
111
|
+
transform: rotate(90deg);
|
|
112
|
+
top: 2px;
|
|
113
|
+
left: 9px;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
.loading-img > view view:nth-child(2) {
|
|
117
|
+
-webkit-transform: rotate(180deg);
|
|
118
|
+
top: 11px;
|
|
119
|
+
right: 0px;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
.loading-img > view view:nth-child(3) {
|
|
123
|
+
transform: rotate(270deg);
|
|
124
|
+
bottom: 4rpx;
|
|
125
|
+
left: 18rpx;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
.loading-img > view view:nth-child(4) {
|
|
129
|
+
top: 22rpx;
|
|
130
|
+
left: 0px;
|
|
131
|
+
}
|
|
132
|
+
|
|
133
|
+
.load1 view:nth-child(1) {
|
|
134
|
+
animation-delay: 0s;
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
.load2 view:nth-child(1) {
|
|
138
|
+
animation-delay: 0.13s;
|
|
139
|
+
}
|
|
140
|
+
|
|
141
|
+
.load3 view:nth-child(1) {
|
|
142
|
+
animation-delay: 0.26s;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
.load1 view:nth-child(2) {
|
|
146
|
+
animation-delay: 0.39s;
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
.load2 view:nth-child(2) {
|
|
150
|
+
animation-delay: 0.52s;
|
|
151
|
+
}
|
|
152
|
+
|
|
153
|
+
.load3 view:nth-child(2) {
|
|
154
|
+
animation-delay: 0.65s;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
.load1 view:nth-child(3) {
|
|
158
|
+
animation-delay: 0.78s;
|
|
159
|
+
}
|
|
160
|
+
|
|
161
|
+
.load2 view:nth-child(3) {
|
|
162
|
+
animation-delay: 0.91s;
|
|
163
|
+
}
|
|
164
|
+
|
|
165
|
+
.load3 view:nth-child(3) {
|
|
166
|
+
animation-delay: 1.04s;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
.load1 view:nth-child(4) {
|
|
170
|
+
animation-delay: 1.17s;
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
.load2 view:nth-child(4) {
|
|
174
|
+
animation-delay: 1.3s;
|
|
175
|
+
}
|
|
176
|
+
|
|
177
|
+
.load3 view:nth-child(4) {
|
|
178
|
+
animation-delay: 1.43s;
|
|
179
|
+
}
|
|
180
|
+
|
|
181
|
+
@-webkit-keyframes load {
|
|
182
|
+
0% {
|
|
183
|
+
opacity: 1;
|
|
184
|
+
}
|
|
185
|
+
100% {
|
|
186
|
+
opacity: 0.2;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
</style>
|
|
@@ -4,7 +4,7 @@
|
|
|
4
4
|
class="cv-rate-item"
|
|
5
5
|
v-for="i in parseInt(max)"
|
|
6
6
|
:key="i"
|
|
7
|
-
|
|
7
|
+
:style="i <= locaValue ? starSelected : starStyle"
|
|
8
8
|
:data-value="i"
|
|
9
9
|
@tap="click_star"
|
|
10
10
|
>
|
|
@@ -17,22 +17,15 @@
|
|
|
17
17
|
<script>
|
|
18
18
|
export default {
|
|
19
19
|
name: 'cvRate',
|
|
20
|
-
inject: {
|
|
21
|
-
cvFormGroup: {
|
|
22
|
-
default() {
|
|
23
|
-
return null;
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
},
|
|
27
20
|
props: {
|
|
28
21
|
// 当前评分
|
|
29
22
|
value: {
|
|
30
23
|
type: [Number, String],
|
|
31
|
-
default:
|
|
24
|
+
default: 0
|
|
32
25
|
},
|
|
33
26
|
modelValue: {
|
|
34
27
|
type: [Number, String],
|
|
35
|
-
default:
|
|
28
|
+
default: 0
|
|
36
29
|
},
|
|
37
30
|
isFill: {
|
|
38
31
|
// 星星的类型,是否镂空
|
|
@@ -78,13 +71,24 @@ export default {
|
|
|
78
71
|
};
|
|
79
72
|
},
|
|
80
73
|
watch: {
|
|
81
|
-
value(newVal) {
|
|
74
|
+
value(newVal) {
|
|
75
|
+
this.locaValue = newVal;
|
|
76
|
+
},
|
|
77
|
+
modelValue(newVal) {
|
|
78
|
+
this.locaValue = newVal;
|
|
79
|
+
}
|
|
82
80
|
},
|
|
83
81
|
created() {
|
|
84
|
-
this.locaValue = this.
|
|
82
|
+
this.locaValue = this.doValueGet();
|
|
83
|
+
console.log(this.locaValue);
|
|
85
84
|
this._dealStyle();
|
|
86
85
|
},
|
|
87
86
|
methods: {
|
|
87
|
+
doValueGet() {
|
|
88
|
+
if (this.value === 0) return this.modelValue;
|
|
89
|
+
if (this.modelValue === 0) return this.value;
|
|
90
|
+
return this.value;
|
|
91
|
+
},
|
|
88
92
|
_dealStyle() {
|
|
89
93
|
if (this.color) {
|
|
90
94
|
let starStyle = 'font-size:' + this.size + 'px;';
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
<view class="cv-specs">
|
|
3
3
|
<!-- 规格 -->
|
|
4
4
|
<view class="cv-specs-area">
|
|
5
|
-
<view class="cv-specs-sort-area" v-for="(item, index1) in
|
|
5
|
+
<view class="cv-specs-sort-area" v-for="(item, index1) in localSpu" :key="index1">
|
|
6
6
|
<!-- 规格类别名称 -->
|
|
7
7
|
<view class="cv-specs-sort-name">
|
|
8
8
|
<text>{{ item.name }}</text>
|
|
@@ -83,8 +83,8 @@ export default {
|
|
|
83
83
|
},
|
|
84
84
|
data() {
|
|
85
85
|
return {
|
|
86
|
-
|
|
87
|
-
|
|
86
|
+
localSpu: [], //spu规格列表
|
|
87
|
+
localSku: [], //sku列表
|
|
88
88
|
shopItemInfo: {}, //存放要和选中的值进行匹配的数据
|
|
89
89
|
selectArr: [], //存放被选中的值
|
|
90
90
|
subIndex: [], //是否选中 因为不确定是多规格还是但规格,所以这里定义数组来判断
|
|
@@ -101,14 +101,14 @@ export default {
|
|
|
101
101
|
methods: {
|
|
102
102
|
//初始化数据
|
|
103
103
|
_dealData() {
|
|
104
|
-
this.
|
|
105
|
-
this.
|
|
104
|
+
this.localSpu = this.specList.items; // spu规格列表
|
|
105
|
+
this.localSku = this.skuList.items; // sku列表
|
|
106
106
|
this.shopItemInfo = {}; //存放要和选中的值进行匹配的数据
|
|
107
107
|
this.selectArr = []; //存放被选中的值
|
|
108
108
|
this.subIndex = []; //是否选中 因为不确定是多规格还是但规格,所以这里定义数组来判断
|
|
109
109
|
this.selectshop = {}; //存放最后选中的商品
|
|
110
|
-
if (this.
|
|
111
|
-
this.
|
|
110
|
+
if (this.localSpu && this.localSku && this.localSpu.length > 0 && this.localSku.length > 0) {
|
|
111
|
+
this.localSpu.map((item) => {
|
|
112
112
|
this.selectArr.push('');
|
|
113
113
|
this.subIndex.push(-1);
|
|
114
114
|
});
|
|
@@ -141,29 +141,29 @@ export default {
|
|
|
141
141
|
//循环所有属性判断哪些属性可选
|
|
142
142
|
//当前选中的兄弟节点和已选中属性不需要循环
|
|
143
143
|
|
|
144
|
-
for (let i = 0, len = this.
|
|
144
|
+
for (let i = 0, len = this.localSpu.length; i < len; i++) {
|
|
145
145
|
if (i == clickIndex) {
|
|
146
146
|
continue;
|
|
147
147
|
}
|
|
148
|
-
let len2 = this.
|
|
148
|
+
let len2 = this.localSpu[i].items.length;
|
|
149
149
|
for (let j = 0; j < len2; j++) {
|
|
150
150
|
if (this.subIndex[i] != -1 && j == this.subIndex[i]) {
|
|
151
151
|
continue;
|
|
152
152
|
}
|
|
153
153
|
let choosed_copy = [...this.selectArr];
|
|
154
|
-
this.$set(choosed_copy, i, this.
|
|
154
|
+
this.$set(choosed_copy, i, this.localSpu[i].items[j].name);
|
|
155
155
|
let choosed_copy2 = choosed_copy.filter((item) => item !== '' && typeof item !== 'undefined');
|
|
156
156
|
if (this.shopItemInfo.hasOwnProperty(choosed_copy2)) {
|
|
157
|
-
this.$set(this.
|
|
157
|
+
this.$set(this.localSpu[i].items[j], 'ishow', true);
|
|
158
158
|
} else {
|
|
159
|
-
this.$set(this.
|
|
159
|
+
this.$set(this.localSpu[i].items[j], 'ishow', false);
|
|
160
160
|
}
|
|
161
161
|
}
|
|
162
162
|
}
|
|
163
163
|
},
|
|
164
164
|
checkItem() {
|
|
165
165
|
//计算可选路径
|
|
166
|
-
let result = this.
|
|
166
|
+
let result = this.localSku.reduce(
|
|
167
167
|
(arrs, items) => {
|
|
168
168
|
return arrs.concat(
|
|
169
169
|
items.sku.reduce(
|
|
@@ -0,0 +1,96 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<view class="cv-tabs-box">
|
|
3
|
+
<scroll-view scroll-with-animation class="cv-tabs-box__scroll-view" :scroll-x="scrollX" :show-scrollbar="showScrollbar">
|
|
4
|
+
<view style="display: flex">
|
|
5
|
+
<slot />
|
|
6
|
+
</view>
|
|
7
|
+
</scroll-view>
|
|
8
|
+
</view>
|
|
9
|
+
</template>
|
|
10
|
+
<script>
|
|
11
|
+
export default {
|
|
12
|
+
name: 'cvTabsBox',
|
|
13
|
+
props: {
|
|
14
|
+
value: {
|
|
15
|
+
type: [Number, String],
|
|
16
|
+
default: ''
|
|
17
|
+
},
|
|
18
|
+
modelValue: {
|
|
19
|
+
type: [Number, String],
|
|
20
|
+
default: ''
|
|
21
|
+
},
|
|
22
|
+
scrollX: {
|
|
23
|
+
type: [Boolean],
|
|
24
|
+
default: true
|
|
25
|
+
},
|
|
26
|
+
showScrollbar: {
|
|
27
|
+
type: [Boolean],
|
|
28
|
+
default: false
|
|
29
|
+
},
|
|
30
|
+
tabClick: {
|
|
31
|
+
type: [Function],
|
|
32
|
+
default: () => {}
|
|
33
|
+
}
|
|
34
|
+
},
|
|
35
|
+
watch: {
|
|
36
|
+
value(newVal) {
|
|
37
|
+
this.localVal = newVal;
|
|
38
|
+
},
|
|
39
|
+
modelValue(newVal) {
|
|
40
|
+
this.localVal = newVal;
|
|
41
|
+
}
|
|
42
|
+
},
|
|
43
|
+
data() {
|
|
44
|
+
return {
|
|
45
|
+
localVal: 0
|
|
46
|
+
};
|
|
47
|
+
},
|
|
48
|
+
created() {
|
|
49
|
+
this.localVal = this.doValueGet();
|
|
50
|
+
// console.log('create', this.localVal, typeof this.localVal);
|
|
51
|
+
},
|
|
52
|
+
methods: {
|
|
53
|
+
doValueGet() {
|
|
54
|
+
if (this.value === '') return this.modelValue;
|
|
55
|
+
if (this.modelValue === '') return this.value;
|
|
56
|
+
return this.value;
|
|
57
|
+
},
|
|
58
|
+
handleClick(itemData) {
|
|
59
|
+
this.localVal = (itemData.name || '').toString();
|
|
60
|
+
// console.log('----handleClick', itemData);
|
|
61
|
+
// console.log('----handleClick2', this.localVal, typeof this.localVal);
|
|
62
|
+
this.$emit('tabClick', itemData);
|
|
63
|
+
this.$emit('input', this.localVal);
|
|
64
|
+
this.$emit('update:modelValue', this.localVal);
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
</script>
|
|
69
|
+
<style>
|
|
70
|
+
.cv-tabs-box {
|
|
71
|
+
flex: 1;
|
|
72
|
+
flex-direction: column;
|
|
73
|
+
overflow: hidden;
|
|
74
|
+
background-color: #fafafa;
|
|
75
|
+
/* #ifdef MP-ALIPAY || MP-BAIDU */
|
|
76
|
+
height: 100vh;
|
|
77
|
+
/* #endif */
|
|
78
|
+
}
|
|
79
|
+
.cv-tabs-box__scroll-view {
|
|
80
|
+
width: 750rpx;
|
|
81
|
+
height: 80rpx;
|
|
82
|
+
background-color: #ffffff;
|
|
83
|
+
flex-direction: row;
|
|
84
|
+
/* #ifndef APP-PLUS */
|
|
85
|
+
white-space: nowrap;
|
|
86
|
+
/* #endif */
|
|
87
|
+
/* #ifdef H5 */
|
|
88
|
+
position: fixed;
|
|
89
|
+
top: 44px;
|
|
90
|
+
left: 0;
|
|
91
|
+
z-index: 999;
|
|
92
|
+
/* #endif */
|
|
93
|
+
position: unset;
|
|
94
|
+
border-bottom: 1px solid #f8f8f8;
|
|
95
|
+
}
|
|
96
|
+
</style>
|
|
@@ -0,0 +1,82 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<view @click="tabItemClick" :key="name">
|
|
3
|
+
<view class="cv-tab-item-title" :class="{ 'cv-tab-item-active': currName == name }">
|
|
4
|
+
<slot>{{ label }}</slot>
|
|
5
|
+
</view>
|
|
6
|
+
</view>
|
|
7
|
+
</template>
|
|
8
|
+
<script>
|
|
9
|
+
export default {
|
|
10
|
+
name: 'cvTabsItem',
|
|
11
|
+
props: {
|
|
12
|
+
label: {
|
|
13
|
+
type: [Number, String],
|
|
14
|
+
default: ''
|
|
15
|
+
},
|
|
16
|
+
name: {
|
|
17
|
+
type: [Number, String],
|
|
18
|
+
default: ''
|
|
19
|
+
}
|
|
20
|
+
},
|
|
21
|
+
data() {
|
|
22
|
+
return {
|
|
23
|
+
currName: '',
|
|
24
|
+
parentObj: null
|
|
25
|
+
};
|
|
26
|
+
},
|
|
27
|
+
watch: {
|
|
28
|
+
'parentObj.localVal'(newVal) {
|
|
29
|
+
// console.log('parentObj.localVal', newVal);
|
|
30
|
+
this.currName = (newVal || '').toString();
|
|
31
|
+
}
|
|
32
|
+
},
|
|
33
|
+
created() {},
|
|
34
|
+
mounted() {
|
|
35
|
+
this.parentObj = this.getParent();
|
|
36
|
+
this.currName = this.parentObj.localVal || '';
|
|
37
|
+
},
|
|
38
|
+
methods: {
|
|
39
|
+
/**
|
|
40
|
+
* 获取父元素实例
|
|
41
|
+
*/
|
|
42
|
+
getParent(name = 'cvTabsBox') {
|
|
43
|
+
let parent = this.$parent;
|
|
44
|
+
let parentName = parent.$options.name;
|
|
45
|
+
while (parentName !== name) {
|
|
46
|
+
parent = parent.$parent;
|
|
47
|
+
if (!parent) return false;
|
|
48
|
+
parentName = parent.$options.name;
|
|
49
|
+
}
|
|
50
|
+
return parent;
|
|
51
|
+
},
|
|
52
|
+
tabItemClick() {
|
|
53
|
+
this.parentObj.handleClick({
|
|
54
|
+
label: (this.label || '').toString(),
|
|
55
|
+
name: (this.name || '').toString()
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
};
|
|
60
|
+
</script>
|
|
61
|
+
<style>
|
|
62
|
+
.cv-tab-item-title {
|
|
63
|
+
color: #555;
|
|
64
|
+
font-size: 15px;
|
|
65
|
+
height: 40px;
|
|
66
|
+
line-height: 40px;
|
|
67
|
+
flex-wrap: nowrap;
|
|
68
|
+
/* #ifndef APP-PLUS */
|
|
69
|
+
white-space: nowrap;
|
|
70
|
+
/* #endif */
|
|
71
|
+
margin-left: 30px;
|
|
72
|
+
}
|
|
73
|
+
|
|
74
|
+
.cv-tab-item-active {
|
|
75
|
+
border-bottom: 1px solid #e10a07;
|
|
76
|
+
color: #e10a07;
|
|
77
|
+
font-size: 16px;
|
|
78
|
+
font-weight: bold;
|
|
79
|
+
border-bottom-width: 3px;
|
|
80
|
+
text-align: center;
|
|
81
|
+
}
|
|
82
|
+
</style>
|
|
@@ -136,7 +136,7 @@ export default {
|
|
|
136
136
|
return {};
|
|
137
137
|
}
|
|
138
138
|
},
|
|
139
|
-
|
|
139
|
+
apiFunc: {
|
|
140
140
|
type: Function,
|
|
141
141
|
default: null
|
|
142
142
|
},
|
|
@@ -297,7 +297,7 @@ export default {
|
|
|
297
297
|
);
|
|
298
298
|
|
|
299
299
|
//将本地资源上传到开发者服务器,客户端发起一个 POST 请求,其中 content-type 为 multipart/form-data。
|
|
300
|
-
this.
|
|
300
|
+
this.apiFunc({
|
|
301
301
|
//要上传文件资源的路径。
|
|
302
302
|
filePath: tempFilePaths,
|
|
303
303
|
//文件对应的 key , 开发者在服务器端通过这个 key 可以获取到文件二进制内容
|
|
@@ -346,7 +346,7 @@ export default {
|
|
|
346
346
|
});
|
|
347
347
|
},
|
|
348
348
|
imgChoose() {
|
|
349
|
-
if (!this.
|
|
349
|
+
if (!this.apiFunc) {
|
|
350
350
|
this._currShowToast('上传方法错误');
|
|
351
351
|
return;
|
|
352
352
|
}
|