├── .gitignore
├── .vscode
├── extensions.json
└── settings.json
├── LICENCE
├── README.md
├── demo
└── formSimple.js
├── index.html
├── jsconfig.json
├── package-lock.json
├── package.json
├── public
├── build
│ ├── bundle.css
│ ├── bundle.js.map
│ ├── bundle.mjs
│ └── form-builder-v1.js
├── favicon.png
└── form-editor.css
├── scripts
└── setupTypeScript.js
├── src
├── App.svelte
├── lib
│ ├── FormBuilder.svelte
│ ├── Step.svelte
│ ├── ui
│ │ ├── Common
│ │ │ ├── Inputs
│ │ │ │ ├── InputAddButton.svelte
│ │ │ │ ├── InputWrapper.svelte
│ │ │ │ ├── Menu.svelte
│ │ │ │ ├── SideMenu.svelte
│ │ │ │ └── Switcher.svelte
│ │ │ ├── Steps
│ │ │ │ ├── SideStepMenu.svelte
│ │ │ │ ├── StepLine.svelte
│ │ │ │ ├── StepMenu.svelte
│ │ │ │ └── StepWrapper.svelte
│ │ │ └── inputs.js
│ │ ├── EditorSteps.svelte
│ │ ├── Icons
│ │ │ ├── AsteriskIcon.svelte
│ │ │ ├── CheckboxIcon.svelte
│ │ │ ├── CloneIcon.svelte
│ │ │ ├── CloseIcon.svelte
│ │ │ ├── DateIcon.svelte
│ │ │ ├── DateTimeIcon.svelte
│ │ │ ├── EmailIcon.svelte
│ │ │ ├── Icon.svelte
│ │ │ ├── MenuIcon.svelte
│ │ │ ├── MultichoiceIcon.svelte
│ │ │ ├── NumberIcon.svelte
│ │ │ ├── PasswordIcon.svelte
│ │ │ ├── PlusIcon.svelte
│ │ │ ├── RadioIcon.svelte
│ │ │ ├── SelectIcon.svelte
│ │ │ ├── TextContentIcon.svelte
│ │ │ ├── TextIcon.svelte
│ │ │ ├── TextareaIcon.svelte
│ │ │ ├── TimeIcon.svelte
│ │ │ ├── TrashIcon.svelte
│ │ │ └── VisiblityIcon.svelte
│ │ ├── InputTypes
│ │ │ ├── Checkbox.svelte
│ │ │ ├── Date.svelte
│ │ │ ├── DateTime.svelte
│ │ │ ├── Email.svelte
│ │ │ ├── Multichoice.svelte
│ │ │ ├── Number.svelte
│ │ │ ├── Password.svelte
│ │ │ ├── Radio.svelte
│ │ │ ├── Select.svelte
│ │ │ ├── Submit.svelte
│ │ │ ├── Text.svelte
│ │ │ ├── TextContent.svelte
│ │ │ ├── Textarea.svelte
│ │ │ └── Time.svelte
│ │ ├── ListInputs.svelte
│ │ └── Modal.svelte
│ └── utils
│ │ ├── clickOutside.js
│ │ ├── cmpsRegistry.js
│ │ ├── random.js
│ │ ├── store.js
│ │ └── util.js
└── main.js
├── tailwind.config.js
└── vite.config.js
/.gitignore:
--------------------------------------------------------------------------------
1 | node_modules
2 | dist
3 | .DS_Store
--------------------------------------------------------------------------------
/.vscode/extensions.json:
--------------------------------------------------------------------------------
1 | {
2 | "recommendations": [
3 | "svelte.svelte-vscode",
4 | "esbenp.prettier-vscode",
5 | "dbaeumer.vscode-eslint",
6 | "rvest.vs-code-prettier-eslint"
7 | ]
8 | }
--------------------------------------------------------------------------------
/.vscode/settings.json:
--------------------------------------------------------------------------------
1 | {
2 | "editor.tabSize": 2,
3 | "editor.insertSpaces": true,
4 | "editor.detectIndentation": false,
5 | "svelte.plugin.css.documentSymbols.enable": false,
6 | "[svelte]": {
7 | "editor.tabSize": 4,
8 | "editor.insertSpaces": true,
9 | "editor.detectIndentation": true,
10 | "editor.defaultFormatter": "svelte.svelte-vscode"
11 | },
12 |
13 | "editor.defaultFormatter": "esbenp.prettier-vscode",
14 | "editor.formatOnSave": true,
15 | "editor.codeActionsOnSave": {
16 | "source.fixAll.eslint": true,
17 | "source.organizeImports": false
18 | },
19 | "workbench.colorCustomizations": {
20 | "activityBar.background": "#ffcb49d5",
21 | "activityBar.foreground": "#000"
22 | },
23 |
24 | "eslint.packageManager": "npm",
25 | "eslint.alwaysShowStatus": true,
26 | "eslint.validate": ["javascript", "typescript", "svelte"],
27 | "eslint.format.enable": true,
28 | "editor.formatOnSaveMode": "file",
29 | "svelte.plugin.svelte.compilerWarnings": {
30 | "a11y-aria-attributes": "ignore",
31 | "a11y-incorrect-aria-attribute-type": "ignore",
32 | "a11y-unknown-aria-attribute": "ignore",
33 | "a11y-hidden": "ignore",
34 | "a11y-misplaced-role": "ignore",
35 | "a11y-unknown-role": "ignore",
36 | "a11y-no-abstract-role": "ignore",
37 | "a11y-no-redundant-roles": "ignore",
38 | "a11y-role-has-required-aria-props": "ignore",
39 | "a11y-accesskey": "ignore",
40 | "a11y-autofocus": "ignore",
41 | "a11y-misplaced-scope": "ignore",
42 | "a11y-positive-tabindex": "ignore",
43 | "a11y-invalid-attribute": "ignore",
44 | "a11y-missing-attribute": "ignore",
45 | "a11y-img-redundant-alt": "ignore",
46 | "a11y-label-has-associated-control": "ignore",
47 | "a11y-media-has-caption": "ignore",
48 | "a11y-distracting-elements": "ignore",
49 | "a11y-structure": "ignore",
50 | "a11y-mouse-events-have-key-events": "ignore",
51 | "a11y-missing-content": "ignore",
52 | "a11y-click-events-have-key-events": "ignore"
53 | }
54 | }
--------------------------------------------------------------------------------
/LICENCE:
--------------------------------------------------------------------------------
1 | MIT License
2 |
3 | Copyright (c) 2022 Fouita
4 |
5 | Permission is hereby granted, free of charge, to any person obtaining a copy
6 | of this software and associated documentation files (the "Software"), to deal
7 | in the Software without restriction, including without limitation the rights
8 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9 | copies of the Software, and to permit persons to whom the Software is
10 | furnished to do so, subject to the following conditions:
11 |
12 | The above copyright notice and this permission notice shall be included in all
13 | copies or substantial portions of the Software.
14 |
15 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21 | SOFTWARE.
22 |
--------------------------------------------------------------------------------
/README.md:
--------------------------------------------------------------------------------
1 | ## Form Builder With Svelte & Tailwindcss
2 |
3 | NoCode Customizable Form Editor
4 |
5 | ### Demo
6 | [Demo Form Builder](https://fouita.com/explore/form-builder/forms/0x57341/edit)
7 |
8 |
9 | ### Screenshots
10 |
11 | 
12 |
13 | 
14 |
15 | 
16 |
17 |
18 | ## Features
19 |
20 | - Customize text and inputs (WYSIWYG)
21 | - Multi Steps Forms
22 | - Customize colors
23 | - RTL support
24 | - Add images and videos by inserting a link inside the text
25 | - Form Schema is exported so you can manipulate the data yourself
26 | - Form data is dispatched when user click on the Submit of the last step
27 |
28 |
29 |
30 | ### Install
31 |
32 | ```bash
33 | npm i @fouita/form-editor
34 | ```
35 |
36 | ### How to use
37 |
38 | Inside your svelte app
39 |
40 | ```html
41 |
87 |
88 |
89 | ```
90 |
91 |
92 | ### Generate CSS
93 | To be able to see the styled Editor, you can either use `form-editor.css` in your index.html or you can build the CSS using tailwind
94 |
95 | 1. Copy the file `tailwind.config.js`
96 | 2. Generate a seperate CSS for the Form Editor using the following command in your project
97 |
98 | ```bash
99 | npx tailwindcss -i ./src/global.css -o ./public/form-editor.css --minify
100 | ```
101 |
102 | ( change `global.css` to your css file that includes `@tailwind`)
103 |
104 | `gloabl.css`
105 | ```css
106 | @tailwind base;
107 | @tailwind components;
108 | @tailwind utilities;
109 | ```
110 |
111 | Include the file in your HTML index file
112 |
113 | ```html
114 |
115 | ```
116 |
117 |
118 |
119 | ## Use it as widget
120 |
121 | You can use the form-editor in your project as an external widget, with backend data collection at [Fouita](https://fouita.com/explore/form-builder) for Free
122 |
123 |
124 |
--------------------------------------------------------------------------------
/demo/formSimple.js:
--------------------------------------------------------------------------------
1 | export default {
2 | "name": "My Form",
3 | "steps": [
4 | {
5 | "index": 0,
6 | "props": {
7 | "previousBtn": "Back",
8 | "nextBtn": "Next"
9 | },
10 | "inputs": [
11 | {
12 | "label": "Text Content",
13 | "type": "TextContent",
14 | "props": {
15 | "fields": {
16 | "arr_content": [
17 | {
18 | "html": "",
19 | "klass": "md:text-xl text-lg leading-loose"
20 | }
21 | ],
22 | "validation": {
23 | "required": false
24 | }
25 | },
26 | "help_html": [],
27 | "arr_html": [],
28 | "inline": false
29 | },
30 | "key": "d3h4prkkwn"
31 | },
32 | {
33 | "label": "Text Input",
34 | "type": "Text",
35 | "value": "",
36 | "props": {
37 | "arr_html": [
38 | {
39 | "html": "Full Name",
40 | "klass": "md:text-xl text-lg leading-loose"
41 | }
42 | ],
43 | "help_html": [
44 | {
45 | "html": "First Name",
46 | "klass": "md:text-sm text-sm leading-loose"
47 | }
48 | ],
49 | "fields": {
50 | "placeholder": "",
51 | "validation": {
52 | "required": false
53 | }
54 | },
55 | "inline": true
56 | },
57 | "key": "v19lse84ab"
58 | },
59 | {
60 | "label": "Text Input",
61 | "type": "Text",
62 | "value": "",
63 | "props": {
64 | "arr_html": [
65 | {
66 | "html": "",
67 | "klass": "md:text-xl text-lg leading-loose"
68 | }
69 | ],
70 | "help_html": [
71 | {
72 | "html": "Last Name",
73 | "klass": "md:text-sm text-sm leading-loose"
74 | }
75 | ],
76 | "fields": {
77 | "placeholder": "",
78 | "validation": {
79 | "required": false
80 | }
81 | },
82 | "inline": false
83 | },
84 | "key": "ddnerzf9u2"
85 | }
86 | ]
87 | }
88 | ],
89 | "props": {
90 | "withMessage": false,
91 | "message": [
92 | {
93 | "html": "Thank you!! Your submission has been sent.",
94 | "klass": "text-center md:text-xl text-lg"
95 | }
96 | ]
97 | },
98 | "version": "18"
99 | }
--------------------------------------------------------------------------------
/index.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 |
6 |
7 | Fouita Form Editor
8 |
9 |
10 |
11 |
12 |
13 |
19 |
20 |
21 |
22 |
23 |
24 |
--------------------------------------------------------------------------------
/jsconfig.json:
--------------------------------------------------------------------------------
1 | {
2 | "compilerOptions": {
3 | "moduleResolution": "node",
4 | "target": "esnext",
5 | "module": "esnext",
6 | /**
7 | * svelte-preprocess cannot figure out whether you have
8 | * a value or a type, so tell TypeScript to enforce using
9 | * `import type` instead of `import` for Types.
10 | */
11 | "importsNotUsedAsValues": "error",
12 | "isolatedModules": true,
13 | "resolveJsonModule": true,
14 | /**
15 | * To have warnings / errors of the Svelte compiler at the
16 | * correct position, enable source maps by default.
17 | */
18 | "sourceMap": true,
19 | "esModuleInterop": true,
20 | "skipLibCheck": true,
21 | "forceConsistentCasingInFileNames": false,
22 | "baseUrl": ".",
23 | /**
24 | * Typecheck JS in `.svelte` and `.js` files by default.
25 | * Disable this if you'd like to use dynamic types.
26 | */
27 | "checkJs": false
28 | },
29 | /**
30 | * Use global.d.ts instead of compilerOptions.types
31 | * to avoid limiting type declarations.
32 | */
33 | "include": ["src/**/*.d.ts", "src/**/*.js", "src/**/*.svelte"]
34 | }
35 |
--------------------------------------------------------------------------------
/package.json:
--------------------------------------------------------------------------------
1 | {
2 | "name": "@fouita/form-editor",
3 | "version": "0.0.5",
4 | "type": "module",
5 | "private": false,
6 | "module": "./src/main.js",
7 | "scripts": {
8 | "build": "vite build",
9 | "dev": "vite",
10 | "start": "vite preview",
11 | "prepublishOnly": "npm run build"
12 | },
13 | "description": "Svelte component to build forms using nocode editor. Built with svelte and tailwindcss.",
14 | "repository": {
15 | "type": "git",
16 | "url": "git+https://github.com/fouita/form-editor.git"
17 | },
18 | "author": "fouita",
19 | "license": "MIT",
20 | "keywords": [
21 | "svelte",
22 | "tailwind",
23 | "wysiwyg",
24 | "editor",
25 | "form",
26 | "builder",
27 | "fouita"
28 | ],
29 | "bugs": {
30 | "url": "https://github.com/fouita/form-editor/issues"
31 | },
32 | "homepage": "https://github.com/fouita/form-editor#readme",
33 | "publishConfig": {
34 | "access": "public",
35 | "registry": "https://registry.npmjs.org/"
36 | },
37 | "devDependencies": {
38 | "@sveltejs/vite-plugin-svelte": "^2.0.2",
39 | "autoprefixer": "^10.4.7",
40 | "postcss": "^8.4.14",
41 | "svelte": "^3.55.0",
42 | "svelte-preprocess": "^4.10.7",
43 | "vite": "^4.0.3",
44 | "vite-plugin-css-injected-by-js": "^1.5.1",
45 | "tailwindcss": "^3.2.4"
46 | },
47 | "dependencies": {
48 | "@tailwindcss/forms": "^0.5.3",
49 | "tailwind-editor": "^0.2.1"
50 | }
51 | }
52 |
--------------------------------------------------------------------------------
/public/build/bundle.css:
--------------------------------------------------------------------------------
1 | *,::before,::after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}::before,::after{--tw-content:''}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";font-feature-settings:normal}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-0.25em}sup{top:-0.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,[type='button'],[type='reset'],[type='submit']{-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type='search']{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input:-ms-input-placeholder,textarea:-ms-input-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role="button"]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]{display:none}*,::before,::after{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x:;--tw-pan-y:;--tw-pinch-zoom:;--tw-scroll-snap-strictness:proximity;--tw-ordinal:;--tw-slashed-zero:;--tw-numeric-figure:;--tw-numeric-spacing:;--tw-numeric-fraction:;--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur:;--tw-brightness:;--tw-contrast:;--tw-grayscale:;--tw-hue-rotate:;--tw-invert:;--tw-saturate:;--tw-sepia:;--tw-drop-shadow:;--tw-backdrop-blur:;--tw-backdrop-brightness:;--tw-backdrop-contrast:;--tw-backdrop-grayscale:;--tw-backdrop-hue-rotate:;--tw-backdrop-invert:;--tw-backdrop-opacity:;--tw-backdrop-saturate:;--tw-backdrop-sepia:}::-webkit-backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x:;--tw-pan-y:;--tw-pinch-zoom:;--tw-scroll-snap-strictness:proximity;--tw-ordinal:;--tw-slashed-zero:;--tw-numeric-figure:;--tw-numeric-spacing:;--tw-numeric-fraction:;--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur:;--tw-brightness:;--tw-contrast:;--tw-grayscale:;--tw-hue-rotate:;--tw-invert:;--tw-saturate:;--tw-sepia:;--tw-drop-shadow:;--tw-backdrop-blur:;--tw-backdrop-brightness:;--tw-backdrop-contrast:;--tw-backdrop-grayscale:;--tw-backdrop-hue-rotate:;--tw-backdrop-invert:;--tw-backdrop-opacity:;--tw-backdrop-saturate:;--tw-backdrop-sepia:}::backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x:;--tw-pan-y:;--tw-pinch-zoom:;--tw-scroll-snap-strictness:proximity;--tw-ordinal:;--tw-slashed-zero:;--tw-numeric-figure:;--tw-numeric-spacing:;--tw-numeric-fraction:;--tw-ring-inset:;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgb(59 130 246 / 0.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur:;--tw-brightness:;--tw-contrast:;--tw-grayscale:;--tw-hue-rotate:;--tw-invert:;--tw-saturate:;--tw-sepia:;--tw-drop-shadow:;--tw-backdrop-blur:;--tw-backdrop-brightness:;--tw-backdrop-contrast:;--tw-backdrop-grayscale:;--tw-backdrop-hue-rotate:;--tw-backdrop-invert:;--tw-backdrop-opacity:;--tw-backdrop-saturate:;--tw-backdrop-sepia:}.container{width:100%}@media(min-width: 640px){.container{max-width:640px}}@media(min-width: 768px){.container{max-width:768px}}@media(min-width: 1024px){.container{max-width:1024px}}@media(min-width: 1280px){.container{max-width:1280px}}@media(min-width: 1536px){.container{max-width:1536px}}.form-checkbox,.form-radio{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}.form-checkbox{border-radius:0px}.form-radio{border-radius:100%}.form-checkbox:focus,.form-radio:focus{outline:2px solid transparent;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow)}.form-checkbox:checked,.form-radio:checked{border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}.form-checkbox:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3cpath d='M12.207 4.793a1 1 0 010 1.414l-5 5a1 1 0 01-1.414 0l-2-2a1 1 0 011.414-1.414L6.5 9.086l4.293-4.293a1 1 0 011.414 0z'/%3e%3c/svg%3e")}.form-radio:checked{background-image:url("data:image/svg+xml,%3csvg viewBox='0 0 16 16' fill='white' xmlns='http://www.w3.org/2000/svg'%3e%3ccircle cx='8' cy='8' r='3'/%3e%3c/svg%3e")}.form-checkbox:checked:hover,.form-checkbox:checked:focus,.form-radio:checked:hover,.form-radio:checked:focus{border-color:transparent;background-color:currentColor}.form-checkbox:indeterminate{background-image:url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3e%3cpath stroke='white' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3e%3c/svg%3e");border-color:transparent;background-color:currentColor;background-size:100% 100%;background-position:center;background-repeat:no-repeat}.form-checkbox:indeterminate:hover,.form-checkbox:indeterminate:focus{border-color:transparent;background-color:currentColor}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0, 0, 0, 0);white-space:nowrap;border-width:0}.visible{visibility:visible}.invisible{visibility:hidden}.collapse{visibility:collapse}.static{position:static}.fixed{position:fixed}.\!fixed{position:fixed !important}.absolute{position:absolute}.relative{position:relative}.sticky{position:-webkit-sticky;position:sticky}.right-0{right:0px}.top-7{top:1.75rem}.top-0{top:0px}.left-0{left:0px}.-left-5{left:-1.25rem}.top-10{top:2.5rem}.-left-3{left:-0.75rem}.-bottom-11{bottom:-2.75rem}.left-0\.5{left:0.125rem}.bottom-10{bottom:2.5rem}.-left-6{left:-1.5rem}.bottom-5{bottom:1.25rem}.bottom-0{bottom:0px}.z-50{z-index:50}.z-20{z-index:20}.z-40{z-index:40}.m-5{margin:1.25rem}.m-1{margin:0.25rem}.mx-auto{margin-left:auto;margin-right:auto}.my-9{margin-top:2.25rem;margin-bottom:2.25rem}.mx-2{margin-left:0.5rem;margin-right:0.5rem}.my-2{margin-top:0.5rem;margin-bottom:0.5rem}.my-3{margin-top:0.75rem;margin-bottom:0.75rem}.my-1{margin-top:0.25rem;margin-bottom:0.25rem}.my-4{margin-top:1rem;margin-bottom:1rem}.ml-16{margin-left:4rem}.mt-1{margin-top:0.25rem}.mb-4{margin-bottom:1rem}.mt-10{margin-top:2.5rem}.mt-4{margin-top:1rem}.ml-2{margin-left:0.5rem}.mr-4{margin-right:1rem}.mt-px{margin-top:1px}.mr-px{margin-right:1px}.mr-0\.5{margin-right:0.125rem}.mr-0{margin-right:0px}.mt-2{margin-top:0.5rem}.mt-0\.5{margin-top:0.125rem}.mt-0{margin-top:0px}.mb-2{margin-bottom:0.5rem}.mb-8{margin-bottom:2rem}.mt-8{margin-top:2rem}.mr-2{margin-right:0.5rem}.-ml-24{margin-left:-6rem}.ml-1{margin-left:0.25rem}.ml-5{margin-left:1.25rem}.-ml-1{margin-left:-0.25rem}.-mt-6{margin-top:-1.5rem}.block{display:block}.\!block{display:block !important}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.table{display:table}.grid{display:grid}.contents{display:contents}.\!contents{display:contents !important}.hidden{display:none}.h-3\/4{height:75%}.h-screen{height:100vh}.h-4{height:1rem}.h-\[0\]{height:0}.h-1{height:0.25rem}.h-5{height:1.25rem}.h-full{height:100%}.h-3{height:0.75rem}.h-8{height:2rem}.h-auto{height:auto}.max-h-fit{max-height:-webkit-fit-content;max-height:-moz-fit-content;max-height:fit-content}.min-h-fit{min-height:-webkit-fit-content;min-height:-moz-fit-content;min-height:fit-content}.w-screen{width:100vw}.w-full{width:100%}.w-4{width:1rem}.w-1\/2{width:50%}.w-\[0\]{width:0}.w-32{width:8rem}.w-8{width:2rem}.w-20{width:5rem}.w-2\/5{width:40%}.w-5{width:1.25rem}.w-64{width:16rem}.w-3{width:0.75rem}.w-24{width:6rem}.w-auto{width:auto}.w-\[\\w\\\.\]{width:\w\.}.w-10{width:2.5rem}.max-w-screen-xl{max-width:1280px}.max-w-screen-lg{max-width:1024px}.max-w-2xl{max-width:42rem}.max-w-\[350px\]{max-width:350px}.max-w-fit{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content}.flex-auto{flex:1 1 auto}.flex-shrink-0{flex-shrink:0}.flex-shrink{flex-shrink:1}.shrink-0{flex-shrink:0}.flex-grow{flex-grow:1}.grow{flex-grow:1}.border-collapse{border-collapse:collapse}.transform{transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.resize{resize:both}.grid-cols-3{grid-template-columns:repeat(3, minmax(0, 1fr))}.grid-cols-2{grid-template-columns:repeat(2, minmax(0, 1fr))}.flex-row{flex-direction:row}.flex-row-reverse{flex-direction:row-reverse}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:0.25rem}.space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.5rem * var(--tw-space-x-reverse));margin-left:calc(0.5rem * calc(1 - var(--tw-space-x-reverse)))}.space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(0.5rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(0.5rem * var(--tw-space-y-reverse))}.space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.75rem * var(--tw-space-x-reverse));margin-left:calc(0.75rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.25rem * var(--tw-space-x-reverse));margin-left:calc(0.25rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-0\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0.125rem * var(--tw-space-x-reverse));margin-left:calc(0.125rem * calc(1 - var(--tw-space-x-reverse)))}.space-x-0>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(0px * var(--tw-space-x-reverse));margin-left:calc(0px * calc(1 - var(--tw-space-x-reverse)))}.overflow-auto{overflow:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.rounded{border-radius:0.25rem}.rounded-lg{border-radius:0.5rem}.rounded-full{border-radius:9999px}.rounded-sm{border-radius:0.125rem}.rounded-l{border-top-left-radius:0.25rem;border-bottom-left-radius:0.25rem}.border{border-width:1px}.border-0{border-width:0px}.border-2{border-width:2px}.border-t-\[22px\]{border-top-width:22px}.border-l-\[25px\]{border-left-width:25px}.border-t-2{border-top-width:2px}.border-l-4{border-left-width:4px}.border-t{border-top-width:1px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-l{border-left-width:1px}.border-dashed{border-style:dashed}.border-tertiary{--tw-border-opacity:1;border-color:rgb(var(--ft-tertiary,31 41 55) / var(--tw-border-opacity))}.border-tertiary\/30{border-color:rgb(var(--ft-tertiary,31 41 55) / 0.3)}.border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55 / var(--tw-border-opacity))}.border-gray-400{--tw-border-opacity:1;border-color:rgb(156 163 175 / var(--tw-border-opacity))}.border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235 / var(--tw-border-opacity))}.border-l-transparent{border-left-color:transparent}.bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255 / var(--tw-bg-opacity))}.bg-secondary{--tw-bg-opacity:1;background-color:rgb(var(--ft-secondary,251 113 133) / var(--tw-bg-opacity))}.bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0 / var(--tw-bg-opacity))}.bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.bg-transparent{background-color:transparent}.bg-primary\/90{background-color:rgb(var(--ft-primary,59 130 246) / 0.9)}.bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219 / var(--tw-bg-opacity))}.bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99 / var(--tw-bg-opacity))}.bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246 / var(--tw-bg-opacity))}.bg-yellow-200{--tw-bg-opacity:1;background-color:rgb(254 240 138 / var(--tw-bg-opacity))}.bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38 / var(--tw-bg-opacity))}.bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235 / var(--tw-bg-opacity))}.bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254 / var(--tw-bg-opacity))}.bg-opacity-50{--tw-bg-opacity:0.5}.bg-opacity-75{--tw-bg-opacity:0.75}.fill-current{fill:currentColor}.p-3{padding:0.75rem}.p-5{padding:1.25rem}.p-10{padding:2.5rem}.p-2{padding:0.5rem}.p-4{padding:1rem}.p-2\.5{padding:0.625rem}.p-1{padding:0.25rem}.px-4{padding-left:1rem;padding-right:1rem}.py-2{padding-top:0.5rem;padding-bottom:0.5rem}.px-3{padding-left:0.75rem;padding-right:0.75rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-10{padding-left:2.5rem;padding-right:2.5rem}.py-2\.5{padding-top:0.625rem;padding-bottom:0.625rem}.px-1{padding-left:0.25rem;padding-right:0.25rem}.px-2{padding-left:0.5rem;padding-right:0.5rem}.px-8{padding-left:2rem;padding-right:2rem}.py-6{padding-top:1.5rem;padding-bottom:1.5rem}.py-1{padding-top:0.25rem;padding-bottom:0.25rem}.pt-4{padding-top:1rem}.pb-10{padding-bottom:2.5rem}.pl-16{padding-left:4rem}.pb-5{padding-bottom:1.25rem}.pt-2{padding-top:0.5rem}.pl-5{padding-left:1.25rem}.pr-2{padding-right:0.5rem}.pl-2{padding-left:0.5rem}.pr-3{padding-right:0.75rem}.pl-1{padding-left:0.25rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-justify{text-align:justify}.font-mono{font-family:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:0.875rem;line-height:1.25rem}.text-2xl{font-size:1.5rem;line-height:2rem}.text-xs{font-size:0.75rem;line-height:1rem}.text-6xl{font-size:3.75rem;line-height:1}.text-5xl{font-size:3rem;line-height:1}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.font-semibold{font-weight:600}.font-medium{font-weight:500}.font-bold{font-weight:700}.font-normal{font-weight:400}.capitalize{text-transform:capitalize}.italic{font-style:italic}.leading-loose{line-height:2}.text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202 / var(--tw-text-opacity))}.text-primary{--tw-text-opacity:1;color:rgb(var(--ft-primary,59 130 246) / var(--tw-text-opacity))}.text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254 / var(--tw-text-opacity))}.text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55 / var(--tw-text-opacity))}.text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81 / var(--tw-text-opacity))}.text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216 / var(--tw-text-opacity))}.text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219 / var(--tw-text-opacity))}.text-secondary{--tw-text-opacity:1;color:rgb(var(--ft-secondary,251 113 133) / var(--tw-text-opacity))}.text-white{--tw-text-opacity:1;color:rgb(255 255 255 / var(--tw-text-opacity))}.text-red-500{--tw-text-opacity:1;color:rgb(239 68 68 / var(--tw-text-opacity))}.text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128 / var(--tw-text-opacity))}.text-yellow-800{--tw-text-opacity:1;color:rgb(133 77 14 / var(--tw-text-opacity))}.text-red-700{--tw-text-opacity:1;color:rgb(185 28 28 / var(--tw-text-opacity))}.text-black{--tw-text-opacity:1;color:rgb(0 0 0 / var(--tw-text-opacity))}.text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235 / var(--tw-text-opacity))}.text-red-100{--tw-text-opacity:1;color:rgb(254 226 226 / var(--tw-text-opacity))}.underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.opacity-50{opacity:0.5}.shadow{--tw-shadow:0 1px 3px 0 rgb(0 0 0 / 0.1), 0 1px 2px -1px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-xl{--tw-shadow:0 20px 25px -5px rgb(0 0 0 / 0.1), 0 8px 10px -6px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color), 0 8px 10px -6px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-inner{--tw-shadow:inset 0 2px 4px 0 rgb(0 0 0 / 0.05);--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.shadow-lg{--tw-shadow:0 10px 15px -3px rgb(0 0 0 / 0.1), 0 4px 6px -4px rgb(0 0 0 / 0.1);--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000), var(--tw-ring-shadow, 0 0 #0000), var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.outline-gray-50{outline-color:#f9fafb}.ring{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(3px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)}.blur{--tw-blur:blur(8px);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.grayscale{--tw-grayscale:grayscale(100%);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.\!filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow) !important}.transition{transition-property:color, background-color, border-color, fill, stroke, opacity, box-shadow, transform, filter, -webkit-text-decoration-color, -webkit-backdrop-filter;transition-property:color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter;transition-property:color, background-color, border-color, text-decoration-color, fill, stroke, opacity, box-shadow, transform, filter, backdrop-filter, -webkit-text-decoration-color, -webkit-backdrop-filter;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.placeholder\:text-gray-400::-moz-placeholder{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.placeholder\:text-gray-400:-ms-input-placeholder{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.placeholder\:text-gray-400::placeholder{--tw-text-opacity:1;color:rgb(156 163 175 / var(--tw-text-opacity))}.after\:absolute::after{content:var(--tw-content);position:absolute}.after\:top-0\.5::after{content:var(--tw-content);top:0.125rem}.after\:left-\[5px\]::after{content:var(--tw-content);left:5px}.after\:top-0::after{content:var(--tw-content);top:0px}.after\:h-3::after{content:var(--tw-content);height:0.75rem}.after\:w-3::after{content:var(--tw-content);width:0.75rem}.after\:rounded-full::after{content:var(--tw-content);border-radius:9999px}.after\:border::after{content:var(--tw-content);border-width:1px}.after\:border-gray-300::after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(209 213 219 / var(--tw-border-opacity))}.after\:bg-white::after{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(255 255 255 / var(--tw-bg-opacity))}.after\:transition-all::after{content:var(--tw-content);transition-property:all;transition-timing-function:cubic-bezier(0.4, 0, 0.2, 1);transition-duration:150ms}.after\:content-\[\'\'\]::after{--tw-content:'';content:var(--tw-content)}.hover\:border-indigo-700:hover{--tw-border-opacity:1;border-color:rgb(67 56 202 / var(--tw-border-opacity))}.hover\:bg-indigo-100:hover{--tw-bg-opacity:1;background-color:rgb(224 231 255 / var(--tw-bg-opacity))}.hover\:bg-primary:hover{--tw-bg-opacity:1;background-color:rgb(var(--ft-primary,59 130 246) / var(--tw-bg-opacity))}.hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251 / var(--tw-bg-opacity))}.hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219 / var(--tw-bg-opacity))}.hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235 / var(--tw-bg-opacity))}.hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28 / var(--tw-bg-opacity))}.hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216 / var(--tw-bg-opacity))}.hover\:text-indigo-700:hover{--tw-text-opacity:1;color:rgb(67 56 202 / var(--tw-text-opacity))}.hover\:text-gray-700:hover{--tw-text-opacity:1;color:rgb(55 65 81 / var(--tw-text-opacity))}.hover\:text-gray-600:hover{--tw-text-opacity:1;color:rgb(75 85 99 / var(--tw-text-opacity))}.focus\:border-transparent:focus{border-color:transparent}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:outline-indigo-300:focus{outline-color:#a5b4fc}.focus\:outline-quaternary:focus{outline-color:rgb(var(--ft-quaternary,250 204 21) / 1)}.focus\:ring-1:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)}.focus\:drop-shadow-sm:focus{--tw-drop-shadow:drop-shadow(0 1px 1px rgb(0 0 0 / 0.05));filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.active\:bg-indigo-50:active{--tw-bg-opacity:1;background-color:rgb(238 242 255 / var(--tw-bg-opacity))}.peer:checked~.peer-checked\:bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229 / var(--tw-bg-opacity))}.peer:checked~.peer-checked\:after\:translate-x-full::after{content:var(--tw-content);--tw-translate-x:100%;transform:translate(var(--tw-translate-x), var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:checked~.peer-checked\:after\:border-white::after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(255 255 255 / var(--tw-border-opacity))}.peer:focus~.peer-focus\:ring-1{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow, 0 0 #0000)}.peer:focus~.peer-focus\:ring-indigo-300{--tw-ring-opacity:1;--tw-ring-color:rgb(165 180 252 / var(--tw-ring-opacity))}@media(prefers-color-scheme: dark){.dark\:border-gray-600{--tw-border-opacity:1;border-color:rgb(75 85 99 / var(--tw-border-opacity))}.dark\:bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81 / var(--tw-bg-opacity))}.dark\:text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219 / var(--tw-text-opacity))}.peer:focus~.dark\:peer-focus\:ring-indigo-800{--tw-ring-opacity:1;--tw-ring-color:rgb(55 48 163 / var(--tw-ring-opacity))}}@media(min-width: 640px){.sm\:px-4{padding-left:1rem;padding-right:1rem}}@media(min-width: 768px){.md\:p-6{padding:1.5rem}.md\:text-xl{font-size:1.25rem;line-height:1.75rem}.md\:text-sm{font-size:0.875rem;line-height:1.25rem}.md\:text-base{font-size:1rem;line-height:1.5rem}.md\:text-6xl{font-size:3.75rem;line-height:1}.md\:text-5xl{font-size:3rem;line-height:1}.md\:text-4xl{font-size:2.25rem;line-height:2.5rem}.md\:text-3xl{font-size:1.875rem;line-height:2.25rem}.md\:text-2xl{font-size:1.5rem;line-height:2rem}}
--------------------------------------------------------------------------------
/public/favicon.png:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/fouita/form-editor/b2982cf83534a5ab7004e0007c5962439ab1d36a/public/favicon.png
--------------------------------------------------------------------------------
/public/form-editor.css:
--------------------------------------------------------------------------------
1 | /*! tailwindcss v3.1.0 | MIT License | https://tailwindcss.com*/*,:after,:before{box-sizing:border-box;border:0 solid #e5e7eb}:after,:before{--tw-content:""}html{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen-Sans,Ubuntu,Cantarell,Helvetica Neue,Helvetica,Arial,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,sans-serif}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:initial}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;font-weight:inherit;line-height:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button;background-color:initial;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:initial}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input:-ms-input-placeholder,textarea:-ms-input-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}::-webkit-backdrop{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }*,::backdrop,:after,:before{--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness:proximity;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:#3b82f680;--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: }.form-checkbox,.form-radio{-webkit-appearance:none;-moz-appearance:none;appearance:none;padding:0;-webkit-print-color-adjust:exact;color-adjust:exact;print-color-adjust:exact;display:inline-block;vertical-align:middle;background-origin:border-box;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;flex-shrink:0;height:1rem;width:1rem;color:#2563eb;background-color:#fff;border-color:#6b7280;border-width:1px;--tw-shadow:0 0 #0000}.form-checkbox{border-radius:0}.form-radio{border-radius:100%}.form-checkbox:focus,.form-radio:focus{outline:2px solid #0000;outline-offset:2px;--tw-ring-inset:var(--tw-empty,/*!*/ /*!*/);--tw-ring-offset-width:2px;--tw-ring-offset-color:#fff;--tw-ring-color:#2563eb;--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow)}.form-checkbox:checked,.form-radio:checked{border-color:#0000;background-color:currentColor;background-size:100% 100%;background-position:50%;background-repeat:no-repeat}.form-checkbox:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.207 4.793a1 1 0 0 1 0 1.414l-5 5a1 1 0 0 1-1.414 0l-2-2a1 1 0 0 1 1.414-1.414L6.5 9.086l4.293-4.293a1 1 0 0 1 1.414 0z'/%3E%3C/svg%3E")}.form-radio:checked{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg viewBox='0 0 16 16' fill='%23fff' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='8' cy='8' r='3'/%3E%3C/svg%3E")}.form-checkbox:checked:focus,.form-checkbox:checked:hover,.form-checkbox:indeterminate,.form-radio:checked:focus,.form-radio:checked:hover{border-color:#0000;background-color:currentColor}.form-checkbox:indeterminate{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 16 16'%3E%3Cpath stroke='%23fff' stroke-linecap='round' stroke-linejoin='round' stroke-width='2' d='M4 8h8'/%3E%3C/svg%3E");background-size:100% 100%;background-position:50%;background-repeat:no-repeat}.form-checkbox:indeterminate:focus,.form-checkbox:indeterminate:hover{border-color:#0000;background-color:currentColor}.ft .sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.ft .visible{visibility:visible}.ft .fixed{position:fixed}.ft .absolute{position:absolute}.ft .relative{position:relative}.ft .right-0{right:0}.ft .top-7{top:28px}.ft .top-0{top:0}.ft .left-0{left:0}.ft .bottom-0{bottom:0}.ft .-left-20{left:-80px}.ft .top-6{top:24px}.ft .top-10{top:40px}.ft .-left-3{left:-12px}.ft .left-0\.5{left:2px}.ft .bottom-10{bottom:40px}.ft .-left-6{left:-24px}.ft .bottom-5{bottom:20px}.ft .top-1{top:4px}.ft .top-2{top:8px}.ft .top-3{top:12px}.ft .top-4{top:16px}.ft .top-5{top:20px}.ft .top-16{top:64px}.ft .top-20{top:80px}.ft .top-40{top:160px}.ft .top-60{top:240px}.ft .top-px{top:1px}.ft .top-0\.5{top:2px}.ft .-top-0{top:0}.ft .-top-1{top:-4px}.ft .-top-2{top:-8px}.ft .-top-3{top:-12px}.ft .-top-4{top:-16px}.ft .-top-5{top:-20px}.ft .-top-10{top:-40px}.ft .-top-16{top:-64px}.ft .-top-20{top:-80px}.ft .-top-40{top:-160px}.ft .-top-60{top:-240px}.ft .-top-px{top:-1px}.ft .-top-0\.5{top:-2px}.ft .bottom-1{bottom:4px}.ft .bottom-2{bottom:8px}.ft .bottom-3{bottom:12px}.ft .bottom-4{bottom:16px}.ft .bottom-16{bottom:64px}.ft .bottom-20{bottom:80px}.ft .bottom-40{bottom:160px}.ft .bottom-60{bottom:240px}.ft .bottom-px{bottom:1px}.ft .bottom-0\.5{bottom:2px}.ft .-bottom-0{bottom:0}.ft .-bottom-1{bottom:-4px}.ft .-bottom-2{bottom:-8px}.ft .-bottom-3{bottom:-12px}.ft .-bottom-4{bottom:-16px}.ft .-bottom-5{bottom:-20px}.ft .-bottom-10{bottom:-40px}.ft .-bottom-16{bottom:-64px}.ft .-bottom-20{bottom:-80px}.ft .-bottom-40{bottom:-160px}.ft .-bottom-60{bottom:-240px}.ft .-bottom-px{bottom:-1px}.ft .-bottom-0\.5{bottom:-2px}.ft .z-50{z-index:50}.ft .z-20{z-index:20}.ft .z-40{z-index:40}.ft .row-auto{grid-row:auto}.ft .m-5{margin:20px}.ft .m-1{margin:4px}.ft .m-0{margin:0}.ft .m-2{margin:8px}.ft .m-3{margin:12px}.ft .m-4{margin:16px}.ft .m-10{margin:40px}.ft .m-16{margin:64px}.ft .m-20{margin:80px}.ft .m-40{margin:160px}.ft .m-60{margin:240px}.ft .m-px{margin:1px}.ft .m-0\.5{margin:2px}.ft .-m-0{margin:0}.ft .-m-1{margin:-4px}.ft .-m-2{margin:-8px}.ft .-m-3{margin:-12px}.ft .-m-4{margin:-16px}.ft .-m-5{margin:-20px}.ft .-m-10{margin:-40px}.ft .-m-16{margin:-64px}.ft .-m-20{margin:-80px}.ft .-m-40{margin:-160px}.ft .-m-60{margin:-240px}.ft .-m-px{margin:-1px}.ft .-m-0\.5{margin:-2px}.ft .mx-auto{margin-left:auto;margin-right:auto}.ft .mx-2{margin-left:8px;margin-right:8px}.ft .my-2{margin-top:8px;margin-bottom:8px}.ft .my-3{margin-top:12px;margin-bottom:12px}.ft .my-4{margin-top:16px}.ft .mb-4,.ft .my-4{margin-bottom:16px}.ft .mt-10{margin-top:40px}.ft .mt-4{margin-top:16px}.ft .ml-2{margin-left:8px}.ft .mb-8{margin-bottom:32px}.ft .mt-8{margin-top:32px}.ft .-ml-1{margin-left:-4px}.ft .-ml-24{margin-left:-96px}.ft .mt-1{margin-top:4px}.ft .mr-2{margin-right:8px}.ft .ml-1{margin-left:4px}.ft .ml-5{margin-left:20px}.ft .-mt-6{margin-top:-24px}.ft .mb-2{margin-bottom:8px}.ft .mt-2{margin-top:8px}.ft .mr-4{margin-right:16px}.ft .ml-16{margin-left:64px}.ft .mt-0{margin-top:0}.ft .mt-3{margin-top:12px}.ft .mt-5{margin-top:20px}.ft .mt-16{margin-top:64px}.ft .mt-20{margin-top:80px}.ft .mt-40{margin-top:160px}.ft .mt-60{margin-top:240px}.ft .mt-px{margin-top:1px}.ft .mt-0\.5{margin-top:2px}.ft .-mt-0{margin-top:0}.ft .-mt-1{margin-top:-4px}.ft .-mt-2{margin-top:-8px}.ft .-mt-3{margin-top:-12px}.ft .-mt-4{margin-top:-16px}.ft .-mt-5{margin-top:-20px}.ft .-mt-10{margin-top:-40px}.ft .-mt-16{margin-top:-64px}.ft .-mt-20{margin-top:-80px}.ft .-mt-40{margin-top:-160px}.ft .-mt-60{margin-top:-240px}.ft .-mt-px{margin-top:-1px}.ft .-mt-0\.5{margin-top:-2px}.ft .mr-0{margin-right:0}.ft .mr-1{margin-right:4px}.ft .mr-3{margin-right:12px}.ft .mr-5{margin-right:20px}.ft .mr-10{margin-right:40px}.ft .mr-16{margin-right:64px}.ft .mr-20{margin-right:80px}.ft .mr-40{margin-right:160px}.ft .mr-60{margin-right:240px}.ft .mr-px{margin-right:1px}.ft .mr-0\.5{margin-right:2px}.ft .-mr-0{margin-right:0}.ft .-mr-1{margin-right:-4px}.ft .-mr-2{margin-right:-8px}.ft .-mr-3{margin-right:-12px}.ft .-mr-4{margin-right:-16px}.ft .-mr-5{margin-right:-20px}.ft .-mr-10{margin-right:-40px}.ft .-mr-16{margin-right:-64px}.ft .-mr-20{margin-right:-80px}.ft .-mr-40{margin-right:-160px}.ft .-mr-60{margin-right:-240px}.ft .-mr-px{margin-right:-1px}.ft .-mr-0\.5{margin-right:-2px}.ft .mb-0{margin-bottom:0}.ft .mb-1{margin-bottom:4px}.ft .mb-3{margin-bottom:12px}.ft .mb-5{margin-bottom:20px}.ft .mb-10{margin-bottom:40px}.ft .mb-16{margin-bottom:64px}.ft .mb-20{margin-bottom:80px}.ft .mb-40{margin-bottom:160px}.ft .mb-60{margin-bottom:240px}.ft .mb-px{margin-bottom:1px}.ft .mb-0\.5{margin-bottom:2px}.ft .-mb-0{margin-bottom:0}.ft .-mb-1{margin-bottom:-4px}.ft .-mb-2{margin-bottom:-8px}.ft .-mb-3{margin-bottom:-12px}.ft .-mb-4{margin-bottom:-16px}.ft .-mb-5{margin-bottom:-20px}.ft .-mb-10{margin-bottom:-40px}.ft .-mb-16{margin-bottom:-64px}.ft .-mb-20{margin-bottom:-80px}.ft .-mb-40{margin-bottom:-160px}.ft .-mb-60{margin-bottom:-240px}.ft .-mb-px{margin-bottom:-1px}.ft .-mb-0\.5{margin-bottom:-2px}.ft .ml-0{margin-left:0}.ft .ml-3{margin-left:12px}.ft .ml-4{margin-left:16px}.ft .ml-10{margin-left:40px}.ft .ml-20{margin-left:80px}.ft .ml-40{margin-left:160px}.ft .ml-60{margin-left:240px}.ft .ml-px{margin-left:1px}.ft .ml-0\.5{margin-left:2px}.ft .-ml-0{margin-left:0}.ft .-ml-2{margin-left:-8px}.ft .-ml-3{margin-left:-12px}.ft .-ml-4{margin-left:-16px}.ft .-ml-5{margin-left:-20px}.ft .-ml-10{margin-left:-40px}.ft .-ml-16{margin-left:-64px}.ft .-ml-20{margin-left:-80px}.ft .-ml-40{margin-left:-160px}.ft .-ml-60{margin-left:-240px}.ft .-ml-px{margin-left:-1px}.ft .-ml-0\.5{margin-left:-2px}.ft .block{display:block}.ft .inline{display:inline}.ft .\!inline{display:inline!important}.ft .flex{display:flex}.ft .inline-flex{display:inline-flex}.ft .grid{display:grid}.ft .hidden{display:none}.ft .h-3\/4{height:75%}.ft .h-screen{height:100vh}.ft .h-5{height:20px}.ft .h-4{height:16px}.ft .h-8{height:32px}.ft .h-3{height:12px}.ft .h-full{height:100%}.ft .h-auto{height:auto}.ft .h-6{height:24px}.ft .h-1{height:4px}.ft .h-0{height:0}.ft .h-10{height:40px}.ft .h-16{height:64px}.ft .h-20{height:80px}.ft .h-32{height:128px}.ft .h-40{height:160px}.ft .h-60{height:240px}.ft .h-80{height:320px}.ft .h-96{height:384px}.ft .h-128{height:512px}.ft .max-h-fit{max-height:-webkit-fit-content;max-height:-moz-fit-content;max-height:fit-content}.ft .max-h-0{max-height:0}.ft .max-h-3{max-height:12px}.ft .max-h-4{max-height:16px}.ft .max-h-10{max-height:40px}.ft .max-h-16{max-height:64px}.ft .max-h-20{max-height:80px}.ft .max-h-32{max-height:128px}.ft .max-h-40{max-height:160px}.ft .max-h-60{max-height:240px}.ft .max-h-80{max-height:320px}.ft .max-h-96{max-height:384px}.ft .max-h-128{max-height:512px}.ft .max-h-full{max-height:100%}.ft .min-h-fit{min-height:-webkit-fit-content;min-height:-moz-fit-content;min-height:fit-content}.ft .min-h-0{min-height:0}.ft .min-h-full{min-height:100%}.ft .w-screen{width:100vw}.ft .w-full{width:100%}.ft .w-32{width:128px}.ft .w-5{width:20px}.ft .w-4{width:16px}.ft .w-8{width:32px}.ft .w-3{width:12px}.ft .w-64{width:256px}.ft .w-auto{width:auto}.ft .w-\[\\w\\\.\]{width:\w\.}.ft .w-10{width:40px}.ft .w-24{width:96px}.ft .w-6{width:24px}.ft .w-1\/2{width:50%}.ft .w-20{width:80px}.ft .w-2\/5{width:40%}.ft .w-0{width:0}.ft .w-16{width:64px}.ft .w-40{width:160px}.ft .w-60{width:240px}.ft .w-80{width:320px}.ft .w-96{width:384px}.ft .w-128{width:512px}.ft .w-1\/3{width:33.333333%}.ft .w-1\/4{width:25%}.ft .w-1\/5{width:20%}.ft .w-1\/6{width:16.666667%}.ft .w-1\/12{width:8.333333%}.ft .min-w-0{min-width:0}.ft .min-w-full{min-width:100%}.ft .max-w-2xl{max-width:42rem}.ft .max-w-\[350px\]{max-width:350px}.ft .max-w-fit{max-width:-webkit-fit-content;max-width:-moz-fit-content;max-width:fit-content}.ft .max-w-0{max-width:0}.ft .max-w-none{max-width:none}.ft .max-w-xs{max-width:20rem}.ft .max-w-sm{max-width:24rem}.ft .max-w-md{max-width:28rem}.ft .max-w-lg{max-width:32rem}.ft .max-w-xl{max-width:36rem}.ft .max-w-3xl{max-width:48rem}.ft .max-w-4xl{max-width:56rem}.ft .max-w-5xl{max-width:64rem}.ft .max-w-6xl{max-width:72rem}.ft .max-w-7xl{max-width:80rem}.ft .max-w-full{max-width:100%}.ft .max-w-min{max-width:-webkit-min-content;max-width:-moz-min-content;max-width:min-content}.ft .max-w-max{max-width:-webkit-max-content;max-width:-moz-max-content;max-width:max-content}.ft .max-w-prose{max-width:65ch}.ft .flex-auto{flex:1 1 auto}.ft .flex-shrink-0,.ft .shrink-0{flex-shrink:0}.ft .flex-grow-0,.ft .grow-0{flex-grow:0}.ft .cursor-pointer{cursor:pointer}.ft .touch-auto{touch-action:auto}.ft .select-none{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.ft .scroll-m-0{scroll-margin:0}.ft .scroll-m-1{scroll-margin:4px}.ft .scroll-m-2{scroll-margin:8px}.ft .scroll-m-3{scroll-margin:12px}.ft .scroll-m-4{scroll-margin:16px}.ft .scroll-m-5{scroll-margin:20px}.ft .scroll-m-10{scroll-margin:40px}.ft .scroll-m-16{scroll-margin:64px}.ft .scroll-m-20{scroll-margin:80px}.ft .scroll-m-40{scroll-margin:160px}.ft .scroll-m-60{scroll-margin:240px}.ft .scroll-m-px{scroll-margin:1px}.ft .scroll-m-0\.5{scroll-margin:2px}.ft .-scroll-m-0{scroll-margin:0}.ft .-scroll-m-1{scroll-margin:-4px}.ft .-scroll-m-2{scroll-margin:-8px}.ft .-scroll-m-3{scroll-margin:-12px}.ft .-scroll-m-4{scroll-margin:-16px}.ft .-scroll-m-5{scroll-margin:-20px}.ft .-scroll-m-10{scroll-margin:-40px}.ft .-scroll-m-16{scroll-margin:-64px}.ft .-scroll-m-20{scroll-margin:-80px}.ft .-scroll-m-40{scroll-margin:-160px}.ft .-scroll-m-60{scroll-margin:-240px}.ft .-scroll-m-px{scroll-margin:-1px}.ft .-scroll-m-0\.5{scroll-margin:-2px}.ft .scroll-mt-0{scroll-margin-top:0}.ft .scroll-mt-1{scroll-margin-top:4px}.ft .scroll-mt-2{scroll-margin-top:8px}.ft .scroll-mt-3{scroll-margin-top:12px}.ft .scroll-mt-4{scroll-margin-top:16px}.ft .scroll-mt-5{scroll-margin-top:20px}.ft .scroll-mt-10{scroll-margin-top:40px}.ft .scroll-mt-16{scroll-margin-top:64px}.ft .scroll-mt-20{scroll-margin-top:80px}.ft .scroll-mt-40{scroll-margin-top:160px}.ft .scroll-mt-60{scroll-margin-top:240px}.ft .scroll-mt-px{scroll-margin-top:1px}.ft .scroll-mt-0\.5{scroll-margin-top:2px}.ft .-scroll-mt-0{scroll-margin-top:0}.ft .-scroll-mt-1{scroll-margin-top:-4px}.ft .-scroll-mt-2{scroll-margin-top:-8px}.ft .-scroll-mt-3{scroll-margin-top:-12px}.ft .-scroll-mt-4{scroll-margin-top:-16px}.ft .-scroll-mt-5{scroll-margin-top:-20px}.ft .-scroll-mt-10{scroll-margin-top:-40px}.ft .-scroll-mt-16{scroll-margin-top:-64px}.ft .-scroll-mt-20{scroll-margin-top:-80px}.ft .-scroll-mt-40{scroll-margin-top:-160px}.ft .-scroll-mt-60{scroll-margin-top:-240px}.ft .-scroll-mt-px{scroll-margin-top:-1px}.ft .-scroll-mt-0\.5{scroll-margin-top:-2px}.ft .scroll-mr-0{scroll-margin-right:0}.ft .scroll-mr-1{scroll-margin-right:4px}.ft .scroll-mr-2{scroll-margin-right:8px}.ft .scroll-mr-3{scroll-margin-right:12px}.ft .scroll-mr-4{scroll-margin-right:16px}.ft .scroll-mr-5{scroll-margin-right:20px}.ft .scroll-mr-10{scroll-margin-right:40px}.ft .scroll-mr-16{scroll-margin-right:64px}.ft .scroll-mr-20{scroll-margin-right:80px}.ft .scroll-mr-40{scroll-margin-right:160px}.ft .scroll-mr-60{scroll-margin-right:240px}.ft .scroll-mr-px{scroll-margin-right:1px}.ft .scroll-mr-0\.5{scroll-margin-right:2px}.ft .-scroll-mr-0{scroll-margin-right:0}.ft .-scroll-mr-1{scroll-margin-right:-4px}.ft .-scroll-mr-2{scroll-margin-right:-8px}.ft .-scroll-mr-3{scroll-margin-right:-12px}.ft .-scroll-mr-4{scroll-margin-right:-16px}.ft .-scroll-mr-5{scroll-margin-right:-20px}.ft .-scroll-mr-10{scroll-margin-right:-40px}.ft .-scroll-mr-16{scroll-margin-right:-64px}.ft .-scroll-mr-20{scroll-margin-right:-80px}.ft .-scroll-mr-40{scroll-margin-right:-160px}.ft .-scroll-mr-60{scroll-margin-right:-240px}.ft .-scroll-mr-px{scroll-margin-right:-1px}.ft .-scroll-mr-0\.5{scroll-margin-right:-2px}.ft .scroll-mb-0{scroll-margin-bottom:0}.ft .scroll-mb-1{scroll-margin-bottom:4px}.ft .scroll-mb-2{scroll-margin-bottom:8px}.ft .scroll-mb-3{scroll-margin-bottom:12px}.ft .scroll-mb-4{scroll-margin-bottom:16px}.ft .scroll-mb-5{scroll-margin-bottom:20px}.ft .scroll-mb-10{scroll-margin-bottom:40px}.ft .scroll-mb-16{scroll-margin-bottom:64px}.ft .scroll-mb-20{scroll-margin-bottom:80px}.ft .scroll-mb-40{scroll-margin-bottom:160px}.ft .scroll-mb-60{scroll-margin-bottom:240px}.ft .scroll-mb-px{scroll-margin-bottom:1px}.ft .scroll-mb-0\.5{scroll-margin-bottom:2px}.ft .-scroll-mb-0{scroll-margin-bottom:0}.ft .-scroll-mb-1{scroll-margin-bottom:-4px}.ft .-scroll-mb-2{scroll-margin-bottom:-8px}.ft .-scroll-mb-3{scroll-margin-bottom:-12px}.ft .-scroll-mb-4{scroll-margin-bottom:-16px}.ft .-scroll-mb-5{scroll-margin-bottom:-20px}.ft .-scroll-mb-10{scroll-margin-bottom:-40px}.ft .-scroll-mb-16{scroll-margin-bottom:-64px}.ft .-scroll-mb-20{scroll-margin-bottom:-80px}.ft .-scroll-mb-40{scroll-margin-bottom:-160px}.ft .-scroll-mb-60{scroll-margin-bottom:-240px}.ft .-scroll-mb-px{scroll-margin-bottom:-1px}.ft .-scroll-mb-0\.5{scroll-margin-bottom:-2px}.ft .scroll-ml-0{scroll-margin-left:0}.ft .scroll-ml-1{scroll-margin-left:4px}.ft .scroll-ml-2{scroll-margin-left:8px}.ft .scroll-ml-3{scroll-margin-left:12px}.ft .scroll-ml-4{scroll-margin-left:16px}.ft .scroll-ml-5{scroll-margin-left:20px}.ft .scroll-ml-10{scroll-margin-left:40px}.ft .scroll-ml-16{scroll-margin-left:64px}.ft .scroll-ml-20{scroll-margin-left:80px}.ft .scroll-ml-40{scroll-margin-left:160px}.ft .scroll-ml-60{scroll-margin-left:240px}.ft .scroll-ml-px{scroll-margin-left:1px}.ft .scroll-ml-0\.5{scroll-margin-left:2px}.ft .-scroll-ml-0{scroll-margin-left:0}.ft .-scroll-ml-1{scroll-margin-left:-4px}.ft .-scroll-ml-2{scroll-margin-left:-8px}.ft .-scroll-ml-3{scroll-margin-left:-12px}.ft .-scroll-ml-4{scroll-margin-left:-16px}.ft .-scroll-ml-5{scroll-margin-left:-20px}.ft .-scroll-ml-10{scroll-margin-left:-40px}.ft .-scroll-ml-16{scroll-margin-left:-64px}.ft .-scroll-ml-20{scroll-margin-left:-80px}.ft .-scroll-ml-40{scroll-margin-left:-160px}.ft .-scroll-ml-60{scroll-margin-left:-240px}.ft .-scroll-ml-px{scroll-margin-left:-1px}.ft .-scroll-ml-0\.5{scroll-margin-left:-2px}.ft .scroll-p-0{scroll-padding:0}.ft .scroll-p-1{scroll-padding:4px}.ft .scroll-p-2{scroll-padding:8px}.ft .scroll-p-3{scroll-padding:12px}.ft .scroll-p-4{scroll-padding:16px}.ft .scroll-p-5{scroll-padding:20px}.ft .scroll-p-10{scroll-padding:40px}.ft .scroll-p-16{scroll-padding:64px}.ft .scroll-p-20{scroll-padding:80px}.ft .scroll-p-40{scroll-padding:160px}.ft .scroll-p-60{scroll-padding:240px}.ft .scroll-p-px{scroll-padding:1px}.ft .scroll-p-0\.5{scroll-padding:2px}.ft .scroll-pt-0{scroll-padding-top:0}.ft .scroll-pt-1{scroll-padding-top:4px}.ft .scroll-pt-2{scroll-padding-top:8px}.ft .scroll-pt-3{scroll-padding-top:12px}.ft .scroll-pt-4{scroll-padding-top:16px}.ft .scroll-pt-5{scroll-padding-top:20px}.ft .scroll-pt-10{scroll-padding-top:40px}.ft .scroll-pt-16{scroll-padding-top:64px}.ft .scroll-pt-20{scroll-padding-top:80px}.ft .scroll-pt-40{scroll-padding-top:160px}.ft .scroll-pt-60{scroll-padding-top:240px}.ft .scroll-pt-px{scroll-padding-top:1px}.ft .scroll-pt-0\.5{scroll-padding-top:2px}.ft .scroll-pr-0{scroll-padding-right:0}.ft .scroll-pr-1{scroll-padding-right:4px}.ft .scroll-pr-2{scroll-padding-right:8px}.ft .scroll-pr-3{scroll-padding-right:12px}.ft .scroll-pr-4{scroll-padding-right:16px}.ft .scroll-pr-5{scroll-padding-right:20px}.ft .scroll-pr-10{scroll-padding-right:40px}.ft .scroll-pr-16{scroll-padding-right:64px}.ft .scroll-pr-20{scroll-padding-right:80px}.ft .scroll-pr-40{scroll-padding-right:160px}.ft .scroll-pr-60{scroll-padding-right:240px}.ft .scroll-pr-px{scroll-padding-right:1px}.ft .scroll-pr-0\.5{scroll-padding-right:2px}.ft .scroll-pb-0{scroll-padding-bottom:0}.ft .scroll-pb-1{scroll-padding-bottom:4px}.ft .scroll-pb-2{scroll-padding-bottom:8px}.ft .scroll-pb-3{scroll-padding-bottom:12px}.ft .scroll-pb-4{scroll-padding-bottom:16px}.ft .scroll-pb-5{scroll-padding-bottom:20px}.ft .scroll-pb-10{scroll-padding-bottom:40px}.ft .scroll-pb-16{scroll-padding-bottom:64px}.ft .scroll-pb-20{scroll-padding-bottom:80px}.ft .scroll-pb-40{scroll-padding-bottom:160px}.ft .scroll-pb-60{scroll-padding-bottom:240px}.ft .scroll-pb-px{scroll-padding-bottom:1px}.ft .scroll-pb-0\.5{scroll-padding-bottom:2px}.ft .scroll-pl-0{scroll-padding-left:0}.ft .scroll-pl-1{scroll-padding-left:4px}.ft .scroll-pl-2{scroll-padding-left:8px}.ft .scroll-pl-3{scroll-padding-left:12px}.ft .scroll-pl-4{scroll-padding-left:16px}.ft .scroll-pl-5{scroll-padding-left:20px}.ft .scroll-pl-10{scroll-padding-left:40px}.ft .scroll-pl-16{scroll-padding-left:64px}.ft .scroll-pl-20{scroll-padding-left:80px}.ft .scroll-pl-40{scroll-padding-left:160px}.ft .scroll-pl-60{scroll-padding-left:240px}.ft .scroll-pl-px{scroll-padding-left:1px}.ft .scroll-pl-0\.5{scroll-padding-left:2px}.ft .grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.ft .grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.ft .flex-row{flex-direction:row}.ft .flex-col{flex-direction:column}.ft .place-items-start{place-items:start}.ft .place-items-end{place-items:end}.ft .place-items-center{place-items:center}.ft .place-items-stretch{place-items:stretch}.ft .items-start{align-items:flex-start}.ft .items-end{align-items:flex-end}.ft .items-center{align-items:center}.ft .items-baseline{align-items:baseline}.ft .items-stretch{align-items:stretch}.ft .justify-start{justify-content:flex-start}.ft .justify-end{justify-content:flex-end}.ft .justify-center{justify-content:center}.ft .justify-between{justify-content:space-between}.ft .justify-around{justify-content:space-around}.ft .justify-evenly{justify-content:space-evenly}.ft .justify-items-start{justify-items:start}.ft .justify-items-end{justify-items:end}.ft .justify-items-center{justify-items:center}.ft .justify-items-stretch{justify-items:stretch}.ft .gap-1{gap:4px}.ft .gap-0{gap:0}.ft .gap-2{gap:8px}.ft .gap-3{gap:12px}.ft .gap-4{gap:16px}.ft .gap-5{gap:20px}.ft .gap-10{gap:40px}.ft .gap-16{gap:64px}.ft .gap-20{gap:80px}.ft .gap-40{gap:160px}.ft .gap-60{gap:240px}.ft .gap-px{gap:1px}.ft .gap-0\.5{gap:2px}.ft .space-x-1>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(4px*var(--tw-space-x-reverse));margin-left:calc(4px*(1 - var(--tw-space-x-reverse)))}.ft .space-y-2>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-top:calc(8px*(1 - var(--tw-space-y-reverse)));margin-bottom:calc(8px*var(--tw-space-y-reverse))}.ft .space-x-3>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(12px*var(--tw-space-x-reverse));margin-left:calc(12px*(1 - var(--tw-space-x-reverse)))}.ft .space-x-2>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(8px*var(--tw-space-x-reverse));margin-left:calc(8px*(1 - var(--tw-space-x-reverse)))}.ft .space-x-0\.5>:not([hidden])~:not([hidden]){--tw-space-x-reverse:0;margin-right:calc(2px*var(--tw-space-x-reverse));margin-left:calc(2px*(1 - var(--tw-space-x-reverse)))}.ft .overflow-auto{overflow:auto}.ft .whitespace-nowrap{white-space:nowrap}.ft .rounded{border-radius:.25rem}.ft .rounded-none{border-radius:0}.ft .rounded-lg{border-radius:.5rem}.ft .rounded-sm{border-radius:.125rem}.ft .rounded-full{border-radius:9999px}.ft .rounded-md{border-radius:.375rem}.ft .rounded-xl{border-radius:.75rem}.ft .rounded-2xl{border-radius:1rem}.ft .rounded-3xl{border-radius:1.5rem}.ft .rounded-l{border-top-left-radius:.25rem;border-bottom-left-radius:.25rem}.ft .rounded-t{border-top-left-radius:.25rem;border-top-right-radius:.25rem}.ft .rounded-r{border-top-right-radius:.25rem}.ft .rounded-b,.ft .rounded-r{border-bottom-right-radius:.25rem}.ft .rounded-b{border-bottom-left-radius:.25rem}.ft .rounded-tl{border-top-left-radius:.25rem}.ft .rounded-tr{border-top-right-radius:.25rem}.ft .rounded-br{border-bottom-right-radius:.25rem}.ft .rounded-bl{border-bottom-left-radius:.25rem}.ft .border{border-width:1px}.ft .border-0{border-width:0}.ft .border-2{border-width:2px}.ft .border-l-4{border-left-width:4px}.ft .border-t{border-top-width:1px}.ft .border-b{border-bottom-width:1px}.ft .border-r{border-right-width:1px}.ft .border-l{border-left-width:1px}.ft .border-t-2{border-top-width:2px}.ft .border-dashed{border-style:dashed}.ft .border-gray-800{--tw-border-opacity:1;border-color:rgb(31 41 55/var(--tw-border-opacity))}.ft .border-gray-200{--tw-border-opacity:1;border-color:rgb(229 231 235/var(--tw-border-opacity))}.ft .border-gray-400{--tw-border-opacity:1;border-color:rgb(156 163 175/var(--tw-border-opacity))}.ft .border-tertiary{--tw-border-opacity:1;border-color:rgb(var(--ft-tertiary,31 41 55)/var(--tw-border-opacity))}.ft .border-tertiary\/50{border-color:rgb(var(--ft-tertiary,31 41 55)/.5)}.ft .border-gray-300{--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.ft .bg-indigo-50{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity))}.ft .bg-transparent{background-color:initial}.ft .bg-secondary{--tw-bg-opacity:1;background-color:rgb(var(--ft-secondary,251 113 133)/var(--tw-bg-opacity))}.ft .bg-blue-700{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity))}.ft .bg-black{--tw-bg-opacity:1;background-color:rgb(0 0 0/var(--tw-bg-opacity))}.ft .bg-white{--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.ft .bg-yellow-200{--tw-bg-opacity:1;background-color:rgb(254 240 138/var(--tw-bg-opacity))}.ft .bg-gray-100{--tw-bg-opacity:1;background-color:rgb(243 244 246/var(--tw-bg-opacity))}.ft .bg-blue-200{--tw-bg-opacity:1;background-color:rgb(191 219 254/var(--tw-bg-opacity))}.ft .bg-red-600{--tw-bg-opacity:1;background-color:rgb(220 38 38/var(--tw-bg-opacity))}.ft .bg-blue-600{--tw-bg-opacity:1;background-color:rgb(37 99 235/var(--tw-bg-opacity))}.ft .bg-primary\/90{background-color:rgb(var(--ft-primary,59 130 246)/.9)}.ft .bg-gray-600{--tw-bg-opacity:1;background-color:rgb(75 85 99/var(--tw-bg-opacity))}.ft .bg-gray-300{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.ft .bg-gray-50{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.ft .bg-gray-200{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.ft .bg-gray-400{--tw-bg-opacity:1;background-color:rgb(156 163 175/var(--tw-bg-opacity))}.ft .bg-gray-500{--tw-bg-opacity:1;background-color:rgb(107 114 128/var(--tw-bg-opacity))}.ft .bg-gray-700{--tw-bg-opacity:1;background-color:rgb(55 65 81/var(--tw-bg-opacity))}.ft .bg-gray-800{--tw-bg-opacity:1;background-color:rgb(31 41 55/var(--tw-bg-opacity))}.ft .bg-gray-900{--tw-bg-opacity:1;background-color:rgb(17 24 39/var(--tw-bg-opacity))}.ft .bg-red-50{--tw-bg-opacity:1;background-color:rgb(254 242 242/var(--tw-bg-opacity))}.ft .bg-red-100{--tw-bg-opacity:1;background-color:rgb(254 226 226/var(--tw-bg-opacity))}.ft .bg-red-200{--tw-bg-opacity:1;background-color:rgb(254 202 202/var(--tw-bg-opacity))}.ft .bg-red-300{--tw-bg-opacity:1;background-color:rgb(252 165 165/var(--tw-bg-opacity))}.ft .bg-red-400{--tw-bg-opacity:1;background-color:rgb(248 113 113/var(--tw-bg-opacity))}.ft .bg-red-500{--tw-bg-opacity:1;background-color:rgb(239 68 68/var(--tw-bg-opacity))}.ft .bg-red-700{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.ft .bg-red-800{--tw-bg-opacity:1;background-color:rgb(153 27 27/var(--tw-bg-opacity))}.ft .bg-red-900{--tw-bg-opacity:1;background-color:rgb(127 29 29/var(--tw-bg-opacity))}.ft .bg-yellow-50{--tw-bg-opacity:1;background-color:rgb(254 252 232/var(--tw-bg-opacity))}.ft .bg-yellow-100{--tw-bg-opacity:1;background-color:rgb(254 249 195/var(--tw-bg-opacity))}.ft .bg-yellow-300{--tw-bg-opacity:1;background-color:rgb(253 224 71/var(--tw-bg-opacity))}.ft .bg-yellow-400{--tw-bg-opacity:1;background-color:rgb(250 204 21/var(--tw-bg-opacity))}.ft .bg-yellow-500{--tw-bg-opacity:1;background-color:rgb(234 179 8/var(--tw-bg-opacity))}.ft .bg-yellow-600{--tw-bg-opacity:1;background-color:rgb(202 138 4/var(--tw-bg-opacity))}.ft .bg-yellow-700{--tw-bg-opacity:1;background-color:rgb(161 98 7/var(--tw-bg-opacity))}.ft .bg-yellow-800{--tw-bg-opacity:1;background-color:rgb(133 77 14/var(--tw-bg-opacity))}.ft .bg-yellow-900{--tw-bg-opacity:1;background-color:rgb(113 63 18/var(--tw-bg-opacity))}.ft .bg-green-50{--tw-bg-opacity:1;background-color:rgb(240 253 244/var(--tw-bg-opacity))}.ft .bg-green-100{--tw-bg-opacity:1;background-color:rgb(220 252 231/var(--tw-bg-opacity))}.ft .bg-green-200{--tw-bg-opacity:1;background-color:rgb(187 247 208/var(--tw-bg-opacity))}.ft .bg-green-300{--tw-bg-opacity:1;background-color:rgb(134 239 172/var(--tw-bg-opacity))}.ft .bg-green-400{--tw-bg-opacity:1;background-color:rgb(74 222 128/var(--tw-bg-opacity))}.ft .bg-green-500{--tw-bg-opacity:1;background-color:rgb(34 197 94/var(--tw-bg-opacity))}.ft .bg-green-600{--tw-bg-opacity:1;background-color:rgb(22 163 74/var(--tw-bg-opacity))}.ft .bg-green-700{--tw-bg-opacity:1;background-color:rgb(21 128 61/var(--tw-bg-opacity))}.ft .bg-green-800{--tw-bg-opacity:1;background-color:rgb(22 101 52/var(--tw-bg-opacity))}.ft .bg-green-900{--tw-bg-opacity:1;background-color:rgb(20 83 45/var(--tw-bg-opacity))}.ft .bg-blue-50{--tw-bg-opacity:1;background-color:rgb(239 246 255/var(--tw-bg-opacity))}.ft .bg-blue-100{--tw-bg-opacity:1;background-color:rgb(219 234 254/var(--tw-bg-opacity))}.ft .bg-blue-300{--tw-bg-opacity:1;background-color:rgb(147 197 253/var(--tw-bg-opacity))}.ft .bg-blue-400{--tw-bg-opacity:1;background-color:rgb(96 165 250/var(--tw-bg-opacity))}.ft .bg-blue-500{--tw-bg-opacity:1;background-color:rgb(59 130 246/var(--tw-bg-opacity))}.ft .bg-blue-800{--tw-bg-opacity:1;background-color:rgb(30 64 175/var(--tw-bg-opacity))}.ft .bg-blue-900{--tw-bg-opacity:1;background-color:rgb(30 58 138/var(--tw-bg-opacity))}.ft .bg-indigo-100{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity))}.ft .bg-indigo-200{--tw-bg-opacity:1;background-color:rgb(199 210 254/var(--tw-bg-opacity))}.ft .bg-indigo-300{--tw-bg-opacity:1;background-color:rgb(165 180 252/var(--tw-bg-opacity))}.ft .bg-indigo-400{--tw-bg-opacity:1;background-color:rgb(129 140 248/var(--tw-bg-opacity))}.ft .bg-indigo-500{--tw-bg-opacity:1;background-color:rgb(99 102 241/var(--tw-bg-opacity))}.ft .bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity))}.ft .bg-indigo-700{--tw-bg-opacity:1;background-color:rgb(67 56 202/var(--tw-bg-opacity))}.ft .bg-indigo-800{--tw-bg-opacity:1;background-color:rgb(55 48 163/var(--tw-bg-opacity))}.ft .bg-indigo-900{--tw-bg-opacity:1;background-color:rgb(49 46 129/var(--tw-bg-opacity))}.ft .bg-purple-50{--tw-bg-opacity:1;background-color:rgb(250 245 255/var(--tw-bg-opacity))}.ft .bg-purple-100{--tw-bg-opacity:1;background-color:rgb(243 232 255/var(--tw-bg-opacity))}.ft .bg-purple-200{--tw-bg-opacity:1;background-color:rgb(233 213 255/var(--tw-bg-opacity))}.ft .bg-purple-300{--tw-bg-opacity:1;background-color:rgb(216 180 254/var(--tw-bg-opacity))}.ft .bg-purple-400{--tw-bg-opacity:1;background-color:rgb(192 132 252/var(--tw-bg-opacity))}.ft .bg-purple-500{--tw-bg-opacity:1;background-color:rgb(168 85 247/var(--tw-bg-opacity))}.ft .bg-purple-600{--tw-bg-opacity:1;background-color:rgb(147 51 234/var(--tw-bg-opacity))}.ft .bg-purple-700{--tw-bg-opacity:1;background-color:rgb(126 34 206/var(--tw-bg-opacity))}.ft .bg-purple-800{--tw-bg-opacity:1;background-color:rgb(107 33 168/var(--tw-bg-opacity))}.ft .bg-purple-900{--tw-bg-opacity:1;background-color:rgb(88 28 135/var(--tw-bg-opacity))}.ft .bg-pink-50{--tw-bg-opacity:1;background-color:rgb(253 242 248/var(--tw-bg-opacity))}.ft .bg-pink-100{--tw-bg-opacity:1;background-color:rgb(252 231 243/var(--tw-bg-opacity))}.ft .bg-pink-200{--tw-bg-opacity:1;background-color:rgb(251 207 232/var(--tw-bg-opacity))}.ft .bg-pink-300{--tw-bg-opacity:1;background-color:rgb(249 168 212/var(--tw-bg-opacity))}.ft .bg-pink-400{--tw-bg-opacity:1;background-color:rgb(244 114 182/var(--tw-bg-opacity))}.ft .bg-pink-500{--tw-bg-opacity:1;background-color:rgb(236 72 153/var(--tw-bg-opacity))}.ft .bg-pink-600{--tw-bg-opacity:1;background-color:rgb(219 39 119/var(--tw-bg-opacity))}.ft .bg-pink-700{--tw-bg-opacity:1;background-color:rgb(190 24 93/var(--tw-bg-opacity))}.ft .bg-pink-800{--tw-bg-opacity:1;background-color:rgb(157 23 77/var(--tw-bg-opacity))}.ft .bg-pink-900{--tw-bg-opacity:1;background-color:rgb(131 24 67/var(--tw-bg-opacity))}.ft .bg-opacity-50{--tw-bg-opacity:0.5}.ft .bg-opacity-75{--tw-bg-opacity:0.75}.ft .fill-current{fill:currentColor}.ft .p-3{padding:12px}.ft .p-5{padding:20px}.ft .p-10{padding:40px}.ft .p-2{padding:8px}.ft .p-4{padding:16px}.ft .p-1{padding:4px}.ft .p-2\.5{padding:10px}.ft .p-0{padding:0}.ft .p-16{padding:64px}.ft .p-20{padding:80px}.ft .p-40{padding:160px}.ft .p-60{padding:240px}.ft .p-px{padding:1px}.ft .p-0\.5{padding:2px}.ft .px-4{padding-left:16px;padding-right:16px}.ft .py-2{padding-top:8px;padding-bottom:8px}.ft .px-3{padding-left:12px;padding-right:12px}.ft .px-8{padding-left:32px;padding-right:32px}.ft .py-6{padding-top:24px;padding-bottom:24px}.ft .px-1{padding-left:4px;padding-right:4px}.ft .py-1{padding-top:4px;padding-bottom:4px}.ft .px-2{padding-left:8px;padding-right:8px}.ft .px-5{padding-left:20px;padding-right:20px}.ft .px-10{padding-left:40px;padding-right:40px}.ft .py-2\.5{padding-top:10px;padding-bottom:10px}.ft .pt-4{padding-top:16px}.ft .pb-10{padding-bottom:40px}.ft .pl-16{padding-left:64px}.ft .pb-5{padding-bottom:20px}.ft .pl-2{padding-left:8px}.ft .pr-3{padding-right:12px}.ft .pr-2{padding-right:8px}.ft .pl-1{padding-left:4px}.ft .pt-2{padding-top:8px}.ft .pl-5{padding-left:20px}.ft .pt-0{padding-top:0}.ft .pt-1{padding-top:4px}.ft .pt-3{padding-top:12px}.ft .pt-5{padding-top:20px}.ft .pt-10{padding-top:40px}.ft .pt-16{padding-top:64px}.ft .pt-20{padding-top:80px}.ft .pt-40{padding-top:160px}.ft .pt-60{padding-top:240px}.ft .pt-px{padding-top:1px}.ft .pt-0\.5{padding-top:2px}.ft .pr-0{padding-right:0}.ft .pr-1{padding-right:4px}.ft .pr-4{padding-right:16px}.ft .pr-5{padding-right:20px}.ft .pr-10{padding-right:40px}.ft .pr-16{padding-right:64px}.ft .pr-20{padding-right:80px}.ft .pr-40{padding-right:160px}.ft .pr-60{padding-right:240px}.ft .pr-px{padding-right:1px}.ft .pr-0\.5{padding-right:2px}.ft .pb-0{padding-bottom:0}.ft .pb-1{padding-bottom:4px}.ft .pb-2{padding-bottom:8px}.ft .pb-3{padding-bottom:12px}.ft .pb-4{padding-bottom:16px}.ft .pb-16{padding-bottom:64px}.ft .pb-20{padding-bottom:80px}.ft .pb-40{padding-bottom:160px}.ft .pb-60{padding-bottom:240px}.ft .pb-px{padding-bottom:1px}.ft .pb-0\.5{padding-bottom:2px}.ft .pl-0{padding-left:0}.ft .pl-3{padding-left:12px}.ft .pl-4{padding-left:16px}.ft .pl-10{padding-left:40px}.ft .pl-20{padding-left:80px}.ft .pl-40{padding-left:160px}.ft .pl-60{padding-left:240px}.ft .pl-px{padding-left:1px}.ft .pl-0\.5{padding-left:2px}.ft .text-left{text-align:left}.ft .text-center{text-align:center}.ft .text-right{text-align:right}.ft .text-justify{text-align:justify}.ft .font-mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace}.ft .text-xl{font-size:20px}.ft .text-lg{font-size:18px}.ft .text-2xl{font-size:24px}.ft .text-sm{font-size:14px}.ft .text-xs{font-size:12px}.ft .text-6xl{font-size:60px}.ft .text-5xl{font-size:48px}.ft .text-4xl{font-size:36px}.ft .text-3xl{font-size:30px}.ft .text-base{font-size:16px}.ft .font-semibold{font-weight:600}.ft .font-medium{font-weight:500}.ft .font-bold{font-weight:700}.ft .font-normal{font-weight:400}.ft .capitalize{text-transform:capitalize}.ft .italic{font-style:italic}.ft .leading-3{line-height:12px}.ft .leading-4{line-height:16px}.ft .leading-5{line-height:20px}.ft .leading-6{line-height:24px}.ft .leading-7{line-height:28px}.ft .leading-8{line-height:32px}.ft .leading-9{line-height:36px}.ft .leading-10{line-height:40px}.ft .leading-none{line-height:1}.ft .leading-tight{line-height:1.25}.ft .leading-snug{line-height:1.375}.ft .leading-normal{line-height:1.5}.ft .leading-relaxed{line-height:1.625}.ft .leading-loose{line-height:2}.ft .text-indigo-700{--tw-text-opacity:1;color:rgb(67 56 202/var(--tw-text-opacity))}.ft .text-primary{--tw-text-opacity:1;color:rgb(var(--ft-primary,59 130 246)/var(--tw-text-opacity))}.ft .text-blue-100{--tw-text-opacity:1;color:rgb(219 234 254/var(--tw-text-opacity))}.ft .text-gray-800{--tw-text-opacity:1;color:rgb(31 41 55/var(--tw-text-opacity))}.ft .text-gray-700{--tw-text-opacity:1;color:rgb(55 65 81/var(--tw-text-opacity))}.ft .text-yellow-800{--tw-text-opacity:1;color:rgb(133 77 14/var(--tw-text-opacity))}.ft .text-red-700{--tw-text-opacity:1;color:rgb(185 28 28/var(--tw-text-opacity))}.ft .text-black{--tw-text-opacity:1;color:rgb(0 0 0/var(--tw-text-opacity))}.ft .text-red-100{--tw-text-opacity:1;color:rgb(254 226 226/var(--tw-text-opacity))}.ft .text-blue-600{--tw-text-opacity:1;color:rgb(37 99 235/var(--tw-text-opacity))}.ft .text-blue-700{--tw-text-opacity:1;color:rgb(29 78 216/var(--tw-text-opacity))}.ft .text-primary\/40{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .text-secondary{--tw-text-opacity:1;color:rgb(var(--ft-secondary,251 113 133)/var(--tw-text-opacity))}.ft .text-white{--tw-text-opacity:1;color:rgb(255 255 255/var(--tw-text-opacity))}.ft .text-red-500{--tw-text-opacity:1;color:rgb(239 68 68/var(--tw-text-opacity))}.ft .text-gray-500{--tw-text-opacity:1;color:rgb(107 114 128/var(--tw-text-opacity))}.ft .text-gray-50{--tw-text-opacity:1;color:rgb(249 250 251/var(--tw-text-opacity))}.ft .text-gray-100{--tw-text-opacity:1;color:rgb(243 244 246/var(--tw-text-opacity))}.ft .text-gray-200{--tw-text-opacity:1;color:rgb(229 231 235/var(--tw-text-opacity))}.ft .text-gray-300{--tw-text-opacity:1;color:rgb(209 213 219/var(--tw-text-opacity))}.ft .text-gray-400{--tw-text-opacity:1;color:rgb(156 163 175/var(--tw-text-opacity))}.ft .text-gray-600{--tw-text-opacity:1;color:rgb(75 85 99/var(--tw-text-opacity))}.ft .text-gray-900{--tw-text-opacity:1;color:rgb(17 24 39/var(--tw-text-opacity))}.ft .text-red-50{--tw-text-opacity:1;color:rgb(254 242 242/var(--tw-text-opacity))}.ft .text-red-200{--tw-text-opacity:1;color:rgb(254 202 202/var(--tw-text-opacity))}.ft .text-red-300{--tw-text-opacity:1;color:rgb(252 165 165/var(--tw-text-opacity))}.ft .text-red-400{--tw-text-opacity:1;color:rgb(248 113 113/var(--tw-text-opacity))}.ft .text-red-600{--tw-text-opacity:1;color:rgb(220 38 38/var(--tw-text-opacity))}.ft .text-red-800{--tw-text-opacity:1;color:rgb(153 27 27/var(--tw-text-opacity))}.ft .text-red-900{--tw-text-opacity:1;color:rgb(127 29 29/var(--tw-text-opacity))}.ft .text-yellow-50{--tw-text-opacity:1;color:rgb(254 252 232/var(--tw-text-opacity))}.ft .text-yellow-100{--tw-text-opacity:1;color:rgb(254 249 195/var(--tw-text-opacity))}.ft .text-yellow-200{--tw-text-opacity:1;color:rgb(254 240 138/var(--tw-text-opacity))}.ft .text-yellow-300{--tw-text-opacity:1;color:rgb(253 224 71/var(--tw-text-opacity))}.ft .text-yellow-400{--tw-text-opacity:1;color:rgb(250 204 21/var(--tw-text-opacity))}.ft .text-yellow-500{--tw-text-opacity:1;color:rgb(234 179 8/var(--tw-text-opacity))}.ft .text-yellow-600{--tw-text-opacity:1;color:rgb(202 138 4/var(--tw-text-opacity))}.ft .text-yellow-700{--tw-text-opacity:1;color:rgb(161 98 7/var(--tw-text-opacity))}.ft .text-yellow-900{--tw-text-opacity:1;color:rgb(113 63 18/var(--tw-text-opacity))}.ft .text-green-50{--tw-text-opacity:1;color:rgb(240 253 244/var(--tw-text-opacity))}.ft .text-green-100{--tw-text-opacity:1;color:rgb(220 252 231/var(--tw-text-opacity))}.ft .text-green-200{--tw-text-opacity:1;color:rgb(187 247 208/var(--tw-text-opacity))}.ft .text-green-300{--tw-text-opacity:1;color:rgb(134 239 172/var(--tw-text-opacity))}.ft .text-green-400{--tw-text-opacity:1;color:rgb(74 222 128/var(--tw-text-opacity))}.ft .text-green-500{--tw-text-opacity:1;color:rgb(34 197 94/var(--tw-text-opacity))}.ft .text-green-600{--tw-text-opacity:1;color:rgb(22 163 74/var(--tw-text-opacity))}.ft .text-green-700{--tw-text-opacity:1;color:rgb(21 128 61/var(--tw-text-opacity))}.ft .text-green-800{--tw-text-opacity:1;color:rgb(22 101 52/var(--tw-text-opacity))}.ft .text-green-900{--tw-text-opacity:1;color:rgb(20 83 45/var(--tw-text-opacity))}.ft .text-blue-50{--tw-text-opacity:1;color:rgb(239 246 255/var(--tw-text-opacity))}.ft .text-blue-200{--tw-text-opacity:1;color:rgb(191 219 254/var(--tw-text-opacity))}.ft .text-blue-300{--tw-text-opacity:1;color:rgb(147 197 253/var(--tw-text-opacity))}.ft .text-blue-400{--tw-text-opacity:1;color:rgb(96 165 250/var(--tw-text-opacity))}.ft .text-blue-500{--tw-text-opacity:1;color:rgb(59 130 246/var(--tw-text-opacity))}.ft .text-blue-800{--tw-text-opacity:1;color:rgb(30 64 175/var(--tw-text-opacity))}.ft .text-blue-900{--tw-text-opacity:1;color:rgb(30 58 138/var(--tw-text-opacity))}.ft .text-indigo-50{--tw-text-opacity:1;color:rgb(238 242 255/var(--tw-text-opacity))}.ft .text-indigo-100{--tw-text-opacity:1;color:rgb(224 231 255/var(--tw-text-opacity))}.ft .text-indigo-200{--tw-text-opacity:1;color:rgb(199 210 254/var(--tw-text-opacity))}.ft .text-indigo-300{--tw-text-opacity:1;color:rgb(165 180 252/var(--tw-text-opacity))}.ft .text-indigo-400{--tw-text-opacity:1;color:rgb(129 140 248/var(--tw-text-opacity))}.ft .text-indigo-500{--tw-text-opacity:1;color:rgb(99 102 241/var(--tw-text-opacity))}.ft .text-indigo-600{--tw-text-opacity:1;color:rgb(79 70 229/var(--tw-text-opacity))}.ft .text-indigo-800{--tw-text-opacity:1;color:rgb(55 48 163/var(--tw-text-opacity))}.ft .text-indigo-900{--tw-text-opacity:1;color:rgb(49 46 129/var(--tw-text-opacity))}.ft .text-purple-50{--tw-text-opacity:1;color:rgb(250 245 255/var(--tw-text-opacity))}.ft .text-purple-100{--tw-text-opacity:1;color:rgb(243 232 255/var(--tw-text-opacity))}.ft .text-purple-200{--tw-text-opacity:1;color:rgb(233 213 255/var(--tw-text-opacity))}.ft .text-purple-300{--tw-text-opacity:1;color:rgb(216 180 254/var(--tw-text-opacity))}.ft .text-purple-400{--tw-text-opacity:1;color:rgb(192 132 252/var(--tw-text-opacity))}.ft .text-purple-500{--tw-text-opacity:1;color:rgb(168 85 247/var(--tw-text-opacity))}.ft .text-purple-600{--tw-text-opacity:1;color:rgb(147 51 234/var(--tw-text-opacity))}.ft .text-purple-700{--tw-text-opacity:1;color:rgb(126 34 206/var(--tw-text-opacity))}.ft .text-purple-800{--tw-text-opacity:1;color:rgb(107 33 168/var(--tw-text-opacity))}.ft .text-purple-900{--tw-text-opacity:1;color:rgb(88 28 135/var(--tw-text-opacity))}.ft .text-pink-50{--tw-text-opacity:1;color:rgb(253 242 248/var(--tw-text-opacity))}.ft .text-pink-100{--tw-text-opacity:1;color:rgb(252 231 243/var(--tw-text-opacity))}.ft .text-pink-200{--tw-text-opacity:1;color:rgb(251 207 232/var(--tw-text-opacity))}.ft .text-pink-300{--tw-text-opacity:1;color:rgb(249 168 212/var(--tw-text-opacity))}.ft .text-pink-400{--tw-text-opacity:1;color:rgb(244 114 182/var(--tw-text-opacity))}.ft .text-pink-500{--tw-text-opacity:1;color:rgb(236 72 153/var(--tw-text-opacity))}.ft .text-pink-600{--tw-text-opacity:1;color:rgb(219 39 119/var(--tw-text-opacity))}.ft .text-pink-700{--tw-text-opacity:1;color:rgb(190 24 93/var(--tw-text-opacity))}.ft .text-pink-800{--tw-text-opacity:1;color:rgb(157 23 77/var(--tw-text-opacity))}.ft .text-pink-900{--tw-text-opacity:1;color:rgb(131 24 67/var(--tw-text-opacity))}.ft .underline{-webkit-text-decoration-line:underline;text-decoration-line:underline}.ft .line-through{-webkit-text-decoration-line:line-through;text-decoration-line:line-through}.ft .opacity-50{opacity:.5}.ft .shadow{--tw-shadow:0 1px 3px 0 #0000001a,0 1px 2px -1px #0000001a;--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color)}.ft .shadow,.ft .shadow-xl{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ft .shadow-xl{--tw-shadow:0 20px 25px -5px #0000001a,0 8px 10px -6px #0000001a;--tw-shadow-colored:0 20px 25px -5px var(--tw-shadow-color),0 8px 10px -6px var(--tw-shadow-color)}.ft .shadow-inner{--tw-shadow:inset 0 2px 4px 0 #0000000d;--tw-shadow-colored:inset 0 2px 4px 0 var(--tw-shadow-color)}.ft .shadow-inner,.ft .shadow-lg{box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.ft .shadow-lg{--tw-shadow:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--tw-shadow-colored:0 10px 15px -3px var(--tw-shadow-color),0 4px 6px -4px var(--tw-shadow-color)}.ft .outline-none{outline:2px solid #0000;outline-offset:2px}.ft .outline{outline-style:solid}.ft .outline-gray-50{outline-color:#f9fafb}.ft .grayscale{--tw-grayscale:grayscale(100%)}.ft .filter,.ft .grayscale{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ft .placeholder\:text-primary\/40::-moz-placeholder{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .placeholder\:text-primary\/40:-ms-input-placeholder{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .placeholder\:text-primary\/40::placeholder{color:rgb(var(--ft-primary,59 130 246)/.4)}.ft .after\:absolute:after{content:var(--tw-content);position:absolute}.ft .after\:top-0\.5:after{content:var(--tw-content);top:2px}.ft .after\:left-\[5px\]:after{content:var(--tw-content);left:5px}.ft .after\:h-3:after{content:var(--tw-content);height:12px}.ft .after\:w-3:after{content:var(--tw-content);width:12px}.ft .after\:rounded-full:after{content:var(--tw-content);border-radius:9999px}.ft .after\:border:after{content:var(--tw-content);border-width:1px}.ft .after\:border-gray-300:after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(209 213 219/var(--tw-border-opacity))}.ft .after\:bg-white:after{content:var(--tw-content);--tw-bg-opacity:1;background-color:rgb(255 255 255/var(--tw-bg-opacity))}.ft .after\:transition-all:after{content:var(--tw-content);transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.ft .after\:content-\[\'\'\]:after{--tw-content:"";content:var(--tw-content)}.ft .hover\:border-indigo-700:hover{--tw-border-opacity:1;border-color:rgb(67 56 202/var(--tw-border-opacity))}.ft .hover\:bg-indigo-100:hover{--tw-bg-opacity:1;background-color:rgb(224 231 255/var(--tw-bg-opacity))}.ft .hover\:bg-gray-300:hover{--tw-bg-opacity:1;background-color:rgb(209 213 219/var(--tw-bg-opacity))}.ft .hover\:bg-gray-200:hover{--tw-bg-opacity:1;background-color:rgb(229 231 235/var(--tw-bg-opacity))}.ft .hover\:bg-red-700:hover{--tw-bg-opacity:1;background-color:rgb(185 28 28/var(--tw-bg-opacity))}.ft .hover\:bg-blue-700:hover{--tw-bg-opacity:1;background-color:rgb(29 78 216/var(--tw-bg-opacity))}.ft .hover\:bg-primary:hover{--tw-bg-opacity:1;background-color:rgb(var(--ft-primary,59 130 246)/var(--tw-bg-opacity))}.ft .hover\:bg-gray-50:hover{--tw-bg-opacity:1;background-color:rgb(249 250 251/var(--tw-bg-opacity))}.ft .hover\:text-indigo-700:hover{--tw-text-opacity:1;color:rgb(67 56 202/var(--tw-text-opacity))}.ft .hover\:text-primary\/60:hover{color:rgb(var(--ft-primary,59 130 246)/.6)}.ft .focus\:border-transparent:focus{border-color:#0000}.ft .focus\:outline-none:focus{outline:2px solid #0000;outline-offset:2px}.ft .focus\:outline-indigo-300:focus{outline-color:#a5b4fc}.ft .focus\:ring-2:focus{--tw-ring-offset-shadow:var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow:var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow,0 0 #0000)}.ft .focus\:ring-quaternary:focus{--tw-ring-opacity:1;--tw-ring-color:rgb(var(--ft-quaternary,250 204 21)/var(--tw-ring-opacity))}.ft .focus\:drop-shadow-sm:focus{--tw-drop-shadow:drop-shadow(0 1px 1px #0000000d);filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.ft .active\:bg-indigo-50:active{--tw-bg-opacity:1;background-color:rgb(238 242 255/var(--tw-bg-opacity))}.ft .peer:checked~.peer-checked\:bg-indigo-600{--tw-bg-opacity:1;background-color:rgb(79 70 229/var(--tw-bg-opacity))}.ft .peer:checked~.peer-checked\:after\:translate-x-full:after{content:var(--tw-content);--tw-translate-x:100%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skewX(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.ft .peer:checked~.peer-checked\:after\:border-white:after{content:var(--tw-content);--tw-border-opacity:1;border-color:rgb(255 255 255/var(--tw-border-opacity))}.ft [dir=rtl] .rtl\:ml-2{margin-left:8px}@media (min-width:640px){.ft .sm\:mr-4{margin-right:16px}.ft .sm\:flex{display:flex}.ft .sm\:w-1\/2{width:50%}.ft .sm\:w-1\/3{width:33.333333%}.ft .sm\:w-1\/4{width:25%}.ft .sm\:w-1\/5{width:20%}.ft .sm\:w-1\/6{width:16.666667%}.ft .sm\:w-1\/12{width:8.333333%}.ft .sm\:px-4{padding-left:16px;padding-right:16px}}@media (min-width:768px){.ft .md\:p-6{padding:24px}.ft .md\:text-xl{font-size:20px}.ft .md\:text-sm{font-size:14px}.ft .md\:text-base{font-size:16px}.ft .md\:text-6xl{font-size:60px}.ft .md\:text-5xl{font-size:48px}.ft .md\:text-4xl{font-size:36px}.ft .md\:text-3xl{font-size:30px}.ft .md\:text-2xl{font-size:24px}}
--------------------------------------------------------------------------------
/scripts/setupTypeScript.js:
--------------------------------------------------------------------------------
1 | // @ts-check
2 |
3 | /** This script modifies the project to support TS code in .svelte files like:
4 |
5 |
8 |
9 | As well as validating the code for CI.
10 | */
11 |
12 | /** To work on this script:
13 | rm -rf test-template template && git clone sveltejs/template test-template && node scripts/setupTypeScript.js test-template
14 | */
15 |
16 | const fs = require("fs")
17 | const path = require("path")
18 | const { argv } = require("process")
19 |
20 | const projectRoot = argv[2] || path.join(__dirname, "..")
21 |
22 | // Add deps to pkg.json
23 | const packageJSON = JSON.parse(fs.readFileSync(path.join(projectRoot, "package.json"), "utf8"))
24 | packageJSON.devDependencies = Object.assign(packageJSON.devDependencies, {
25 | "svelte-check": "^2.0.0",
26 | "svelte-preprocess": "^4.0.0",
27 | "@rollup/plugin-typescript": "^8.0.0",
28 | "typescript": "^4.0.0",
29 | "tslib": "^2.0.0",
30 | "@tsconfig/svelte": "^2.0.0"
31 | })
32 |
33 | // Add script for checking
34 | packageJSON.scripts = Object.assign(packageJSON.scripts, {
35 | "check": "svelte-check --tsconfig ./tsconfig.json"
36 | })
37 |
38 | // Write the package JSON
39 | fs.writeFileSync(path.join(projectRoot, "package.json"), JSON.stringify(packageJSON, null, " "))
40 |
41 | // mv src/main.js to main.ts - note, we need to edit rollup.config.js for this too
42 | const beforeMainJSPath = path.join(projectRoot, "src", "main.js")
43 | const afterMainTSPath = path.join(projectRoot, "src", "main.ts")
44 | fs.renameSync(beforeMainJSPath, afterMainTSPath)
45 |
46 | // Switch the app.svelte file to use TS
47 | const appSveltePath = path.join(projectRoot, "src", "App.svelte")
48 | let appFile = fs.readFileSync(appSveltePath, "utf8")
49 | appFile = appFile.replace("
19 |
20 |
23 |
35 |
36 |
--------------------------------------------------------------------------------
/src/lib/FormBuilder.svelte:
--------------------------------------------------------------------------------
1 |
111 |
112 |
118 | {#if editable}
119 |
120 | {#each formStore?.steps ?? [] as step, i}
121 |
134 |
addStep(i)}
144 | />
145 | {/each}
146 |
147 | {#if formStore?.props.withMessage}
148 |
149 |
150 |
151 | {/if}
152 |
153 | {:else if !editable && !withMessage}
154 |
167 | {:else if !editable && withMessage}
168 |
169 | {/if}
170 |
171 |
--------------------------------------------------------------------------------
/src/lib/Step.svelte:
--------------------------------------------------------------------------------
1 |
108 |
109 |
110 |
111 |
112 | {#each inputGroups as inputs, indexGrp}
113 |
114 | {#each inputs as input, index}
115 | getIndex(indexGrp, index)}
131 | >
132 |
144 |
145 | {/each}
146 |
147 | {/each}
148 | {#if inputGroups.length}
149 |
150 | {/if}
151 |
152 |
153 | {#if stepInd == numberOfSteps - 1 && numberOfSteps !== 1}
154 |
164 |
172 | {:else if stepInd == numberOfSteps - 1 && numberOfSteps == 1}
173 |
181 | {:else if stepInd == 0}
182 |
190 | {:else}
191 |
201 |
209 | {/if}
210 |
211 |
212 |
213 | {#if show_inputs}
214 |
215 | {/if}
216 |
217 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Inputs/InputAddButton.svelte:
--------------------------------------------------------------------------------
1 |
13 |
14 | {#if editable}
15 |
24 | {/if}
25 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Inputs/InputWrapper.svelte:
--------------------------------------------------------------------------------
1 |
37 |
38 |
39 | {#if showElement}
40 |
{
43 | if (editable) {
44 | showDrag = true;
45 | }
46 | }}
47 | on:mouseleave={() => {
48 | if (menu) {
49 | } else {
50 | showDrag = false;
51 | }
52 | }}
53 | >
54 | {#if !isTextContent}
55 |
56 | {/if}
57 |
58 |
64 |
65 |
66 | {#if showDrag}
67 |
70 |
79 |
80 | {/if}
81 |
82 |
83 | {#if !editable && validation.errorMsg}
84 |
85 | {validation.errorMsg}
86 |
87 | {/if}
88 |
89 | {#if help_html !== undefined}
90 |
91 | {/if}
92 |
93 | {/if}
94 |
95 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Inputs/Menu.svelte:
--------------------------------------------------------------------------------
1 |
13 |
14 |
19 |
{
22 | inline = !inline;
23 | }}
24 | >
25 | Inline
26 |
27 |
28 | {#if required !== undefined}
29 |
{
32 | required = !required;
33 | }}
34 | >
35 |
36 | {label}
37 |
38 |
39 |
40 | {/if}
41 |
42 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Inputs/SideMenu.svelte:
--------------------------------------------------------------------------------
1 |
31 |
32 |
33 |
34 |
35 |
removeInput()}
38 | on:mouseenter={() => (showDelete = true)}
39 | on:mouseleave={() => (showDelete = false)}
40 | >
41 |
42 |
43 | {#if showDelete}
44 |
47 | Delete input
48 |
49 | {/if}
50 |
51 |
52 |
53 |
54 |
(showAdd = true)}
58 | on:mouseleave={() => (showAdd = false)}
59 | >
60 |
61 |
62 | {#if showAdd}
63 |
66 | Add input
67 |
68 | {/if}
69 |
70 |
71 |
72 |
73 |
{
77 | menu = !menu;
78 | showMenu = false;
79 | }}
80 | on:mouseenter={() => {
81 | if (!menu) {
82 | showMenu = true;
83 | }
84 | }}
85 | on:mouseleave={() => (showMenu = false)}
86 | >
87 |
88 |
89 | {#if showMenu}
90 |
93 | Show menu
94 |
95 | {/if}
96 |
97 | {#if menu}
98 |
99 | {/if}
100 |
101 |
102 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Inputs/Switcher.svelte:
--------------------------------------------------------------------------------
1 |
11 |
12 |
28 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Steps/SideStepMenu.svelte:
--------------------------------------------------------------------------------
1 |
19 |
20 |
21 |
22 | {#if numberOfSteps !== 1}
23 |
24 |
(showDelete = true)}
28 | on:mouseleave={() => (showDelete = false)}
29 | >
30 |
31 |
32 | {#if showDelete}
33 |
36 | Delete Step
37 |
38 | {/if}
39 |
40 | {/if}
41 |
42 |
43 |
{
47 | stepMenu = !stepMenu;
48 | showMenu = false;
49 | }}
50 | on:mouseenter={() => {
51 | if (!stepMenu) {
52 | showMenu = true;
53 | }
54 | }}
55 | on:mouseleave={() => (showMenu = false)}
56 | >
57 |
58 |
59 | {#if showMenu}
60 |
63 | Show menu
64 |
65 | {/if}
66 | {#if stepMenu}
67 |
75 | {/if}
76 |
77 |
78 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Steps/StepLine.svelte:
--------------------------------------------------------------------------------
1 |
15 |
16 |
17 |
{
24 | if (editable) {
25 | stepper = true;
26 | }
27 | }}
28 | on:mouseleave={() => {
29 | stepper = false;
30 | }}
31 | >
32 |
33 |
36 |
43 |
44 |
45 |
46 | {#if stepInd == numberOfSteps - 1}
47 |
{
50 | withMessage = !withMessage;
51 | }}
52 | >
53 |
54 | {label}
55 |
56 |
57 |
58 | {/if}
59 |
60 |
61 |
62 |
63 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Steps/StepMenu.svelte:
--------------------------------------------------------------------------------
1 |
21 |
22 | {
26 | stepMenu = false;
27 | }}
28 | >
29 |
30 | {#if numberOfSteps !== 1}
31 |
35 |
36 | delete
37 |
38 | {/if}
39 |
40 |
44 |
45 | duplicate
46 |
47 |
48 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/Steps/StepWrapper.svelte:
--------------------------------------------------------------------------------
1 |
11 |
12 | {
15 | if (editable) {
16 | stepper = true;
17 | }
18 | }}
19 | on:mouseleave={() => {
20 | if (stepMenu) {
21 | stepper = true;
22 | } else {
23 | stepper = false;
24 | }
25 | }}
26 | >
27 |
28 |
29 | {#if stepper && stepInd < numberOfSteps - 1}
30 |
37 |
44 |
45 | {/if}
46 |
47 |
--------------------------------------------------------------------------------
/src/lib/ui/Common/inputs.js:
--------------------------------------------------------------------------------
1 | import TextIcon from "../Icons/TextIcon.svelte"
2 | import TextareaIcon from "../Icons/TextareaIcon.svelte"
3 | import NumberIcon from "../Icons/NumberIcon.svelte"
4 | import EmailIcon from "../Icons/EmailIcon.svelte"
5 | import PasswordIcon from "../Icons/PasswordIcon.svelte"
6 | import DateIcon from "../Icons/DateIcon.svelte"
7 | import TimeIcon from "../Icons/TimeIcon.svelte"
8 | import DateTimeIcon from "../Icons/DateTimeIcon.svelte"
9 | import SelectIcon from "../Icons/SelectIcon.svelte"
10 | import MultichoiceIcon from "../Icons/MultichoiceIcon.svelte"
11 | import RadioIcon from "../Icons/RadioIcon.svelte"
12 | import CheckboxIcon from "../Icons/CheckboxIcon.svelte"
13 | import TextContentIcon from "../Icons/TextContentIcon.svelte"
14 |
15 | const required = false;
16 |
17 | export const textContent = () => ({
18 | label: "Text Content",
19 | type: "TextContent",
20 | props: {
21 | icon: TextContentIcon,
22 | fields: {
23 | arr_content: [
24 | { html: "Text content to update!", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
25 | ],
26 | validation: {
27 |
28 | },
29 | },
30 | }
31 | })
32 |
33 | export default () => [
34 | {
35 | label: "Text Input",
36 | type: "Text", // need to be the same component name
37 | value: "",
38 | props: {
39 | icon: TextIcon,
40 | arr_html: [
41 | { html: "Text", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
42 | ],
43 | help_html: [
44 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
45 | ],
46 | fields: {
47 | placeholder: "",
48 | validation: {
49 | required: required,
50 | },
51 | },
52 | },
53 | },
54 | {
55 | label: "Textarea",
56 | type: "Textarea",
57 | value: "",
58 | props: {
59 | icon: TextareaIcon,
60 | arr_html: [
61 | { html: "Paragraph", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
62 | ],
63 | help_html: [
64 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
65 | ],
66 | fields: {
67 | placeholder: "",
68 | rows: "5",
69 | validation: {
70 | required: required,
71 | },
72 | },
73 | },
74 | },
75 | {
76 | label: "Number",
77 | type: "Number",
78 | value: "",
79 | props: {
80 | icon: NumberIcon,
81 | arr_html: [
82 | { html: "Number", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
83 | ],
84 | help_html: [
85 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
86 | ],
87 | fields: {
88 | placeholder: "",
89 | validation: {
90 | required: required,
91 | },
92 | },
93 | },
94 | },
95 | {
96 | label: "Email",
97 | type: "Email",
98 | value: "",
99 | props: {
100 | icon: EmailIcon,
101 | arr_html: [
102 | { html: "Email", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
103 | ],
104 | help_html: [
105 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
106 | ],
107 | fields: {
108 | placeholder: "",
109 | validation: {
110 | required: required,
111 | },
112 | },
113 | },
114 | },
115 | {
116 | label: "Password",
117 | value: "",
118 | type: "Password",
119 | props: {
120 | icon: PasswordIcon,
121 | arr_html: [
122 | { html: "Password", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
123 | ],
124 | help_html: [
125 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
126 | ],
127 | fields: {
128 | placeholder: "",
129 | validation: {
130 | required: required,
131 | },
132 | },
133 | },
134 | },
135 | {
136 | label: "Date",
137 | type: "Date",
138 | value: "",
139 | props: {
140 | icon: DateIcon,
141 | arr_html: [
142 | { html: "Date", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
143 | ],
144 | help_html: [
145 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
146 | ],
147 | fields: {
148 | placeholder: "",
149 | validation: {
150 | required: required,
151 | },
152 | },
153 | },
154 | },
155 | {
156 | label: "Time",
157 | type: "Time",
158 | value: "",
159 | props: {
160 | icon: TimeIcon,
161 | arr_html: [
162 | { html: "Time", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
163 | ],
164 | help_html: [
165 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
166 | ],
167 | fields: {
168 | placeholder: "",
169 | validation: {
170 | required: required,
171 | },
172 | },
173 | },
174 | },
175 | {
176 | label: "DateTime",
177 | type: "DateTime",
178 | value: "",
179 | props: {
180 | icon: DateTimeIcon,
181 | arr_html: [
182 | { html: "DateTime", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
183 | ],
184 | help_html: [
185 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
186 | ],
187 | fields: {
188 | validation: {
189 | required: required,
190 | },
191 | },
192 | },
193 | },
194 | {
195 | label: "Select",
196 | type: "Select",
197 | value: "",
198 | props: {
199 | icon: SelectIcon,
200 | arr_html: [
201 | { html: "Select", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
202 | ],
203 | help_html: [
204 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
205 | ],
206 |
207 | fields: {
208 | store: [
209 | { option: "" },
210 | ],
211 | validation: {
212 | required: required,
213 | },
214 | },
215 | },
216 | },
217 | {
218 | label: "Multi-choice",
219 | type: "Multichoice",
220 | value: "",
221 | props: {
222 | icon: MultichoiceIcon,
223 | arr_html: [
224 | {
225 | html: "Multichoice",
226 | klass: "md:text-xl text-lg leading-loose md:leading-loose",
227 | },
228 | ],
229 | help_html: [
230 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
231 | ],
232 | fields: {
233 | store: [
234 | { option: "" },
235 | ],
236 | validation: {
237 | required: required,
238 | },
239 | },
240 | },
241 | },
242 | {
243 | label: "Radio",
244 | type: "Radio",
245 | value: "",
246 | props: {
247 | icon: RadioIcon,
248 | arr_html: [
249 | { html: "Radio", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
250 | ],
251 | help_html: [
252 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
253 | ],
254 | fields: {
255 | store:[
256 | { option: "" },
257 | ],
258 | validation: {
259 | required: required,
260 | },
261 | },
262 | },
263 | },
264 | {
265 | label: "CheckBox",
266 | type: "Checkbox",
267 | value: "",
268 | props: {
269 | icon: CheckboxIcon,
270 | arr_html: [
271 | { html: "Checkbox", klass: "md:text-xl text-lg leading-loose md:leading-loose" },
272 | ],
273 | help_html: [
274 | { html: "Help text", klass: "md:text-sm text-sm leading-loose md:leading-loose" },
275 | ],
276 | fields: {
277 | store: [
278 | { option: "" },
279 | ],
280 | validation: {
281 | required: required,
282 | },
283 | },
284 | },
285 | },
286 | ];
287 |
--------------------------------------------------------------------------------
/src/lib/ui/EditorSteps.svelte:
--------------------------------------------------------------------------------
1 |
12 |
13 |
14 |
15 |
16 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/AsteriskIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/CheckboxIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/CloneIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
13 |
14 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/CloseIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
12 |
13 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/DateIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/DateTimeIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/EmailIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/Icon.svelte:
--------------------------------------------------------------------------------
1 |
5 |
6 |
15 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/MenuIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
14 |
15 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/MultichoiceIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/NumberIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/PasswordIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/PlusIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
7 |
8 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/RadioIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/SelectIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/TextContentIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/TextIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
14 |
15 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/TextareaIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/TimeIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
13 |
14 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/TrashIcon.svelte:
--------------------------------------------------------------------------------
1 |
4 |
5 |
6 |
10 |
11 |
--------------------------------------------------------------------------------
/src/lib/ui/Icons/VisiblityIcon.svelte:
--------------------------------------------------------------------------------
1 |
5 |
6 |
7 | {#if visible}
8 |
12 | {:else}
13 |
17 | {/if}
18 |
19 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Checkbox.svelte:
--------------------------------------------------------------------------------
1 |
42 |
43 | {#if editable}
44 |
63 | {
66 | e.key = "Enter";
67 | addOption(e);
68 | }}
69 | >
70 |
71 | Add Option
72 |
73 | {:else}
74 | {#each store as opt}
75 |
86 | {/each}
87 | {/if}
88 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Date.svelte:
--------------------------------------------------------------------------------
1 |
5 |
6 |
7 |
12 |
13 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/DateTime.svelte:
--------------------------------------------------------------------------------
1 |
5 |
6 |
12 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Email.svelte:
--------------------------------------------------------------------------------
1 |
7 |
8 |
9 | {#if editable}
10 |
16 | {:else}
17 |
23 | {/if}
24 |
25 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Multichoice.svelte:
--------------------------------------------------------------------------------
1 |
43 |
44 |
45 | {#if editable}
46 |
47 |
50 |
65 |
{
68 | e.key = "Enter";
69 | addOption(e);
70 | }}
71 | >
72 |
73 | Add Option
74 |
75 |
76 |
77 | {:else}
78 |
87 | {/if}
88 |
89 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Number.svelte:
--------------------------------------------------------------------------------
1 |
7 |
8 |
9 | {#if editable}
10 |
16 | {:else}
17 |
23 | {/if}
24 |
25 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Password.svelte:
--------------------------------------------------------------------------------
1 |
7 |
8 |
9 | {#if editable}
10 |
16 | {:else}
17 |
23 | {/if}
24 |
25 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Radio.svelte:
--------------------------------------------------------------------------------
1 |
43 |
44 |
45 | {#if editable}
46 |
69 |
70 |
{
73 | e.key = "Enter";
74 | addOption(e);
75 | }}
76 | >
77 |
78 | Add Option
79 |
80 | {:else}
81 | {#each store as opt}
82 |
94 | {/each}
95 | {/if}
96 |
97 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Select.svelte:
--------------------------------------------------------------------------------
1 |
42 |
43 |
44 | {#if editable}
45 |
48 |
63 |
{
66 | e.key = "Enter";
67 | addOption(e);
68 | }}
69 | >
70 | Add Option
71 |
72 |
73 | {:else}
74 |
82 | {/if}
83 |
84 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Submit.svelte:
--------------------------------------------------------------------------------
1 |
15 |
16 |
17 | {#if editable}
18 |
19 |
27 | {#if previous}
28 |
32 |
33 |
34 | {/if}
35 |
36 | {:else if !previous || !noPrevious}
37 |
42 | {label}
43 |
44 | {/if}
45 |
46 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Text.svelte:
--------------------------------------------------------------------------------
1 |
8 |
9 |
10 | {#if editable}
11 |
18 | {:else}
19 |
26 | {/if}
27 |
28 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/TextContent.svelte:
--------------------------------------------------------------------------------
1 |
7 |
8 |
9 |
10 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Textarea.svelte:
--------------------------------------------------------------------------------
1 |
8 |
9 |
10 | {#if editable}
11 |
17 | {:else}
18 |
25 | {/if}
26 |
27 |
--------------------------------------------------------------------------------
/src/lib/ui/InputTypes/Time.svelte:
--------------------------------------------------------------------------------
1 |
5 |
6 |
7 |
12 |
13 |
--------------------------------------------------------------------------------
/src/lib/ui/ListInputs.svelte:
--------------------------------------------------------------------------------
1 |
12 |
13 |
14 |
15 | choose content
16 |
17 |
18 |
19 |
20 |
select(textContent())}
23 | >
24 |
25 |
{textContent().label}
26 |
27 |
28 |
29 | {#each basicInputs as input}
30 |
select(input)}
33 | >
34 | {#if input?.props?.icon}
35 |
36 | {/if}
37 |
38 | {input.label}
39 |
40 |
41 | {/each}
42 |
43 |
44 |
--------------------------------------------------------------------------------
/src/lib/ui/Modal.svelte:
--------------------------------------------------------------------------------
1 |
13 |
14 |
15 | {#if show}
16 |
20 |
25 |
29 |
30 |
31 |
32 |
33 |
34 |
35 |
36 |
37 | {/if}
38 |
39 |
--------------------------------------------------------------------------------
/src/lib/utils/clickOutside.js:
--------------------------------------------------------------------------------
1 | /** Dispatch event on click outside of node */
2 | export function clickOutside(node) {
3 |
4 | const handleClick = event => {
5 | const dname = event?.path?.[0]?.dataset.name || event?.path?.[1]?.dataset.name
6 |
7 | if(dname === "showMenu") return
8 | if (node && !node.contains(event.target) && !event.defaultPrevented) {
9 | node.dispatchEvent(
10 | new CustomEvent('click_outside', node)
11 | )
12 | }
13 | }
14 |
15 | document.addEventListener('click', handleClick, true);
16 |
17 | return {
18 | destroy() {
19 | document.removeEventListener('click', handleClick, true);
20 | }
21 | }
22 | }
--------------------------------------------------------------------------------
/src/lib/utils/cmpsRegistry.js:
--------------------------------------------------------------------------------
1 | import Radio from "../ui/InputTypes/Radio.svelte";
2 | import Select from "../ui/InputTypes/Select.svelte";
3 | import Multichoice from "../ui/InputTypes/Multichoice.svelte";
4 | import Text from "../ui/InputTypes/Text.svelte";
5 | import Textarea from "../ui/InputTypes/Textarea.svelte";
6 | import Submit from "../ui/InputTypes/Submit.svelte";
7 | import Checkbox from "../ui/InputTypes/CheckBox.svelte";
8 | import Password from "../ui/InputTypes/Password.svelte";
9 | import Date from "../ui/InputTypes/Date.svelte";
10 | import DateTime from "../ui/InputTypes/DateTime.svelte";
11 | import Email from "../ui/InputTypes/Email.svelte";
12 | import Number from "../ui/InputTypes/Number.svelte";
13 | import Time from "../ui/InputTypes/Time.svelte";
14 | import TextContent from "../ui/InputTypes/TextContent.svelte";
15 |
16 | export default {
17 | Radio,
18 | Select,
19 | Multichoice,
20 | Text,
21 | Textarea,
22 | Submit,
23 | Checkbox,
24 | Password,
25 | Date,
26 | DateTime,
27 | Email,
28 | Number,
29 | Time,
30 | TextContent
31 | };
32 |
--------------------------------------------------------------------------------
/src/lib/utils/random.js:
--------------------------------------------------------------------------------
1 | export function randomString() {
2 | return (Math.random() + 1).toString(36).substring(2);
3 | }
--------------------------------------------------------------------------------
/src/lib/utils/store.js:
--------------------------------------------------------------------------------
1 | import { writable } from "svelte/store"
2 |
3 |
4 | function fromLS(key){
5 | let lstore = localStorage.getItem(key)
6 | if(lstore){
7 | return JSON.parse(lstore)
8 | }
9 | }
10 |
11 | export function createPersistedStore(key){
12 | const { subscribe, set, update } = writable(fromLS(key))
13 |
14 | return {
15 | get() {
16 | return fromLS(key)
17 | },
18 | subscribe,
19 | set: (payload) => {
20 | set(payload)
21 | localStorage.setItem(key, JSON.stringify(payload))
22 | },
23 | update: (payload) => update((store) => ({ ...store, ...payload })),
24 | clear(){
25 | this.set(undefined)
26 | localStorage.removeItem(key)
27 | }
28 | }
29 | }
30 |
31 |
32 | export const formStore = createPersistedStore('ft/form/store')
--------------------------------------------------------------------------------
/src/lib/utils/util.js:
--------------------------------------------------------------------------------
1 | export default {
2 | clone(obj) {
3 | if(!obj) return
4 | return JSON.parse(JSON.stringify(obj))
5 | }
6 | }
--------------------------------------------------------------------------------
/src/main.js:
--------------------------------------------------------------------------------
1 | import App from './App.svelte';
2 |
3 | export default App
4 |
5 |
--------------------------------------------------------------------------------
/tailwind.config.js:
--------------------------------------------------------------------------------
1 | module.exports = {
2 | darkMode: 'class',
3 | important: ".ft",
4 | content: ["./src/**/*.{html,js,svelte}","node_modules/form-builder/**/*.svelte"],
5 | safelist: [
6 | {
7 | pattern: /^w-1\/(\d+)$/,
8 | variants: ['sm']
9 | },
10 | {
11 | pattern: /justify-(\w+)$/
12 | },
13 | {
14 | pattern: /items-(\w+)$/
15 | },
16 | {
17 | pattern: /text-(left|right|center|justify)$/
18 | },
19 | {
20 | pattern: /text-(left|right|center|justify)$/
21 | },
22 | {
23 | pattern: /(bg|text)-(gray|red|yellow|green|blue|indigo|purple|pink)-(\d{1}0{1,2})$/,
24 | },
25 | {
26 | pattern: /leading-(\w+)$/,
27 | },
28 | {
29 | pattern: /-?(m|p)[tlrb]?-(0|px|0.5|1|2|3|4|5|10|16|20|40|60)$/,
30 | },
31 | {
32 | pattern: /(w|h)-(auto|full|0|3|4|10|16|20|32|40|60|80|96|128)$/,
33 | },
34 | {
35 | pattern: /rounded-(\w+)$/,
36 | },
37 | {
38 | pattern: /max-w-(\w+)$/,
39 | },
40 |
41 | ],
42 | theme: {
43 | extend: {
44 | fontFamily: {
45 | sans: ['Inter', '-apple-system', 'BlinkMacSystemFont', '"Segoe UI"', 'Roboto', 'Oxygen-Sans', 'Ubuntu', 'Cantarell',
46 | '"Helvetica Neue"', 'Helvetica', 'Arial', '"Apple Color Emoji"', '"Segoe UI Emoji"', '"Segoe UI Symbol"', 'sans-serif'],
47 | },
48 | "colors": {
49 | "primary": "rgb(var(--ft-primary,59 130 246) / )",
50 | "secondary": "rgb(var(--ft-secondary,251 113 133) / )",
51 | "tertiary": "rgb(var(--ft-tertiary,31 41 55) / )",
52 | "quaternary": "rgb(var(--ft-quaternary,250 204 21) / )",
53 | "transparent": "transparent",
54 | "current": "currentColor"
55 | },
56 | lineHeight: {
57 | 3: '12px',
58 | 4: '16px',
59 | 5: '20px',
60 | 6: '24px',
61 | 7: '28px',
62 | 8: '32px',
63 | 9: '36px',
64 | 10: '40px',
65 | },
66 | },
67 | fontSize: {
68 | xs: '12px',
69 | sm: '14px',
70 | base: '16px',
71 | lg: '18px',
72 | xl: '20px',
73 | '2xl': '24px',
74 | '3xl': '30px',
75 | '4xl': '36px',
76 | '5xl': '48px',
77 | '6xl': '60px',
78 | '7xl': '72px',
79 | },
80 | spacing: {
81 | px: '1px',
82 | 0: '0',
83 | 0.5: '2px',
84 | 1: '4px',
85 | 1.5: '6px',
86 | 2: '8px',
87 | 2.5: '10px',
88 | 3: '12px',
89 | 3.5: '14px',
90 | 4: '16px',
91 | 5: '20px',
92 | 6: '24px',
93 | 7: '28px',
94 | 8: '32px',
95 | 9: '36px',
96 | 10: '40px',
97 | 11: '44px',
98 | 12: '48px',
99 | 14: '56px',
100 | 16: '64px',
101 | 20: '80px',
102 | 24: '96px',
103 | 28: '112px',
104 | 32: '128px',
105 | 36: '144px',
106 | 40: '160px',
107 | 44: '176px',
108 | 48: '192px',
109 | 52: '208px',
110 | 56: '224px',
111 | 60: '240px',
112 | 64: '256px',
113 | 72: '288px',
114 | 80: '320px',
115 | 96: '384px',
116 | 128: '512px',
117 | }
118 | },
119 | plugins: [
120 | require('@tailwindcss/forms')({
121 | // strategy: 'base', // only generate global styles
122 | strategy: 'class', // only generate classes
123 | }),
124 | ],
125 | }
126 |
--------------------------------------------------------------------------------
/vite.config.js:
--------------------------------------------------------------------------------
1 | import path from "path"
2 | import { defineConfig } from 'vite'
3 | import { svelte } from '@sveltejs/vite-plugin-svelte'
4 | import cssInjectedByJsPlugin from "vite-plugin-css-injected-by-js";
5 |
6 |
7 | // https://vitejs.dev/config/
8 | export default defineConfig({
9 | plugins: [svelte({
10 | emitCss: false,
11 | onwarn: (warning, handler) => {
12 | if (warning.code.startsWith('a11y-')) {
13 | return;
14 | }
15 | handler(warning);
16 | },
17 | }), cssInjectedByJsPlugin()],
18 | build: {
19 | lib: {
20 | entry: path.resolve(__dirname, 'src/main.js'),
21 | name: 'FormEditor',
22 | fileName: (format) => `form-editor.${format}.js`
23 | },
24 | rollupOptions: {
25 | output: {
26 | manualChunks: undefined,
27 | },
28 | },
29 | }
30 | })
31 |
--------------------------------------------------------------------------------