index.vue 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. <template>
  2. <uni-shadow-root class="vant-goods-action-icon-index"><van-button square :id="id" size="large" :lang="lang" :loading="loading" :disabled="disabled" :open-type="openType" :business-id="businessId" custom-class="van-goods-action-icon" :session-from="sessionFrom" :app-parameter="appParameter" :send-message-img="sendMessageImg" :send-message-path="sendMessagePath" :show-message-card="showMessageCard" :send-message-title="sendMessageTitle" @click="onClick" @error="bindError" @contact="bindContact" @opensetting="bindOpenSetting" @getuserinfo="bindGetUserInfo" @getphonenumber="bindGetPhoneNumber" @launchapp="bindLaunchApp">
  3. <view class="van-goods-action-icon__content">
  4. <van-icon v-if="icon" size="20px" :name="icon" :dot="dot" :info="info" class="van-goods-action-icon__icon" custom-class="icon-class"></van-icon>
  5. <slot name="icon"></slot>
  6. <text class="text-class">{{ text }}</text>
  7. </view>
  8. </van-button></uni-shadow-root>
  9. </template>
  10. <script>
  11. import VanIcon from '../icon/index.vue'
  12. import VanButton from '../button/index.vue'
  13. global['__wxVueOptions'] = {components:{'van-icon': VanIcon,'van-button': VanButton}}
  14. global['__wxRoute'] = 'vant/goods-action-icon/index'
  15. import { VantComponent } from '../common/component';
  16. import { link } from '../mixins/link';
  17. import { button } from '../mixins/button';
  18. import { openType } from '../mixins/open-type';
  19. VantComponent({
  20. classes: ['icon-class', 'text-class'],
  21. mixins: [link, button, openType],
  22. props: {
  23. text: String,
  24. dot: Boolean,
  25. info: String,
  26. icon: String,
  27. disabled: Boolean,
  28. loading: Boolean
  29. },
  30. methods: {
  31. onClick(event) {
  32. this.$emit('click', event.detail);
  33. this.jumpLink();
  34. }
  35. }
  36. });
  37. export default global['__wxComponents']['vant/goods-action-icon/index']
  38. </script>
  39. <style platform="mp-weixin">
  40. @import '../common/index.css';.van-goods-action-icon{border:none!important;width:50px!important;width:var(--goods-action-icon-height,50px)!important}.van-goods-action-icon__content{display:-webkit-flex;display:flex;-webkit-flex-direction:column;flex-direction:column;-webkit-justify-content:center;justify-content:center;height:100%;line-height:1;font-size:10px;font-size:var(--goods-action-icon-font-size,10px);color:#646566;color:var(--goods-action-icon-text-color,#646566)}.van-goods-action-icon__icon{margin-bottom:4px}
  41. </style>