service-card.vue 2.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. <template>
  2. <view class="service-card">
  3. <view class="service-row" @click="onClick">
  4. <view class="icon-box">
  5. <image src="/pages-sell/static/goods/icon-down.png" class="service-icon" mode="aspectFit"></image>
  6. </view>
  7. <text class="service-label">可降</text>
  8. <text class="separator">|</text>
  9. <text class="service-val red">分享一人助力,可降 1.5 元</text>
  10. <u-icon name="arrow-right" size="24" color="#999" class="arrow"></u-icon>
  11. </view>
  12. <view class="service-row">
  13. <view class="icon-box">
  14. <image src="/pages-sell/static/goods/icon-fee.png" class="service-icon" mode="aspectFit"></image>
  15. </view>
  16. <text class="service-label">运费</text>
  17. <text class="separator">|</text>
  18. <text class="service-val green">全场满 5.8 元包邮(偏远地区除外)</text>
  19. </view>
  20. <view class="service-row">
  21. <view class="icon-box">
  22. <image src="/pages-sell/static/goods/icon-fire.png" class="service-icon" mode="aspectFit"></image>
  23. </view>
  24. <text class="service-label">活动</text>
  25. <text class="separator">|</text>
  26. <text class="service-val red">每满 48 元减 5 元</text>
  27. </view>
  28. <view class="service-row last" @click="openServicePopup">
  29. <view class="icon-box">
  30. <image src="/pages-sell/static/goods/icon-service.png" class="service-icon" mode="aspectFit"></image>
  31. </view>
  32. <text class="service-label">服务</text>
  33. <text class="separator">|</text>
  34. <text class="service-val">破损包赔 · 降价补差 · 24 小时发货</text>
  35. <u-icon name="arrow-right" size="24" color="#999" class="arrow"></u-icon>
  36. </view>
  37. <ServicePopup ref="servicePopup" />
  38. </view>
  39. </template>
  40. <script>
  41. import ServicePopup from '@/pages-sell/components/service-popup/index.vue';
  42. export default {
  43. name: 'ServiceCard',
  44. components: {
  45. ServicePopup
  46. },
  47. methods: {
  48. onClick() {
  49. this.$emit('click');
  50. },
  51. openServicePopup() {
  52. this.$refs.servicePopup.open();
  53. }
  54. }
  55. }
  56. </script>
  57. <style lang="scss" scoped>
  58. .service-card {
  59. background: #fff;
  60. border-radius: 24rpx 24rpx 0 0;
  61. padding: 0 30rpx;
  62. margin-bottom: 20rpx;
  63. .service-row {
  64. display: flex;
  65. align-items: center;
  66. padding: 30rpx 0;
  67. font-size: 26rpx;
  68. position: relative;
  69. border-bottom: 1rpx solid #F5F5F5;
  70. &.last {
  71. border-bottom: none;
  72. }
  73. .icon-box {
  74. width: 32rpx;
  75. height: 32rpx;
  76. margin-right: 12rpx;
  77. display: flex;
  78. align-items: center;
  79. justify-content: center;
  80. .service-icon {
  81. width: 100%;
  82. height: 100%;
  83. }
  84. }
  85. .service-label {
  86. color: #333;
  87. font-weight: bold;
  88. width: 50rpx; // Fixed width for 2 characters to ensure alignment
  89. text-align: justify;
  90. text-align-last: justify;
  91. }
  92. .separator {
  93. color: #eee;
  94. margin: 0 10rpx;
  95. }
  96. .service-val {
  97. color: #666;
  98. flex: 1; // Allow text to take remaining space
  99. @include ellipsis;
  100. &.red {
  101. color: #D81A00;
  102. }
  103. &.green {
  104. color: #38C248;
  105. }
  106. }
  107. .arrow {
  108. position: absolute;
  109. right: 0;
  110. }
  111. }
  112. }
  113. </style>