2019-08-02 15:54:10 +02:00
|
|
|
<script>
|
|
|
|
|
|
|
|
import {
|
2020-01-18 00:06:42 +01:00
|
|
|
keys, map, some, includes,
|
|
|
|
cloneDeep, isEqual, sortBy,
|
|
|
|
filter, difference
|
2019-08-02 15:54:10 +02:00
|
|
|
} from "lodash/fp";
|
2019-08-14 23:11:59 +02:00
|
|
|
import { pipe } from "../common/core";
|
2020-01-18 00:06:42 +01:00
|
|
|
import { getInstanceProps } from "./pagesParsing/createProps";
|
2019-08-07 10:03:49 +02:00
|
|
|
import Checkbox from "../common/Checkbox.svelte";
|
|
|
|
import Textbox from "../common/Textbox.svelte";
|
|
|
|
import Dropdown from "../common/Dropdown.svelte";
|
2019-08-16 16:48:45 +02:00
|
|
|
import PropControl from "./PropControl.svelte";
|
|
|
|
import IconButton from "../common/IconButton.svelte";
|
2019-08-02 15:54:10 +02:00
|
|
|
|
2019-08-14 23:11:59 +02:00
|
|
|
export let componentInfo;
|
2019-08-16 16:48:45 +02:00
|
|
|
export let instanceProps = null;
|
2019-08-14 23:11:59 +02:00
|
|
|
export let onPropsChanged = () => {};
|
2020-01-24 15:30:17 +01:00
|
|
|
export let components;
|
2019-08-14 23:11:59 +02:00
|
|
|
|
|
|
|
let errors = [];
|
|
|
|
let props = {};
|
2019-08-16 16:48:45 +02:00
|
|
|
let propsDefinitions = [];
|
2019-08-19 09:51:01 +02:00
|
|
|
let isInstance = false;
|
2019-08-16 16:48:45 +02:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
const props_to_ignore = ['_component','_children', '_layout'];
|
2019-08-02 15:54:10 +02:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
$: propDefs = componentInfo && Object.entries(componentInfo).filter(([name])=> !props_to_ignore.includes(name));
|
2020-01-20 13:28:05 +01:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
function find_type(prop_name) {
|
|
|
|
if(!componentInfo._component) return;
|
|
|
|
return components.find(({name}) => name === componentInfo._component).props[prop_name];
|
2019-08-14 23:11:59 +02:00
|
|
|
}
|
2020-01-20 13:28:05 +01:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
let setProp = (name, value) => {
|
|
|
|
onPropsChanged(name, value);
|
2019-08-14 23:11:59 +02:00
|
|
|
}
|
2019-08-04 23:21:16 +02:00
|
|
|
|
2020-01-20 13:28:05 +01:00
|
|
|
const fieldHasError = (propName) =>
|
2019-08-14 23:11:59 +02:00
|
|
|
some(e => e.propName === propName)(errors);
|
2019-08-07 10:03:49 +02:00
|
|
|
|
2019-08-02 15:54:10 +02:00
|
|
|
</script>
|
|
|
|
|
2019-08-04 23:21:16 +02:00
|
|
|
<div class="root">
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
<form class="uk-form-stacked form-root">
|
2020-01-24 15:30:17 +01:00
|
|
|
{#each propDefs as [prop_name, prop_value], index}
|
2020-01-20 13:28:05 +01:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
<div class="prop-container">
|
2019-08-16 16:48:45 +02:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
<PropControl {setProp}
|
|
|
|
{prop_name}
|
|
|
|
{prop_value}
|
|
|
|
prop_type={find_type(prop_name)}
|
|
|
|
{index}
|
|
|
|
disabled={false} />
|
2019-08-16 16:48:45 +02:00
|
|
|
|
2020-01-24 15:30:17 +01:00
|
|
|
</div>
|
2020-01-20 13:28:05 +01:00
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
{/each}
|
|
|
|
|
2019-08-07 10:03:49 +02:00
|
|
|
</form>
|
2019-08-16 16:48:45 +02:00
|
|
|
|
2019-08-04 23:21:16 +02:00
|
|
|
</div>
|
2019-08-02 15:54:10 +02:00
|
|
|
|
|
|
|
|
|
|
|
<style>
|
2019-08-04 23:21:16 +02:00
|
|
|
|
|
|
|
.root {
|
2019-08-07 10:03:49 +02:00
|
|
|
font-size:10pt;
|
2020-01-18 00:06:42 +01:00
|
|
|
width: 100%;
|
2019-08-07 10:03:49 +02:00
|
|
|
}
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
.form-root {
|
|
|
|
display: flex;
|
|
|
|
flex-wrap: wrap;
|
2019-08-07 10:03:49 +02:00
|
|
|
}
|
|
|
|
|
2020-01-18 00:06:42 +01:00
|
|
|
.prop-container {
|
|
|
|
flex: 1 1 auto;
|
|
|
|
min-width: 250px;
|
2019-08-04 23:21:16 +02:00
|
|
|
}
|
|
|
|
|
2020-01-20 13:28:05 +01:00
|
|
|
</style>
|