index.vue 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283
  1. <template>
  2. <view :class="classes" @click="handleClick">
  3. <slot>
  4. <view
  5. class="nut-cell__title"
  6. :class="{ icon: icon }"
  7. v-if="title || subTitle || icon"
  8. >
  9. <nut-icon v-if="icon" class="icon" :name="icon"></nut-icon>
  10. <template v-if="subTitle">
  11. <view class="title">{{ title }}</view>
  12. <view class="nut-cell__title-desc">{{ subTitle }}</view>
  13. </template>
  14. <template v-else>
  15. {{ title }}
  16. </template>
  17. </view>
  18. <view
  19. v-if="desc"
  20. class="nut-cell__value"
  21. :style="{ 'text-align': descTextAlign }"
  22. >{{ desc }}</view
  23. >
  24. <nut-icon
  25. v-if="isLink || to"
  26. size="14px"
  27. color="#979797"
  28. name="right"
  29. ></nut-icon>
  30. </slot>
  31. </view>
  32. </template>
  33. <script lang="ts">
  34. import { computed } from 'vue';
  35. import { createComponent } from '@/utils/create';
  36. import { useRouter } from 'vue-router';
  37. const { componentName, create } = createComponent('cell');
  38. export default create({
  39. props: {
  40. title: { type: String, default: '' },
  41. subTitle: { type: String, default: '' },
  42. desc: { type: String, default: '' },
  43. descTextAlign: { type: String, default: 'right' },
  44. isLink: { type: Boolean, default: false },
  45. to: { type: String, default: '' },
  46. replace: { type: Boolean, default: false },
  47. url: { type: String, default: '' },
  48. icon: { type: String, default: '' }
  49. },
  50. emits: ['click'],
  51. setup(props, { emit }) {
  52. const classes = computed(() => {
  53. const prefixCls = componentName;
  54. return {
  55. [prefixCls]: true,
  56. [`${prefixCls}--clickable`]: props.isLink || props.to
  57. };
  58. });
  59. const router = useRouter();
  60. const handleClick = (event: Event) => {
  61. emit('click', event);
  62. if (props.to && router) {
  63. router[props.replace ? 'replace' : 'push'](props.to);
  64. } else if (props.url) {
  65. props.replace
  66. ? location.replace(props.url)
  67. : (location.href = props.url);
  68. }
  69. };
  70. return {
  71. handleClick,
  72. classes
  73. };
  74. }
  75. });
  76. </script>
  77. <style lang="scss">
  78. @import 'index.scss';
  79. </style>