From 5b4bce8b8f03c264d20e5e4c57642253f48e5e58 Mon Sep 17 00:00:00 2001 From: Martin McKeaveney Date: Sat, 2 May 2020 15:29:10 +0100 Subject: [PATCH] component library modules and definitions refactor - moved to backend. More routing and middleware reorganisation --- packages/bootstrap-components/.gitignore | 5 - packages/bootstrap-components/README.md | 33 - packages/bootstrap-components/components.json | 47 - .../bootstrap-components/dist/index.js.map | 1 - packages/bootstrap-components/package.json | 36 - .../public/budibase-logo.png | Bin 12702 -> 0 bytes .../bootstrap-components/public/bundle.css | 13 - .../public/bundle.css.map | 30 - .../bootstrap-components/public/bundle.js | 33412 ---------------- .../bootstrap-components/public/bundle.js.map | 210 - .../public/clientAppDefinition.js | 103 - .../bootstrap-components/public/favicon.png | Bin 3127 -> 0 bytes .../bootstrap-components/public/global.css | 62 - .../bootstrap-components/public/index.html | 18 - .../bootstrap-components/rollup.config.js | 20 - .../bootstrap-components/rollup.testconfig.js | 131 - .../scripts/publishDev.js | 86 - packages/bootstrap-components/src/Form.svelte | 44 - packages/bootstrap-components/src/Nav.svelte | 119 - .../src/Test/TestApp.svelte | 34 - .../src/Test/createApp.js | 43 - .../bootstrap-components/src/Test/props.js | 247 - .../bootstrap-components/src/Test/testMain.js | 7 - .../bootstrap-components/src/buildStyle.js | 9 - packages/bootstrap-components/src/cssVars.js | 19 - .../bootstrap-components/src/emptyProps.js | 1 - packages/bootstrap-components/src/index.js | 2 - .../builder/src/builderStore/generate_css.js | 3 +- .../builderStore/loadComponentLibraries.js | 95 +- .../builder/src/builderStore/store/backend.js | 7 - .../builder/src/builderStore/store/index.js | 238 +- .../actionsAndTriggers/ActionView.svelte | 133 - .../actionsAndTriggers/Actions.svelte | 108 - .../ActionsAndTriggersRoot.svelte | 135 - .../actionsAndTriggers/TriggerView.svelte | 74 - .../actionsAndTriggers/Triggers.svelte | 93 - .../components/common/DropdownButton.svelte | 67 - .../ModelDataTable/ModelDataTable.svelte | 1 - .../CreateEditModel/CreateEditModel.svelte | 3 +- .../modals/CreateEditModel/FieldView.svelte | 4 - .../modals/CreateEditRecord.svelte | 5 - .../nav/SchemaManagementDrawer.svelte | 1 - .../CurrentItemPreview.svelte | 2 +- .../userInterface/AppPreview/index.js | 1 + .../ComponentSelectionList.svelte | 62 +- .../userInterface/ComponentsHierarchy.svelte | 2 - .../ComponentsHierarchyChildren.svelte | 3 +- .../EventsEditor/EventsEditor.svelte | 4 +- .../components/userInterface/NewScreen.svelte | 34 +- .../userInterface/PageLayout.svelte | 24 +- .../components/userInterface/PageView.svelte | 7 +- .../components/userInterface/PropsView.svelte | 5 +- .../userInterface/UserInterfaceRoot.svelte | 4 +- .../userInterface/pagesParsing/createProps.js | 57 +- .../pagesParsing/findDependencies.js | 80 - .../pagesParsing/searchComponents.js | 3 +- .../pagesParsing/splitRootComponentName.js | 3 +- .../userInterface/pagesParsing/types.js | 142 +- .../pagesParsing/validatePages.js | 64 - .../index.js} | 4 +- packages/builder/src/global.css | 4 + .../src/pages/[application]/_layout.svelte | 11 +- .../backend/database/index.svelte | 3 - packages/builder/tests/validatePages.spec.js | 95 - packages/cli/package.json | 1 - .../appDirectoryTemplate/pages/main/page.json | 19 + .../pages/unauthenticated/page.json | 19 + packages/cli/src/commands/new/newHandler.js | 1 - packages/cli/src/common.js | 31 +- packages/cli/yarn.lock | 3440 +- packages/client/src/createApp.js | 11 +- packages/client/src/index.js | 3 +- packages/client/src/state/eventHandlers.js | 18 +- packages/client/src/state/stateManager.js | 3 +- packages/datastores/.babelrc | 5 - packages/datastores/.gitignore | 1 - packages/datastores/.npmignore | 5 - packages/datastores/.vscode/launch.json | 20 - packages/datastores/config.js | 34 - packages/datastores/config.template.js | 26 - packages/datastores/datastores/azure-blob.js | 81 - packages/datastores/datastores/local.js | 112 - packages/datastores/datastores/memory.js | 133 - packages/datastores/index.js | 28 - packages/datastores/package.json | 39 - packages/datastores/tests/diagnosticPlugin.js | 26 - packages/datastores/tests/helpers.js | 13 - packages/datastores/tests/index.js | 60 - packages/datastores/tests/records.js | 69 - packages/datastores/tests/setup.js | 61 - packages/datastores/yarn.lock | 2179 - .../server/api/controllers/application.js | 4 + packages/server/api/controllers/component.js | 32 + packages/server/api/controllers/static.js | 27 +- packages/server/api/index.js | 44 +- packages/server/api/routes/authenticated.js | 16 +- packages/server/api/routes/components.js | 35 +- packages/server/api/routes/neo/component.js | 9 + packages/server/api/routes/neo/static.js | 3 +- packages/server/package.json | 4 +- packages/server/routes/neo/client.js | 11 - packages/server/routes/neo/page.js | 12 - packages/server/routes/neo/screen.js | 12 - packages/server/routes/neo/static.js | 14 - packages/server/tests/createNewApp.js | 1 - packages/server/tests/multipleInstances.js | 223 - packages/server/tests/testApp.js | 157 - packages/server/utilities/budibaseApi.js | 84 - .../utilities/builder/componentLibraryInfo.js | 2 +- .../server/utilities/builder/componentTree.js | 649 + packages/server/utilities/builder/index.js | 5 +- packages/server/utilities/datastore.js | 2 - packages/server/yarn.lock | 40 +- 113 files changed, 1207 insertions(+), 42930 deletions(-) delete mode 100644 packages/bootstrap-components/.gitignore delete mode 100644 packages/bootstrap-components/README.md delete mode 100644 packages/bootstrap-components/components.json delete mode 100644 packages/bootstrap-components/dist/index.js.map delete mode 100644 packages/bootstrap-components/package.json delete mode 100644 packages/bootstrap-components/public/budibase-logo.png delete mode 100644 packages/bootstrap-components/public/bundle.css delete mode 100644 packages/bootstrap-components/public/bundle.css.map delete mode 100644 packages/bootstrap-components/public/bundle.js delete mode 100644 packages/bootstrap-components/public/bundle.js.map delete mode 100644 packages/bootstrap-components/public/clientAppDefinition.js delete mode 100644 packages/bootstrap-components/public/favicon.png delete mode 100644 packages/bootstrap-components/public/global.css delete mode 100644 packages/bootstrap-components/public/index.html delete mode 100644 packages/bootstrap-components/rollup.config.js delete mode 100644 packages/bootstrap-components/rollup.testconfig.js delete mode 100644 packages/bootstrap-components/scripts/publishDev.js delete mode 100644 packages/bootstrap-components/src/Form.svelte delete mode 100644 packages/bootstrap-components/src/Nav.svelte delete mode 100644 packages/bootstrap-components/src/Test/TestApp.svelte delete mode 100644 packages/bootstrap-components/src/Test/createApp.js delete mode 100644 packages/bootstrap-components/src/Test/props.js delete mode 100644 packages/bootstrap-components/src/Test/testMain.js delete mode 100644 packages/bootstrap-components/src/buildStyle.js delete mode 100644 packages/bootstrap-components/src/cssVars.js delete mode 100644 packages/bootstrap-components/src/emptyProps.js delete mode 100644 packages/bootstrap-components/src/index.js delete mode 100644 packages/builder/src/components/actionsAndTriggers/ActionView.svelte delete mode 100644 packages/builder/src/components/actionsAndTriggers/Actions.svelte delete mode 100644 packages/builder/src/components/actionsAndTriggers/ActionsAndTriggersRoot.svelte delete mode 100644 packages/builder/src/components/actionsAndTriggers/TriggerView.svelte delete mode 100644 packages/builder/src/components/actionsAndTriggers/Triggers.svelte delete mode 100644 packages/builder/src/components/common/DropdownButton.svelte rename packages/builder/src/components/userInterface/{ => AppPreview}/CurrentItemPreview.svelte (98%) create mode 100644 packages/builder/src/components/userInterface/AppPreview/index.js delete mode 100644 packages/builder/src/components/userInterface/pagesParsing/findDependencies.js delete mode 100644 packages/builder/src/components/userInterface/pagesParsing/validatePages.js rename packages/builder/src/{components/userInterface/pagesParsing/defaultPagesObject.js => constants/index.js} (88%) delete mode 100644 packages/builder/tests/validatePages.spec.js create mode 100644 packages/cli/src/commands/new/appDirectoryTemplate/pages/main/page.json create mode 100644 packages/cli/src/commands/new/appDirectoryTemplate/pages/unauthenticated/page.json delete mode 100644 packages/datastores/.babelrc delete mode 100644 packages/datastores/.gitignore delete mode 100644 packages/datastores/.npmignore delete mode 100644 packages/datastores/.vscode/launch.json delete mode 100644 packages/datastores/config.js delete mode 100644 packages/datastores/config.template.js delete mode 100644 packages/datastores/datastores/azure-blob.js delete mode 100644 packages/datastores/datastores/local.js delete mode 100644 packages/datastores/datastores/memory.js delete mode 100644 packages/datastores/index.js delete mode 100644 packages/datastores/package.json delete mode 100644 packages/datastores/tests/diagnosticPlugin.js delete mode 100644 packages/datastores/tests/helpers.js delete mode 100644 packages/datastores/tests/index.js delete mode 100644 packages/datastores/tests/records.js delete mode 100644 packages/datastores/tests/setup.js delete mode 100644 packages/datastores/yarn.lock create mode 100644 packages/server/api/controllers/component.js create mode 100644 packages/server/api/routes/neo/component.js delete mode 100644 packages/server/routes/neo/client.js delete mode 100644 packages/server/routes/neo/page.js delete mode 100644 packages/server/routes/neo/screen.js delete mode 100644 packages/server/routes/neo/static.js delete mode 100644 packages/server/tests/multipleInstances.js delete mode 100644 packages/server/tests/testApp.js delete mode 100644 packages/server/utilities/budibaseApi.js create mode 100644 packages/server/utilities/builder/componentTree.js delete mode 100644 packages/server/utilities/datastore.js diff --git a/packages/bootstrap-components/.gitignore b/packages/bootstrap-components/.gitignore deleted file mode 100644 index 2986122cff..0000000000 --- a/packages/bootstrap-components/.gitignore +++ /dev/null @@ -1,5 +0,0 @@ -.DS_Store -node_modules -yarn.lock -package-lock.json -dist/index.js diff --git a/packages/bootstrap-components/README.md b/packages/bootstrap-components/README.md deleted file mode 100644 index 71e531fc9d..0000000000 --- a/packages/bootstrap-components/README.md +++ /dev/null @@ -1,33 +0,0 @@ -*Psst — looking for an app template? Go here --> [sveltejs/template](https://github.com/sveltejs/template)* - ---- - -# component-template - -A base for building shareable Svelte components. Clone it with [degit](https://github.com/Rich-Harris/degit): - -```bash -npx degit sveltejs/component-template my-new-component -cd my-new-component -npm install # or yarn -``` - -Your component's source code lives in `src/index.html`. - -TODO - -* [ ] some firm opinions about the best way to test components -* [ ] update `degit` so that it automates some of the setup work - - -## Setting up - -* Run `npm init` (or `yarn init`) -* Replace this README with your own - - -## Consuming components - -Your package.json has a `"svelte"` field pointing to `src/index.html`, which allows Svelte apps to import the source code directly, if they are using a bundler plugin like [rollup-plugin-svelte](https://github.com/rollup/rollup-plugin-svelte) or [svelte-loader](https://github.com/sveltejs/svelte-loader) (where [`resolve.mainFields`](https://webpack.js.org/configuration/resolve/#resolve-mainfields) in your webpack config includes `"svelte"`). **This is recommended.** - -For everyone else, `npm run build` will bundle your component's source code into a plain JavaScript module (`index.mjs`) and a UMD script (`index.js`). This will happen automatically when you publish your component to npm, courtesy of the `prepublishOnly` hook in package.json. diff --git a/packages/bootstrap-components/components.json b/packages/bootstrap-components/components.json deleted file mode 100644 index 70d4668213..0000000000 --- a/packages/bootstrap-components/components.json +++ /dev/null @@ -1,47 +0,0 @@ -{ - "_lib": "./dist/index.js", - "form" : { - "importPath": "Form", - "name": "Form", - "description": "A form - allgned fields with labels", - "props" : { - "containerClass": "string", - "formControls": { - "type":"array", - "elementDefinition": { - "label": "string", - "control":"component", - "controlPosition": { - "type":"options", - "options": ["Before Label","After Label"], - "default": "After Label" - } - } - } - }, - "tags": ["form"] - }, - "nav": { - "importPath": "Nav", - "name": "Nav", - "description": "A nav - a side bar of buttons that control the currently active component", - "props" : { - "items": { - "type": "array", - "elementDefinition" : { - "title": "string", - "component": "component" - } - }, - "selectedItem":"string", - "pills":"bool", - "orientation":{"type":"options", "options": ["horizontal", "vertical"]}, - "alignment":{"type":"options", "options": ["start", "center", "end"]}, - "fill":"bool", - "hideNavBar":"bool", - "className": "string" - - }, - "tags": ["nav", "navigation", "sidebar"] - } -} \ No newline at end of file diff --git a/packages/bootstrap-components/dist/index.js.map b/packages/bootstrap-components/dist/index.js.map deleted file mode 100644 index eb9dac7595..0000000000 --- a/packages/bootstrap-components/dist/index.js.map +++ /dev/null @@ -1 +0,0 @@ -{"version":3,"file":"index.js","sources":["../node_modules/svelte/internal/index.js","../src/Button.svelte","../src/Textbox.svelte","../src/Form.svelte","../src/api.js","../src/Login.svelte","../src/buildStyle.js","../src/Grid.svelte","../src/StackPanel.svelte"],"sourcesContent":["function noop() { }\nconst identity = x => x;\nfunction assign(tar, src) {\n // @ts-ignore\n for (const k in src)\n tar[k] = src[k];\n return tar;\n}\nfunction is_promise(value) {\n return value && typeof value === 'object' && typeof value.then === 'function';\n}\nfunction add_location(element, file, line, column, char) {\n element.__svelte_meta = {\n loc: { file, line, column, char }\n };\n}\nfunction run(fn) {\n return fn();\n}\nfunction blank_object() {\n return Object.create(null);\n}\nfunction run_all(fns) {\n fns.forEach(run);\n}\nfunction is_function(thing) {\n return typeof thing === 'function';\n}\nfunction safe_not_equal(a, b) {\n return a != a ? b == b : a !== b || ((a && typeof a === 'object') || typeof a === 'function');\n}\nfunction not_equal(a, b) {\n return a != a ? b == b : a !== b;\n}\nfunction validate_store(store, name) {\n if (!store || typeof store.subscribe !== 'function') {\n throw new Error(`'${name}' is not a store with a 'subscribe' method`);\n }\n}\nfunction subscribe(store, callback) {\n const unsub = store.subscribe(callback);\n return unsub.unsubscribe ? () => unsub.unsubscribe() : unsub;\n}\nfunction get_store_value(store) {\n let value;\n subscribe(store, _ => value = _)();\n return value;\n}\nfunction component_subscribe(component, store, callback) {\n component.$$.on_destroy.push(subscribe(store, callback));\n}\nfunction create_slot(definition, ctx, fn) {\n if (definition) {\n const slot_ctx = get_slot_context(definition, ctx, fn);\n return definition[0](slot_ctx);\n }\n}\nfunction get_slot_context(definition, ctx, fn) {\n return definition[1]\n ? assign({}, assign(ctx.$$scope.ctx, definition[1](fn ? fn(ctx) : {})))\n : ctx.$$scope.ctx;\n}\nfunction get_slot_changes(definition, ctx, changed, fn) {\n return definition[1]\n ? assign({}, assign(ctx.$$scope.changed || {}, definition[1](fn ? fn(changed) : {})))\n : ctx.$$scope.changed || {};\n}\nfunction exclude_internal_props(props) {\n const result = {};\n for (const k in props)\n if (k[0] !== '$')\n result[k] = props[k];\n return result;\n}\nfunction once(fn) {\n let ran = false;\n return function (...args) {\n if (ran)\n return;\n ran = true;\n fn.call(this, ...args);\n };\n}\nfunction null_to_empty(value) {\n return value == null ? '' : value;\n}\nfunction set_store_value(store, ret, value = ret) {\n store.set(value);\n return ret;\n}\n\nconst is_client = typeof window !== 'undefined';\nlet now = is_client\n ? () => window.performance.now()\n : () => Date.now();\nlet raf = is_client ? cb => requestAnimationFrame(cb) : noop;\n// used internally for testing\nfunction set_now(fn) {\n now = fn;\n}\nfunction set_raf(fn) {\n raf = fn;\n}\n\nconst tasks = new Set();\nlet running = false;\nfunction run_tasks() {\n tasks.forEach(task => {\n if (!task[0](now())) {\n tasks.delete(task);\n task[1]();\n }\n });\n running = tasks.size > 0;\n if (running)\n raf(run_tasks);\n}\nfunction clear_loops() {\n // for testing...\n tasks.forEach(task => tasks.delete(task));\n running = false;\n}\nfunction loop(fn) {\n let task;\n if (!running) {\n running = true;\n raf(run_tasks);\n }\n return {\n promise: new Promise(fulfil => {\n tasks.add(task = [fn, fulfil]);\n }),\n abort() {\n tasks.delete(task);\n }\n };\n}\n\nfunction append(target, node) {\n target.appendChild(node);\n}\nfunction insert(target, node, anchor) {\n target.insertBefore(node, anchor || null);\n}\nfunction detach(node) {\n node.parentNode.removeChild(node);\n}\nfunction destroy_each(iterations, detaching) {\n for (let i = 0; i < iterations.length; i += 1) {\n if (iterations[i])\n iterations[i].d(detaching);\n }\n}\nfunction element(name) {\n return document.createElement(name);\n}\nfunction element_is(name, is) {\n return document.createElement(name, { is });\n}\nfunction object_without_properties(obj, exclude) {\n // eslint-disable-next-line @typescript-eslint/no-object-literal-type-assertion\n const target = {};\n for (const k in obj) {\n if (Object.prototype.hasOwnProperty.call(obj, k)\n // @ts-ignore\n && exclude.indexOf(k) === -1) {\n // @ts-ignore\n target[k] = obj[k];\n }\n }\n return target;\n}\nfunction svg_element(name) {\n return document.createElementNS('http://www.w3.org/2000/svg', name);\n}\nfunction text(data) {\n return document.createTextNode(data);\n}\nfunction space() {\n return text(' ');\n}\nfunction empty() {\n return text('');\n}\nfunction listen(node, event, handler, options) {\n node.addEventListener(event, handler, options);\n return () => node.removeEventListener(event, handler, options);\n}\nfunction prevent_default(fn) {\n return function (event) {\n event.preventDefault();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction stop_propagation(fn) {\n return function (event) {\n event.stopPropagation();\n // @ts-ignore\n return fn.call(this, event);\n };\n}\nfunction self(fn) {\n return function (event) {\n // @ts-ignore\n if (event.target === this)\n fn.call(this, event);\n };\n}\nfunction attr(node, attribute, value) {\n if (value == null)\n node.removeAttribute(attribute);\n else\n node.setAttribute(attribute, value);\n}\nfunction set_attributes(node, attributes) {\n for (const key in attributes) {\n if (key === 'style') {\n node.style.cssText = attributes[key];\n }\n else if (key in node) {\n node[key] = attributes[key];\n }\n else {\n attr(node, key, attributes[key]);\n }\n }\n}\nfunction set_svg_attributes(node, attributes) {\n for (const key in attributes) {\n attr(node, key, attributes[key]);\n }\n}\nfunction set_custom_element_data(node, prop, value) {\n if (prop in node) {\n node[prop] = value;\n }\n else {\n attr(node, prop, value);\n }\n}\nfunction xlink_attr(node, attribute, value) {\n node.setAttributeNS('http://www.w3.org/1999/xlink', attribute, value);\n}\nfunction get_binding_group_value(group) {\n const value = [];\n for (let i = 0; i < group.length; i += 1) {\n if (group[i].checked)\n value.push(group[i].__value);\n }\n return value;\n}\nfunction to_number(value) {\n return value === '' ? undefined : +value;\n}\nfunction time_ranges_to_array(ranges) {\n const array = [];\n for (let i = 0; i < ranges.length; i += 1) {\n array.push({ start: ranges.start(i), end: ranges.end(i) });\n }\n return array;\n}\nfunction children(element) {\n return Array.from(element.childNodes);\n}\nfunction claim_element(nodes, name, attributes, svg) {\n for (let i = 0; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeName === name) {\n for (let j = 0; j < node.attributes.length; j += 1) {\n const attribute = node.attributes[j];\n if (!attributes[attribute.name])\n node.removeAttribute(attribute.name);\n }\n return nodes.splice(i, 1)[0]; // TODO strip unwanted attributes\n }\n }\n return svg ? svg_element(name) : element(name);\n}\nfunction claim_text(nodes, data) {\n for (let i = 0; i < nodes.length; i += 1) {\n const node = nodes[i];\n if (node.nodeType === 3) {\n node.data = '' + data;\n return nodes.splice(i, 1)[0];\n }\n }\n return text(data);\n}\nfunction claim_space(nodes) {\n return claim_text(nodes, ' ');\n}\nfunction set_data(text, data) {\n data = '' + data;\n if (text.data !== data)\n text.data = data;\n}\nfunction set_input_value(input, value) {\n if (value != null || input.value) {\n input.value = value;\n }\n}\nfunction set_input_type(input, type) {\n try {\n input.type = type;\n }\n catch (e) {\n // do nothing\n }\n}\nfunction set_style(node, key, value, important) {\n node.style.setProperty(key, value, important ? 'important' : '');\n}\nfunction select_option(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n if (option.__value === value) {\n option.selected = true;\n return;\n }\n }\n}\nfunction select_options(select, value) {\n for (let i = 0; i < select.options.length; i += 1) {\n const option = select.options[i];\n option.selected = ~value.indexOf(option.__value);\n }\n}\nfunction select_value(select) {\n const selected_option = select.querySelector(':checked') || select.options[0];\n return selected_option && selected_option.__value;\n}\nfunction select_multiple_value(select) {\n return [].map.call(select.querySelectorAll(':checked'), option => option.__value);\n}\nfunction add_resize_listener(element, fn) {\n if (getComputedStyle(element).position === 'static') {\n element.style.position = 'relative';\n }\n const object = document.createElement('object');\n object.setAttribute('style', 'display: block; position: absolute; top: 0; left: 0; height: 100%; width: 100%; overflow: hidden; pointer-events: none; z-index: -1;');\n object.type = 'text/html';\n object.tabIndex = -1;\n let win;\n object.onload = () => {\n win = object.contentDocument.defaultView;\n win.addEventListener('resize', fn);\n };\n if (/Trident/.test(navigator.userAgent)) {\n element.appendChild(object);\n object.data = 'about:blank';\n }\n else {\n object.data = 'about:blank';\n element.appendChild(object);\n }\n return {\n cancel: () => {\n win && win.removeEventListener && win.removeEventListener('resize', fn);\n element.removeChild(object);\n }\n };\n}\nfunction toggle_class(element, name, toggle) {\n element.classList[toggle ? 'add' : 'remove'](name);\n}\nfunction custom_event(type, detail) {\n const e = document.createEvent('CustomEvent');\n e.initCustomEvent(type, false, false, detail);\n return e;\n}\nclass HtmlTag {\n constructor(html, anchor = null) {\n this.e = element('div');\n this.a = anchor;\n this.u(html);\n }\n m(target, anchor = null) {\n for (let i = 0; i < this.n.length; i += 1) {\n insert(target, this.n[i], anchor);\n }\n this.t = target;\n }\n u(html) {\n this.e.innerHTML = html;\n this.n = Array.from(this.e.childNodes);\n }\n p(html) {\n this.d();\n this.u(html);\n this.m(this.t, this.a);\n }\n d() {\n this.n.forEach(detach);\n }\n}\n\nlet stylesheet;\nlet active = 0;\nlet current_rules = {};\n// https://github.com/darkskyapp/string-hash/blob/master/index.js\nfunction hash(str) {\n let hash = 5381;\n let i = str.length;\n while (i--)\n hash = ((hash << 5) - hash) ^ str.charCodeAt(i);\n return hash >>> 0;\n}\nfunction create_rule(node, a, b, duration, delay, ease, fn, uid = 0) {\n const step = 16.666 / duration;\n let keyframes = '{\\n';\n for (let p = 0; p <= 1; p += step) {\n const t = a + (b - a) * ease(p);\n keyframes += p * 100 + `%{${fn(t, 1 - t)}}\\n`;\n }\n const rule = keyframes + `100% {${fn(b, 1 - b)}}\\n}`;\n const name = `__svelte_${hash(rule)}_${uid}`;\n if (!current_rules[name]) {\n if (!stylesheet) {\n const style = element('style');\n document.head.appendChild(style);\n stylesheet = style.sheet;\n }\n current_rules[name] = true;\n stylesheet.insertRule(`@keyframes ${name} ${rule}`, stylesheet.cssRules.length);\n }\n const animation = node.style.animation || '';\n node.style.animation = `${animation ? `${animation}, ` : ``}${name} ${duration}ms linear ${delay}ms 1 both`;\n active += 1;\n return name;\n}\nfunction delete_rule(node, name) {\n node.style.animation = (node.style.animation || '')\n .split(', ')\n .filter(name\n ? anim => anim.indexOf(name) < 0 // remove specific animation\n : anim => anim.indexOf('__svelte') === -1 // remove all Svelte animations\n )\n .join(', ');\n if (name && !--active)\n clear_rules();\n}\nfunction clear_rules() {\n raf(() => {\n if (active)\n return;\n let i = stylesheet.cssRules.length;\n while (i--)\n stylesheet.deleteRule(i);\n current_rules = {};\n });\n}\n\nfunction create_animation(node, from, fn, params) {\n if (!from)\n return noop;\n const to = node.getBoundingClientRect();\n if (from.left === to.left && from.right === to.right && from.top === to.top && from.bottom === to.bottom)\n return noop;\n const { delay = 0, duration = 300, easing = identity, \n // @ts-ignore todo: should this be separated from destructuring? Or start/end added to public api and documentation?\n start: start_time = now() + delay, \n // @ts-ignore todo:\n end = start_time + duration, tick = noop, css } = fn(node, { from, to }, params);\n let running = true;\n let started = false;\n let name;\n function start() {\n if (css) {\n name = create_rule(node, 0, 1, duration, delay, easing, css);\n }\n if (!delay) {\n started = true;\n }\n }\n function stop() {\n if (css)\n delete_rule(node, name);\n running = false;\n }\n loop(now => {\n if (!started && now >= start_time) {\n started = true;\n }\n if (started && now >= end) {\n tick(1, 0);\n stop();\n }\n if (!running) {\n return false;\n }\n if (started) {\n const p = now - start_time;\n const t = 0 + 1 * easing(p / duration);\n tick(t, 1 - t);\n }\n return true;\n });\n start();\n tick(0, 1);\n return stop;\n}\nfunction fix_position(node) {\n const style = getComputedStyle(node);\n if (style.position !== 'absolute' && style.position !== 'fixed') {\n const { width, height } = style;\n const a = node.getBoundingClientRect();\n node.style.position = 'absolute';\n node.style.width = width;\n node.style.height = height;\n add_transform(node, a);\n }\n}\nfunction add_transform(node, a) {\n const b = node.getBoundingClientRect();\n if (a.left !== b.left || a.top !== b.top) {\n const style = getComputedStyle(node);\n const transform = style.transform === 'none' ? '' : style.transform;\n node.style.transform = `${transform} translate(${a.left - b.left}px, ${a.top - b.top}px)`;\n }\n}\n\nlet current_component;\nfunction set_current_component(component) {\n current_component = component;\n}\nfunction get_current_component() {\n if (!current_component)\n throw new Error(`Function called outside component initialization`);\n return current_component;\n}\nfunction beforeUpdate(fn) {\n get_current_component().$$.before_update.push(fn);\n}\nfunction onMount(fn) {\n get_current_component().$$.on_mount.push(fn);\n}\nfunction afterUpdate(fn) {\n get_current_component().$$.after_update.push(fn);\n}\nfunction onDestroy(fn) {\n get_current_component().$$.on_destroy.push(fn);\n}\nfunction createEventDispatcher() {\n const component = current_component;\n return (type, detail) => {\n const callbacks = component.$$.callbacks[type];\n if (callbacks) {\n // TODO are there situations where events could be dispatched\n // in a server (non-DOM) environment?\n const event = custom_event(type, detail);\n callbacks.slice().forEach(fn => {\n fn.call(component, event);\n });\n }\n };\n}\nfunction setContext(key, context) {\n get_current_component().$$.context.set(key, context);\n}\nfunction getContext(key) {\n return get_current_component().$$.context.get(key);\n}\n// TODO figure out if we still want to support\n// shorthand events, or if we want to implement\n// a real bubbling mechanism\nfunction bubble(component, event) {\n const callbacks = component.$$.callbacks[event.type];\n if (callbacks) {\n callbacks.slice().forEach(fn => fn(event));\n }\n}\n\nconst dirty_components = [];\nconst intros = { enabled: false };\nconst binding_callbacks = [];\nconst render_callbacks = [];\nconst flush_callbacks = [];\nconst resolved_promise = Promise.resolve();\nlet update_scheduled = false;\nfunction schedule_update() {\n if (!update_scheduled) {\n update_scheduled = true;\n resolved_promise.then(flush);\n }\n}\nfunction tick() {\n schedule_update();\n return resolved_promise;\n}\nfunction add_render_callback(fn) {\n render_callbacks.push(fn);\n}\nfunction add_flush_callback(fn) {\n flush_callbacks.push(fn);\n}\nfunction flush() {\n const seen_callbacks = new Set();\n do {\n // first, call beforeUpdate functions\n // and update components\n while (dirty_components.length) {\n const component = dirty_components.shift();\n set_current_component(component);\n update(component.$$);\n }\n while (binding_callbacks.length)\n binding_callbacks.pop()();\n // then, once components are updated, call\n // afterUpdate functions. This may cause\n // subsequent updates...\n for (let i = 0; i < render_callbacks.length; i += 1) {\n const callback = render_callbacks[i];\n if (!seen_callbacks.has(callback)) {\n callback();\n // ...so guard against infinite loops\n seen_callbacks.add(callback);\n }\n }\n render_callbacks.length = 0;\n } while (dirty_components.length);\n while (flush_callbacks.length) {\n flush_callbacks.pop()();\n }\n update_scheduled = false;\n}\nfunction update($$) {\n if ($$.fragment) {\n $$.update($$.dirty);\n run_all($$.before_update);\n $$.fragment.p($$.dirty, $$.ctx);\n $$.dirty = null;\n $$.after_update.forEach(add_render_callback);\n }\n}\n\nlet promise;\nfunction wait() {\n if (!promise) {\n promise = Promise.resolve();\n promise.then(() => {\n promise = null;\n });\n }\n return promise;\n}\nfunction dispatch(node, direction, kind) {\n node.dispatchEvent(custom_event(`${direction ? 'intro' : 'outro'}${kind}`));\n}\nconst outroing = new Set();\nlet outros;\nfunction group_outros() {\n outros = {\n r: 0,\n c: [],\n p: outros // parent group\n };\n}\nfunction check_outros() {\n if (!outros.r) {\n run_all(outros.c);\n }\n outros = outros.p;\n}\nfunction transition_in(block, local) {\n if (block && block.i) {\n outroing.delete(block);\n block.i(local);\n }\n}\nfunction transition_out(block, local, detach, callback) {\n if (block && block.o) {\n if (outroing.has(block))\n return;\n outroing.add(block);\n outros.c.push(() => {\n outroing.delete(block);\n if (callback) {\n if (detach)\n block.d(1);\n callback();\n }\n });\n block.o(local);\n }\n}\nconst null_transition = { duration: 0 };\nfunction create_in_transition(node, fn, params) {\n let config = fn(node, params);\n let running = false;\n let animation_name;\n let task;\n let uid = 0;\n function cleanup() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 0, 1, duration, delay, easing, css, uid++);\n tick(0, 1);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n if (task)\n task.abort();\n running = true;\n add_render_callback(() => dispatch(node, true, 'start'));\n task = loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(1, 0);\n dispatch(node, true, 'end');\n cleanup();\n return running = false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(t, 1 - t);\n }\n }\n return running;\n });\n }\n let started = false;\n return {\n start() {\n if (started)\n return;\n delete_rule(node);\n if (is_function(config)) {\n config = config();\n wait().then(go);\n }\n else {\n go();\n }\n },\n invalidate() {\n started = false;\n },\n end() {\n if (running) {\n cleanup();\n running = false;\n }\n }\n };\n}\nfunction create_out_transition(node, fn, params) {\n let config = fn(node, params);\n let running = true;\n let animation_name;\n const group = outros;\n group.r += 1;\n function go() {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n if (css)\n animation_name = create_rule(node, 1, 0, duration, delay, easing, css);\n const start_time = now() + delay;\n const end_time = start_time + duration;\n add_render_callback(() => dispatch(node, false, 'start'));\n loop(now => {\n if (running) {\n if (now >= end_time) {\n tick(0, 1);\n dispatch(node, false, 'end');\n if (!--group.r) {\n // this will result in `end()` being called,\n // so we don't need to clean up here\n run_all(group.c);\n }\n return false;\n }\n if (now >= start_time) {\n const t = easing((now - start_time) / duration);\n tick(1 - t, t);\n }\n }\n return running;\n });\n }\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go();\n });\n }\n else {\n go();\n }\n return {\n end(reset) {\n if (reset && config.tick) {\n config.tick(1, 0);\n }\n if (running) {\n if (animation_name)\n delete_rule(node, animation_name);\n running = false;\n }\n }\n };\n}\nfunction create_bidirectional_transition(node, fn, params, intro) {\n let config = fn(node, params);\n let t = intro ? 0 : 1;\n let running_program = null;\n let pending_program = null;\n let animation_name = null;\n function clear_animation() {\n if (animation_name)\n delete_rule(node, animation_name);\n }\n function init(program, duration) {\n const d = program.b - t;\n duration *= Math.abs(d);\n return {\n a: t,\n b: program.b,\n d,\n duration,\n start: program.start,\n end: program.start + duration,\n group: program.group\n };\n }\n function go(b) {\n const { delay = 0, duration = 300, easing = identity, tick = noop, css } = config || null_transition;\n const program = {\n start: now() + delay,\n b\n };\n if (!b) {\n // @ts-ignore todo: improve typings\n program.group = outros;\n outros.r += 1;\n }\n if (running_program) {\n pending_program = program;\n }\n else {\n // if this is an intro, and there's a delay, we need to do\n // an initial tick and/or apply CSS animation immediately\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, b, duration, delay, easing, css);\n }\n if (b)\n tick(0, 1);\n running_program = init(program, duration);\n add_render_callback(() => dispatch(node, b, 'start'));\n loop(now => {\n if (pending_program && now > pending_program.start) {\n running_program = init(pending_program, duration);\n pending_program = null;\n dispatch(node, running_program.b, 'start');\n if (css) {\n clear_animation();\n animation_name = create_rule(node, t, running_program.b, running_program.duration, 0, easing, config.css);\n }\n }\n if (running_program) {\n if (now >= running_program.end) {\n tick(t = running_program.b, 1 - t);\n dispatch(node, running_program.b, 'end');\n if (!pending_program) {\n // we're done\n if (running_program.b) {\n // intro — we can tidy up immediately\n clear_animation();\n }\n else {\n // outro — needs to be coordinated\n if (!--running_program.group.r)\n run_all(running_program.group.c);\n }\n }\n running_program = null;\n }\n else if (now >= running_program.start) {\n const p = now - running_program.start;\n t = running_program.a + running_program.d * easing(p / running_program.duration);\n tick(t, 1 - t);\n }\n }\n return !!(running_program || pending_program);\n });\n }\n }\n return {\n run(b) {\n if (is_function(config)) {\n wait().then(() => {\n // @ts-ignore\n config = config();\n go(b);\n });\n }\n else {\n go(b);\n }\n },\n end() {\n clear_animation();\n running_program = pending_program = null;\n }\n };\n}\n\nfunction handle_promise(promise, info) {\n const token = info.token = {};\n function update(type, index, key, value) {\n if (info.token !== token)\n return;\n info.resolved = key && { [key]: value };\n const child_ctx = assign(assign({}, info.ctx), info.resolved);\n const block = type && (info.current = type)(child_ctx);\n if (info.block) {\n if (info.blocks) {\n info.blocks.forEach((block, i) => {\n if (i !== index && block) {\n group_outros();\n transition_out(block, 1, 1, () => {\n info.blocks[i] = null;\n });\n check_outros();\n }\n });\n }\n else {\n info.block.d(1);\n }\n block.c();\n transition_in(block, 1);\n block.m(info.mount(), info.anchor);\n flush();\n }\n info.block = block;\n if (info.blocks)\n info.blocks[index] = block;\n }\n if (is_promise(promise)) {\n const current_component = get_current_component();\n promise.then(value => {\n set_current_component(current_component);\n update(info.then, 1, info.value, value);\n set_current_component(null);\n }, error => {\n set_current_component(current_component);\n update(info.catch, 2, info.error, error);\n set_current_component(null);\n });\n // if we previously had a then/catch block, destroy it\n if (info.current !== info.pending) {\n update(info.pending, 0);\n return true;\n }\n }\n else {\n if (info.current !== info.then) {\n update(info.then, 1, info.value, promise);\n return true;\n }\n info.resolved = { [info.value]: promise };\n }\n}\n\nconst globals = (typeof window !== 'undefined' ? window : global);\n\nfunction destroy_block(block, lookup) {\n block.d(1);\n lookup.delete(block.key);\n}\nfunction outro_and_destroy_block(block, lookup) {\n transition_out(block, 1, 1, () => {\n lookup.delete(block.key);\n });\n}\nfunction fix_and_destroy_block(block, lookup) {\n block.f();\n destroy_block(block, lookup);\n}\nfunction fix_and_outro_and_destroy_block(block, lookup) {\n block.f();\n outro_and_destroy_block(block, lookup);\n}\nfunction update_keyed_each(old_blocks, changed, get_key, dynamic, ctx, list, lookup, node, destroy, create_each_block, next, get_context) {\n let o = old_blocks.length;\n let n = list.length;\n let i = o;\n const old_indexes = {};\n while (i--)\n old_indexes[old_blocks[i].key] = i;\n const new_blocks = [];\n const new_lookup = new Map();\n const deltas = new Map();\n i = n;\n while (i--) {\n const child_ctx = get_context(ctx, list, i);\n const key = get_key(child_ctx);\n let block = lookup.get(key);\n if (!block) {\n block = create_each_block(key, child_ctx);\n block.c();\n }\n else if (dynamic) {\n block.p(changed, child_ctx);\n }\n new_lookup.set(key, new_blocks[i] = block);\n if (key in old_indexes)\n deltas.set(key, Math.abs(i - old_indexes[key]));\n }\n const will_move = new Set();\n const did_move = new Set();\n function insert(block) {\n transition_in(block, 1);\n block.m(node, next);\n lookup.set(block.key, block);\n next = block.first;\n n--;\n }\n while (o && n) {\n const new_block = new_blocks[n - 1];\n const old_block = old_blocks[o - 1];\n const new_key = new_block.key;\n const old_key = old_block.key;\n if (new_block === old_block) {\n // do nothing\n next = new_block.first;\n o--;\n n--;\n }\n else if (!new_lookup.has(old_key)) {\n // remove old block\n destroy(old_block, lookup);\n o--;\n }\n else if (!lookup.has(new_key) || will_move.has(new_key)) {\n insert(new_block);\n }\n else if (did_move.has(old_key)) {\n o--;\n }\n else if (deltas.get(new_key) > deltas.get(old_key)) {\n did_move.add(new_key);\n insert(new_block);\n }\n else {\n will_move.add(old_key);\n o--;\n }\n }\n while (o--) {\n const old_block = old_blocks[o];\n if (!new_lookup.has(old_block.key))\n destroy(old_block, lookup);\n }\n while (n)\n insert(new_blocks[n - 1]);\n return new_blocks;\n}\nfunction measure(blocks) {\n const rects = {};\n let i = blocks.length;\n while (i--)\n rects[blocks[i].key] = blocks[i].node.getBoundingClientRect();\n return rects;\n}\n\nfunction get_spread_update(levels, updates) {\n const update = {};\n const to_null_out = {};\n const accounted_for = { $$scope: 1 };\n let i = levels.length;\n while (i--) {\n const o = levels[i];\n const n = updates[i];\n if (n) {\n for (const key in o) {\n if (!(key in n))\n to_null_out[key] = 1;\n }\n for (const key in n) {\n if (!accounted_for[key]) {\n update[key] = n[key];\n accounted_for[key] = 1;\n }\n }\n levels[i] = n;\n }\n else {\n for (const key in o) {\n accounted_for[key] = 1;\n }\n }\n }\n for (const key in to_null_out) {\n if (!(key in update))\n update[key] = undefined;\n }\n return update;\n}\nfunction get_spread_object(spread_props) {\n return typeof spread_props === 'object' && spread_props !== null ? spread_props : {};\n}\n\nconst invalid_attribute_name_character = /[\\s'\">/=\\u{FDD0}-\\u{FDEF}\\u{FFFE}\\u{FFFF}\\u{1FFFE}\\u{1FFFF}\\u{2FFFE}\\u{2FFFF}\\u{3FFFE}\\u{3FFFF}\\u{4FFFE}\\u{4FFFF}\\u{5FFFE}\\u{5FFFF}\\u{6FFFE}\\u{6FFFF}\\u{7FFFE}\\u{7FFFF}\\u{8FFFE}\\u{8FFFF}\\u{9FFFE}\\u{9FFFF}\\u{AFFFE}\\u{AFFFF}\\u{BFFFE}\\u{BFFFF}\\u{CFFFE}\\u{CFFFF}\\u{DFFFE}\\u{DFFFF}\\u{EFFFE}\\u{EFFFF}\\u{FFFFE}\\u{FFFFF}\\u{10FFFE}\\u{10FFFF}]/u;\n// https://html.spec.whatwg.org/multipage/syntax.html#attributes-2\n// https://infra.spec.whatwg.org/#noncharacter\nfunction spread(args) {\n const attributes = Object.assign({}, ...args);\n let str = '';\n Object.keys(attributes).forEach(name => {\n if (invalid_attribute_name_character.test(name))\n return;\n const value = attributes[name];\n if (value === undefined)\n return;\n if (value === true)\n str += \" \" + name;\n const escaped = String(value)\n .replace(/\"/g, '"')\n .replace(/'/g, ''');\n str += \" \" + name + \"=\" + JSON.stringify(escaped);\n });\n return str;\n}\nconst escaped = {\n '\"': '"',\n \"'\": ''',\n '&': '&',\n '<': '<',\n '>': '>'\n};\nfunction escape(html) {\n return String(html).replace(/[\"'&<>]/g, match => escaped[match]);\n}\nfunction each(items, fn) {\n let str = '';\n for (let i = 0; i < items.length; i += 1) {\n str += fn(items[i], i);\n }\n return str;\n}\nconst missing_component = {\n $$render: () => ''\n};\nfunction validate_component(component, name) {\n if (!component || !component.$$render) {\n if (name === 'svelte:component')\n name += ' this={...}';\n throw new Error(`<${name}> is not a valid SSR component. You may need to review your build config to ensure that dependencies are compiled, rather than imported as pre-compiled modules`);\n }\n return component;\n}\nfunction debug(file, line, column, values) {\n console.log(`{@debug} ${file ? file + ' ' : ''}(${line}:${column})`); // eslint-disable-line no-console\n console.log(values); // eslint-disable-line no-console\n return '';\n}\nlet on_destroy;\nfunction create_ssr_component(fn) {\n function $$render(result, props, bindings, slots) {\n const parent_component = current_component;\n const $$ = {\n on_destroy,\n context: new Map(parent_component ? parent_component.$$.context : []),\n // these will be immediately discarded\n on_mount: [],\n before_update: [],\n after_update: [],\n callbacks: blank_object()\n };\n set_current_component({ $$ });\n const html = fn(result, props, bindings, slots);\n set_current_component(parent_component);\n return html;\n }\n return {\n render: (props = {}, options = {}) => {\n on_destroy = [];\n const result = { head: '', css: new Set() };\n const html = $$render(result, props, {}, options);\n run_all(on_destroy);\n return {\n html,\n css: {\n code: Array.from(result.css).map(css => css.code).join('\\n'),\n map: null // TODO\n },\n head: result.head\n };\n },\n $$render\n };\n}\nfunction add_attribute(name, value, boolean) {\n if (value == null || (boolean && !value))\n return '';\n return ` ${name}${value === true ? '' : `=${typeof value === 'string' ? JSON.stringify(escape(value)) : `\"${value}\"`}`}`;\n}\nfunction add_classes(classes) {\n return classes ? ` class=\"${classes}\"` : ``;\n}\n\nfunction bind(component, name, callback) {\n if (component.$$.props.indexOf(name) === -1)\n return;\n component.$$.bound[name] = callback;\n callback(component.$$.ctx[name]);\n}\nfunction mount_component(component, target, anchor) {\n const { fragment, on_mount, on_destroy, after_update } = component.$$;\n fragment.m(target, anchor);\n // onMount happens before the initial afterUpdate\n add_render_callback(() => {\n const new_on_destroy = on_mount.map(run).filter(is_function);\n if (on_destroy) {\n on_destroy.push(...new_on_destroy);\n }\n else {\n // Edge case - component was destroyed immediately,\n // most likely as a result of a binding initialising\n run_all(new_on_destroy);\n }\n component.$$.on_mount = [];\n });\n after_update.forEach(add_render_callback);\n}\nfunction destroy_component(component, detaching) {\n if (component.$$.fragment) {\n run_all(component.$$.on_destroy);\n component.$$.fragment.d(detaching);\n // TODO null out other refs, including component.$$ (but need to\n // preserve final state?)\n component.$$.on_destroy = component.$$.fragment = null;\n component.$$.ctx = {};\n }\n}\nfunction make_dirty(component, key) {\n if (!component.$$.dirty) {\n dirty_components.push(component);\n schedule_update();\n component.$$.dirty = blank_object();\n }\n component.$$.dirty[key] = true;\n}\nfunction init(component, options, instance, create_fragment, not_equal, prop_names) {\n const parent_component = current_component;\n set_current_component(component);\n const props = options.props || {};\n const $$ = component.$$ = {\n fragment: null,\n ctx: null,\n // state\n props: prop_names,\n update: noop,\n not_equal,\n bound: blank_object(),\n // lifecycle\n on_mount: [],\n on_destroy: [],\n before_update: [],\n after_update: [],\n context: new Map(parent_component ? parent_component.$$.context : []),\n // everything else\n callbacks: blank_object(),\n dirty: null\n };\n let ready = false;\n $$.ctx = instance\n ? instance(component, props, (key, ret, value = ret) => {\n if ($$.ctx && not_equal($$.ctx[key], $$.ctx[key] = value)) {\n if ($$.bound[key])\n $$.bound[key](value);\n if (ready)\n make_dirty(component, key);\n }\n return ret;\n })\n : props;\n $$.update();\n ready = true;\n run_all($$.before_update);\n $$.fragment = create_fragment($$.ctx);\n if (options.target) {\n if (options.hydrate) {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment.l(children(options.target));\n }\n else {\n // eslint-disable-next-line @typescript-eslint/no-non-null-assertion\n $$.fragment.c();\n }\n if (options.intro)\n transition_in(component.$$.fragment);\n mount_component(component, options.target, options.anchor);\n flush();\n }\n set_current_component(parent_component);\n}\nlet SvelteElement;\nif (typeof HTMLElement !== 'undefined') {\n SvelteElement = class extends HTMLElement {\n constructor() {\n super();\n this.attachShadow({ mode: 'open' });\n }\n connectedCallback() {\n // @ts-ignore todo: improve typings\n for (const key in this.$$.slotted) {\n // @ts-ignore todo: improve typings\n this.appendChild(this.$$.slotted[key]);\n }\n }\n attributeChangedCallback(attr, _oldValue, newValue) {\n this[attr] = newValue;\n }\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n // TODO should this delegate to addEventListener?\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set() {\n // overridden by instance, if it has props\n }\n };\n}\nclass SvelteComponent {\n $destroy() {\n destroy_component(this, 1);\n this.$destroy = noop;\n }\n $on(type, callback) {\n const callbacks = (this.$$.callbacks[type] || (this.$$.callbacks[type] = []));\n callbacks.push(callback);\n return () => {\n const index = callbacks.indexOf(callback);\n if (index !== -1)\n callbacks.splice(index, 1);\n };\n }\n $set() {\n // overridden by instance, if it has props\n }\n}\n\nfunction dispatch_dev(type, detail) {\n document.dispatchEvent(custom_event(type, detail));\n}\nfunction append_dev(target, node) {\n dispatch_dev(\"SvelteDOMInsert\", { target, node });\n append(target, node);\n}\nfunction insert_dev(target, node, anchor) {\n dispatch_dev(\"SvelteDOMInsert\", { target, node, anchor });\n insert(target, node, anchor);\n}\nfunction detach_dev(node) {\n dispatch_dev(\"SvelteDOMRemove\", { node });\n detach(node);\n}\nfunction detach_between_dev(before, after) {\n while (before.nextSibling && before.nextSibling !== after) {\n detach_dev(before.nextSibling);\n }\n}\nfunction detach_before_dev(after) {\n while (after.previousSibling) {\n detach_dev(after.previousSibling);\n }\n}\nfunction detach_after_dev(before) {\n while (before.nextSibling) {\n detach_dev(before.nextSibling);\n }\n}\nfunction listen_dev(node, event, handler, options, has_prevent_default, has_stop_propagation) {\n const modifiers = options === true ? [\"capture\"] : options ? Array.from(Object.keys(options)) : [];\n if (has_prevent_default)\n modifiers.push('preventDefault');\n if (has_stop_propagation)\n modifiers.push('stopPropagation');\n dispatch_dev(\"SvelteDOMAddEventListener\", { node, event, handler, modifiers });\n const dispose = listen(node, event, handler, options);\n return () => {\n dispatch_dev(\"SvelteDOMRemoveEventListener\", { node, event, handler, modifiers });\n dispose();\n };\n}\nfunction attr_dev(node, attribute, value) {\n attr(node, attribute, value);\n if (value == null)\n dispatch_dev(\"SvelteDOMRemoveAttribute\", { node, attribute });\n else\n dispatch_dev(\"SvelteDOMSetAttribute\", { node, attribute, value });\n}\nfunction prop_dev(node, property, value) {\n node[property] = value;\n dispatch_dev(\"SvelteDOMSetProperty\", { node, property, value });\n}\nfunction dataset_dev(node, property, value) {\n node.dataset[property] = value;\n dispatch_dev(\"SvelteDOMSetDataset\", { node, property, value });\n}\nfunction set_data_dev(text, data) {\n data = '' + data;\n if (text.data === data)\n return;\n dispatch_dev(\"SvelteDOMSetData\", { node: text, data });\n text.data = data;\n}\nclass SvelteComponentDev extends SvelteComponent {\n constructor(options) {\n if (!options || (!options.target && !options.$$inline)) {\n throw new Error(`'target' is a required option`);\n }\n super();\n }\n $destroy() {\n super.$destroy();\n this.$destroy = () => {\n console.warn(`Component was already destroyed`); // eslint-disable-line no-console\n };\n }\n}\n\nexport { HtmlTag, SvelteComponent, SvelteComponentDev, SvelteElement, add_attribute, add_classes, add_flush_callback, add_location, add_render_callback, add_resize_listener, add_transform, afterUpdate, append, append_dev, assign, attr, attr_dev, beforeUpdate, bind, binding_callbacks, blank_object, bubble, check_outros, children, claim_element, claim_space, claim_text, clear_loops, component_subscribe, createEventDispatcher, create_animation, create_bidirectional_transition, create_in_transition, create_out_transition, create_slot, create_ssr_component, current_component, custom_event, dataset_dev, debug, destroy_block, destroy_component, destroy_each, detach, detach_after_dev, detach_before_dev, detach_between_dev, detach_dev, dirty_components, dispatch_dev, each, element, element_is, empty, escape, escaped, exclude_internal_props, fix_and_destroy_block, fix_and_outro_and_destroy_block, fix_position, flush, getContext, get_binding_group_value, get_current_component, get_slot_changes, get_slot_context, get_spread_object, get_spread_update, get_store_value, globals, group_outros, handle_promise, identity, init, insert, insert_dev, intros, invalid_attribute_name_character, is_client, is_function, is_promise, listen, listen_dev, loop, measure, missing_component, mount_component, noop, not_equal, now, null_to_empty, object_without_properties, onDestroy, onMount, once, outro_and_destroy_block, prevent_default, prop_dev, raf, run, run_all, safe_not_equal, schedule_update, select_multiple_value, select_option, select_options, select_value, self, setContext, set_attributes, set_current_component, set_custom_element_data, set_data, set_data_dev, set_input_type, set_input_value, set_now, set_raf, set_store_value, set_style, set_svg_attributes, space, spread, stop_propagation, subscribe, svg_element, text, tick, time_ranges_to_array, to_number, toggle_class, transition_in, transition_out, update_keyed_each, validate_component, validate_store, xlink_attr };\n","\n\n\n\n\n\n","\n\n{#if hideValue}\n\n{:else}\n\n{/if}\n\n","\n\n
\n {#each formControls as child, index}\n
{labels[index]}
\n
\n
\n {/each}\n
\n\n","\r\nconst apiCall = (method) => (url, body) => \r\n fetch(url, {\r\n method: method,\r\n headers: {\r\n 'Content-Type': 'application/json',\r\n },\r\n body: body && JSON.stringify(body), \r\n });\r\n\r\nexport const post = apiCall(\"POST\");\r\nexport const get = apiCall(\"GET\");\r\nexport const patch = apiCall(\"PATCH\");\r\nexport const del = apiCall(\"DELETE\");\r\n\r\nexport const authenticate = (username, password) => post(\"./api/authenticate\", {\r\n username, password\r\n});\r\n\r\nexport default {\r\npost, get, patch, delete:del\r\n};","\n\n
\n\n
\n\n {#if logo}\n
\n \"logo\"/\n
\n {/if}\n\n
\n
\n {usernameLabel}\n
\n
\n \n
\n
\n {passwordLabel}\n
\n
\n \n
\n
\n\n
\n \n
\n\n {#if incorrect}\n
\n Incorrect username or password\n
\n {/if}\n\n
\n\n
\n\n","export const buildStyle = (styles) => {\r\n let str = \"\";\r\n for(let s in styles) {\r\n if(styles[s]) {\r\n str += `${s}: ${styles[s]}; `\r\n }\r\n }\r\n return str;\r\n}","\r\n\r\n
\r\n {#each children as child, index}\r\n
\r\n
\r\n {/each}\r\n
\r\n\r\n","\n\n
\n {#each children as child, index}\n
\n
\n
\n
\n {/each}\n
\n\n"],"names":[],"mappings":"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"} \ No newline at end of file diff --git a/packages/bootstrap-components/package.json b/packages/bootstrap-components/package.json deleted file mode 100644 index 2b34da6e09..0000000000 --- a/packages/bootstrap-components/package.json +++ /dev/null @@ -1,36 +0,0 @@ -{ - "name": "@budibase/bootstrap-components", - "svelte": "src/index.svelte", - "main": "dist/index.js", - "module": "dist/index.js", - "scripts": { - "build": "rollup -c", - "prepublishOnly": "npm run build", - "testbuild": "rollup -w -c rollup.testconfig.js", - "dev": "run-p start:dev testbuild", - "start:dev": "sirv public --single --dev", - "publishdev": "yarn build && node ./scripts/publishDev.js" - }, - "devDependencies": { - "@budibase/client": "^0.0.32", - "fs-extra": "^8.1.0", - "lodash": "^4.17.15", - "npm-run-all": "^4.1.5", - "rollup": "^1.11.0", - "rollup-plugin-commonjs": "^10.0.2", - "rollup-plugin-json": "^4.0.0", - "rollup-plugin-livereload": "^1.0.1", - "rollup-plugin-node-resolve": "^5.0.0", - "rollup-plugin-svelte": "^5.0.0", - "rollup-plugin-terser": "^5.1.1", - "shortid": "^2.2.15", - "sirv-cli": "^0.4.4", - "svelte": "^3.12.1" - }, - "keywords": [ - "svelte" - ], - "version": "0.0.32", - "license": "MIT", - "gitHead": "b1f4f90927d9e494e513220ef060af28d2d42455" -} diff --git a/packages/bootstrap-components/public/budibase-logo.png b/packages/bootstrap-components/public/budibase-logo.png deleted file mode 100644 index 1d6fc3d1cc242d10958432a769beb0982e4b56fa..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12702 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 WLMMb$jYUhZR2d0*@lw&Re*XuLUll+A diff --git a/packages/bootstrap-components/public/bundle.css b/packages/bootstrap-components/public/bundle.css deleted file mode 100644 index 238494fab3..0000000000 --- a/packages/bootstrap-components/public/bundle.css +++ /dev/null @@ -1,13 +0,0 @@ -#current_component.svelte-1xqz9vm{height:100%;width:100%} -.root.svelte-10kw8to{display:grid} -.root.svelte-crnq0a{height:100%;display:grid;grid-template-columns:[left] 1fr [middle] auto [right] 1fr;grid-template-rows:[top] 1fr [center] auto [bottom] 1fr}.content.svelte-crnq0a{grid-column-start:middle;grid-row-start:center;width:400px}.logo-container.svelte-crnq0a{margin-bottom:20px -}.logo-container.svelte-crnq0a>img.svelte-crnq0a{max-width:100%}.login-button-container.svelte-crnq0a{text-align:right;margin-top:20px}.incorrect-details-panel.svelte-crnq0a{margin-top:30px;padding:10px;border-style:solid;border-width:1px;border-color:maroon;border-radius:1px;text-align:center;color:maroon;background-color:mistyrose}.form-root.svelte-crnq0a{display:grid;grid-template-columns:[label] auto [control] 1fr}.label.svelte-crnq0a{grid-column-start:label;padding:5px 10px;vertical-align:middle}.control.svelte-crnq0a{grid-column-start:control;padding:5px 10px}.default-input.svelte-crnq0a{font-family:inherit;font-size:inherit;padding:0.4em;margin:0 0 0.5em 0;box-sizing:border-box;border:1px solid #ccc;border-radius:2px;width:100%}.default-button.svelte-crnq0a{font-family:inherit;font-size:inherit;padding:0.4em;margin:0 0 0.5em 0;box-sizing:border-box;border:1px solid #ccc;border-radius:2px;color:#333;background-color:#f4f4f4;outline:none}.default-button.svelte-crnq0a:active{background-color:#ddd}.default-button.svelte-crnq0a:focus{border-color:#666} -.form-root.svelte-m9d6ue{display:grid;grid-template-columns:[label] auto [control] 1fr}.label.svelte-m9d6ue{grid-column-start:label;padding:5px 10px;vertical-align:middle}.control.svelte-m9d6ue{grid-column-start:control;padding:5px 10px}.overflow.svelte-m9d6ue{grid-column-start:overflow}.full-width.svelte-m9d6ue{width:100%} -.root.svelte-aihwli{height:100%;width:100%;grid-template-columns:[navbar] auto [content] 1fr;display:grid}.navbar.svelte-aihwli{grid-column:navbar;background:var(--navBarBackground);border:var(--navBarBorder);color:var(--navBarColor)}.navitem.svelte-aihwli{padding:10px 17px;cursor:pointer}.navitem.svelte-aihwli:hover{background:var(--itemHoverBackground);color:var(--itemHoverColor)}.navitem.selected.svelte-aihwli{background:var(--selectedItemBackground);border:var(--selectedItemBorder);color:var(--selectedItemColor)}.content.svelte-aihwli{grid-column:content} -.default.svelte-1ec4wqj{width:100%;font-family:inherit;font-size:inherit;padding:0.4em;margin:0 0 0.5em 0;box-sizing:border-box;border:1px solid #ccc;border-radius:2px;width:100%}.default.svelte-1ec4wqj:disabled{color:#ccc} -.panel.svelte-6yfcjx:hover{background:var(--hoverBackground);color:var(--hoverColor)} -.horizontal.svelte-osi0db{display:inline-block}.vertical.svelte-osi0db{display:block} -.table-default.svelte-h8rqk6{width:100%;margin-bottom:1rem;color:#212529;border-collapse:collapse}.table-default.svelte-h8rqk6 .thead-default .th-default.svelte-h8rqk6{vertical-align:bottom;border-bottom:2px solid #dee2e6;font-weight:bold}.table-default.svelte-h8rqk6 .th-default.svelte-h8rqk6{padding:.75rem;vertical-align:top;border-top:1px solid #dee2e6;font-weight:normal}.th-default.svelte-h8rqk6{text-align:inherit}.table-default.svelte-h8rqk6 .tbody-default .tr-default.svelte-h8rqk6:hover{color:#212529;background-color:rgba(0,0,0,.075);cursor:pointer} -.default.svelte-1q8lga0{font-family:inherit;font-size:inherit;padding:0.4em;margin:0 0 0.5em 0;box-sizing:border-box;border:1px solid #ccc;border-radius:2px;color:#333;background-color:#f4f4f4;outline:none}.default.svelte-1q8lga0:active{background-color:#ddd}.default.svelte-1q8lga0:focus{border-color:#666} - -/*# sourceMappingURL=bundle.css.map */ \ No newline at end of file diff --git a/packages/bootstrap-components/public/bundle.css.map b/packages/bootstrap-components/public/bundle.css.map deleted file mode 100644 index 20454673ef..0000000000 --- a/packages/bootstrap-components/public/bundle.css.map +++ /dev/null @@ -1,30 +0,0 @@ -{ - "version": 3, - "file": "bundle.css", - "sources": [ - "..\\src\\Test\\TestApp.svelte", - "..\\src\\Grid.svelte", - "..\\src\\Login.svelte", - "..\\src\\Form.svelte", - "..\\src\\Nav.svelte", - "..\\src\\Textbox.svelte", - "..\\src\\Panel.svelte", - "..\\src\\StackPanel.svelte", - "..\\src\\Table.svelte", - "..\\src\\Button.svelte" - ], - "sourcesContent": [ - "\n\n{#await _appPromise}\nloading\n{:then _bb}\n\n
\n
\n\n{/await}\n\n\n\n\n", - "\r\n\r\n
\r\n {#each children as child, index}\r\n
\r\n
\r\n {/each}\r\n
\r\n\r\n", - "\n\n
\n\n
\n\n {#if _logo}\n
\n \"logo\"/\n
\n {/if}\n\n
\n
\n {usernameLabel}\n
\n
\n \n
\n
\n {passwordLabel}\n
\n
\n \n
\n
\n\n
\n \n
\n\n {#if incorrect}\n
\n Incorrect username or password\n
\n {/if}\n\n
\n\n
\n\n", - "\n\n
\n {#each formControls as child, index}\n
{labels[index]}
\n
\n
\n {/each}\n
\n\n", - "\r\n\r\n
\r\n {#if !hideNavBar}\r\n
\r\n {#each items as navItem, index}\r\n
\r\n {navItem.title}\r\n
\r\n {/each}\r\n
\r\n {/if}\r\n {#each items as navItem, index}\r\n\r\n
\r\n
\r\n {/each}\r\n
\r\n\r\n\r\n\r\n", - "\n\n{#if hideValue}\n\n{:else}\n\n{/if}\n\n", - "\r\n\r\n
\r\n {component && component._component ? \"\" : text}\r\n
\r\n\r\n\r\n", - "\n\n
\n\n {#if children}\n {#each children as child, index}\n
\n
\n
\n
\n {/each}\n {/if}\n\n {#if data && data.length > 0}\n {#each data as child, index}\n
\n
\n
\n
\n {/each}\n {/if}\n
\n\n", - "\r\n\r\n \r\n \r\n \r\n {#each columns as col}\r\n \r\n {/each}\r\n \r\n \r\n \r\n {#each data as row}\r\n \r\n {#each columns as col}\r\n \r\n {/each}\r\n \r\n {/each}\r\n \r\n
{col.title}
{_bb.getStateOrValue(col.value, row)}
\r\n\r\n", - "\n\n\n\n\n\n" - ], - "names": [], - "mappings": "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" -} \ No newline at end of file diff --git a/packages/bootstrap-components/public/bundle.js b/packages/bootstrap-components/public/bundle.js deleted file mode 100644 index e406984883..0000000000 --- a/packages/bootstrap-components/public/bundle.js +++ /dev/null @@ -1,33412 +0,0 @@ -; (function (l, i, v, e) { - v = l.createElement(i) - v.async = 1 - v.src = - "//" + - (location.host || "localhost").split(":")[0] + - ":35729/livereload.js?snipver=1" - e = l.getElementsByTagName(i)[0] - e.parentNode.insertBefore(v, e) -})(document, "script") -var app = (function () { - "use strict" - - function noop() { } - function assign(tar, src) { - // @ts-ignore - for (const k in src) tar[k] = src[k] - return tar - } - function is_promise(value) { - return ( - value && typeof value === "object" && typeof value.then === "function" - ) - } - function add_location(element, file, line, column, char) { - element.__svelte_meta = { - loc: { file, line, column, char }, - } - } - function run(fn) { - return fn() - } - function blank_object() { - return Object.create(null) - } - function run_all(fns) { - fns.forEach(run) - } - function is_function(thing) { - return typeof thing === "function" - } - function safe_not_equal(a, b) { - return a != a - ? b == b - : a !== b || (a && typeof a === "object") || typeof a === "function" - } - function create_slot(definition, ctx, fn) { - if (definition) { - const slot_ctx = get_slot_context(definition, ctx, fn) - return definition[0](slot_ctx) - } - } - function get_slot_context(definition, ctx, fn) { - return definition[1] - ? assign({}, assign(ctx.$$scope.ctx, definition[1](fn ? fn(ctx) : {}))) - : ctx.$$scope.ctx - } - function get_slot_changes(definition, ctx, changed, fn) { - return definition[1] - ? assign( - {}, - assign( - ctx.$$scope.changed || {}, - definition[1](fn ? fn(changed) : {}) - ) - ) - : ctx.$$scope.changed || {} - } - function null_to_empty(value) { - return value == null ? "" : value - } - - function append(target, node) { - target.appendChild(node) - } - function insert(target, node, anchor) { - target.insertBefore(node, anchor || null) - } - function detach(node) { - node.parentNode.removeChild(node) - } - function destroy_each(iterations, detaching) { - for (let i = 0; i < iterations.length; i += 1) { - if (iterations[i]) iterations[i].d(detaching) - } - } - function element(name) { - return document.createElement(name) - } - function svg_element(name) { - return document.createElementNS("http://www.w3.org/2000/svg", name) - } - function text(data) { - return document.createTextNode(data) - } - function space() { - return text(" ") - } - function empty() { - return text("") - } - function listen(node, event, handler, options) { - node.addEventListener(event, handler, options) - return () => node.removeEventListener(event, handler, options) - } - function attr(node, attribute, value) { - if (value == null) node.removeAttribute(attribute) - else node.setAttribute(attribute, value) - } - function children(element) { - return Array.from(element.childNodes) - } - function claim_element(nodes, name, attributes, svg) { - for (let i = 0; i < nodes.length; i += 1) { - const node = nodes[i] - if (node.nodeName === name) { - for (let j = 0; j < node.attributes.length; j += 1) { - const attribute = node.attributes[j] - if (!attributes[attribute.name]) node.removeAttribute(attribute.name) - } - return nodes.splice(i, 1)[0] // TODO strip unwanted attributes - } - } - return svg ? svg_element(name) : element(name) - } - function claim_text(nodes, data) { - for (let i = 0; i < nodes.length; i += 1) { - const node = nodes[i] - if (node.nodeType === 3) { - node.data = "" + data - return nodes.splice(i, 1)[0] - } - } - return text(data) - } - function claim_space(nodes) { - return claim_text(nodes, " ") - } - function set_input_value(input, value) { - if (value != null || input.value) { - input.value = value - } - } - function set_style(node, key, value, important) { - node.style.setProperty(key, value, important ? "important" : "") - } - function toggle_class(element, name, toggle) { - element.classList[toggle ? "add" : "remove"](name) - } - function custom_event(type, detail) { - const e = document.createEvent("CustomEvent") - e.initCustomEvent(type, false, false, detail) - return e - } - - let current_component - function set_current_component(component) { - current_component = component - } - function get_current_component() { - if (!current_component) - throw new Error(`Function called outside component initialization`) - return current_component - } - // TODO figure out if we still want to support - // shorthand events, or if we want to implement - // a real bubbling mechanism - function bubble(component, event) { - const callbacks = component.$$.callbacks[event.type] - if (callbacks) { - callbacks.slice().forEach(fn => fn(event)) - } - } - - const dirty_components = [] - const binding_callbacks = [] - const render_callbacks = [] - const flush_callbacks = [] - const resolved_promise = Promise.resolve() - let update_scheduled = false - function schedule_update() { - if (!update_scheduled) { - update_scheduled = true - resolved_promise.then(flush) - } - } - function add_render_callback(fn) { - render_callbacks.push(fn) - } - function flush() { - const seen_callbacks = new Set() - do { - // first, call beforeUpdate functions - // and update components - while (dirty_components.length) { - const component = dirty_components.shift() - set_current_component(component) - update(component.$$) - } - while (binding_callbacks.length) binding_callbacks.pop()() - // then, once components are updated, call - // afterUpdate functions. This may cause - // subsequent updates... - for (let i = 0; i < render_callbacks.length; i += 1) { - const callback = render_callbacks[i] - if (!seen_callbacks.has(callback)) { - callback() - // ...so guard against infinite loops - seen_callbacks.add(callback) - } - } - render_callbacks.length = 0 - } while (dirty_components.length) - while (flush_callbacks.length) { - flush_callbacks.pop()() - } - update_scheduled = false - } - function update($$) { - if ($$.fragment) { - $$.update($$.dirty) - run_all($$.before_update) - $$.fragment.p($$.dirty, $$.ctx) - $$.dirty = null - $$.after_update.forEach(add_render_callback) - } - } - const outroing = new Set() - let outros - function group_outros() { - outros = { - r: 0, - c: [], - p: outros, // parent group - } - } - function check_outros() { - if (!outros.r) { - run_all(outros.c) - } - outros = outros.p - } - function transition_in(block, local) { - if (block && block.i) { - outroing.delete(block) - block.i(local) - } - } - function transition_out(block, local, detach, callback) { - if (block && block.o) { - if (outroing.has(block)) return - outroing.add(block) - outros.c.push(() => { - outroing.delete(block) - if (callback) { - if (detach) block.d(1) - callback() - } - }) - block.o(local) - } - } - - function handle_promise(promise, info) { - const token = (info.token = {}) - function update(type, index, key, value) { - if (info.token !== token) return - info.resolved = key && { [key]: value } - const child_ctx = assign(assign({}, info.ctx), info.resolved) - const block = type && (info.current = type)(child_ctx) - if (info.block) { - if (info.blocks) { - info.blocks.forEach((block, i) => { - if (i !== index && block) { - group_outros() - transition_out(block, 1, 1, () => { - info.blocks[i] = null - }) - check_outros() - } - }) - } else { - info.block.d(1) - } - block.c() - transition_in(block, 1) - block.m(info.mount(), info.anchor) - flush() - } - info.block = block - if (info.blocks) info.blocks[index] = block - } - if (is_promise(promise)) { - const current_component = get_current_component() - promise.then( - value => { - set_current_component(current_component) - update(info.then, 1, info.value, value) - set_current_component(null) - }, - error => { - set_current_component(current_component) - update(info.catch, 2, info.error, error) - set_current_component(null) - } - ) - // if we previously had a then/catch block, destroy it - if (info.current !== info.pending) { - update(info.pending, 0) - return true - } - } else { - if (info.current !== info.then) { - update(info.then, 1, info.value, promise) - return true - } - info.resolved = { [info.value]: promise } - } - } - - const globals = typeof window !== "undefined" ? window : global - function mount_component(component, target, anchor) { - const { fragment, on_mount, on_destroy, after_update } = component.$$ - fragment.m(target, anchor) - // onMount happens before the initial afterUpdate - add_render_callback(() => { - const new_on_destroy = on_mount.map(run).filter(is_function) - if (on_destroy) { - on_destroy.push(...new_on_destroy) - } else { - // Edge case - component was destroyed immediately, - // most likely as a result of a binding initialising - run_all(new_on_destroy) - } - component.$$.on_mount = [] - }) - after_update.forEach(add_render_callback) - } - function destroy_component(component, detaching) { - if (component.$$.fragment) { - run_all(component.$$.on_destroy) - component.$$.fragment.d(detaching) - // TODO null out other refs, including component.$$ (but need to - // preserve final state?) - component.$$.on_destroy = component.$$.fragment = null - component.$$.ctx = {} - } - } - function make_dirty(component, key) { - if (!component.$$.dirty) { - dirty_components.push(component) - schedule_update() - component.$$.dirty = blank_object() - } - component.$$.dirty[key] = true - } - function init( - component, - options, - instance, - create_fragment, - not_equal, - prop_names - ) { - const parent_component = current_component - set_current_component(component) - const props = options.props || {} - const $$ = (component.$$ = { - fragment: null, - ctx: null, - // state - props: prop_names, - update: noop, - not_equal, - bound: blank_object(), - // lifecycle - on_mount: [], - on_destroy: [], - before_update: [], - after_update: [], - context: new Map(parent_component ? parent_component.$$.context : []), - // everything else - callbacks: blank_object(), - dirty: null, - }) - let ready = false - $$.ctx = instance - ? instance(component, props, (key, ret, value = ret) => { - if ($$.ctx && not_equal($$.ctx[key], ($$.ctx[key] = value))) { - if ($$.bound[key]) $$.bound[key](value) - if (ready) make_dirty(component, key) - } - return ret - }) - : props - $$.update() - ready = true - run_all($$.before_update) - $$.fragment = create_fragment($$.ctx) - if (options.target) { - if (options.hydrate) { - // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - $$.fragment.l(children(options.target)) - } else { - // eslint-disable-next-line @typescript-eslint/no-non-null-assertion - $$.fragment.c() - } - if (options.intro) transition_in(component.$$.fragment) - mount_component(component, options.target, options.anchor) - flush() - } - set_current_component(parent_component) - } - let SvelteElement - if (typeof HTMLElement !== "undefined") { - SvelteElement = class extends HTMLElement { - constructor() { - super() - this.attachShadow({ mode: "open" }) - } - connectedCallback() { - // @ts-ignore todo: improve typings - for (const key in this.$$.slotted) { - // @ts-ignore todo: improve typings - this.appendChild(this.$$.slotted[key]) - } - } - attributeChangedCallback(attr, _oldValue, newValue) { - this[attr] = newValue - } - $destroy() { - destroy_component(this, 1) - this.$destroy = noop - } - $on(type, callback) { - // TODO should this delegate to addEventListener? - const callbacks = - this.$$.callbacks[type] || (this.$$.callbacks[type] = []) - callbacks.push(callback) - return () => { - const index = callbacks.indexOf(callback) - if (index !== -1) callbacks.splice(index, 1) - } - } - $set() { - // overridden by instance, if it has props - } - } - } - class SvelteComponent { - $destroy() { - destroy_component(this, 1) - this.$destroy = noop - } - $on(type, callback) { - const callbacks = - this.$$.callbacks[type] || (this.$$.callbacks[type] = []) - callbacks.push(callback) - return () => { - const index = callbacks.indexOf(callback) - if (index !== -1) callbacks.splice(index, 1) - } - } - $set() { - // overridden by instance, if it has props - } - } - - function dispatch_dev(type, detail) { - document.dispatchEvent(custom_event(type, detail)) - } - function append_dev(target, node) { - dispatch_dev("SvelteDOMInsert", { target, node }) - append(target, node) - } - function insert_dev(target, node, anchor) { - dispatch_dev("SvelteDOMInsert", { target, node, anchor }) - insert(target, node, anchor) - } - function detach_dev(node) { - dispatch_dev("SvelteDOMRemove", { node }) - detach(node) - } - function listen_dev( - node, - event, - handler, - options, - has_prevent_default, - has_stop_propagation - ) { - const modifiers = - options === true - ? ["capture"] - : options - ? Array.from(Object.keys(options)) - : [] - if (has_prevent_default) modifiers.push("preventDefault") - if (has_stop_propagation) modifiers.push("stopPropagation") - dispatch_dev("SvelteDOMAddEventListener", { - node, - event, - handler, - modifiers, - }) - const dispose = listen(node, event, handler, options) - return () => { - dispatch_dev("SvelteDOMRemoveEventListener", { - node, - event, - handler, - modifiers, - }) - dispose() - } - } - function attr_dev(node, attribute, value) { - attr(node, attribute, value) - if (value == null) - dispatch_dev("SvelteDOMRemoveAttribute", { node, attribute }) - else dispatch_dev("SvelteDOMSetAttribute", { node, attribute, value }) - } - function prop_dev(node, property, value) { - node[property] = value - dispatch_dev("SvelteDOMSetProperty", { node, property, value }) - } - function set_data_dev(text, data) { - data = "" + data - if (text.data === data) return - dispatch_dev("SvelteDOMSetData", { node: text, data }) - text.data = data - } - class SvelteComponentDev extends SvelteComponent { - constructor(options) { - if (!options || (!options.target && !options.$$inline)) { - throw new Error(`'target' is a required option`) - } - super() - } - $destroy() { - super.$destroy() - this.$destroy = () => { - console.warn(`Component was already destroyed`) // eslint-disable-line no-console - } - } - } - - const subscriber_queue = [] - /** - * Create a `Writable` store that allows both updating and reading by subscription. - * @param {*=}value initial value - * @param {StartStopNotifier=}start start and stop notifications for subscriptions - */ - function writable(value, start = noop) { - let stop - const subscribers = [] - function set(new_value) { - if (safe_not_equal(value, new_value)) { - value = new_value - if (stop) { - // store is ready - const run_queue = !subscriber_queue.length - for (let i = 0; i < subscribers.length; i += 1) { - const s = subscribers[i] - s[1]() - subscriber_queue.push(s, value) - } - if (run_queue) { - for (let i = 0; i < subscriber_queue.length; i += 2) { - subscriber_queue[i][0](subscriber_queue[i + 1]) - } - subscriber_queue.length = 0 - } - } - } - } - function update(fn) { - set(fn(value)) - } - function subscribe(run, invalidate = noop) { - const subscriber = [run, invalidate] - subscribers.push(subscriber) - if (subscribers.length === 1) { - stop = start(set) || noop - } - run(value) - return () => { - const index = subscribers.indexOf(subscriber) - if (index !== -1) { - subscribers.splice(index, 1) - } - if (subscribers.length === 0) { - stop() - stop = null - } - } - } - return { set, update, subscribe } - } - - /* src\Textbox.svelte generated by Svelte v3.12.1 */ - - const file = "src\\Textbox.svelte" - - // (32:0) {:else} - function create_else_block(ctx) { - var input, input_class_value - - const block = { - c: function create() { - input = element("input") - this.h() - }, - - l: function claim(nodes) { - input = claim_element( - nodes, - "INPUT", - { class: true, type: true, value: true }, - false - ) - var input_nodes = children(input) - - input_nodes.forEach(detach_dev) - this.h() - }, - - h: function hydrate() { - attr_dev( - input, - "class", - (input_class_value = - "" + null_to_empty(ctx.className) + " svelte-1ec4wqj") - ) - attr_dev(input, "type", "text") - input.value = ctx.actualValue - add_location(input, file, 32, 0, 546) - }, - - m: function mount(target, anchor) { - insert_dev(target, input, anchor) - }, - - p: function update(changed, ctx) { - if ( - changed.className && - input_class_value !== - (input_class_value = - "" + null_to_empty(ctx.className) + " svelte-1ec4wqj") - ) { - attr_dev(input, "class", input_class_value) - } - - if (changed.actualValue) { - prop_dev(input, "value", ctx.actualValue) - } - }, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(input) - } - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_else_block.name, - type: "else", - source: "(32:0) {:else}", - ctx, - }) - return block - } - - // (28:0) {#if hideValue} - function create_if_block(ctx) { - var input, input_class_value, dispose - - const block = { - c: function create() { - input = element("input") - this.h() - }, - - l: function claim(nodes) { - input = claim_element( - nodes, - "INPUT", - { class: true, type: true, value: true }, - false - ) - var input_nodes = children(input) - - input_nodes.forEach(detach_dev) - this.h() - }, - - h: function hydrate() { - attr_dev( - input, - "class", - (input_class_value = - "" + null_to_empty(ctx.className) + " svelte-1ec4wqj") - ) - attr_dev(input, "type", "password") - input.value = ctx.actualValue - add_location(input, file, 28, 0, 455) - dispose = listen_dev(input, "change", ctx.change_handler) - }, - - m: function mount(target, anchor) { - insert_dev(target, input, anchor) - }, - - p: function update(changed, ctx) { - if ( - changed.className && - input_class_value !== - (input_class_value = - "" + null_to_empty(ctx.className) + " svelte-1ec4wqj") - ) { - attr_dev(input, "class", input_class_value) - } - - if (changed.actualValue) { - prop_dev(input, "value", ctx.actualValue) - } - }, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(input) - } - - dispose() - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_if_block.name, - type: "if", - source: "(28:0) {#if hideValue}", - ctx, - }) - return block - } - - function create_fragment(ctx) { - var if_block_anchor - - function select_block_type(changed, ctx) { - if (ctx.hideValue) return create_if_block - return create_else_block - } - - var current_block_type = select_block_type(null, ctx) - var if_block = current_block_type(ctx) - - const block = { - c: function create() { - if_block.c() - if_block_anchor = empty() - }, - - l: function claim(nodes) { - if_block.l(nodes) - if_block_anchor = empty() - }, - - m: function mount(target, anchor) { - if_block.m(target, anchor) - insert_dev(target, if_block_anchor, anchor) - }, - - p: function update(changed, ctx) { - if ( - current_block_type === - (current_block_type = select_block_type(changed, ctx)) && - if_block - ) { - if_block.p(changed, ctx) - } else { - if_block.d(1) - if_block = current_block_type(ctx) - if (if_block) { - if_block.c() - if_block.m(if_block_anchor.parentNode, if_block_anchor) - } - } - }, - - i: noop, - o: noop, - - d: function destroy(detaching) { - if_block.d(detaching) - - if (detaching) { - detach_dev(if_block_anchor) - } - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_fragment.name, - type: "component", - source: "", - ctx, - }) - return block - } - - function instance($$self, $$props, $$invalidate) { - let { value = "", hideValue = false, className = "default", _bb } = $$props - - let actualValue = "" - - const writable_props = ["value", "hideValue", "className", "_bb"] - Object.keys($$props).forEach(key => { - if (!writable_props.includes(key) && !key.startsWith("$$")) - console.warn(` was created with unknown prop '${key}'`) - }) - - function change_handler(event) { - bubble($$self, event) - } - - $$self.$set = $$props => { - if ("value" in $$props) $$invalidate("value", (value = $$props.value)) - if ("hideValue" in $$props) - $$invalidate("hideValue", (hideValue = $$props.hideValue)) - if ("className" in $$props) - $$invalidate("className", (className = $$props.className)) - if ("_bb" in $$props) $$invalidate("_bb", (_bb = $$props._bb)) - } - - $$self.$capture_state = () => { - return { value, hideValue, className, _bb, actualValue } - } - - $$self.$inject_state = $$props => { - if ("value" in $$props) $$invalidate("value", (value = $$props.value)) - if ("hideValue" in $$props) - $$invalidate("hideValue", (hideValue = $$props.hideValue)) - if ("className" in $$props) - $$invalidate("className", (className = $$props.className)) - if ("_bb" in $$props) $$invalidate("_bb", (_bb = $$props._bb)) - if ("actualValue" in $$props) - $$invalidate("actualValue", (actualValue = $$props.actualValue)) - } - - $$self.$$.update = ($$dirty = { _bb: 1, value: 1 }) => { - if ($$dirty._bb || $$dirty.value) { - { - if (_bb && value._isstate) { - _bb.store.subscribe(s => { - $$invalidate( - "actualValue", - (actualValue = _bb.store.getValue(s, value)) - ) - }) - } - } - } - } - - return { - value, - hideValue, - className, - _bb, - actualValue, - change_handler, - } - } - - class Textbox extends SvelteComponentDev { - constructor(options) { - super(options) - init(this, options, instance, create_fragment, safe_not_equal, [ - "value", - "hideValue", - "className", - "_bb", - ]) - dispatch_dev("SvelteRegisterComponent", { - component: this, - tagName: "Textbox", - options, - id: create_fragment.name, - }) - - const { ctx } = this.$$ - const props = options.props || {} - if (ctx._bb === undefined && !("_bb" in props)) { - console.warn(" was created without expected prop '_bb'") - } - } - - get value() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set value(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - - get hideValue() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set hideValue(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - - get className() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set className(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - - get _bb() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set _bb(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - } - - /* src\Form.svelte generated by Svelte v3.12.1 */ - - const file$1 = "src\\Form.svelte" - - function get_each_context(ctx, list, i) { - const child_ctx = Object.create(ctx) - child_ctx.child = list[i] - child_ctx.index = i - return child_ctx - } - - // (30:4) {#each formControls as child, index} - function create_each_block(ctx) { - var div0, - t0_value = ctx.labels[ctx.index] + "", - t0, - t1, - div1, - index = ctx.index - - const assign_div1 = () => ctx.div1_binding(div1, index) - const unassign_div1 = () => ctx.div1_binding(null, index) - - const block = { - c: function create() { - div0 = element("div") - t0 = text(t0_value) - t1 = space() - div1 = element("div") - this.h() - }, - - l: function claim(nodes) { - div0 = claim_element(nodes, "DIV", { class: true }, false) - var div0_nodes = children(div0) - - t0 = claim_text(div0_nodes, t0_value) - div0_nodes.forEach(detach_dev) - t1 = claim_space(nodes) - - div1 = claim_element(nodes, "DIV", { class: true }, false) - var div1_nodes = children(div1) - - div1_nodes.forEach(detach_dev) - this.h() - }, - - h: function hydrate() { - attr_dev(div0, "class", "label svelte-m9d6ue") - add_location(div0, file$1, 30, 4, 559) - attr_dev(div1, "class", "control svelte-m9d6ue") - add_location(div1, file$1, 31, 4, 604) - }, - - m: function mount(target, anchor) { - insert_dev(target, div0, anchor) - append_dev(div0, t0) - insert_dev(target, t1, anchor) - insert_dev(target, div1, anchor) - assign_div1() - }, - - p: function update(changed, new_ctx) { - ctx = new_ctx - if ( - changed.labels && - t0_value !== (t0_value = ctx.labels[ctx.index] + "") - ) { - set_data_dev(t0, t0_value) - } - - if (index !== ctx.index) { - unassign_div1() - index = ctx.index - assign_div1() - } - }, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(div0) - detach_dev(t1) - detach_dev(div1) - } - - unassign_div1() - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_each_block.name, - type: "each", - source: "(30:4) {#each formControls as child, index}", - ctx, - }) - return block - } - - function create_fragment$1(ctx) { - var div, div_class_value - - let each_value = ctx.formControls - - let each_blocks = [] - - for (let i = 0; i < each_value.length; i += 1) { - each_blocks[i] = create_each_block(get_each_context(ctx, each_value, i)) - } - - const block = { - c: function create() { - div = element("div") - - for (let i = 0; i < each_blocks.length; i += 1) { - each_blocks[i].c() - } - this.h() - }, - - l: function claim(nodes) { - div = claim_element(nodes, "DIV", { class: true }, false) - var div_nodes = children(div) - - for (let i = 0; i < each_blocks.length; i += 1) { - each_blocks[i].l(div_nodes) - } - - div_nodes.forEach(detach_dev) - this.h() - }, - - h: function hydrate() { - attr_dev( - div, - "class", - (div_class_value = - "form-root " + ctx.containerClass + " svelte-m9d6ue") - ) - add_location(div, file$1, 28, 0, 473) - }, - - m: function mount(target, anchor) { - insert_dev(target, div, anchor) - - for (let i = 0; i < each_blocks.length; i += 1) { - each_blocks[i].m(div, null) - } - }, - - p: function update(changed, ctx) { - if (changed.htmlElements || changed.labels || changed.formControls) { - each_value = ctx.formControls - - let i - for (i = 0; i < each_value.length; i += 1) { - const child_ctx = get_each_context(ctx, each_value, i) - - if (each_blocks[i]) { - each_blocks[i].p(changed, child_ctx) - } else { - each_blocks[i] = create_each_block(child_ctx) - each_blocks[i].c() - each_blocks[i].m(div, null) - } - } - - for (; i < each_blocks.length; i += 1) { - each_blocks[i].d(1) - } - each_blocks.length = each_value.length - } - - if ( - changed.containerClass && - div_class_value !== - (div_class_value = - "form-root " + ctx.containerClass + " svelte-m9d6ue") - ) { - attr_dev(div, "class", div_class_value) - } - }, - - i: noop, - o: noop, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(div) - } - - destroy_each(each_blocks, detaching) - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_fragment$1.name, - type: "component", - source: "", - ctx, - }) - return block - } - - function instance$1($$self, $$props, $$invalidate) { - let { containerClass = "", formControls = [], _bb } = $$props - - let htmlElements = {} - let labels = {} - - const writable_props = ["containerClass", "formControls", "_bb"] - Object.keys($$props).forEach(key => { - if (!writable_props.includes(key) && !key.startsWith("$$")) - console.warn(`
was created with unknown prop '${key}'`) - }) - - function div1_binding($$value, index) { - if (htmlElements[index] === $$value) return - binding_callbacks[$$value ? "unshift" : "push"](() => { - htmlElements[index] = $$value - $$invalidate("htmlElements", htmlElements) - }) - } - - $$self.$set = $$props => { - if ("containerClass" in $$props) - $$invalidate( - "containerClass", - (containerClass = $$props.containerClass) - ) - if ("formControls" in $$props) - $$invalidate("formControls", (formControls = $$props.formControls)) - if ("_bb" in $$props) $$invalidate("_bb", (_bb = $$props._bb)) - } - - $$self.$capture_state = () => { - return { containerClass, formControls, _bb, htmlElements, labels } - } - - $$self.$inject_state = $$props => { - if ("containerClass" in $$props) - $$invalidate( - "containerClass", - (containerClass = $$props.containerClass) - ) - if ("formControls" in $$props) - $$invalidate("formControls", (formControls = $$props.formControls)) - if ("_bb" in $$props) $$invalidate("_bb", (_bb = $$props._bb)) - if ("htmlElements" in $$props) - $$invalidate("htmlElements", (htmlElements = $$props.htmlElements)) - if ("labels" in $$props) $$invalidate("labels", (labels = $$props.labels)) - } - - $$self.$$.update = ( - $$dirty = { formControls: 1, _bb: 1, htmlElements: 1 } - ) => { - if ($$dirty.formControls || $$dirty._bb || $$dirty.htmlElements) { - { - let cIndex = 0 - for (let c of formControls) { - $$invalidate("labels", (labels[cIndex] = c.label), labels) - cIndex++ - } - - if (_bb && htmlElements) { - for (let el in htmlElements) { - _bb.initialiseComponent( - formControls[el].control, - htmlElements[el] - ) - } - } - } - } - } - - return { - containerClass, - formControls, - _bb, - htmlElements, - labels, - div1_binding, - } - } - - class Form extends SvelteComponentDev { - constructor(options) { - super(options) - init(this, options, instance$1, create_fragment$1, safe_not_equal, [ - "containerClass", - "formControls", - "_bb", - ]) - dispatch_dev("SvelteRegisterComponent", { - component: this, - tagName: "Form", - options, - id: create_fragment$1.name, - }) - - const { ctx } = this.$$ - const props = options.props || {} - if (ctx._bb === undefined && !("_bb" in props)) { - console.warn(" was created without expected prop '_bb'") - } - } - - get containerClass() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set containerClass(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - - get formControls() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set formControls(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - - get _bb() { - throw new Error( - ": Props cannot be read directly from the component instance unless compiling with 'accessors: true' or ''" - ) - } - - set _bb(value) { - throw new Error( - ": Props cannot be set directly on the component instance unless compiling with 'accessors: true' or ''" - ) - } - } - - /* src\Button.svelte generated by Svelte v3.12.1 */ - - const file$2 = "src\\Button.svelte" - - // (30:4) {:else} - function create_else_block$1(ctx) { - var current - - const default_slot_template = ctx.$$slots.default - const default_slot = create_slot(default_slot_template, ctx, null) - - const block = { - c: function create() { - if (default_slot) default_slot.c() - }, - - l: function claim(nodes) { - if (default_slot) default_slot.l(nodes) - }, - - m: function mount(target, anchor) { - if (default_slot) { - default_slot.m(target, anchor) - } - - current = true - }, - - p: function update(changed, ctx) { - if (default_slot && default_slot.p && changed.$$scope) { - default_slot.p( - get_slot_changes(default_slot_template, ctx, changed, null), - get_slot_context(default_slot_template, ctx, null) - ) - } - }, - - i: function intro(local) { - if (current) return - transition_in(default_slot, local) - current = true - }, - - o: function outro(local) { - transition_out(default_slot, local) - current = false - }, - - d: function destroy(detaching) { - if (default_slot) default_slot.d(detaching) - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_else_block$1.name, - type: "else", - source: "(30:4) {:else}", - ctx, - }) - return block - } - - // (28:26) - function create_if_block_1(ctx) { - var t - - const block = { - c: function create() { - t = text(ctx.contentText) - }, - - l: function claim(nodes) { - t = claim_text(nodes, ctx.contentText) - }, - - m: function mount(target, anchor) { - insert_dev(target, t, anchor) - }, - - p: function update(changed, ctx) { - if (changed.contentText) { - set_data_dev(t, ctx.contentText) - } - }, - - i: noop, - o: noop, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(t) - } - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_if_block_1.name, - type: "if", - source: "(28:26) ", - ctx, - }) - return block - } - - // (25:4) {#if contentComponent && contentComponent._component} - function create_if_block$1(ctx) { - var div - - const block = { - c: function create() { - div = element("div") - this.h() - }, - - l: function claim(nodes) { - div = claim_element(nodes, "DIV", {}, false) - var div_nodes = children(div) - - div_nodes.forEach(detach_dev) - this.h() - }, - - h: function hydrate() { - add_location(div, file$2, 25, 1, 543) - }, - - m: function mount(target, anchor) { - insert_dev(target, div, anchor) - ctx.div_binding(div) - }, - - p: noop, - i: noop, - o: noop, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(div) - } - - ctx.div_binding(null) - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_if_block$1.name, - type: "if", - source: "(25:4) {#if contentComponent && contentComponent._component}", - ctx, - }) - return block - } - - function create_fragment$2(ctx) { - var button, - current_block_type_index, - if_block, - button_class_value, - current, - dispose - - var if_block_creators = [ - create_if_block$1, - create_if_block_1, - create_else_block$1, - ] - - var if_blocks = [] - - function select_block_type(changed, ctx) { - if (ctx.contentComponent && ctx.contentComponent._component) return 0 - if (ctx.contentText) return 1 - return 2 - } - - current_block_type_index = select_block_type(null, ctx) - if_block = if_blocks[current_block_type_index] = if_block_creators[ - current_block_type_index - ](ctx) - - const block = { - c: function create() { - button = element("button") - if_block.c() - this.h() - }, - - l: function claim(nodes) { - button = claim_element( - nodes, - "BUTTON", - { class: true, disabled: true }, - false - ) - var button_nodes = children(button) - - if_block.l(button_nodes) - button_nodes.forEach(detach_dev) - this.h() - }, - - h: function hydrate() { - attr_dev( - button, - "class", - (button_class_value = - "" + null_to_empty(ctx.className) + " svelte-1q8lga0") - ) - button.disabled = ctx.disabled - add_location(button, file$2, 23, 0, 422) - dispose = listen_dev(button, "click", ctx.clickHandler) - }, - - m: function mount(target, anchor) { - insert_dev(target, button, anchor) - if_blocks[current_block_type_index].m(button, null) - current = true - }, - - p: function update(changed, ctx) { - var previous_block_index = current_block_type_index - current_block_type_index = select_block_type(changed, ctx) - if (current_block_type_index === previous_block_index) { - if_blocks[current_block_type_index].p(changed, ctx) - } else { - group_outros() - transition_out(if_blocks[previous_block_index], 1, 1, () => { - if_blocks[previous_block_index] = null - }) - check_outros() - - if_block = if_blocks[current_block_type_index] - if (!if_block) { - if_block = if_blocks[current_block_type_index] = if_block_creators[ - current_block_type_index - ](ctx) - if_block.c() - } - transition_in(if_block, 1) - if_block.m(button, null) - } - - if ( - (!current || changed.className) && - button_class_value !== - (button_class_value = - "" + null_to_empty(ctx.className) + " svelte-1q8lga0") - ) { - attr_dev(button, "class", button_class_value) - } - - if (!current || changed.disabled) { - prop_dev(button, "disabled", ctx.disabled) - } - }, - - i: function intro(local) { - if (current) return - transition_in(if_block) - current = true - }, - - o: function outro(local) { - transition_out(if_block) - current = false - }, - - d: function destroy(detaching) { - if (detaching) { - detach_dev(button) - } - - if_blocks[current_block_type_index].d() - dispose() - }, - } - dispatch_dev("SvelteRegisterBlock", { - block, - id: create_fragment$2.name, - type: "component", - source: "", - ctx, - }) - return block - } - - function instance$2($$self, $$props, $$invalidate) { - let { - className = "default", - disabled = false, - contentText, - contentComponent, - onClick = () => { }, - } = $$props - - let { _bb } = $$props - let contentComponentContainer - - const clickHandler = () => { - if (onClick) onClick() - } - - const writable_props = [ - "className", - "disabled", - "contentText", - "contentComponent", - "onClick", - "_bb", - ] - Object.keys($$props).forEach(key => { - if (!writable_props.includes(key) && !key.startsWith("$$")) - console.warn(` - - {/each} - - {/if} - {#each items as navItem, index} -
- {/each} -
- - diff --git a/packages/bootstrap-components/src/Test/TestApp.svelte b/packages/bootstrap-components/src/Test/TestApp.svelte deleted file mode 100644 index 546bdee504..0000000000 --- a/packages/bootstrap-components/src/Test/TestApp.svelte +++ /dev/null @@ -1,34 +0,0 @@ - - -{#await _appPromise} - loading -{:then _bb} - -
- -{/await} - - diff --git a/packages/bootstrap-components/src/Test/createApp.js b/packages/bootstrap-components/src/Test/createApp.js deleted file mode 100644 index ac2ecb579b..0000000000 --- a/packages/bootstrap-components/src/Test/createApp.js +++ /dev/null @@ -1,43 +0,0 @@ -import Login from "../Login.svelte" -import Grid from "../Grid.svelte" -import Form from "../Form.svelte" -import Textbox from "../Textbox.svelte" -import Text from "../Text.svelte" -import Nav from "../Nav.svelte" -import Panel from "../Panel.svelte" -import StackPanel from "../StackPanel.svelte" -import Table from "../Table.svelte" -import Button from "../Button.svelte" -import { createApp } from "@budibase/client/src/createApp" - -export default async () => { - const componentLibraries = { - components: { - login: Login, - grid: Grid, - form: Form, - textbox: Textbox, - text: Text, - nav: Nav, - panel: Panel, - table: Table, - stackpanel: StackPanel, - button: Button, - }, - } - - const appDef = { hierarchy: {}, actions: {} } - const user = { name: "yeo", permissions: [] } - - var app = createApp(componentLibraries, appDef, user) - app.store.update(s => { - s.people = [ - { name: "bob", address: "123 Main Street", status: "Open" }, - { name: "poppy", address: "456 Side Road", status: "Closed" }, - { name: "Oscar", address: "678 Dodgy Alley", status: "Open" }, - ] - return s - }) - - return app -} diff --git a/packages/bootstrap-components/src/Test/props.js b/packages/bootstrap-components/src/Test/props.js deleted file mode 100644 index 299d685cd5..0000000000 --- a/packages/bootstrap-components/src/Test/props.js +++ /dev/null @@ -1,247 +0,0 @@ -export const props = { - login: { _component: "components/login" }, - - form: { - _component: "components/form", - formControls: [ - { - control: { - _component: "components/textbox", - }, - label: "First Name", - }, - { - control: { - _component: "components/textbox", - }, - label: "Last Name", - }, - ], - }, - - nav: { - _component: "components/nav", - navBarBackground: "red", - navBarBorder: "1px solid maroon", - navBarColor: "black", - selectedItemBackground: "maroon", - selectedItemColor: "white", - selectedItemBorder: "green", - itemHoverBackground: "yellow", - itemHoverColor: "pink", - items: [ - { - title: "People", - component: { - _component: "components/panel", - text: "People Panel", - padding: "40px", - border: "2px solid pink", - background: "mistyrose", - }, - }, - { - title: "Animals", - component: { - _component: "components/panel", - text: "Animals Panel", - padding: "40px", - border: "2px solid green", - background: "azure", - }, - }, - ], - }, - - table: { - _component: "components/table", - columns: [ - { - title: { - "##bbstate": "NameColumnName", - "##bbsource": "store", - "##bbstatefallback": "Name", - }, - value: { - "##bbstate": "name", - "##bbsource": "context", - }, - }, - { - title: "Address", - value: { - "##bbstate": "address", - "##bbsource": "context", - }, - }, - { - title: "Status", - value: { - "##bbstate": "status", - "##bbsource": "context", - }, - }, - ], - data: { - "##bbstate": "people", - }, - onRowClick: [ - { - "##eventHandlerType": "Set State", - parameters: { - path: "NameColumnName", - value: { - "##bbstate": "name", - "##bbsource": "context", - "##bbstatefallback": "balls to that", - }, - }, - }, - ], - tableClass: "table-default", - theadClass: "thead-default", - tbodyClass: "tbody-default", - trClass: "tr-default", - thClass: "th-default", - }, - - grid: { - _component: "components/grid", - gridTemplateColumns: "[left] auto [center] auto [right] auto", - gridTemplateRows: "[top] auto [middle] auto [bottom] auto", - children: [ - { - control: { - _component: "components/text", - value: "1", - background: "blue", - textAlign: "center", - color: "white", - }, - gridColumn: "left", - gridRow: "top", - }, - { - control: { - _component: "components/text", - value: "2", - background: "red", - textAlign: "center", - color: "white", - padding: "10px", - }, - gridColumn: "center", - gridRow: "middle", - }, - { - control: { - _component: "components/text", - value: "3", - background: "yellow", - textAlign: "center", - color: "black", - }, - gridColumn: "right", - gridRow: "bottom", - }, - ], - }, - boundStackPanel: { - _component: "components/stackpanel", - direction: "horizontal", - children: [ - { - control: { - _component: "components/text", - value: "STATIC", - }, - }, - ], - data: { - "##bbstate": "people", - }, - dataItemComponent: { - _component: "components/panel", - text: { - "##bbstate": "name", - "##bbsource": "context", - "##bbstatefallback": "balls to that", - }, - padding: "10px", - border: "5px solid black", - margin: "10px", - hoverColor: "white", - hoverBackground: "black", - height: "200px", - weight: "200px", - }, - }, - hiddenNav: { - _component: "components/stackpanel", - children: [ - { - control: { - _component: "components/button", - contentText: "Peep", - onClick: [ - { - "##eventHandlerType": "Set State", - parameters: { - path: "selected", - value: "People", - }, - }, - ], - }, - }, - { - control: { - _component: "components/button", - contentText: "Ani", - onClick: [ - { - "##eventHandlerType": "Set State", - parameters: { - path: "selected", - value: "Animals", - }, - }, - ], - }, - }, - { - control: { - _component: "components/nav", - hideNavBar: true, - selectedItem: { - "##bbstate": "selected", - "##bbsource": "store", - "##bbstatefallback": "Animals", - }, - items: [ - { - title: "People", - component: { - _component: "components/panel", - text: "People Panel", - padding: "40px", - border: "2px solid pink", - background: "mistyrose", - }, - }, - { - title: "Animals", - component: { - _component: "components/panel", - text: "Animals Panel", - padding: "40px", - border: "2px solid green", - background: "azure", - }, - }, - ], - }, - }, - ], - }, -} diff --git a/packages/bootstrap-components/src/Test/testMain.js b/packages/bootstrap-components/src/Test/testMain.js deleted file mode 100644 index d31b18d42e..0000000000 --- a/packages/bootstrap-components/src/Test/testMain.js +++ /dev/null @@ -1,7 +0,0 @@ -import App from "./TestApp.svelte" - -const app = new App({ - target: document.body, -}) - -export default app diff --git a/packages/bootstrap-components/src/buildStyle.js b/packages/bootstrap-components/src/buildStyle.js deleted file mode 100644 index 53c77e062e..0000000000 --- a/packages/bootstrap-components/src/buildStyle.js +++ /dev/null @@ -1,9 +0,0 @@ -export const buildStyle = styles => { - let str = "" - for (let s in styles) { - if (styles[s]) { - str += `${s}: ${styles[s]}; ` - } - } - return str -} diff --git a/packages/bootstrap-components/src/cssVars.js b/packages/bootstrap-components/src/cssVars.js deleted file mode 100644 index 610cdc8f0a..0000000000 --- a/packages/bootstrap-components/src/cssVars.js +++ /dev/null @@ -1,19 +0,0 @@ -// https://github.com/kaisermann/svelte-css-vars - -export default (node, props) => { - Object.entries(props).forEach(([key, value]) => { - node.style.setProperty(`--${key}`, value) - }) - - return { - update(new_props) { - Object.entries(new_props).forEach(([key, value]) => { - node.style.setProperty(`--${key}`, value) - delete props[key] - }) - - Object.keys(props).forEach(name => node.style.removeProperty(`--${name}`)) - props = new_props - }, - } -} diff --git a/packages/bootstrap-components/src/emptyProps.js b/packages/bootstrap-components/src/emptyProps.js deleted file mode 100644 index 6938c06462..0000000000 --- a/packages/bootstrap-components/src/emptyProps.js +++ /dev/null @@ -1 +0,0 @@ -export const emptyProps = () => ({ _component: "" }) diff --git a/packages/bootstrap-components/src/index.js b/packages/bootstrap-components/src/index.js deleted file mode 100644 index 4333f880be..0000000000 --- a/packages/bootstrap-components/src/index.js +++ /dev/null @@ -1,2 +0,0 @@ -export { default as form } from "./Form.svelte" -export { default as nav } from "./Nav.svelte" diff --git a/packages/builder/src/builderStore/generate_css.js b/packages/builder/src/builderStore/generate_css.js index 8c98d01e75..fb7c9e3808 100644 --- a/packages/builder/src/builderStore/generate_css.js +++ b/packages/builder/src/builderStore/generate_css.js @@ -1,4 +1,5 @@ -import { filter, map, reduce, toPairs, pipe } from "lodash/fp" +import { pipe } from "components/common/core"; +import { filter, map, reduce, toPairs } from "lodash/fp" const self = n => n const join_with = delimiter => a => a.join(delimiter) diff --git a/packages/builder/src/builderStore/loadComponentLibraries.js b/packages/builder/src/builderStore/loadComponentLibraries.js index 3935eee9ea..04b25ca5d2 100644 --- a/packages/builder/src/builderStore/loadComponentLibraries.js +++ b/packages/builder/src/builderStore/loadComponentLibraries.js @@ -1,56 +1,73 @@ -import { flatten, values, uniq, map } from "lodash/fp" -import { pipe } from "components/common/core" +/** + * Fetches the definitions for component library components. This includes + * their props and other metadata from components.json. + * @param {string} clientId - ID of the current client + * @param {string} appId - ID of the currently running app + */ +export const fetchComponentLibDefinitions = async (clientId, appId) => { + const LIB_DEFINITION_URL = `/${clientId}/${appId}/components/definitions`; + try { + const libDefinitionResponse = await fetch(LIB_DEFINITION_URL); + return await libDefinitionResponse.json(); + } catch (err) { + console.error(`Error fetching component definitions for ${appId}`, err); + } +}; -export const loadLibs = async (appId, appPackage) => { +/** + * Loads the JavaScript files for app component libraries and returns a map of their modules. + * @param {object} application - package definition + */ +export const fetchComponentLibModules = async application => { const allLibraries = {} - for (let lib of libsFromPages(appPackage.pages)) { - console.log(libModule); - const libModule = await import(makeLibraryUrl(appId, lib)) - allLibraries[lib] = libModule + for (let libraryName of application.componentLibraries) { + const LIBRARY_URL = `/${application._id}/componentlibrary?library=${libraryName}`; + const libraryModule = await import(LIBRARY_URL) + allLibraries[libraryName] = libraryModule } return allLibraries } -export const loadLibUrls = (appId, appPackage) => { - const allLibraries = [] - for (let lib of libsFromPages(appPackage.pages)) { - const libUrl = makeLibraryUrl(appId, lib) - allLibraries.push({ libName: lib, importPath: libUrl }) - } +// export const loadLibUrls = (appId, appPackage) => { +// const allLibraries = [] +// for (let lib of libsFromPages(appPackage.pages)) { +// const libUrl = makeLibraryUrl(appId, lib) +// allLibraries.push({ libName: lib, importPath: libUrl }) +// } - return allLibraries -} +// return allLibraries +// } -export const loadLib = async (appId, lib, allLibs) => { - allLibs[lib] = await import(makeLibraryUrl(appId, lib)) - return allLibs -} +// export const loadLib = async (appId, lib, allLibs) => { +// allLibs[lib] = await import(makeLibraryUrl(appId, lib)) +// return allLibs +// } -export const makeLibraryUrl = (appId, lib) => - `/_builder/${appId}/componentlibrary?lib=${encodeURI(lib)}` +// export const makeLibraryUrl = (appId, lib) => +// `/_builder/${appId}/componentlibrary?lib=${encodeURI(lib)}` -export const libsFromPages = pages => - pipe(pages, [values, map(p => p.componentLibraries), flatten, uniq]) +// export const libsFromPages = pages => +// pipe(pages, [values, map(p => p.componentLibraries), flatten, uniq]) -export const libUrlsForPreview = (appPackage, pageName) => { - const resolve = path => { - let file = appPackage.components.libraryPaths[path] - if (file.startsWith("./")) file = file.substring(2) - if (file.startsWith("/")) file = file.substring(1) +// export const libUrlsForPreview = (appPackage, pageName) => { +// const resolve = path => { +// let file = appPackage.components.libraryPaths[path] +// if (file.startsWith("./")) file = file.substring(2) +// if (file.startsWith("/")) file = file.substring(1) - let newPath = path +// let newPath = path - if (!newPath.startsWith("./") && !newPath.startsWith("/")) { - newPath = `/node_modules/${path}` - } +// if (!newPath.startsWith("./") && !newPath.startsWith("/")) { +// newPath = `/node_modules/${path}` +// } - return { - importPath: `/lib${newPath}/${file}`, - libName: path, - } - } +// return { +// importPath: `/lib${newPath}/${file}`, +// libName: path, +// } +// } - return pipe([appPackage.pages[pageName]], [libsFromPages, map(resolve)]) -} +// return pipe([appPackage.pages[pageName]], [libsFromPages, map(resolve)]) +// } diff --git a/packages/builder/src/builderStore/store/backend.js b/packages/builder/src/builderStore/store/backend.js index 00918f724f..e3c1033925 100644 --- a/packages/builder/src/builderStore/store/backend.js +++ b/packages/builder/src/builderStore/store/backend.js @@ -1,12 +1,5 @@ import { writable } from "svelte/store" import api from "../api" -import { find } from "lodash/fp" -import { - getNode, - constructHierarchy, -} from "components/common/core" - -import backendActions from "../../actions/backend"; export const getBackendUiStore = () => { const INITIAL_BACKEND_UI_STATE = { diff --git a/packages/builder/src/builderStore/store/index.js b/packages/builder/src/builderStore/store/index.js index de2a76e2ea..1783f5d983 100644 --- a/packages/builder/src/builderStore/store/index.js +++ b/packages/builder/src/builderStore/store/index.js @@ -1,19 +1,23 @@ -import { filter, cloneDeep, last, concat, isEmpty, values } from "lodash/fp" -import { pipe, getNode, constructHierarchy } from "components/common/core" +import { filter, cloneDeep, values } from "lodash/fp" +import { pipe } from "components/common/core" import * as backendStoreActions from "./backend" import { writable } from "svelte/store" -import { defaultPagesObject } from "components/userInterface/pagesParsing/defaultPagesObject" import api from "../api" +import { + DEFAULT_PAGES_OBJECT +} from "../../constants"; import { getExactComponent } from "components/userInterface/pagesParsing/searchComponents" import { rename } from "components/userInterface/pagesParsing/renameScreen" import { - getNewScreen, + // getNewScreen, createProps, makePropsSafe, getBuiltin, } from "components/userInterface/pagesParsing/createProps" -import { expandComponentDefinition } from "components/userInterface/pagesParsing/types" -import { loadLibs, libUrlsForPreview } from "../loadComponentLibraries" +import { + fetchComponentLibModules, + fetchComponentLibDefinitions +} from "../loadComponentLibraries" import { buildCodeForScreens } from "../buildCodeForScreens" import { generate_screen_css } from "../generate_css" import { insertCodeMetadata } from "../insertCodeMetadata" @@ -24,7 +28,7 @@ export const getStore = () => { apps: [], appname: "", hierarchy: {}, - pages: defaultPagesObject(), + pages: DEFAULT_PAGES_OBJECT, mainUi: {}, unauthenticatedUi: {}, components: [], @@ -35,8 +39,6 @@ export const getStore = () => { currentComponentProps: null, errors: [], hasAppPackage: false, - // accessLevels: { version: 0, levels: [] }, - // currentNode: null, libraries: null, appId: "" } @@ -52,7 +54,7 @@ export const getStore = () => { // store.deleteAction = backendStoreActions.deleteAction(store) // store.saveTrigger = backendStoreActions.saveTrigger(store) // store.deleteTrigger = backendStoreActions.deleteTrigger(store) - store.importAppDefinition = importAppDefinition(store) + // store.importAppDefinition = importAppDefinition(store) store.saveScreen = saveScreen(store) store.renameScreen = renameScreen(store) @@ -60,11 +62,9 @@ export const getStore = () => { store.setCurrentScreen = setCurrentScreen(store) store.setCurrentPage = setCurrentPage(store) store.createScreen = createScreen(store) - // store.removeComponentLibrary = removeComponentLibrary(store) store.addStylesheet = addStylesheet(store) store.removeStylesheet = removeStylesheet(store) store.savePage = savePage(store) - store.createGeneratedComponents = createGeneratedComponents(store) store.addChildComponent = addChildComponent(store) store.selectComponent = selectComponent(store) store.setComponentProp = setComponentProp(store) @@ -102,7 +102,9 @@ const setPackage = (store, initial) => async (pkg) => { }, } - initial.libraries = await loadLibs(pkg.application._id, pkg) + initial.libraries = await fetchComponentLibModules(pkg.application) + // TODO: Rename to componentDefinitions + initial.components = await fetchComponentLibDefinitions(pkg.clientId, pkg.application._id); initial.loadLibraryUrls = pageName => { const libs = libUrlsForPreview(pkg, pageName) return libs @@ -111,40 +113,20 @@ const setPackage = (store, initial) => async (pkg) => { initial.appId = pkg.application._id initial.pages = pkg.pages initial.hasAppPackage = true - initial.hierarchy = pkg.appDefinition.hierarchy - initial.accessLevels = pkg.accessLevels initial.screens = values(pkg.screens) - initial.components = values(pkg.components.components).map( - expandComponentDefinition - ) initial.templates = pkg.components.templates initial.builtins = [getBuiltin("##builtin/screenslot")] - initial.actions = values(pkg.appDefinition.actions) - initial.triggers = pkg.appDefinition.triggers initial.appInstances = pkg.application.instances initial.appId = pkg.application._id store.set(initial) + console.log(initial) return initial } -const importAppDefinition = store => appDefinition => { - store.update(s => { - s.hierarchy = appDefinition.hierarchy - s.currentNode = - appDefinition.hierarchy.children.length > 0 - ? appDefinition.hierarchy.children[0] - : null - s.actions = appDefinition.actions - s.triggers = appDefinition.triggers - s.currentNodeIsNew = false - return s - }) -} - const saveScreen = store => screen => { - store.update(s => { - return _saveScreen(store, s, screen) + store.update(state => { + return _saveScreen(store, state, screen) }) } @@ -166,10 +148,7 @@ const _saveScreen = async (store, s, screen) => { innerState.screens = screens innerState.currentPreviewItem = screen const safeProps = makePropsSafe( - getComponentDefinition( - innerState.components, - screen.props._component - ), + innerState.components[screen.props._component], screen.props ) innerState.currentComponentInfo = safeProps @@ -192,21 +171,27 @@ const _saveScreenApi = (screen, s) => .then(() => _savePage(s)) const createScreen = store => (screenName, route, layoutComponentName) => { - store.update(s => { - const newScreen = getNewScreen( - s.components, - layoutComponentName, - screenName - ) + store.update(state => { + console.log(layoutComponentName); + const rootComponent = state.components[layoutComponentName] + + const newScreen = { + name: screenName || "", + description: "", + url: "", + _css: "", + uiFunctions: "", + props: createProps(rootComponent).props, + } newScreen.route = route - s.currentPreviewItem = newScreen - s.currentComponentInfo = newScreen.props - s.currentFrontEndType = "screen" + state.currentPreviewItem = newScreen + state.currentComponentInfo = newScreen.props + state.currentFrontEndType = "screen" - _saveScreen(store, s, newScreen) + _saveScreen(store, state, newScreen) - return s + return state }) } @@ -219,7 +204,7 @@ const setCurrentScreen = store => screenName => { s.currentView = "detail" const safeProps = makePropsSafe( - getComponentDefinition(s.components, screen.props._component), + s.components[screen.props._component], screen.props ) screen.props = safeProps @@ -229,25 +214,6 @@ const setCurrentScreen = store => screenName => { }) } -const createGeneratedComponents = store => components => { - store.update(s => { - s.components = [...s.components, ...components] - s.screens = [...s.screens, ...components] - - const doCreate = async () => { - for (let c of components) { - await api.post(`/_builder/api/${s.appId}/screen`, c) - } - - await _savePage(s) - } - - doCreate() - - return s - }) -} - const deleteScreen = store => name => { store.update(s => { const components = pipe(s.components, [filter(c => c.name !== name)]) @@ -319,46 +285,6 @@ const savePage = store => async page => { }) } -// const addComponentLibrary = store => async lib => { -// const response = await api.get( -// `/_builder/api/${s.appId}/componentlibrary?lib=${encodeURI(lib)}`, -// undefined, -// false -// ) - -// const success = response.status === 200 - -// const components = success ? await response.json() : [] - -// store.update(s => { -// if (success) { -// const componentsArray = [] -// for (let c in components) { -// componentsArray.push(expandComponentDefinition(components[c])) -// } - -// s.components = pipe(s.components, [ -// filter(c => !c.name.startsWith(`${lib}/`)), -// concat(componentsArray), -// ]) - -// s.pages.componentLibraries.push(lib) -// _savePage(s) -// } - -// return s -// }) -// } - -// const removeComponentLibrary = store => lib => { -// store.update(state => { -// state.pages.componentLibraries = state.pages.componentLibraries.filter(l => l !== lib); -// _savePage(state); - -// return state; -// }) -// } - const addStylesheet = store => stylesheet => { store.update(s => { s.pages.stylesheets.push(stylesheet) @@ -386,42 +312,44 @@ const _savePage = async s => { } const setCurrentPage = store => pageName => { - store.update(s => { - const current_screens = s.pages[pageName]._screens + store.update(state => { + const current_screens = state.pages[pageName]._screens - s.currentFrontEndType = "page" - s.currentPageName = pageName - s.screens = Array.isArray(current_screens) + const currentPage = state.pages[pageName]; + + state.currentFrontEndType = "page" + state.currentPageName = pageName + state.screens = Array.isArray(current_screens) ? current_screens : Object.values(current_screens) const safeProps = makePropsSafe( - getComponentDefinition(s.components, s.pages[pageName].props._component), - s.pages[pageName].props + state.components[currentPage.props._component], + currentPage.props ) - s.currentComponentInfo = safeProps - s.pages[pageName].props = safeProps - s.currentPreviewItem = s.pages[pageName] - s.currentPreviewItem._css = generate_screen_css([ - s.currentPreviewItem.props, + state.currentComponentInfo = safeProps + currentPage.props = safeProps + state.currentPreviewItem = state.pages[pageName] + state.currentPreviewItem._css = generate_screen_css([ + state.currentPreviewItem.props, ]) - for (let screen of s.screens) { + for (let screen of state.screens) { screen._css = generate_screen_css([screen.props]) } - setCurrentPageFunctions(s) - return s + setCurrentPageFunctions(state) + return state }) } -const getComponentDefinition = (components, name) => - components.find(c => c.name === name) +// const getComponentDefinition = (components, name) => components.find(c => c.name === name) /** * @param {string} componentToAdd - name of the component to add to the application * @param {string} presetName - name of the component preset if defined */ const addChildComponent = store => (componentToAdd, presetName) => { + // componentToAdd looks like: @budibase/standard-components/container store.update(state => { function findSlot(component_array) { for (let i = 0; i < component_array.length; i += 1) { @@ -442,7 +370,7 @@ const addChildComponent = store => (componentToAdd, presetName) => { const component = componentToAdd.startsWith("##") ? getBuiltin(componentToAdd) - : state.components.find(({ name }) => name === componentToAdd) + : state.components[componentToAdd] const presetProps = presetName ? component.presets[presetName] : {} const newComponent = createProps(component, presetProps) @@ -488,7 +416,7 @@ const selectComponent = store => component => { store.update(state => { const componentDef = component._component.startsWith("##") ? component - : state.components.find(c => c.name === component._component) + : state.components[component._component] state.currentComponentInfo = makePropsSafe(componentDef, component) state.currentView = "component" return state @@ -508,28 +436,28 @@ const setComponentProp = store => (name, value) => { } const setComponentStyle = store => (type, name, value) => { - store.update(s => { - if (!s.currentComponentInfo._styles) { - s.currentComponentInfo._styles = {} + store.update(state => { + if (!state.currentComponentInfo._styles) { + state.currentComponentInfo._styles = {} } - s.currentComponentInfo._styles[type][name] = value - s.currentPreviewItem._css = generate_screen_css([ - s.currentPreviewItem.props, + state.currentComponentInfo._styles[type][name] = value + state.currentPreviewItem._css = generate_screen_css([ + state.currentPreviewItem.props, ]) // save without messing with the store - _saveCurrentPreviewItem(s) - return s + _saveCurrentPreviewItem(state) + return state }) } const setComponentCode = store => code => { - store.update(s => { - s.currentComponentInfo._code = code + store.update(state => { + state.currentComponentInfo._code = code - setCurrentPageFunctions(s) + setCurrentPageFunctions(state) // save without messing with the store - _saveScreenApi(s.currentPreviewItem, s) + _saveScreenApi(state.currentPreviewItem, state) return s }) @@ -543,31 +471,31 @@ const setCurrentPageFunctions = s => { const buildPageCode = (screens, page) => buildCodeForScreens([page, ...screens]) const setScreenType = store => type => { - store.update(s => { - s.currentFrontEndType = type + store.update(state => { + state.currentFrontEndType = type const pageOrScreen = type === "page" - ? s.pages[s.currentPageName] - : s.pages[s.currentPageName]._screens[0] + ? state.pages[state.currentPageName] + : state.pages[state.currentPageName]._screens[0] - s.currentComponentInfo = pageOrScreen ? pageOrScreen.props : null - s.currentPreviewItem = pageOrScreen - return s + state.currentComponentInfo = pageOrScreen ? pageOrScreen.props : null + state.currentPreviewItem = pageOrScreen + return state }) } -const deleteComponent = store => component => { - store.update(s => { - const parent = getParent(s.currentPreviewItem.props, component) +const deleteComponent = store => componentName => { + store.update(state => { + const parent = getParent(state.currentPreviewItem.props, componentName) if (parent) { - parent._children = parent._children.filter(c => c !== component) + parent._children = parent._children.filter(component => component !== componentName) } - _saveCurrentPreviewItem(s) + _saveCurrentPreviewItem(state) - return s + return state }) } diff --git a/packages/builder/src/components/actionsAndTriggers/ActionView.svelte b/packages/builder/src/components/actionsAndTriggers/ActionView.svelte deleted file mode 100644 index c1eb2f3fd4..0000000000 --- a/packages/builder/src/components/actionsAndTriggers/ActionView.svelte +++ /dev/null @@ -1,133 +0,0 @@ - - -
- - - -
- - - - - - - -
- -
- - - Add -
-
- {#each initialOptions as option} - - {option.key} : {option.value} - removeOption(option)}> - {@html getIcon('trash-2')} - - - {/each} -
-
- - -
- - diff --git a/packages/builder/src/components/actionsAndTriggers/Actions.svelte b/packages/builder/src/components/actionsAndTriggers/Actions.svelte deleted file mode 100644 index 06a8c6906d..0000000000 --- a/packages/builder/src/components/actionsAndTriggers/Actions.svelte +++ /dev/null @@ -1,108 +0,0 @@ - - -

Actions

- -{#if actionsArray} - - - - - - - - - - - {#each actionsArray as action} - - - - - - - - {/each} - -
DescriptionBehaviour SourceBehaviour NameDefault Options -
{action.name}{action.behaviourSource}{action.behaviourName} - {@html getDefaultOptionsHtml(action.initialOptions)} - - onActionEdit(action)}> - {@html getIcon('edit')} - - onActionDelete(action)}> - {@html getIcon('trash')} - -
-{:else}(no actions added){/if} - - - {#if isEditing} - - {/if} - - - diff --git a/packages/builder/src/components/actionsAndTriggers/ActionsAndTriggersRoot.svelte b/packages/builder/src/components/actionsAndTriggers/ActionsAndTriggersRoot.svelte deleted file mode 100644 index 2d7c1e23cd..0000000000 --- a/packages/builder/src/components/actionsAndTriggers/ActionsAndTriggersRoot.svelte +++ /dev/null @@ -1,135 +0,0 @@ - - -
-
- - - Create New Action - - - Create New Trigger - - -
- -
- - - -
- -
- - diff --git a/packages/builder/src/components/actionsAndTriggers/TriggerView.svelte b/packages/builder/src/components/actionsAndTriggers/TriggerView.svelte deleted file mode 100644 index c2133e9395..0000000000 --- a/packages/builder/src/components/actionsAndTriggers/TriggerView.svelte +++ /dev/null @@ -1,74 +0,0 @@ - - -
- - - -
- - - - - - - - - -
- - diff --git a/packages/builder/src/components/actionsAndTriggers/Triggers.svelte b/packages/builder/src/components/actionsAndTriggers/Triggers.svelte deleted file mode 100644 index 3e96bf72a8..0000000000 --- a/packages/builder/src/components/actionsAndTriggers/Triggers.svelte +++ /dev/null @@ -1,93 +0,0 @@ - - -

Triggers

- -{#if $store.triggers} - - - - - - - - - - - {#each $store.triggers as trigger} - - - - - - - - {/each} - -
EventActionConditionCreate Options -
{trigger.eventName}{trigger.actionName}{trigger.condition}{trigger.optionsCreator} - onTriggerEdit(trigger)}> - {@html getIcon('edit')} - - onTriggerDelete(trigger)}> - {@html getIcon('trash')} - -
-{:else}(no triggers added){/if} - - (isEditing = false)} - bind:isOpen={isEditing}> - {#if isEditing} - - {/if} - - - diff --git a/packages/builder/src/components/common/DropdownButton.svelte b/packages/builder/src/components/common/DropdownButton.svelte deleted file mode 100644 index 8fd85c372d..0000000000 --- a/packages/builder/src/components/common/DropdownButton.svelte +++ /dev/null @@ -1,67 +0,0 @@ - - -
(isDroppedDown = !isDroppedDown)}> - {@html getIcon(iconName)} - - - - diff --git a/packages/builder/src/components/database/ModelDataTable/ModelDataTable.svelte b/packages/builder/src/components/database/ModelDataTable/ModelDataTable.svelte index f6a5db8949..5210ddbcce 100644 --- a/packages/builder/src/components/database/ModelDataTable/ModelDataTable.svelte +++ b/packages/builder/src/components/database/ModelDataTable/ModelDataTable.svelte @@ -14,7 +14,6 @@ takeRight, } from "lodash/fp" import Select from "components/common/Select.svelte" - import { getIndexSchema } from "components/common/core" import ActionButton from "components/common/ActionButton.svelte" import TablePagination from "./TablePagination.svelte" import { DeleteRecordModal, CreateEditRecordModal } from "./modals" diff --git a/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/CreateEditModel.svelte b/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/CreateEditModel.svelte index 243f20aefd..1f4062bf44 100644 --- a/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/CreateEditModel.svelte +++ b/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/CreateEditModel.svelte @@ -9,8 +9,7 @@ import api from "builderStore/api" import { store, backendUiStore } from "builderStore" import { common, hierarchy } from "../../../../../../../core/src/" - import { getNode } from "components/common/core" - import { templateApi, pipe, validate } from "components/common/core" + import { pipe } from "components/common/core" import ErrorsBox from "components/common/ErrorsBox.svelte" export let model = { schema: {} } diff --git a/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/FieldView.svelte b/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/FieldView.svelte index ba5b379dbb..65934a032d 100644 --- a/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/FieldView.svelte +++ b/packages/builder/src/components/database/ModelDataTable/modals/CreateEditModel/FieldView.svelte @@ -10,10 +10,6 @@ import ActionButton from "components/common/ActionButton.svelte" import DatePicker from "components/common/DatePicker.svelte" import { keys, cloneDeep } from "lodash/fp" - import { - allTypes, - validate, - } from "components/common/core" const FIELD_TYPES = ["string", "number", "boolean"] diff --git a/packages/builder/src/components/database/ModelDataTable/modals/CreateEditRecord.svelte b/packages/builder/src/components/database/ModelDataTable/modals/CreateEditRecord.svelte index d2e03f28f7..2a09b68efe 100644 --- a/packages/builder/src/components/database/ModelDataTable/modals/CreateEditRecord.svelte +++ b/packages/builder/src/components/database/ModelDataTable/modals/CreateEditRecord.svelte @@ -4,11 +4,6 @@ import { compose, map, get, flatten } from "lodash/fp" import ActionButton from "components/common/ActionButton.svelte" import Select from "components/common/Select.svelte" - import { - getNewRecord, - joinKey, - getExactNodeForKey, - } from "components/common/core" import RecordFieldControl from "./RecordFieldControl.svelte" import * as api from "../api" import ErrorsBox from "components/common/ErrorsBox.svelte" diff --git a/packages/builder/src/components/nav/SchemaManagementDrawer.svelte b/packages/builder/src/components/nav/SchemaManagementDrawer.svelte index 7407066868..d01b6b089b 100644 --- a/packages/builder/src/components/nav/SchemaManagementDrawer.svelte +++ b/packages/builder/src/components/nav/SchemaManagementDrawer.svelte @@ -2,7 +2,6 @@ import { getContext, onMount } from "svelte" import { store, backendUiStore } from "builderStore" import HierarchyRow from "./HierarchyRow.svelte" - import DropdownButton from "components/common/DropdownButton.svelte" import NavItem from "./NavItem.svelte" import getIcon from "components/common/icon" import api from "builderStore/api" diff --git a/packages/builder/src/components/userInterface/CurrentItemPreview.svelte b/packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte similarity index 98% rename from packages/builder/src/components/userInterface/CurrentItemPreview.svelte rename to packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte index c43e805673..129a76c103 100644 --- a/packages/builder/src/components/userInterface/CurrentItemPreview.svelte +++ b/packages/builder/src/components/userInterface/AppPreview/CurrentItemPreview.svelte @@ -32,7 +32,7 @@ $: screensExist = $store.currentPreviewItem._screens && $store.currentPreviewItem._screens.length > 0 $: frontendDefinition = { - componentLibraries: $store.loadLibraryUrls($store.currentPageName), + libraries: $store.libraries, page: $store.currentPreviewItem, screens: screensExist ? $store.currentPreviewItem._screens : [{ name: "Screen Placeholder", diff --git a/packages/builder/src/components/userInterface/AppPreview/index.js b/packages/builder/src/components/userInterface/AppPreview/index.js new file mode 100644 index 0000000000..09937800fa --- /dev/null +++ b/packages/builder/src/components/userInterface/AppPreview/index.js @@ -0,0 +1 @@ +export { default } from "./CurrentItemPreview.svelte"; \ No newline at end of file diff --git a/packages/builder/src/components/userInterface/ComponentSelectionList.svelte b/packages/builder/src/components/userInterface/ComponentSelectionList.svelte index 02d8e9df20..66df3aa686 100644 --- a/packages/builder/src/components/userInterface/ComponentSelectionList.svelte +++ b/packages/builder/src/components/userInterface/ComponentSelectionList.svelte @@ -29,23 +29,6 @@ const categories = components.categories let selectedCategory = categories[0] - // const onTemplateChosen = template => { - // selectedComponent = null - // const { componentName, libName } = splitName(template.name) - // const templateOptions = { - // records: getRecordNodes(hierarchy), - // indexes: getIndexNodes(hierarchy), - // helpers: { - // indexSchema: getIndexSchema(hierarchy), - // }, - // } - - // templateInstances = libraryModules[libName][componentName](templateOptions) - // if (!templateInstances || templateInstances.length === 0) return - // selectedTemplateInstance = templateInstances[0].name - // selectTemplateDialog.show() - // } - const onComponentChosen = component => { if (component.template) { // onTemplateChosen(component.template) @@ -55,28 +38,26 @@ } } - const onTemplateInstanceChosen = () => { - selectedComponent = null - const instance = templateInstances.find( - i => i.name === selectedTemplateInstance - ) - store.addTemplatedComponent(instance.props) - toggleTab() - } + // const onTemplateInstanceChosen = () => { + // selectedComponent = null + // const instance = templateInstances.find( + // i => i.name === selectedTemplateInstance + // ) + // store.addTemplatedComponent(instance.props) + // toggleTab() + // } - $: templatesByComponent = groupBy(t => t.component)($store.templates) - $: hierarchy = $store.hierarchy - $: libraryModules = $store.libraries - $: standaloneTemplates = pipe( - templatesByComponent, - [ - values, - flatten, - filter(t => !$store.components.some(c => c.name === t.component)), - map(t => ({ name: splitName(t.component).componentName, template: t })), - uniqBy(t => t.name), - ] - ) + // $: templatesByComponent = groupBy(t => t.component)($store.templates) + // $: standaloneTemplates = pipe( + // templatesByComponent, + // [ + // values, + // flatten, + // filter(t => !$store.components.some(c => c.name === t.component)), + // map(t => ({ name: splitName(t.component).componentName, template: t })), + // uniqBy(t => t.name), + // ] + // )
@@ -93,12 +74,11 @@ onComponentChosen(e.detail)} - {onTemplateChosen} {toggleTab} />
- (selectedComponent = null)} @@ -115,7 +95,7 @@
{/each} - + -->