@kwiz/fluentui 1.0.33 → 1.0.34
Sign up to get free protection for your applications and to get access to all the features.
- package/dist/controls/html-editor/editor.d.ts +20 -0
- package/dist/controls/html-editor/editor.js +53 -0
- package/dist/controls/html-editor/editor.js.map +1 -0
- package/dist/controls/svg.d.ts +1 -0
- package/dist/controls/svg.js +10 -0
- package/dist/controls/svg.js.map +1 -1
- package/dist/index.d.ts +1 -0
- package/dist/index.js +1 -0
- package/dist/index.js.map +1 -1
- package/package.json +2 -1
- package/src/controls/html-editor/editor.tsx +92 -0
- package/src/controls/svg.tsx +11 -0
- package/src/index.ts +1 -0
@@ -0,0 +1,20 @@
|
|
1
|
+
import React from 'react';
|
2
|
+
interface IProps {
|
3
|
+
value?: string;
|
4
|
+
onChange?: (value: string) => void;
|
5
|
+
onSave?: (value: string) => void;
|
6
|
+
onCancel?: () => void;
|
7
|
+
readonly?: boolean;
|
8
|
+
css?: string[];
|
9
|
+
smallToolbar?: boolean;
|
10
|
+
editOnDemand?: boolean;
|
11
|
+
/** all designers */
|
12
|
+
kitchensink?: boolean;
|
13
|
+
speech?: boolean;
|
14
|
+
spellcheck?: boolean;
|
15
|
+
table?: boolean;
|
16
|
+
media?: boolean;
|
17
|
+
source?: boolean;
|
18
|
+
}
|
19
|
+
export declare const HtmlEditor: React.FunctionComponent<React.PropsWithChildren<IProps>>;
|
20
|
+
export {};
|
@@ -0,0 +1,53 @@
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
2
|
+
import { makeStyles, tokens } from '@fluentui/react-components';
|
3
|
+
import { DismissRegular, SaveRegular } from '@fluentui/react-icons';
|
4
|
+
import JoditEditor, { Jodit } from "jodit-react";
|
5
|
+
import React, { useRef } from 'react';
|
6
|
+
import { IconToSVG } from '../svg';
|
7
|
+
const useStyles = makeStyles({
|
8
|
+
htmlDiv: {
|
9
|
+
border: `${tokens.strokeWidthThin} solid ${tokens.colorNeutralStrokeAccessible}`,
|
10
|
+
padding: tokens.spacingHorizontalS,
|
11
|
+
minHeight: `100px`
|
12
|
+
}
|
13
|
+
});
|
14
|
+
export const HtmlEditor = (props) => {
|
15
|
+
const classes = useStyles();
|
16
|
+
const [active, setActive] = React.useState(false);
|
17
|
+
//quill react demos: https://codesandbox.io/examples/package/react-quill
|
18
|
+
const editor = useRef(null);
|
19
|
+
const extraCondig = {
|
20
|
+
uploader: {
|
21
|
+
insertImageAsBase64URI: true,
|
22
|
+
toolbarStickyOffset: 30,
|
23
|
+
},
|
24
|
+
autofocus: props.editOnDemand,
|
25
|
+
};
|
26
|
+
const options = props.kitchensink ? {
|
27
|
+
speech: true,
|
28
|
+
spellcheck: true,
|
29
|
+
table: true,
|
30
|
+
media: true,
|
31
|
+
source: true,
|
32
|
+
} : props;
|
33
|
+
Jodit.defaultOptions.controls.save = {
|
34
|
+
childTemplate: () => IconToSVG(_jsx(SaveRegular, {})),
|
35
|
+
exec: () => {
|
36
|
+
props.onSave(editor.current.value);
|
37
|
+
}
|
38
|
+
};
|
39
|
+
Jodit.defaultOptions.controls.cancel = {
|
40
|
+
childTemplate: () => IconToSVG(_jsx(DismissRegular, {})),
|
41
|
+
exec: () => {
|
42
|
+
props.onCancel();
|
43
|
+
}
|
44
|
+
};
|
45
|
+
return (props.editOnDemand && !active
|
46
|
+
? _jsx("div", { className: classes.htmlDiv, dangerouslySetInnerHTML: { __html: props.value || "" }, tabIndex: 0, onFocus: () => setActive(true), onClick: () => setActive(true) })
|
47
|
+
: _jsx(JoditEditor, { ref: editor, value: props.value || "", config: Object.assign(Object.assign({}, extraCondig), { readonly: props.readonly, inline: true, statusbar: false, toolbarButtonSize: props.smallToolbar ? "xsmall" : "middle", buttons: `${props.onSave && 'save,'}${props.onCancel && 'cancel,'}${(props.onSave || props.onCancel) && ',|'}bold,italic,underline,strikethrough,|,ul,ol,font,fontsize,paragraph,lineHeight,superscript,subscript,copyformat,brush,eraser,|,${options.media && 'image,video,'}${options.spellcheck && 'spellcheck,'}${options.speech && 'speechRecognize,'}hr,${options.table && 'table,'}link,indent,outdent,${options.source && '---,source,'}`.replace(/undefined/g, '') }), onBlur: newContent => {
|
48
|
+
if (props.onChange)
|
49
|
+
props.onChange(newContent);
|
50
|
+
setActive(false);
|
51
|
+
} }));
|
52
|
+
};
|
53
|
+
//# sourceMappingURL=editor.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"editor.js","sourceRoot":"","sources":["../../../src/controls/html-editor/editor.tsx"],"names":[],"mappings":"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"}
|
package/dist/controls/svg.d.ts
CHANGED
package/dist/controls/svg.js
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
2
2
|
import { tokens } from '@fluentui/react-components';
|
3
|
+
import { flushSync } from 'react-dom';
|
4
|
+
import { createRoot } from 'react-dom/client';
|
3
5
|
export const YouTubeIcon = (props) => {
|
4
6
|
return (_jsx("svg", { height: `${props.size}px`, width: `${props.size}px`, version: "1.1", id: "Layer_1", xmlns: "http://www.w3.org/2000/svg", xmlnsXlink: "http://www.w3.org/1999/xlink", viewBox: "0 0 461.001 461.001", xmlSpace: "preserve", children: _jsx("g", { children: _jsx("path", { style: { fill: "#F61C0D" }, d: "M365.257,67.393H95.744C42.866,67.393,0,110.259,0,163.137v134.728\nc0,52.878,42.866,95.744,95.744,95.744h269.513c52.878,0,95.744-42.866,95.744-95.744V163.137\nC461.001,110.259,418.135,67.393,365.257,67.393z M300.506,237.056l-126.06,60.123c-3.359,1.602-7.239-0.847-7.239-4.568V168.607\nc0-3.774,3.982-6.22,7.348-4.514l126.06,63.881C304.363,229.873,304.298,235.248,300.506,237.056z" }) }) }));
|
5
7
|
};
|
@@ -42,4 +44,12 @@ export const GetSVGSplitIcon = (props) => {
|
|
42
44
|
<path d="M10.646 13.146l0.707 0.707-2.853 2.854-2.854-2.854 0.707-0.707 1.647 1.647v-3.772h1v3.772l1.646-1.647zM8 2.207v3.772h1v-3.772l1.646 1.646 0.707-0.707-2.853-2.853-2.854 2.853 0.707 0.707 1.647-1.646zM0 8v1h17v-1h-17z" />
|
43
45
|
</svg>`;
|
44
46
|
};
|
47
|
+
export function IconToSVG(icon) {
|
48
|
+
const iconDiv = document.createElement('div');
|
49
|
+
const root = createRoot(iconDiv);
|
50
|
+
flushSync(() => {
|
51
|
+
root.render(icon);
|
52
|
+
});
|
53
|
+
return iconDiv.innerHTML;
|
54
|
+
}
|
45
55
|
//# sourceMappingURL=svg.js.map
|
package/dist/controls/svg.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"svg.js","sourceRoot":"","sources":["../../src/controls/svg.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,4BAA4B,CAAC;
|
1
|
+
{"version":3,"file":"svg.js","sourceRoot":"","sources":["../../src/controls/svg.tsx"],"names":[],"mappings":"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"}
|
package/dist/index.d.ts
CHANGED
@@ -8,6 +8,7 @@ export * from './controls/error-boundary';
|
|
8
8
|
export * from './controls/field-editor';
|
9
9
|
export * from './controls/file-upload';
|
10
10
|
export * from './controls/horizontal';
|
11
|
+
export * from './controls/html-editor/editor';
|
11
12
|
export * from './controls/input';
|
12
13
|
export * from './controls/kwizoverflow';
|
13
14
|
export * from './controls/list';
|
package/dist/index.js
CHANGED
@@ -8,6 +8,7 @@ export * from './controls/error-boundary';
|
|
8
8
|
export * from './controls/field-editor';
|
9
9
|
export * from './controls/file-upload';
|
10
10
|
export * from './controls/horizontal';
|
11
|
+
export * from './controls/html-editor/editor';
|
11
12
|
export * from './controls/input';
|
12
13
|
export * from './controls/kwizoverflow';
|
13
14
|
export * from './controls/list';
|
package/dist/index.js.map
CHANGED
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,kBAAkB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,6BAA6B,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAE5E,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iBAAiB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,sBAAsB,CAAC;AACrC,cAAc,mBAAmB,CAAC;AAClC,cAAc,qBAAqB,CAAC;AACpC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,2BAA2B,CAAC;AAC1C,cAAc,yBAAyB,CAAC;AACxC,cAAc,wBAAwB,CAAC;AACvC,cAAc,uBAAuB,CAAC;AACtC,cAAc,+BAA+B,CAAC;AAC9C,cAAc,kBAAkB,CAAC;AACjC,cAAc,yBAAyB,CAAC;AACxC,cAAc,iBAAiB,CAAC;AAChC,cAAc,oBAAoB,CAAC;AACnC,cAAc,iBAAiB,CAAC;AAChC,cAAc,wBAAwB,CAAC;AACvC,cAAc,mBAAmB,CAAC;AAClC,cAAc,mBAAmB,CAAC;AAClC,cAAc,oBAAoB,CAAC;AACnC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,qBAAqB,CAAC;AACpC,cAAc,6BAA6B,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAC;AAE5E,cAAc,6BAA6B,CAAC;AAC5C,cAAc,iBAAiB,CAAC;AAChC,OAAO,EAAE,eAAe,EAAE,WAAW,EAAE,MAAM,iBAAiB,CAAC"}
|
package/package.json
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
{
|
2
2
|
"name": "@kwiz/fluentui",
|
3
|
-
"version": "1.0.
|
3
|
+
"version": "1.0.34",
|
4
4
|
"description": "KWIZ common controls for FluentUI",
|
5
5
|
"module": "dist/index.js",
|
6
6
|
"types": "dist/index.d.ts",
|
@@ -59,6 +59,7 @@
|
|
59
59
|
"@kwiz/common": "^1.0.83",
|
60
60
|
"esbuild": "^0.19.12",
|
61
61
|
"get-tsconfig": "^4.7.2",
|
62
|
+
"jodit-react": "^4.1.2",
|
62
63
|
"react-dnd": "^16.0.1",
|
63
64
|
"react-dnd-html5-backend": "^16.0.1",
|
64
65
|
"resolve-pkg-maps": "^1.0.0"
|
@@ -0,0 +1,92 @@
|
|
1
|
+
import { makeStyles, tokens } from '@fluentui/react-components';
|
2
|
+
import { DismissRegular, SaveRegular } from '@fluentui/react-icons';
|
3
|
+
import JoditEditor, { Jodit } from "jodit-react";
|
4
|
+
import React, { useRef } from 'react';
|
5
|
+
import { IconToSVG } from '../svg';
|
6
|
+
|
7
|
+
const useStyles = makeStyles({
|
8
|
+
htmlDiv: {
|
9
|
+
border: `${tokens.strokeWidthThin} solid ${tokens.colorNeutralStrokeAccessible}`,
|
10
|
+
padding: tokens.spacingHorizontalS,
|
11
|
+
minHeight: `100px`
|
12
|
+
}
|
13
|
+
});
|
14
|
+
|
15
|
+
interface IProps {
|
16
|
+
value?: string;
|
17
|
+
onChange?: (value: string) => void;
|
18
|
+
onSave?: (value: string) => void;
|
19
|
+
onCancel?: () => void;
|
20
|
+
readonly?: boolean;
|
21
|
+
css?: string[];
|
22
|
+
smallToolbar?: boolean;
|
23
|
+
editOnDemand?: boolean;
|
24
|
+
|
25
|
+
/** all designers */
|
26
|
+
kitchensink?: boolean;
|
27
|
+
speech?: boolean;
|
28
|
+
spellcheck?: boolean;
|
29
|
+
table?: boolean;
|
30
|
+
media?: boolean;
|
31
|
+
source?: boolean;
|
32
|
+
|
33
|
+
}
|
34
|
+
export const HtmlEditor: React.FunctionComponent<React.PropsWithChildren<IProps>> = (props) => {
|
35
|
+
const classes = useStyles();
|
36
|
+
const [active, setActive] = React.useState(false);
|
37
|
+
|
38
|
+
//quill react demos: https://codesandbox.io/examples/package/react-quill
|
39
|
+
const editor = useRef<Jodit>(null);
|
40
|
+
|
41
|
+
const extraCondig = {
|
42
|
+
uploader: {
|
43
|
+
insertImageAsBase64URI: true,
|
44
|
+
toolbarStickyOffset: 30,
|
45
|
+
},
|
46
|
+
autofocus: props.editOnDemand,
|
47
|
+
};
|
48
|
+
|
49
|
+
const options = props.kitchensink ? {
|
50
|
+
speech: true,
|
51
|
+
spellcheck: true,
|
52
|
+
table: true,
|
53
|
+
media: true,
|
54
|
+
source: true,
|
55
|
+
} : props
|
56
|
+
|
57
|
+
Jodit.defaultOptions.controls.save = {
|
58
|
+
childTemplate: () => IconToSVG(<SaveRegular />),
|
59
|
+
exec: () => {
|
60
|
+
props.onSave(editor.current.value);
|
61
|
+
}
|
62
|
+
};
|
63
|
+
Jodit.defaultOptions.controls.cancel = {
|
64
|
+
childTemplate: () => IconToSVG(<DismissRegular />),
|
65
|
+
exec: () => {
|
66
|
+
props.onCancel();
|
67
|
+
}
|
68
|
+
};
|
69
|
+
return (props.editOnDemand && !active
|
70
|
+
? <div className={classes.htmlDiv} dangerouslySetInnerHTML={{ __html: props.value || "" }}
|
71
|
+
tabIndex={0} onFocus={() => setActive(true)}
|
72
|
+
onClick={() => setActive(true)} />
|
73
|
+
: <JoditEditor
|
74
|
+
ref={editor}
|
75
|
+
value={props.value || ""}
|
76
|
+
config={{
|
77
|
+
...extraCondig,
|
78
|
+
readonly: props.readonly,
|
79
|
+
inline: true,
|
80
|
+
statusbar: false,
|
81
|
+
toolbarButtonSize: props.smallToolbar ? "xsmall" : "middle",
|
82
|
+
buttons: `${props.onSave && 'save,'}${props.onCancel && 'cancel,'}${(props.onSave || props.onCancel) && ',|'}bold,italic,underline,strikethrough,|,ul,ol,font,fontsize,paragraph,lineHeight,superscript,subscript,copyformat,brush,eraser,|,${options.media && 'image,video,'}${options.spellcheck && 'spellcheck,'}${options.speech && 'speechRecognize,'}hr,${options.table && 'table,'}link,indent,outdent,${options.source && '---,source,'}`.replace(/undefined/g, ''),
|
83
|
+
}}
|
84
|
+
onBlur={newContent => {
|
85
|
+
if (props.onChange)
|
86
|
+
props.onChange(newContent);
|
87
|
+
setActive(false);
|
88
|
+
}} // preferred to use only this option to update the content for performance reasons
|
89
|
+
//onChange={newContent => { }}
|
90
|
+
/>
|
91
|
+
);
|
92
|
+
}
|
package/src/controls/svg.tsx
CHANGED
@@ -1,5 +1,7 @@
|
|
1
1
|
import { tokens } from '@fluentui/react-components';
|
2
2
|
import React from 'react';
|
3
|
+
import { flushSync } from 'react-dom';
|
4
|
+
import { createRoot } from 'react-dom/client';
|
3
5
|
|
4
6
|
interface IProps {
|
5
7
|
size: number;
|
@@ -118,3 +120,12 @@ export const GetSVGSplitIcon = (props: { size: number }) => {
|
|
118
120
|
<path d="M10.646 13.146l0.707 0.707-2.853 2.854-2.854-2.854 0.707-0.707 1.647 1.647v-3.772h1v3.772l1.646-1.647zM8 2.207v3.772h1v-3.772l1.646 1.646 0.707-0.707-2.853-2.853-2.854 2.853 0.707 0.707 1.647-1.646zM0 8v1h17v-1h-17z" />
|
119
121
|
</svg>`;
|
120
122
|
}
|
123
|
+
|
124
|
+
export function IconToSVG(icon: JSX.Element) {
|
125
|
+
const iconDiv = document.createElement('div');
|
126
|
+
const root = createRoot(iconDiv);
|
127
|
+
flushSync(() => {
|
128
|
+
root.render(icon);
|
129
|
+
});
|
130
|
+
return iconDiv.innerHTML;
|
131
|
+
}
|
package/src/index.ts
CHANGED
@@ -8,6 +8,7 @@ export * from './controls/error-boundary';
|
|
8
8
|
export * from './controls/field-editor';
|
9
9
|
export * from './controls/file-upload';
|
10
10
|
export * from './controls/horizontal';
|
11
|
+
export * from './controls/html-editor/editor';
|
11
12
|
export * from './controls/input';
|
12
13
|
export * from './controls/kwizoverflow';
|
13
14
|
export * from './controls/list';
|