u-text.vue
7.2 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
<template>
<view
class="u-text"
:class="[]"
v-if="show"
:style="{
margin: margin,
justifyContent: align === 'left' ? 'flex-start' : align === 'center' ? 'center' : 'flex-end'
}"
@tap="clickHandler"
>
<text
:class="['u-text__price', type && `u-text__value--${type}`]"
v-if="mode === 'price'"
:style="[valueStyle]"
>¥</text
>
<view class="u-text__prefix-icon" v-if="prefixIcon">
<u-icon
:name="prefixIcon"
:customStyle="$u.addStyle(iconStyle)"
></u-icon>
</view>
<u-link
v-if="mode === 'link'"
:text="value"
:href="href"
underLine
></u-link>
<template v-else-if="openType && isMp">
<button
class="u-reset-button u-text__value"
:style="[valueStyle]"
:data-index="index"
:openType="openType"
@getuserinfo="onGetUserInfo"
@contact="onContact"
@getphonenumber="onGetPhoneNumber"
@error="onError"
@launchapp="onLaunchApp"
@opensetting="onOpenSetting"
:lang="lang"
:session-from="sessionFrom"
:send-message-title="sendMessageTitle"
:send-message-path="sendMessagePath"
:send-message-img="sendMessageImg"
:show-message-card="showMessageCard"
:app-parameter="appParameter"
>
{{ value }}
</button>
</template>
<text
v-else
class="u-text__value"
:style="[valueStyle]"
:class="[
type && `u-text__value--${type}`,
lines && `u-line-${lines}`
]"
>{{ value }}</text
>
<view class="u-text__suffix-icon" v-if="suffixIcon">
<u-icon
:name="suffixIcon"
:customStyle="$u.addStyle(iconStyle)"
></u-icon>
</view>
</view>
</template>
<script>
import value from './value.js'
import mpMixin from '../../libs/mixin/mpMixin.js';
import mixin from '../../libs/mixin/mixin.js';
import button from '../../libs/mixin/button.js'
import openType from '../../libs/mixin/openType.js'
import props from './props.js'
/**
* Text 文本
* @description 此组件集成了文本类在项目中的常用功能,包括状态,拨打电话,格式化日期,*替换,超链接...等功能。 您大可不必在使用特殊文本时自己定义,text组件几乎涵盖您能使用的大部分场景。
* @tutorial https://ijry.github.io/uview-plus/components/loading.html
* @property {String} type 主题颜色
* @property {Boolean} show 是否显示(默认 true )
* @property {String | Number} text 显示的值
* @property {String} prefixIcon 前置图标
* @property {String} suffixIcon 后置图标
* @property {String} mode 文本处理的匹配模式 text-普通文本,price-价格,phone-手机号,name-姓名,date-日期,link-超链接
* @property {String} href mode=link下,配置的链接
* @property {String | Function} format 格式化规则
* @property {Boolean} call mode=phone时,点击文本是否拨打电话(默认 false )
* @property {String} openType 小程序的打开方式
* @property {Boolean} bold 是否粗体,默认normal(默认 false )
* @property {Boolean} block 是否块状(默认 false )
* @property {String | Number} lines 文本显示的行数,如果设置,超出此行数,将会显示省略号
* @property {String} color 文本颜色(默认 '#303133' )
* @property {String | Number} size 字体大小(默认 15 )
* @property {Object | String} iconStyle 图标的样式 (默认 {fontSize: '15px'} )
* @property {String} decoration 文字装饰,下划线,中划线等,可选值 none|underline|line-through(默认 'none' )
* @property {Object | String | Number} margin 外边距,对象、字符串,数值形式均可(默认 0 )
* @property {String | Number} lineHeight 文本行高
* @property {String} align 文本对齐方式,可选值left|center|right(默认 'left' )
* @property {String} wordWrap 文字换行,可选值break-word|normal|anywhere(默认 'normal' )
* @event {Function} click 点击触发事件
* @example <u--text text="我用十年青春,赴你最后之约"></u--text>
*/
export default {
name: 'u--text',
// #ifdef MP
mixins: [mpMixin, mixin, value, button, openType, props],
// #endif
// #ifndef MP
mixins: [mpMixin, mixin, value, props],
// #endif
emits: ['click'],
computed: {
valueStyle() {
const style = {
textDecoration: this.decoration,
fontWeight: this.bold ? 'bold' : 'normal',
wordWrap: this.wordWrap,
fontSize: uni.$u.addUnit(this.size)
}
!this.type && (style.color = this.color)
this.isNvue && this.lines && (style.lines = this.lines)
this.lineHeight &&
(style.lineHeight = uni.$u.addUnit(this.lineHeight))
!this.isNvue && this.block && (style.display = 'block')
return uni.$u.deepMerge(style, uni.$u.addStyle(this.customStyle))
},
isNvue() {
let nvue = false
// #ifdef APP-NVUE
nvue = true
// #endif
return nvue
},
isMp() {
let mp = false
// #ifdef MP
mp = true
// #endif
return mp
}
},
data() {
return {}
},
methods: {
clickHandler() {
// 如果为手机号模式,拨打电话
if (this.call && this.mode === 'phone') {
uni.makePhoneCall({
phoneNumber: this.text
})
}
this.$emit('click')
}
}
}
</script>
<style lang="scss" scoped>
@import '../../libs/css/components.scss';
.u-text {
@include flex(row);
align-items: center;
flex-wrap: nowrap;
flex: 1;
/* #ifndef APP-NVUE */
width: 100%;
/* #endif */
&__price {
font-size: 14px;
color: $u-content-color;
}
&__value {
font-size: 14px;
@include flex;
color: $u-content-color;
flex-wrap: wrap;
// flex: 1;
text-overflow: ellipsis;
align-items: center;
&--primary {
color: $u-primary;
}
&--warning {
color: $u-warning;
}
&--success {
color: $u-success;
}
&--info {
color: $u-info;
}
&--error {
color: $u-error;
}
&--main {
color: $u-main-color;
}
&--content {
color: $u-content-color;
}
&--tips {
color: $u-tips-color;
}
&--light {
color: $u-light-color;
}
}
}
</style>