2019-08-07 10:03:49 +02:00
|
|
|
<script>
|
|
|
|
|
2019-10-07 07:03:41 +02:00
|
|
|
import ComponentSelector from "./ComponentSelector.svelte";
|
2019-08-07 10:03:49 +02:00
|
|
|
import { store } from "../builderStore";
|
|
|
|
import PropsView from "./PropsView.svelte";
|
|
|
|
import Textbox from "../common/Textbox.svelte";
|
2019-08-14 23:11:59 +02:00
|
|
|
import Button from "../common/Button.svelte";
|
|
|
|
import ButtonGroup from "../common/ButtonGroup.svelte";
|
|
|
|
import { pipe } from "../common/core";
|
|
|
|
import UIkit from "uikit";
|
|
|
|
import { isRootComponent } from "./pagesParsing/searchComponents";
|
2020-01-18 00:06:42 +01:00
|
|
|
import { splitName } from "./pagesParsing/splitRootComponentName.js"
|
2019-08-07 10:03:49 +02:00
|
|
|
|
2019-08-14 23:11:59 +02:00
|
|
|
import {
|
2020-01-18 00:06:42 +01:00
|
|
|
find, filter, some, map, includes
|
2019-08-14 23:11:59 +02:00
|
|
|
} from "lodash/fp";
|
|
|
|
import { assign } from "lodash";
|
2019-08-07 10:03:49 +02:00
|
|
|
|
2019-08-14 23:11:59 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
export const show = () => {
|
|
|
|
UIkit.modal(componentSelectorModal).show();
|
|
|
|
}
|
2019-08-14 23:11:59 +02:00
|
|
|
|
2019-10-07 07:03:41 +02:00
|
|
|
let componentSelectorModal;
|
2020-01-18 00:06:42 +01:00
|
|
|
let layoutComponents;
|
|
|
|
let layoutComponent;
|
|
|
|
let screens;
|
|
|
|
let name="";
|
|
|
|
let saveAttempted=false;
|
2019-08-14 23:11:59 +02:00
|
|
|
|
2019-08-16 16:48:45 +02:00
|
|
|
store.subscribe(s => {
|
2019-08-14 23:11:59 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
layoutComponents = pipe(s.components, [
|
|
|
|
filter(c => includes("layout")(c.tags)),
|
|
|
|
map(c => ({name:c.name, ...splitName(c.name)}))
|
|
|
|
]);
|
2019-08-14 23:11:59 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
layoutComponent = layoutComponent
|
|
|
|
? find(c => c.name === layoutComponent.name)(layoutComponents)
|
|
|
|
: layoutComponents[0];
|
2019-08-14 23:11:59 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
screens = s.screens;
|
|
|
|
});
|
|
|
|
|
|
|
|
const save = () => {
|
|
|
|
saveAttempted = true;
|
2019-08-07 10:03:49 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
const isValid = name.length > 0
|
|
|
|
&& !screenNameExists(name)
|
|
|
|
&& layoutComponent;
|
|
|
|
|
|
|
|
if(!isValid) return;
|
|
|
|
|
|
|
|
store.createScreen(name, layoutComponent.name);
|
2019-10-07 07:03:41 +02:00
|
|
|
UIkit.modal(componentSelectorModal).hide();
|
|
|
|
}
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
const cancel = () => {
|
|
|
|
UIkit.modal(componentSelectorModal).hide();
|
2019-10-07 07:03:41 +02:00
|
|
|
}
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
const screenNameExists = (name) =>
|
|
|
|
some(s => s.name.toLowerCase() === name.toLowerCase())(screens)
|
|
|
|
|
2019-08-07 10:03:49 +02:00
|
|
|
</script>
|
|
|
|
|
2019-10-07 07:03:41 +02:00
|
|
|
<div bind:this={componentSelectorModal} id="new-component-modal" uk-modal>
|
|
|
|
<div class="uk-modal-dialog" uk-overflow-auto>
|
2019-08-14 23:11:59 +02:00
|
|
|
|
|
|
|
<div class="uk-modal-header">
|
2020-01-18 00:06:42 +01:00
|
|
|
<h1>New Screen</h1>
|
2019-08-14 23:11:59 +02:00
|
|
|
</div>
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
<div class="uk-modal-body uk-form-horizontal">
|
|
|
|
<div class="uk-margin">
|
|
|
|
<label class="uk-form-label">Name</label>
|
|
|
|
<div class="uk-form-controls">
|
|
|
|
<input class="uk-input uk-form-small"
|
|
|
|
class:uk-form-danger={saveAttempted && (name.length === 0 || screenNameExists(name))}
|
|
|
|
bind:value={name} >
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<div class="uk-margin">
|
|
|
|
<label class="uk-form-label">Layout Component</label>
|
|
|
|
<div class="uk-form-controls">
|
|
|
|
<select class="uk-select uk-form-small"
|
|
|
|
bind:value={layoutComponent}
|
|
|
|
class:uk-form-danger={saveAttempted && !layoutComponent}>
|
|
|
|
{#each layoutComponents as comp}
|
|
|
|
<option value={comp}>
|
|
|
|
{comp.componentName} - {comp.libName}
|
|
|
|
</option>
|
|
|
|
{/each}
|
|
|
|
</select>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<ButtonGroup style="float: right;">
|
|
|
|
<Button color="primary" grouped on:click={save}>Create Screen</Button>
|
|
|
|
<Button color="tertiary" grouped on:click={cancel}>Cancel</Button>
|
|
|
|
</ButtonGroup>
|
2019-10-07 07:03:41 +02:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
<style>
|
|
|
|
h1 {
|
|
|
|
font-size:1.2em;
|
|
|
|
}
|
2019-10-07 07:03:41 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
.component-option {
|
|
|
|
border-style: solid;
|
|
|
|
border-color: var(--slate);
|
|
|
|
border-width: 0 0 1px 0;
|
|
|
|
padding: 3px;
|
|
|
|
}
|
2019-10-07 07:03:41 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
.component-option:hover {
|
|
|
|
background-color: var(--lightslate);
|
|
|
|
}
|
2019-08-07 10:03:49 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
.component-name {
|
|
|
|
font-size: 11pt;
|
|
|
|
}
|
2019-10-07 07:03:41 +02:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
.lib-name {
|
|
|
|
font-size: 9pt;
|
2019-08-14 23:11:59 +02:00
|
|
|
}
|
|
|
|
|
2019-08-07 10:03:49 +02:00
|
|
|
</style>
|