UNPKG

vuetify

Version:

Vue Material Component Framework

125 lines (122 loc) 4.16 kB
import { createVNode as _createVNode } from "vue"; // Styles import "./VBanner.css"; // Components import { VAvatar } from "../VAvatar/index.mjs"; import { VBannerActions } from "./VBannerActions.mjs"; import { VBannerText } from "./VBannerText.mjs"; import { VDefaultsProvider } from "../VDefaultsProvider/index.mjs"; // Composables import { makeBorderProps, useBorder } from "../../composables/border.mjs"; import { makeDensityProps, useDensity } from "../../composables/density.mjs"; import { makeDimensionProps, useDimension } from "../../composables/dimensions.mjs"; import { makeElevationProps, useElevation } from "../../composables/elevation.mjs"; import { makeLocationProps, useLocation } from "../../composables/location.mjs"; import { makePositionProps, usePosition } from "../../composables/position.mjs"; import { makeRoundedProps, useRounded } from "../../composables/rounded.mjs"; import { makeTagProps } from "../../composables/tag.mjs"; import { makeThemeProps, provideTheme } from "../../composables/theme.mjs"; import { provideDefaults } from "../../composables/defaults.mjs"; import { useDisplay } from "../../composables/display.mjs"; import { IconValue } from "../../composables/icons.mjs"; // Utilities import { genericComponent, useRender } from "../../util/index.mjs"; import { toRef } from 'vue'; // Types export const VBanner = genericComponent()({ name: 'VBanner', props: { avatar: String, color: String, icon: IconValue, lines: String, stacked: Boolean, sticky: Boolean, text: String, ...makeBorderProps(), ...makeDensityProps(), ...makeDimensionProps(), ...makeElevationProps(), ...makeLocationProps(), ...makePositionProps(), ...makeRoundedProps(), ...makeTagProps(), ...makeThemeProps() }, setup(props, _ref) { let { slots } = _ref; const { borderClasses } = useBorder(props); const { densityClasses } = useDensity(props); const { mobile } = useDisplay(); const { dimensionStyles } = useDimension(props); const { elevationClasses } = useElevation(props); const { locationStyles } = useLocation(props); const { positionClasses } = usePosition(props); const { roundedClasses } = useRounded(props); const { themeClasses } = provideTheme(props); const color = toRef(props, 'color'); const density = toRef(props, 'density'); provideDefaults({ VBannerActions: { color, density } }); useRender(() => { const hasText = !!(props.text || slots.text); const hasPrepend = !!(slots.prepend || props.avatar || props.icon); return _createVNode(props.tag, { "class": ['v-banner', { 'v-banner--stacked': props.stacked || mobile.value, 'v-banner--sticky': props.sticky, [`v-banner--${props.lines}-line`]: !!props.lines }, borderClasses.value, densityClasses.value, elevationClasses.value, positionClasses.value, roundedClasses.value, themeClasses.value], "style": [dimensionStyles.value, locationStyles.value], "role": "banner" }, { default: () => [hasPrepend && _createVNode(VDefaultsProvider, { "key": "prepend", "defaults": { VAvatar: { color: color.value, density: density.value, icon: props.icon, image: props.avatar } } }, { default: () => [_createVNode("div", { "class": "v-banner__prepend" }, [slots.prepend ? slots.prepend() : (props.avatar || props.icon) && _createVNode(VAvatar, null, null)])] }), _createVNode("div", { "class": "v-banner__content" }, [hasText && _createVNode(VBannerText, { "key": "text" }, { default: () => [slots.text ? slots.text() : props.text] }), slots.default?.()]), slots.actions && _createVNode(VBannerActions, null, { default: () => [slots.actions()] })] }); }); } }); //# sourceMappingURL=VBanner.mjs.map