diff --git a/docs/styleGuide.md b/docs/styleGuide.md index e39bd0febf..77f5fb0363 100644 --- a/docs/styleGuide.md +++ b/docs/styleGuide.md @@ -5,7 +5,8 @@ #### Component 1. Must be written following the kebab-case style; -1. Must be prefixed with `kup-`. +2. Must be prefixed with `kup-`. +3. Being a web component, it must include a Shadow DOM. #### Interfaces and enums diff --git a/packages/ketchup-react/package.json b/packages/ketchup-react/package.json index b3e2a9eea4..0f8f335f4d 100644 --- a/packages/ketchup-react/package.json +++ b/packages/ketchup-react/package.json @@ -1,6 +1,6 @@ { "name": "@sme.up/ketchup-react", - "version": "9.5.2", + "version": "9.6.0", "module": "dist/index.js", "typings": "dist/index.d.ts", "keywords": [ @@ -20,7 +20,7 @@ "description": "Ketchup React Components library by smeup", "license": "Apache-2.0", "dependencies": { - "@sme.up/ketchup": "^9.5.2", + "@sme.up/ketchup": "^9.6.0", "react": "^18.2.0", "react-dom": "^18.2.0" }, diff --git a/packages/ketchup-react/src/index.ts b/packages/ketchup-react/src/index.ts index 6a3c61ecac..f6b43e3781 100644 --- a/packages/ketchup-react/src/index.ts +++ b/packages/ketchup-react/src/index.ts @@ -32,6 +32,7 @@ export const KupDialog = /*@__PURE__*/createReactComponent('kup-drawer'); export const KupDropdownButton = /*@__PURE__*/createReactComponent('kup-dropdown-button'); export const KupEchart = /*@__PURE__*/createReactComponent('kup-echart'); +export const KupEditor = /*@__PURE__*/createReactComponent('kup-editor'); export const KupFamilyTree = /*@__PURE__*/createReactComponent('kup-family-tree'); export const KupForm = /*@__PURE__*/createReactComponent('kup-form'); export const KupGantt = /*@__PURE__*/createReactComponent('kup-gantt'); diff --git a/packages/ketchup-showcase/package.json b/packages/ketchup-showcase/package.json index 5d804ef8c3..bc47af9998 100644 --- a/packages/ketchup-showcase/package.json +++ b/packages/ketchup-showcase/package.json @@ -19,7 +19,7 @@ "lint": "vue-cli-service lint" }, "dependencies": { - "@sme.up/ketchup": "^9.5.2", + "@sme.up/ketchup": "^9.6.0", "core-js": "^3.30.2", "vue": "^2.6.14", "vue-router": "^3.5.1" diff --git a/packages/ketchup-showcase/src/App.vue b/packages/ketchup-showcase/src/App.vue index 9a504e9324..3b927f6637 100644 --- a/packages/ketchup-showcase/src/App.vue +++ b/packages/ketchup-showcase/src/App.vue @@ -55,8 +55,8 @@ @kup-tree-nodeselected="treeClick" > @@ -365,6 +365,16 @@ export default { value: 'EChart', visible: true, }, + { + cells: { + ROUTE: { + value: 'editor', + }, + }, + icon: 'mode_edit', + value: 'Editor', + visible: true, + }, { cells: { ROUTE: { diff --git a/packages/ketchup-showcase/src/plugins/router.ts b/packages/ketchup-showcase/src/plugins/router.ts index 89863225f6..cf18903b04 100644 --- a/packages/ketchup-showcase/src/plugins/router.ts +++ b/packages/ketchup-showcase/src/plugins/router.ts @@ -250,6 +250,11 @@ const advancedRoutes = [ name: 'planner', component: () => import(`@/views/components/advanced/planner/Planner.vue`), }, + { + path: `/editor`, + name: 'editor', + component: () => import(`@/views/components/advanced/editor/Editor.vue`), + }, ]; const thirdPartiesRoutes = [ diff --git a/packages/ketchup-showcase/src/views/components/advanced/editor/Editor.vue b/packages/ketchup-showcase/src/views/components/advanced/editor/Editor.vue new file mode 100644 index 0000000000..e85450c3e1 --- /dev/null +++ b/packages/ketchup-showcase/src/views/components/advanced/editor/Editor.vue @@ -0,0 +1,36 @@ + + + diff --git a/packages/ketchup-showcase/src/views/components/advanced/editor/examples/EditorBasic.vue b/packages/ketchup-showcase/src/views/components/advanced/editor/examples/EditorBasic.vue new file mode 100644 index 0000000000..7e43f8f29c --- /dev/null +++ b/packages/ketchup-showcase/src/views/components/advanced/editor/examples/EditorBasic.vue @@ -0,0 +1,26 @@ + + + diff --git a/packages/ketchup-showcase/src/views/components/advanced/editor/examples/EditorDemo.vue b/packages/ketchup-showcase/src/views/components/advanced/editor/examples/EditorDemo.vue new file mode 100644 index 0000000000..f3265cf1d5 --- /dev/null +++ b/packages/ketchup-showcase/src/views/components/advanced/editor/examples/EditorDemo.vue @@ -0,0 +1,170 @@ + + + diff --git a/packages/ketchup/package.json b/packages/ketchup/package.json index 08bdd9b327..83e2dd2955 100644 --- a/packages/ketchup/package.json +++ b/packages/ketchup/package.json @@ -1,6 +1,6 @@ { "name": "@sme.up/ketchup", - "version": "9.5.2", + "version": "9.6.0", "keywords": [ "smeup", "KetchUP", @@ -46,6 +46,7 @@ "@material/form-field": "^14.0.0", "@material/ripple": "^14.0.0", "@material/textfield": "^14.0.0", + "@toast-ui/editor": "^2.5.4", "d3-shape": "^3.2.0", "dayjs": "^1.11.7", "echarts": "^5.4.2", @@ -58,9 +59,9 @@ "vanilla-picker": "^2.12.1" }, "devDependencies": { - "@stencil/core": "^4.8.1", + "@stencil/core": "^4.12.0", "@stencil/react-output-target": "0.5.3", - "@stencil/sass": "^3.0.7", + "@stencil/sass": "^3.0.9", "jest": "^29.7.0", "jest-cli": "^29.7.0", "jest-html-reporter": "^3.10.2", diff --git a/packages/ketchup/src/assets/editor-example-1.js b/packages/ketchup/src/assets/editor-example-1.js new file mode 100644 index 0000000000..26244c13d6 --- /dev/null +++ b/packages/ketchup/src/assets/editor-example-1.js @@ -0,0 +1,52 @@ +let comp = document.getElementById('editor-html'); + +comp.addEventListener('kup-editor-autosave', (e) => { + console.log('kup-editor-autosave (html) ' + new Date().toISOString(), e); +}); + +let props = { + customStyle: '', + editorHeight: '400px', + initialEditType: 'wysiwyg', + initialValue: + '
prova prova 123456 56

e vado a capo

ancora

e ancora
', + isReadOnly: false, + previewStyle: 'tab', + showSaveButton: true, + showToolbar: true, + autosaveTimer: 5000, +}; + +if (props) { + for (const key in props) { + comp[key] = props[key]; + } +} + +comp = document.getElementById('editor-markdown'); + +comp.addEventListener('kup-editor-autosave', (e) => { + console.log( + 'kup-editor-autosave (markdown) ' + new Date().toISOString(), + e + ); +}); + +props = { + customStyle: '', + initialEditType: 'markdown', + initialValue: '# title 1 \n ## title2', + isReadOnly: false, + previewStyle: 'tab', + showSaveButton: false, + showToolbar: true, + autosaveTimer: 5000, +}; + +comp.style = '--kup-editor-height: 300px;'; + +if (props) { + for (const key in props) { + comp[key] = props[key]; + } +} diff --git a/packages/ketchup/src/assets/editor.js b/packages/ketchup/src/assets/editor.js new file mode 100644 index 0000000000..dc61c5ec1a --- /dev/null +++ b/packages/ketchup/src/assets/editor.js @@ -0,0 +1,60 @@ +const comp = document.getElementById('editor'); + +comp.addEventListener('kup-editor-ready', (e) => { + console.log('Editor ready', e); +}); + +comp.addEventListener('kup-editor-save', (e) => { + console.log('Editor saved', e); +}); + +comp.addEventListener('kup-editor-autosave', (e) => { + console.log('Editor auto saved', e); +}); + +const props = { + initialEditType: 'markdown', + initialValue: `

image

+

Awesome Editor!

+

It has been released as opensource in 2018 and has continually evolved to receive 10k GitHub ⭐️ Stars.

+

Create Instance

+

You can create an instance with the following code and use getHtml() and getMarkdown() of the Editor.

+
co
+
+    > See the table below for default options
+    > > More API information can be found in the document
+
+    | name | type | description |
+    | --- | --- | --- |
+    | el | HTMLElement | container element |
+
+    ## Featuress
+
+    * CommonMark + GFM Specifications
+       * Live Preview
+       * Scroll Sync
+       * Auto Indent
+       * Syntax Highlight
+            1. Markdown
+            2. Preview
+
+    ## Support Wrappers
+
+    > * Wrappers
+    >    1. [x] React
+    >    2. [x] Vue
+    >    3. [ ] Ember<p>My Custom value for editor</p>
+    
+ `, + isReadOnly: false, + previewStyle: 'vertical', + showSaveButton: true, + showToolbar: true, + // autosaveTimer: 2000 +}; + +if (props) { + for (const key in props) { + comp[key] = props[key]; + } +} diff --git a/packages/ketchup/src/assets/index.js b/packages/ketchup/src/assets/index.js index dbc1ef0de2..c142015c46 100644 --- a/packages/ketchup/src/assets/index.js +++ b/packages/ketchup/src/assets/index.js @@ -102,6 +102,14 @@ components.data = [ value: 'Echart', id: 'echart.html', }, + { + value: 'Editor', + id: 'editor.html', + }, + { + value: 'Editor example 1', + id: 'editor-example-1.html', + }, { value: 'Family tree', id: 'family-tree.html', diff --git a/packages/ketchup/src/components.d.ts b/packages/ketchup/src/components.d.ts index 0054222bb0..39deb1b65e 100644 --- a/packages/ketchup/src/components.d.ts +++ b/packages/ketchup/src/components.d.ts @@ -35,6 +35,7 @@ import { KupDropdownButtonEventPayload } from "./components/kup-dropdown-button/ import { KupEchartClickEventPayload, KupEchartLegendPlacement, KupEchartMaps, KupEchartTitle, KupEchartTypes } from "./components/kup-echart/kup-echart-declarations"; import { GeoJSON } from "geojson"; import { XAXisComponentOption, YAXisComponentOption } from "echarts"; +import { KupEditorEventPayload, KupEditorPreview, KupEditorType } from "./components/kup-editor/kup-editor-declarations"; import { KupFamilyTreeData, KupFamilyTreeEventPayload, KupFamilyTreeLayout, KupFamilyTreeNode } from "./components/kup-family-tree/kup-family-tree-declarations"; import { KupFormData, KupFormLabelPlacement, KupFormLayout } from "./components/kup-form/kup-form-declarations"; import { KupBadge } from "./components/kup-badge/kup-badge"; @@ -83,6 +84,7 @@ export { KupDropdownButtonEventPayload } from "./components/kup-dropdown-button/ export { KupEchartClickEventPayload, KupEchartLegendPlacement, KupEchartMaps, KupEchartTitle, KupEchartTypes } from "./components/kup-echart/kup-echart-declarations"; export { GeoJSON } from "geojson"; export { XAXisComponentOption, YAXisComponentOption } from "echarts"; +export { KupEditorEventPayload, KupEditorPreview, KupEditorType } from "./components/kup-editor/kup-editor-declarations"; export { KupFamilyTreeData, KupFamilyTreeEventPayload, KupFamilyTreeLayout, KupFamilyTreeNode } from "./components/kup-family-tree/kup-family-tree-declarations"; export { KupFormData, KupFormLabelPlacement, KupFormLayout } from "./components/kup-form/kup-form-declarations"; export { KupBadge } from "./components/kup-badge/kup-badge"; @@ -1832,6 +1834,71 @@ export namespace Components { */ "yAxis": YAXisComponentOption; } + interface KupEditor { + /** + * When specified, the component will emit the kup-editor-autosave event at regular intervals. + * @default null + */ + "autosaveTimer": number; + /** + * Sets the height of the component. + * @default "auto" + */ + "editorHeight": string; + /** + * Used to retrieve component's props values. + * @param descriptions - When provided and true, the result will be the list of props with their description. + * @returns List of props as object, each key will be a prop. + */ + "getProps": (descriptions?: boolean) => Promise; + /** + * Returns the component's internal value as html. + */ + "getValueAsHTML": () => Promise; + /** + * Returns the component's internal value as markdown. + */ + "getValueAsMarkdown": () => Promise; + /** + * The editor type. + * @default 'markdown' + */ + "initialEditType": KupEditorType; + /** + * The initial editor value. + * @default '' + */ + "initialValue": string; + /** + * Defines whether the editor is disabled or not. + * @default false + */ + "isReadOnly": boolean; + /** + * The editor preview style. + * @default 'vertical' + */ + "previewStyle": KupEditorPreview; + /** + * This method is used to trigger a new render of the component. + */ + "refresh": () => Promise; + /** + * Sets the props to the component. + * @param props - Object containing props that will be set to the component. + */ + "setProps": (props: GenericObject) => Promise; + /** + * Defines whether to show the save button in editor's toolbar or not. + * @default true + */ + "showSaveButton": boolean; + /** + * Defines whether to show the editor's toolbar or not. + * @default true + */ + "showToolbar": boolean; + } interface KupFamilyTree { /** * The component will autofit everytime a node is expanded. @@ -2212,7 +2279,7 @@ export namespace Components { "rtl": boolean; "scrollNumber": number; "svgWidth": number; - "taskGanttRef": HTMLDivElement; + "taskListTrueRef": HTMLKupTaskListElement; "taskListWidth": number; } interface KupIframe { @@ -3873,6 +3940,10 @@ export interface KupEchartCustomEvent extends CustomEvent { detail: T; target: HTMLKupEchartElement; } +export interface KupEditorCustomEvent extends CustomEvent { + detail: T; + target: HTMLKupEditorElement; +} export interface KupFamilyTreeCustomEvent extends CustomEvent { detail: T; target: HTMLKupFamilyTreeElement; @@ -4392,6 +4463,25 @@ declare global { prototype: HTMLKupEchartElement; new (): HTMLKupEchartElement; }; + interface HTMLKupEditorElementEventMap { + "kup-editor-autosave": KupEditorEventPayload; + "kup-editor-ready": KupEventPayload; + "kup-editor-save": KupEditorEventPayload; + } + interface HTMLKupEditorElement extends Components.KupEditor, HTMLStencilElement { + addEventListener(type: K, listener: (this: HTMLKupEditorElement, ev: KupEditorCustomEvent) => any, options?: boolean | AddEventListenerOptions): void; + addEventListener(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void; + addEventListener(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void; + addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void; + removeEventListener(type: K, listener: (this: HTMLKupEditorElement, ev: KupEditorCustomEvent) => any, options?: boolean | EventListenerOptions): void; + removeEventListener(type: K, listener: (this: Document, ev: DocumentEventMap[K]) => any, options?: boolean | EventListenerOptions): void; + removeEventListener(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void; + removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void; + } + var HTMLKupEditorElement: { + prototype: HTMLKupEditorElement; + new (): HTMLKupEditorElement; + }; interface HTMLKupFamilyTreeElementEventMap { "kup-familytree-click": KupFamilyTreeEventPayload; "kup-familytree-contextmenu": KupFamilyTreeEventPayload; @@ -4926,6 +5016,7 @@ declare global { "kup-drawer": HTMLKupDrawerElement; "kup-dropdown-button": HTMLKupDropdownButtonElement; "kup-echart": HTMLKupEchartElement; + "kup-editor": HTMLKupEditorElement; "kup-family-tree": HTMLKupFamilyTreeElement; "kup-form": HTMLKupFormElement; "kup-gantt": HTMLKupGanttElement; @@ -6400,6 +6491,60 @@ declare namespace LocalJSX { */ "yAxis"?: YAXisComponentOption; } + interface KupEditor { + /** + * When specified, the component will emit the kup-editor-autosave event at regular intervals. + * @default null + */ + "autosaveTimer"?: number; + /** + * Sets the height of the component. + * @default "auto" + */ + "editorHeight"?: string; + /** + * The editor type. + * @default 'markdown' + */ + "initialEditType"?: KupEditorType; + /** + * The initial editor value. + * @default '' + */ + "initialValue"?: string; + /** + * Defines whether the editor is disabled or not. + * @default false + */ + "isReadOnly"?: boolean; + /** + * Triggered at regular intervals if autosaveTimer prop is initialised. + */ + "onKup-editor-autosave"?: (event: KupEditorCustomEvent) => void; + /** + * Triggered when the component is ready. + */ + "onKup-editor-ready"?: (event: KupEditorCustomEvent) => void; + /** + * Triggered when save button is clicked. + */ + "onKup-editor-save"?: (event: KupEditorCustomEvent) => void; + /** + * The editor preview style. + * @default 'vertical' + */ + "previewStyle"?: KupEditorPreview; + /** + * Defines whether to show the save button in editor's toolbar or not. + * @default true + */ + "showSaveButton"?: boolean; + /** + * Defines whether to show the editor's toolbar or not. + * @default true + */ + "showToolbar"?: boolean; + } interface KupFamilyTree { /** * The component will autofit everytime a node is expanded. @@ -6709,7 +6854,7 @@ declare namespace LocalJSX { "rtl"?: boolean; "scrollNumber"?: number; "svgWidth"?: number; - "taskGanttRef"?: HTMLDivElement; + "taskListTrueRef"?: HTMLKupTaskListElement; "taskListWidth"?: number; } interface KupIframe { @@ -8065,6 +8210,7 @@ declare namespace LocalJSX { "kup-drawer": KupDrawer; "kup-dropdown-button": KupDropdownButton; "kup-echart": KupEchart; + "kup-editor": KupEditor; "kup-family-tree": KupFamilyTree; "kup-form": KupForm; "kup-gantt": KupGantt; @@ -8134,6 +8280,7 @@ declare module "@stencil/core" { "kup-drawer": LocalJSX.KupDrawer & JSXBase.HTMLAttributes; "kup-dropdown-button": LocalJSX.KupDropdownButton & JSXBase.HTMLAttributes; "kup-echart": LocalJSX.KupEchart & JSXBase.HTMLAttributes; + "kup-editor": LocalJSX.KupEditor & JSXBase.HTMLAttributes; "kup-family-tree": LocalJSX.KupFamilyTree & JSXBase.HTMLAttributes; "kup-form": LocalJSX.KupForm & JSXBase.HTMLAttributes; "kup-gantt": LocalJSX.KupGantt & JSXBase.HTMLAttributes; diff --git a/packages/ketchup/src/components/kup-accordion/readme.md b/packages/ketchup/src/components/kup-accordion/readme.md index df465069f8..983dfff953 100644 --- a/packages/ketchup/src/components/kup-accordion/readme.md +++ b/packages/ketchup/src/components/kup-accordion/readme.md @@ -45,6 +45,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -65,6 +71,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -75,6 +87,12 @@ Type: `Promise` This method activates or deactivates an item +#### Parameters + +| Name | Type | Description | +| ---------- | -------- | ------------------- | +| `itemName` | `string` | - Name of the item. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-autocomplete/readme.md b/packages/ketchup/src/components/kup-autocomplete/readme.md index 140594c5c4..3f5eb0bddc 100644 --- a/packages/ketchup/src/components/kup-autocomplete/readme.md +++ b/packages/ketchup/src/components/kup-autocomplete/readme.md @@ -39,6 +39,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -79,6 +85,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -89,6 +101,12 @@ Type: `Promise` Sets the value of the component. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ------------------------- | +| `value` | `string` | - Value of the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-badge/readme.md b/packages/ketchup/src/components/kup-badge/readme.md index c2a5e81044..3ead4cc4ee 100644 --- a/packages/ketchup/src/components/kup-badge/readme.md +++ b/packages/ketchup/src/components/kup-badge/readme.md @@ -25,6 +25,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -45,6 +51,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-box/readme.md b/packages/ketchup/src/components/kup-box/readme.md index dc45af5bdc..41a595f7ab 100644 --- a/packages/ketchup/src/components/kup-box/readme.md +++ b/packages/ketchup/src/components/kup-box/readme.md @@ -56,6 +56,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -66,6 +72,13 @@ List of props as object, each key will be a prop. +#### Parameters + +| Name | Type | Description | +| --------- | -------------------- | ----------- | +| `row` | `KupBoxRow` | | +| `actions` | `KupDataRowAction[]` | | + #### Returns Type: `Promise` @@ -86,6 +99,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-box/styles/kup-box-main.scss b/packages/ketchup/src/components/kup-box/styles/kup-box-main.scss index 40c17c838d..70f6d8fc40 100644 --- a/packages/ketchup/src/components/kup-box/styles/kup-box-main.scss +++ b/packages/ketchup/src/components/kup-box/styles/kup-box-main.scss @@ -61,7 +61,7 @@ } } - * { + *:not(.progress-bar-percentage) { box-sizing: border-box; } diff --git a/packages/ketchup/src/components/kup-button-list/readme.md b/packages/ketchup/src/components/kup-button-list/readme.md index 0fea5ee6dc..3f6445bd6d 100644 --- a/packages/ketchup/src/components/kup-button-list/readme.md +++ b/packages/ketchup/src/components/kup-button-list/readme.md @@ -32,6 +32,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -52,6 +58,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-button/readme.md b/packages/ketchup/src/components/kup-button/readme.md index 6d3f8185ef..075e9e128a 100644 --- a/packages/ketchup/src/components/kup-button/readme.md +++ b/packages/ketchup/src/components/kup-button/readme.md @@ -35,6 +35,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -55,6 +61,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-calendar/readme.md b/packages/ketchup/src/components/kup-calendar/readme.md index 2ba1558836..85221c0dce 100644 --- a/packages/ketchup/src/components/kup-calendar/readme.md +++ b/packages/ketchup/src/components/kup-calendar/readme.md @@ -33,6 +33,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -63,6 +69,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-card-list/readme.md b/packages/ketchup/src/components/kup-card-list/readme.md index 5f516c8732..a416a6ea30 100644 --- a/packages/ketchup/src/components/kup-card-list/readme.md +++ b/packages/ketchup/src/components/kup-card-list/readme.md @@ -38,6 +38,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -58,6 +64,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-card/readme.md b/packages/ketchup/src/components/kup-card/readme.md index cbd3ed9a71..2222af06e7 100644 --- a/packages/ketchup/src/components/kup-card/readme.md +++ b/packages/ketchup/src/components/kup-card/readme.md @@ -33,6 +33,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -63,6 +69,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -106,6 +118,7 @@ Type: `Promise` - [kup-drawer](../kup-drawer) - [kup-dropdown-button](../kup-dropdown-button) - [kup-echart](../kup-echart) + - [kup-editor](../kup-editor) - [kup-family-tree](../kup-family-tree) - [kup-form](../kup-form) - [kup-gauge](../kup-gauge) @@ -199,6 +212,7 @@ graph TD; kup-dashboard --> kup-card kup-drawer --> kup-card kup-echart --> kup-card + kup-editor --> kup-card kup-family-tree --> kup-card kup-grid --> kup-card kup-iframe --> kup-card diff --git a/packages/ketchup/src/components/kup-cell/readme.md b/packages/ketchup/src/components/kup-cell/readme.md index ff4395117e..ef0ee0eee8 100644 --- a/packages/ketchup/src/components/kup-cell/readme.md +++ b/packages/ketchup/src/components/kup-cell/readme.md @@ -21,6 +21,12 @@ Adds the given CSS classes to the cell's data. +#### Parameters + +| Name | Type | Description | +| --------- | ---------- | ----------------------- | +| `classes` | `string[]` | - Array of CSS classes. | + #### Returns Type: `Promise` @@ -31,6 +37,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -51,6 +63,12 @@ Type: `Promise` Removes the given CSS classes from the cell's data. +#### Parameters + +| Name | Type | Description | +| --------- | ---------- | ----------------------- | +| `classes` | `string[]` | - Array of CSS classes. | + #### Returns Type: `Promise` @@ -61,6 +79,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-chart/readme.md b/packages/ketchup/src/components/kup-chart/readme.md index a380a395ae..9bbad25441 100644 --- a/packages/ketchup/src/components/kup-chart/readme.md +++ b/packages/ketchup/src/components/kup-chart/readme.md @@ -43,6 +43,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -73,6 +79,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-checkbox/readme.md b/packages/ketchup/src/components/kup-checkbox/readme.md index f3f2892868..835977965a 100644 --- a/packages/ketchup/src/components/kup-checkbox/readme.md +++ b/packages/ketchup/src/components/kup-checkbox/readme.md @@ -35,6 +35,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -55,6 +61,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-chip/readme.md b/packages/ketchup/src/components/kup-chip/readme.md index 916d9f25fd..27cf264aaf 100644 --- a/packages/ketchup/src/components/kup-chip/readme.md +++ b/packages/ketchup/src/components/kup-chip/readme.md @@ -31,6 +31,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -51,6 +57,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-color-picker/readme.md b/packages/ketchup/src/components/kup-color-picker/readme.md index fdea59c924..66e98d7dbe 100644 --- a/packages/ketchup/src/components/kup-color-picker/readme.md +++ b/packages/ketchup/src/components/kup-color-picker/readme.md @@ -29,6 +29,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -69,6 +75,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -79,6 +91,12 @@ Type: `Promise` Sets the component's value. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ------------------ | +| `value` | `string` | - Value to be set. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-combobox/readme.md b/packages/ketchup/src/components/kup-combobox/readme.md index 2c0a7256f1..51caba25fc 100644 --- a/packages/ketchup/src/components/kup-combobox/readme.md +++ b/packages/ketchup/src/components/kup-combobox/readme.md @@ -36,6 +36,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -76,6 +82,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -86,6 +98,12 @@ Type: `Promise` Sets the component's value. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ------------------ | +| `value` | `string` | - Value to be set. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-dashboard/readme.md b/packages/ketchup/src/components/kup-dashboard/readme.md index 67ab6a91b4..2055c88623 100644 --- a/packages/ketchup/src/components/kup-dashboard/readme.md +++ b/packages/ketchup/src/components/kup-dashboard/readme.md @@ -25,6 +25,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -45,6 +51,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-data-table/kup-data-table.tsx b/packages/ketchup/src/components/kup-data-table/kup-data-table.tsx index b5938bd8e8..5559887b9a 100644 --- a/packages/ketchup/src/components/kup-data-table/kup-data-table.tsx +++ b/packages/ketchup/src/components/kup-data-table/kup-data-table.tsx @@ -4368,7 +4368,7 @@ export class KupDataTable { totalMenu = ( - {this.#kupManager.openAI && this.#kupManager.openAI.url ? ( + {this.#kupManager.enableExperimentalFeatures && + this.#kupManager.openAI && + this.#kupManager.openAI.url ? ( ` +#### Parameters + +| Name | Type | Description | +| ---------------------- | ----------------- | ----------- | +| `columns` | `KupDataColumn[]` | | +| `receivingColumnIndex` | `number` | | +| `sortedColumnIndex` | `number` | | +| `useNewObject` | `boolean` | | + #### Returns Type: `Promise` @@ -170,6 +179,12 @@ Type: `Promise` This method will delete rows by id from the data table dataset. +#### Parameters + +| Name | Type | Description | +| ----- | ---------- | ----------------------------- | +| `ids` | `string[]` | - Array of row ids to delete. | + #### Returns Type: `Promise` @@ -210,6 +225,12 @@ Type: `Promise<{ groups: GroupObject[]; filters: GenericFilter; data: KupDataTab Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -230,6 +251,12 @@ Type: `Promise` Hides the given column. +#### Parameters + +| Name | Type | Description | +| -------- | --------------- | ----------------- | +| `column` | `KupDataColumn` | - Column to hide. | + #### Returns Type: `Promise` @@ -240,6 +267,12 @@ Type: `Promise` Adds a new row to the list data +#### Parameters + +| Name | Type | Description | +| ----- | ----------------- | ----------- | +| `row` | `KupDataTableRow` | new row | + #### Returns Type: `Promise` @@ -250,6 +283,13 @@ Type: `Promise` Invokes the KupData API for column creation, then refreshes the component in case no errors were catched. +#### Parameters + +| Name | Type | Description | +| --------- | ------------------------- | ------------------------------ | +| `type` | `KupDataNewColumnTypes` | - Type of the column creation. | +| `options` | `KupDataNewColumnOptions` | - Options of the creation. | + #### Returns Type: `Promise` @@ -260,6 +300,12 @@ Returns the new column created or a string containing the error message if somet Opens the column menu of the given column. +#### Parameters + +| Name | Type | Description | +| -------- | -------- | --------------------- | +| `column` | `string` | - Name of the column. | + #### Returns Type: `Promise` @@ -270,6 +316,12 @@ Type: `Promise` This method is used to trigger a new render of the component. +#### Parameters + +| Name | Type | Description | +| ------------ | --------- | ----------- | +| `recalcRows` | `boolean` | | + #### Returns Type: `Promise` @@ -290,6 +342,14 @@ Type: `Promise` Sets the cell value in a table cell. +#### Parameters + +| Name | Type | Description | +| ------------ | -------- | --------------------- | +| `columnName` | `string` | - Name of the column. | +| `rowId` | `string` | - Id of the row. | +| `value` | `string` | - Value to set. | + #### Returns Type: `Promise` @@ -300,6 +360,13 @@ Type: `Promise` Sets the focus on an editable table cell. +#### Parameters + +| Name | Type | Description | +| -------- | -------- | --------------------- | +| `column` | `string` | - Name of the column. | +| `rowId` | `string` | - Id of the row. | + #### Returns Type: `Promise` @@ -310,6 +377,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -320,6 +393,13 @@ Type: `Promise` This method will set the selected rows of the component. +#### Parameters + +| Name | Type | Description | +| ----------------- | ---------------------- | -------------------------------------------------------------------- | +| `rowsIdentifiers` | `string[] \| number[]` | - Array of ids (dataset) or indexes (rendered rows). | +| `emitEvent` | `boolean` | - The event will always be emitted unless emitEvent is set to false. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-date-picker/readme.md b/packages/ketchup/src/components/kup-date-picker/readme.md index 19c6b2ab64..afea304078 100644 --- a/packages/ketchup/src/components/kup-date-picker/readme.md +++ b/packages/ketchup/src/components/kup-date-picker/readme.md @@ -35,6 +35,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -75,6 +81,12 @@ Type: `Promise` Sets the component's value. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ------------------ | +| `value` | `string` | - Value to be set. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-dialog/kup-dialog.scss b/packages/ketchup/src/components/kup-dialog/kup-dialog.scss index 4860ff7ee6..a0b12b7367 100644 --- a/packages/ketchup/src/components/kup-dialog/kup-dialog.scss +++ b/packages/ketchup/src/components/kup-dialog/kup-dialog.scss @@ -8,11 +8,11 @@ box-sizing: border-box; display: block; height: var(--kup_dialog_height); - left: var(--kup_dialog_left); + left: var(--kup_dialog_left, -100%); min-height: var(--kup_dialog_height); min-width: var(--kup_dialog_width); position: absolute; - top: var(--kup_dialog_top); + top: var(--kup_dialog_top, -100%); transition: opacity 0.25s ease-in; width: var(--kup_dialog_width); } diff --git a/packages/ketchup/src/components/kup-dialog/kup-dialog.tsx b/packages/ketchup/src/components/kup-dialog/kup-dialog.tsx index 3be61d33a0..fbf1603f9b 100644 --- a/packages/ketchup/src/components/kup-dialog/kup-dialog.tsx +++ b/packages/ketchup/src/components/kup-dialog/kup-dialog.tsx @@ -136,7 +136,7 @@ export class KupDialog { @Method() async recalcPosition(): Promise { const rect = this.rootElement.getBoundingClientRect(); - if (!rect.x && !rect.y) { + if (!rect.x && !rect.y && !rect.height && !rect.width) { this.#kupManager.debug.logMessage( this, `recalcPosition() ran before the component finished being drawn. Running again (attempt #${ @@ -158,7 +158,7 @@ export class KupDialog { } this.#recalcSafeguard = 0; const left = window.innerWidth / 2 - rect.width / 2; - const top = window.innerHeight / 2 - rect.height / 2; + const top = window.innerHeight / 2 - rect.height / 2 + window.scrollY; this.rootElement.style.setProperty('--kup_dialog_left', left + 'px'); this.rootElement.style.setProperty('--kup_dialog_top', top + 'px'); this.rootElement.removeAttribute('fade-in'); diff --git a/packages/ketchup/src/components/kup-dialog/readme.md b/packages/ketchup/src/components/kup-dialog/readme.md index 47b25c9286..bac826b690 100644 --- a/packages/ketchup/src/components/kup-dialog/readme.md +++ b/packages/ketchup/src/components/kup-dialog/readme.md @@ -42,6 +42,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -72,6 +78,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -112,6 +124,7 @@ Type: `Promise` - [kup-drawer](../kup-drawer) - [kup-dropdown-button](../kup-dropdown-button) - [kup-echart](../kup-echart) + - [kup-editor](../kup-editor) - [kup-family-tree](../kup-family-tree) - [kup-form](../kup-form) - [kup-gauge](../kup-gauge) @@ -183,6 +196,7 @@ graph TD; kup-dashboard --> kup-dialog kup-drawer --> kup-dialog kup-echart --> kup-dialog + kup-editor --> kup-dialog kup-family-tree --> kup-dialog kup-grid --> kup-dialog kup-iframe --> kup-dialog diff --git a/packages/ketchup/src/components/kup-drawer/readme.md b/packages/ketchup/src/components/kup-drawer/readme.md index 7d4dc16f1a..fd16c69759 100644 --- a/packages/ketchup/src/components/kup-drawer/readme.md +++ b/packages/ketchup/src/components/kup-drawer/readme.md @@ -37,6 +37,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -77,6 +83,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-dropdown-button/readme.md b/packages/ketchup/src/components/kup-dropdown-button/readme.md index 1cc6451af1..c852f77be7 100644 --- a/packages/ketchup/src/components/kup-dropdown-button/readme.md +++ b/packages/ketchup/src/components/kup-dropdown-button/readme.md @@ -39,6 +39,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -69,6 +75,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -79,6 +91,12 @@ Type: `Promise` Sets the internal value of the component. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ----------- | +| `value` | `string` | | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-echart/readme.md b/packages/ketchup/src/components/kup-echart/readme.md index 010756ce44..4900838c55 100644 --- a/packages/ketchup/src/components/kup-echart/readme.md +++ b/packages/ketchup/src/components/kup-echart/readme.md @@ -38,6 +38,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -68,6 +74,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-editor/kup-editor-declarations.ts b/packages/ketchup/src/components/kup-editor/kup-editor-declarations.ts new file mode 100644 index 0000000000..7b0e31bdbe --- /dev/null +++ b/packages/ketchup/src/components/kup-editor/kup-editor-declarations.ts @@ -0,0 +1,25 @@ +import { KupEventPayload } from '../../types/GenericTypes'; + +/** + * Props of the kup-dropdown-button component. + * Used to export every prop in an object. + */ +export enum KupEditorProps { + autosaveTimer = 'When a number is specified, the component will emit the kup-editor-save event at regular intervals. The amount of time every interval will last is specified but the prop itself.', + editorHeight = 'Sets the height of the component.', + initialEditType = 'Initializes editor with the specified editor type. Suported values: "markdown", "wysiwyg".', + initialValue = 'Initializes editor with the specified string.', + isReadOnly = 'Defaults at false. When set, When set, the editor’s content can’t be changed..', + previewStyle = 'Initializes editor with the specified preview type. Suported values: "tab", "vertical".', + showSaveButton = 'When set, a save button shown in the editor’s toolbar.', + showToolbar = 'When set to false, the toolbar will not be shown.', +} + +export type KupEditorType = 'wysiwyg' | 'markdown'; + +export type KupEditorPreview = 'tab' | 'vertical'; + +export interface KupEditorEventPayload extends KupEventPayload { + htmlValue: string; + markdownValue: string; +} diff --git a/packages/ketchup/src/components/kup-editor/kup-editor.tsx b/packages/ketchup/src/components/kup-editor/kup-editor.tsx new file mode 100644 index 0000000000..5070ff88c2 --- /dev/null +++ b/packages/ketchup/src/components/kup-editor/kup-editor.tsx @@ -0,0 +1,560 @@ +import { + Component, + Element, + Event, + EventEmitter, + forceUpdate, + h, + Host, + Method, + Prop, + State, + Watch, +} from '@stencil/core'; +import { + KupManager, + kupManagerInstance, +} from '../../managers/kup-manager/kup-manager'; +import { componentWrapperId } from '../../variables/GenericVariables'; +import { + GenericObject, + KupComponent, + KupEventPayload, +} from '../../types/GenericTypes'; +import Editor, { EditorOptions } from '@toast-ui/editor'; +import { + KupEditorEventPayload, + KupEditorPreview, + KupEditorProps, + KupEditorType, +} from './kup-editor-declarations'; +import Viewer, { + ViewerOptions, +} from '@toast-ui/editor/dist/toastui-editor-viewer'; +import { getProps, setProps } from '../../utils/utils'; + +@Component({ + tag: 'kup-editor', + shadow: false, +}) +export class KupEditor { + /** + * References the root HTML element of the component (). + */ + @Element() rootElement: HTMLElement; + + /*-------------------------------------------------*/ + /* S t a t e s */ + /*-------------------------------------------------*/ + + /** + * The editor instance. + * @default null + */ + @State() editor: Editor = null; + + /** + * The editor html element instance. + * @default null + */ + @State() editorRef: HTMLDivElement; + + /** + * The viewer instance. + * @default null + */ + @State() viewer: Viewer = null; + + /*-------------------------------------------------*/ + /* P r o p s */ + /*-------------------------------------------------*/ + + /** + * When specified, the component will emit the kup-editor-autosave event at regular intervals. + * @default null + */ + @Prop() autosaveTimer: number; + + /** + * Sets the height of the component. + * @default "auto" + */ + @Prop() editorHeight: string = 'auto'; + + /** + * The editor type. + * @default 'markdown' + */ + @Prop() initialEditType: KupEditorType = 'markdown'; + + /** + * The initial editor value. + * @default '' + */ + @Prop({ mutable: false, reflect: false }) initialValue: string = ''; + + /** + * Defines whether the editor is disabled or not. + * @default false + */ + @Prop() isReadOnly: boolean = false; + + /** + * The editor preview style. + * @default 'vertical' + */ + @Prop() previewStyle: KupEditorPreview = 'vertical'; + + /** + * Defines whether to show the save button in editor's toolbar or not. + * @default true + */ + @Prop() showSaveButton: boolean = true; + + /** + * Defines whether to show the editor's toolbar or not. + * @default true + */ + @Prop() showToolbar: boolean = true; + + /*-------------------------------------------------*/ + /* I n t e r n a l V a r i a b l e s */ + /*-------------------------------------------------*/ + + #autosaveInterval: NodeJS.Timeout; + #hasChanges: boolean = false; + #initialContent: string = ''; + #kupManager: KupManager = kupManagerInstance(); + #unsavedChangesIndex = 0; + #unsavedChangesItem: toastui.ToolbarButton = { + options: { + className: 'kup-editor-unsaved-changes', + el: this.createUnsavedChanges(), + tooltip: 'There are unsaved changes.', + }, + type: 'button', + }; + + /*-------------------------------------------------*/ + /* E v e n t s */ + /*-------------------------------------------------*/ + + /** + * Triggered at regular intervals if autosaveTimer prop is initialised. + */ + @Event({ + eventName: 'kup-editor-autosave', + composed: true, + cancelable: false, + bubbles: true, + }) + kupAutoSave: EventEmitter; + + /** + * Triggered when the component is ready. + */ + @Event({ + eventName: 'kup-editor-ready', + composed: true, + cancelable: false, + bubbles: true, + }) + kupReady: EventEmitter; + + /** + * Triggered when save button is clicked. + */ + @Event({ + eventName: 'kup-editor-save', + composed: true, + cancelable: false, + bubbles: true, + }) + kupSave: EventEmitter; + + /*-------------------------------------------------*/ + /* W a t c h e r s */ + /*-------------------------------------------------*/ + + @Watch('editorRef') + onEditorRefUpdated() { + if (this.editorRef && !this.editor) { + if (!this.isReadOnly) { + this.createEditor(); + } else { + this.createViewer(); + } + } + } + + @Watch('editor') + onEditorUpdate() { + if (this.editor) { + // to give focus to editor + setTimeout(() => { + this.editor && this.editor.moveCursorToStart(); + }, 100); + } + } + + @Watch('initialEditType') + onInitialEditTypeChanged() { + if ( + (this.initialEditType != 'markdown' && + this.initialEditType != 'wysiwyg') || + !this.editor + ) + return; + this.editor.changeMode(this.initialEditType); + this.updateToolbarVisiblity(); + } + + @Watch('isReadOnly') + onIsReadOnlyChanged() { + if (this.isReadOnly) { + this.editor.remove(); + this.editor = null; + this.createViewer(); + } else { + this.viewer.remove(); + this.viewer = null; + this.createEditor(); + } + } + + @Watch('previewStyle') + onPreviewStyleChanged() { + if ( + (this.previewStyle != 'tab' && this.previewStyle != 'vertical') || + !this.editor + ) + return; + this.editor.changePreviewStyle(this.previewStyle); + + /* + this is a fix to a bug in editor, when editor is in tab style and preview tab is selected + all toolbar buttons are disabled so at that point if we change the preview style to vertical + the toolbar buttons still remains disabled, so we call the enable all button function manually + */ + if (this.previewStyle == 'vertical') { + this.editor.getUI().getToolbar().enableAllButton(); + } + + this.updateToolbarVisiblity(); + } + + @Watch('showSaveButton') + onShowSaveButtonChanged() { + if (this.editor) { + const toolbar = this.editor.getUI().getToolbar(); + if (this.showSaveButton) { + toolbar.insertItem(0, this.getToolBarWithSaveButton(false)[0]); + } else { + toolbar.removeItem(0); + } + } + } + + @Watch('showToolbar') + onShowToolBarChanged() { + if (this.editor) { + this.updateToolbarVisiblity(); + } + } + + @Watch('autosaveTimer') + onAutosaveTimerChanged() { + if (this.editor) { + this.#autosaveInterval && clearInterval(this.#autosaveInterval); + typeof this.autosaveTimer === 'number' && + this.autosaveTimer > 0 && + this.setAutosaveInterval(); + } + } + + /*-------------------------------------------------*/ + /* P u b l i c M e t h o d s */ + /*-------------------------------------------------*/ + + /** + * Used to retrieve component's props values. + * @param {boolean} descriptions - When provided and true, the result will be the list of props with their description. + * @returns {Promise} List of props as object, each key will be a prop. + */ + @Method() + async getProps(descriptions?: boolean): Promise { + return getProps(this, KupEditorProps, descriptions); + } + /** + * Returns the component's internal value as html. + */ + @Method() + async getValueAsHTML(): Promise { + return this.editor?.getHtml() ?? ''; + } + /** + * Returns the component's internal value as markdown. + */ + @Method() + async getValueAsMarkdown(): Promise { + return this.editor?.getMarkdown() ?? ''; + } + /** + * This method is used to trigger a new render of the component. + */ + @Method() + async refresh(): Promise { + forceUpdate(this); + } + /** + * Sets the props to the component. + * @param {GenericObject} props - Object containing props that will be set to the component. + */ + @Method() + async setProps(props: GenericObject): Promise { + setProps(this, KupEditorProps, props); + } + + /*-------------------------------------------------*/ + /* P r i v a t e M e t h o d s */ + /*-------------------------------------------------*/ + + createEditor() { + const editorProps: EditorOptions = { + el: this.editorRef, + events: { + change: () => { + if (this.#initialContent !== this.editor.getMarkdown()) { + if (!this.#hasChanges) { + this.#unsavedChangesIndex = + this.editor.getUI().getToolbar().getItems() + .length - 1; + this.editor + .getUI() + .getToolbar() + .insertItem( + this.#unsavedChangesIndex, + this.#unsavedChangesItem + ); + } + this.#hasChanges = true; + } else { + if (this.#hasChanges) { + this.editor + .getUI() + .getToolbar() + .removeItem(this.#unsavedChangesIndex); + } + this.#hasChanges = false; + } + }, + focus: () => { + if (!this.isReadOnly && !this.showToolbar) { + this.showToolbar = true; + } + }, + }, + height: this.editorHeight ?? 'auto', + hideModeSwitch: true, + initialEditType: this.initialEditType, + initialValue: this.initialValue, + placeholder: 'Type your text here...', + previewStyle: this.previewStyle, + usageStatistics: false, + }; + + if (this.showSaveButton) { + editorProps.toolbarItems = this.getToolBarWithSaveButton(); + } + + this.editor = new Editor(editorProps); + this.#initialContent = this.editor.getMarkdown(); + + if (!this.showToolbar) { + this.updateToolbarVisiblity(); + } + + typeof this.autosaveTimer === 'number' && + this.autosaveTimer > 0 && + this.setAutosaveInterval(); + } + + createViewer() { + const viewerProps: ViewerOptions = { + el: this.editorRef, + initialValue: this.initialValue, + }; + + this.viewer = new Viewer(viewerProps); + } + + createSaveButton() { + const button: HTMLElement = document.createElement('button'); + + button.className = 'kup-editor-save-button'; + button.innerHTML = ` + + + + + + + `; + button.addEventListener('click', this.onEditorSave.bind(this)); + + return button; + } + + createDivider() { + const el: HTMLElement = document.createElement('div'); + el.className = 'kup-editor-divider'; + const divider: toastui.ToolbarButton = { + options: { + className: 'kup-editor-divider', + el, + }, + type: 'button', + }; + return divider; + } + + createUnsavedChanges() { + const el: HTMLElement = document.createElement('span'); + el.className = 'kup-editor-unsaved-changes'; + el.innerText = 'Unsaved changes.'; + return el; + } + + updateToolbarVisiblity() { + const toolbarElement = this.editor.getUI().getToolbar().el; + const toolbarParentElement = toolbarElement.parentElement; + + toolbarElement.style.display = ''; + toolbarParentElement.style.display = ''; + + if (!this.showToolbar) { + toolbarElement.style.display = 'none'; + if ( + this.initialEditType != 'markdown' || + this.previewStyle != 'tab' + ) { + toolbarParentElement.style.display = 'none'; + } + } + } + + setAutosaveInterval() { + this.#autosaveInterval = setInterval(() => { + this.onEditorAutoSave(); + }, this.autosaveTimer); + } + + onEditorSave() { + this.kupSave.emit(this.getSaveAndAutoSaveProps()); + } + + onEditorAutoSave() { + this.kupAutoSave.emit(this.getSaveAndAutoSaveProps()); + } + + getToolBarWithSaveButton(includeDefaultItems: boolean = true) { + const options: Partial = { + toolbarItems: [ + { + options: { + el: this.createSaveButton(), + tooltip: 'Save', + }, + type: 'button', + }, + this.createDivider(), + ...(includeDefaultItems ? this.getDefaultToolBarItems() : []), + ], + }; + + return options.toolbarItems; + } + + getDefaultToolBarItems() { + const toolBarItems = [ + 'heading', + 'bold', + 'italic', + 'strike', + this.createDivider(), + 'hr', + 'quote', + this.createDivider(), + 'ul', + 'ol', + 'task', + 'indent', + 'outdent', + this.createDivider(), + 'table', + 'image', + 'link', + this.createDivider(), + 'code', + 'codeblock', + ]; + + if (this.initialEditType == 'markdown') { + toolBarItems.push('scrollSync'); + } + return toolBarItems; + } + + getSaveAndAutoSaveProps(): KupEditorEventPayload { + return { + comp: this, + id: this.rootElement.id, + htmlValue: this.editor.getHtml() ?? '', + markdownValue: this.editor.getMarkdown() ?? '', + }; + } + + /*-------------------------------------------------*/ + /* L i f e c y c l e H o o k s */ + /*-------------------------------------------------*/ + + componentWillLoad() { + this.#kupManager.debug.logLoad(this, false); + this.#kupManager.theme.register(this); + } + + componentDidLoad() { + this.kupReady.emit({ + comp: this, + id: this.rootElement.id, + }); + this.#kupManager.debug.logLoad(this, true); + } + + componentWillRender() { + this.#kupManager.debug.logRender(this, false); + } + + componentDidRender() { + this.#kupManager.debug.logRender(this, true); + } + + render() { + return ( + +
+
(this.editorRef = el)} + class="kup-editor" + >
+
+
+ ); + } + + disconnectedCallback() { + this.#kupManager.theme.unregister(this); + this.#autosaveInterval && clearInterval(this.#autosaveInterval); + } +} diff --git a/packages/ketchup/src/components/kup-editor/readme.md b/packages/ketchup/src/components/kup-editor/readme.md new file mode 100644 index 0000000000..fd7057f2c9 --- /dev/null +++ b/packages/ketchup/src/components/kup-editor/readme.md @@ -0,0 +1,256 @@ +# kup-editor + + + + + + +## Properties + +| Property | Attribute | Description | Type | Default | +| ----------------- | ------------------- | ------------------------------------------------------------------------------------------- | ------------------------- | ------------ | +| `autosaveTimer` | `autosave-timer` | When specified, the component will emit the kup-editor-autosave event at regular intervals. | `number` | `undefined` | +| `editorHeight` | `editor-height` | Sets the height of the component. | `string` | `'auto'` | +| `initialEditType` | `initial-edit-type` | The editor type. | `"markdown" \| "wysiwyg"` | `'markdown'` | +| `initialValue` | `initial-value` | The initial editor value. | `string` | `''` | +| `isReadOnly` | `is-read-only` | Defines whether the editor is disabled or not. | `boolean` | `false` | +| `previewStyle` | `preview-style` | The editor preview style. | `"tab" \| "vertical"` | `'vertical'` | +| `showSaveButton` | `show-save-button` | Defines whether to show the save button in editor's toolbar or not. | `boolean` | `true` | +| `showToolbar` | `show-toolbar` | Defines whether to show the editor's toolbar or not. | `boolean` | `true` | + + +## Events + +| Event | Description | Type | +| --------------------- | -------------------------------------------------------------------- | ------------------------------------ | +| `kup-editor-autosave` | Triggered at regular intervals if autosaveTimer prop is initialised. | `CustomEvent` | +| `kup-editor-ready` | Triggered when the component is ready. | `CustomEvent` | +| `kup-editor-save` | Triggered when save button is clicked. | `CustomEvent` | + + +## Methods + +### `getProps(descriptions?: boolean) => Promise` + +Used to retrieve component's props values. + +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + +#### Returns + +Type: `Promise` + +List of props as object, each key will be a prop. + +### `getValueAsHTML() => Promise` + +Returns the component's internal value as html. + +#### Returns + +Type: `Promise` + + + +### `getValueAsMarkdown() => Promise` + +Returns the component's internal value as markdown. + +#### Returns + +Type: `Promise` + + + +### `refresh() => Promise` + +This method is used to trigger a new render of the component. + +#### Returns + +Type: `Promise` + + + +### `setProps(props: GenericObject) => Promise` + +Sets the props to the component. + +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + +#### Returns + +Type: `Promise` + + + + +## Dependencies + +### Depends on + +- [kup-card](../kup-card) +- [kup-dialog](../kup-dialog) + +### Graph +```mermaid +graph TD; + kup-editor --> kup-card + kup-editor --> kup-dialog + kup-card --> kup-autocomplete + kup-card --> kup-chip + kup-card --> kup-text-field + kup-card --> kup-color-picker + kup-card --> kup-combobox + kup-card --> kup-date-picker + kup-card --> kup-rating + kup-card --> kup-time-picker + kup-card --> kup-image + kup-card --> kup-button-list + kup-card --> kup-chart + kup-card --> kup-gauge + kup-card --> kup-progress-bar + kup-card --> kup-badge + kup-card --> kup-button + kup-card --> kup-list + kup-card --> kup-spinner + kup-card --> kup-checkbox + kup-card --> kup-data-table + kup-card --> kup-tab-bar + kup-card --> kup-tree + kup-card --> kup-switch + kup-card --> kup-dropdown-button + kup-card --> kup-card + kup-card --> kup-dialog + kup-autocomplete --> kup-list + kup-autocomplete --> kup-card + kup-autocomplete --> kup-dialog + kup-list --> kup-list + kup-list --> kup-radio + kup-list --> kup-card + kup-list --> kup-dialog + kup-list --> kup-badge + kup-radio --> kup-card + kup-radio --> kup-dialog + kup-dialog --> kup-badge + kup-dialog --> kup-card + kup-dialog --> kup-dialog + kup-badge --> kup-badge + kup-badge --> kup-card + kup-badge --> kup-dialog + kup-chip --> kup-card + kup-chip --> kup-dialog + kup-chip --> kup-badge + kup-text-field --> kup-card + kup-text-field --> kup-dialog + kup-color-picker --> kup-card + kup-color-picker --> kup-dialog + kup-combobox --> kup-list + kup-combobox --> kup-card + kup-combobox --> kup-dialog + kup-date-picker --> kup-card + kup-date-picker --> kup-dialog + kup-rating --> kup-card + kup-rating --> kup-dialog + kup-time-picker --> kup-card + kup-time-picker --> kup-list + kup-time-picker --> kup-dialog + kup-image --> kup-spinner + kup-image --> kup-card + kup-image --> kup-dialog + kup-image --> kup-badge + kup-spinner --> kup-card + kup-spinner --> kup-dialog + kup-button-list --> kup-dropdown-button + kup-button-list --> kup-card + kup-button-list --> kup-dialog + kup-button-list --> kup-badge + kup-dropdown-button --> kup-list + kup-dropdown-button --> kup-card + kup-dropdown-button --> kup-dialog + kup-dropdown-button --> kup-badge + kup-chart --> kup-card + kup-chart --> kup-dialog + kup-gauge --> kup-card + kup-gauge --> kup-dialog + kup-progress-bar --> kup-card + kup-progress-bar --> kup-dialog + kup-button --> kup-card + kup-button --> kup-dialog + kup-button --> kup-badge + kup-checkbox --> kup-card + kup-checkbox --> kup-dialog + kup-data-table --> kup-card + kup-data-table --> kup-list + kup-data-table --> kup-switch + kup-data-table --> kup-button + kup-data-table --> kup-spinner + kup-data-table --> kup-form + kup-data-table --> kup-image + kup-data-table --> kup-dialog + kup-data-table --> kup-checkbox + kup-data-table --> kup-combobox + kup-data-table --> kup-badge + kup-data-table --> kup-autocomplete + kup-data-table --> kup-chip + kup-data-table --> kup-text-field + kup-data-table --> kup-color-picker + kup-data-table --> kup-date-picker + kup-data-table --> kup-rating + kup-data-table --> kup-time-picker + kup-data-table --> kup-button-list + kup-data-table --> kup-chart + kup-data-table --> kup-gauge + kup-data-table --> kup-progress-bar + kup-switch --> kup-card + kup-switch --> kup-dialog + kup-form --> kup-card + kup-form --> kup-dialog + kup-form --> kup-autocomplete + kup-form --> kup-chip + kup-form --> kup-text-field + kup-form --> kup-color-picker + kup-form --> kup-combobox + kup-form --> kup-date-picker + kup-form --> kup-rating + kup-form --> kup-time-picker + kup-form --> kup-image + kup-form --> kup-button-list + kup-form --> kup-chart + kup-form --> kup-gauge + kup-form --> kup-progress-bar + kup-form --> kup-badge + kup-tab-bar --> kup-card + kup-tab-bar --> kup-dialog + kup-tab-bar --> kup-badge + kup-tree --> kup-card + kup-tree --> kup-list + kup-tree --> kup-text-field + kup-tree --> kup-dialog + kup-tree --> kup-autocomplete + kup-tree --> kup-chip + kup-tree --> kup-color-picker + kup-tree --> kup-combobox + kup-tree --> kup-date-picker + kup-tree --> kup-rating + kup-tree --> kup-time-picker + kup-tree --> kup-image + kup-tree --> kup-button-list + kup-tree --> kup-chart + kup-tree --> kup-gauge + kup-tree --> kup-progress-bar + kup-tree --> kup-badge + style kup-editor fill:#f9f,stroke:#333,stroke-width:4px +``` + +---------------------------------------------- + +*Built with [StencilJS](https://stenciljs.com/)* diff --git a/packages/ketchup/src/components/kup-family-tree/readme.md b/packages/ketchup/src/components/kup-family-tree/readme.md index 2ed8318f90..1beda2058f 100644 --- a/packages/ketchup/src/components/kup-family-tree/readme.md +++ b/packages/ketchup/src/components/kup-family-tree/readme.md @@ -32,6 +32,12 @@ Collapses all nodes. +#### Parameters + +| Name | Type | Description | +| ------- | --------------------- | ----------- | +| `nodes` | `KupFamilyTreeNode[]` | | + #### Returns Type: `Promise` @@ -42,6 +48,12 @@ Type: `Promise` Expands all nodes. +#### Parameters + +| Name | Type | Description | +| ------- | --------------------- | ----------- | +| `nodes` | `KupFamilyTreeNode[]` | | + #### Returns Type: `Promise` @@ -52,6 +64,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -82,6 +100,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-form/readme.md b/packages/ketchup/src/components/kup-form/readme.md index 5a2cc83251..60913a56f9 100644 --- a/packages/ketchup/src/components/kup-form/readme.md +++ b/packages/ketchup/src/components/kup-form/readme.md @@ -30,6 +30,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -50,6 +56,13 @@ Type: `Promise` Sets the focus on an editable table cell. +#### Parameters + +| Name | Type | Description | +| -------- | -------- | --------------------- | +| `column` | `string` | - Name of the column. | +| `rowId` | `string` | - Id of the row. | + #### Returns Type: `Promise` @@ -60,6 +73,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-gauge/readme.md b/packages/ketchup/src/components/kup-gauge/readme.md index 541f16b200..18bec20b80 100644 --- a/packages/ketchup/src/components/kup-gauge/readme.md +++ b/packages/ketchup/src/components/kup-gauge/readme.md @@ -104,6 +104,12 @@ Fundamentally, the main problem here is that that if Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -124,6 +130,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-grid/readme.md b/packages/ketchup/src/components/kup-grid/readme.md index 9a2152d6c8..1ac0acb0b6 100644 --- a/packages/ketchup/src/components/kup-grid/readme.md +++ b/packages/ketchup/src/components/kup-grid/readme.md @@ -18,6 +18,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -38,6 +44,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-iframe/readme.md b/packages/ketchup/src/components/kup-iframe/readme.md index 3e66b80642..4b0ee21a72 100644 --- a/packages/ketchup/src/components/kup-iframe/readme.md +++ b/packages/ketchup/src/components/kup-iframe/readme.md @@ -28,6 +28,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -48,6 +54,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-image-list/readme.md b/packages/ketchup/src/components/kup-image-list/readme.md index 1d73a3bf09..3078d43eb7 100644 --- a/packages/ketchup/src/components/kup-image-list/readme.md +++ b/packages/ketchup/src/components/kup-image-list/readme.md @@ -32,6 +32,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -52,6 +58,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-image/readme.md b/packages/ketchup/src/components/kup-image/readme.md index 7979939f36..5c1d8e63ca 100644 --- a/packages/ketchup/src/components/kup-image/readme.md +++ b/packages/ketchup/src/components/kup-image/readme.md @@ -32,6 +32,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -52,6 +58,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-lazy/readme.md b/packages/ketchup/src/components/kup-lazy/readme.md index e2f40cee97..1c8436cc9e 100644 --- a/packages/ketchup/src/components/kup-lazy/readme.md +++ b/packages/ketchup/src/components/kup-lazy/readme.md @@ -39,6 +39,12 @@ Lazy loaded component. Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -59,6 +65,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-list/readme.md b/packages/ketchup/src/components/kup-list/readme.md index 322a9e93d3..4c262703e9 100644 --- a/packages/ketchup/src/components/kup-list/readme.md +++ b/packages/ketchup/src/components/kup-list/readme.md @@ -56,6 +56,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -86,6 +92,12 @@ Type: `Promise` Calls handleSelection internal method to select the given item. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ---------------------------------------------------------------------------------------------------------------------------- | +| `index` | `number` | - Based zero index of the item that must be selected, when not provided the list will attempt to select the focused element. | + #### Returns Type: `Promise` @@ -96,6 +108,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-magic-box/readme.md b/packages/ketchup/src/components/kup-magic-box/readme.md index e400562d1f..7b5e9ad05c 100644 --- a/packages/ketchup/src/components/kup-magic-box/readme.md +++ b/packages/ketchup/src/components/kup-magic-box/readme.md @@ -19,6 +19,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -39,6 +45,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-nav-bar/readme.md b/packages/ketchup/src/components/kup-nav-bar/readme.md index 66b98fa716..f325f36e70 100644 --- a/packages/ketchup/src/components/kup-nav-bar/readme.md +++ b/packages/ketchup/src/components/kup-nav-bar/readme.md @@ -25,6 +25,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -55,6 +61,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-numeric-picker/readme.md b/packages/ketchup/src/components/kup-numeric-picker/readme.md index b6d42f4515..01e1d5ee92 100644 --- a/packages/ketchup/src/components/kup-numeric-picker/readme.md +++ b/packages/ketchup/src/components/kup-numeric-picker/readme.md @@ -41,6 +41,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -81,6 +87,12 @@ Type: `Promise` Sets the component's value. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ------------------ | +| `value` | `string` | - Value to be set. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-photo-frame/readme.md b/packages/ketchup/src/components/kup-photo-frame/readme.md index 67f1aa42df..9edcc04d83 100644 --- a/packages/ketchup/src/components/kup-photo-frame/readme.md +++ b/packages/ketchup/src/components/kup-photo-frame/readme.md @@ -29,6 +29,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -49,6 +55,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-planner/readme.md b/packages/ketchup/src/components/kup-planner/readme.md index 30d65bb63e..126ab5492c 100644 --- a/packages/ketchup/src/components/kup-planner/readme.md +++ b/packages/ketchup/src/components/kup-planner/readme.md @@ -71,6 +71,13 @@ Add a list of phases to the project +#### Parameters + +| Name | Type | Description | +| -------- | ---------------- | -------------------------------------- | +| `taskId` | `string` | | +| `data` | `KupDataDataset` | - Matrix which contains project phases | + #### Returns Type: `Promise` @@ -81,6 +88,12 @@ Type: `Promise` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -101,6 +114,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-planner/utils/kup-gantt/kup-gantt.tsx b/packages/ketchup/src/components/kup-planner/utils/kup-gantt/kup-gantt.tsx index 8f91d44056..c96958f73f 100644 --- a/packages/ketchup/src/components/kup-planner/utils/kup-gantt/kup-gantt.tsx +++ b/packages/ketchup/src/components/kup-planner/utils/kup-gantt/kup-gantt.tsx @@ -342,7 +342,7 @@ export class KupGantt { */ @Element() rootElement: HTMLElement; - + taskListTrueRef: HTMLKupTaskListElement = null; //---- Lifecycle hooks ---- componentWillLoad() { @@ -980,6 +980,7 @@ export class KupGantt { setDoubleView={this.setDoubleView} {...tableProps} class="tasks" + ref={(el) => (this.taskListTrueRef = el)} /> )} { + this.updateScrollX(); + this.updateScrollY(); + }, 75); } render() { diff --git a/packages/ketchup/src/components/kup-planner/utils/kup-task-list/kup-task-list.tsx b/packages/ketchup/src/components/kup-planner/utils/kup-task-list/kup-task-list.tsx index 7a99a15743..86e031cb1d 100644 --- a/packages/ketchup/src/components/kup-planner/utils/kup-task-list/kup-task-list.tsx +++ b/packages/ketchup/src/components/kup-planner/utils/kup-task-list/kup-task-list.tsx @@ -123,6 +123,11 @@ export class TaskList { componentDidLoad() { this.taskListRef.prepend(this.filter); + setTimeout(() => { + if (this.horizontalContainerRef) { + this.horizontalContainerRef.scrollTop = this.scrollY; + } + }, 75); } componentDidUpdate() { diff --git a/packages/ketchup/src/components/kup-planner/utils/kup-vertical-scroll/kup-vertical-scroll.scss b/packages/ketchup/src/components/kup-planner/utils/kup-vertical-scroll/kup-vertical-scroll.scss index ee3493f4d1..afa2105d71 100644 --- a/packages/ketchup/src/components/kup-planner/utils/kup-vertical-scroll/kup-vertical-scroll.scss +++ b/packages/ketchup/src/components/kup-planner/utils/kup-vertical-scroll/kup-vertical-scroll.scss @@ -2,8 +2,6 @@ overflow: hidden auto; width: 1rem; flex-shrink: 0; - /*firefox*/ - scrollbar-width: thin; } .scroll::-webkit-scrollbar { diff --git a/packages/ketchup/src/components/kup-progress-bar/kup-progress-bar.tsx b/packages/ketchup/src/components/kup-progress-bar/kup-progress-bar.tsx index 202f9ce2e6..7b02b123fb 100644 --- a/packages/ketchup/src/components/kup-progress-bar/kup-progress-bar.tsx +++ b/packages/ketchup/src/components/kup-progress-bar/kup-progress-bar.tsx @@ -2,7 +2,6 @@ import { Component, Element, forceUpdate, - getAssetPath, h, Host, Method, diff --git a/packages/ketchup/src/components/kup-progress-bar/readme.md b/packages/ketchup/src/components/kup-progress-bar/readme.md index 8d4109c0fe..6cf3ff4df7 100644 --- a/packages/ketchup/src/components/kup-progress-bar/readme.md +++ b/packages/ketchup/src/components/kup-progress-bar/readme.md @@ -22,6 +22,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -42,6 +48,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-radio/readme.md b/packages/ketchup/src/components/kup-radio/readme.md index 6f60591cd7..43ba8774ba 100644 --- a/packages/ketchup/src/components/kup-radio/readme.md +++ b/packages/ketchup/src/components/kup-radio/readme.md @@ -29,6 +29,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -49,6 +55,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-rating/readme.md b/packages/ketchup/src/components/kup-rating/readme.md index 2bea9c38c4..3ab6044d9f 100644 --- a/packages/ketchup/src/components/kup-rating/readme.md +++ b/packages/ketchup/src/components/kup-rating/readme.md @@ -28,6 +28,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -48,6 +54,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-snackbar/readme.md b/packages/ketchup/src/components/kup-snackbar/readme.md index 113a56356d..adf3ea5f31 100644 --- a/packages/ketchup/src/components/kup-snackbar/readme.md +++ b/packages/ketchup/src/components/kup-snackbar/readme.md @@ -33,6 +33,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -63,6 +69,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-spinner/readme.md b/packages/ketchup/src/components/kup-spinner/readme.md index 0361d580a1..f08a077f9c 100644 --- a/packages/ketchup/src/components/kup-spinner/readme.md +++ b/packages/ketchup/src/components/kup-spinner/readme.md @@ -30,6 +30,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -50,6 +56,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-switch/readme.md b/packages/ketchup/src/components/kup-switch/readme.md index 672de93ef2..92eb956a8e 100644 --- a/packages/ketchup/src/components/kup-switch/readme.md +++ b/packages/ketchup/src/components/kup-switch/readme.md @@ -29,6 +29,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -49,6 +55,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-tab-bar/readme.md b/packages/ketchup/src/components/kup-tab-bar/readme.md index fdf7756eff..1bcc9d4a72 100644 --- a/packages/ketchup/src/components/kup-tab-bar/readme.md +++ b/packages/ketchup/src/components/kup-tab-bar/readme.md @@ -27,6 +27,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -57,6 +63,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-text-field/readme.md b/packages/ketchup/src/components/kup-text-field/readme.md index 9f8acec058..0ac236d76f 100644 --- a/packages/ketchup/src/components/kup-text-field/readme.md +++ b/packages/ketchup/src/components/kup-text-field/readme.md @@ -59,6 +59,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -99,6 +105,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -109,6 +121,12 @@ Type: `Promise` Sets the internal value of the component. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ----------- | +| `value` | `string` | | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-time-picker/readme.md b/packages/ketchup/src/components/kup-time-picker/readme.md index eea44fcf8f..cc39195fa7 100644 --- a/packages/ketchup/src/components/kup-time-picker/readme.md +++ b/packages/ketchup/src/components/kup-time-picker/readme.md @@ -37,6 +37,12 @@ Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -77,6 +83,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -87,6 +99,12 @@ Type: `Promise` Sets the internal value of the component. +#### Parameters + +| Name | Type | Description | +| ------- | -------- | ----------- | +| `value` | `string` | | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/components/kup-tree/kup-tree.tsx b/packages/ketchup/src/components/kup-tree/kup-tree.tsx index 5c5710da91..a4689c4448 100644 --- a/packages/ketchup/src/components/kup-tree/kup-tree.tsx +++ b/packages/ketchup/src/components/kup-tree/kup-tree.tsx @@ -1853,7 +1853,7 @@ export class KupTree { totalMenu = ( ` Used to retrieve component's props values. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------------------------- | +| `descriptions` | `boolean` | - When provided and true, the result will be the list of props with their description. | + #### Returns Type: `Promise` @@ -163,6 +169,12 @@ Type: `Promise` Hides the given column. +#### Parameters + +| Name | Type | Description | +| -------- | --------------- | ----------------- | +| `column` | `KupDataColumn` | - Column to hide. | + #### Returns Type: `Promise` @@ -183,6 +195,12 @@ Type: `Promise` Opens the column menu of the given column. +#### Parameters + +| Name | Type | Description | +| -------- | -------- | --------------------- | +| `column` | `string` | - Name of the column. | + #### Returns Type: `Promise` @@ -213,6 +231,12 @@ Type: `Promise` Sets the props to the component. +#### Parameters + +| Name | Type | Description | +| ------- | --------------- | ------------------------------------------------------------ | +| `props` | `GenericObject` | - Object containing props that will be set to the component. | + #### Returns Type: `Promise` @@ -223,6 +247,13 @@ Type: `Promise` This method will set the selected rows of the component. +#### Parameters + +| Name | Type | Description | +| -------------- | --------- | -------------------------------------------------------------------- | +| `treeNodePath` | `string` | | +| `emitEvent` | `boolean` | - The event will always be emitted unless emitEvent is set to false. | + #### Returns Type: `Promise` diff --git a/packages/ketchup/src/debug.html b/packages/ketchup/src/debug.html index c443eee4be..447f6902c6 100644 --- a/packages/ketchup/src/debug.html +++ b/packages/ketchup/src/debug.html @@ -77,6 +77,7 @@ document.documentElement['ketchupInit'] = { debug: { active: true, logLimit: 20000 }, autoSetLocalization: true, + enableExperimentalFeatures: true, };

Debug component

diff --git a/packages/ketchup/src/editor-example-1.html b/packages/ketchup/src/editor-example-1.html new file mode 100644 index 0000000000..da6681b143 --- /dev/null +++ b/packages/ketchup/src/editor-example-1.html @@ -0,0 +1,48 @@ + + + + + + + + Ketchup editor (example 1) + + + + + + + + +

Editor html

+ +

Editor markdown

+ + + + + diff --git a/packages/ketchup/src/editor.html b/packages/ketchup/src/editor.html new file mode 100644 index 0000000000..7920bf84ec --- /dev/null +++ b/packages/ketchup/src/editor.html @@ -0,0 +1,41 @@ + + + + + + + + Ketchup editor + + + + + + + + + + + + + diff --git a/packages/ketchup/src/f-components/f-cell/f-cell.tsx b/packages/ketchup/src/f-components/f-cell/f-cell.tsx index ea93fdd484..ca63878332 100644 --- a/packages/ketchup/src/f-components/f-cell/f-cell.tsx +++ b/packages/ketchup/src/f-components/f-cell/f-cell.tsx @@ -532,6 +532,7 @@ function setEditableCell( onInput={onInput} type={type} value={value} + maxLength={column.cellData?.maxLength ?? -1} > ); } else { diff --git a/packages/ketchup/src/f-components/f-progress-bar/f-progress-bar.scss b/packages/ketchup/src/f-components/f-progress-bar/f-progress-bar.scss index 50512e6cb3..aa663658d5 100644 --- a/packages/ketchup/src/f-components/f-progress-bar/f-progress-bar.scss +++ b/packages/ketchup/src/f-components/f-progress-bar/f-progress-bar.scss @@ -55,6 +55,7 @@ .progress-bar-percentage { background: var(--kup_progressbar_primary_color); border-radius: var(--kup_progressbar_border_radius); + box-sizing: content-box; color: var(--kup_progressbar_text_color); height: var(--kup_progressbar_height); padding: 0.5em 0; diff --git a/packages/ketchup/src/managers/kup-manager/kup-manager-declarations.ts b/packages/ketchup/src/managers/kup-manager/kup-manager-declarations.ts index 9eb49dc6a9..24b0828592 100644 --- a/packages/ketchup/src/managers/kup-manager/kup-manager-declarations.ts +++ b/packages/ketchup/src/managers/kup-manager/kup-manager-declarations.ts @@ -38,6 +38,7 @@ export interface KupManager { dates: KupDates; debug: KupDebug; dynamicPosition: KupDynamicPosition; + enableExperimentalFeatures: boolean; interact: KupInteract; language: KupLanguage; magicBox: HTMLKupMagicBoxElement; @@ -89,6 +90,7 @@ export interface KupManagerInitialization { autoSetLocalization?: boolean; dates?: KupManagerDatesSettings; debug?: KupManagerDebugSettings; + enableExperimentalFeatures?: boolean; interact?: KupManagerInteractSettings; language?: KupManagerLanguageSettings; math?: KupManagerMathSettings; diff --git a/packages/ketchup/src/managers/kup-manager/kup-manager.ts b/packages/ketchup/src/managers/kup-manager/kup-manager.ts index a066ee912f..79ca8ec969 100644 --- a/packages/ketchup/src/managers/kup-manager/kup-manager.ts +++ b/packages/ketchup/src/managers/kup-manager/kup-manager.ts @@ -50,6 +50,7 @@ export class KupManager { dates: KupDates; debug: KupDebug; dynamicPosition: KupDynamicPosition; + enableExperimentalFeatures: boolean; interact: KupInteract; language: KupLanguage; magicBox: HTMLKupMagicBoxElement; @@ -86,6 +87,7 @@ export class KupManager { tooltipDelay: number = null, tooltipFCellCallbacks: KupTooltipCallbacks = null; + this.enableExperimentalFeatures = false; /** POI VIA */ let openAIUrl = 'https://kokosstaging.smeup.com'; @@ -93,6 +95,8 @@ export class KupManager { const assetsPath = overrides.assetsPath; const dates = overrides.dates; const debug = overrides.debug; + const enableExperimentalFeatures = + overrides.enableExperimentalFeatures; const interact = overrides.interact; const language = overrides.language; const objects = overrides.objects; @@ -113,6 +117,9 @@ export class KupManager { debugAutoprint = debug.autoPrint ? debug.autoPrint : null; debugLogLimit = debug.logLimit ? debug.logLimit : null; } + if (enableExperimentalFeatures) { + this.enableExperimentalFeatures = enableExperimentalFeatures; + } if (interact) { dialogRestrictContainer = interact.restrictContainer ? dialogRestrictContainer diff --git a/packages/ketchup/src/managers/kup-openai/kup-openai.ts b/packages/ketchup/src/managers/kup-openai/kup-openai.ts index 047e068f1f..2df2af020e 100644 --- a/packages/ketchup/src/managers/kup-openai/kup-openai.ts +++ b/packages/ketchup/src/managers/kup-openai/kup-openai.ts @@ -66,7 +66,7 @@ export class KupOpenAI { icons: { close: true }, }; this.dialog.id = 'openai'; - this.dialog.modal = { closeOnBackdropClick: false }; + this.dialog.modal = null; this.dialog.sizeX = '50vw'; this.dialog.sizeY = '50vh'; this.dialog.addEventListener('kup-dialog-close', () => this.hide()); @@ -169,19 +169,22 @@ export class KupOpenAI { show(data: KupDataTableDataset) { this.data = data; - // Creates the card or updates it with new options - this.#create(); + if (!this.card) { + this.#create(); + } } /** * Hides the component. */ hide() { - this.card.remove(); - this.card = null; - this.dialog.remove(); - this.dialog = null; - this.#disconnect(); + if (this.card) { + this.card.remove(); + this.card = null; + this.dialog.remove(); + this.dialog = null; + this.#disconnect(); + } } async auth(event: KupTextFieldCustomEvent) { diff --git a/packages/ketchup/src/managers/kup-theme/kup-theme-application.scss b/packages/ketchup/src/managers/kup-theme/kup-theme-application.scss index cd52644c18..801d3eb029 100644 --- a/packages/ketchup/src/managers/kup-theme/kup-theme-application.scss +++ b/packages/ketchup/src/managers/kup-theme/kup-theme-application.scss @@ -1,3 +1,2363 @@ +/*-------------------------------------------------*/ +/* E d i t o r */ +/*-------------------------------------------------*/ + +$editorFont: var( + --kup-font-family, + 'Open Sans', + 'Helvetica Neue', + 'Helvetica', + 'Arial', + '나눔바른고딕', + 'Nanum Barun Gothic', + '맑은고딕', + 'Malgun Gothic', + sans-serif +); +$editorFontMono: var( + --kup-font-family-monospace, + Consolas, + Courier, + 'Lucida Grande', + '나눔바른고딕', + 'Nanum Barun Gothic', + '맑은고딕', + 'Malgun Gothic', + sans-serif +); + +kup-editor { + display: block; + + pre { + white-space: pre-wrap; + } + + .kup-editor-save-button { + color: #585858; + font-weight: 600; + margin-top: 5px; + } + + .kup-editor-save-button:disabled { + opacity: 0.2; + } + + .kup-editor-unsaved-changes { + animation: pulsealert 0.75s infinite; + border-radius: 0; + box-sizing: border-box; + color: var(--kup-primary-color); + float: left; + height: 22px; + margin: 5px 3px; + padding: 3px; + width: max-content; + } + + /*! + * @toast-ui/editor + * @version 2.5.4 | Tue Nov 30 2021 + * @author NHN FE Development Lab + * @license MIT + */ + + /* height */ + .auto-height, + .auto-height .tui-editor-defaultUI { + height: auto; + } + + .auto-height .tui-editor { + position: relative; + } + + :not(.auto-height) > .tui-editor-defaultUI, + :not(.auto-height) > .tui-editor-defaultUI > .te-editor-section { + display: -ms-flexbox; + display: flex; + -ms-flex-direction: column; + flex-direction: column; + } + + :not(.auto-height) > .tui-editor-defaultUI > .te-editor-section { + -ms-flex: 1; + flex: 1; + } + + /* tui editor */ + .tui-editor:after, + .tui-editor-defaultUI-toolbar:after { + content: ''; + display: block; + height: 0; + clear: both; + } + + .tui-editor { + position: absolute; + line-height: 1; + color: #222; + width: 100%; + height: inherit; + } + + .te-editor-section { + min-height: 0px; + position: relative; + height: inherit; + } + + .te-md-container { + display: none; + overflow: hidden; + height: 100%; + } + + .te-md-container .te-editor { + line-height: 1.5; + } + + .te-md-container .te-editor, + .te-md-container .te-preview { + box-sizing: border-box; + padding: 0; + height: inherit; + } + + .te-md-container .CodeMirror { + font-size: 13px; + height: inherit; + } + + .te-md-container .te-preview { + overflow: auto; + padding: 0 25px; + height: 100%; + } + + .te-md-container .te-preview > p:first-child { + margin-top: 0 !important; + } + + .te-md-container .te-preview .tui-editor-contents { + padding-top: 8px; + } + + .tui-editor .te-preview-style-tab > .te-editor, + .tui-editor .te-preview-style-tab > .te-preview { + float: left; + width: 100%; + display: none; + } + + .tui-editor .te-preview-style-tab > .te-tab-active { + display: block; + } + + .tui-editor .te-preview-style-vertical > .te-tab-section { + display: none; + } + + .tui-editor .te-preview-style-tab > .te-tab-section { + display: block; + } + + .tui-editor .te-preview-style-vertical .te-editor { + float: left; + width: 50%; + } + + .tui-editor .te-preview-style-vertical .te-preview { + float: left; + width: 50%; + } + + .tui-editor .te-md-splitter { + display: none; + position: absolute; + left: 50%; + top: 0; + height: 100%; + width: 1px; + border-left: 1px solid #e5e5e5; + } + + .tui-editor .te-preview-style-vertical .te-md-splitter { + display: block; + } + + .te-ww-container { + display: none; + overflow: hidden; + z-index: 10; + height: inherit; + background-color: #fff; + } + + .te-ww-container > .te-editor { + overflow: auto; + height: inherit; + } + + .te-ww-container .tui-editor-contents:focus { + outline: none; + } + + .te-ww-container .tui-editor-contents { + padding: 0 25px; + } + + .te-ww-container .tui-editor-contents:first-child { + box-sizing: border-box; + margin: 0px; + padding: 16px 25px 0px 25px; + height: inherit; + min-height: max-content !important; // Fix to prevent scrolling content even when there is nothing to scroll + } + + .te-ww-container .tui-editor-contents:last-child { + margin-bottom: 16px; + } + + .te-md-mode .te-md-container { + display: block; + z-index: 100; + } + + .te-ww-mode .te-ww-container { + display: block; + z-index: 100; + } + + .tui-editor.te-hide, + .tui-editor-defaultUI.te-hide { + display: none; + } + + .tui-editor-defaultUI .CodeMirror-lines { + padding-top: 18px; + padding-bottom: 18px; + } + + .tui-editor-defaultUI pre.CodeMirror-line { + padding-left: 25px; + padding-right: 25px; + } + + .tui-editor-defaultUI .CodeMirror pre.CodeMirror-placeholder { + margin: 0; + padding-left: 25px; + color: grey; + } + + .tui-editor-defaultUI .CodeMirror-scroll { + cursor: text; + } + + /* Essential element style */ + .tui-editor-contents td.te-cell-selected { + background-color: #d8dfec; + } + .tui-editor-contents td.te-cell-selected::selection { + background-color: #d8dfec; + } + .tui-editor-contents th.te-cell-selected { + background-color: #908f8f; + } + .tui-editor-contents th.te-cell-selected::selection { + background-color: #908f8f; + } + + /* default UI Styles */ + .tui-editor-defaultUI { + position: relative; + border: 1px solid #e5e5e5; + height: 100%; + font-family: $editorFont; + } + + .tui-editor-defaultUI button { + color: #fff; + padding: 0px 14px 0px 15px; + height: 28px; + font-size: 12px; + border: none; + cursor: pointer; + outline: none; + } + .tui-editor-defaultUI button.te-ok-button { + background-color: #4b96e6; + } + .tui-editor-defaultUI button.te-close-button { + background-color: #777; + } + + .tui-editor-defaultUI-toolbar { + padding: 0 25px; + height: 31px; + background-color: #fff; + border: 0; + overflow: hidden; + } + + .tui-toolbar-divider { + float: left; + display: inline-block; + width: 1px; + height: 14px; + background-color: #ddd; + margin: 9px 6px; + } + + .tui-toolbar-button-group { + height: 28px; + border-right: 1px solid #d9d9d9; + float: left; + } + + .te-toolbar-section { + height: 32px; + box-sizing: border-box; + border-bottom: 1px solid #e5e5e5; + } + + .tui-editor-defaultUI-toolbar button { + float: left; + box-sizing: border-box; + outline: none; + cursor: pointer; + background-color: #fff; + width: 22px; + height: 22px; + padding: 3px; + border-radius: 0; + margin: 5px 3px; + border: 1px solid #fff; + } + + .tui-editor-defaultUI-toolbar button:hover, + .tui-editor-defaultUI-toolbar button:active, + .tui-editor-defaultUI-toolbar button.active { + border: 1px solid #aaa; + background-color: #fff; + } + + .tui-editor-defaultUI-toolbar button:first-child { + margin-left: 0; + } + + .tui-editor-defaultUI-toolbar button:last-child { + margin-right: 0; + } + + .tui-editor-defaultUI-toolbar button.tui-scrollsync { + width: auto; + color: #777777; + border: 0; + } + + .tui-editor-defaultUI button.tui-scrollsync:after { + content: 'Scroll off'; + } + + .tui-editor-defaultUI button.tui-scrollsync.active { + color: #4b96e6; + font-weight: bold; + } + + .tui-editor-defaultUI button.tui-scrollsync.active:after { + content: 'Scroll on'; + } + + .tui-editor-defaultUI .te-mode-switch-section { + background-color: #f9f9f9; + border-top: 1px solid #e5e5e5; + height: 20px; + font-size: 12px; + } + + .tui-editor-defaultUI .te-mode-switch { + float: right; + height: 100%; + } + + .tui-editor-defaultUI .te-switch-button { + width: 92px; + height: inherit; + background: #e5e5e5; + outline: 0; + color: #a0aabf; + cursor: pointer; + border: 0; + border-left: 1px solid #ddd; + border-right: 1px solid #ddd; + } + + .tui-editor-defaultUI .te-switch-button.active { + background-color: #fff; + color: #000; + } + + .tui-editor-defaultUI .te-markdown-tab-section { + float: left; + height: 31px; + background: #fff; + } + + .te-markdown-tab-section .te-tab { + margin: 0 -7px 0 24px; + background: #fff; + } + + .tui-editor-defaultUI .te-tab button { + box-sizing: border-box; + line-height: 100%; + position: relative; + cursor: pointer; + z-index: 1; + font-size: 13px; + background-color: #f9f9f9; + border: solid 1px #e5e5e5; + border-top: 0; + padding: 0 9px; + color: #777; + border-radius: 0; + outline: 0; + } + + .te-markdown-tab-section .te-tab button:last-child { + margin-left: -1px; + } + + .te-markdown-tab-section .te-tab button.te-tab-active, + .te-markdown-tab-section .te-tab button:hover.te-tab-active { + background-color: #fff; + color: #333; + border-bottom: 1px solid #fff; + z-index: 2; + } + + .te-markdown-tab-section .te-tab button:hover { + background-color: #fff; + color: #333; + } + + .tui-popup-modal-background { + background-color: rgba(202, 202, 202, 0.6); + position: fixed; + margin: 0px; + left: 0px; + top: 0px; + width: 100%; + height: 100%; + z-index: 9999; + } + + .tui-popup-wrapper.fit-window, + .tui-popup-modal-background.fit-window .tui-popup-wrapper { + width: 100%; + height: 100%; + } + + .tui-popup-wrapper { + width: 500px; + margin-right: auto; + border: 1px solid #cacaca; + background: white; + z-index: 9999; + } + + .tui-popup-modal-background .tui-popup-wrapper { + position: absolute; + margin: auto; + top: 0px; + right: 0px; + bottom: 0px; + left: 0px; + } + + .tui-popup-header { + padding: 10px; + height: auto; + line-height: normal; + position: relative; + border-bottom: 1px solid #cacaca; + } + + .tui-popup-header .tui-popup-header-buttons { + float: right; + } + + .tui-popup-header .tui-popup-header-buttons button { + padding: 0px; + background-color: transparent; + background-size: cover; + float: left; + } + + .tui-popup-header .tui-popup-close-button { + margin: 3px; + width: 13px; + height: 13px; + background-image: url(); + } + + .tui-popup-header .tui-popup-title { + font-size: 13px; + font-weight: bold; + color: #333; + vertical-align: bottom; + } + + .tui-popup-body { + padding: 15px; + font-size: 12px; + } + + .tui-editor-popup { + position: absolute; + top: 30px; + left: 50%; + margin-left: -250px; + } + + .tui-editor-popup.tui-popup-modal-background { + position: fixed; + top: 0px; + left: 0px; + margin: 0px; + } + + .tui-editor-popup .tui-popup-body label { + font-weight: bold; + color: #666; + display: block; + margin: 10px 0 5px; + } + + .tui-editor-popup .tui-popup-body .te-button-section { + margin-top: 15px; + } + + .tui-editor-popup .tui-popup-body input[type='text'], + .tui-editor-popup .tui-popup-body input[type='file'] { + padding: 4px 10px; + border: 1px solid #bfbfbf; + box-sizing: border-box; + width: 100%; + } + + .tui-editor-popup .tui-popup-body input[type='text'].disabled { + border-color: #e5e5e5; + background-color: #eee; + color: #e5e5e5; + } + + .tui-editor-popup .tui-popup-body input.wrong { + border-color: #ff0000; + } + + .te-popup-add-link .tui-popup-wrapper { + height: 219px; + } + + .te-popup-add-image .tui-popup-wrapper { + height: 243px; + } + + .te-popup-add-image .te-tab { + display: block; + background: none; + border-bottom: 1px solid #ebebeb; + margin-bottom: 8px; + } + + .te-popup-add-image .te-url-type { + display: none; + } + + .te-popup-add-image .te-file-type { + display: none; + } + + .te-popup-add-image div.te-tab-active, + .te-popup-add-image form.te-tab-active { + display: block; + } + + .te-popup-add-image .te-tab button { + border: 1px solid #ccc; + background: #eee; + min-width: 100px; + margin-left: -1px; + border-bottom: 0px; + border-radius: 3px 3px 0px 0px; + } + + .te-popup-add-image .te-tab button.te-tab-active { + background: #fff; + } + + .te-popup-add-table .te-table-selection { + position: relative; + } + + .te-popup-add-table .te-table-body { + background-image: url(''); + } + + .te-popup-add-table .te-table-header { + background-image: url(''); + } + + .te-popup-add-table .te-selection-area { + position: absolute; + top: 0; + left: 0; + background: #80d2ff; + opacity: 0.3; + z-index: 999; + } + + .te-popup-add-table .te-description { + margin: 10px 0 0 0; + text-align: center; + } + + .te-popup-table-utils { + width: auto; + min-width: 120px; + } + + .te-popup-table-utils .tui-popup-body { + padding: 0px; + } + + .te-popup-table-utils button { + display: block; + width: 100%; + background-color: #fff; + border: none; + outline: 0; + padding: 0px 10px 0px 10px; + font-size: 12px; + line-height: 28px; + text-align: left; + color: #777; + } + + .te-popup-table-utils button:hover { + background-color: #f4f4f4; + } + + .te-popup-table-utils hr { + margin: 0; + background-color: #cacaca; + border-style: none; + height: 1px; + } + + .te-popup-table-utils .te-context-menu-disabled { + color: #ccc; + } + + .te-popup-table-utils .te-context-menu-disabled:hover { + background-color: #fff; + } + + .te-heading-add { + width: auto; + } + + .te-heading-add .tui-popup-body { + padding: 0; + } + + .te-heading-add h1, + .te-heading-add h2, + .te-heading-add h3, + .te-heading-add h4, + .te-heading-add h5, + .te-heading-add h6, + .te-heading-add ul, + .te-heading-add p { + padding: 0; + margin: 0; + } + + .te-heading-add ul { + list-style: none; + } + + .te-heading-add ul li { + padding: 2px 10px; + cursor: pointer; + } + + .te-heading-add ul li:hover { + background-color: #eee; + } + + .te-heading-add h1 { + font-size: 24px; + } + + .te-heading-add h2 { + font-size: 22px; + } + + .te-heading-add h3 { + font-size: 20px; + } + + .te-heading-add h4 { + font-size: 18px; + } + + .te-heading-add h5 { + font-size: 16px; + } + + .te-heading-add h6 { + font-size: 14px; + } + + .te-dropdown-toolbar { + position: absolute; + width: auto; + } + + .te-dropdown-toolbar .tui-popup-body { + padding: 0px; + } + + .tui-popup-color { + padding: 0; + } + + .tui-popup-color .tui-colorpicker-container, + .tui-popup-color .tui-colorpicker-palette-container { + width: 144px; + } + + .tui-popup-color .tui-colorpicker-container ul { + width: 144px; + margin-bottom: 8px; + } + + .tui-popup-color .tui-colorpicker-container li { + padding: 0 1px 1px 0; + } + + .tui-popup-color + .tui-colorpicker-container + li + .tui-colorpicker-palette-button { + border: 0; + width: 17px; + height: 17px; + } + + .tui-popup-color .tui-popup-body { + padding: 10px; + } + + .tui-popup-color + .tui-colorpicker-container + .tui-colorpicker-palette-toggle-slider { + display: none; + } + + .tui-popup-color .te-apply-button, + .tui-popup-color .tui-colorpicker-palette-hex { + float: right; + } + + .tui-popup-color .te-apply-button { + height: 21px; + width: 35px; + background: #fff; + border: 1px solid #efefef; + position: absolute; + bottom: 135px; + right: 10px; + color: black; + } + + .tui-popup-color .tui-colorpicker-container .tui-colorpicker-palette-hex { + border: 1px solid #e1e1e1; + padding: 3px 14px; + margin-left: -1px; + } + + .tui-popup-color .tui-colorpicker-container div.tui-colorpicker-clearfix { + display: inline-block; + } + + .tui-popup-color .tui-colorpicker-container .tui-colorpicker-palette-preview { + width: 19px; + height: 19px; + } + + .tui-popup-color + .tui-colorpicker-slider-container + .tui-colorpicker-slider-right { + width: 22px; + } + + .tui-popup-color + .tui-colorpicker-slider-container + .tui-colorpicker-huebar-handle { + display: none; + } + + .tui-toolbar-icons { + background: url(); + background-size: 218px 188px; + display: inline-block; + } + + @media only screen and (-webkit-min-device-pixel-ratio: 2), + only screen and (min--moz-device-pixel-ratio: 2), + only screen and (-o-min-device-pixel-ratio: 2/1), + only screen and (min-device-pixel-ratio: 2), + only screen and (min-resolution: 192dpi), + only screen and (min-resolution: 2dppx) { + .tui-toolbar-icons { + background: url(); + background-size: 218px 188px; + display: inline-block; + } + } + + .tui-toolbar-icons.tui-heading { + background-position: -172px -48px; + } + + .tui-toolbar-icons.tui-heading:disabled { + background-position: -193px -48px; + } + + .tui-toolbar-icons.tui-bold { + background-position: -4px -4px; + } + + .tui-toolbar-icons.tui-bold:disabled { + background-position: -25px -4px; + } + + .tui-toolbar-icons.tui-italic { + background-position: -4px -48px; + } + + .tui-toolbar-icons.tui-italic:disabled { + background-position: -25px -48px; + } + + .tui-toolbar-icons.tui-color { + background-position: -172px -70px; + } + + .tui-toolbar-icons.tui-color:disabled { + background-position: -193px -70px; + } + + .tui-toolbar-icons.tui-strike { + background-position: -4px -26px; + } + + .tui-toolbar-icons.tui-strike:disabled { + background-position: -25px -26px; + } + + .tui-toolbar-icons.tui-hrline { + background-position: -46px -92px; + } + + .tui-toolbar-icons.tui-hrline:disabled { + background-position: -67px -92px; + } + + .tui-toolbar-icons.tui-quote { + background-position: -4px -114px; + } + + .tui-toolbar-icons.tui-quote:disabled { + background-position: -25px -114px; + } + + .tui-toolbar-icons.tui-ul { + background-position: -46px -4px; + } + + .tui-toolbar-icons.tui-ul:disabled { + background-position: -67px -4px; + } + + .tui-toolbar-icons.tui-ol { + background-position: -46px -26px; + } + + .tui-toolbar-icons.tui-ol:disabled { + background-position: -67px -26px; + } + + .tui-toolbar-icons.tui-task { + background-position: -130px -48px; + } + + .tui-toolbar-icons.tui-task:disabled { + background-position: -151px -48px; + } + + .tui-toolbar-icons.tui-indent { + background-position: -46px -48px; + } + + .tui-toolbar-icons.tui-indent:disabled { + background-position: -67px -48px; + } + + .tui-toolbar-icons.tui-outdent { + background-position: -46px -70px; + } + + .tui-toolbar-icons.tui-outdent:disabled { + background-position: -67px -70px; + } + + .tui-toolbar-icons.tui-table { + background-position: -88px -92px; + } + + .tui-toolbar-icons.tui-table:disabled { + background-position: -109px -92px; + } + + .tui-toolbar-icons.tui-image { + background-position: -130px -4px; + } + + .tui-toolbar-icons.tui-image:disabled { + background-position: -151px -4px; + } + + .tui-toolbar-icons.tui-link { + background-position: -130px -26px; + } + + .tui-toolbar-icons.tui-link:disabled { + background-position: -151px -26px; + } + + .tui-toolbar-icons.tui-code { + background-position: -130px -92px; + } + + .tui-toolbar-icons.tui-code:disabled { + background-position: -151px -92px; + } + + .tui-toolbar-icons.tui-codeblock { + background-position: -130px -70px; + } + + .tui-toolbar-icons.tui-codeblock:disabled { + background-position: -151px -70px; + } + + .tui-toolbar-icons.tui-more { + background-position: -172px -92px; + } + + .tui-toolbar-icons.tui-more:disabled { + background-position: -193px -92px; + } + .tui-colorpicker-svg-slider { + border: 1px solid #ebebeb; + } + .tui-colorpicker-vml-slider { + border: 1px solid #ebebeb; + } + .tui-colorpicker-svg-huebar { + border: 1px solid #ebebeb; + } + + .tui-editor-pseudo-clipboard { + position: fixed; + left: -1000px; + top: -1000px; + width: 100px; + height: 100px; + } + + .te-ww-block-overlay.code-block-header { + text-align: right; + font-family: $editorFont; + } + + .te-ww-block-overlay.code-block-header span { + font-size: 10px; + font-weight: 600; + padding: 0px 10px; + color: #333333; + cursor: default; + } + + .te-ww-block-overlay.code-block-header button { + margin: 8px; + font-size: 10px; + color: #333333; + background-color: #f9f9f9; + border: 1px solid #dddddd; + padding: 4px; + height: auto; + } + + .te-popup-code-block-languages { + position: fixed; + box-sizing: border-box; + width: 130px; + } + + .te-popup-code-block-languages .tui-popup-body { + max-height: 169px; + overflow: auto; + padding: 0px; + } + + .te-popup-code-block-languages button { + width: 100%; + background-color: #fff; + border: none; + outline: 0; + padding: 0px 10px 0px 10px; + font-size: 12px; + line-height: 24px; + text-align: left; + color: #777; + } + + .te-popup-code-block-languages button.active { + background-color: #f4f4f4; + } + + .tui-popup-code-block-editor .tui-popup-wrapper { + width: 70%; + height: 70%; + margin: auto; + display: -ms-flexbox; + display: flex; + -ms-flex-direction: column; + flex-direction: column; + } + + .te-input-language { + position: relative; + margin-left: 15px; + cursor: pointer; + } + + .te-input-language input { + font-family: $editorFont; + font-size: 10px; + padding: 3px 5px; + border: 1px solid #dddddd; + background-color: #f9f9f9; + box-sizing: border-box; + width: 130px; + outline: none; + } + + .te-input-language input::-ms-clear { + display: none; + } + + .te-input-language::after { + content: url(); + position: absolute; + top: 1px; + right: 3px; + } + + .te-input-language.active::after { + content: url(); + } + + .tui-popup-code-block-editor button { + margin: -1px 3px; + } + + .tui-popup-code-block-editor .tui-popup-header-buttons { + height: 20px; + } + + .tui-popup-code-block-editor .popup-editor-toggle-preview::after { + content: 'Preview off'; + color: #777; + margin-right: 22px; + } + + .tui-popup-code-block-editor .popup-editor-toggle-preview.active::after { + content: 'Preview on'; + color: #4b96e6; + } + + .tui-popup-code-block-editor .popup-editor-toggle-scroll::after { + content: 'Scroll off'; + color: #777; + margin-right: 16px; + } + + .tui-popup-code-block-editor .popup-editor-toggle-scroll.active::after { + content: 'Scroll on'; + color: #4b96e6; + } + + .tui-popup-code-block-editor .popup-editor-toggle-fit { + width: 18px; + height: 18px; + margin-top: 4px; + margin-right: 14px; + background-image: url(); + } + + .tui-popup-code-block-editor .popup-editor-toggle-fit.active { + background-image: url(); + } + + .tui-popup-code-block-editor .tui-popup-close-button { + margin-top: 6px; + } + + .tui-popup-code-block-editor .tui-popup-body { + z-index: -1; + padding: 0px; + display: -ms-flexbox; + display: flex; + -ms-flex-direction: column; + flex-direction: column; + -ms-flex: 1; + flex: 1; + } + + .tui-popup-code-block-editor .popup-editor-body { + position: relative; + -ms-flex: 1; + flex: 1; + border-bottom: 1px solid #cacaca; + } + + .tui-popup-code-block-editor .te-button-section { + padding: 15px; + } + + .tui-popup-code-block-editor .te-button-section button { + float: left; + } + + .tui-popup-code-block-editor .tui-editor-contents pre { + margin: 0px; + background-color: transparent; + } + + .tui-popup-code-block-editor .CodeMirror { + height: auto; + } + + .tui-popup-code-block-editor .CodeMirror-line { + font-family: $editorFontMono; + font-size: 13px; + line-height: 160%; + letter-spacing: -0.3px; + } + + .tui-popup-code-block-editor .popup-editor-editor-wrapper { + min-height: 100%; + } + + .tui-split-scroll-wrapper { + position: relative; + } + + .tui-split-scroll { + position: absolute; + } + + .tui-split-scroll, + .tui-split-scroll-wrapper { + width: 100%; + height: 100%; + } + + .tui-split-scroll .tui-split-content-left, + .tui-split-scroll .tui-split-content-right { + position: absolute; + top: 0px; + width: 50%; + box-sizing: border-box; + } + + .tui-split-scroll .tui-split-content-left { + left: 0px; + } + + .tui-split-scroll .tui-split-content-right { + left: 50%; + } + + .tui-split-scroll .tui-splitter { + position: absolute; + left: 50%; + top: 0; + height: 100%; + width: 1px; + border-left: 1px solid #cacaca; + } + + .tui-split-scroll .tui-split-scroll-content { + width: 100%; + height: 100%; + overflow: hidden; + position: relative; + } + + .tui-split-scroll .tui-split-content-left, + .tui-split-scroll .tui-split-content-right { + height: 100%; + overflow-x: hidden; + overflow-y: auto; + } + + .tui-split-scroll button.tui-scrollsync { + top: 10px; + opacity: 0.2; + } + + .tui-split-scroll button.tui-scrollsync::after { + content: 'scroll off'; + } + + .tui-split-scroll.scroll-sync button.tui-scrollsync { + opacity: 0.5; + } + + .tui-split-scroll.scroll-sync .tui-split-content-left, + .tui-split-scroll.scroll-sync .tui-split-content-right { + height: auto; + overflow: initial; + } + + .tui-split-scroll.scroll-sync button.tui-scrollsync::after { + content: 'scroll on'; + } + + .tui-split-scroll.scroll-sync .tui-split-scroll-content { + overflow-y: auto; + } + + .tui-split-scroll.single-content .tui-splitter { + display: none; + } + + .tui-split-scroll.single-content .tui-split-content-left { + width: 100%; + } + + .tui-split-scroll.single-content .tui-split-content-right { + display: none; + } + + .tui-split-scroll.single-content button.tui-scrollsync { + display: none; + } + + @media all and (-ms-high-contrast: none), (-ms-high-contrast: active) { + /* IE10+ */ + .tui-split-scroll-wrapper .tui-splitter { + left: calc(50% - 9px); + } + } + + @supports (-ms-accelerator: true) { + /* IE Edge 12+ CSS styles go here */ + .tui-split-scroll-wrapper .tui-splitter { + left: calc(50% - 9px); + } + } + + @media screen and (max-width: 480px) { + .tui-popup-wrapper { + max-width: 300px; + } + + .tui-editor-popup { + margin-left: -150px; + } + + .te-dropdown-toolbar { + max-width: none; + } + } + + .tui-editor-contents { + margin: 0; + padding: 0; + font-size: 13px; + font-family: $editorFont; + } + + .tui-editor-contents *:not(table) { + line-height: 160%; + box-sizing: content-box; + } + + .tui-editor-contents i, + .tui-editor-contents cite, + .tui-editor-contents em, + .tui-editor-contents var, + .tui-editor-contents address, + .tui-editor-contents dfn { + font-style: italic; + } + + .tui-editor-contents strong { + font-weight: bold; + } + + .tui-editor-contents p { + margin: 10px 0; + color: #222; + } + + .tui-editor-contents > h1:first-of-type, + .tui-editor-contents > div > div:first-of-type h1 { + margin-top: 14px; + } + + .tui-editor-contents h1, + .tui-editor-contents h2, + .tui-editor-contents h3, + .tui-editor-contents h4, + .tui-editor-contents h5, + .tui-editor-contents h6 { + font-weight: bold; + color: #222; + } + + .tui-editor-contents h1 { + font-size: 24px; + line-height: 28px; + border-bottom: 3px double #999; + margin: 52px 0 15px 0; + padding-bottom: 7px; + } + + .tui-editor-contents h2 { + font-size: 22px; + line-height: 23px; + border-bottom: 1px solid #dbdbdb; + margin: 20px 0 13px 0; + padding-bottom: 7px; + } + + .tui-editor-contents h3 { + font-size: 20px; + margin: 18px 0 2px; + } + + .tui-editor-contents h4 { + font-size: 18px; + margin: 10px 0 2px; + } + + .tui-editor-contents h3, + .tui-editor-contents h4 { + line-height: 18px; + } + + .tui-editor-contents h5 { + font-size: 16px; + } + + .tui-editor-contents h6 { + font-size: 14px; + } + + .tui-editor-contents h5, + .tui-editor-contents h6 { + line-height: 17px; + margin: 9px 0 -4px; + } + + .tui-editor-contents del { + color: #999; + } + + .tui-editor-contents blockquote { + margin: 14px 0; + border-left: 4px solid #e5e5e5; + padding: 0 16px; + color: #999; + } + + .tui-editor-contents blockquote p, + .tui-editor-contents blockquote ul, + .tui-editor-contents blockquote ol { + color: #999; + } + + .tui-editor-contents blockquote > :first-child { + margin-top: 0; + } + + .tui-editor-contents blockquote > :last-child { + margin-bottom: 0; + } + + .tui-editor-contents pre, + .tui-editor-contents code { + font-family: $editorFontMono; + border: 0; + border-radius: 0; + } + + .tui-editor-contents pre { + margin: 2px 0 8px; + padding: 18px; + background-color: #f5f7f8; + } + + .tui-editor-contents code { + color: #c1798b; + background-color: #f9f2f4; + padding: 2px 3px; + letter-spacing: -0.3px; + border-radius: 2px; + } + + .tui-editor-contents pre code { + padding: 0; + color: inherit; + white-space: pre-wrap; + background-color: transparent; + } + + .tui-editor-contents pre.addon { + border: 1px solid #e8ebed; + background-color: #fff; + } + + .tui-editor-contents img { + margin: 4px 0 10px; + box-sizing: border-box; + vertical-align: top; + max-width: 100%; + } + + .tui-editor-contents table { + border: 1px solid rgba(0, 0, 0, 0.1); + margin: 12px 0 14px; + color: #222; + width: auto; + border-collapse: collapse; + box-sizing: border-box; + } + + .tui-editor-contents table th, + .tui-editor-contents table td { + border: 1px solid rgba(0, 0, 0, 0.1); + padding: 5px 14px 5px 12px; + height: 32px; + } + + .tui-editor-contents table th { + background-color: #555; + font-weight: 300; + color: #fff; + padding-top: 6px; + } + + .tui-editor-contents ul, + .tui-editor-contents menu, + .tui-editor-contents ol, + .tui-editor-contents dir { + display: block; + list-style-type: none; + padding-left: 24px; + margin: 6px 0 10px; + color: #222; + } + + .tui-editor-contents ol { + list-style-type: none; + counter-reset: li; + } + + .tui-editor-contents ol > li { + counter-increment: li; + } + + .tui-editor-contents ul > li::before, + .tui-editor-contents ol > li::before { + display: inline-block; + position: absolute; + } + + .tui-editor-contents ul > li::before { + content: ''; + margin-top: 6px; + margin-left: -17px; + width: 5px; + height: 5px; + border-radius: 50%; + background-color: #ccc; + } + + .tui-editor-contents ol > li::before { + content: '.' counter(li); + margin-left: -28px; + width: 24px; + text-align: right; + direction: rtl; + color: #aaa; + } + + .tui-editor-contents ul ul, + .tui-editor-contents ul ol, + .tui-editor-contents ol ol, + .tui-editor-contents ol ul { + margin-top: 0 !important; + margin-bottom: 0 !important; + } + + .tui-editor-contents ul li, + .tui-editor-contents ol li { + position: relative; + } + + .tui-editor-contents ul p, + .tui-editor-contents ol p { + margin: 0; + } + + .tui-editor-contents ul li.task-list-item::before, + .tui-editor-contents ol li.task-list-item::before, + .tui-editor-contents pre ul li::before { + content: ''; + } + + .tui-editor-contents th ol, + .tui-editor-contents th ul { + color: #fff; + } + + .tui-editor-contents hr { + border-top: 1px solid #eee; + margin: 16px 0; + } + + .tui-editor-contents a { + text-decoration: underline; + color: #4b96e6; + } + + .tui-editor-contents a:hover { + color: #1f70de; + } + + .tui-editor-contents a.image-link { + position: relative; + } + + .tui-editor-contents a.image-link::before { + content: ''; + position: absolute; + margin: 0; + width: 20px; + height: 20px; + top: 2px; + right: 2px; + background-repeat: no-repeat; + background-image: url(''); + cursor: pointer; + } + + .tui-editor-contents .task-list-item { + border: 0; + list-style: none; + padding-left: 24px; + margin-left: -24px; + } + + .tui-editor-contents .task-list-item::before { + background-repeat: no-repeat; + background-size: 18px 18px; + background-position: center; + content: ''; + margin-left: 0; + margin-top: 0; + border-radius: 0; + height: 18px; + width: 18px; + position: absolute; + left: 0; + top: 1px; + cursor: pointer; + background-image: url(''); + } + + .tui-editor-contents .task-list-item.checked::before { + background-image: url(''); + } + + .tui-editor-contents .task-list-item input[type='checkbox'], + .tui-editor-contents .task-list-item .task-list-item-checkbox { + margin-left: -17px; + margin-right: 3.8px; + margin-top: 3px; + } + + .tui-editor-contents-placeholder::before { + content: attr(data-placeholder); + color: grey; + line-height: 160%; + position: absolute; + } + + .te-preview .tui-editor-contents h1 { + min-height: 28px; + } + + .te-preview .tui-editor-contents h2 { + min-height: 23px; + } + + .te-preview .tui-editor-contents blockquote { + min-height: 20px; + } + + .te-preview .tui-editor-contents li { + min-height: 22px; + } + + @media all and (-ms-high-contrast: none), (-ms-high-contrast: active) { + /* IE10+11 */ + .te-ww-container .tui-editor-contents li { + vertical-align: middle; + } + + .te-ww-container .tui-editor-contents ul > li::before, + .te-ww-container .tui-editor-contents ol > li::before, + .te-ww-container .tui-editor-contents .task-list-item:before { + position: static; + vertical-align: middle; + } + + .te-ww-container .tui-editor-contents ul > li::before { + margin-top: -3px; + margin-right: 12px; + } + + .te-ww-container .tui-editor-contents ol > li::before { + margin-right: 6px; + } + + .te-ww-container .tui-editor-contents .task-list-item { + padding-left: 2px; + } + } + + .tui-editor-contents .te-preview-highlight { + position: relative; + z-index: 0; + } + + .tui-editor-contents .te-preview-highlight::after { + content: ''; + background-color: rgba(255, 245, 131, 0.5); + border-radius: 4px; + z-index: -1; + position: absolute; + top: -4px; + right: -4px; + left: -4px; + bottom: -4px; + } + + .tui-editor-contents h1.te-preview-highlight::after, + .tui-editor-contents h2.te-preview-highlight::after { + bottom: 0; + } + + .tui-editor-contents td.te-preview-highlight::after, + .tui-editor-contents th.te-preview-highlight::after { + display: none; + } + + .tui-editor-contents th.te-preview-highlight, + .tui-editor-contents td.te-preview-highlight { + background-color: rgba(255, 245, 131, 0.5); + } + + .tui-editor-contents th.te-preview-highlight { + color: #222; + } + + .te-md-container .CodeMirror { + font-family: $editorFont; + color: #222; + } + + .tui-md-heading1 { + font-size: 24px; + } + + .tui-md-heading2 { + font-size: 22px; + } + + .tui-md-heading3 { + font-size: 20px; + } + + .tui-md-heading4 { + font-size: 18px; + } + + .tui-md-heading5 { + font-size: 16px; + } + + .tui-md-heading6 { + font-size: 14px; + } + + .tui-md-heading.tui-md-delimiter.setext { + line-height: 15px; + } + + .tui-md-strong, + .tui-md-heading, + .tui-md-list-item.tui-md-list-item-bullet, + .tui-md-list-item.tui-md-meta { + font-weight: bold; + } + + .tui-md-emph { + font-style: italic; + } + + .tui-md-strike { + text-decoration: line-through; + } + + .tui-md-strike.tui-md-delimiter { + text-decoration: none; + } + + .tui-md-delimiter, + .tui-md-thematic-break, + .tui-md-link, + .tui-md-table, + .tui-md-block-quote { + color: #ccc; + } + + .tui-md-code-block.tui-md-meta, + .tui-md-code.tui-md-delimiter { + color: #aaa; + } + + .tui-md-meta, + .tui-md-html, + .tui-md-link.tui-md-link-url.tui-md-marked-text { + color: #999; + } + + .tui-md-block-quote.tui-md-marked-text, + .tui-md-list-item.tui-md-meta { + color: #555; + } + + .tui-md-table.tui-md-marked-text { + color: #222; + } + + .tui-md-link.tui-md-link-desc.tui-md-marked-text, + .tui-md-list-item-odd.tui-md-list-item-bullet { + color: #4b96e6; + } + + .tui-md-list-item-even.tui-md-list-item-bullet { + color: #cb4848; + } + + .tui-md-code.tui-md-marked-text { + color: #c1798b; + } + + .tui-md-code { + background-color: rgba(243, 229, 233, 0.5); + padding: 2px 0; + letter-spacing: -0.3px; + } + + .tui-md-code.tui-md-delimiter.start { + padding-left: 2px; + border-top-left-radius: 2px; + border-bottom-left-radius: 2px; + } + + .tui-md-code.tui-md-delimiter.end { + padding-right: 2px; + border-top-right-radius: 2px; + border-bottom-right-radius: 2px; + } + + .tui-md-code-block.CodeMirror-linebackground { + left: 20px; + right: 20px; + background-color: #f5f7f8; + } + + .tui-md-code-block.CodeMirror-linebackground.start { + top: 2px; + } + + .tui-md-code-block.CodeMirror-linebackground.end { + bottom: 2px; + } + + .tui-md-code, + .tui-md-code-block { + font-family: $editorFontMono; + } + /* BASICS */ + + .CodeMirror { + /* Set height, width, borders, and global font properties here */ + font-family: $editorFontMono; + height: 300px; + color: black; + direction: ltr; + } + + /* PADDING */ + + .CodeMirror-lines { + padding: 4px 0; /* Vertical padding around content */ + } + .CodeMirror pre.CodeMirror-line, + .CodeMirror pre.CodeMirror-line-like { + padding: 0 4px; /* Horizontal padding of content */ + } + + .CodeMirror-scrollbar-filler, + .CodeMirror-gutter-filler { + background-color: white; /* The little square between H and V scrollbars */ + } + + /* GUTTER */ + + .CodeMirror-gutters { + border-right: 1px solid #ddd; + background-color: #f7f7f7; + white-space: nowrap; + } + .CodeMirror-linenumber { + padding: 0 3px 0 5px; + min-width: 20px; + text-align: right; + color: #999; + white-space: nowrap; + } + + .CodeMirror-guttermarker { + color: black; + } + .CodeMirror-guttermarker-subtle { + color: #999; + } + + /* CURSOR */ + + .CodeMirror-cursor { + border-left: 1px solid black; + border-right: none; + width: 0; + } + /* Shown when moving in bi-directional text */ + .CodeMirror div.CodeMirror-secondarycursor { + border-left: 1px solid silver; + } + .cm-fat-cursor .CodeMirror-cursor { + width: auto; + border: 0 !important; + background: #7e7; + } + .cm-fat-cursor div.CodeMirror-cursors { + z-index: 1; + } + .cm-fat-cursor .CodeMirror-line::selection, + .cm-fat-cursor .CodeMirror-line > span::selection, + .cm-fat-cursor .CodeMirror-line > span > span::selection { + background: transparent; + } + .cm-fat-cursor .CodeMirror-line::-moz-selection, + .cm-fat-cursor .CodeMirror-line > span::-moz-selection, + .cm-fat-cursor .CodeMirror-line > span > span::-moz-selection { + background: transparent; + } + .cm-fat-cursor { + caret-color: transparent; + } + @-moz-keyframes blink { + 0% { + } + 50% { + background-color: transparent; + } + 100% { + } + } + @-webkit-keyframes blink { + 0% { + } + 50% { + background-color: transparent; + } + 100% { + } + } + @keyframes blink { + 0% { + } + 50% { + background-color: transparent; + } + 100% { + } + } + + .cm-tab { + display: inline-block; + text-decoration: inherit; + } + + .CodeMirror-rulers { + position: absolute; + left: 0; + right: 0; + top: -50px; + bottom: 0; + overflow: hidden; + } + .CodeMirror-ruler { + border-left: 1px solid #ccc; + top: 0; + bottom: 0; + position: absolute; + } + + /* DEFAULT THEME */ + + .cm-s-default .cm-header { + color: blue; + } + .cm-s-default .cm-quote { + color: #090; + } + .cm-negative { + color: #d44; + } + .cm-positive { + color: #292; + } + .cm-header, + .cm-strong { + font-weight: bold; + } + .cm-em { + font-style: italic; + } + .cm-link { + text-decoration: underline; + } + .cm-strikethrough { + text-decoration: line-through; + } + + .cm-s-default .cm-keyword { + color: #708; + } + .cm-s-default .cm-atom { + color: #219; + } + .cm-s-default .cm-number { + color: #164; + } + .cm-s-default .cm-def { + color: #00f; + } + .cm-s-default .cm-variable-2 { + color: #05a; + } + .cm-s-default .cm-variable-3, + .cm-s-default .cm-type { + color: #085; + } + .cm-s-default .cm-comment { + color: #a50; + } + .cm-s-default .cm-string { + color: #a11; + } + .cm-s-default .cm-string-2 { + color: #f50; + } + .cm-s-default .cm-meta { + color: #555; + } + .cm-s-default .cm-qualifier { + color: #555; + } + .cm-s-default .cm-builtin { + color: #30a; + } + .cm-s-default .cm-bracket { + color: #997; + } + .cm-s-default .cm-tag { + color: #170; + } + .cm-s-default .cm-attribute { + color: #00c; + } + .cm-s-default .cm-hr { + color: #999; + } + .cm-s-default .cm-link { + color: #00c; + } + + .cm-s-default .cm-error { + color: #f00; + } + .cm-invalidchar { + color: #f00; + } + + .CodeMirror-composing { + border-bottom: 2px solid; + } + + /* Default styles for common addons */ + + div.CodeMirror span.CodeMirror-matchingbracket { + color: #0b0; + } + div.CodeMirror span.CodeMirror-nonmatchingbracket { + color: #a22; + } + .CodeMirror-matchingtag { + background: rgba(255, 150, 0, 0.3); + } + .CodeMirror-activeline-background { + background: #e8f2ff; + } + + /* STOP */ + + /* The rest of this file contains styles related to the mechanics of + the editor. You probably shouldn't touch them. */ + + .CodeMirror { + background: white; + min-height: auto !important; // Search "PHINDFIX" for the explanation + overflow: hidden; + position: relative; + } + + /* +PHINDFIX +ANSWER | PHIND V9 MODEL +Yes, Toast UI Editor applies an inline style of min-height: 200px; to the .CodeMirror class. +This is set by default in the library's CSS and it's intended to ensure that the editor has a minimum height of 200 pixels. + +This inline style is applied by the library itself and is not something that you should normally need to change. +However, if you find that it's causing issues with your layout, you can override it in your own CSS. + +Here's how you can do it: + +.CodeMirror { + min-height: auto !important; +} +This will override the min-height property set by Toast UI Editor and set it to auto, which means the height will adjust based on the content of the editor. + +Please note that using !important should generally be avoided if possible, as it increases the specificity of a rule and can make debugging and maintenance more difficult. However, in this case, it may be necessary to override the inline style set by the library 3. +*/ + + .CodeMirror-scroll { + overflow: scroll !important; /* Things will break if this is overridden */ + /* 50px is the magic margin used to hide the element's real scrollbars */ + /* See overflow: hidden in .CodeMirror */ + margin-bottom: -50px; + margin-right: -50px; + padding-bottom: 50px; + height: 100%; + outline: none; /* Prevent dragging from highlighting the element */ + position: relative; + z-index: 0; + } + + .CodeMirror-sizer { + position: relative; + border-right: 50px solid transparent; + } + + /* The fake, visible scrollbars. Used to force redraw during scrolling + before actual scrolling happens, thus preventing shaking and + flickering artifacts. */ + .CodeMirror-vscrollbar, + .CodeMirror-hscrollbar, + .CodeMirror-scrollbar-filler, + .CodeMirror-gutter-filler { + position: absolute; + z-index: 6; + display: none; + outline: none; + } + .CodeMirror-vscrollbar { + right: 0; + top: 0; + overflow-x: hidden; + overflow-y: scroll; + } + .CodeMirror-hscrollbar { + bottom: 0; + left: 0; + overflow-y: hidden; + overflow-x: scroll; + } + .CodeMirror-scrollbar-filler { + right: 0; + bottom: 0; + } + .CodeMirror-gutter-filler { + left: 0; + bottom: 0; + } + + .CodeMirror-gutters { + position: absolute; + left: 0; + top: 0; + min-height: 100%; + z-index: 3; + } + .CodeMirror-gutter { + white-space: normal; + height: 100%; + display: inline-block; + vertical-align: top; + margin-bottom: -50px; + } + .CodeMirror-gutter-wrapper { + position: absolute; + z-index: 4; + background: none !important; + border: none !important; + } + .CodeMirror-gutter-background { + position: absolute; + top: 0; + bottom: 0; + z-index: 4; + } + .CodeMirror-gutter-elt { + position: absolute; + cursor: default; + z-index: 4; + } + .CodeMirror-gutter-wrapper ::selection { + background-color: transparent; + } + .CodeMirror-gutter-wrapper ::-moz-selection { + background-color: transparent; + } + + .CodeMirror-lines { + cursor: text; + min-height: 1px; /* prevents collapsing before first draw */ + } + .CodeMirror pre.CodeMirror-line, + .CodeMirror pre.CodeMirror-line-like { + /* Reset some styles that the rest of the page might have set */ + -moz-border-radius: 0; + -webkit-border-radius: 0; + border-radius: 0; + border-width: 0; + background: transparent; + font-family: inherit; + font-size: inherit; + margin: 0; + white-space: pre; + word-wrap: normal; + line-height: inherit; + color: inherit; + z-index: 2; + position: relative; + overflow: visible; + -webkit-tap-highlight-color: transparent; + -webkit-font-variant-ligatures: contextual; + font-variant-ligatures: contextual; + } + .CodeMirror-wrap pre.CodeMirror-line, + .CodeMirror-wrap pre.CodeMirror-line-like { + word-wrap: break-word; + white-space: pre-wrap; + word-break: normal; + } + + .CodeMirror-linebackground { + position: absolute; + left: 0; + right: 0; + top: 0; + bottom: 0; + z-index: 0; + } + + .CodeMirror-linewidget { + position: relative; + z-index: 2; + padding: 0.1px; /* Force widget margins to stay inside of the container */ + } + + .CodeMirror-rtl pre { + direction: rtl; + } + + .CodeMirror-code { + outline: none; + } + + /* Force content-box sizing for the elements where we expect it */ + .CodeMirror-scroll, + .CodeMirror-sizer, + .CodeMirror-gutter, + .CodeMirror-gutters, + .CodeMirror-linenumber { + -moz-box-sizing: content-box; + box-sizing: content-box; + } + + .CodeMirror-measure { + position: absolute; + width: 100%; + height: 0; + overflow: hidden; + visibility: hidden; + } + + .CodeMirror-cursor { + position: absolute; + pointer-events: none; + } + .CodeMirror-measure pre { + position: static; + } + + div.CodeMirror-cursors { + visibility: hidden; + position: relative; + z-index: 3; + } + div.CodeMirror-dragcursors { + visibility: visible; + } + + .CodeMirror-focused div.CodeMirror-cursors { + visibility: visible; + } + + .CodeMirror-selected { + background: #d9d9d9; + } + .CodeMirror-focused .CodeMirror-selected { + background: #d7d4f0; + } + .CodeMirror-crosshair { + cursor: crosshair; + } + .CodeMirror-line::selection, + .CodeMirror-line > span::selection, + .CodeMirror-line > span > span::selection { + background: #d7d4f0; + } + .CodeMirror-line::-moz-selection, + .CodeMirror-line > span::-moz-selection, + .CodeMirror-line > span > span::-moz-selection { + background: #d7d4f0; + } + + .cm-searching { + background-color: #ffa; + background-color: rgba(255, 255, 0, 0.4); + } + + /* Used to force a border model for a node */ + .cm-force-border { + padding-right: 0.1px; + } + + @media print { + /* Hide the cursor when printing */ + .CodeMirror div.CodeMirror-cursors { + visibility: hidden; + } + } + + /* See issue #2901 */ + .cm-tab-wrap-hack:after { + content: ''; + } + + /* Help users use markselection to safely style text background */ + span.CodeMirror-selectedtext { + background: none; + } +} + +.tui-tooltip { + position: absolute; + background-color: #222; + z-index: 999; + opacity: 0.8; + color: #fff; + padding: 2px 5px; + font-size: 10px; +} + +.tui-tooltip .arrow { + content: ''; + display: inline-block; + width: 10px; + height: 10px; + background-color: #222; + -webkit-transform: rotate(45deg); + -moz-transform: rotate(45deg); + -ms-transform: rotate(45deg); + -o-transform: rotate(45deg); + transform: rotate(45deg); + position: absolute; + top: -3px; + left: 6px; + z-index: -1; +} + /*-------------------------------------------------*/ /* D e b u g */ /*-------------------------------------------------*/ @@ -146,3 +2506,15 @@ transform: translate(-10px, -10px); } } + +@keyframes pulsealert { + 0% { + opacity: 0.5; + } + 50% { + opacity: 1; + } + 100% { + opacity: 0.5; + } +} diff --git a/packages/ketchup/src/managers/kup-theme/themes.json b/packages/ketchup/src/managers/kup-theme/themes.json index b0e91e52c7..399145e7e8 100644 --- a/packages/ketchup/src/managers/kup-theme/themes.json +++ b/packages/ketchup/src/managers/kup-theme/themes.json @@ -1,927 +1,927 @@ { - "octane": { - "cssVariables": { - "--kup-primary-color": "#068a9c", - "--kup-secondary-color": "#f4a22e", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#068a9c", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#535353", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "IBM Plex Sans, sans-serif", - "--kup-font-family-monospace": "IBM Plex Sans, sans-serif", - "--kup-font-size": "14px", - "--kup-text-color": "#474747", - "--kup-text-on-primary-color": "#e8e8e8", - "--kup-text-on-secondary-color": "#312c2c", - "--kup-disabled-background-color": "#d1d1d1", - "--kup-disabled-color": "#636363", - "--kup-hover-background-color": "#e8e8e8", - "--kup-hover-color": "#303030", - "--kup-title-background-color": "#068a9c", - "--kup-title-color": "#fff", - "--kup-icon-color": "#e8e8e8", - "--kup-border-color": "#d8d8d8", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#a4ba4c", - "--kup-warning-color": "#de8906", - "--kup-danger-color": "#a6192e", - "--kup-spinner-color": "#fddc69", - "--kup-chart-color-1": "#60c3fc", - "--kup-chart-color-2": "#e268d8", - "--kup-chart-color-3": "#860bb5", - "--kup-chart-color-4": "#1a83e4", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [], - "customStyles": {} + "octane": { + "cssVariables": { + "--kup-primary-color": "#068a9c", + "--kup-secondary-color": "#f4a22e", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#068a9c", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#535353", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "IBM Plex Sans, sans-serif", + "--kup-font-family-monospace": "IBM Plex Sans, sans-serif", + "--kup-font-size": "14px", + "--kup-text-color": "#474747", + "--kup-text-on-primary-color": "#e8e8e8", + "--kup-text-on-secondary-color": "#312c2c", + "--kup-disabled-background-color": "#d1d1d1", + "--kup-disabled-color": "#636363", + "--kup-hover-background-color": "#e8e8e8", + "--kup-hover-color": "#303030", + "--kup-title-background-color": "#068a9c", + "--kup-title-color": "#fff", + "--kup-icon-color": "#e8e8e8", + "--kup-border-color": "#d8d8d8", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#a4ba4c", + "--kup-warning-color": "#de8906", + "--kup-danger-color": "#a6192e", + "--kup-spinner-color": "#fddc69", + "--kup-chart-color-1": "#60c3fc", + "--kup-chart-color-2": "#e268d8", + "--kup-chart-color-3": "#860bb5", + "--kup-chart-color-4": "#1a83e4", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "bubbles": { - "cssVariables": { - "--kup-primary-color": "#c18f00", - "--kup-secondary-color": "#1d1d1d", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#beb08d", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#000000", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Lato, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "14px", - "--kup-text-color": "#2e2e2e", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#eaeaea", - "--kup-disabled-color": "#5c5c5c", - "--kup-hover-background-color": "#f0f0f0", - "--kup-hover-color": "#545454", - "--kup-title-background-color": "#f1f3f4", - "--kup-title-color": "#2e2e2e", - "--kup-icon-color": "#505050", - "--kup-border-color": "#e0e0e0", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#1D1D1B", - "--kup-chart-color-1": "#ff5959", - "--kup-chart-color-2": "#e0a0a0", - "--kup-chart-color-3": "#8e1010", - "--kup-chart-color-4": "#f5f5dc", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "sort-ascending", - "--kup-descending-icon": "sort-descending", - "--kup-expanded-icon": "chevron-down", - "--kup-collapsed-icon": "chevron_right", - "--kup-dropdown-icon": "chevron-down", - "--kup-clear-icon": "clear", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "customStyles": {}, - "imports": [ - "@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400&display=swap')" - ] + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" }, - "cobalt": { - "cssVariables": { - "--kup-primary-color": "#248aff", - "--kup-secondary-color": "#65cbe9", - "--kup-background-color": "#222222", - "--kup-navbar-background-color": "#131313", - "--kup-navbar-color": "#65cbe9", - "--kup-drawer-background-color": "#2e2e2e", - "--kup-drawer-color": "#65cbe9", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Blinker, sans-serif;", - "--kup-font-family-monospace": "Andalé Mono, monospace", - "--kup-font-size": "14px", - "--kup-text-color": "#65cbe9", - "--kup-text-on-primary-color": "#f1f7ff", - "--kup-text-on-secondary-color": "#000000", - "--kup-disabled-background-color": "#3c3c3c", - "--kup-disabled-color": "#7e7e7e", - "--kup-hover-background-color": "#383838", - "--kup-hover-color": "#96e7ff", - "--kup-title-background-color": "#2e2e2e", - "--kup-title-color": "#f5f5f5", - "--kup-icon-color": "#65cbe9", - "--kup-border-color": "#535353", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#a4d9f7", - "--kup-chart-color-1": "#308aff", - "--kup-chart-color-2": "#5eb6d1", - "--kup-chart-color-3": "#b1eafb", - "--kup-chart-color-4": "#ffffff", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Blinker:wght@200;300;600&display=swap')" - ] + "imports": [], + "customStyles": {} + }, + "bubbles": { + "cssVariables": { + "--kup-primary-color": "#c18f00", + "--kup-secondary-color": "#1d1d1d", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#beb08d", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#000000", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Lato, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "14px", + "--kup-text-color": "#2e2e2e", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#eaeaea", + "--kup-disabled-color": "#5c5c5c", + "--kup-hover-background-color": "#f0f0f0", + "--kup-hover-color": "#545454", + "--kup-title-background-color": "#f1f3f4", + "--kup-title-color": "#2e2e2e", + "--kup-icon-color": "#505050", + "--kup-border-color": "#e0e0e0", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#1D1D1B", + "--kup-chart-color-1": "#ff5959", + "--kup-chart-color-2": "#e0a0a0", + "--kup-chart-color-3": "#8e1010", + "--kup-chart-color-4": "#f5f5dc", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "dark": { - "cssVariables": { - "--kup-primary-color": "#82f0e2", - "--kup-secondary-color": "#f9ff00", - "--kup-background-color": "#2d2d2d", - "--kup-navbar-background-color": "#2d2d2d", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#1f1f1f", - "--kup-drawer-color": "#f5f5f5", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Lato, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "14px", - "--kup-text-color": "#f5f5f5", - "--kup-text-on-primary-color": "#555555", - "--kup-text-on-secondary-color": "#000000", - "--kup-disabled-background-color": "#3c3c3c", - "--kup-disabled-color": "#7e7e7e", - "--kup-hover-background-color": "#3c3c3c", - "--kup-hover-color": "#dddddd", - "--kup-title-background-color": "#111111", - "--kup-title-color": "#f5f5f5", - "--kup-icon-color": "#e0e0e0", - "--kup-border-color": "#535353", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#f2e114", - "--kup-chart-color-1": "#60c3fc", - "--kup-chart-color-2": "#e268d8", - "--kup-chart-color-3": "#860bb5", - "--kup-chart-color-4": "#1a83e4", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400&display=swap')" - ] + "icons": { + "--kup-ascending-icon": "sort-ascending", + "--kup-descending-icon": "sort-descending", + "--kup-expanded-icon": "chevron-down", + "--kup-collapsed-icon": "chevron_right", + "--kup-dropdown-icon": "chevron-down", + "--kup-clear-icon": "clear", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" }, - "flamingo": { - "cssVariables": { - "--kup-primary-color": "#e88aab", - "--kup-secondary-color": "#7f00e7", - "--kup-background-color": "#222222", - "--kup-navbar-background-color": "#2d2d2d", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#1f1f1f", - "--kup-drawer-color": "#f5f5f5", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Mali, cursive;", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "14px", - "--kup-text-color": "#f5f5f5", - "--kup-text-on-primary-color": "#000000", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#3c3c3c", - "--kup-disabled-color": "#7e7e7e", - "--kup-hover-background-color": "#3c3c3c", - "--kup-hover-color": "#dddddd", - "--kup-title-background-color": "#111111", - "--kup-title-color": "#f5f5f5", - "--kup-icon-color": "#e0e0e0", - "--kup-border-color": "#535353", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#ffd0d8", - "--kup-chart-color-1": "#e88aab", - "--kup-chart-color-2": "#dc5584", - "--kup-chart-color-3": "#c21350", - "--kup-chart-color-4": "#c88da1", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Mali:wght@300&display=swap')" - ] + "customStyles": {}, + "imports": [ + "@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400&display=swap')" + ] + }, + "cobalt": { + "cssVariables": { + "--kup-primary-color": "#248aff", + "--kup-secondary-color": "#65cbe9", + "--kup-background-color": "#222222", + "--kup-navbar-background-color": "#131313", + "--kup-navbar-color": "#65cbe9", + "--kup-drawer-background-color": "#2e2e2e", + "--kup-drawer-color": "#65cbe9", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Blinker, sans-serif;", + "--kup-font-family-monospace": "Andalé Mono, monospace", + "--kup-font-size": "14px", + "--kup-text-color": "#65cbe9", + "--kup-text-on-primary-color": "#f1f7ff", + "--kup-text-on-secondary-color": "#000000", + "--kup-disabled-background-color": "#3c3c3c", + "--kup-disabled-color": "#7e7e7e", + "--kup-hover-background-color": "#383838", + "--kup-hover-color": "#96e7ff", + "--kup-title-background-color": "#2e2e2e", + "--kup-title-color": "#f5f5f5", + "--kup-icon-color": "#65cbe9", + "--kup-border-color": "#535353", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#a4d9f7", + "--kup-chart-color-1": "#308aff", + "--kup-chart-color-2": "#5eb6d1", + "--kup-chart-color-3": "#b1eafb", + "--kup-chart-color-4": "#ffffff", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "graphite": { - "cssVariables": { - "--kup-primary-color": "#888888", - "--kup-secondary-color": "#d91e18", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#535353", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#545454", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Roboto, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "13px", - "--kup-text-color": "#545454", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-color": "#5c5c5c", - "--kup-disabled-background-color": "#eaeaea", - "--kup-hover-background-color": "#f0f0f0", - "--kup-hover-color": "#545454", - "--kup-title-background-color": "#f0f0f0", - "--kup-title-color": "#545454", - "--kup-icon-color": "#808080", - "--kup-border-color": "#e0e0e0", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#eaa710", - "--kup-chart-color-1": "red", - "--kup-chart-color-2": "blue", - "--kup-chart-color-3": "orange", - "--kup-chart-color-4": "green", - "--kup-chart-color-5": "yellow", - "--kup-chart-color-6": "cyan", - "--kup-chart-color-7": "brown", - "--kup-chart-color-8": "magenta", - "--kup-chart-color-9": "grey", - "--kup-chart-color-10": "indigo", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "customStyles": { - "KUP-BUTTON": "#kup-component button {\ntext-transform: unset;\n}\n\n" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - } + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" }, - "ketchup": { - "cssVariables": { - "--kup-primary-color": "#d64325", - "--kup-secondary-color": "#a6192e", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#2e2e2e", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#595959", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Ubuntu, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "14px", - "--kup-text-color": "#595959", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#eaeaea", - "--kup-disabled-color": "#5c5c5c", - "--kup-hover-background-color": "#f0f0f0", - "--kup-hover-color": "#545454", - "--kup-title-background-color": "#f1f3f4", - "--kup-title-color": "#2e2e2e", - "--kup-icon-color": "#505050", - "--kup-border-color": "#e0e0e0", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#eaa710", - "--kup-chart-color-1": "#ff5959", - "--kup-chart-color-2": "#e0a0a0", - "--kup-chart-color-3": "#8e1010", - "--kup-chart-color-4": "#f5f5dc", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "sort-ascending", - "--kup-descending-icon": "sort-descending", - "--kup-expanded-icon": "chevron-down", - "--kup-collapsed-icon": "chevron_right", - "--kup-dropdown-icon": "chevron-down", - "--kup-clear-icon": "clear", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@300;500&display=swap')" - ] + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Blinker:wght@200;300;600&display=swap')" + ] + }, + "dark": { + "cssVariables": { + "--kup-primary-color": "#82f0e2", + "--kup-secondary-color": "#f9ff00", + "--kup-background-color": "#2d2d2d", + "--kup-navbar-background-color": "#2d2d2d", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#1f1f1f", + "--kup-drawer-color": "#f5f5f5", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Lato, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "14px", + "--kup-text-color": "#f5f5f5", + "--kup-text-on-primary-color": "#555555", + "--kup-text-on-secondary-color": "#000000", + "--kup-disabled-background-color": "#3c3c3c", + "--kup-disabled-color": "#7e7e7e", + "--kup-hover-background-color": "#3c3c3c", + "--kup-hover-color": "#dddddd", + "--kup-title-background-color": "#111111", + "--kup-title-color": "#f5f5f5", + "--kup-icon-color": "#e0e0e0", + "--kup-border-color": "#535353", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#f2e114", + "--kup-chart-color-1": "#60c3fc", + "--kup-chart-color-2": "#e268d8", + "--kup-chart-color-3": "#860bb5", + "--kup-chart-color-4": "#1a83e4", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "obsidian": { - "cssVariables": { - "--kup-primary-color": "#a6192e", - "--kup-secondary-color": "#f5f4f4", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#000000", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#f5f4f4", - "--kup-drawer-color": "#4c4c4d", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Open Sans, arial, helvatica", - "--kup-font-family-monospace": "Courier New, Courier, monospace", - "--kup-font-size": "13px", - "--kup-text-color": "#4c4c4d", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#a6192e", - "--kup-disabled-background-color": "#ffffff", - "--kup-disabled-color": "#4c4c4d", - "--kup-hover-background-color": "#f5f4f4", - "--kup-hover-color": "#000000", - "--kup-title-background-color": "#068a9c", - "--kup-title-color": "#ffffff", - "--kup-icon-color": "#9d9d9d", - "--kup-border-color": "#ededed", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#A6192E", - "--kup-spinner-color": "#a6192e", - "--kup-chart-color-1": "#735DED", - "--kup-chart-color-2": "#00B2CB", - "--kup-chart-color-3": "#EDC900", - "--kup-chart-color-4": "green", - "--kup-chart-color-5": "yellow", - "--kup-chart-color-6": "cyan", - "--kup-chart-color-7": "brown", - "--kup-chart-color-8": "magenta", - "--kup-chart-color-9": "grey", - "--kup-chart-color-10": "indigo", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400&display=swap')" - ] + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" }, - "ocean": { - "cssVariables": { - "--kup-primary-color": "#0081c5", - "--kup-secondary-color": "#3a8ede", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#001d3e", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#e6f1ff", - "--kup-drawer-color": "#1b1b1b", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Open Sans Condensed, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "16px", - "--kup-text-color": "#1b1b1b", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#eaeaea", - "--kup-disabled-color": "#5c5c5c", - "--kup-hover-background-color": "#cfe8ff", - "--kup-hover-color": "#545454", - "--kup-title-background-color": "#f1f3f4", - "--kup-title-color": "#1b1b1b", - "--kup-icon-color": "#505050", - "--kup-border-color": "#e0e0e0", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#6edeff", - "--kup-chart-color-1": "#60c3fc", - "--kup-chart-color-2": "#e268d8", - "--kup-chart-color-3": "#e48b47", - "--kup-chart-color-4": "#81e447", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Open+Sans+Condensed:wght@300;700&display=swap')" - ] + "imports": [ + "@import url('https://fonts.googleapis.com/css2?family=Lato:wght@300;400&display=swap')" + ] + }, + "flamingo": { + "cssVariables": { + "--kup-primary-color": "#e88aab", + "--kup-secondary-color": "#7f00e7", + "--kup-background-color": "#222222", + "--kup-navbar-background-color": "#2d2d2d", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#1f1f1f", + "--kup-drawer-color": "#f5f5f5", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Mali, cursive;", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "14px", + "--kup-text-color": "#f5f5f5", + "--kup-text-on-primary-color": "#000000", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#3c3c3c", + "--kup-disabled-color": "#7e7e7e", + "--kup-hover-background-color": "#3c3c3c", + "--kup-hover-color": "#dddddd", + "--kup-title-background-color": "#111111", + "--kup-title-color": "#f5f5f5", + "--kup-icon-color": "#e0e0e0", + "--kup-border-color": "#535353", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#ffd0d8", + "--kup-chart-color-1": "#e88aab", + "--kup-chart-color-2": "#dc5584", + "--kup-chart-color-3": "#c21350", + "--kup-chart-color-4": "#c88da1", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "print": { - "cssVariables": { - "--kup-primary-color": "#000000", - "--kup-secondary-color": "#cccccc", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#000000", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#000000", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Arial, Helvetica, sans-serif", - "--kup-font-family-monospace": "Courier New, Courier, monospace", - "--kup-font-size": "13px", - "--kup-text-color": "#000000", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#000000", - "--kup-disabled-background-color": "#ffffff", - "--kup-disabled-color": "#000000", - "--kup-hover-background-color": "#ffffff", - "--kup-hover-color": "#000000", - "--kup-title-background-color": "#f1f1f1", - "--kup-title-color": "#000000", - "--kup-icon-color": "#9d9d9d", - "--kup-border-color": "#ededed", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#A6192E", - "--kup-spinner-color": "#eaa710", - "--kup-chart-color-1": "#735DED", - "--kup-chart-color-2": "#00B2CB", - "--kup-chart-color-3": "#EDC900", - "--kup-chart-color-4": "green", - "--kup-chart-color-5": "yellow", - "--kup-chart-color-6": "cyan", - "--kup-chart-color-7": "brown", - "--kup-chart-color-8": "magenta", - "--kup-chart-color-9": "grey", - "--kup-chart-color-10": "indigo", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "customStyles": { - "MASTER": "#kup-component #global-filter {\ndisplay: none;\n}\n\n", - "KUP-BOX": "#kup-component #box-container .box-wrapper .box:hover {\nbox-shadow: none;\n}\n\n#kup-component #box-container .box-wrapper .box.selected {\nbackground-color: inherit;\n}", - "KUP-BUTTON": ":host(:not(.printable)) {\ndisplay: none;\n}\n\n", - "KUP-CARD": "", - "KUP-DATA-TABLE": "#kup-component sticky-header {\ndisplay: none;\n}\n\n#kup-component kup-paginator {\ndisplay: none;\n}\n\n:host(.cross-selection) #kup-component table tr.selected td.selected, \n#kup-component table td.selected, #kup-component tr.selected td {\nbackground-color: inherit;\nbackground-image: none;\n}\n\n#kup-component table,\n#kup-component .below-wrapper {\noverflow: hidden !important;\n}\n\n:host(.cross-selection) #kup-component tr.selected td:first-of-type,\n:host(.cross-selection) #kup-component th.selected { \nbox-shadow: none !important;\n}\n\n:host(.cross-selection) #kup-component table td.selected,\n:host(.cross-selection) #kup-component table tr.selected td {\nbackground-color: inherit;\n}\n\n:host(.cross-selection) #kup-component table tr.selected td.fixed-column.selected,\n:host(.cross-selection) #kup-component table td.selected.fixed-column, \n:host(.cross-selection) #kup-component table td.selected.fixed-row,\n:host(.cross-selection) #kup-component table tr.selected td.fixed-column, \n:host(.cross-selection) #kup-component table tr.selected td.fixed-row {\nbackground-color: inherit;\nbackground-image: none;\n}\n\n", - "KUP-FAMILY-TREE": "#kup-component .family-tree__item__expand {\ndisplay: none;\n}\n\n", - "KUP-PROGRESS-BAR": "#kup-component .progress-bar {\nbackground: #e7e7e7;\n}\n\n#kup-component .progress-bar-percentage span {\ntext-shadow: 0px 0px 0px hsl(0deg 0% 100%);\n}\n\n", - "KUP-TREE": "#kup-component .wrapper {\noverflow: hidden;\n}\n\n#kup-component tr.mdc-ripple-surface::before, \n#kup-component tr.mdc-ripple-surface::after,\n#kup-component td.mdc-ripple-surface::before, \n#kup-component td.mdc-ripple-surface::after,\n#kup-component .kup-tree__node--selected:not(.kup-tree__node--disabled) td {\nbackground-color: var(--kup-background-color);\n}" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - } + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" }, - "raj": { - "cssVariables": { - "--kup-primary-color": "rgb(187, 198, 5)", - "--kup-secondary-color": "#ffe600", - "--kup-background-color": "#000000", - "--kup-navbar-background-color": "#000000", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#000000", - "--kup-drawer-color": "#ffffff", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "'Rajdhani', sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "15px", - "--kup-text-color": "#ffffff", - "--kup-text-on-primary-color": "#000000", - "--kup-text-on-secondary-color": "#000000", - "--kup-disabled-background-color": "#151515", - "--kup-disabled-color": "#7b7b7b", - "--kup-hover-background-color": "#404040", - "--kup-hover-color": "#ffffff", - "--kup-title-background-color": "#ffe600", - "--kup-title-color": "#000000", - "--kup-icon-color": "#9d9d9d", - "--kup-border-color": "#9d9d9d", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#ffe600", - "--kup-chart-color-1": "#ffffff", - "--kup-chart-color-2": "rgb(187, 198, 5)", - "--kup-chart-color-3": "#ffe600", - "--kup-chart-color-4": "#effd02", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "sort-ascending", - "--kup-descending-icon": "sort-descending", - "--kup-expanded-icon": "chevron-down", - "--kup-collapsed-icon": "chevron_right", - "--kup-dropdown-icon": "chevron-down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@600&display=swap')" - ] + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Mali:wght@300&display=swap')" + ] + }, + "graphite": { + "cssVariables": { + "--kup-primary-color": "#888888", + "--kup-secondary-color": "#d91e18", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#535353", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#545454", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Roboto, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "13px", + "--kup-text-color": "#545454", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-color": "#5c5c5c", + "--kup-disabled-background-color": "#eaeaea", + "--kup-hover-background-color": "#f0f0f0", + "--kup-hover-color": "#545454", + "--kup-title-background-color": "#f0f0f0", + "--kup-title-color": "#545454", + "--kup-icon-color": "#808080", + "--kup-border-color": "#e0e0e0", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#eaa710", + "--kup-chart-color-1": "red", + "--kup-chart-color-2": "blue", + "--kup-chart-color-3": "orange", + "--kup-chart-color-4": "green", + "--kup-chart-color-5": "yellow", + "--kup-chart-color-6": "cyan", + "--kup-chart-color-7": "brown", + "--kup-chart-color-8": "magenta", + "--kup-chart-color-9": "grey", + "--kup-chart-color-10": "indigo", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "red": { - "cssVariables": { - "--kup-primary-color": "#a6192e", - "--kup-secondary-color": "#ffc107", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#a6192e", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#f5f5f5", - "--kup-drawer-color": "#000000", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Open Sans, arial, helvatica", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "13px", - "--kup-text-color": "#000000", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#eaeaea", - "--kup-disabled-color": "#333333", - "--kup-hover-background-color": "#eeeeee", - "--kup-hover-color": "#000000", - "--kup-title-background-color": "#f1f3f4", - "--kup-title-color": "#2e2e2e", - "--kup-icon-color": "#808080", - "--kup-border-color": "#ededed", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#A6192E", - "--kup-spinner-color": "#1D1D1B", - "--kup-chart-color-1": "#735DED", - "--kup-chart-color-2": "#00B2CB", - "--kup-chart-color-3": "#EDC900", - "--kup-chart-color-4": "#a6192e", - "--kup-chart-color-5": "yellow", - "--kup-chart-color-6": "cyan", - "--kup-chart-color-7": "brown", - "--kup-chart-color-8": "magenta", - "--kup-chart-color-9": "grey", - "--kup-chart-color-10": "indigo", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "customStyles": {}, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400&display=swap')" - ] + "customStyles": { + "KUP-BUTTON": "#kup-component button {\ntext-transform: unset;\n}\n\n" }, - "sapphire": { - "cssVariables": { - "--kup-primary-color": "#003b77", - "--kup-secondary-color": "#ff1414", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#003b77", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#002244", - "--kup-drawer-color": "#ffffff", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "20em", - "--kup-font-family": "Arial", - "--kup-font-family-monospace": "Arial", - "--kup-font-size": "13px", - "--kup-text-color": "#333333", - "--kup-text-on-primary-color": "#fafafa", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#ddecf8", - "--kup-disabled-color": "#333333", - "--kup-hover-background-color": "#d8ecf6", - "--kup-hover-color": "#333333", - "--kup-title-background-color": "#003b77", - "--kup-title-color": "#ffffff", - "--kup-icon-color": "#808080", - "--kup-border-color": "#93c4ec", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#a94442", - "--kup-spinner-color": "#003b77", - "--kup-chart-color-1": "#0781fd", - "--kup-chart-color-2": "#002244", - "--kup-chart-color-3": "#c6cff8", - "--kup-chart-color-4": "#66bdda", - "--kup-chart-color-5": "yellow", - "--kup-chart-color-6": "cyan", - "--kup-chart-color-7": "brown", - "--kup-chart-color-8": "magenta", - "--kup-chart-color-9": "grey", - "--kup-chart-color-10": "indigo", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "customStyles": { - "KUP-DATA-TABLE": "#kup-component th { --kup_datatable_th_border: none; font-weight: normal; }" - } + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + } + }, + "ketchup": { + "cssVariables": { + "--kup-primary-color": "#d64325", + "--kup-secondary-color": "#a6192e", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#2e2e2e", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#595959", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Ubuntu, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "14px", + "--kup-text-color": "#595959", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#eaeaea", + "--kup-disabled-color": "#5c5c5c", + "--kup-hover-background-color": "#f0f0f0", + "--kup-hover-color": "#545454", + "--kup-title-background-color": "#f1f3f4", + "--kup-title-color": "#2e2e2e", + "--kup-icon-color": "#505050", + "--kup-border-color": "#e0e0e0", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#eaa710", + "--kup-chart-color-1": "#ff5959", + "--kup-chart-color-2": "#e0a0a0", + "--kup-chart-color-3": "#8e1010", + "--kup-chart-color-4": "#f5f5dc", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "sort-ascending", + "--kup-descending-icon": "sort-descending", + "--kup-expanded-icon": "chevron-down", + "--kup-collapsed-icon": "chevron_right", + "--kup-dropdown-icon": "chevron-down", + "--kup-clear-icon": "clear", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key", + "--kup-search-icon": "search" + }, + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Ubuntu:wght@300;500&display=swap')" + ] + }, + "obsidian": { + "cssVariables": { + "--kup-primary-color": "#a6192e", + "--kup-secondary-color": "#f5f4f4", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#000000", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#f5f4f4", + "--kup-drawer-color": "#4c4c4d", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Open Sans, arial, helvatica", + "--kup-font-family-monospace": "Courier New, Courier, monospace", + "--kup-font-size": "13px", + "--kup-text-color": "#4c4c4d", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#a6192e", + "--kup-disabled-background-color": "#ffffff", + "--kup-disabled-color": "#4c4c4d", + "--kup-hover-background-color": "#f5f4f4", + "--kup-hover-color": "#000000", + "--kup-title-background-color": "#068a9c", + "--kup-title-color": "#ffffff", + "--kup-icon-color": "#9d9d9d", + "--kup-border-color": "#ededed", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#A6192E", + "--kup-spinner-color": "#a6192e", + "--kup-chart-color-1": "#735DED", + "--kup-chart-color-2": "#00B2CB", + "--kup-chart-color-3": "#EDC900", + "--kup-chart-color-4": "green", + "--kup-chart-color-5": "yellow", + "--kup-chart-color-6": "cyan", + "--kup-chart-color-7": "brown", + "--kup-chart-color-8": "magenta", + "--kup-chart-color-9": "grey", + "--kup-chart-color-10": "indigo", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + }, + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400&display=swap')" + ] + }, + "ocean": { + "cssVariables": { + "--kup-primary-color": "#0081c5", + "--kup-secondary-color": "#3a8ede", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#001d3e", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#e6f1ff", + "--kup-drawer-color": "#1b1b1b", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Open Sans Condensed, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "16px", + "--kup-text-color": "#1b1b1b", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#eaeaea", + "--kup-disabled-color": "#5c5c5c", + "--kup-hover-background-color": "#cfe8ff", + "--kup-hover-color": "#545454", + "--kup-title-background-color": "#f1f3f4", + "--kup-title-color": "#1b1b1b", + "--kup-icon-color": "#505050", + "--kup-border-color": "#e0e0e0", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#6edeff", + "--kup-chart-color-1": "#60c3fc", + "--kup-chart-color-2": "#e268d8", + "--kup-chart-color-3": "#e48b47", + "--kup-chart-color-4": "#81e447", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "silver": { - "cssVariables": { - "--kup-primary-color": "#c0c0c0", - "--kup-secondary-color": "#c0c0c0", - "--kup-background-color": "#000000", - "--kup-navbar-background-color": "#ffffff", - "--kup-navbar-color": "#000000", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#000000", - "--kup-navbar-height": "80px", - "--kup-drawer-width": "320px", - "--kup-font-family": "Oswald, sans-serif", - "--kup-font-family-monospace": "Xanh Mono, monospace", - "--kup-font-size": "16px", - "--kup-text-color": "#fefefe", - "--kup-text-on-primary-color": "#4a4a4a", - "--kup-text-on-secondary-color": "#4a4a4a", - "--kup-disabled-background-color": "#3c3c3c", - "--kup-disabled-color": "#7e7e7e", - "--kup-hover-background-color": "#3c3c3c", - "--kup-hover-color": "#dddddd", - "--kup-title-background-color": "#151515", - "--kup-title-color": "#d9d9d9", - "--kup-icon-color": "#c0c0c0", - "--kup-border-color": "#c0c0c0", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#c0c0c0", - "--kup-chart-color-1": "#ffffff", - "--kup-chart-color-2": "#b0b0b0", - "--kup-chart-color-3": "#5c5c5c", - "--kup-chart-color-4": "#000000", - "--kup-chart-color-5": "#b35454", - "--kup-chart-color-6": "#59af57", - "--kup-chart-color-7": "#aeaa5d", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Oswald:wght@200;300;400;500;600;700&family=Xanh+Mono&display=swap')" - ], - "customStyles": {} + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" }, - "teal": { - "cssVariables": { - "--kup-primary-color": "#068A9C", - "--kup-secondary-color": "#ffc107", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#068A9C", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#ffffff", - "--kup-drawer-color": "#000000", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Roboto, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "13px", - "--kup-text-color": "#000000", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#eaeaea", - "--kup-disabled-color": "#333333", - "--kup-hover-background-color": "#f0f0f0", - "--kup-hover-color": "#000000", - "--kup-title-background-color": "#f1f3f4", - "--kup-title-color": "#2e2e2e", - "--kup-icon-color": "#808080", - "--kup-border-color": "#ededed", - "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#A6192E", - "--kup-spinner-color": "#eaa710", - "--kup-chart-color-1": "#068A9C", - "--kup-chart-color-2": "#009643", - "--kup-chart-color-3": "#EDC900", - "--kup-chart-color-4": "#188F00", - "--kup-chart-color-5": "#758700", - "--kup-chart-color-6": "#7D2F00", - "--kup-chart-color-7": "#710008", - "--kup-chart-color-8": "#640056", - "--kup-chart-color-9": "#1C0056", - "--kup-chart-color-10": "#000046", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - } + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Open+Sans+Condensed:wght@300;700&display=swap')" + ] + }, + "print": { + "cssVariables": { + "--kup-primary-color": "#000000", + "--kup-secondary-color": "#cccccc", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#000000", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#000000", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Arial, Helvetica, sans-serif", + "--kup-font-family-monospace": "Courier New, Courier, monospace", + "--kup-font-size": "13px", + "--kup-text-color": "#000000", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#000000", + "--kup-disabled-background-color": "#ffffff", + "--kup-disabled-color": "#000000", + "--kup-hover-background-color": "#ffffff", + "--kup-hover-color": "#000000", + "--kup-title-background-color": "#f1f1f1", + "--kup-title-color": "#000000", + "--kup-icon-color": "#9d9d9d", + "--kup-border-color": "#ededed", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#A6192E", + "--kup-spinner-color": "#eaa710", + "--kup-chart-color-1": "#735DED", + "--kup-chart-color-2": "#00B2CB", + "--kup-chart-color-3": "#EDC900", + "--kup-chart-color-4": "green", + "--kup-chart-color-5": "yellow", + "--kup-chart-color-6": "cyan", + "--kup-chart-color-7": "brown", + "--kup-chart-color-8": "magenta", + "--kup-chart-color-9": "grey", + "--kup-chart-color-10": "indigo", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" }, - "wildlife": { - "cssVariables": { - "--kup-primary-color": "#0fa918", - "--kup-secondary-color": "#739f5a", - "--kup-background-color": "#ffffff", - "--kup-navbar-background-color": "#095a1f", - "--kup-navbar-color": "#ffffff", - "--kup-drawer-background-color": "#dbfbd5", - "--kup-drawer-color": "#000000", - "--kup-navbar-height": "64px", - "--kup-drawer-width": "300px", - "--kup-font-family": "Abel, sans-serif", - "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", - "--kup-font-size": "16px", - "--kup-text-color": "#000000", - "--kup-text-on-primary-color": "#ffffff", - "--kup-text-on-secondary-color": "#ffffff", - "--kup-disabled-background-color": "#eaeaea", - "--kup-disabled-color": "#5c5c5c", - "--kup-hover-background-color": "#63ab46", - "--kup-hover-color": "#ffffff", - "--kup-title-background-color": "#f1f3f4", - "--kup-title-color": "#000000", - "--kup-icon-color": "#333333", - "--kup-border-color": "#e0e0e0", - "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", - "--kup-info-color": "#2592df", - "--kup-success-color": "#4d9f02", - "--kup-warning-color": "#ffc107", - "--kup-danger-color": "#d91e18", - "--kup-spinner-color": "#44b383", - "--kup-chart-color-1": "#60c3fc", - "--kup-chart-color-2": "#e268d8", - "--kup-chart-color-3": "#e48b47", - "--kup-chart-color-4": "#81e447", - "--kup-obj-cursor": "inherit", - "--kup-card-zindex": "900", - "--kup-drawer-zindex": "900", - "--kup-navbar-zindex": "900" - }, - "icons": { - "--kup-ascending-icon": "arrow_drop_up", - "--kup-descending-icon": "arrow_drop_down", - "--kup-expanded-icon": "arrow_drop_down", - "--kup-collapsed-icon": "menu-right", - "--kup-dropdown-icon": "arrow_drop_down", - "--kup-clear-icon": "cancel", - "--kup-filter-remove-icon": "filter-remove", - "--kup-key-icon": "key-variant", - "--kup-search-icon": "search" - }, - "imports": [ - "url('https://fonts.googleapis.com/css2?family=Abel&display=swap')" - ] + "customStyles": { + "MASTER": "#kup-component #global-filter {\ndisplay: none;\n}\n\n", + "KUP-BOX": "#kup-component #box-container .box-wrapper .box:hover {\nbox-shadow: none;\n}\n\n#kup-component #box-container .box-wrapper .box.selected {\nbackground-color: inherit;\n}", + "KUP-BUTTON": ":host(:not(.printable)) {\ndisplay: none;\n}\n\n", + "KUP-CARD": "", + "KUP-DATA-TABLE": "#kup-component sticky-header {\ndisplay: none;\n}\n\n#kup-component kup-paginator {\ndisplay: none;\n}\n\n:host(.cross-selection) #kup-component table tr.selected td.selected, \n#kup-component table td.selected, #kup-component tr.selected td {\nbackground-color: inherit;\nbackground-image: none;\n}\n\n#kup-component table,\n#kup-component .below-wrapper {\noverflow: hidden !important;\n}\n\n:host(.cross-selection) #kup-component tr.selected td:first-of-type,\n:host(.cross-selection) #kup-component th.selected { \nbox-shadow: none !important;\n}\n\n:host(.cross-selection) #kup-component table td.selected,\n:host(.cross-selection) #kup-component table tr.selected td {\nbackground-color: inherit;\n}\n\n:host(.cross-selection) #kup-component table tr.selected td.fixed-column.selected,\n:host(.cross-selection) #kup-component table td.selected.fixed-column, \n:host(.cross-selection) #kup-component table td.selected.fixed-row,\n:host(.cross-selection) #kup-component table tr.selected td.fixed-column, \n:host(.cross-selection) #kup-component table tr.selected td.fixed-row {\nbackground-color: inherit;\nbackground-image: none;\n}\n\n", + "KUP-FAMILY-TREE": "#kup-component .family-tree__item__expand {\ndisplay: none;\n}\n\n", + "KUP-PROGRESS-BAR": "#kup-component .progress-bar {\nbackground: #e7e7e7;\n}\n\n#kup-component .progress-bar-percentage span {\ntext-shadow: 0px 0px 0px hsl(0deg 0% 100%);\n}\n\n", + "KUP-TREE": "#kup-component .wrapper {\noverflow: hidden;\n}\n\n#kup-component tr.mdc-ripple-surface::before, \n#kup-component tr.mdc-ripple-surface::after,\n#kup-component td.mdc-ripple-surface::before, \n#kup-component td.mdc-ripple-surface::after,\n#kup-component .kup-tree__node--selected:not(.kup-tree__node--disabled) td {\nbackground-color: var(--kup-background-color);\n}" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" } -} + }, + "raj": { + "cssVariables": { + "--kup-primary-color": "rgb(187, 198, 5)", + "--kup-secondary-color": "#ffe600", + "--kup-background-color": "#000000", + "--kup-navbar-background-color": "#000000", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#000000", + "--kup-drawer-color": "#ffffff", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "'Rajdhani', sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "15px", + "--kup-text-color": "#ffffff", + "--kup-text-on-primary-color": "#000000", + "--kup-text-on-secondary-color": "#000000", + "--kup-disabled-background-color": "#151515", + "--kup-disabled-color": "#7b7b7b", + "--kup-hover-background-color": "#404040", + "--kup-hover-color": "#ffffff", + "--kup-title-background-color": "#ffe600", + "--kup-title-color": "#000000", + "--kup-icon-color": "#9d9d9d", + "--kup-border-color": "#9d9d9d", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#ffe600", + "--kup-chart-color-1": "#ffffff", + "--kup-chart-color-2": "rgb(187, 198, 5)", + "--kup-chart-color-3": "#ffe600", + "--kup-chart-color-4": "#effd02", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "sort-ascending", + "--kup-descending-icon": "sort-descending", + "--kup-expanded-icon": "chevron-down", + "--kup-collapsed-icon": "chevron_right", + "--kup-dropdown-icon": "chevron-down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + }, + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Rajdhani:wght@600&display=swap')" + ] + }, + "red": { + "cssVariables": { + "--kup-primary-color": "#a6192e", + "--kup-secondary-color": "#ffc107", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#a6192e", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#f5f5f5", + "--kup-drawer-color": "#000000", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Open Sans, arial, helvatica", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "13px", + "--kup-text-color": "#000000", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#eaeaea", + "--kup-disabled-color": "#333333", + "--kup-hover-background-color": "#eeeeee", + "--kup-hover-color": "#000000", + "--kup-title-background-color": "#f1f3f4", + "--kup-title-color": "#2e2e2e", + "--kup-icon-color": "#808080", + "--kup-border-color": "#ededed", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#A6192E", + "--kup-spinner-color": "#1D1D1B", + "--kup-chart-color-1": "#735DED", + "--kup-chart-color-2": "#00B2CB", + "--kup-chart-color-3": "#EDC900", + "--kup-chart-color-4": "#a6192e", + "--kup-chart-color-5": "yellow", + "--kup-chart-color-6": "cyan", + "--kup-chart-color-7": "brown", + "--kup-chart-color-8": "magenta", + "--kup-chart-color-9": "grey", + "--kup-chart-color-10": "indigo", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + }, + "customStyles": {}, + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Open+Sans:wght@400&display=swap')" + ] + }, + "sapphire": { + "cssVariables": { + "--kup-primary-color": "#003b77", + "--kup-secondary-color": "#ff1414", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#003b77", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#002244", + "--kup-drawer-color": "#ffffff", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "20em", + "--kup-font-family": "Arial", + "--kup-font-family-monospace": "Arial", + "--kup-font-size": "13px", + "--kup-text-color": "#333333", + "--kup-text-on-primary-color": "#fafafa", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#ddecf8", + "--kup-disabled-color": "#333333", + "--kup-hover-background-color": "#d8ecf6", + "--kup-hover-color": "#333333", + "--kup-title-background-color": "#003b77", + "--kup-title-color": "#ffffff", + "--kup-icon-color": "#808080", + "--kup-border-color": "#93c4ec", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#a94442", + "--kup-spinner-color": "#003b77", + "--kup-chart-color-1": "#0781fd", + "--kup-chart-color-2": "#002244", + "--kup-chart-color-3": "#c6cff8", + "--kup-chart-color-4": "#66bdda", + "--kup-chart-color-5": "yellow", + "--kup-chart-color-6": "cyan", + "--kup-chart-color-7": "brown", + "--kup-chart-color-8": "magenta", + "--kup-chart-color-9": "grey", + "--kup-chart-color-10": "indigo", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + }, + "customStyles": { + "KUP-DATA-TABLE": "#kup-component th { --kup_datatable_th_border: none; font-weight: normal; }" + } + }, + "silver": { + "cssVariables": { + "--kup-primary-color": "#c0c0c0", + "--kup-secondary-color": "#c0c0c0", + "--kup-background-color": "#000000", + "--kup-navbar-background-color": "#ffffff", + "--kup-navbar-color": "#000000", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#000000", + "--kup-navbar-height": "80px", + "--kup-drawer-width": "320px", + "--kup-font-family": "Oswald, sans-serif", + "--kup-font-family-monospace": "Xanh Mono, monospace", + "--kup-font-size": "16px", + "--kup-text-color": "#fefefe", + "--kup-text-on-primary-color": "#4a4a4a", + "--kup-text-on-secondary-color": "#4a4a4a", + "--kup-disabled-background-color": "#3c3c3c", + "--kup-disabled-color": "#7e7e7e", + "--kup-hover-background-color": "#3c3c3c", + "--kup-hover-color": "#dddddd", + "--kup-title-background-color": "#151515", + "--kup-title-color": "#d9d9d9", + "--kup-icon-color": "#c0c0c0", + "--kup-border-color": "#c0c0c0", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#c0c0c0", + "--kup-chart-color-1": "#ffffff", + "--kup-chart-color-2": "#b0b0b0", + "--kup-chart-color-3": "#5c5c5c", + "--kup-chart-color-4": "#000000", + "--kup-chart-color-5": "#b35454", + "--kup-chart-color-6": "#59af57", + "--kup-chart-color-7": "#aeaa5d", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + }, + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Oswald:wght@200;300;400;500;600;700&family=Xanh+Mono&display=swap')" + ], + "customStyles": {} + }, + "teal": { + "cssVariables": { + "--kup-primary-color": "#068A9C", + "--kup-secondary-color": "#ffc107", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#068A9C", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#ffffff", + "--kup-drawer-color": "#000000", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Roboto, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "13px", + "--kup-text-color": "#000000", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#eaeaea", + "--kup-disabled-color": "#333333", + "--kup-hover-background-color": "#f0f0f0", + "--kup-hover-color": "#000000", + "--kup-title-background-color": "#f1f3f4", + "--kup-title-color": "#2e2e2e", + "--kup-icon-color": "#808080", + "--kup-border-color": "#ededed", + "--kup-box-shadow": "rgba(0, 0, 0, 0.2) 0px 5px 5px -3px, rgba(0, 0, 0, 0.14) 0px 8px 10px 1px, rgba(0, 0, 0, 0.12) 0px 3px 14px 2px", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#A6192E", + "--kup-spinner-color": "#eaa710", + "--kup-chart-color-1": "#068A9C", + "--kup-chart-color-2": "#009643", + "--kup-chart-color-3": "#EDC900", + "--kup-chart-color-4": "#188F00", + "--kup-chart-color-5": "#758700", + "--kup-chart-color-6": "#7D2F00", + "--kup-chart-color-7": "#710008", + "--kup-chart-color-8": "#640056", + "--kup-chart-color-9": "#1C0056", + "--kup-chart-color-10": "#000046", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + } + }, + "wildlife": { + "cssVariables": { + "--kup-primary-color": "#0fa918", + "--kup-secondary-color": "#739f5a", + "--kup-background-color": "#ffffff", + "--kup-navbar-background-color": "#095a1f", + "--kup-navbar-color": "#ffffff", + "--kup-drawer-background-color": "#dbfbd5", + "--kup-drawer-color": "#000000", + "--kup-navbar-height": "64px", + "--kup-drawer-width": "300px", + "--kup-font-family": "Abel, sans-serif", + "--kup-font-family-monospace": "Roboto Mono, consolas, monospace", + "--kup-font-size": "16px", + "--kup-text-color": "#000000", + "--kup-text-on-primary-color": "#ffffff", + "--kup-text-on-secondary-color": "#ffffff", + "--kup-disabled-background-color": "#eaeaea", + "--kup-disabled-color": "#5c5c5c", + "--kup-hover-background-color": "#63ab46", + "--kup-hover-color": "#ffffff", + "--kup-title-background-color": "#f1f3f4", + "--kup-title-color": "#000000", + "--kup-icon-color": "#333333", + "--kup-border-color": "#e0e0e0", + "--kup-box-shadow": "0px 0px 7.5px 0px rgba(128, 128, 128, 0.5)", + "--kup-info-color": "#2592df", + "--kup-success-color": "#4d9f02", + "--kup-warning-color": "#ffc107", + "--kup-danger-color": "#d91e18", + "--kup-spinner-color": "#44b383", + "--kup-chart-color-1": "#60c3fc", + "--kup-chart-color-2": "#e268d8", + "--kup-chart-color-3": "#e48b47", + "--kup-chart-color-4": "#81e447", + "--kup-obj-cursor": "inherit", + "--kup-card-zindex": "900", + "--kup-drawer-zindex": "900", + "--kup-navbar-zindex": "900" + }, + "icons": { + "--kup-ascending-icon": "arrow_drop_up", + "--kup-descending-icon": "arrow_drop_down", + "--kup-expanded-icon": "arrow_drop_down", + "--kup-collapsed-icon": "menu-right", + "--kup-dropdown-icon": "arrow_drop_down", + "--kup-clear-icon": "cancel", + "--kup-filter-remove-icon": "filter-remove", + "--kup-key-icon": "key-variant", + "--kup-search-icon": "search" + }, + "imports": [ + "url('https://fonts.googleapis.com/css2?family=Abel&display=swap')" + ] + } +} \ No newline at end of file diff --git a/packages/ketchup/stencil.config.ts b/packages/ketchup/stencil.config.ts index d1286fd9e7..3e0959e3cc 100644 --- a/packages/ketchup/stencil.config.ts +++ b/packages/ketchup/stencil.config.ts @@ -69,6 +69,8 @@ export const config: Config = { { src: 'drawer.html' }, { src: 'dropdown-button.html' }, { src: 'echart.html' }, + { src: 'editor.html' }, + { src: 'editor-example-1.html' }, { src: 'family-tree.html' }, { src: 'form.html' }, { src: 'gantt.html' }, diff --git a/yarn.lock b/yarn.lock index b12a4753f7..bc69afe3a6 100644 --- a/yarn.lock +++ b/yarn.lock @@ -2923,7 +2923,7 @@ __metadata: version: 0.0.0-use.local resolution: "@sme.up/ketchup-react@workspace:packages/ketchup-react" dependencies: - "@sme.up/ketchup": ^9.5.2 + "@sme.up/ketchup": ^9.6.0 "@types/geojson": ^7946.0.10 "@types/node": ^20.2.5 "@types/react": ^18.2.7 @@ -2956,7 +2956,7 @@ __metadata: version: 0.0.0-use.local resolution: "@sme.up/ketchup-showcase@workspace:packages/ketchup-showcase" dependencies: - "@sme.up/ketchup": ^9.5.2 + "@sme.up/ketchup": ^9.6.0 "@typescript-eslint/eslint-plugin": ^5.59.8 "@typescript-eslint/parser": ^5.59.8 "@vue/cli-plugin-babel": ~5.0.8 @@ -2980,7 +2980,7 @@ __metadata: languageName: unknown linkType: soft -"@sme.up/ketchup@^9.5.2, @sme.up/ketchup@workspace:packages/ketchup": +"@sme.up/ketchup@^9.6.0, @sme.up/ketchup@workspace:packages/ketchup": version: 0.0.0-use.local resolution: "@sme.up/ketchup@workspace:packages/ketchup" dependencies: @@ -2992,9 +2992,10 @@ __metadata: "@material/form-field": ^14.0.0 "@material/ripple": ^14.0.0 "@material/textfield": ^14.0.0 - "@stencil/core": ^4.8.1 + "@stencil/core": ^4.12.0 "@stencil/react-output-target": 0.5.3 - "@stencil/sass": ^3.0.7 + "@stencil/sass": ^3.0.9 + "@toast-ui/editor": ^2.5.4 d3-shape: ^3.2.0 dayjs: ^1.11.7 echarts: ^5.4.2 @@ -3043,12 +3044,12 @@ __metadata: languageName: node linkType: hard -"@stencil/core@npm:^4.8.1": - version: 4.8.2 - resolution: "@stencil/core@npm:4.8.2" +"@stencil/core@npm:^4.12.0": + version: 4.12.1 + resolution: "@stencil/core@npm:4.12.1" bin: stencil: bin/stencil - checksum: 74c89ceb40aa88756668e685303b0d3d8bc3ccee20c0fd91c857c68ddcbd1e13dd8c3a7e654f9ded95c722f1e678e8c51cc49c9a3eeee8c330ce2dba65274084 + checksum: 5d19ba883b36599205cbdd0e4bc7aa7f69640a80fa22e9340e88a02a1531da0145783b8f77ae4bcb3885bed7ddd468a700f44465dbeb906397591dbb60e238ce languageName: node linkType: hard @@ -3061,12 +3062,12 @@ __metadata: languageName: node linkType: hard -"@stencil/sass@npm:^3.0.7": - version: 3.0.7 - resolution: "@stencil/sass@npm:3.0.7" +"@stencil/sass@npm:^3.0.9": + version: 3.0.9 + resolution: "@stencil/sass@npm:3.0.9" peerDependencies: "@stencil/core": ">=2.0.0 || >=3.0.0-beta.0 || >= 4.0.0-beta.0 || >= 4.0.0" - checksum: 49930a1ac77375630a26ad20c35f0d91e90f961af47cc65adaa81f0d2e16eb60453076813663782bd095cc4ea2e0779222ca79879c62521e6a5b5af6d00f8f5f + checksum: 2265ac3af2db425b7be0b836ea52aabbd44f55cb97d869eceab5468e8a47dc1ff79e5ef19b2d40a99542f5c3d8a2f812f6829fef18b6f7d551ba6e886c333a3c languageName: node linkType: hard @@ -3082,6 +3083,16 @@ __metadata: languageName: node linkType: hard +"@toast-ui/editor@npm:^2.5.4": + version: 2.5.4 + resolution: "@toast-ui/editor@npm:2.5.4" + dependencies: + "@types/codemirror": 0.0.71 + codemirror: ^5.48.4 + checksum: 3396e34f881c667fa3766f206266c131d5e4eb1d5aff7fb6815601e7b7fbb0af5d93949368d6bb8ca0c915ddf57060249715f892fb428d228234e22243955580 + languageName: node + linkType: hard + "@tootallnate/once@npm:2": version: 2.0.0 resolution: "@tootallnate/once@npm:2.0.0" @@ -3180,6 +3191,15 @@ __metadata: languageName: node linkType: hard +"@types/codemirror@npm:0.0.71": + version: 0.0.71 + resolution: "@types/codemirror@npm:0.0.71" + dependencies: + "@types/tern": "*" + checksum: 185d7f62935e6e7f806d07f2e4cb5201fd9f35b2a68d10a3aa399c96f46dc66dcea7ad9b02a4f43a6286fe4e5fc16a46408cc8500d4687a07553ccdaaec69d9c + languageName: node + linkType: hard + "@types/connect-history-api-fallback@npm:^1.3.5": version: 1.5.4 resolution: "@types/connect-history-api-fallback@npm:1.5.4" @@ -3538,6 +3558,15 @@ __metadata: languageName: node linkType: hard +"@types/tern@npm:*": + version: 0.23.9 + resolution: "@types/tern@npm:0.23.9" + dependencies: + "@types/estree": "*" + checksum: 53f229c79edf9454011f5b37c8539e0e760a130beac953d4e2126823de1ac6b0e2a45612596679fb232ec861826584fcaa272e2254a890b410575683423d56a8 + languageName: node + linkType: hard + "@types/trusted-types@npm:^2.0.2": version: 2.0.7 resolution: "@types/trusted-types@npm:2.0.7" @@ -5623,6 +5652,13 @@ __metadata: languageName: node linkType: hard +"codemirror@npm:^5.48.4": + version: 5.65.16 + resolution: "codemirror@npm:5.65.16" + checksum: 1c5036bfffcce19b1ff91d8b158dcb45faba27047c4093f55ea7ad1165975179eb47c9ef604baa9c4f4ea6bf9817886c767f33e72fa9c62710404029be3c4744 + languageName: node + linkType: hard + "collect-v8-coverage@npm:^1.0.0": version: 1.0.2 resolution: "collect-v8-coverage@npm:1.0.2"