2022-03-26 14:52:54 +00:00
|
|
|
import type { ExtractPropTypes } from 'vue';
|
2021-10-07 01:23:36 +00:00
|
|
|
import { defineComponent, computed } from 'vue';
|
2023-01-27 08:00:17 +00:00
|
|
|
import useConfigInject from '../config-provider/hooks/useConfigInject';
|
2018-01-20 06:33:42 +00:00
|
|
|
|
2022-03-26 14:52:54 +00:00
|
|
|
export const cardGridProps = () => ({
|
|
|
|
prefixCls: String,
|
|
|
|
hoverable: { type: Boolean, default: true },
|
|
|
|
});
|
|
|
|
export type CardGridProps = Partial<ExtractPropTypes<ReturnType<typeof cardGridProps>>>;
|
2020-10-12 11:19:10 +00:00
|
|
|
export default defineComponent({
|
2022-09-26 13:33:41 +00:00
|
|
|
compatConfig: { MODE: 3 },
|
2018-04-08 13:17:20 +00:00
|
|
|
name: 'ACardGrid',
|
2018-09-05 13:28:54 +00:00
|
|
|
__ANT_CARD_GRID: true,
|
2022-03-26 14:52:54 +00:00
|
|
|
props: cardGridProps(),
|
2021-10-07 01:23:36 +00:00
|
|
|
setup(props, { slots }) {
|
|
|
|
const { prefixCls } = useConfigInject('card', props);
|
|
|
|
const classNames = computed(() => {
|
|
|
|
return {
|
|
|
|
[`${prefixCls.value}-grid`]: true,
|
|
|
|
[`${prefixCls.value}-grid-hoverable`]: props.hoverable,
|
|
|
|
};
|
|
|
|
});
|
|
|
|
return () => {
|
|
|
|
return <div class={classNames.value}>{slots.default?.()}</div>;
|
2020-06-22 15:22:52 +00:00
|
|
|
};
|
2019-03-13 13:32:14 +00:00
|
|
|
},
|
2020-10-12 11:19:10 +00:00
|
|
|
});
|