VBanner.mjs 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. import { resolveDirective as _resolveDirective, createVNode as _createVNode } from "vue";
  2. // Styles
  3. import "./VBanner.css";
  4. // Components
  5. import { VBannerActions } from "./VBannerActions.mjs";
  6. import { VBannerText } from "./VBannerText.mjs";
  7. import { VAvatar } from "../VAvatar/index.mjs";
  8. import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs"; // Composables
  9. import { makeBorderProps, useBorder } from "../../composables/border.mjs";
  10. import { useBackgroundColor } from "../../composables/color.mjs";
  11. import { makeComponentProps } from "../../composables/component.mjs";
  12. import { provideDefaults } from "../../composables/defaults.mjs";
  13. import { makeDensityProps, useDensity } from "../../composables/density.mjs";
  14. import { makeDimensionProps, useDimension } from "../../composables/dimensions.mjs";
  15. import { makeDisplayProps, useDisplay } from "../../composables/display.mjs";
  16. import { makeElevationProps, useElevation } from "../../composables/elevation.mjs";
  17. import { IconValue } from "../../composables/icons.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 { makeTagProps } from "../../composables/tag.mjs";
  22. import { makeThemeProps, provideTheme } from "../../composables/theme.mjs"; // Utilities
  23. import { toRef } from 'vue';
  24. import { genericComponent, propsFactory, useRender } from "../../util/index.mjs"; // Types
  25. export const makeVBannerProps = propsFactory({
  26. avatar: String,
  27. bgColor: String,
  28. color: String,
  29. icon: IconValue,
  30. lines: String,
  31. stacked: Boolean,
  32. sticky: Boolean,
  33. text: String,
  34. ...makeBorderProps(),
  35. ...makeComponentProps(),
  36. ...makeDensityProps(),
  37. ...makeDimensionProps(),
  38. ...makeDisplayProps({
  39. mobile: null
  40. }),
  41. ...makeElevationProps(),
  42. ...makeLocationProps(),
  43. ...makePositionProps(),
  44. ...makeRoundedProps(),
  45. ...makeTagProps(),
  46. ...makeThemeProps()
  47. }, 'VBanner');
  48. export const VBanner = genericComponent()({
  49. name: 'VBanner',
  50. props: makeVBannerProps(),
  51. setup(props, _ref) {
  52. let {
  53. slots
  54. } = _ref;
  55. const {
  56. backgroundColorClasses,
  57. backgroundColorStyles
  58. } = useBackgroundColor(props, 'bgColor');
  59. const {
  60. borderClasses
  61. } = useBorder(props);
  62. const {
  63. densityClasses
  64. } = useDensity(props);
  65. const {
  66. displayClasses,
  67. mobile
  68. } = useDisplay(props);
  69. const {
  70. dimensionStyles
  71. } = useDimension(props);
  72. const {
  73. elevationClasses
  74. } = useElevation(props);
  75. const {
  76. locationStyles
  77. } = useLocation(props);
  78. const {
  79. positionClasses
  80. } = usePosition(props);
  81. const {
  82. roundedClasses
  83. } = useRounded(props);
  84. const {
  85. themeClasses
  86. } = provideTheme(props);
  87. const color = toRef(props, 'color');
  88. const density = toRef(props, 'density');
  89. provideDefaults({
  90. VBannerActions: {
  91. color,
  92. density
  93. }
  94. });
  95. useRender(() => {
  96. const hasText = !!(props.text || slots.text);
  97. const hasPrependMedia = !!(props.avatar || props.icon);
  98. const hasPrepend = !!(hasPrependMedia || slots.prepend);
  99. return _createVNode(props.tag, {
  100. "class": ['v-banner', {
  101. 'v-banner--stacked': props.stacked || mobile.value,
  102. 'v-banner--sticky': props.sticky,
  103. [`v-banner--${props.lines}-line`]: !!props.lines
  104. }, themeClasses.value, backgroundColorClasses.value, borderClasses.value, densityClasses.value, displayClasses.value, elevationClasses.value, positionClasses.value, roundedClasses.value, props.class],
  105. "style": [backgroundColorStyles.value, dimensionStyles.value, locationStyles.value, props.style],
  106. "role": "banner"
  107. }, {
  108. default: () => [hasPrepend && _createVNode("div", {
  109. "key": "prepend",
  110. "class": "v-banner__prepend"
  111. }, [!slots.prepend ? _createVNode(VAvatar, {
  112. "key": "prepend-avatar",
  113. "color": color.value,
  114. "density": density.value,
  115. "icon": props.icon,
  116. "image": props.avatar
  117. }, null) : _createVNode(VDefaultsProvider, {
  118. "key": "prepend-defaults",
  119. "disabled": !hasPrependMedia,
  120. "defaults": {
  121. VAvatar: {
  122. color: color.value,
  123. density: density.value,
  124. icon: props.icon,
  125. image: props.avatar
  126. }
  127. }
  128. }, slots.prepend)]), _createVNode("div", {
  129. "class": "v-banner__content"
  130. }, [hasText && _createVNode(VBannerText, {
  131. "key": "text"
  132. }, {
  133. default: () => [slots.text?.() ?? props.text]
  134. }), slots.default?.()]), slots.actions && _createVNode(VBannerActions, {
  135. "key": "actions"
  136. }, slots.actions)]
  137. });
  138. });
  139. }
  140. });
  141. //# sourceMappingURL=VBanner.mjs.map