城阳工作端uniH5前端代码
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.
 
 

324 lines
9.9 KiB

<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>