You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
325 lines
9.9 KiB
325 lines
9.9 KiB
10 months ago
|
<template>
|
||
|
<view>
|
||
|
<button
|
||
|
:id="id || buttonId"
|
||
|
:data-detail="dataset"
|
||
|
:class="
|
||
|
'custom-class ' +
|
||
|
utils.bem('button', [type, size, { block, round, plain, square, loading, disabled, hairline, unclickable: disabled || loading }]) +
|
||
|
' ' +
|
||
|
(hairline ? 'van-hairline--surround' : '')
|
||
|
"
|
||
|
:hover-class="disabled || loading ? '' : 'van-button--active hover-class'"
|
||
|
:lang="lang"
|
||
|
:form-type="formType"
|
||
|
:style="computed.rootStyle({ plain, color, customStyle })"
|
||
|
:open-type="disabled || loading || (canIUseGetUserProfile && openType === 'getUserInfo') ? '' : openType"
|
||
|
:business-id="businessId"
|
||
|
:session-from="sessionFrom"
|
||
|
:send-message-title="sendMessageTitle"
|
||
|
:send-message-path="sendMessagePath"
|
||
|
:send-message-img="sendMessageImg"
|
||
|
:show-message-card="showMessageCard"
|
||
|
:app-parameter="appParameter"
|
||
|
:aria-label="ariaLabel"
|
||
|
@tap="parseEventDynamicCode($event, disabled || loading ? '' : 'onClick')"
|
||
|
@getuserinfo="onGetUserInfo"
|
||
|
@contact="onContact"
|
||
|
@getphonenumber="onGetPhoneNumber"
|
||
|
@getrealtimephonenumber="onGetRealTimePhoneNumber"
|
||
|
@agreeprivacyauthorization="onAgreePrivacyAuthorization"
|
||
|
@error="onError"
|
||
|
@launchapp="onLaunchApp"
|
||
|
@opensetting="onOpenSetting"
|
||
|
@chooseavatar="onChooseAvatar"
|
||
|
>
|
||
|
<block v-if="loading">
|
||
|
<van-loading custom-class="loading-class" :size="loadingSize" :type="loadingType" :color="computed.loadingColor({ type, color, plain })" />
|
||
|
<view v-if="loadingText" class="van-button__loading-text">
|
||
|
{{ loadingText }}
|
||
|
</view>
|
||
|
</block>
|
||
|
<block v-else>
|
||
|
<van-icon v-if="icon" size="1.2em" :name="icon" :class-prefix="classPrefix" class="van-button__icon" custom-style="line-height: inherit;" />
|
||
|
<view class="van-button__text">
|
||
|
<slot />
|
||
|
</view>
|
||
|
</block>
|
||
|
</button>
|
||
|
</view>
|
||
|
</template>
|
||
|
<script module="utils" lang="wxs" src="@/miniprogram_npm/@vant/weapp/wxs/utils.wxs"></script>
|
||
|
<script module="computed" lang="wxs" src="@/miniprogram_npm/@vant/weapp/button/index.wxs"></script>
|
||
|
<script>
|
||
|
'use strict';
|
||
|
Object.defineProperty(exports, '__esModule', {
|
||
|
value: true
|
||
|
});
|
||
|
var component_1 = require('../common/component');
|
||
|
var button_1 = require('../mixins/button');
|
||
|
var version_1 = require('../common/version');
|
||
|
var mixins = [button_1.button];
|
||
|
if ((0, version_1.canIUseFormFieldButton)()) {
|
||
|
mixins.push('wx://form-field-button');
|
||
|
}
|
||
|
export default {
|
||
|
data() {
|
||
|
return {
|
||
|
baseStyle: '',
|
||
|
id: '',
|
||
|
buttonId: '',
|
||
|
lang: '',
|
||
|
canIUseGetUserProfile: '',
|
||
|
openType: '',
|
||
|
businessId: '',
|
||
|
sessionFrom: '',
|
||
|
sendMessageTitle: '',
|
||
|
sendMessagePath: '',
|
||
|
sendMessageImg: '',
|
||
|
showMessageCard: '',
|
||
|
appParameter: '',
|
||
|
ariaLabel: ''
|
||
|
};
|
||
|
},
|
||
|
mixins: mixins,
|
||
|
classes: ['hover-class', 'loading-class'],
|
||
|
props: {
|
||
|
formType: String,
|
||
|
icon: String,
|
||
|
classPrefix: {
|
||
|
type: String,
|
||
|
default: 'van-icon'
|
||
|
},
|
||
|
plain: Boolean,
|
||
|
block: Boolean,
|
||
|
round: Boolean,
|
||
|
square: Boolean,
|
||
|
loading: Boolean,
|
||
|
hairline: Boolean,
|
||
|
disabled: Boolean,
|
||
|
loadingText: String,
|
||
|
customStyle: String,
|
||
|
loadingType: {
|
||
|
type: String,
|
||
|
default: 'circular'
|
||
|
},
|
||
|
type: {
|
||
|
type: String,
|
||
|
default: 'default'
|
||
|
},
|
||
|
dataset: null,
|
||
|
size: {
|
||
|
type: String,
|
||
|
default: 'normal'
|
||
|
},
|
||
|
loadingSize: {
|
||
|
type: String,
|
||
|
default: '20px'
|
||
|
},
|
||
|
color: String
|
||
|
},
|
||
|
methods: {
|
||
|
onClick: function (event) {
|
||
|
var that = this;
|
||
|
this.$emit('click', event);
|
||
|
var _a = this;
|
||
|
var canIUseGetUserProfile = _a.canIUseGetUserProfile;
|
||
|
var openType = _a.openType;
|
||
|
var getUserProfileDesc = _a.getUserProfileDesc;
|
||
|
var lang = _a.lang;
|
||
|
if (openType === 'getUserInfo' && canIUseGetUserProfile) {
|
||
|
uni.getUserProfile({
|
||
|
desc: getUserProfileDesc || ' ',
|
||
|
lang: lang || 'en',
|
||
|
complete: function (userProfile) {
|
||
|
that.$emit('getuserinfo', userProfile);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
},
|
||
|
|
||
|
onGetUserInfo() {
|
||
|
console.log('占位:函数 onGetUserInfo 未声明');
|
||
|
},
|
||
|
|
||
|
onContact() {
|
||
|
console.log('占位:函数 onContact 未声明');
|
||
|
},
|
||
|
|
||
|
onGetPhoneNumber() {
|
||
|
console.log('占位:函数 onGetPhoneNumber 未声明');
|
||
|
},
|
||
|
|
||
|
onGetRealTimePhoneNumber() {
|
||
|
console.log('占位:函数 onGetRealTimePhoneNumber 未声明');
|
||
|
},
|
||
|
|
||
|
onAgreePrivacyAuthorization() {
|
||
|
console.log('占位:函数 onAgreePrivacyAuthorization 未声明');
|
||
|
},
|
||
|
|
||
|
onError() {
|
||
|
console.log('占位:函数 onError 未声明');
|
||
|
},
|
||
|
|
||
|
onLaunchApp() {
|
||
|
console.log('占位:函数 onLaunchApp 未声明');
|
||
|
},
|
||
|
|
||
|
onOpenSetting() {
|
||
|
console.log('占位:函数 onOpenSetting 未声明');
|
||
|
},
|
||
|
|
||
|
onChooseAvatar() {
|
||
|
console.log('占位:函数 onChooseAvatar 未声明');
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
</script>
|
||
|
<style>
|
||
|
@import '../common/index.css';
|
||
|
.van-button {
|
||
|
-webkit-text-size-adjust: 100%;
|
||
|
align-items: center;
|
||
|
-webkit-appearance: none;
|
||
|
border-radius: var(--button-border-radius, 2px);
|
||
|
box-sizing: border-box;
|
||
|
display: inline-flex;
|
||
|
font-size: var(--button-default-font-size, 16px);
|
||
|
height: var(--button-default-height, 44px);
|
||
|
justify-content: center;
|
||
|
line-height: var(--button-line-height, 20px);
|
||
|
padding: 0;
|
||
|
position: relative;
|
||
|
text-align: center;
|
||
|
transition: opacity 0.2s;
|
||
|
vertical-align: middle;
|
||
|
}
|
||
|
.van-button:before {
|
||
|
background-color: #000;
|
||
|
border: inherit;
|
||
|
border-color: #000;
|
||
|
border-radius: inherit;
|
||
|
content: ' ';
|
||
|
height: 100%;
|
||
|
left: 50%;
|
||
|
opacity: 0;
|
||
|
position: absolute;
|
||
|
top: 50%;
|
||
|
transform: translate(-50%, -50%);
|
||
|
width: 100%;
|
||
|
}
|
||
|
.van-button:after {
|
||
|
border-width: 0;
|
||
|
}
|
||
|
.van-button--active:before {
|
||
|
opacity: 0.15;
|
||
|
}
|
||
|
.van-button--unclickable:after {
|
||
|
display: none;
|
||
|
}
|
||
|
.van-button--default {
|
||
|
background: var(--button-default-background-color, #fff);
|
||
|
border: var(--button-border-width, 1px) solid var(--button-default-border-color, #ebedf0);
|
||
|
color: var(--button-default-color, #323233);
|
||
|
}
|
||
|
.van-button--primary {
|
||
|
background: var(--button-primary-background-color, #07c160);
|
||
|
border: var(--button-border-width, 1px) solid var(--button-primary-border-color, #07c160);
|
||
|
color: var(--button-primary-color, #fff);
|
||
|
}
|
||
|
.van-button--info {
|
||
|
background: var(--button-info-background-color, #1989fa);
|
||
|
border: var(--button-border-width, 1px) solid var(--button-info-border-color, #1989fa);
|
||
|
color: var(--button-info-color, #fff);
|
||
|
}
|
||
|
.van-button--danger {
|
||
|
background: var(--button-danger-background-color, #ee0a24);
|
||
|
border: var(--button-border-width, 1px) solid var(--button-danger-border-color, #ee0a24);
|
||
|
color: var(--button-danger-color, #fff);
|
||
|
}
|
||
|
.van-button--warning {
|
||
|
background: var(--button-warning-background-color, #ff976a);
|
||
|
border: var(--button-border-width, 1px) solid var(--button-warning-border-color, #ff976a);
|
||
|
color: var(--button-warning-color, #fff);
|
||
|
}
|
||
|
.van-button--plain {
|
||
|
background: var(--button-plain-background-color, #fff);
|
||
|
}
|
||
|
.van-button--plain.van-button--primary {
|
||
|
color: var(--button-primary-background-color, #07c160);
|
||
|
}
|
||
|
.van-button--plain.van-button--info {
|
||
|
color: var(--button-info-background-color, #1989fa);
|
||
|
}
|
||
|
.van-button--plain.van-button--danger {
|
||
|
color: var(--button-danger-background-color, #ee0a24);
|
||
|
}
|
||
|
.van-button--plain.van-button--warning {
|
||
|
color: var(--button-warning-background-color, #ff976a);
|
||
|
}
|
||
|
.van-button--large {
|
||
|
height: var(--button-large-height, 50px);
|
||
|
width: 100%;
|
||
|
}
|
||
|
.van-button--normal {
|
||
|
font-size: var(--button-normal-font-size, 14px);
|
||
|
padding: 0 15px;
|
||
|
}
|
||
|
.van-button--small {
|
||
|
font-size: var(--button-small-font-size, 12px);
|
||
|
height: var(--button-small-height, 30px);
|
||
|
min-width: var(--button-small-min-width, 60px);
|
||
|
padding: 0 var(--padding-xs, 8px);
|
||
|
}
|
||
|
.van-button--mini {
|
||
|
display: inline-block;
|
||
|
font-size: var(--button-mini-font-size, 10px);
|
||
|
height: var(--button-mini-height, 22px);
|
||
|
min-width: var(--button-mini-min-width, 50px);
|
||
|
}
|
||
|
.van-button--mini + .van-button--mini {
|
||
|
margin-left: 5px;
|
||
|
}
|
||
|
.van-button--block {
|
||
|
display: flex;
|
||
|
width: 100%;
|
||
|
}
|
||
|
.van-button--round {
|
||
|
border-radius: var(--button-round-border-radius, 999px);
|
||
|
}
|
||
|
.van-button--square {
|
||
|
border-radius: 0;
|
||
|
}
|
||
|
.van-button--disabled {
|
||
|
opacity: var(--button-disabled-opacity, 0.5);
|
||
|
}
|
||
|
.van-button__text {
|
||
|
display: inline;
|
||
|
}
|
||
|
.van-button__icon + .van-button__text:not(:empty),
|
||
|
.van-button__loading-text {
|
||
|
margin-left: 4px;
|
||
|
}
|
||
|
.van-button__icon {
|
||
|
line-height: inherit !important;
|
||
|
min-width: 1em;
|
||
|
vertical-align: top;
|
||
|
}
|
||
|
.van-button--hairline {
|
||
|
border-width: 0;
|
||
|
padding-top: 1px;
|
||
|
}
|
||
|
.van-button--hairline:after {
|
||
|
border-color: inherit;
|
||
|
border-radius: calc(var(--button-border-radius, 2px) * 2);
|
||
|
border-width: 1px;
|
||
|
}
|
||
|
.van-button--hairline.van-button--round:after {
|
||
|
border-radius: var(--button-round-border-radius, 999px);
|
||
|
}
|
||
|
.van-button--hairline.van-button--square:after {
|
||
|
border-radius: 0;
|
||
|
}
|
||
|
</style>
|