2020-01-21 15:50:35 +01:00
|
|
|
<script>
|
2020-03-31 13:16:03 +02:00
|
|
|
import { store } from "builderStore"
|
2020-05-04 17:07:04 +02:00
|
|
|
import panelStructure from "./temporaryPanelStructure.js"
|
|
|
|
import CategoryTab from "./CategoryTab.svelte"
|
|
|
|
import DesignView from "./DesignView.svelte"
|
2020-05-18 17:32:00 +02:00
|
|
|
import SettingsView from "./SettingsView.svelte"
|
2020-05-04 17:07:04 +02:00
|
|
|
|
|
|
|
let flattenedPanel = flattenComponents(panelStructure.categories)
|
|
|
|
let categories = [
|
2020-05-18 17:32:00 +02:00
|
|
|
{ value: "settings", name: "Settings" },
|
2020-07-21 14:19:05 +02:00
|
|
|
{ value: "design", name: "Design" },
|
2020-05-04 17:07:04 +02:00
|
|
|
]
|
|
|
|
let selectedCategory = categories[0]
|
2020-02-03 10:50:30 +01:00
|
|
|
|
2020-06-25 17:02:30 +02:00
|
|
|
$: componentInstance =
|
|
|
|
$store.currentView !== "component"
|
|
|
|
? { ...$store.currentPreviewItem, ...$store.currentComponentInfo }
|
|
|
|
: $store.currentComponentInfo
|
2020-05-18 17:32:00 +02:00
|
|
|
$: componentDefinition = $store.components[componentInstance._component]
|
2020-05-20 12:55:25 +02:00
|
|
|
$: componentPropDefinition =
|
|
|
|
flattenedPanel.find(
|
|
|
|
//use for getting controls for each component property
|
2020-10-22 18:47:49 +02:00
|
|
|
(c) => c._component === componentInstance._component
|
2020-05-20 12:55:25 +02:00
|
|
|
) || {}
|
2020-06-11 14:15:19 +02:00
|
|
|
|
2020-06-15 18:08:59 +02:00
|
|
|
$: panelDefinition =
|
|
|
|
componentPropDefinition.properties &&
|
|
|
|
componentPropDefinition.properties[selectedCategory.value]
|
2020-05-04 17:07:04 +02:00
|
|
|
|
2020-02-03 10:50:30 +01:00
|
|
|
const onStyleChanged = store.setComponentStyle
|
2020-02-26 10:43:38 +01:00
|
|
|
|
2020-06-25 17:02:30 +02:00
|
|
|
$: isComponentOrScreen =
|
|
|
|
$store.currentView === "component" ||
|
|
|
|
$store.currentFrontEndType === "screen"
|
2020-06-24 17:16:06 +02:00
|
|
|
$: isNotScreenslot = componentInstance._component !== "##builtin/screenslot"
|
|
|
|
|
2020-06-25 17:02:30 +02:00
|
|
|
$: displayName =
|
|
|
|
isComponentOrScreen && componentInstance._instanceName && isNotScreenslot
|
2020-06-04 19:08:50 +02:00
|
|
|
|
2020-05-04 17:07:04 +02:00
|
|
|
function walkProps(component, action) {
|
|
|
|
action(component)
|
|
|
|
if (component.children) {
|
|
|
|
for (let child of component.children) {
|
|
|
|
walkProps(child, action)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
function flattenComponents(props) {
|
|
|
|
const components = []
|
2020-10-22 18:47:49 +02:00
|
|
|
props.forEach((comp) =>
|
|
|
|
walkProps(comp, (c) => {
|
2020-05-04 17:07:04 +02:00
|
|
|
if ("_component" in c) {
|
|
|
|
components.push(c)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
)
|
|
|
|
return components
|
|
|
|
}
|
2020-02-26 10:43:38 +01:00
|
|
|
|
|
|
|
function getProps(obj, keys) {
|
2020-05-06 11:33:30 +02:00
|
|
|
return keys.map((key, i) => [key, obj[key], obj.props._id + i])
|
2020-02-26 10:43:38 +01:00
|
|
|
}
|
2020-01-21 15:50:35 +01:00
|
|
|
</script>
|
|
|
|
|
2020-10-22 18:47:49 +02:00
|
|
|
<CategoryTab
|
|
|
|
onClick={(category) => (selectedCategory = category)}
|
|
|
|
{categories}
|
|
|
|
{selectedCategory} />
|
|
|
|
|
|
|
|
{#if displayName}
|
|
|
|
<div class="instance-name">{componentInstance._instanceName}</div>
|
|
|
|
{/if}
|
|
|
|
|
|
|
|
<div class="component-props-container">
|
|
|
|
{#if selectedCategory.value === 'design'}
|
|
|
|
<DesignView {panelDefinition} {componentInstance} {onStyleChanged} />
|
|
|
|
{:else if selectedCategory.value === 'settings'}
|
|
|
|
<SettingsView
|
|
|
|
{componentInstance}
|
|
|
|
{componentDefinition}
|
|
|
|
{panelDefinition}
|
|
|
|
displayNameField={displayName}
|
|
|
|
onChange={store.setComponentProp}
|
|
|
|
onScreenPropChange={store.setPageOrScreenProp}
|
|
|
|
screenOrPageInstance={$store.currentView !== 'component' && $store.currentPreviewItem} />
|
2020-06-25 17:02:30 +02:00
|
|
|
{/if}
|
2020-01-24 15:30:17 +01:00
|
|
|
</div>
|
2020-01-21 15:50:35 +01:00
|
|
|
|
|
|
|
<style>
|
2020-02-03 10:50:30 +01:00
|
|
|
.title > div:nth-child(1) {
|
2020-01-21 15:50:35 +01:00
|
|
|
grid-column-start: name;
|
2020-05-27 13:18:05 +02:00
|
|
|
color: var(--ink);
|
2020-02-03 10:50:30 +01:00
|
|
|
}
|
2020-01-21 15:50:35 +01:00
|
|
|
|
2020-02-03 10:50:30 +01:00
|
|
|
.title > div:nth-child(2) {
|
2020-01-21 15:50:35 +01:00
|
|
|
grid-column-start: actions;
|
2020-02-03 10:50:30 +01:00
|
|
|
}
|
2020-01-21 15:50:35 +01:00
|
|
|
|
2020-02-03 10:50:30 +01:00
|
|
|
.component-props-container {
|
2020-01-21 15:50:35 +01:00
|
|
|
flex: 1 1 auto;
|
2020-06-01 23:04:32 +02:00
|
|
|
min-height: 0;
|
2020-07-28 15:19:46 +02:00
|
|
|
overflow-y: auto;
|
2020-10-12 16:12:48 +02:00
|
|
|
margin-left: -20px;
|
|
|
|
margin-right: -20px;
|
|
|
|
padding: 0 20px;
|
2020-02-03 10:50:30 +01:00
|
|
|
}
|
2020-06-04 19:08:50 +02:00
|
|
|
|
|
|
|
.instance-name {
|
2020-10-22 19:23:11 +02:00
|
|
|
font-size: var(--font-size-xs);
|
2020-07-01 15:37:57 +02:00
|
|
|
font-weight: 500;
|
|
|
|
color: var(--grey-7);
|
2020-06-04 19:08:50 +02:00
|
|
|
}
|
2020-01-21 15:50:35 +01:00
|
|
|
</style>
|