index.vue 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100
  1. <template>
  2. <uni-shadow-root class="weapp-lib-submit-bar-index"><view class="van-submit-bar custom-class">
  3. <slot name="top"></slot>
  4. <view class="van-submit-bar__tip">
  5. <van-icon v-if="tipIcon" size="12px" :name="tipIcon" custom-class="van-submit-bar__tip-icon"></van-icon>
  6. <view v-if="hasTip" class="van-submit-bar__tip-text">
  7. {{ tip }}
  8. </view>
  9. <slot name="tip"></slot>
  10. </view>
  11. <view class="bar-class van-submit-bar__bar">
  12. <slot></slot>
  13. <view v-if="hasPrice" class="van-submit-bar__text">
  14. <text>{{ label || '合计:' }}</text>
  15. <text class="van-submit-bar__price price-class">
  16. <text class="van-submit-bar__currency">{{ currency }} </text>
  17. <text class="van-submit-bar__price-integer">{{ integerStr }}</text><text>{{decimalStr}}</text>
  18. </text>
  19. <text class="van-submit-bar__suffix-label">{{ suffixLabel }}</text>
  20. </view>
  21. <van-button round :type="buttonType" :loading="loading" :disabled="disabled" class="van-submit-bar__button" custom-class="button-class" custom-style="width: 100%;" @click="onSubmit">
  22. {{ loading ? '' : buttonText }}
  23. </van-button>
  24. </view>
  25. <view v-if="safeAreaInsetBottom" class="van-submit-bar__safe"></view>
  26. </view></uni-shadow-root>
  27. </template>
  28. <wxs src="../wxs/utils.wxs" module="utils"></wxs>
  29. <script>
  30. import VanButton from '../button/index.vue'
  31. import VanIcon from '../icon/index.vue'
  32. global['__wxVueOptions'] = {components:{'van-button': VanButton,'van-icon': VanIcon}}
  33. global['__wxRoute'] = 'weapp/lib/submit-bar/index'
  34. "use strict";
  35. Object.defineProperty(exports, "__esModule", { value: true });
  36. var component_1 = require("../common/component");
  37. (0, component_1.VantComponent)({
  38. classes: ['bar-class', 'price-class', 'button-class'],
  39. props: {
  40. tip: {
  41. type: null,
  42. observer: 'updateTip',
  43. },
  44. tipIcon: String,
  45. type: Number,
  46. price: {
  47. type: null,
  48. observer: 'updatePrice',
  49. },
  50. label: String,
  51. loading: Boolean,
  52. disabled: Boolean,
  53. buttonText: String,
  54. currency: {
  55. type: String,
  56. value: '¥',
  57. },
  58. buttonType: {
  59. type: String,
  60. value: 'danger',
  61. },
  62. decimalLength: {
  63. type: Number,
  64. value: 2,
  65. observer: 'updatePrice',
  66. },
  67. suffixLabel: String,
  68. safeAreaInsetBottom: {
  69. type: Boolean,
  70. value: true,
  71. },
  72. },
  73. methods: {
  74. updatePrice: function () {
  75. var _a = this.data, price = _a.price, decimalLength = _a.decimalLength;
  76. var priceStrArr = typeof price === 'number' &&
  77. (price / 100).toFixed(decimalLength).split('.');
  78. this.setData({
  79. hasPrice: typeof price === 'number',
  80. integerStr: priceStrArr && priceStrArr[0],
  81. decimalStr: decimalLength && priceStrArr ? ".".concat(priceStrArr[1]) : '',
  82. });
  83. },
  84. updateTip: function () {
  85. this.setData({ hasTip: typeof this.data.tip === 'string' });
  86. },
  87. onSubmit: function (event) {
  88. this.$emit('submit', event.detail);
  89. },
  90. },
  91. });
  92. export default global['__wxComponents']['weapp/lib/submit-bar/index']
  93. </script>
  94. <style platform="mp-weixin">
  95. @import '../common/index.css';.van-submit-bar{background-color:var(--submit-bar-background-color,#fff);bottom:0;left:0;position:fixed;-webkit-user-select:none;user-select:none;width:100%;z-index:var(--submit-bar-z-index,100)}.van-submit-bar__tip{background-color:var(--submit-bar-tip-background-color,#fff7cc);color:var(--submit-bar-tip-color,#f56723);font-size:var(--submit-bar-tip-font-size,12px);line-height:var(--submit-bar-tip-line-height,1.5);padding:var(--submit-bar-tip-padding,10px)}.van-submit-bar__tip:empty{display:none}.van-submit-bar__tip-icon{margin-right:4px;vertical-align:middle}.van-submit-bar__tip-text{display:inline;vertical-align:middle}.van-submit-bar__bar{align-items:center;background-color:var(--submit-bar-background-color,#fff);display:flex;font-size:var(--submit-bar-text-font-size,14px);height:var(--submit-bar-height,50px);justify-content:flex-end;padding:var(--submit-bar-padding,0 16px)}.van-submit-bar__safe{height:constant(safe-area-inset-bottom);height:env(safe-area-inset-bottom)}.van-submit-bar__text{color:var(--submit-bar-text-color,#323233);flex:1;font-weight:var(--font-weight-bold,500);padding-right:var(--padding-sm,12px);text-align:right}.van-submit-bar__price{color:var(--submit-bar-price-color,#ee0a24);font-size:var(--submit-bar-price-font-size,12px);font-weight:var(--font-weight-bold,500)}.van-submit-bar__price-integer{font-family:Avenir-Heavy,PingFang SC,Helvetica Neue,Arial,sans-serif;font-size:20px}.van-submit-bar__currency{font-size:var(--submit-bar-currency-font-size,12px)}.van-submit-bar__suffix-label{margin-left:5px}.van-submit-bar__button{--button-default-height:var(--submit-bar-button-height,40px)!important;--button-line-height:var(--submit-bar-button-height,40px)!important;font-weight:var(--font-weight-bold,500);width:var(--submit-bar-button-width,110px)}
  96. </style>