| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283 |
- <template>
- <view :class="classes" @click="handleClick">
- <slot>
- <view
- class="nut-cell__title"
- :class="{ icon: icon }"
- v-if="title || subTitle || icon"
- >
- <nut-icon v-if="icon" class="icon" :name="icon"></nut-icon>
- <template v-if="subTitle">
- <view class="title">{{ title }}</view>
- <view class="nut-cell__title-desc">{{ subTitle }}</view>
- </template>
- <template v-else>
- {{ title }}
- </template>
- </view>
- <view
- v-if="desc"
- class="nut-cell__value"
- :style="{ 'text-align': descTextAlign }"
- >{{ desc }}</view
- >
- <nut-icon
- v-if="isLink || to"
- size="14px"
- color="#979797"
- name="right"
- ></nut-icon>
- </slot>
- </view>
- </template>
- <script lang="ts">
- import { computed } from 'vue';
- import { createComponent } from '@/utils/create';
- import { useRouter } from 'vue-router';
- const { componentName, create } = createComponent('cell');
- export default create({
- props: {
- title: { type: String, default: '' },
- subTitle: { type: String, default: '' },
- desc: { type: String, default: '' },
- descTextAlign: { type: String, default: 'right' },
- isLink: { type: Boolean, default: false },
- to: { type: String, default: '' },
- replace: { type: Boolean, default: false },
- url: { type: String, default: '' },
- icon: { type: String, default: '' }
- },
- emits: ['click'],
- setup(props, { emit }) {
- const classes = computed(() => {
- const prefixCls = componentName;
- return {
- [prefixCls]: true,
- [`${prefixCls}--clickable`]: props.isLink || props.to
- };
- });
- const router = useRouter();
- const handleClick = (event: Event) => {
- emit('click', event);
- if (props.to && router) {
- router[props.replace ? 'replace' : 'push'](props.to);
- } else if (props.url) {
- props.replace
- ? location.replace(props.url)
- : (location.href = props.url);
- }
- };
- return {
- handleClick,
- classes
- };
- }
- });
- </script>
- <style lang="scss">
- @import 'index.scss';
- </style>
|