VCard.mjs 6.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  1. import { withDirectives as _withDirectives, mergeProps as _mergeProps, resolveDirective as _resolveDirective, createVNode as _createVNode } from "vue";
  2. /* eslint-disable complexity */
  3. // Styles
  4. import "./VCard.css";
  5. // Components
  6. import { VCardActions } from "./VCardActions.mjs";
  7. import { VCardItem } from "./VCardItem.mjs";
  8. import { VCardText } from "./VCardText.mjs";
  9. import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs";
  10. import { VImg } from "../VImg/index.mjs"; // Composables
  11. import { makeBorderProps, useBorder } from "../../composables/border.mjs";
  12. import { makeComponentProps } from "../../composables/component.mjs";
  13. import { makeDensityProps, useDensity } from "../../composables/density.mjs";
  14. import { makeDimensionProps, useDimension } from "../../composables/dimensions.mjs";
  15. import { makeElevationProps, useElevation } from "../../composables/elevation.mjs";
  16. import { IconValue } from "../../composables/icons.mjs";
  17. import { LoaderSlot, makeLoaderProps, useLoader } from "../../composables/loader.mjs";
  18. import { makeLocationProps, useLocation } from "../../composables/location.mjs";
  19. import { makePositionProps, usePosition } from "../../composables/position.mjs";
  20. import { makeRoundedProps, useRounded } from "../../composables/rounded.mjs";
  21. import { makeRouterProps, useLink } from "../../composables/router.mjs";
  22. import { makeTagProps } from "../../composables/tag.mjs";
  23. import { makeThemeProps, provideTheme } from "../../composables/theme.mjs";
  24. import { genOverlays, makeVariantProps, useVariant } from "../../composables/variant.mjs"; // Directives
  25. import { Ripple } from "../../directives/ripple/index.mjs"; // Utilities
  26. import { computed } from 'vue';
  27. import { genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
  28. export const makeVCardProps = propsFactory({
  29. appendAvatar: String,
  30. appendIcon: IconValue,
  31. disabled: Boolean,
  32. flat: Boolean,
  33. hover: Boolean,
  34. image: String,
  35. link: {
  36. type: Boolean,
  37. default: undefined
  38. },
  39. prependAvatar: String,
  40. prependIcon: IconValue,
  41. ripple: {
  42. type: [Boolean, Object],
  43. default: true
  44. },
  45. subtitle: [String, Number],
  46. text: [String, Number],
  47. title: [String, Number],
  48. ...makeBorderProps(),
  49. ...makeComponentProps(),
  50. ...makeDensityProps(),
  51. ...makeDimensionProps(),
  52. ...makeElevationProps(),
  53. ...makeLoaderProps(),
  54. ...makeLocationProps(),
  55. ...makePositionProps(),
  56. ...makeRoundedProps(),
  57. ...makeRouterProps(),
  58. ...makeTagProps(),
  59. ...makeThemeProps(),
  60. ...makeVariantProps({
  61. variant: 'elevated'
  62. })
  63. }, 'VCard');
  64. export const VCard = genericComponent()({
  65. name: 'VCard',
  66. directives: {
  67. Ripple
  68. },
  69. props: makeVCardProps(),
  70. setup(props, _ref) {
  71. let {
  72. attrs,
  73. slots
  74. } = _ref;
  75. const {
  76. themeClasses
  77. } = provideTheme(props);
  78. const {
  79. borderClasses
  80. } = useBorder(props);
  81. const {
  82. colorClasses,
  83. colorStyles,
  84. variantClasses
  85. } = useVariant(props);
  86. const {
  87. densityClasses
  88. } = useDensity(props);
  89. const {
  90. dimensionStyles
  91. } = useDimension(props);
  92. const {
  93. elevationClasses
  94. } = useElevation(props);
  95. const {
  96. loaderClasses
  97. } = useLoader(props);
  98. const {
  99. locationStyles
  100. } = useLocation(props);
  101. const {
  102. positionClasses
  103. } = usePosition(props);
  104. const {
  105. roundedClasses
  106. } = useRounded(props);
  107. const link = useLink(props, attrs);
  108. const isLink = computed(() => props.link !== false && link.isLink.value);
  109. const isClickable = computed(() => !props.disabled && props.link !== false && (props.link || link.isClickable.value));
  110. useRender(() => {
  111. const Tag = isLink.value ? 'a' : props.tag;
  112. const hasTitle = !!(slots.title || props.title != null);
  113. const hasSubtitle = !!(slots.subtitle || props.subtitle != null);
  114. const hasHeader = hasTitle || hasSubtitle;
  115. const hasAppend = !!(slots.append || props.appendAvatar || props.appendIcon);
  116. const hasPrepend = !!(slots.prepend || props.prependAvatar || props.prependIcon);
  117. const hasImage = !!(slots.image || props.image);
  118. const hasCardItem = hasHeader || hasPrepend || hasAppend;
  119. const hasText = !!(slots.text || props.text != null);
  120. return _withDirectives(_createVNode(Tag, _mergeProps({
  121. "class": ['v-card', {
  122. 'v-card--disabled': props.disabled,
  123. 'v-card--flat': props.flat,
  124. 'v-card--hover': props.hover && !(props.disabled || props.flat),
  125. 'v-card--link': isClickable.value
  126. }, themeClasses.value, borderClasses.value, colorClasses.value, densityClasses.value, elevationClasses.value, loaderClasses.value, positionClasses.value, roundedClasses.value, variantClasses.value, props.class],
  127. "style": [colorStyles.value, dimensionStyles.value, locationStyles.value, props.style],
  128. "onClick": isClickable.value && link.navigate,
  129. "tabindex": props.disabled ? -1 : undefined
  130. }, link.linkProps), {
  131. default: () => [hasImage && _createVNode("div", {
  132. "key": "image",
  133. "class": "v-card__image"
  134. }, [!slots.image ? _createVNode(VImg, {
  135. "key": "image-img",
  136. "cover": true,
  137. "src": props.image
  138. }, null) : _createVNode(VDefaultsProvider, {
  139. "key": "image-defaults",
  140. "disabled": !props.image,
  141. "defaults": {
  142. VImg: {
  143. cover: true,
  144. src: props.image
  145. }
  146. }
  147. }, slots.image)]), _createVNode(LoaderSlot, {
  148. "name": "v-card",
  149. "active": !!props.loading,
  150. "color": typeof props.loading === 'boolean' ? undefined : props.loading
  151. }, {
  152. default: slots.loader
  153. }), hasCardItem && _createVNode(VCardItem, {
  154. "key": "item",
  155. "prependAvatar": props.prependAvatar,
  156. "prependIcon": props.prependIcon,
  157. "title": props.title,
  158. "subtitle": props.subtitle,
  159. "appendAvatar": props.appendAvatar,
  160. "appendIcon": props.appendIcon
  161. }, {
  162. default: slots.item,
  163. prepend: slots.prepend,
  164. title: slots.title,
  165. subtitle: slots.subtitle,
  166. append: slots.append
  167. }), hasText && _createVNode(VCardText, {
  168. "key": "text"
  169. }, {
  170. default: () => [slots.text?.() ?? props.text]
  171. }), slots.default?.(), slots.actions && _createVNode(VCardActions, null, {
  172. default: slots.actions
  173. }), genOverlays(isClickable.value, 'v-card')]
  174. }), [[_resolveDirective("ripple"), isClickable.value && props.ripple]]);
  175. });
  176. return {};
  177. }
  178. });
  179. //# sourceMappingURL=VCard.mjs.map