index.vue 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. <template>
  2. <uni-shadow-root class="weapp-dist-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="onError" @contact="onContact" @opensetting="onOpenSetting" @getuserinfo="onGetUserInfo" @getphonenumber="onGetPhoneNumber" @launchapp="onLaunchApp">
  3. <van-icon v-if="icon" :name="icon" :dot="dot" :info="info" :color="color" :class-prefix="classPrefix" class="van-goods-action-icon__icon" custom-class="icon-class"></van-icon>
  4. <slot v-else name="icon"></slot>
  5. <text class="text-class">{{ text }}</text>
  6. </van-button></uni-shadow-root>
  7. </template>
  8. <script>
  9. import VanIcon from '../icon/index.vue'
  10. import VanButton from '../button/index.vue'
  11. global['__wxVueOptions'] = {components:{'van-icon': VanIcon,'van-button': VanButton}}
  12. global['__wxRoute'] = 'weapp/dist/goods-action-icon/index'
  13. import { VantComponent } from '../common/component';
  14. import { button } from '../mixins/button';
  15. import { link } from '../mixins/link';
  16. VantComponent({
  17. classes: ['icon-class', 'text-class'],
  18. mixins: [link, button],
  19. props: {
  20. text: String,
  21. dot: Boolean,
  22. info: String,
  23. icon: String,
  24. color: String,
  25. classPrefix: {
  26. type: String,
  27. value: 'van-icon',
  28. },
  29. disabled: Boolean,
  30. loading: Boolean,
  31. },
  32. methods: {
  33. onClick(event) {
  34. this.$emit('click', event.detail);
  35. this.jumpLink();
  36. },
  37. },
  38. });
  39. export default global['__wxComponents']['weapp/dist/goods-action-icon/index']
  40. </script>
  41. <style platform="mp-weixin">
  42. @import '../common/index.css';.van-goods-action-icon{border:none!important;color:var(--goods-action-icon-text-color,#646566)!important;display:flex!important;flex-direction:column;font-size:var(--goods-action-icon-font-size,10px)!important;height:var(--goods-action-icon-height,50px)!important;justify-content:center!important;line-height:1!important;min-width:var(--goods-action-icon-width,48px)}.van-goods-action-icon__icon{color:var(--goods-action-icon-color,#323233);display:flex;font-size:var(--goods-action-icon-size,18px);margin:0 auto 5px}
  43. </style>