budibase/packages/builder/src/userInterface/LayoutEditor.svelte

143 lines
2.9 KiB
Svelte
Raw Normal View History

<script>
2020-02-03 10:50:30 +01:00
import InputGroup from "../common/Inputs/InputGroup.svelte"
2020-02-03 10:50:30 +01:00
export let onStyleChanged = () => {}
export let componentInfo
const tbrl = [
2020-02-03 10:50:30 +01:00
{ placeholder: "T" },
{ placeholder: "R" },
{ placeholder: "B" },
{ placeholder: "L" },
]
2020-02-03 10:50:30 +01:00
const se = [{ placeholder: "START" }, { placeholder: "END" }]
2020-02-03 10:50:30 +01:00
const single = [{ placeholder: "" }]
2020-02-03 10:50:30 +01:00
$: layout = {
...componentInfo._styles.position,
...componentInfo._styles.layout,
}
$: layouts = {
2020-02-03 10:50:30 +01:00
templaterows: ["Grid Rows", single],
templatecolumns: ["Grid Columns", single],
}
$: positions = {
2020-02-03 10:50:30 +01:00
column: ["Column", se],
row: ["Row", se],
}
$: spacing = {
2020-02-03 10:50:30 +01:00
margin: ["Margin", tbrl, "small"],
padding: ["Padding", tbrl, "small"],
}
$: zindex = {
2020-02-03 10:50:30 +01:00
zindex: ["Z-Index", single],
}
2020-02-03 10:50:30 +01:00
const newValue = n => Array(n).fill("")
</script>
2020-01-22 12:21:42 +01:00
<h3>Styles</h3>
2020-01-22 12:21:42 +01:00
<h4>Positioning</h4>
<div class="layout-pos">
2020-02-03 10:50:30 +01:00
{#each Object.entries(layouts) as [key, [name, meta, size]]}
<div class="grid">
<h5>{name}:</h5>
2020-02-03 10:50:30 +01:00
<InputGroup
onStyleChanged={_value => onStyleChanged('layout', key, _value)}
values={layout[key] || newValue(meta.length)}
{meta}
{size}
type="text" />
</div>
{/each}
</div>
2020-01-22 12:21:42 +01:00
<h4>Positioning</h4>
2020-01-22 12:21:42 +01:00
<div class="layout-pos">
2020-02-03 10:50:30 +01:00
{#each Object.entries(positions) as [key, [name, meta, size]]}
<div class="grid">
<h5>{name}:</h5>
2020-02-03 10:50:30 +01:00
<InputGroup
onStyleChanged={_value => onStyleChanged('position', key, _value)}
values={layout[key] || newValue(meta.length)}
{meta}
{size} />
</div>
{/each}
2020-01-22 12:21:42 +01:00
</div>
<h4>Spacing</h4>
<div class="layout-spacing">
{#each Object.entries(spacing) as [key, [name, meta, size]]}
<div class="grid">
<h5>{name}:</h5>
2020-02-03 10:50:30 +01:00
<InputGroup
onStyleChanged={_value => onStyleChanged('position', key, _value)}
values={layout[key] || newValue(meta.length)}
{meta}
{size} />
</div>
{/each}
2020-01-22 12:21:42 +01:00
</div>
<h4>Z-Index</h4>
<div class="layout-layer">
{#each Object.entries(zindex) as [key, [name, meta, size]]}
<div class="grid">
<h5>{name}:</h5>
2020-02-03 10:50:30 +01:00
<InputGroup
onStyleChanged={_value => onStyleChanged('position', key, _value)}
values={layout[key] || newValue(meta.length)}
{meta}
{size} />
</div>
{/each}
2020-01-22 12:21:42 +01:00
</div>
<style>
h3 {
text-transform: uppercase;
font-size: 12px;
font-weight: 700;
color: #8997ab;
margin-bottom: 10px;
}
h4 {
text-transform: uppercase;
font-size: 10px;
font-weight: 700;
color: #163057;
opacity: 0.3;
margin-bottom: 15px;
}
h5 {
font-size: 12px;
font-weight: 700;
color: #163057;
opacity: 0.6;
padding-top: 12px;
margin-bottom: 0;
2020-01-22 12:21:42 +01:00
}
div > div {
display: grid;
grid-template-rows: 1fr;
grid-gap: 10px;
height: 40px;
margin-bottom: 15px;
}
.grid {
grid-template-columns: 70px 1fr;
}
</style>