goodteditor-ui 1.0.26 → 1.0.27
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.eslintrc.js +7 -7
- package/.prettierrc +14 -14
- package/README.md +35 -35
- package/babel.config.js +5 -5
- package/index.js +53 -53
- package/jsconfig.json +13 -13
- package/package.json +67 -67
- package/src/App.vue +36 -36
- package/src/components/ui/Avatar.md +68 -68
- package/src/components/ui/Avatar.vue +180 -180
- package/src/components/ui/Badge.md +20 -20
- package/src/components/ui/Badge.vue +75 -75
- package/src/components/ui/Collapse.md +90 -90
- package/src/components/ui/Collapse.vue +86 -86
- package/src/components/ui/ColorPicker/Alpha.vue +114 -114
- package/src/components/ui/ColorPicker/Colors.vue +117 -117
- package/src/components/ui/ColorPicker/Hue.vue +113 -113
- package/src/components/ui/ColorPicker/Preview.vue +55 -55
- package/src/components/ui/ColorPicker/Saturation.vue +123 -123
- package/src/components/ui/ColorPicker/mixin.js +105 -105
- package/src/components/ui/ColorPicker.md +17 -17
- package/src/components/ui/ColorPicker.vue +314 -314
- package/src/components/ui/Datalist.md +41 -41
- package/src/components/ui/Datalist.vue +164 -164
- package/src/components/ui/DatePicker.md +168 -168
- package/src/components/ui/DatePicker.vue +527 -527
- package/src/components/ui/FileSelector.md +105 -105
- package/src/components/ui/FileSelector.vue +82 -82
- package/src/components/ui/Grid.md +130 -130
- package/src/components/ui/Grid.vue +92 -92
- package/src/components/ui/Image.md +59 -59
- package/src/components/ui/Image.vue +57 -57
- package/src/components/ui/InputAutocomplete.md +115 -115
- package/src/components/ui/InputAutocomplete.vue +349 -349
- package/src/components/ui/InputColorPicker.md +51 -51
- package/src/components/ui/InputColorPicker.vue +151 -151
- package/src/components/ui/InputDatePicker.md +121 -121
- package/src/components/ui/InputDatePicker.vue +326 -326
- package/src/components/ui/InputTags.md +51 -51
- package/src/components/ui/InputTags.vue +184 -184
- package/src/components/ui/InputTimePicker.md +25 -25
- package/src/components/ui/InputTimePicker.vue +253 -253
- package/src/components/ui/InputUnits.md +20 -20
- package/src/components/ui/InputUnits.vue +257 -257
- package/src/components/ui/Lazy.md +37 -37
- package/src/components/ui/Lazy.vue +92 -92
- package/src/components/ui/Pagination.md +74 -74
- package/src/components/ui/Pagination.vue +138 -138
- package/src/components/ui/Paginator.md +34 -34
- package/src/components/ui/Paginator.vue +83 -83
- package/src/components/ui/Popover.md +34 -34
- package/src/components/ui/Popover.vue +274 -274
- package/src/components/ui/Popup.md +59 -59
- package/src/components/ui/Popup.vue +150 -150
- package/src/components/ui/ResponsiveContainer.md +58 -58
- package/src/components/ui/ResponsiveContainer.vue +99 -99
- package/src/components/ui/Select.md +187 -187
- package/src/components/ui/Select.vue +421 -421
- package/src/components/ui/TimePicker.md +50 -50
- package/src/components/ui/TimePicker.vue +252 -252
- package/src/components/ui/Tooltip.md +54 -54
- package/src/components/ui/Tooltip.vue +113 -113
- package/src/components/ui/WysiwygEditor/WysiwygEditor.d.ts +128 -128
- package/src/components/ui/WysiwygEditor/constants.js +273 -273
- package/src/components/ui/WysiwygEditor/extensions/blockquote.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/bold.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/bullet-list.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/code-block.js +13 -13
- package/src/components/ui/WysiwygEditor/extensions/code.js +13 -13
- package/src/components/ui/WysiwygEditor/extensions/font-size.js +34 -34
- package/src/components/ui/WysiwygEditor/extensions/formatting.js +14 -14
- package/src/components/ui/WysiwygEditor/extensions/heading.js +13 -13
- package/src/components/ui/WysiwygEditor/extensions/horizontal-rule.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/image.js +37 -33
- package/src/components/ui/WysiwygEditor/extensions/index.d.ts +32 -32
- package/src/components/ui/WysiwygEditor/extensions/index.js +32 -32
- package/src/components/ui/WysiwygEditor/extensions/italic.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/link.js +16 -16
- package/src/components/ui/WysiwygEditor/extensions/list-item.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/ordered-list.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/paragraph.js +23 -23
- package/src/components/ui/WysiwygEditor/extensions/strike.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/table-cell.js +13 -13
- package/src/components/ui/WysiwygEditor/extensions/table-header.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/table-row.js +15 -15
- package/src/components/ui/WysiwygEditor/extensions/table.js +29 -29
- package/src/components/ui/WysiwygEditor/extensions/text-align.js +6 -6
- package/src/components/ui/WysiwygEditor/extensions/text-style.js +12 -12
- package/src/components/ui/WysiwygEditor/extensions/underline.js +15 -15
- package/src/components/ui/WysiwygEditor/index.d.ts +4 -4
- package/src/components/ui/WysiwygEditor/index.js +4 -4
- package/src/components/ui/WysiwygEditor/renders/Button.vue +28 -28
- package/src/components/ui/WysiwygEditor/renders/ColorPicker.vue +41 -41
- package/src/components/ui/WysiwygEditor/renders/Image.vue +200 -162
- package/src/components/ui/WysiwygEditor/renders/InputAuto.vue +34 -34
- package/src/components/ui/WysiwygEditor/renders/InputUnits.vue +37 -37
- package/src/components/ui/WysiwygEditor/renders/Link.vue +82 -82
- package/src/components/ui/WysiwygEditor/renders/Select.vue +47 -47
- package/src/components/ui/WysiwygEditor/renders/ToolbarPopover.vue +49 -49
- package/src/components/ui/WysiwygEditor/renders/components/Popover.vue +15 -0
- package/src/components/ui/WysiwygEditor/renders/components/WithPopover.vue +35 -35
- package/src/components/ui/WysiwygEditor/renders/index.d.ts +8 -8
- package/src/components/ui/WysiwygEditor/renders/index.js +8 -8
- package/src/components/ui/WysiwygEditor/renders/mixins/RenderMixin.js +39 -39
- package/src/components/ui/WysiwygEditor/renders/mixins/index.js +1 -1
- package/src/components/ui/WysiwygEditor/tools-and-commands.js +709 -702
- package/src/components/ui/WysiwygEditor/utils.js +72 -72
- package/src/components/ui/WysiwygEditor.md +18 -18
- package/src/components/ui/WysiwygEditor.vue +266 -266
- package/src/components/ui/utils/FormComponent.js +107 -107
- package/src/components/ui/utils/Helpers.js +84 -84
- package/src/components/ui/utils/WithPopover.js +81 -81
- package/src/main.js +8 -8
- package/styleguide.config.js +37 -37
- package/vue.config.js +8 -8
- package/dist/js.png +0 -0
|
@@ -1,72 +1,72 @@
|
|
|
1
|
-
import { ToolsMap } from './tools-and-commands';
|
|
2
|
-
|
|
3
|
-
/**
|
|
4
|
-
* @typedef {import('./WysiwygEditor').ToolDef} Tool
|
|
5
|
-
* @typedef {import('./WysiwygEditor').CommandDef} Command
|
|
6
|
-
*/
|
|
7
|
-
|
|
8
|
-
/**
|
|
9
|
-
* @param {Tool | string} tool
|
|
10
|
-
* @param {string} toolName
|
|
11
|
-
* @return boolean
|
|
12
|
-
*/
|
|
13
|
-
const findTool = (tool, toolName) => {
|
|
14
|
-
if (typeof tool === 'string') {
|
|
15
|
-
return toolName === tool;
|
|
16
|
-
}
|
|
17
|
-
|
|
18
|
-
return tool?.name === toolName;
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* @param {Tool[][]} tools
|
|
23
|
-
* @return Tool[][]
|
|
24
|
-
*/
|
|
25
|
-
export const buildToolGroups = (tools) => {
|
|
26
|
-
const toolsFlatted = tools.flat();
|
|
27
|
-
|
|
28
|
-
if (toolsFlatted.length === 0) {
|
|
29
|
-
return [Object.values(ToolsMap)];
|
|
30
|
-
}
|
|
31
|
-
|
|
32
|
-
const availableTools = Object
|
|
33
|
-
.values(ToolsMap)
|
|
34
|
-
.filter(({ name }) => toolsFlatted.some((tool) => findTool(tool, name)));
|
|
35
|
-
|
|
36
|
-
/**
|
|
37
|
-
* @param {Tool[]} toolsGroup
|
|
38
|
-
* @return Tool[]
|
|
39
|
-
*/
|
|
40
|
-
const populateToolsGroup = (toolsGroup) =>
|
|
41
|
-
toolsGroup.reduce((acc, tool) => {
|
|
42
|
-
const { name: toolName = tool, ...rest } = typeof tool === 'string' ? {} : tool;
|
|
43
|
-
const foundTool = availableTools.find(({ name }) => findTool(tool, name));
|
|
44
|
-
|
|
45
|
-
return [...acc, { ...foundTool, ...rest }];
|
|
46
|
-
}, []);
|
|
47
|
-
|
|
48
|
-
return tools.reduce((acc, toolsGroup) => [...acc, populateToolsGroup(toolsGroup)], []);
|
|
49
|
-
};
|
|
50
|
-
|
|
51
|
-
/**
|
|
52
|
-
* @param {Tool|Command} value
|
|
53
|
-
* @param {Record<string, any>} context
|
|
54
|
-
* @return {Tool|Command}
|
|
55
|
-
*/
|
|
56
|
-
export const bindContext = (value, context) => {
|
|
57
|
-
if (value == null || typeof value !== 'object') {
|
|
58
|
-
return value;
|
|
59
|
-
}
|
|
60
|
-
|
|
61
|
-
return Object.entries(value).reduce((acc, [propName, propValue]) => {
|
|
62
|
-
if (typeof propValue === 'function') {
|
|
63
|
-
return { ...acc, [propName]: propValue.bind(context) };
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
if (Array.isArray(propValue)) {
|
|
67
|
-
return { ...acc, [propName]: propValue.map((childProp) => bindContext(childProp, context)) };
|
|
68
|
-
}
|
|
69
|
-
|
|
70
|
-
return { ...acc, [propName]: propValue };
|
|
71
|
-
}, {});
|
|
72
|
-
};
|
|
1
|
+
import { ToolsMap } from './tools-and-commands';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* @typedef {import('./WysiwygEditor').ToolDef} Tool
|
|
5
|
+
* @typedef {import('./WysiwygEditor').CommandDef} Command
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
/**
|
|
9
|
+
* @param {Tool | string} tool
|
|
10
|
+
* @param {string} toolName
|
|
11
|
+
* @return boolean
|
|
12
|
+
*/
|
|
13
|
+
const findTool = (tool, toolName) => {
|
|
14
|
+
if (typeof tool === 'string') {
|
|
15
|
+
return toolName === tool;
|
|
16
|
+
}
|
|
17
|
+
|
|
18
|
+
return tool?.name === toolName;
|
|
19
|
+
};
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* @param {Tool[][]} tools
|
|
23
|
+
* @return Tool[][]
|
|
24
|
+
*/
|
|
25
|
+
export const buildToolGroups = (tools) => {
|
|
26
|
+
const toolsFlatted = tools.flat();
|
|
27
|
+
|
|
28
|
+
if (toolsFlatted.length === 0) {
|
|
29
|
+
return [Object.values(ToolsMap)];
|
|
30
|
+
}
|
|
31
|
+
|
|
32
|
+
const availableTools = Object
|
|
33
|
+
.values(ToolsMap)
|
|
34
|
+
.filter(({ name }) => toolsFlatted.some((tool) => findTool(tool, name)));
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* @param {Tool[]} toolsGroup
|
|
38
|
+
* @return Tool[]
|
|
39
|
+
*/
|
|
40
|
+
const populateToolsGroup = (toolsGroup) =>
|
|
41
|
+
toolsGroup.reduce((acc, tool) => {
|
|
42
|
+
const { name: toolName = tool, ...rest } = typeof tool === 'string' ? {} : tool;
|
|
43
|
+
const foundTool = availableTools.find(({ name }) => findTool(tool, name));
|
|
44
|
+
|
|
45
|
+
return [...acc, { ...foundTool, ...rest }];
|
|
46
|
+
}, []);
|
|
47
|
+
|
|
48
|
+
return tools.reduce((acc, toolsGroup) => [...acc, populateToolsGroup(toolsGroup)], []);
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
/**
|
|
52
|
+
* @param {Tool|Command} value
|
|
53
|
+
* @param {Record<string, any>} context
|
|
54
|
+
* @return {Tool|Command}
|
|
55
|
+
*/
|
|
56
|
+
export const bindContext = (value, context) => {
|
|
57
|
+
if (value == null || typeof value !== 'object') {
|
|
58
|
+
return value;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
return Object.entries(value).reduce((acc, [propName, propValue]) => {
|
|
62
|
+
if (typeof propValue === 'function') {
|
|
63
|
+
return { ...acc, [propName]: propValue.bind(context) };
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
if (Array.isArray(propValue)) {
|
|
67
|
+
return { ...acc, [propName]: propValue.map((childProp) => bindContext(childProp, context)) };
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
return { ...acc, [propName]: propValue };
|
|
71
|
+
}, {});
|
|
72
|
+
};
|
|
@@ -1,18 +1,18 @@
|
|
|
1
|
-
```vue
|
|
2
|
-
<template>
|
|
3
|
-
<div class="pad-l5">
|
|
4
|
-
<ui-wysiwyg-editor v-model="model"></ui-wysiwyg-editor>
|
|
5
|
-
</div>
|
|
6
|
-
</template>
|
|
7
|
-
<script>
|
|
8
|
-
import UiWysiwygEditor from './WysiwygEditor.vue';
|
|
9
|
-
export default {
|
|
10
|
-
components: { UiWysiwygEditor },
|
|
11
|
-
data: () => ({
|
|
12
|
-
model: `<p>This WYSIWYG is based on
|
|
13
|
-
<a target="_blank" rel="noopener noreferrer nofollow" href="https://tiptap.dev/" class="color-link">tiptap</a>
|
|
14
|
-
editor framework.</p>`
|
|
15
|
-
})
|
|
16
|
-
};
|
|
17
|
-
</script>
|
|
18
|
-
```
|
|
1
|
+
```vue
|
|
2
|
+
<template>
|
|
3
|
+
<div class="pad-l5">
|
|
4
|
+
<ui-wysiwyg-editor v-model="model"></ui-wysiwyg-editor>
|
|
5
|
+
</div>
|
|
6
|
+
</template>
|
|
7
|
+
<script>
|
|
8
|
+
import UiWysiwygEditor from './WysiwygEditor.vue';
|
|
9
|
+
export default {
|
|
10
|
+
components: { UiWysiwygEditor },
|
|
11
|
+
data: () => ({
|
|
12
|
+
model: `<p>This WYSIWYG is based on
|
|
13
|
+
<a target="_blank" rel="noopener noreferrer nofollow" href="https://tiptap.dev/" class="color-link">tiptap</a>
|
|
14
|
+
editor framework.</p>`
|
|
15
|
+
})
|
|
16
|
+
};
|
|
17
|
+
</script>
|
|
18
|
+
```
|