108 lines
2.2 KiB
Svelte
108 lines
2.2 KiB
Svelte
<script>
|
|
import { getContext } from "svelte"
|
|
|
|
const { styleable } = getContext("sdk")
|
|
const component = getContext("component")
|
|
|
|
export let direction
|
|
export let hAlign
|
|
export let vAlign
|
|
export let size
|
|
export let gap
|
|
export let wrap
|
|
|
|
$: directionClass = direction ? `valid-container direction-${direction}` : ""
|
|
$: hAlignClass = hAlign ? `hAlign-${hAlign}` : ""
|
|
$: vAlignClass = vAlign ? `vAlign-${vAlign}` : ""
|
|
$: sizeClass = size ? `size-${size}` : ""
|
|
$: gapClass = gap ? `gap-${gap}` : ""
|
|
$: classNames = [
|
|
directionClass,
|
|
hAlignClass,
|
|
vAlignClass,
|
|
sizeClass,
|
|
gapClass,
|
|
].join(" ")
|
|
</script>
|
|
|
|
<div class={classNames} use:styleable={$component.styles} class:wrap>
|
|
<slot />
|
|
</div>
|
|
|
|
<style>
|
|
.valid-container {
|
|
display: flex;
|
|
max-width: 100%;
|
|
}
|
|
.valid-container :global(.component > *) {
|
|
max-width: 100%;
|
|
}
|
|
.direction-row {
|
|
flex-direction: row;
|
|
}
|
|
.direction-column {
|
|
flex-direction: column;
|
|
}
|
|
|
|
/* Grow containers inside a row need 0 width 0 so that they ignore content */
|
|
/* The nested selector for data-type is the wrapper around all components */
|
|
.direction-row :global(> .component > .size-grow) {
|
|
width: 0;
|
|
}
|
|
|
|
.size-shrink {
|
|
flex: 0 1 auto;
|
|
}
|
|
.size-grow {
|
|
flex: 1 1 auto;
|
|
}
|
|
|
|
.direction-row.hAlign-left,
|
|
.direction-column.vAlign-top {
|
|
justify-content: flex-start;
|
|
}
|
|
.direction-row.hAlign-center,
|
|
.direction-column.vAlign-middle {
|
|
justify-content: center;
|
|
}
|
|
.direction-row.hAlign-right,
|
|
.direction-column.vAlign-bottom {
|
|
justify-content: flex-end;
|
|
}
|
|
.direction-row.hAlign-stretch,
|
|
.direction-column.vAlign-stretch {
|
|
justify-content: space-between;
|
|
}
|
|
|
|
.direction-row.vAlign-top,
|
|
.direction-column.hAlign-left {
|
|
align-items: flex-start;
|
|
}
|
|
.direction-row.vAlign-middle,
|
|
.direction-column.hAlign-center {
|
|
align-items: center;
|
|
}
|
|
.direction-row.vAlign-bottom,
|
|
.direction-column.hAlign-right {
|
|
align-items: flex-end;
|
|
}
|
|
.direction-row.vAlign-stretch,
|
|
.direction-column.hAlign-stretch {
|
|
align-items: stretch;
|
|
}
|
|
|
|
.gap-S {
|
|
gap: 8px;
|
|
}
|
|
.gap-M {
|
|
gap: 16px;
|
|
}
|
|
.gap-L {
|
|
gap: 32px;
|
|
}
|
|
|
|
.wrap {
|
|
flex-wrap: wrap;
|
|
}
|
|
</style>
|