@m4l/components 9.17.0 → 9.17.1-beta-feature-731-m4l-components-code-editor.0

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.
Files changed (44) hide show
  1. package/@types/types.d.ts +11 -0
  2. package/components/extended/ReactSimpleCodeEditor/CodeEditor.d.ts +6 -0
  3. package/components/extended/ReactSimpleCodeEditor/CodeEditor.d.ts.map +1 -0
  4. package/components/extended/ReactSimpleCodeEditor/CodeEditor.js +247 -0
  5. package/components/extended/ReactSimpleCodeEditor/CodeEditor.styles.d.ts +3 -0
  6. package/components/extended/ReactSimpleCodeEditor/CodeEditor.styles.d.ts.map +1 -0
  7. package/components/extended/ReactSimpleCodeEditor/CodeEditor.styles.js +297 -0
  8. package/components/extended/ReactSimpleCodeEditor/constants.d.ts +82 -0
  9. package/components/extended/ReactSimpleCodeEditor/constants.d.ts.map +1 -0
  10. package/components/extended/ReactSimpleCodeEditor/constants.js +149 -0
  11. package/components/extended/ReactSimpleCodeEditor/dictionary.d.ts +11 -0
  12. package/components/extended/ReactSimpleCodeEditor/dictionary.d.ts.map +1 -0
  13. package/components/extended/ReactSimpleCodeEditor/dictionary.js +7 -0
  14. package/components/extended/ReactSimpleCodeEditor/helpers/highlighting.d.ts +59 -0
  15. package/components/extended/ReactSimpleCodeEditor/helpers/highlighting.d.ts.map +1 -0
  16. package/components/extended/ReactSimpleCodeEditor/helpers/highlighting.js +1063 -0
  17. package/components/extended/ReactSimpleCodeEditor/helpers/languageIcon.d.ts +6 -0
  18. package/components/extended/ReactSimpleCodeEditor/helpers/languageIcon.d.ts.map +1 -0
  19. package/components/extended/ReactSimpleCodeEditor/helpers/languageIcon.js +7 -0
  20. package/components/extended/ReactSimpleCodeEditor/index.d.ts +4 -0
  21. package/components/extended/ReactSimpleCodeEditor/index.d.ts.map +1 -0
  22. package/components/extended/ReactSimpleCodeEditor/slots/CodeEditorEnum.d.ts +18 -0
  23. package/components/extended/ReactSimpleCodeEditor/slots/CodeEditorEnum.d.ts.map +1 -0
  24. package/components/extended/ReactSimpleCodeEditor/slots/CodeEditorEnum.js +4 -0
  25. package/components/extended/ReactSimpleCodeEditor/slots/CodeEditorSlots.d.ts +84 -0
  26. package/components/extended/ReactSimpleCodeEditor/slots/CodeEditorSlots.d.ts.map +1 -0
  27. package/components/extended/ReactSimpleCodeEditor/slots/CodeEditorSlots.js +63 -0
  28. package/components/extended/ReactSimpleCodeEditor/slots/index.d.ts +3 -0
  29. package/components/extended/ReactSimpleCodeEditor/slots/index.d.ts.map +1 -0
  30. package/components/extended/ReactSimpleCodeEditor/storybookRuntime.d.ts +15 -0
  31. package/components/extended/ReactSimpleCodeEditor/storybookRuntime.d.ts.map +1 -0
  32. package/components/extended/ReactSimpleCodeEditor/types.d.ts +127 -0
  33. package/components/extended/ReactSimpleCodeEditor/types.d.ts.map +1 -0
  34. package/components/extended/index.d.ts +1 -0
  35. package/components/extended/index.d.ts.map +1 -1
  36. package/components/hook-form/RHFCodeEditor/RHFCodeEditor.d.ts +7 -0
  37. package/components/hook-form/RHFCodeEditor/RHFCodeEditor.d.ts.map +1 -0
  38. package/components/hook-form/RHFCodeEditor/RHFCodeEditor.js +6 -0
  39. package/components/hook-form/RHFCodeEditor/index.d.ts +3 -0
  40. package/components/hook-form/RHFCodeEditor/index.d.ts.map +1 -0
  41. package/components/hook-form/index.d.ts +1 -0
  42. package/components/hook-form/index.d.ts.map +1 -1
  43. package/index.js +561 -548
  44. package/package.json +12 -9
@@ -0,0 +1,6 @@
1
+ import { CodeEditorLanguageIcon } from '../types';
2
+ /**
3
+ * Resolve the language chip icon provided by the current instance, falling back to the generic file icon.
4
+ */
5
+ export declare function resolveCodeEditorLanguageIcon(languageIcon?: CodeEditorLanguageIcon): CodeEditorLanguageIcon;
6
+ //# sourceMappingURL=languageIcon.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"languageIcon.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/helpers/languageIcon.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,UAAU,CAAC;AAEvD;;GAEG;AACH,wBAAgB,6BAA6B,CAC3C,YAAY,CAAC,EAAE,sBAAsB,GACpC,sBAAsB,CAExB"}
@@ -0,0 +1,7 @@
1
+ import { CODE_EDITOR_FALLBACK_LANGUAGE_ICON as r } from "../constants.js";
2
+ function n(o) {
3
+ return o ?? r;
4
+ }
5
+ export {
6
+ n as resolveCodeEditorLanguageIcon
7
+ };
@@ -0,0 +1,4 @@
1
+ export { CodeEditor } from './CodeEditor';
2
+ export { createCodeEditorLezerSyntaxValidator, DEFAULT_CODE_EDITOR_AT_LANGUAGE_TEMPLATE, ensureCodeEditorRuntimeDependencies, registerCodeEditorLanguage, registerCodeEditorLanguageTemplate, registerCodeEditorSyntaxValidator, resolveCodeEditorLanguage, resolveCodeEditorLanguageTemplate, } from './helpers/highlighting';
3
+ export type { CodeEditorCustomLanguages, CodeEditorLanguage, CodeEditorLanguageIcon, CodeEditorLezerParser, CodeEditorLezerSyntaxValidatorOptions, CodeEditorLanguageTemplate, CodeEditorLanguageTemplateInput, CodeEditorLanguageTemplateName, CodeEditorLanguageTemplateTokens, CodeEditorLanguageTemplateType, CodeEditorOwnerState, CodeEditorProps, CodeEditorRuntimeDependency, CodeEditorSyntaxValidationContext, CodeEditorSyntaxValidationResult, CodeEditorSyntaxValidator, CodeEditorSlotsType, CodeEditorStyles, CodeEditorVariant, } from './types';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC1C,OAAO,EACL,oCAAoC,EACpC,wCAAwC,EACxC,mCAAmC,EACnC,0BAA0B,EAC1B,kCAAkC,EAClC,iCAAiC,EACjC,yBAAyB,EACzB,iCAAiC,GAClC,MAAM,wBAAwB,CAAC;AAChC,YAAY,EACV,yBAAyB,EACzB,kBAAkB,EAClB,sBAAsB,EACtB,qBAAqB,EACrB,qCAAqC,EACrC,0BAA0B,EAC1B,+BAA+B,EAC/B,8BAA8B,EAC9B,gCAAgC,EAChC,8BAA8B,EAC9B,oBAAoB,EACpB,eAAe,EACf,2BAA2B,EAC3B,iCAAiC,EACjC,gCAAgC,EAChC,yBAAyB,EACzB,mBAAmB,EACnB,gBAAgB,EAChB,iBAAiB,GAClB,MAAM,SAAS,CAAC"}
@@ -0,0 +1,18 @@
1
+ export declare enum CodeEditorSlots {
2
+ root = "root",
3
+ header = "header",
4
+ headerBadges = "headerBadges",
5
+ languageChip = "languageChip",
6
+ languageChipIcon = "languageChipIcon",
7
+ readOnlyChip = "readOnlyChip",
8
+ body = "body",
9
+ lineNumbers = "lineNumbers",
10
+ lineNumber = "lineNumber",
11
+ editorScroller = "editorScroller",
12
+ editor = "editor",
13
+ textarea = "textarea",
14
+ pre = "pre",
15
+ placeholder = "placeholder",
16
+ skeleton = "skeleton"
17
+ }
18
+ //# sourceMappingURL=CodeEditorEnum.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CodeEditorEnum.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/slots/CodeEditorEnum.ts"],"names":[],"mappings":"AAAA,oBAAY,eAAe;IACzB,IAAI,SAAS;IACb,MAAM,WAAW;IACjB,YAAY,iBAAiB;IAC7B,YAAY,iBAAiB;IAC7B,gBAAgB,qBAAqB;IACrC,YAAY,iBAAiB;IAC7B,IAAI,SAAS;IACb,WAAW,gBAAgB;IAC3B,UAAU,eAAe;IACzB,cAAc,mBAAmB;IACjC,MAAM,WAAW;IACjB,QAAQ,aAAa;IACrB,GAAG,QAAQ;IACX,WAAW,gBAAgB;IAC3B,QAAQ,aAAa;CACtB"}
@@ -0,0 +1,4 @@
1
+ var a = /* @__PURE__ */ ((e) => (e.root = "root", e.header = "header", e.headerBadges = "headerBadges", e.languageChip = "languageChip", e.languageChipIcon = "languageChipIcon", e.readOnlyChip = "readOnlyChip", e.body = "body", e.lineNumbers = "lineNumbers", e.lineNumber = "lineNumber", e.editorScroller = "editorScroller", e.editor = "editor", e.textarea = "textarea", e.pre = "pre", e.placeholder = "placeholder", e.skeleton = "skeleton", e))(a || {});
2
+ export {
3
+ a as CodeEditorSlots
4
+ };
@@ -0,0 +1,84 @@
1
+ export declare const RootStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
2
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
3
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import('react').ClassAttributes<HTMLDivElement> | keyof import('react').HTMLAttributes<HTMLDivElement>>, {}>;
4
+ export declare const HeaderStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
5
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
6
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import('react').ClassAttributes<HTMLDivElement> | keyof import('react').HTMLAttributes<HTMLDivElement>>, {}>;
7
+ export declare const HeaderBadgesStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
8
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
9
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import('react').ClassAttributes<HTMLDivElement> | keyof import('react').HTMLAttributes<HTMLDivElement>>, {}>;
10
+ export declare const LanguageChipStyled: import('@emotion/styled').StyledComponent<Pick<import('../../..').ChipProps & import('react').RefAttributes<HTMLDivElement>, keyof import('react').RefAttributes<HTMLDivElement> | keyof import('../../..').ChipProps> & import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
11
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
12
+ }, {}, {}>;
13
+ export declare const LanguageChipIconStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
14
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
15
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, keyof import('react').ClassAttributes<HTMLSpanElement> | keyof import('react').HTMLAttributes<HTMLSpanElement>>, {}>;
16
+ export declare const ReadOnlyChipStyled: import('@emotion/styled').StyledComponent<Pick<import('../../..').ChipProps & import('react').RefAttributes<HTMLDivElement>, keyof import('react').RefAttributes<HTMLDivElement> | keyof import('../../..').ChipProps> & import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
17
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
18
+ }, {}, {}>;
19
+ export declare const BodyStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
20
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
21
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import('react').ClassAttributes<HTMLDivElement> | keyof import('react').HTMLAttributes<HTMLDivElement>>, {}>;
22
+ export declare const LineNumbersStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
23
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
24
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import('react').ClassAttributes<HTMLDivElement> | keyof import('react').HTMLAttributes<HTMLDivElement>>, {}>;
25
+ export declare const LineNumberStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
26
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
27
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, keyof import('react').ClassAttributes<HTMLSpanElement> | keyof import('react').HTMLAttributes<HTMLSpanElement>>, {}>;
28
+ export declare const EditorScrollerStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
29
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
30
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLDivElement>, HTMLDivElement>, keyof import('react').ClassAttributes<HTMLDivElement> | keyof import('react').HTMLAttributes<HTMLDivElement>>, {}>;
31
+ export declare const EditorStyled: import('@emotion/styled').StyledComponent<import('react').HTMLAttributes<HTMLDivElement> & {
32
+ highlight: (value: string) => string | React.ReactNode;
33
+ ignoreTabKey?: boolean | undefined;
34
+ insertSpaces?: boolean | undefined;
35
+ onValueChange: (value: string) => void;
36
+ padding?: (string | number | {
37
+ top?: string | number | undefined;
38
+ right?: string | number | undefined;
39
+ bottom?: string | number | undefined;
40
+ left?: string | number | undefined;
41
+ }) | undefined;
42
+ style?: React.CSSProperties | undefined;
43
+ tabSize?: number | undefined;
44
+ value: string;
45
+ autoFocus?: boolean | undefined;
46
+ disabled?: boolean | undefined;
47
+ form?: string | undefined;
48
+ maxLength?: number | undefined;
49
+ minLength?: number | undefined;
50
+ name?: string | undefined;
51
+ onBlur?: React.FocusEventHandler<HTMLTextAreaElement> | undefined;
52
+ onClick?: React.MouseEventHandler<HTMLTextAreaElement> | undefined;
53
+ onFocus?: React.FocusEventHandler<HTMLTextAreaElement> | undefined;
54
+ onKeyDown?: React.KeyboardEventHandler<HTMLTextAreaElement> | undefined;
55
+ onKeyUp?: React.KeyboardEventHandler<HTMLTextAreaElement> | undefined;
56
+ placeholder?: string | undefined;
57
+ readOnly?: boolean | undefined;
58
+ required?: boolean | undefined;
59
+ textareaClassName?: string | undefined;
60
+ textareaId?: string | undefined;
61
+ preClassName?: string | undefined;
62
+ } & import('react').RefAttributes<{
63
+ session: {
64
+ history: {
65
+ stack: ({
66
+ value: string;
67
+ selectionStart: number;
68
+ selectionEnd: number;
69
+ } & {
70
+ timestamp: number;
71
+ })[];
72
+ offset: number;
73
+ };
74
+ };
75
+ }> & import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
76
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
77
+ }, {}, {}>;
78
+ export declare const PlaceholderStyled: import('@emotion/styled').StyledComponent<import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
79
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
80
+ }, Pick<import('react').DetailedHTMLProps<import('react').HTMLAttributes<HTMLSpanElement>, HTMLSpanElement>, keyof import('react').ClassAttributes<HTMLSpanElement> | keyof import('react').HTMLAttributes<HTMLSpanElement>>, {}>;
81
+ export declare const SkeletonStyled: import('@emotion/styled').StyledComponent<Pick<import('../../mui/Skeleton/types').SkeletonProps, keyof import('../../mui/Skeleton/types').SkeletonProps> & import('@mui/system').MUIStyledCommonProps<import('@mui/material').Theme> & Record<string, unknown> & {
82
+ ownerState?: (Partial<import('..').CodeEditorOwnerState> & Record<string, unknown>) | undefined;
83
+ }, {}, {}>;
84
+ //# sourceMappingURL=CodeEditorSlots.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CodeEditorSlots.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/slots/CodeEditorSlots.ts"],"names":[],"mappings":"AAQA,eAAO,MAAM,UAAU;;6NAGG,CAAC;AAE3B,eAAO,MAAM,YAAY;;6NAGG,CAAC;AAE7B,eAAO,MAAM,kBAAkB;;6NAGG,CAAC;AAEnC,eAAO,MAAM,kBAAkB;;UAGG,CAAC;AAEnC,eAAO,MAAM,sBAAsB;;iOAGG,CAAC;AAEvC,eAAO,MAAM,kBAAkB;;UAGG,CAAC;AAEnC,eAAO,MAAM,UAAU;;6NAGG,CAAC;AAE3B,eAAO,MAAM,iBAAiB;;6NAGG,CAAC;AAElC,eAAO,MAAM,gBAAgB;;iOAGG,CAAC;AAEjC,eAAO,MAAM,oBAAoB;;6NAGG,CAAC;AAErC,eAAO,MAAM,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;UAIG,CAAC;AAE7B,eAAO,MAAM,iBAAiB;;iOAGG,CAAC;AAElC,eAAO,MAAM,cAAc;;UAGG,CAAC"}
@@ -0,0 +1,63 @@
1
+ import n from "react-simple-code-editor";
2
+ import { styled as e } from "@mui/material/styles";
3
+ import { Chip as r } from "../../../Chip/Chip.js";
4
+ import { codeEditorStyles as o } from "../CodeEditor.styles.js";
5
+ import { CODE_EDITOR_KEY_COMPONENT as t } from "../constants.js";
6
+ import { CodeEditorSlots as l } from "./CodeEditorEnum.js";
7
+ import { Skeleton as a } from "../../mui/Skeleton/Skeleton.js";
8
+ const h = e("div", {
9
+ name: t,
10
+ slot: l.root
11
+ })(o?.root), g = e("div", {
12
+ name: t,
13
+ slot: l.header
14
+ })(o?.header), C = e("div", {
15
+ name: t,
16
+ slot: l.headerBadges
17
+ })(o?.headerBadges), u = e(r, {
18
+ name: t,
19
+ slot: l.languageChip
20
+ })(o?.languageChip), E = e("span", {
21
+ name: t,
22
+ slot: l.languageChipIcon
23
+ })(o?.languageChipIcon), b = e(r, {
24
+ name: t,
25
+ slot: l.readOnlyChip
26
+ })(o?.readOnlyChip), N = e("div", {
27
+ name: t,
28
+ slot: l.body
29
+ })(o?.body), f = e("div", {
30
+ name: t,
31
+ slot: l.lineNumbers
32
+ })(o?.lineNumbers), O = e("span", {
33
+ name: t,
34
+ slot: l.lineNumber
35
+ })(o?.lineNumber), v = e("div", {
36
+ name: t,
37
+ slot: l.editorScroller
38
+ })(o?.editorScroller), k = e(n, {
39
+ name: t,
40
+ slot: l.editor,
41
+ shouldForwardProp: (d) => d !== "ownerState"
42
+ })(o?.editor), B = e("span", {
43
+ name: t,
44
+ slot: l.placeholder
45
+ })(o?.placeholder), I = e(a, {
46
+ name: t,
47
+ slot: l.skeleton
48
+ })(o?.skeleton);
49
+ export {
50
+ N as BodyStyled,
51
+ v as EditorScrollerStyled,
52
+ k as EditorStyled,
53
+ C as HeaderBadgesStyled,
54
+ g as HeaderStyled,
55
+ E as LanguageChipIconStyled,
56
+ u as LanguageChipStyled,
57
+ O as LineNumberStyled,
58
+ f as LineNumbersStyled,
59
+ B as PlaceholderStyled,
60
+ b as ReadOnlyChipStyled,
61
+ h as RootStyled,
62
+ I as SkeletonStyled
63
+ };
@@ -0,0 +1,3 @@
1
+ export * from './CodeEditorEnum';
2
+ export * from './CodeEditorSlots';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/slots/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { CodeEditorLanguageIcon, CodeEditorLanguageTemplateInput, CodeEditorRuntimeDependency } from './types';
2
+ type CodeEditorStoryRuntimeArgs = {
3
+ languageTemplate?: CodeEditorLanguageTemplateInput;
4
+ languageText?: string;
5
+ };
6
+ /**
7
+ * Build the runtime dependency list needed for Storybook CodeEditor examples.
8
+ */
9
+ export declare function resolveCodeEditorStoryRuntimeDependencies(args: CodeEditorStoryRuntimeArgs): CodeEditorRuntimeDependency[] | undefined;
10
+ /**
11
+ * Resolve the Storybook example icon for the current language so the base component stays instance-owned.
12
+ */
13
+ export declare function resolveCodeEditorStoryLanguageIcon(args: CodeEditorStoryRuntimeArgs): CodeEditorLanguageIcon | undefined;
14
+ export {};
15
+ //# sourceMappingURL=storybookRuntime.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"storybookRuntime.d.ts","sourceRoot":"","sources":["../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/storybookRuntime.ts"],"names":[],"mappings":"AAgBA,OAAO,KAAK,EACV,sBAAsB,EACtB,+BAA+B,EAC/B,2BAA2B,EAC5B,MAAM,SAAS,CAAC;AAEjB,KAAK,0BAA0B,GAAG;IAChC,gBAAgB,CAAC,EAAE,+BAA+B,CAAC;IACnD,YAAY,CAAC,EAAE,MAAM,CAAC;CACvB,CAAC;AAyIF;;GAEG;AACH,wBAAgB,yCAAyC,CACvD,IAAI,EAAE,0BAA0B,GAC/B,2BAA2B,EAAE,GAAG,SAAS,CAwC3C;AAED;;GAEG;AACH,wBAAgB,kCAAkC,CAChD,IAAI,EAAE,0BAA0B,GAC/B,sBAAsB,GAAG,SAAS,CA6BpC"}
@@ -0,0 +1,127 @@
1
+ import { ComponentProps, ElementType } from 'react';
2
+ import { default as Editor } from 'react-simple-code-editor';
3
+ import { Theme } from '@mui/material';
4
+ import { PrismTheme } from 'prism-react-renderer';
5
+ import { Sizes } from '@m4l/styles';
6
+ import { M4LOverridesStyleRules } from '../../../@types/augmentations';
7
+ import { CODE_EDITOR_KEY_COMPONENT } from './constants';
8
+ import { CodeEditorSlots } from './slots/CodeEditorEnum';
9
+ type BaseEditorProps = ComponentProps<typeof Editor>;
10
+ export type CodeEditorVariant = 'outlined' | 'contained';
11
+ export type CodeEditorLanguage = string;
12
+ export type CodeEditorLanguageIcon = ElementType;
13
+ export type CodeEditorCustomLanguages = Record<string, Prism.Grammar>;
14
+ export type CodeEditorLanguageTemplateName = string;
15
+ export type CodeEditorLanguageTemplateType = 'at-commands';
16
+ export type CodeEditorRuntimeDependency = () => void | Promise<unknown>;
17
+ export interface CodeEditorLanguageTemplateTokens {
18
+ argumentSeparators?: string[];
19
+ commandPrefixes?: string[];
20
+ concatenationSeparators?: string[];
21
+ reservedWords?: string[];
22
+ }
23
+ export interface CodeEditorLanguageTemplate {
24
+ languageIcon?: CodeEditorLanguageIcon;
25
+ languageLabel?: string;
26
+ languageText: CodeEditorLanguage;
27
+ templateName: CodeEditorLanguageTemplateName;
28
+ templateType: CodeEditorLanguageTemplateType;
29
+ tokens?: CodeEditorLanguageTemplateTokens;
30
+ }
31
+ export type CodeEditorLanguageTemplateInput = CodeEditorLanguageTemplateName | CodeEditorLanguageTemplate;
32
+ export interface CodeEditorSyntaxValidationContext {
33
+ code: string;
34
+ languageTemplate?: CodeEditorLanguageTemplateInput;
35
+ languageText?: CodeEditorLanguage;
36
+ }
37
+ export interface CodeEditorSyntaxErrorLocation {
38
+ column: number;
39
+ line: number;
40
+ offset?: number;
41
+ }
42
+ export interface CodeEditorSyntaxErrorRange {
43
+ end?: CodeEditorSyntaxErrorLocation;
44
+ start: CodeEditorSyntaxErrorLocation;
45
+ }
46
+ export interface CodeEditorSyntaxValidationResult {
47
+ errorRange?: CodeEditorSyntaxErrorRange;
48
+ isValid: boolean;
49
+ message?: string;
50
+ }
51
+ export type CodeEditorSyntaxValidator = (context: CodeEditorSyntaxValidationContext) => CodeEditorSyntaxValidationResult;
52
+ export interface CodeEditorLezerTreeCursor {
53
+ firstChild: () => boolean;
54
+ from: number;
55
+ nextSibling: () => boolean;
56
+ parent: () => boolean;
57
+ to: number;
58
+ type: {
59
+ isError: boolean;
60
+ };
61
+ }
62
+ export interface CodeEditorLezerParser {
63
+ parse: (code: string) => {
64
+ cursor: () => CodeEditorLezerTreeCursor;
65
+ };
66
+ }
67
+ export interface CodeEditorLezerSyntaxValidatorOptions {
68
+ label: string;
69
+ parser: CodeEditorLezerParser;
70
+ }
71
+ export interface CodeEditorProps extends Omit<BaseEditorProps, 'className' | 'defaultValue' | 'highlight' | 'onChange' | 'onValueChange' | 'placeholder' | 'preClassName' | 'textareaClassName' | 'textareaId' | 'value'> {
72
+ className?: string;
73
+ dataTestId?: string;
74
+ defaultValue?: string;
75
+ editorClassName?: string;
76
+ error?: boolean;
77
+ highlightTheme?: PrismTheme;
78
+ languageIcon?: CodeEditorLanguageIcon;
79
+ languageLabel?: string;
80
+ languageTemplate?: CodeEditorLanguageTemplateInput;
81
+ languageText?: CodeEditorLanguage;
82
+ maxLines?: number;
83
+ minLines?: number;
84
+ onChange?: (nextValue: string) => void;
85
+ placeholder?: string;
86
+ preClassName?: string;
87
+ readOnly?: boolean;
88
+ readOnlyLabel?: string;
89
+ showLineNumbers?: boolean;
90
+ showPlaceholder?: boolean;
91
+ size?: Extract<Sizes, 'small' | 'medium'>;
92
+ syntaxValidator?: CodeEditorSyntaxValidator;
93
+ runtimeDependencies?: CodeEditorRuntimeDependency | CodeEditorRuntimeDependency[];
94
+ skeleton?: boolean;
95
+ textareaClassName?: string;
96
+ validateSyntax?: boolean;
97
+ value?: string;
98
+ customLanguages?: CodeEditorCustomLanguages;
99
+ variant?: CodeEditorVariant;
100
+ }
101
+ export interface CodeEditorOwnerState extends Record<string, unknown> {
102
+ disabled: boolean;
103
+ error: boolean;
104
+ isLineCapped: boolean;
105
+ isEmpty: boolean;
106
+ isPlaceholderVisible: boolean;
107
+ lineHeight: number;
108
+ maxLines: number;
109
+ minLines: number;
110
+ readOnly: boolean;
111
+ showLineNumbers: boolean;
112
+ size: Extract<Sizes, 'small' | 'medium'>;
113
+ variant: CodeEditorVariant;
114
+ visibleLineCount: number;
115
+ }
116
+ export type CodeEditorSlotsType = keyof typeof CodeEditorSlots;
117
+ export type CodeEditorStyles = M4LOverridesStyleRules<CodeEditorSlotsType, typeof CODE_EDITOR_KEY_COMPONENT, Theme>;
118
+ export interface HighlightCodeOptions {
119
+ code: string;
120
+ customLanguages?: CodeEditorCustomLanguages;
121
+ languageTemplate?: CodeEditorLanguageTemplateInput;
122
+ languageText?: CodeEditorLanguage;
123
+ prismTheme: PrismTheme;
124
+ syntaxErrorRange?: CodeEditorSyntaxErrorRange;
125
+ }
126
+ export {};
127
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../../../../packages/components/src/components/extended/ReactSimpleCodeEditor/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,WAAW,EAAE,MAAM,OAAO,CAAC;AACzD,OAAO,KAAK,MAAM,MAAM,0BAA0B,CAAC;AACnD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAC;AACvD,OAAO,KAAK,EAAE,KAAK,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAC;AAC5E,OAAO,EAAE,yBAAyB,EAAE,MAAM,aAAa,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAEzD,KAAK,eAAe,GAAG,cAAc,CAAC,OAAO,MAAM,CAAC,CAAC;AAErD,MAAM,MAAM,iBAAiB,GAAG,UAAU,GAAG,WAAW,CAAC;AAEzD,MAAM,MAAM,kBAAkB,GAAG,MAAM,CAAC;AAExC,MAAM,MAAM,sBAAsB,GAAG,WAAW,CAAC;AAEjD,MAAM,MAAM,yBAAyB,GAAG,MAAM,CAAC,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC;AAEtE,MAAM,MAAM,8BAA8B,GAAG,MAAM,CAAC;AAEpD,MAAM,MAAM,8BAA8B,GAAG,aAAa,CAAC;AAE3D,MAAM,MAAM,2BAA2B,GAAG,MAAM,IAAI,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;AAExE,MAAM,WAAW,gCAAgC;IAC/C,kBAAkB,CAAC,EAAE,MAAM,EAAE,CAAC;IAC9B,eAAe,CAAC,EAAE,MAAM,EAAE,CAAC;IAC3B,uBAAuB,CAAC,EAAE,MAAM,EAAE,CAAC;IACnC,aAAa,CAAC,EAAE,MAAM,EAAE,CAAC;CAC1B;AAED,MAAM,WAAW,0BAA0B;IACzC,YAAY,CAAC,EAAE,sBAAsB,CAAC;IACtC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,kBAAkB,CAAC;IACjC,YAAY,EAAE,8BAA8B,CAAC;IAC7C,YAAY,EAAE,8BAA8B,CAAC;IAC7C,MAAM,CAAC,EAAE,gCAAgC,CAAC;CAC3C;AAED,MAAM,MAAM,+BAA+B,GACvC,8BAA8B,GAC9B,0BAA0B,CAAC;AAE/B,MAAM,WAAW,iCAAiC;IAChD,IAAI,EAAE,MAAM,CAAC;IACb,gBAAgB,CAAC,EAAE,+BAA+B,CAAC;IACnD,YAAY,CAAC,EAAE,kBAAkB,CAAC;CACnC;AAED,MAAM,WAAW,6BAA6B;IAC5C,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,EAAE,MAAM,CAAC;IACb,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,MAAM,WAAW,0BAA0B;IACzC,GAAG,CAAC,EAAE,6BAA6B,CAAC;IACpC,KAAK,EAAE,6BAA6B,CAAC;CACtC;AAED,MAAM,WAAW,gCAAgC;IAC/C,UAAU,CAAC,EAAE,0BAA0B,CAAC;IACxC,OAAO,EAAE,OAAO,CAAC;IACjB,OAAO,CAAC,EAAE,MAAM,CAAC;CAClB;AAED,MAAM,MAAM,yBAAyB,GAAG,CACtC,OAAO,EAAE,iCAAiC,KACvC,gCAAgC,CAAC;AAEtC,MAAM,WAAW,yBAAyB;IACxC,UAAU,EAAE,MAAM,OAAO,CAAC;IAC1B,IAAI,EAAE,MAAM,CAAC;IACb,WAAW,EAAE,MAAM,OAAO,CAAC;IAC3B,MAAM,EAAE,MAAM,OAAO,CAAC;IACtB,EAAE,EAAE,MAAM,CAAC;IACX,IAAI,EAAE;QACJ,OAAO,EAAE,OAAO,CAAC;KAClB,CAAC;CACH;AAED,MAAM,WAAW,qBAAqB;IACpC,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK;QACvB,MAAM,EAAE,MAAM,yBAAyB,CAAC;KACzC,CAAC;CACH;AAED,MAAM,WAAW,qCAAqC;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,MAAM,EAAE,qBAAqB,CAAC;CAC/B;AAED,MAAM,WAAW,eACf,SAAQ,IAAI,CACV,eAAe,EACb,WAAW,GACX,cAAc,GACd,WAAW,GACX,UAAU,GACV,eAAe,GACf,aAAa,GACb,cAAc,GACd,mBAAmB,GACnB,YAAY,GACZ,OAAO,CACV;IACD,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,KAAK,CAAC,EAAE,OAAO,CAAC;IAChB,cAAc,CAAC,EAAE,UAAU,CAAC;IAC5B,YAAY,CAAC,EAAE,sBAAsB,CAAC;IACtC,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,gBAAgB,CAAC,EAAE,+BAA+B,CAAC;IACnD,YAAY,CAAC,EAAE,kBAAkB,CAAC;IAClC,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,QAAQ,CAAC,EAAE,CAAC,SAAS,EAAE,MAAM,KAAK,IAAI,CAAC;IACvC,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,IAAI,CAAC,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,QAAQ,CAAC,CAAC;IAC1C,eAAe,CAAC,EAAE,yBAAyB,CAAC;IAC5C,mBAAmB,CAAC,EAAE,2BAA2B,GAAG,2BAA2B,EAAE,CAAC;IAClF,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAC3B,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,yBAAyB,CAAC;IAC5C,OAAO,CAAC,EAAE,iBAAiB,CAAC;CAC7B;AAED,MAAM,WAAW,oBAAqB,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IACnE,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,OAAO,CAAC;IACf,YAAY,EAAE,OAAO,CAAC;IACtB,OAAO,EAAE,OAAO,CAAC;IACjB,oBAAoB,EAAE,OAAO,CAAC;IAC9B,UAAU,EAAE,MAAM,CAAC;IACnB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,MAAM,CAAC;IACjB,QAAQ,EAAE,OAAO,CAAC;IAClB,eAAe,EAAE,OAAO,CAAC;IACzB,IAAI,EAAE,OAAO,CAAC,KAAK,EAAE,OAAO,GAAG,QAAQ,CAAC,CAAC;IACzC,OAAO,EAAE,iBAAiB,CAAC;IAC3B,gBAAgB,EAAE,MAAM,CAAC;CAC1B;AAED,MAAM,MAAM,mBAAmB,GAAG,MAAM,OAAO,eAAe,CAAC;AAE/D,MAAM,MAAM,gBAAgB,GAAG,sBAAsB,CACnD,mBAAmB,EACnB,OAAO,yBAAyB,EAChC,KAAK,CACN,CAAC;AAEF,MAAM,WAAW,oBAAoB;IACnC,IAAI,EAAE,MAAM,CAAC;IACb,eAAe,CAAC,EAAE,yBAAyB,CAAC;IAC5C,gBAAgB,CAAC,EAAE,+BAA+B,CAAC;IACnD,YAAY,CAAC,EAAE,kBAAkB,CAAC;IAClC,UAAU,EAAE,UAAU,CAAC;IACvB,gBAAgB,CAAC,EAAE,0BAA0B,CAAC;CAC/C"}
@@ -3,5 +3,6 @@ export * from './React-resizable-panels';
3
3
  export * from './React-Spinners';
4
4
  export * from './React-Window';
5
5
  export * from './React-Json-Viewer';
6
+ export * from './ReactSimpleCodeEditor';
6
7
  export * from './mui';
7
8
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../packages/components/src/components/extended/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,OAAO,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../packages/components/src/components/extended/index.ts"],"names":[],"mappings":"AAAA,cAAc,mBAAmB,CAAC;AAClC,cAAc,0BAA0B,CAAC;AACzC,cAAc,kBAAkB,CAAC;AACjC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,qBAAqB,CAAC;AACpC,cAAc,yBAAyB,CAAC;AACxC,cAAc,OAAO,CAAC"}
@@ -0,0 +1,7 @@
1
+ import { ComponentProps } from 'react';
2
+ /**
3
+ * Connect CodeEditor to react-hook-form through the shared controller wrapper.
4
+ */
5
+ export declare const RHFCodeEditor: import('react').ForwardRefExoticComponent<Omit<import('../..').CodeEditorProps & import('../../../hocs').BaseRHFProps<import('react-hook-form').FieldValues>, "ref"> & import('react').RefAttributes<any>>;
6
+ export type RHFCodeEditorProps = ComponentProps<typeof RHFCodeEditor>;
7
+ //# sourceMappingURL=RHFCodeEditor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RHFCodeEditor.d.ts","sourceRoot":"","sources":["../../../../../../../packages/components/src/components/hook-form/RHFCodeEditor/RHFCodeEditor.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAI5C;;GAEG;AACH,eAAO,MAAM,aAAa,4MAAgC,CAAC;AAE3D,MAAM,MAAM,kBAAkB,GAAG,cAAc,CAAC,OAAO,aAAa,CAAC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { withRHFController as o } from "../../../hocs/withRHFController/index.js";
2
+ import { CodeEditor as r } from "../../extended/ReactSimpleCodeEditor/CodeEditor.js";
3
+ const d = o(r);
4
+ export {
5
+ d as RHFCodeEditor
6
+ };
@@ -0,0 +1,3 @@
1
+ export { RHFCodeEditor } from './RHFCodeEditor';
2
+ export type { RHFCodeEditorProps } from './RHFCodeEditor';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../packages/components/src/components/hook-form/RHFCodeEditor/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC"}
@@ -1,5 +1,6 @@
1
1
  export { RHFAutocomplete } from './RHFAutocomplete/RHFAutocomplete';
2
2
  export * from './RHFColorPicker';
3
+ export * from './RHFCodeEditor';
3
4
  export { getRHFAutocompleteComponentsDictionary } from './RHFAutocomplete/dictionary';
4
5
  export { RHFAutocompleteAsync } from './RHFAutocompleteAsync/RHFAutocompleteAsync';
5
6
  export * from './RHFImageSelector';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../packages/components/src/components/hook-form/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,cAAc,kBAAkB,CAAC;AACjC,OAAO,EAAE,sCAAsC,EAAE,MAAM,8BAA8B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AACnF,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,2CAA2C,EAAE,MAAM,mCAAmC,CAAC;AAChG,cAAc,2BAA2B,CAAC;AAC1C,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,cAAc,0BAA0B,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,YAAY,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,cAAc,gBAAgB,CAAC;AAC/B,cAAc,wBAAwB,CAAC;AACvC,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,cAAc,kBAAkB,CAAC;AACjC,OAAO,EAAE,mBAAmB,EAAE,MAAM,qDAAqD,CAAC;AAC1F,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../packages/components/src/components/hook-form/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,mCAAmC,CAAC;AACpE,cAAc,kBAAkB,CAAC;AACjC,cAAc,iBAAiB,CAAC;AAChC,OAAO,EAAE,sCAAsC,EAAE,MAAM,8BAA8B,CAAC;AACtF,OAAO,EAAE,oBAAoB,EAAE,MAAM,6CAA6C,CAAC;AACnF,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,2CAA2C,EAAE,MAAM,mCAAmC,CAAC;AAChG,cAAc,2BAA2B,CAAC;AAC1C,cAAc,oBAAoB,CAAC;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,cAAc,0BAA0B,CAAC;AACzC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,cAAc,iBAAiB,CAAC;AAChC,cAAc,uBAAuB,CAAC;AACtC,cAAc,wBAAwB,CAAC;AACvC,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,YAAY,EAAE,cAAc,EAAE,MAAM,aAAa,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AAClD,cAAc,gBAAgB,CAAC;AAC/B,cAAc,wBAAwB,CAAC;AACvC,cAAc,aAAa,CAAC;AAC5B,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,cAAc,kBAAkB,CAAC;AACjC,OAAO,EAAE,mBAAmB,EAAE,MAAM,qDAAqD,CAAC;AAC1F,cAAc,aAAa,CAAC;AAC5B,cAAc,kBAAkB,CAAC;AACjC,cAAc,mBAAmB,CAAC;AAClC,cAAc,aAAa,CAAC"}