@eccenca/gui-elements 25.1.0-rc.1 → 25.1.0-rc.2

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 (74) hide show
  1. package/CHANGELOG.md +13 -1
  2. package/dist/cjs/cmem/react-flow/StickyNoteModal/StickyNoteModal.js +1 -1
  3. package/dist/cjs/cmem/react-flow/StickyNoteModal/StickyNoteModal.js.map +1 -1
  4. package/dist/cjs/common/index.js +1 -0
  5. package/dist/cjs/common/index.js.map +1 -1
  6. package/dist/cjs/common/utils/CssCustomProperties.js.map +1 -1
  7. package/dist/cjs/common/utils/colorHash.js +26 -12
  8. package/dist/cjs/common/utils/colorHash.js.map +1 -1
  9. package/dist/cjs/components/ColorField/ColorField.js +114 -0
  10. package/dist/cjs/components/ColorField/ColorField.js.map +1 -0
  11. package/dist/cjs/components/RadioButton/RadioButton.js +5 -2
  12. package/dist/cjs/components/RadioButton/RadioButton.js.map +1 -1
  13. package/dist/cjs/components/TextField/useTextValidation.js +17 -8
  14. package/dist/cjs/components/TextField/useTextValidation.js.map +1 -1
  15. package/dist/cjs/components/index.js +1 -0
  16. package/dist/cjs/components/index.js.map +1 -1
  17. package/dist/cjs/extensions/codemirror/CodeMirror.js +40 -14
  18. package/dist/cjs/extensions/codemirror/CodeMirror.js.map +1 -1
  19. package/dist/cjs/extensions/codemirror/toolbars/EditorAppearanceConfigMenu.js +23 -0
  20. package/dist/cjs/extensions/codemirror/toolbars/EditorAppearanceConfigMenu.js.map +1 -0
  21. package/dist/cjs/extensions/codemirror/toolbars/markdown.toolbar.js +5 -2
  22. package/dist/cjs/extensions/codemirror/toolbars/markdown.toolbar.js.map +1 -1
  23. package/dist/esm/cmem/react-flow/StickyNoteModal/StickyNoteModal.js +1 -1
  24. package/dist/esm/cmem/react-flow/StickyNoteModal/StickyNoteModal.js.map +1 -1
  25. package/dist/esm/common/index.js +2 -1
  26. package/dist/esm/common/index.js.map +1 -1
  27. package/dist/esm/common/utils/CssCustomProperties.js.map +1 -1
  28. package/dist/esm/common/utils/colorHash.js +26 -13
  29. package/dist/esm/common/utils/colorHash.js.map +1 -1
  30. package/dist/esm/components/ColorField/ColorField.js +140 -0
  31. package/dist/esm/components/ColorField/ColorField.js.map +1 -0
  32. package/dist/esm/components/RadioButton/RadioButton.js +6 -2
  33. package/dist/esm/components/RadioButton/RadioButton.js.map +1 -1
  34. package/dist/esm/components/TextField/useTextValidation.js +39 -8
  35. package/dist/esm/components/TextField/useTextValidation.js.map +1 -1
  36. package/dist/esm/components/index.js +1 -0
  37. package/dist/esm/components/index.js.map +1 -1
  38. package/dist/esm/extensions/codemirror/CodeMirror.js +42 -16
  39. package/dist/esm/extensions/codemirror/CodeMirror.js.map +1 -1
  40. package/dist/esm/extensions/codemirror/toolbars/EditorAppearanceConfigMenu.js +47 -0
  41. package/dist/esm/extensions/codemirror/toolbars/EditorAppearanceConfigMenu.js.map +1 -0
  42. package/dist/esm/extensions/codemirror/toolbars/markdown.toolbar.js +16 -2
  43. package/dist/esm/extensions/codemirror/toolbars/markdown.toolbar.js.map +1 -1
  44. package/dist/types/common/index.d.ts +2 -1
  45. package/dist/types/common/utils/CssCustomProperties.d.ts +2 -2
  46. package/dist/types/common/utils/colorHash.d.ts +5 -4
  47. package/dist/types/components/ColorField/ColorField.d.ts +30 -0
  48. package/dist/types/components/RadioButton/RadioButton.d.ts +8 -2
  49. package/dist/types/components/index.d.ts +1 -0
  50. package/dist/types/extensions/codemirror/CodeMirror.d.ts +12 -9
  51. package/dist/types/extensions/codemirror/toolbars/EditorAppearanceConfigMenu.d.ts +24 -0
  52. package/dist/types/extensions/codemirror/toolbars/markdown.toolbar.d.ts +2 -0
  53. package/package.json +1 -1
  54. package/src/cmem/react-flow/StickyNoteModal/StickyNoteModal.tsx +1 -1
  55. package/src/common/index.ts +2 -1
  56. package/src/common/utils/CssCustomProperties.ts +5 -3
  57. package/src/common/utils/colorHash.ts +38 -20
  58. package/src/components/ColorField/ColorField.stories.tsx +72 -0
  59. package/src/components/ColorField/ColorField.test.tsx +101 -0
  60. package/src/components/ColorField/ColorField.tsx +200 -0
  61. package/src/components/ColorField/_colorfield.scss +67 -0
  62. package/src/components/RadioButton/RadioButton.tsx +15 -3
  63. package/src/components/RadioButton/radiobutton.scss +13 -0
  64. package/src/components/TextField/stories/TextField.stories.tsx +23 -0
  65. package/src/components/TextField/tests/useTextValidation.test.tsx +83 -0
  66. package/src/components/TextField/useTextValidation.ts +17 -8
  67. package/src/components/index.scss +1 -0
  68. package/src/components/index.ts +1 -0
  69. package/src/extensions/codemirror/CodeMirror.stories.tsx +9 -4
  70. package/src/extensions/codemirror/CodeMirror.tsx +71 -26
  71. package/src/extensions/codemirror/tests/CodeEditor.test.tsx +138 -0
  72. package/src/extensions/codemirror/tests/EditorAppearanceConfigMenu.test.tsx +131 -0
  73. package/src/extensions/codemirror/toolbars/EditorAppearanceConfigMenu.tsx +59 -0
  74. package/src/extensions/codemirror/toolbars/markdown.toolbar.tsx +17 -3
package/CHANGELOG.md CHANGED
@@ -15,12 +15,19 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/) and this p
15
15
  - component for hiding elements in specific media
16
16
  - `<InlineText />`
17
17
  - force children to get displayed as inline content
18
- - `<DecoupledOverlay />`
18
+ - `<DecoupledOverlay />`
19
19
  - similar to `ContextOverlay` component but not directly linked to a React element, it specifies the target in the DOM to get connected lazy
20
20
  - `<StringPreviewContentBlobToggler />`
21
21
  - `useOnly` property: specify if only parts of the content should be used for the shortened preview, this property replaces `firstNonEmptyLineOnly`
22
22
  - `<ContextOverlay />`
23
23
  - `paddingSize` property to add easily some white space
24
+ - `<CodeEditor />`
25
+ - toolbar in `markdown` mode provides a user config menu for the editor appearance
26
+ - `<RadioButton />`
27
+ - `hideIndicator` property: hide the radio inout indicator but click on children can be processed via `onChange` event
28
+ - `<ColorField />`
29
+ - input component for colors
30
+ - uses a subset from the configured color palette by default, but it also allows to enter custom colors
24
31
  - CSS custom properties
25
32
  - beside the color palette we now mirror the most important layout configuration variables as CSS custom properties
26
33
  - new icons:
@@ -48,6 +55,8 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/) and this p
48
55
  - adjust displaying fallback symbols in different browsers
49
56
  - `<CodeMirror />`
50
57
  - use the latest provided `onChange` function
58
+ - `<TextField />`, `<TextArea />`
59
+ - fix emoji false-positives in invisible character detection
51
60
 
52
61
  ### Changed
53
62
 
@@ -55,6 +64,9 @@ The format is based on [Keep a Changelog](http://keepachangelog.com/) and this p
55
64
  - Change default filter predicate to match multi-word queries.
56
65
  - `<EdgeDefault />`
57
66
  - reduce stroke width to only 1px
67
+ - `<CodeMirror />`
68
+ - `wrapLines` and `preventLineNumber` do not use `false` default value but if not set then it will be interpreted as `false`
69
+ - in this way it can be overwritten by new user config for the markdown mode
58
70
  - automatically hide user interaction elements in print view
59
71
  - all application header components except `<WorkspaceHeader />`
60
72
  - `<CardActions />` and `<CardOptions />`
@@ -47,7 +47,7 @@ exports.StickyNoteModal = react_1.default.memo(({ metaData, onClose, onSubmit, t
47
47
  htmlFor: "noteinput",
48
48
  text: translate("noteLabel"),
49
49
  } },
50
- react_1.default.createElement(extensions_1.CodeEditor, Object.assign({ name: translate("noteLabel"), id: "sticky-note-input", mode: "markdown", preventLineNumbers: true, onChange: (value) => {
50
+ react_1.default.createElement(extensions_1.CodeEditor, Object.assign({ name: translate("noteLabel"), id: "sticky-note-input", mode: "markdown", useToolbar: true, onChange: (value) => {
51
51
  refNote.current = value;
52
52
  }, defaultValue: refNote.current }, codeEditorProps))),
53
53
  react_1.default.createElement(index_1.FieldItem, { key: "color", labelProps: {
@@ -1 +1 @@
1
- {"version":3,"file":"StickyNoteModal.js","sourceRoot":"","sources":["../../../../../src/cmem/react-flow/StickyNoteModal/StickyNoteModal.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"StickyNoteModal.js","sourceRoot":"","sources":["../../../../../src/cmem/react-flow/StickyNoteModal/StickyNoteModal.tsx"],"names":[],"mappings":"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"}
@@ -24,6 +24,7 @@ exports.utils = {
24
24
  setGlobalVar: globalVars_1.setGlobalVar,
25
25
  getScrollParent: getScrollParent_1.getScrollParent,
26
26
  getEnabledColorsFromPalette: colorHash_1.getEnabledColorsFromPalette,
27
+ getEnabledColorPropertiesFromPalette: colorHash_1.getEnabledColorPropertiesFromPalette,
27
28
  textToColorHash: colorHash_1.textToColorHash,
28
29
  reduceToText: reduceToText_1.reduceToText,
29
30
  decodeHtmlEntities: he_1.decode,
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/index.ts"],"names":[],"mappings":";;;;;;AAAA,2BAA4B;AAE5B,mDAAkE;AAClE,2EAAwE;AACxE,gGAAwE;AACxE,iDAAiF;AACjF,0FAAkE;AAClE,6DAA0D;AAC1D,mDAAgE;AAChE,uDAAoD;AACpD,uDAAoD;AAIvC,QAAA,KAAK,GAAG;IACjB,YAAY,EAAZ,2BAAY;IACZ,wBAAwB,EAAxB,kCAAwB;IACxB,sBAAsB,EAAtB,+CAAsB;IACtB,qBAAqB,EAArB,+BAAqB;IACrB,4BAA4B,EAA5B,yCAA4B;IAC5B,YAAY,EAAZ,yBAAY;IACZ,YAAY,EAAZ,yBAAY;IACZ,eAAe,EAAf,iCAAe;IACf,2BAA2B,EAA3B,uCAA2B;IAC3B,eAAe,EAAf,2BAAe;IACf,YAAY,EAAZ,2BAAY;IACZ,kBAAkB,EAAE,WAAM;CAC7B,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/common/index.ts"],"names":[],"mappings":";;;;;;AAAA,2BAA4B;AAE5B,mDAAkE;AAClE,2EAAwE;AACxE,gGAAwE;AACxE,iDAAuH;AACvH,0FAAkE;AAClE,6DAA0D;AAC1D,mDAAgE;AAChE,uDAAoD;AACpD,uDAAoD;AAIvC,QAAA,KAAK,GAAG;IACjB,YAAY,EAAZ,2BAAY;IACZ,wBAAwB,EAAxB,kCAAwB;IACxB,sBAAsB,EAAtB,+CAAsB;IACtB,qBAAqB,EAArB,+BAAqB;IACrB,4BAA4B,EAA5B,yCAA4B;IAC5B,YAAY,EAAZ,yBAAY;IACZ,YAAY,EAAZ,yBAAY;IACZ,eAAe,EAAf,iCAAe;IACf,2BAA2B,EAA3B,uCAA2B;IAC3B,oCAAoC,EAApC,gDAAoC;IACpC,eAAe,EAAf,2BAAe;IACf,YAAY,EAAZ,2BAAY;IACZ,kBAAkB,EAAE,WAAM;CAC7B,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"CssCustomProperties.js","sourceRoot":"","sources":["../../../../src/common/utils/CssCustomProperties.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"CssCustomProperties.js","sourceRoot":"","sources":["../../../../src/common/utils/CssCustomProperties.ts"],"names":[],"mappings":"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"}
@@ -4,21 +4,37 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.getEnabledColorsFromPalette = getEnabledColorsFromPalette;
7
+ exports.getEnabledColorPropertiesFromPalette = getEnabledColorPropertiesFromPalette;
7
8
  exports.textToColorHash = textToColorHash;
8
9
  const color_1 = __importDefault(require("color"));
9
10
  const constants_1 = require("../../configuration/constants");
10
11
  const colorCalculateDistance_1 = require("./colorCalculateDistance");
11
12
  const CssCustomProperties_1 = __importDefault(require("./CssCustomProperties"));
12
13
  const getEnabledColorsFromPaletteCache = new Map();
13
- function getEnabledColorsFromPalette({ includePaletteGroup = ["layout"], includeColorWeight = [100, 300, 500, 700, 900],
14
- // TODO (planned for later): includeMixedColors = false,
14
+ const getEnabledColorPropertiesFromPaletteCache = new Map();
15
+ function getEnabledColorsFromPalette(props) {
16
+ const configId = JSON.stringify({
17
+ includePaletteGroup: props.includePaletteGroup,
18
+ includeColorWeight: props.includeColorWeight,
19
+ });
20
+ if (getEnabledColorsFromPaletteCache.has(configId)) {
21
+ return getEnabledColorsFromPaletteCache.get(configId);
22
+ }
23
+ const colorPropertiesFromPalette = Object.values(getEnabledColorPropertiesFromPalette(props));
24
+ getEnabledColorsFromPaletteCache.set(configId, colorPropertiesFromPalette.map((color) => {
25
+ return (0, color_1.default)(color[1]);
26
+ }));
27
+ return getEnabledColorsFromPaletteCache.get(configId);
28
+ }
29
+ function getEnabledColorPropertiesFromPalette({ includePaletteGroup = ["layout"], includeColorWeight = [100, 300, 500, 700, 900],
30
+ // (planned for later): includeMixedColors = false,
15
31
  minimalColorDistance = constants_1.COLORMINDISTANCE, }) {
16
32
  const configId = JSON.stringify({
17
33
  includePaletteGroup,
18
34
  includeColorWeight,
19
35
  });
20
- if (getEnabledColorsFromPaletteCache.has(configId)) {
21
- return getEnabledColorsFromPaletteCache.get(configId);
36
+ if (getEnabledColorPropertiesFromPaletteCache.has(configId)) {
37
+ return getEnabledColorPropertiesFromPaletteCache.get(configId);
22
38
  }
23
39
  const colorsFromPalette = new CssCustomProperties_1.default({
24
40
  selectorText: `:root`,
@@ -33,15 +49,15 @@ minimalColorDistance = constants_1.COLORMINDISTANCE, }) {
33
49
  const weight = parseInt(tint[2], 10);
34
50
  return includePaletteGroup.includes(group) && includeColorWeight.includes(weight);
35
51
  },
36
- removeDashPrefix: false,
52
+ removeDashPrefix: true,
37
53
  returnObject: true,
38
54
  }).customProperties();
39
- const colorsFromPaletteValues = Object.values(colorsFromPalette);
55
+ const colorsFromPaletteValues = Object.entries(colorsFromPalette);
40
56
  const colorsFromPaletteWithEnoughDistance = minimalColorDistance > 0
41
57
  ? colorsFromPaletteValues.reduce((enoughDistance, color) => {
42
58
  if (enoughDistance.includes(color)) {
43
59
  return enoughDistance.filter((checkColor) => {
44
- const distance = (0, colorCalculateDistance_1.colorCalculateDistance)({ color1: color, color2: checkColor });
60
+ const distance = (0, colorCalculateDistance_1.colorCalculateDistance)({ color1: color[1], color2: checkColor[1] });
45
61
  return checkColor === color || (distance && minimalColorDistance <= distance);
46
62
  });
47
63
  }
@@ -50,10 +66,8 @@ minimalColorDistance = constants_1.COLORMINDISTANCE, }) {
50
66
  }
51
67
  }, colorsFromPaletteValues)
52
68
  : colorsFromPaletteValues;
53
- getEnabledColorsFromPaletteCache.set(configId, colorsFromPaletteWithEnoughDistance.map((color) => {
54
- return (0, color_1.default)(color);
55
- }));
56
- return getEnabledColorsFromPaletteCache.get(configId);
69
+ getEnabledColorPropertiesFromPaletteCache.set(configId, colorsFromPaletteWithEnoughDistance);
70
+ return getEnabledColorPropertiesFromPaletteCache.get(configId);
57
71
  }
58
72
  function getColorcode(text) {
59
73
  try {
@@ -101,7 +115,7 @@ function textToColorHash({ text, options = {
101
115
  .toString();
102
116
  }
103
117
  function stringToIntegerHash(inputString) {
104
- /* this function is idempotend, meaning it retrieves the same result for the same input
118
+ /* this function is idempotent, meaning it retrieves the same result for the same input
105
119
  no matter how many times it's called */
106
120
  // Convert the string to a hash code
107
121
  let hashCode = 0;
@@ -1 +1 @@
1
- {"version":3,"file":"colorHash.js","sourceRoot":"","sources":["../../../../src/common/utils/colorHash.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"colorHash.js","sourceRoot":"","sources":["../../../../src/common/utils/colorHash.ts"],"names":[],"mappings":";;;;;AAyBA,kEAoBC;AAED,oFAmDC;AA2BD,0CAwCC;AArKD,kDAA0B;AAE1B,6DAAwF;AAExF,qEAAkE;AAClE,gFAAwD;AAiBxD,MAAM,gCAAgC,GAAG,IAAI,GAAG,EAAmB,CAAC;AACpE,MAAM,yCAAyC,GAAG,IAAI,GAAG,EAA8B,CAAC;AAExF,SAAgB,2BAA2B,CAAC,KAA4B;IACpE,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;QAC5B,mBAAmB,EAAE,KAAK,CAAC,mBAAmB;QAC9C,kBAAkB,EAAE,KAAK,CAAC,kBAAkB;KAC/C,CAAC,CAAC;IAEH,IAAI,gCAAgC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;QACjD,OAAO,gCAAgC,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;IAC3D,CAAC;IAED,MAAM,0BAA0B,GAAG,MAAM,CAAC,MAAM,CAAC,oCAAoC,CAAC,KAAK,CAAC,CAAC,CAAC;IAE9F,gCAAgC,CAAC,GAAG,CAChC,QAAQ,EACR,0BAA0B,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE;QACrC,OAAO,IAAA,eAAK,EAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;IAC3B,CAAC,CAAC,CACL,CAAC;IAEF,OAAO,gCAAgC,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;AAC3D,CAAC;AAED,SAAgB,oCAAoC,CAAC,EACjD,mBAAmB,GAAG,CAAC,QAAQ,CAAC,EAChC,kBAAkB,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,EAAE,GAAG,CAAC;AAC9C,mDAAmD;AACnD,oBAAoB,GAAG,4BAAgB,GACnB;IACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,SAAS,CAAC;QAC5B,mBAAmB;QACnB,kBAAkB;KACrB,CAAC,CAAC;IAEH,IAAI,yCAAyC,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;QAC1D,OAAO,yCAAyC,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;IACpE,CAAC;IAED,MAAM,iBAAiB,GAAG,IAAI,6BAAmB,CAAC;QAC9C,YAAY,EAAE,OAAO;QACrB,UAAU,EAAE,CAAC,IAAY,EAAE,EAAE;YACzB,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,uBAAM,iBAAiB,CAAC,EAAE,CAAC;gBAC/C,uDAAuD;gBACvD,OAAO,KAAK,CAAC;YACjB,CAAC;YACD,yDAAyD;YACzD,MAAM,IAAI,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,uBAAM,iBAAiB,CAAC,MAAM,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAC5E,MAAM,KAAK,GAAG,IAAI,CAAC,CAAC,CAAiB,CAAC;YACtC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAgB,CAAC;YACpD,OAAO,mBAAmB,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,kBAAkB,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QACtF,CAAC;QACD,gBAAgB,EAAE,IAAI;QACtB,YAAY,EAAE,IAAI;KACrB,CAAC,CAAC,gBAAgB,EAAE,CAAC;IAEtB,MAAM,uBAAuB,GAAG,MAAM,CAAC,OAAO,CAAC,iBAAiB,CAAuB,CAAC;IAExF,MAAM,mCAAmC,GACrC,oBAAoB,GAAG,CAAC;QACpB,CAAC,CAAC,uBAAuB,CAAC,MAAM,CAAC,CAAC,cAAkC,EAAE,KAAuB,EAAE,EAAE;YAC3F,IAAI,cAAc,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CAAC;gBACjC,OAAO,cAAc,CAAC,MAAM,CAAC,CAAC,UAAU,EAAE,EAAE;oBACxC,MAAM,QAAQ,GAAG,IAAA,+CAAsB,EAAC,EAAE,MAAM,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;oBACrF,OAAO,UAAU,KAAK,KAAK,IAAI,CAAC,QAAQ,IAAI,oBAAoB,IAAI,QAAQ,CAAC,CAAC;gBAClF,CAAC,CAAC,CAAC;YACP,CAAC;iBAAM,CAAC;gBACJ,OAAO,cAAc,CAAC;YAC1B,CAAC;QACL,CAAC,EAAE,uBAAuB,CAAC;QAC7B,CAAC,CAAC,uBAAuB,CAAC;IAElC,yCAAyC,CAAC,GAAG,CAAC,QAAQ,EAAE,mCAAmC,CAAC,CAAC;IAE7F,OAAO,yCAAyC,CAAC,GAAG,CAAC,QAAQ,CAAE,CAAC;AACpE,CAAC;AAED,SAAS,YAAY,CAAC,IAAY;IAC9B,IAAI,CAAC;QACD,OAAO,IAAA,eAAK,EAAC,IAAI,CAAC,CAAC;IACvB,CAAC;IAAC,WAAM,CAAC;QACL,OAAO,KAAK,CAAC;IACjB,CAAC;AACL,CAAC;AAcD;;;;GAIG;AACH,SAAgB,eAAe,CAAC,EAC5B,IAAI,EACJ,OAAO,GAAG;IACN,aAAa,EAAE,2BAA2B,CAAC,EAAE,CAAC;IAC9C,yBAAyB,EAAE,KAAK;CACnC,GACc;IACf,IAAI,KAAK,GAAG,YAAY,CAAC,IAAI,CAAC,CAAC;IAE/B,IAAI,OAAO,CAAC,yBAAyB,IAAI,KAAK,EAAE,CAAC;QAC7C,iEAAiE;QACjE,OAAO,KAAK,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IAED,IAAI,CAAC,KAAK,EAAE,CAAC;QACT,KAAK,GAAG,YAAY,CAAC,oBAAoB,CAAC,IAAI,CAAC,CAAU,CAAC;IAC9D,CAAC;IAED,IAAI,OAAO,CAAC,aAAa,KAAK,KAAK,IAAI,KAAK,EAAE,CAAC;QAC3C,yCAAyC;QACzC,OAAO,KAAK,CAAC,GAAG,EAAE,CAAC,QAAQ,EAAE,CAAC;IAClC,CAAC;IAED,IAAI,aAAa,GAAG,EAAa,CAAC;IAElC,IAAI,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE,CAAC;QACvC,aAAa,GAAG,OAAO,CAAC,aAAa,CAAC;IAC1C,CAAC;SAAM,CAAC;QACJ,aAAa,GAAG,2BAA2B,CAAC,OAAO,CAAC,aAAsC,CAAC,CAAC;IAChG,CAAC;IAED,IAAI,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;QAC7B,sCAAsC;QACtC,OAAO,CAAC,IAAI,CAAC,6EAA6E,CAAC,CAAC;QAC5F,OAAO,KAAK,CAAC;IACjB,CAAC;IAED,OAAO,qBAAqB,CAAC,KAAK,EAAE,aAAwB,CAAC;SACxD,GAAG,EAAE;SACL,QAAQ,EAAE,CAAC;AACpB,CAAC;AAED,SAAS,mBAAmB,CAAC,WAAmB;IAC5C;2CACuC;IACvC,oCAAoC;IACpC,IAAI,QAAQ,GAAG,CAAC,CAAC;IACjB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;QAC1C,QAAQ,GAAG,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,QAAQ,GAAG,WAAW,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;QAClE,QAAQ,IAAI,QAAQ,CAAC,CAAC,2BAA2B;IACrD,CAAC;IACD,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED,SAAS,iBAAiB,CAAC,MAAc;IACrC,0DAA0D;IAC1D,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC;IAChD,sDAAsD;IACtD,MAAM,QAAQ,GAAG,GAAG,GAAG,CAAC,IAAI,GAAG,QAAQ,CAAC,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACvE,OAAO,QAAQ,CAAC;AACpB,CAAC;AAED,SAAS,oBAAoB,CAAC,WAAmB;IAC7C,MAAM,WAAW,GAAG,mBAAmB,CAAC,WAAW,CAAC,CAAC;IACrD,OAAO,iBAAiB,CAAC,WAAW,CAAC,CAAC;AAC1C,CAAC;AAED,SAAS,qBAAqB,CAAC,KAAY,EAAE,aAAsB;IAC/D,MAAM,gBAAgB,GAAG,aAAa,CAAC,MAAM,CACzC,CAAC,YAAY,EAAE,iBAAiB,EAAE,EAAE;QAChC,MAAM,QAAQ,GAAG,IAAA,+CAAsB,EAAC;YACpC,MAAM,EAAE,KAAK;YACb,MAAM,EAAE,iBAAiB;SAC5B,CAAC,CAAC;QACH,OAAO,QAAQ,IAAI,QAAQ,GAAG,YAAY,CAAC,QAAQ;YAC/C,CAAC,CAAC;gBACI,QAAQ;gBACR,KAAK,EAAE,iBAAiB;aAC3B;YACH,CAAC,CAAC,YAAY,CAAC;IACvB,CAAC,EACD;QACI,QAAQ,EAAE,MAAM,CAAC,iBAAiB;QAClC,KAAK,EAAE,aAAa,CAAC,CAAC,CAAC;KAC1B,CACJ,CAAC;IACF,OAAO,gBAAgB,CAAC,KAAK,CAAC;AAClC,CAAC"}
@@ -0,0 +1,114 @@
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ var __importDefault = (this && this.__importDefault) || function (mod) {
14
+ return (mod && mod.__esModule) ? mod : { "default": mod };
15
+ };
16
+ Object.defineProperty(exports, "__esModule", { value: true });
17
+ exports.ColorField = void 0;
18
+ const react_1 = __importDefault(require("react"));
19
+ const classnames_1 = __importDefault(require("classnames"));
20
+ const common_1 = require("../../common");
21
+ const constants_1 = require("../../configuration/constants");
22
+ const ContextOverlay_1 = require("../ContextOverlay");
23
+ const Form_1 = require("../Form");
24
+ const RadioButton_1 = require("../RadioButton/RadioButton");
25
+ const Spacing_1 = require("../Separation/Spacing");
26
+ const Tag_1 = require("../Tag");
27
+ const TextField_1 = require("../TextField");
28
+ const Tooltip_1 = require("../Tooltip/Tooltip");
29
+ const Typography_1 = require("../Typography");
30
+ /**
31
+ * Color input field that provides resets from the configured color palette.
32
+ * Use `includeColorWeight` and `includePaletteGroup` to filter them.
33
+ */
34
+ const ColorField = (_a) => {
35
+ var { className = "", allowCustomColor = false, colorPresets = listColorPalettePresets(), defaultValue, value, onChange, fullWidth = false } = _a, otherTextFieldProps = __rest(_a, ["className", "allowCustomColor", "colorPresets", "defaultValue", "value", "onChange", "fullWidth"]);
36
+ const ref = react_1.default.useRef(null);
37
+ const [colorValue, setColorValue] = react_1.default.useState(defaultValue || value || "#000000");
38
+ if (value && value !== colorValue) {
39
+ setColorValue(value);
40
+ }
41
+ const disableNativePicker = colorPresets.length > 0;
42
+ const disabled = (!disableNativePicker && !allowCustomColor) || otherTextFieldProps.disabled;
43
+ const forwardOnChange = (forwardedEvent) => {
44
+ setColorValue(forwardedEvent.target.value);
45
+ if (onChange) {
46
+ onChange(forwardedEvent);
47
+ }
48
+ };
49
+ const colorInput = (react_1.default.createElement(TextField_1.TextField, Object.assign({ inputRef: ref, className: (0, classnames_1.default)(`${constants_1.CLASSPREFIX}-colorfield`, className, {
50
+ [`${constants_1.CLASSPREFIX}-colorfield--custom-picker`]: disableNativePicker,
51
+ [`${constants_1.CLASSPREFIX}-colorfield--disabled`]: disabled,
52
+ }),
53
+ // we cannot use `color` type for the custom picker because we do not have control over it then
54
+ type: !disableNativePicker ? "color" : "text", readOnly: disableNativePicker, disabled: disabled, value: colorValue, fullWidth: fullWidth }, otherTextFieldProps, { onChange: !disableNativePicker
55
+ ? (e) => {
56
+ forwardOnChange(e);
57
+ }
58
+ : undefined, style: Object.assign(Object.assign({}, otherTextFieldProps.style), { [`--eccgui-colorfield-background`]: colorValue }) })));
59
+ return disableNativePicker && !disabled ? (react_1.default.createElement(ContextOverlay_1.ContextOverlay, { fill: fullWidth, content: react_1.default.createElement(Typography_1.WhiteSpaceContainer, { paddingTop: "small", paddingRight: "small", paddingBottom: "small", paddingLeft: "small", className: `${constants_1.CLASSPREFIX}-colorfield__picker` },
60
+ allowCustomColor && (react_1.default.createElement(react_1.default.Fragment, null,
61
+ react_1.default.createElement(TextField_1.TextField, { type: "color", value: colorValue, onChange: (e) => {
62
+ forwardOnChange(e);
63
+ } }),
64
+ react_1.default.createElement(Spacing_1.Spacing, { size: "small" }))),
65
+ react_1.default.createElement(Form_1.FieldSet, null,
66
+ react_1.default.createElement(Tag_1.TagList, { className: `${constants_1.CLASSPREFIX}-colorfield__palette` }, colorPresets.map((color, idx) => [
67
+ react_1.default.createElement(RadioButton_1.RadioButton, { key: idx, className: `${constants_1.CLASSPREFIX}-colorfield__palette__color`, hideIndicator: true, value: typeof color[1] === "string" ? color[1] : color[1].toString(), onChange: (e) => {
68
+ forwardOnChange(e);
69
+ } },
70
+ react_1.default.createElement(Tooltip_1.Tooltip, { content: color[0] },
71
+ react_1.default.createElement(Tag_1.Tag, { large: true, style: { [`--eccgui-colorfield-palette-color`]: color[1] } }, color[1]))),
72
+ // Looks like we cannot force some type of line break in the tag list via CSS only
73
+ (idx + 1) % 8 === 0 && (react_1.default.createElement(react_1.default.Fragment, null,
74
+ react_1.default.createElement("br", { className: `${constants_1.CLASSPREFIX}-colorfield__palette-linebreak` }))),
75
+ ])))) }, colorInput)) : (colorInput);
76
+ };
77
+ exports.ColorField = ColorField;
78
+ const defaultColorPaletteSet = {
79
+ // on default, we only include color weights that can have enough contrasts to black/white
80
+ includeColorWeight: [100, 300, 700, 900],
81
+ // on default, we only include layout colors
82
+ includePaletteGroup: ["layout"],
83
+ };
84
+ /**
85
+ * Simple helper function to get a list of colors defined in the color palette.
86
+ */
87
+ const listColorPalettePresets = (colorPaletteSet = defaultColorPaletteSet) => {
88
+ return common_1.utils
89
+ .getEnabledColorPropertiesFromPalette(Object.assign(Object.assign({}, colorPaletteSet), { minimalColorDistance: 0 }))
90
+ .map((color) => [
91
+ color[0].replace(`${constants_1.CLASSPREFIX}-color-palette-`, ""),
92
+ color[1],
93
+ ]);
94
+ };
95
+ exports.ColorField.listColorPalettePresets = listColorPalettePresets;
96
+ /**
97
+ * Simple helper function that provide simple access to color hash calculation.
98
+ */
99
+ exports.ColorField.calculateColorHashValue = (text, options = Object.assign(Object.assign({}, defaultColorPaletteSet), { allowCustomColor: false })) => {
100
+ const hash = common_1.utils.textToColorHash({
101
+ text,
102
+ options: {
103
+ returnValidColorsDirectly: options.allowCustomColor,
104
+ enabledColors: common_1.utils.getEnabledColorsFromPalette({
105
+ includePaletteGroup: options.includePaletteGroup,
106
+ includeColorWeight: options.includeColorWeight,
107
+ minimalColorDistance: 0,
108
+ }),
109
+ },
110
+ });
111
+ return hash ? hash : undefined;
112
+ };
113
+ exports.default = exports.ColorField;
114
+ //# sourceMappingURL=ColorField.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ColorField.js","sourceRoot":"","sources":["../../../../src/components/ColorField/ColorField.tsx"],"names":[],"mappings":"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"}
@@ -17,10 +17,13 @@ Object.defineProperty(exports, "__esModule", { value: true });
17
17
  exports.RadioButton = void 0;
18
18
  const react_1 = __importDefault(require("react"));
19
19
  const core_1 = require("@blueprintjs/core");
20
+ const classnames_1 = __importDefault(require("classnames"));
20
21
  const constants_1 = require("../../configuration/constants");
21
22
  const RadioButton = (_a) => {
22
- var { children, className = "" } = _a, restProps = __rest(_a, ["children", "className"]);
23
- return (react_1.default.createElement(core_1.Radio, Object.assign({}, restProps, { className: `${constants_1.CLASSPREFIX}-radiobutton ` + className }), children));
23
+ var { children, className = "", hideIndicator = false } = _a, restProps = __rest(_a, ["children", "className", "hideIndicator"]);
24
+ return (react_1.default.createElement(core_1.Radio, Object.assign({}, restProps, { className: (0, classnames_1.default)(`${constants_1.CLASSPREFIX}-radiobutton`, className, {
25
+ [`${constants_1.CLASSPREFIX}-radiobutton--hidden-indicator`]: hideIndicator,
26
+ }) }), children));
24
27
  };
25
28
  exports.RadioButton = RadioButton;
26
29
  exports.default = exports.RadioButton;
@@ -1 +1 @@
1
- {"version":3,"file":"RadioButton.js","sourceRoot":"","sources":["../../../../src/components/RadioButton/RadioButton.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,4CAAqG;AAErG,6DAAsE;AAI/D,MAAM,WAAW,GAAG,CAAC,EAA4D,EAAE,EAAE;QAAhE,EAAE,QAAQ,EAAE,SAAS,GAAG,EAAE,OAAkC,EAA7B,SAAS,cAAxC,yBAA0C,CAAF;IAChE,OAAO,CACH,8BAAC,YAAoB,oBAAK,SAAS,IAAE,SAAS,EAAE,GAAG,uBAAM,eAAe,GAAG,SAAS,KAC/E,QAAQ,CACU,CAC1B,CAAC;AACN,CAAC,CAAC;AANW,QAAA,WAAW,eAMtB;AAEF,kBAAe,mBAAW,CAAC"}
1
+ {"version":3,"file":"RadioButton.js","sourceRoot":"","sources":["../../../../src/components/RadioButton/RadioButton.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;AAAA,kDAA0B;AAC1B,4CAAqG;AACrG,4DAAoC;AAEpC,6DAAsE;AAU/D,MAAM,WAAW,GAAG,CAAC,EAAmF,EAAE,EAAE;QAAvF,EAAE,QAAQ,EAAE,SAAS,GAAG,EAAE,EAAE,aAAa,GAAG,KAAK,OAAkC,EAA7B,SAAS,cAA/D,0CAAiE,CAAF;IACvF,OAAO,CACH,8BAAC,YAAoB,oBACb,SAAS,IACb,SAAS,EAAE,IAAA,oBAAU,EAAC,GAAG,uBAAM,cAAc,EAAE,SAAS,EAAE;YACtD,CAAC,GAAG,uBAAM,gCAAgC,CAAC,EAAE,aAAa;SAC7D,CAAC,KAED,QAAQ,CACU,CAC1B,CAAC;AACN,CAAC,CAAC;AAXW,QAAA,WAAW,eAWtB;AAEF,kBAAe,mBAAW,CAAC"}
@@ -17,17 +17,26 @@ const useTextValidation = ({ value, onChange, invisibleCharacterWarning }) => {
17
17
  state.current.detectedCodePoints = new Set();
18
18
  }, []);
19
19
  const detectionRegex = react_1.default.useMemo(() => characters_1.default.invisibleZeroWidthCharacters.createRegex(), []);
20
+ const segmenter = react_1.default.useMemo(() => new Intl.Segmenter(undefined, { granularity: "grapheme" }), []);
21
+ const emojiRegex = react_1.default.useMemo(() => new RegExp("\\p{Extended_Pictographic}|\\u20E3", "u"), []);
20
22
  const detectIssues = react_1.default.useCallback((value) => {
21
- detectionRegex.lastIndex = 0;
22
- let matchArray = detectionRegex.exec(value);
23
- while (matchArray) {
24
- const codePoint = matchArray[0].codePointAt(0);
25
- if (codePoint) {
26
- state.current.detectedCodePoints.add(codePoint);
23
+ for (const { segment } of segmenter.segment(value)) {
24
+ if (emojiRegex.test(segment)) {
25
+ // skip emoji clusters since they legitimately contain variation selectors, ZWJ, tags, etc.
26
+ }
27
+ else {
28
+ detectionRegex.lastIndex = 0;
29
+ let matchArray = detectionRegex.exec(segment);
30
+ while (matchArray) {
31
+ const codePoint = matchArray[0].codePointAt(0);
32
+ if (codePoint) {
33
+ state.current.detectedCodePoints.add(codePoint);
34
+ }
35
+ matchArray = detectionRegex.exec(segment);
36
+ }
27
37
  }
28
- matchArray = detectionRegex.exec(value);
29
38
  }
30
- }, [detectionRegex]);
39
+ }, [detectionRegex, segmenter, emojiRegex]);
31
40
  // Checks if the value contains any problematic characters with a small delay.
32
41
  const checkValue = react_1.default.useCallback((value) => {
33
42
  state.current.detectedCodePoints = new Set();
@@ -1 +1 @@
1
- {"version":3,"file":"useTextValidation.js","sourceRoot":"","sources":["../../../../src/components/TextField/useTextValidation.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"useTextValidation.js","sourceRoot":"","sources":["../../../../src/components/TextField/useTextValidation.ts"],"names":[],"mappings":"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"}
@@ -23,6 +23,7 @@ __exportStar(require("./Card"), exports);
23
23
  __exportStar(require("./Chat"), exports);
24
24
  __exportStar(require("./Checkbox/Checkbox"), exports);
25
25
  __exportStar(require("./CodeAutocompleteField"), exports);
26
+ __exportStar(require("./ColorField/ColorField"), exports);
26
27
  __exportStar(require("./ContentGroup/ContentGroup"), exports);
27
28
  __exportStar(require("./ContextOverlay"), exports);
28
29
  __exportStar(require("./DecoupledOverlay/DecoupledOverlay"), exports);
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,gDAA8B;AAC9B,gDAA8B;AAC9B,+CAA6B;AAC7B,kDAAgC;AAChC,yCAAuB;AACvB,yCAAuB;AACvB,sDAAoC;AACpC,0DAAwC;AACxC,8DAA4C;AAC5C,mDAAiC;AACjC,sEAAoD;AACpD,wDAAsC;AACtC,2CAAyB;AACzB,mDAAiC;AACjC,yCAAuB;AACvB,yCAAuB;AACvB,8DAA4C;AAC5C,yCAAuB;AACvB,2CAAyB;AACzB,oEAAkD;AAClD,gDAA8B;AAC9B,8CAA4B;AAC5B,8CAA4B;AAC5B,yCAAuB;AACvB,sDAAoC;AACpC,iDAA+B;AAC/B,iDAA+B;AAC/B,0DAAwC;AACxC,gDAA8B;AAC9B,sDAAoC;AACpC,4DAA0C;AAC1C,kDAAgC;AAChC,uDAAqC;AACrC,uDAAqC;AACrC,sDAAoC;AACpC,oDAAkC;AAClC,2CAAyB;AACzB,8CAA4B;AAC5B,iDAA+B;AAC/B,kDAAgC;AAChC,0CAAwB;AACxB,yCAAuB;AACvB,wCAAsB;AACtB,8CAA4B;AAC5B,4DAA0C;AAC1C,4CAA0B;AAC1B,oDAAkC;AAClC,8CAA4B;AAC5B,+CAA6B;AAC7B,0DAAwC;AACxC,8CAA4B;AAE5B,+CAA6B"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;AAAA,8CAA4B;AAC5B,gDAA8B;AAC9B,gDAA8B;AAC9B,+CAA6B;AAC7B,kDAAgC;AAChC,yCAAuB;AACvB,yCAAuB;AACvB,sDAAoC;AACpC,0DAAwC;AACxC,0DAAwC;AACxC,8DAA4C;AAC5C,mDAAiC;AACjC,sEAAoD;AACpD,wDAAsC;AACtC,2CAAyB;AACzB,mDAAiC;AACjC,yCAAuB;AACvB,yCAAuB;AACvB,8DAA4C;AAC5C,yCAAuB;AACvB,2CAAyB;AACzB,oEAAkD;AAClD,gDAA8B;AAC9B,8CAA4B;AAC5B,8CAA4B;AAC5B,yCAAuB;AACvB,sDAAoC;AACpC,iDAA+B;AAC/B,iDAA+B;AAC/B,0DAAwC;AACxC,gDAA8B;AAC9B,sDAAoC;AACpC,4DAA0C;AAC1C,kDAAgC;AAChC,uDAAqC;AACrC,uDAAqC;AACrC,sDAAoC;AACpC,oDAAkC;AAClC,2CAAyB;AACzB,8CAA4B;AAC5B,iDAA+B;AAC/B,kDAAgC;AAChC,0CAAwB;AACxB,yCAAuB;AACvB,wCAAsB;AACtB,8CAA4B;AAC5B,4DAA0C;AAC1C,4CAA0B;AAC1B,oDAAkC;AAClC,8CAA4B;AAC5B,+CAA6B;AAC7B,0DAAwC;AACxC,8CAA4B;AAE5B,+CAA6B"}
@@ -42,6 +42,7 @@ const state_1 = require("@codemirror/state");
42
42
  const view_1 = require("@codemirror/view");
43
43
  const codemirror_1 = require("codemirror");
44
44
  const Markdown_1 = require("../../cmem/markdown/Markdown");
45
+ const EditorAppearanceConfigMenu_1 = require("./toolbars/EditorAppearanceConfigMenu");
45
46
  const markText_1 = require("../../components/AutoSuggestion/extensions/markText");
46
47
  const constants_1 = require("../../configuration/constants");
47
48
  //hooks
@@ -59,13 +60,29 @@ const ModeLinterMap = new Map([
59
60
  ["javascript", [jsLinter_1.jsLinter]],
60
61
  ]);
61
62
  const ModeToolbarSupport = ["markdown"];
63
+ const defaultAppearanceForModeWithToolbar = new Map([
64
+ ["markdown", { wrapLines: true, preventLineNumbers: true }]
65
+ ]);
66
+ const getDefaultAppearanceForModeWithToolbar = (hasToolbar, mode) => {
67
+ if (hasToolbar && mode) {
68
+ return defaultAppearanceForModeWithToolbar.get(mode);
69
+ }
70
+ return undefined;
71
+ };
62
72
  /**
63
73
  * Includes a code editor, currently we use CodeMirror library as base.
64
74
  */
65
75
  const CodeEditor = (_a) => {
66
- var { className, onChange, onSelection, onMouseDown, onFocusChange, onKeyDown, onCursorChange, name, id, mode, preventLineNumbers = false, defaultValue = "", readOnly = false, shouldHaveMinimalSetup = true, wrapLines = false, onScroll, setEditorView, supportCodeFolding = false, shouldHighlightActiveLine = false, outerDivAttributes, tabIntentSize = 2, tabIntentStyle = "tab", placeholder, additionalExtensions = [], tabForceSpaceForModes = ["python", "yaml"], enableTab = false, height, useLinting = false, autoFocus = false, disabled = false, intent, useToolbar, translate } = _a, otherCodeEditorProps = __rest(_a, ["className", "onChange", "onSelection", "onMouseDown", "onFocusChange", "onKeyDown", "onCursorChange", "name", "id", "mode", "preventLineNumbers", "defaultValue", "readOnly", "shouldHaveMinimalSetup", "wrapLines", "onScroll", "setEditorView", "supportCodeFolding", "shouldHighlightActiveLine", "outerDivAttributes", "tabIntentSize", "tabIntentStyle", "placeholder", "additionalExtensions", "tabForceSpaceForModes", "enableTab", "height", "useLinting", "autoFocus", "disabled", "intent", "useToolbar", "translate"]);
76
+ var _b, _c;
77
+ var { className, onChange, onSelection, onMouseDown, onFocusChange, onKeyDown, onCursorChange, name, id, mode, preventLineNumbers, wrapLines, defaultValue = "", readOnly = false, shouldHaveMinimalSetup = true, onScroll, setEditorView, supportCodeFolding = false, shouldHighlightActiveLine = false, outerDivAttributes, tabIntentSize = 2, tabIntentStyle = "tab", placeholder, additionalExtensions = [], tabForceSpaceForModes = ["python", "yaml"], enableTab = false, height, useLinting = false, autoFocus = false, disabled = false, intent, useToolbar = false, translate } = _a, otherCodeEditorProps = __rest(_a, ["className", "onChange", "onSelection", "onMouseDown", "onFocusChange", "onKeyDown", "onCursorChange", "name", "id", "mode", "preventLineNumbers", "wrapLines", "defaultValue", "readOnly", "shouldHaveMinimalSetup", "onScroll", "setEditorView", "supportCodeFolding", "shouldHighlightActiveLine", "outerDivAttributes", "tabIntentSize", "tabIntentStyle", "placeholder", "additionalExtensions", "tabForceSpaceForModes", "enableTab", "height", "useLinting", "autoFocus", "disabled", "intent", "useToolbar", "translate"]);
67
78
  const parent = (0, react_1.useRef)(undefined);
68
79
  const [view, setView] = react_1.default.useState();
80
+ const defaultAppearanceForModeWithToolbar = getDefaultAppearanceForModeWithToolbar(useToolbar, mode);
81
+ const [editorAppearance, setEditorAppearance] = react_1.default.useState({
82
+ // we also set the fallback default here
83
+ wrapLines: (_b = wrapLines !== null && wrapLines !== void 0 ? wrapLines : defaultAppearanceForModeWithToolbar === null || defaultAppearanceForModeWithToolbar === void 0 ? void 0 : defaultAppearanceForModeWithToolbar.wrapLines) !== null && _b !== void 0 ? _b : false,
84
+ preventLineNumbers: (_c = preventLineNumbers !== null && preventLineNumbers !== void 0 ? preventLineNumbers : defaultAppearanceForModeWithToolbar === null || defaultAppearanceForModeWithToolbar === void 0 ? void 0 : defaultAppearanceForModeWithToolbar.preventLineNumbers) !== null && _c !== void 0 ? _c : false,
85
+ });
69
86
  const currentView = react_1.default.useRef();
70
87
  currentView.current = view;
71
88
  const currentReadOnly = react_1.default.useRef(readOnly);
@@ -74,6 +91,8 @@ const CodeEditor = (_a) => {
74
91
  currentOnChange.current = onChange;
75
92
  const currentDisabled = react_1.default.useRef(disabled);
76
93
  currentDisabled.current = disabled;
94
+ const currentIntent = react_1.default.useRef(intent);
95
+ currentIntent.current = intent;
77
96
  const [showPreview, setShowPreview] = react_1.default.useState(false);
78
97
  // CodeMirror Compartments in order to allow for re-configuration after initialization
79
98
  const readOnlyCompartment = react_1.default.useRef((0, codemirrorTestHelper_1.compartment)());
@@ -151,8 +170,8 @@ const CodeEditor = (_a) => {
151
170
  }
152
171
  if (onSelection)
153
172
  onSelection(v.state.selection.ranges.filter((r) => !r.empty).map(({ from, to }) => ({ from, to })));
154
- if (onFocusChange && intent && !((_a = v.view.dom.classList) === null || _a === void 0 ? void 0 : _a.contains(`${constants_1.CLASSPREFIX}-intent--${intent}`))) {
155
- v.view.dom.classList.add(`${constants_1.CLASSPREFIX}-intent--${intent}`);
173
+ if (onFocusChange && currentIntent.current && !((_a = v.view.dom.classList) === null || _a === void 0 ? void 0 : _a.contains(`${constants_1.CLASSPREFIX}-intent--${currentIntent.current}`))) {
174
+ v.view.dom.classList.add(`${constants_1.CLASSPREFIX}-intent--${currentIntent.current}`);
156
175
  }
157
176
  if (onCursorChange) {
158
177
  const cursorPosition = (_b = v.state.selection.main.head) !== null && _b !== void 0 ? _b : 0;
@@ -167,9 +186,9 @@ const CodeEditor = (_a) => {
167
186
  }
168
187
  }),
169
188
  shouldHaveMinimalSetupCompartment.current.of(addExtensionsFor(shouldHaveMinimalSetup, codemirror_1.minimalSetup)),
170
- preventLineNumbersCompartment.current.of(addExtensionsFor(!preventLineNumbers, (0, codemirrorTestHelper_1.adaptedLineNumbers)())),
189
+ preventLineNumbersCompartment.current.of(addExtensionsFor(!editorAppearance.preventLineNumbers, (0, codemirrorTestHelper_1.adaptedLineNumbers)())),
171
190
  shouldHighlightActiveLineCompartment.current.of(addExtensionsFor(shouldHighlightActiveLine, (0, codemirrorTestHelper_1.adaptedHighlightActiveLine)())),
172
- wrapLinesCompartment.current.of(addExtensionsFor(wrapLines, view_1.EditorView === null || view_1.EditorView === void 0 ? void 0 : view_1.EditorView.lineWrapping)),
191
+ wrapLinesCompartment.current.of(addExtensionsFor((editorAppearance.wrapLines), view_1.EditorView === null || view_1.EditorView === void 0 ? void 0 : view_1.EditorView.lineWrapping)),
173
192
  supportCodeFoldingCompartment.current.of(addExtensionsFor(supportCodeFolding, (0, codemirrorTestHelper_1.adaptedFoldGutter)(), (0, codemirrorTestHelper_1.adaptedCodeFolding)())),
174
193
  useLintingCompartment.current.of(addExtensionsFor(useLinting, ...linters)),
175
194
  (0, codemirrorTestHelper_1.adaptedSyntaxHighlighting)(language_1.defaultHighlightStyle),
@@ -190,8 +209,8 @@ const CodeEditor = (_a) => {
190
209
  if (disabled) {
191
210
  view.dom.classList.add(`${constants_1.CLASSPREFIX}-disabled`);
192
211
  }
193
- if (intent) {
194
- view.dom.className += ` ${constants_1.CLASSPREFIX}-intent--${intent}`;
212
+ if (currentIntent.current) {
213
+ view.dom.className += ` ${constants_1.CLASSPREFIX}-intent--${currentIntent.current}`;
195
214
  }
196
215
  if (autoFocus) {
197
216
  view.focus();
@@ -243,18 +262,22 @@ const CodeEditor = (_a) => {
243
262
  }
244
263
  }
245
264
  }, [disabled]);
265
+ react_1.default.useEffect(() => {
266
+ var _a;
267
+ setEditorAppearance(Object.assign(Object.assign({}, editorAppearance), { preventLineNumbers: (_a = preventLineNumbers !== null && preventLineNumbers !== void 0 ? preventLineNumbers : editorAppearance === null || editorAppearance === void 0 ? void 0 : editorAppearance.preventLineNumbers) !== null && _a !== void 0 ? _a : false }));
268
+ updateExtension(addExtensionsFor(!editorAppearance.preventLineNumbers, (0, codemirrorTestHelper_1.adaptedLineNumbers)()), preventLineNumbersCompartment.current);
269
+ }, [preventLineNumbers, editorAppearance.preventLineNumbers]);
270
+ react_1.default.useEffect(() => {
271
+ var _a;
272
+ setEditorAppearance(Object.assign(Object.assign({}, editorAppearance), { wrapLines: (_a = wrapLines !== null && wrapLines !== void 0 ? wrapLines : editorAppearance === null || editorAppearance === void 0 ? void 0 : editorAppearance.wrapLines) !== null && _a !== void 0 ? _a : false }));
273
+ updateExtension(addExtensionsFor(editorAppearance.wrapLines, view_1.EditorView === null || view_1.EditorView === void 0 ? void 0 : view_1.EditorView.lineWrapping), wrapLinesCompartment.current);
274
+ }, [wrapLines, editorAppearance.wrapLines]);
246
275
  react_1.default.useEffect(() => {
247
276
  updateExtension(addExtensionsFor(shouldHaveMinimalSetup !== null && shouldHaveMinimalSetup !== void 0 ? shouldHaveMinimalSetup : true, codemirror_1.minimalSetup), shouldHaveMinimalSetupCompartment.current);
248
277
  }, [shouldHaveMinimalSetup]);
249
- react_1.default.useEffect(() => {
250
- updateExtension(addExtensionsFor(!preventLineNumbers, (0, codemirrorTestHelper_1.adaptedLineNumbers)()), preventLineNumbersCompartment.current);
251
- }, [preventLineNumbers]);
252
278
  react_1.default.useEffect(() => {
253
279
  updateExtension(addExtensionsFor(shouldHighlightActiveLine !== null && shouldHighlightActiveLine !== void 0 ? shouldHighlightActiveLine : false, (0, codemirrorTestHelper_1.adaptedHighlightActiveLine)()), shouldHighlightActiveLineCompartment.current);
254
280
  }, [shouldHighlightActiveLine]);
255
- react_1.default.useEffect(() => {
256
- updateExtension(addExtensionsFor(wrapLines !== null && wrapLines !== void 0 ? wrapLines : false, view_1.EditorView === null || view_1.EditorView === void 0 ? void 0 : view_1.EditorView.lineWrapping), wrapLinesCompartment.current);
257
- }, [wrapLines]);
258
281
  react_1.default.useEffect(() => {
259
282
  updateExtension(addExtensionsFor(supportCodeFolding !== null && supportCodeFolding !== void 0 ? supportCodeFolding : false, (0, codemirrorTestHelper_1.adaptedFoldGutter)(), (0, codemirrorTestHelper_1.adaptedCodeFolding)()), supportCodeFoldingCompartment.current);
260
283
  }, [supportCodeFolding]);
@@ -268,7 +291,10 @@ const CodeEditor = (_a) => {
268
291
  case "markdown":
269
292
  return (react_1.default.createElement("div", null,
270
293
  react_1.default.createElement("div", { className: `${constants_1.CLASSPREFIX}-codeeditor__toolbar` },
271
- react_1.default.createElement(markdown_toolbar_1.MarkdownToolbar, { view: view, togglePreviewStatus: () => setShowPreview((p) => !p), showPreview: showPreview, translate: getTranslation, disabled: disabled, readonly: readOnly })),
294
+ react_1.default.createElement(markdown_toolbar_1.MarkdownToolbar, { view: view, togglePreviewStatus: () => setShowPreview((p) => !p), showPreview: showPreview, translate: getTranslation, disabled: disabled, readonly: readOnly, configMenu: (react_1.default.createElement(EditorAppearanceConfigMenu_1.EditorAppearanceConfigMenu, { config: Object.assign({}, editorAppearance), configLocked: {
295
+ wrapLines,
296
+ preventLineNumbers,
297
+ }, setConfig: setEditorAppearance, configPropertyTranslate: getTranslation })) })),
272
298
  showPreview && (react_1.default.createElement("div", { className: `${constants_1.CLASSPREFIX}-codeeditor__preview` },
273
299
  react_1.default.createElement(Markdown_1.Markdown, null, (_a = view === null || view === void 0 ? void 0 : view.state.doc.toString()) !== null && _a !== void 0 ? _a : "")))));
274
300
  default: