lxui-uni 0.0.8 → 0.1.0

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.
@@ -1,92 +1,92 @@
1
- <script lang="ts" setup>
2
- /** * 传参说明
3
- * @param imgUrl 默认图
4
- * @param imgIsShow 默认图是否展示
5
- * @param tips 默认提示语
6
- * */
7
- defineProps({
8
- // 分页加载数据有无下一页
9
- isNoData: {
10
- type: Boolean,
11
- default: false
12
- },
13
- // 正在加载中
14
- isLoading: {
15
- type: Boolean,
16
- default: false
17
- },
18
- // 暂无数据
19
- isEmpty: {
20
- type: Boolean,
21
- default: false
22
- },
23
- // 暂无数据使用
24
- imgUrl: {
25
- type: String,
26
- default: ''
27
- },
28
- imgIsShow: {
29
- type: Boolean,
30
- default: true
31
- },
32
- tips: {
33
- type: String,
34
- default: '暂无数据~'
35
- }
36
- })
37
- </script>
38
-
39
- <template>
40
- <view class="list_state_box">
41
- <view class="flex empty column" v-if="isEmpty">
42
- <slot>
43
- <view class="img" v-if="imgIsShow">
44
- <image :src="imgUrl" mode="widthFix"></image>
45
- </view>
46
- </slot>
47
- <view class="txt">
48
- {{ tips }}
49
- </view>
50
- </view>
51
- <view class="list_state" v-else>
52
- <view class="txt" v-if="isLoading">正在努力加载更多~</view>
53
- <view class="txt" v-else-if="isNoData && isNoData == true">已加载全部~</view>
54
- <view class="txt" v-if="!isLoading && !isNoData">上拉加载更多~</view>
55
- </view>
56
- </view>
57
- </template>
58
- <style lang="scss">
59
- .list_state_box {
60
- .list_state {
61
- margin: 30rpx 0;
62
-
63
- .txt {
64
- text-align: center;
65
- color: #666;
66
- margin: 10rpx 0;
67
- font-size: 28rpx;
68
- }
69
- }
70
-
71
- .empty {
72
- min-height: 60vh;
73
- .txt {
74
- font-size: 26rpx;
75
- color: #666;
76
- text-align: center;
77
- }
78
-
79
- .img {
80
- width: 70%;
81
- // max-height: 300rpx;
82
- margin: 0 auto;
83
- text-align: center;
84
-
85
- image {
86
- width: 100%;
87
- // height: 100%;
88
- }
89
- }
90
- }
91
- }
92
- </style>
1
+ <script lang="ts" setup>
2
+ /** * 传参说明
3
+ * @param imgUrl 默认图
4
+ * @param imgIsShow 默认图是否展示
5
+ * @param tips 默认提示语
6
+ * */
7
+ defineProps({
8
+ // 分页加载数据有无下一页
9
+ isNoData: {
10
+ type: Boolean,
11
+ default: false
12
+ },
13
+ // 正在加载中
14
+ isLoading: {
15
+ type: Boolean,
16
+ default: false
17
+ },
18
+ // 暂无数据
19
+ isEmpty: {
20
+ type: Boolean,
21
+ default: false
22
+ },
23
+ // 暂无数据使用
24
+ imgUrl: {
25
+ type: String,
26
+ default: ''
27
+ },
28
+ imgIsShow: {
29
+ type: Boolean,
30
+ default: true
31
+ },
32
+ tips: {
33
+ type: String,
34
+ default: '暂无数据~'
35
+ }
36
+ })
37
+ </script>
38
+
39
+ <template>
40
+ <view class="list_state_box">
41
+ <view class="flex empty column" v-if="isEmpty">
42
+ <slot>
43
+ <view class="img" v-if="imgIsShow">
44
+ <image :src="imgUrl" mode="widthFix"></image>
45
+ </view>
46
+ </slot>
47
+ <view class="txt">
48
+ {{ tips }}
49
+ </view>
50
+ </view>
51
+ <view class="list_state" v-else>
52
+ <view class="txt" v-if="isLoading">正在努力加载更多~</view>
53
+ <view class="txt" v-else-if="isNoData && isNoData == true">已加载全部~</view>
54
+ <view class="txt" v-if="!isLoading && !isNoData">上拉加载更多~</view>
55
+ </view>
56
+ </view>
57
+ </template>
58
+ <style lang="scss">
59
+ .list_state_box {
60
+ .list_state {
61
+ margin: 30rpx 0;
62
+
63
+ .txt {
64
+ text-align: center;
65
+ color: #666;
66
+ margin: 10rpx 0;
67
+ font-size: 28rpx;
68
+ }
69
+ }
70
+
71
+ .empty {
72
+ min-height: 60vh;
73
+ .txt {
74
+ font-size: 26rpx;
75
+ color: #666;
76
+ text-align: center;
77
+ }
78
+
79
+ .img {
80
+ width: 70%;
81
+ // max-height: 300rpx;
82
+ margin: 0 auto;
83
+ text-align: center;
84
+
85
+ image {
86
+ width: 100%;
87
+ // height: 100%;
88
+ }
89
+ }
90
+ }
91
+ }
92
+ </style>
@@ -1,116 +1,116 @@
1
- <script setup lang="ts">
2
- /*
3
- * @description: 底部安全距离盒子
4
- * @fileName: lx-safety-bottom.vue
5
- * @params
6
- * @author: lxx
7
- * @date: 2024-02-26 11:24:59"
8
- * @version: V1.0.0
9
- */
10
- interface PropsInt {
11
- tipType: 'price' | 'discount' | 'custom'
12
- customTxt?: string
13
- rightConfirmTxt?: string
14
- rightCancelTxt?: string
15
- discount?: string | number
16
- amount?: string | number
17
- tip?: string
18
- }
19
- withDefaults(defineProps<PropsInt>(), {
20
- customTxt: '',
21
- rightConfirmTxt: '',
22
- discount: '',
23
- amount: ''
24
- })
25
- const emit = defineEmits(['confirm', 'cancel'])
26
- const confirmClick = () => emit('confirm')
27
- const cancelClick = () => emit('cancel')
28
- </script>
29
- <template>
30
- <view class="lx_safety_bottom flex-center-between">
31
- <view class="bottom_left_box">
32
- <slot name="left">
33
- <view class="amount_box flex-center" v-if="tipType === 'price'">
34
- <view class="amount_tip">{{ tip }}</view>
35
- <view class="amount">¥{{ amount }}</view>
36
- <view class="discount" v-if="discount">¥{{ discount }}</view>
37
- </view>
38
- <view class="amount_box flex-center" v-if="tipType === 'discount'">
39
- <view class="amount">¥{{ amount }}</view>
40
- <view class="discount">¥{{ discount }}</view>
41
- </view>
42
- <view v-if="tipType === 'custom' && customTxt" class="left_txt text-ellipsis">{{ customTxt }}</view>
43
- </slot>
44
- </view>
45
- <view class="bottom_right_box">
46
- <slot name="right">
47
- <view class="flex">
48
- <view class="cancel_btn" v-if="rightCancelTxt" @click="cancelClick">{{ rightCancelTxt }}</view>
49
- <view class="sub_btn" v-if="rightConfirmTxt" @click="confirmClick">{{ rightConfirmTxt }}</view>
50
- </view>
51
- </slot>
52
- </view>
53
- </view>
54
- <view class="lx_safety_bottom_mark"></view>
55
- </template>
56
- <style lang="scss" scoped>
57
- .lx_safety_bottom_mark {
58
- /* 兼容 iOS < 11.2 */
59
- padding-bottom: constant(safe-area-inset-bottom);
60
- /* 兼容 iOS >= 11.2 */
61
- padding-bottom: calc(env(safe-area-inset-bottom) + 6rpx);
62
- height: 100rpx;
63
- // box-sizing: border-box;
64
- }
65
- .lx_safety_bottom {
66
- position: fixed;
67
- left: 0;
68
- width: calc(100% - 72rpx);
69
- bottom: 0;
70
- /* 兼容 iOS < 11.2 */
71
- padding-bottom: constant(safe-area-inset-bottom);
72
- /* 兼容 iOS >= 11.2 */
73
- padding-bottom: calc(env(safe-area-inset-bottom) + 6rpx);
74
- // height: 100rpx;
75
- background-color: rgb(255, 255, 255);
76
- padding-left: 36rpx;
77
- padding-right: 36rpx;
78
- padding-top: 10rpx;
79
- // box-sizing: border-box;
80
- .bottom_left_box {
81
- // max-width: 70%;
82
- // 普通文本
83
- .left_txt {
84
- font-size: $font-size-36;
85
- font-weight: 600;
86
- color: $main-color;
87
- }
88
- // 金额+优惠金额
89
- .amount_box {
90
- font-size: $font-size-36;
91
- .amount_tip {
92
- color: #000;
93
- }
94
- .amount {
95
- font-weight: 600;
96
- color: $main-color;
97
- }
98
- .discount {
99
- padding-left: 30rpx;
100
- text-decoration-line: line-through;
101
- color: rgba(166, 166, 166, 1);
102
- }
103
- }
104
- }
105
- .bottom_right_box {
106
- .sub_btn {
107
- @include btn-solid;
108
- }
109
- .cancel_btn {
110
- @include btn-line;
111
- margin-right: 8rpx;
112
- border-radius: 8rpx;
113
- }
114
- }
115
- }
116
- </style>
1
+ <script setup lang="ts">
2
+ /*
3
+ * @description: 底部安全距离盒子
4
+ * @fileName: lx-safety-bottom.vue
5
+ * @params
6
+ * @author: lxx
7
+ * @date: 2024-02-26 11:24:59"
8
+ * @version: V1.0.0
9
+ */
10
+ interface PropsInt {
11
+ tipType: 'price' | 'discount' | 'custom'
12
+ customTxt?: string
13
+ rightConfirmTxt?: string
14
+ rightCancelTxt?: string
15
+ discount?: string | number
16
+ amount?: string | number
17
+ tip?: string
18
+ }
19
+ withDefaults(defineProps<PropsInt>(), {
20
+ customTxt: '',
21
+ rightConfirmTxt: '',
22
+ discount: '',
23
+ amount: ''
24
+ })
25
+ const emit = defineEmits(['confirm', 'cancel'])
26
+ const confirmClick = () => emit('confirm')
27
+ const cancelClick = () => emit('cancel')
28
+ </script>
29
+ <template>
30
+ <view class="lx_safety_bottom flex-center-between">
31
+ <view class="bottom_left_box">
32
+ <slot name="left">
33
+ <view class="amount_box flex-center" v-if="tipType === 'price'">
34
+ <view class="amount_tip">{{ tip }}</view>
35
+ <view class="amount">¥{{ amount }}</view>
36
+ <view class="discount" v-if="discount">¥{{ discount }}</view>
37
+ </view>
38
+ <view class="amount_box flex-center" v-if="tipType === 'discount'">
39
+ <view class="amount">¥{{ amount }}</view>
40
+ <view class="discount">¥{{ discount }}</view>
41
+ </view>
42
+ <view v-if="tipType === 'custom' && customTxt" class="left_txt text-ellipsis">{{ customTxt }}</view>
43
+ </slot>
44
+ </view>
45
+ <view class="bottom_right_box">
46
+ <slot name="right">
47
+ <view class="flex">
48
+ <view class="cancel_btn" v-if="rightCancelTxt" @click="cancelClick">{{ rightCancelTxt }}</view>
49
+ <view class="sub_btn" v-if="rightConfirmTxt" @click="confirmClick">{{ rightConfirmTxt }}</view>
50
+ </view>
51
+ </slot>
52
+ </view>
53
+ </view>
54
+ <view class="lx_safety_bottom_mark"></view>
55
+ </template>
56
+ <style lang="scss" scoped>
57
+ .lx_safety_bottom_mark {
58
+ /* 兼容 iOS < 11.2 */
59
+ padding-bottom: constant(safe-area-inset-bottom);
60
+ /* 兼容 iOS >= 11.2 */
61
+ padding-bottom: calc(env(safe-area-inset-bottom) + 6rpx);
62
+ height: 100rpx;
63
+ // box-sizing: border-box;
64
+ }
65
+ .lx_safety_bottom {
66
+ position: fixed;
67
+ left: 0;
68
+ width: calc(100% - 72rpx);
69
+ bottom: 0;
70
+ /* 兼容 iOS < 11.2 */
71
+ padding-bottom: constant(safe-area-inset-bottom);
72
+ /* 兼容 iOS >= 11.2 */
73
+ padding-bottom: calc(env(safe-area-inset-bottom) + 6rpx);
74
+ // height: 100rpx;
75
+ background-color: rgb(255, 255, 255);
76
+ padding-left: 36rpx;
77
+ padding-right: 36rpx;
78
+ padding-top: 10rpx;
79
+ // box-sizing: border-box;
80
+ .bottom_left_box {
81
+ // max-width: 70%;
82
+ // 普通文本
83
+ .left_txt {
84
+ font-size: $font-size-36;
85
+ font-weight: 600;
86
+ color: $main-color;
87
+ }
88
+ // 金额+优惠金额
89
+ .amount_box {
90
+ font-size: $font-size-36;
91
+ .amount_tip {
92
+ color: #000;
93
+ }
94
+ .amount {
95
+ font-weight: 600;
96
+ color: $main-color;
97
+ }
98
+ .discount {
99
+ padding-left: 30rpx;
100
+ text-decoration-line: line-through;
101
+ color: rgba(166, 166, 166, 1);
102
+ }
103
+ }
104
+ }
105
+ .bottom_right_box {
106
+ .sub_btn {
107
+ @include btn-solid;
108
+ }
109
+ .cancel_btn {
110
+ @include btn-line;
111
+ margin-right: 8rpx;
112
+ border-radius: 8rpx;
113
+ }
114
+ }
115
+ }
116
+ </style>
@@ -1,61 +1,61 @@
1
- <script setup lang="ts">
2
- /*
3
- * @description: 提交按钮组件
4
- * @fileName: lx-submit-btn.vue
5
- * @params
6
- * @author: lxx 2399270194@qq.com
7
- * @date: 2024-02-27 14:58:31"
8
- * @version: V1.0.0
9
- */
10
- interface PropsInt {
11
- text: string
12
- loading?: boolean
13
- }
14
- withDefaults(defineProps<PropsInt>(), {
15
- text: '提交',
16
- loading: false
17
- })
18
- const emit = defineEmits(['submit'])
19
- </script>
20
- <template>
21
- <view class="submit_btn_box">
22
- <button class="submit_btn" :loading="loading" @click="emit('submit')">{{ text }}</button>
23
- </view>
24
- <view class="submit_mark_box"></view>
25
- </template>
26
- <style lang="scss" scoped>
27
- .submit_mark_box {
28
- padding-bottom: constant(safe-area-inset-bottom);
29
- /* 兼容 iOS >= 11.2 */
30
- padding-bottom: env(safe-area-inset-bottom);
31
- padding-top: 10rpx;
32
- height: 92rpx;
33
- }
34
- .submit_btn_box {
35
- padding: 0 28rpx;
36
- /* 兼容 iOS < 11.2 */
37
- padding-bottom: constant(safe-area-inset-bottom);
38
- /* 兼容 iOS >= 11.2 */
39
- padding-bottom: env(safe-area-inset-bottom);
40
- padding-top: 10rpx;
41
- position: fixed;
42
- bottom: 10rpx;
43
- left: 50%;
44
- transform: translateX(-50%);
45
- width: 100%;
46
-
47
- .submit_btn {
48
- margin: 0 auto;
49
- width: 96%;
50
- box-sizing: border-box;
51
- border-radius: 8rpx;
52
- background: $main-color;
53
- font-size: $font-size-28;
54
- font-weight: 400;
55
- line-height: 92rpx;
56
- text-align: center;
57
- color: rgba(255, 255, 255, 1);
58
- height: 92rpx;
59
- }
60
- }
61
- </style>
1
+ <script setup lang="ts">
2
+ /*
3
+ * @description: 提交按钮组件
4
+ * @fileName: lx-submit-btn.vue
5
+ * @params
6
+ * @author: lxx 2399270194@qq.com
7
+ * @date: 2024-02-27 14:58:31"
8
+ * @version: V1.0.0
9
+ */
10
+ interface PropsInt {
11
+ text: string
12
+ loading?: boolean
13
+ }
14
+ withDefaults(defineProps<PropsInt>(), {
15
+ text: '提交',
16
+ loading: false
17
+ })
18
+ const emit = defineEmits(['submit'])
19
+ </script>
20
+ <template>
21
+ <view class="submit_btn_box">
22
+ <button class="submit_btn" :loading="loading" @click="emit('submit')">{{ text }}</button>
23
+ </view>
24
+ <view class="submit_mark_box"></view>
25
+ </template>
26
+ <style lang="scss" scoped>
27
+ .submit_mark_box {
28
+ padding-bottom: constant(safe-area-inset-bottom);
29
+ /* 兼容 iOS >= 11.2 */
30
+ padding-bottom: env(safe-area-inset-bottom);
31
+ padding-top: 10rpx;
32
+ height: 92rpx;
33
+ }
34
+ .submit_btn_box {
35
+ padding: 0 28rpx;
36
+ /* 兼容 iOS < 11.2 */
37
+ padding-bottom: constant(safe-area-inset-bottom);
38
+ /* 兼容 iOS >= 11.2 */
39
+ padding-bottom: env(safe-area-inset-bottom);
40
+ padding-top: 10rpx;
41
+ position: fixed;
42
+ bottom: 10rpx;
43
+ left: 50%;
44
+ transform: translateX(-50%);
45
+ width: 100%;
46
+
47
+ .submit_btn {
48
+ margin: 0 auto;
49
+ width: 96%;
50
+ box-sizing: border-box;
51
+ border-radius: 8rpx;
52
+ background: $main-color;
53
+ font-size: $font-size-28;
54
+ font-weight: 400;
55
+ line-height: 92rpx;
56
+ text-align: center;
57
+ color: rgba(255, 255, 255, 1);
58
+ height: 92rpx;
59
+ }
60
+ }
61
+ </style>