@commercetools-uikit/localized-rich-text-input 15.15.0 → 16.0.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.
- package/dist/commercetools-uikit-localized-rich-text-input.cjs.d.ts +1 -0
- package/dist/commercetools-uikit-localized-rich-text-input.cjs.d.ts.map +1 -0
- package/dist/commercetools-uikit-localized-rich-text-input.cjs.dev.js +109 -131
- package/dist/commercetools-uikit-localized-rich-text-input.cjs.prod.js +109 -131
- package/dist/commercetools-uikit-localized-rich-text-input.esm.js +109 -131
- package/package.json +19 -19
|
@@ -74,11 +74,9 @@ var pipe__default = /*#__PURE__*/_interopDefault(pipe);
|
|
|
74
74
|
|
|
75
75
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$1() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
76
76
|
|
|
77
|
-
|
|
78
|
-
return "1px solid ".concat(props.isReadOnly ? designSystem.designTokens.borderColorForInputWhenReadonly : designSystem.designTokens.borderColorForInputWhenDisabled);
|
|
79
|
-
};
|
|
77
|
+
const getEditorLanguageLabelBorderColor = props => "1px solid ".concat(props.isReadOnly ? designSystem.designTokens.borderColorForInputWhenReadonly : designSystem.designTokens.borderColorForInputWhenDisabled);
|
|
80
78
|
|
|
81
|
-
|
|
79
|
+
const getBackgroundColor = props => {
|
|
82
80
|
if (props.isDisabled) {
|
|
83
81
|
return designSystem.designTokens.backgroundColorForInputWhenDisabled;
|
|
84
82
|
}
|
|
@@ -90,29 +88,21 @@ var getBackgroundColor = function getBackgroundColor(props) {
|
|
|
90
88
|
return designSystem.designTokens.backgroundColorForInput;
|
|
91
89
|
};
|
|
92
90
|
|
|
93
|
-
|
|
91
|
+
const EditorLanguageLabel = /*#__PURE__*/_styled__default["default"]("label", process.env.NODE_ENV === "production" ? {
|
|
94
92
|
target: "ew063c2"
|
|
95
93
|
} : {
|
|
96
94
|
target: "ew063c2",
|
|
97
95
|
label: "EditorLanguageLabel"
|
|
98
|
-
})("white-space:nowrap;flex:0;color:", designSystem.designTokens.fontColorForInputWhenDisabled, ";line-height:calc(\n ", designSystem.designTokens.sizeHeightInput, " - 2 * ", designSystem.designTokens.borderRadius1, "\n );background-color:",
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
return getEditorLanguageLabelBorderColor(props);
|
|
102
|
-
}, ";padding:", designSystem.designTokens.paddingForLocalizedRichTextInputLabel, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ",color ", designSystem.designTokens.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;display:", function (props) {
|
|
103
|
-
return props.isNewTheme && 'flex';
|
|
104
|
-
}, ";align-items:center;cursor:inherit;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNtRSIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLy9UT0RPOiBAcmVkZXNpZ24gY2xlYW51cFxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRFZGl0b3JQcm9wcyB9IGZyb20gJy4vZWRpdG9yJztcblxuY29uc3QgZ2V0RWRpdG9yTGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBURWRpdG9yTGFuZ3VhZ2VMYWJlbFByb3BzKSA9PlxuICBgMXB4IHNvbGlkICR7XG4gICAgcHJvcHMuaXNSZWFkT25seVxuICAgICAgPyBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5SZWFkb25seVxuICAgICAgOiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICB9YDtcblxudHlwZSBUSW5wdXRQcm9wcyA9IHtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIGlzUmVhZE9ubHk/OiBib29sZWFuO1xufTtcblxudHlwZSBURWRpdG9yTGFuZ3VhZ2VMYWJlbFByb3BzID0ge1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIGlzTmV3VGhlbWU/OiBib29sZWFuO1xufTtcblxuY29uc3QgZ2V0QmFja2dyb3VuZENvbG9yID0gKHByb3BzOiBUSW5wdXRQcm9wcykgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXQ7XG59O1xuXG5jb25zdCBFZGl0b3JMYW5ndWFnZUxhYmVsID0gc3R5bGVkLmxhYmVsPFRFZGl0b3JMYW5ndWFnZUxhYmVsUHJvcHM+YFxuICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBmbGV4OiAwO1xuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWR9O1xuICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAke2Rlc2lnblRva2Vucy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICk7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHByb3BzKSA9PiBnZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlcjogJHsocHJvcHMpID0+IGdldEVkaXRvckxhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yTG9jYWxpemVkUmljaFRleHRJbnB1dExhYmVsfTtcbiAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgYmFja2dyb3VuZC1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgIGNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIGJvcmRlci1yaWdodDogMDtcbiAgYm94LXNoYWRvdzogbm9uZTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IHByb3BzLmlzTmV3VGhlbWUgJiYgJ2ZsZXgnfTtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAvKiBjdXJzb3Igc2hvdWxkIGJlIGluaGVyaXRlZCBmcm9tIHBhcmVudCxcbiAgICAqIEdJVkVOIHBhcmVudCBoYXMgJ25vdC1hbGxvd2VkJyBjdXJzb3JcbiAgICAqIFRIRU4gdGhlIGxhbmd1YWdlIGxhYmVsIHNob3VsZCBhbHNvIGhhdmUgdGhhdCAoaW5zdGVhZCBvZiBsYWJlbCdzIGRlZmF1bHQgY3Vyc29yKVxuICAgICovXG4gIGN1cnNvcjogaW5oZXJpdDtcbmA7XG5cbmNvbnN0IEVkaXRvcldyYXBwZXIgPSBzdHlsZWQuZGl2PFxuICBQaWNrPFRFZGl0b3JQcm9wcywgJ2lzRGlzYWJsZWQnIHwgJ2lzUmVhZE9ubHknPlxuPmBcbiAgd2lkdGg6IDEwMCU7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgY3Vyc29yOiAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5pc0Rpc2FibGVkIHx8IHByb3BzLmlzUmVhZE9ubHkgPyAnbm90LWFsbG93ZWQnIDogJ2luaGVyaXQnfTtcbmA7XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgRWRpdG9yTGFuZ3VhZ2VMYWJlbCwgRWRpdG9yV3JhcHBlciwgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */"));
|
|
105
|
-
|
|
106
|
-
var EditorWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
96
|
+
})("white-space:nowrap;flex:0;color:", designSystem.designTokens.fontColorForInputWhenDisabled, ";line-height:calc(\n ", designSystem.designTokens.sizeHeightInput, " - 2 * ", designSystem.designTokens.borderRadius1, "\n );background-color:", props => getBackgroundColor(props), ";border-top-left-radius:", designSystem.designTokens.borderRadiusForInput, ";border-bottom-left-radius:", designSystem.designTokens.borderRadiusForInput, ";border:", props => getEditorLanguageLabelBorderColor(props), ";padding:", designSystem.designTokens.paddingForLocalizedRichTextInputLabel, ";transition:border-color ", designSystem.designTokens.transitionStandard, ",background-color ", designSystem.designTokens.transitionStandard, ",color ", designSystem.designTokens.transitionStandard, ";border-right:0;box-shadow:none;appearance:none;display:", props => props.isNewTheme && 'flex', ";align-items:center;cursor:inherit;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBaUNtRSIsImZpbGUiOiJlZGl0b3Iuc3R5bGVzLnRzIiwic291cmNlc0NvbnRlbnQiOlsiLy9UT0RPOiBAcmVkZXNpZ24gY2xlYW51cFxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRFZGl0b3JQcm9wcyB9IGZyb20gJy4vZWRpdG9yJztcblxuY29uc3QgZ2V0RWRpdG9yTGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yID0gKHByb3BzOiBURWRpdG9yTGFuZ3VhZ2VMYWJlbFByb3BzKSA9PlxuICBgMXB4IHNvbGlkICR7XG4gICAgcHJvcHMuaXNSZWFkT25seVxuICAgICAgPyBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5SZWFkb25seVxuICAgICAgOiBkZXNpZ25Ub2tlbnMuYm9yZGVyQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZFxuICB9YDtcblxudHlwZSBUSW5wdXRQcm9wcyA9IHtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIGlzUmVhZE9ubHk/OiBib29sZWFuO1xufTtcblxudHlwZSBURWRpdG9yTGFuZ3VhZ2VMYWJlbFByb3BzID0ge1xuICBpc1JlYWRPbmx5PzogYm9vbGVhbjtcbiAgaXNEaXNhYmxlZD86IGJvb2xlYW47XG4gIGlzTmV3VGhlbWU/OiBib29sZWFuO1xufTtcblxuY29uc3QgZ2V0QmFja2dyb3VuZENvbG9yID0gKHByb3BzOiBUSW5wdXRQcm9wcykgPT4ge1xuICBpZiAocHJvcHMuaXNEaXNhYmxlZCkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgaWYgKHByb3BzLmlzUmVhZE9ubHkpIHtcbiAgICByZXR1cm4gZGVzaWduVG9rZW5zLmJhY2tncm91bmRDb2xvckZvcklucHV0V2hlbkRpc2FibGVkO1xuICB9XG4gIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXQ7XG59O1xuXG5jb25zdCBFZGl0b3JMYW5ndWFnZUxhYmVsID0gc3R5bGVkLmxhYmVsPFRFZGl0b3JMYW5ndWFnZUxhYmVsUHJvcHM+YFxuICAvKiBhdm9pZCB3cmFwcGluZyBsYWJlbCBvbnRvIG5ldyBsaW5lcyAqL1xuICB3aGl0ZS1zcGFjZTogbm93cmFwO1xuICBmbGV4OiAwO1xuICBjb2xvcjogJHtkZXNpZ25Ub2tlbnMuZm9udENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWR9O1xuICBsaW5lLWhlaWdodDogY2FsYyhcbiAgICAke2Rlc2lnblRva2Vucy5zaXplSGVpZ2h0SW5wdXR9IC0gMiAqICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czF9XG4gICk7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHByb3BzKSA9PiBnZXRCYWNrZ3JvdW5kQ29sb3IocHJvcHMpfTtcbiAgYm9yZGVyLXRvcC1sZWZ0LXJhZGl1czogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzRm9ySW5wdXR9O1xuICBib3JkZXItYm90dG9tLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlcjogJHsocHJvcHMpID0+IGdldEVkaXRvckxhbmd1YWdlTGFiZWxCb3JkZXJDb2xvcihwcm9wcyl9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yTG9jYWxpemVkUmljaFRleHRJbnB1dExhYmVsfTtcbiAgdHJhbnNpdGlvbjogYm9yZGVyLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgYmFja2dyb3VuZC1jb2xvciAke2Rlc2lnblRva2Vucy50cmFuc2l0aW9uU3RhbmRhcmR9LFxuICAgIGNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH07XG4gIGJvcmRlci1yaWdodDogMDtcbiAgYm94LXNoYWRvdzogbm9uZTtcbiAgYXBwZWFyYW5jZTogbm9uZTtcbiAgZGlzcGxheTogJHsocHJvcHMpID0+IHByb3BzLmlzTmV3VGhlbWUgJiYgJ2ZsZXgnfTtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICAvKiBjdXJzb3Igc2hvdWxkIGJlIGluaGVyaXRlZCBmcm9tIHBhcmVudCxcbiAgICAqIEdJVkVOIHBhcmVudCBoYXMgJ25vdC1hbGxvd2VkJyBjdXJzb3JcbiAgICAqIFRIRU4gdGhlIGxhbmd1YWdlIGxhYmVsIHNob3VsZCBhbHNvIGhhdmUgdGhhdCAoaW5zdGVhZCBvZiBsYWJlbCdzIGRlZmF1bHQgY3Vyc29yKVxuICAgICovXG4gIGN1cnNvcjogaW5oZXJpdDtcbmA7XG5cbmNvbnN0IEVkaXRvcldyYXBwZXIgPSBzdHlsZWQuZGl2PFxuICBQaWNrPFRFZGl0b3JQcm9wcywgJ2lzRGlzYWJsZWQnIHwgJ2lzUmVhZE9ubHknPlxuPmBcbiAgd2lkdGg6IDEwMCU7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZGlzcGxheTogZmxleDtcbiAgY3Vyc29yOiAkeyhwcm9wcykgPT5cbiAgICBwcm9wcy5pc0Rpc2FibGVkIHx8IHByb3BzLmlzUmVhZE9ubHkgPyAnbm90LWFsbG93ZWQnIDogJ2luaGVyaXQnfTtcbmA7XG5cbmNvbnN0IFRvZ2dsZUJ1dHRvbldyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBmbGV4OiAwO1xuICBkaXNwbGF5OiBmbGV4O1xuYDtcblxuZXhwb3J0IHsgRWRpdG9yTGFuZ3VhZ2VMYWJlbCwgRWRpdG9yV3JhcHBlciwgVG9nZ2xlQnV0dG9uV3JhcHBlciB9O1xuIl19 */"));
|
|
97
|
+
|
|
98
|
+
const EditorWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
107
99
|
target: "ew063c1"
|
|
108
100
|
} : {
|
|
109
101
|
target: "ew063c1",
|
|
110
102
|
label: "EditorWrapper"
|
|
111
|
-
})("width:100%;position:relative;display:flex;cursor:",
|
|
112
|
-
return props.isDisabled || props.isReadOnly ? 'not-allowed' : 'inherit';
|
|
113
|
-
}, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0VDIiwiZmlsZSI6ImVkaXRvci5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvL1RPRE86IEByZWRlc2lnbiBjbGVhbnVwXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB0eXBlIHsgVEVkaXRvclByb3BzIH0gZnJvbSAnLi9lZGl0b3InO1xuXG5jb25zdCBnZXRFZGl0b3JMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRFZGl0b3JMYW5ndWFnZUxhYmVsUHJvcHMpID0+XG4gIGAxcHggc29saWQgJHtcbiAgICBwcm9wcy5pc1JlYWRPbmx5XG4gICAgICA/IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlblJlYWRvbmx5XG4gICAgICA6IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gIH1gO1xuXG50eXBlIFRJbnB1dFByb3BzID0ge1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG50eXBlIFRFZGl0b3JMYW5ndWFnZUxhYmVsUHJvcHMgPSB7XG4gIGlzUmVhZE9ubHk/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNOZXdUaGVtZT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRCYWNrZ3JvdW5kQ29sb3IgPSAocHJvcHM6IFRJbnB1dFByb3BzKSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dDtcbn07XG5cbmNvbnN0IEVkaXRvckxhbmd1YWdlTGFiZWwgPSBzdHlsZWQubGFiZWw8VEVkaXRvckxhbmd1YWdlTGFiZWxQcm9wcz5gXG4gIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIGZsZXg6IDA7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH07XG4gIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICR7ZGVzaWduVG9rZW5zLnNpemVIZWlnaHRJbnB1dH0gLSAyICogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMX1cbiAgKTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsocHJvcHMpID0+IGdldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gZ2V0RWRpdG9yTGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX07XG4gIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JMb2NhbGl6ZWRSaWNoVGV4dElucHV0TGFiZWx9O1xuICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgYm9yZGVyLXJpZ2h0OiAwO1xuICBib3gtc2hhZG93OiBub25lO1xuICBhcHBlYXJhbmNlOiBub25lO1xuICBkaXNwbGF5OiAkeyhwcm9wcykgPT4gcHJvcHMuaXNOZXdUaGVtZSAmJiAnZmxleCd9O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgY3Vyc29yOiBpbmhlcml0O1xuYDtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXY8XG4gIFBpY2s8VEVkaXRvclByb3BzLCAnaXNEaXNhYmxlZCcgfCAnaXNSZWFkT25seSc+XG4+YFxuICB3aWR0aDogMTAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBjdXJzb3I6ICR7KHByb3BzKSA9PlxuICAgIHByb3BzLmlzRGlzYWJsZWQgfHwgcHJvcHMuaXNSZWFkT25seSA/ICdub3QtYWxsb3dlZCcgOiAnaW5oZXJpdCd9O1xuYDtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBFZGl0b3JMYW5ndWFnZUxhYmVsLCBFZGl0b3JXcmFwcGVyLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */"));
|
|
103
|
+
})("width:100%;position:relative;display:flex;cursor:", props => props.isDisabled || props.isReadOnly ? 'not-allowed' : 'inherit', ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbImVkaXRvci5zdHlsZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0VDIiwiZmlsZSI6ImVkaXRvci5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyIvL1RPRE86IEByZWRlc2lnbiBjbGVhbnVwXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZCc7XG5pbXBvcnQgeyBkZXNpZ25Ub2tlbnMgfSBmcm9tICdAY29tbWVyY2V0b29scy11aWtpdC9kZXNpZ24tc3lzdGVtJztcbmltcG9ydCB0eXBlIHsgVEVkaXRvclByb3BzIH0gZnJvbSAnLi9lZGl0b3InO1xuXG5jb25zdCBnZXRFZGl0b3JMYW5ndWFnZUxhYmVsQm9yZGVyQ29sb3IgPSAocHJvcHM6IFRFZGl0b3JMYW5ndWFnZUxhYmVsUHJvcHMpID0+XG4gIGAxcHggc29saWQgJHtcbiAgICBwcm9wcy5pc1JlYWRPbmx5XG4gICAgICA/IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlblJlYWRvbmx5XG4gICAgICA6IGRlc2lnblRva2Vucy5ib3JkZXJDb2xvckZvcklucHV0V2hlbkRpc2FibGVkXG4gIH1gO1xuXG50eXBlIFRJbnB1dFByb3BzID0ge1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNSZWFkT25seT86IGJvb2xlYW47XG59O1xuXG50eXBlIFRFZGl0b3JMYW5ndWFnZUxhYmVsUHJvcHMgPSB7XG4gIGlzUmVhZE9ubHk/OiBib29sZWFuO1xuICBpc0Rpc2FibGVkPzogYm9vbGVhbjtcbiAgaXNOZXdUaGVtZT86IGJvb2xlYW47XG59O1xuXG5jb25zdCBnZXRCYWNrZ3JvdW5kQ29sb3IgPSAocHJvcHM6IFRJbnB1dFByb3BzKSA9PiB7XG4gIGlmIChwcm9wcy5pc0Rpc2FibGVkKSB7XG4gICAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZDtcbiAgfVxuICBpZiAocHJvcHMuaXNSZWFkT25seSkge1xuICAgIHJldHVybiBkZXNpZ25Ub2tlbnMuYmFja2dyb3VuZENvbG9yRm9ySW5wdXRXaGVuRGlzYWJsZWQ7XG4gIH1cbiAgcmV0dXJuIGRlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JJbnB1dDtcbn07XG5cbmNvbnN0IEVkaXRvckxhbmd1YWdlTGFiZWwgPSBzdHlsZWQubGFiZWw8VEVkaXRvckxhbmd1YWdlTGFiZWxQcm9wcz5gXG4gIC8qIGF2b2lkIHdyYXBwaW5nIGxhYmVsIG9udG8gbmV3IGxpbmVzICovXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG4gIGZsZXg6IDA7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5mb250Q29sb3JGb3JJbnB1dFdoZW5EaXNhYmxlZH07XG4gIGxpbmUtaGVpZ2h0OiBjYWxjKFxuICAgICR7ZGVzaWduVG9rZW5zLnNpemVIZWlnaHRJbnB1dH0gLSAyICogJHtkZXNpZ25Ub2tlbnMuYm9yZGVyUmFkaXVzMX1cbiAgKTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsocHJvcHMpID0+IGdldEJhY2tncm91bmRDb2xvcihwcm9wcyl9O1xuICBib3JkZXItdG9wLWxlZnQtcmFkaXVzOiAke2Rlc2lnblRva2Vucy5ib3JkZXJSYWRpdXNGb3JJbnB1dH07XG4gIGJvcmRlci1ib3R0b20tbGVmdC1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1c0ZvcklucHV0fTtcbiAgYm9yZGVyOiAkeyhwcm9wcykgPT4gZ2V0RWRpdG9yTGFuZ3VhZ2VMYWJlbEJvcmRlckNvbG9yKHByb3BzKX07XG4gIHBhZGRpbmc6ICR7ZGVzaWduVG9rZW5zLnBhZGRpbmdGb3JMb2NhbGl6ZWRSaWNoVGV4dElucHV0TGFiZWx9O1xuICB0cmFuc2l0aW9uOiBib3JkZXItY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfSxcbiAgICBiYWNrZ3JvdW5kLWNvbG9yICR7ZGVzaWduVG9rZW5zLnRyYW5zaXRpb25TdGFuZGFyZH0sXG4gICAgY29sb3IgJHtkZXNpZ25Ub2tlbnMudHJhbnNpdGlvblN0YW5kYXJkfTtcbiAgYm9yZGVyLXJpZ2h0OiAwO1xuICBib3gtc2hhZG93OiBub25lO1xuICBhcHBlYXJhbmNlOiBub25lO1xuICBkaXNwbGF5OiAkeyhwcm9wcykgPT4gcHJvcHMuaXNOZXdUaGVtZSAmJiAnZmxleCd9O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIC8qIGN1cnNvciBzaG91bGQgYmUgaW5oZXJpdGVkIGZyb20gcGFyZW50LFxuICAgICogR0lWRU4gcGFyZW50IGhhcyAnbm90LWFsbG93ZWQnIGN1cnNvclxuICAgICogVEhFTiB0aGUgbGFuZ3VhZ2UgbGFiZWwgc2hvdWxkIGFsc28gaGF2ZSB0aGF0IChpbnN0ZWFkIG9mIGxhYmVsJ3MgZGVmYXVsdCBjdXJzb3IpXG4gICAgKi9cbiAgY3Vyc29yOiBpbmhlcml0O1xuYDtcblxuY29uc3QgRWRpdG9yV3JhcHBlciA9IHN0eWxlZC5kaXY8XG4gIFBpY2s8VEVkaXRvclByb3BzLCAnaXNEaXNhYmxlZCcgfCAnaXNSZWFkT25seSc+XG4+YFxuICB3aWR0aDogMTAwJTtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBjdXJzb3I6ICR7KHByb3BzKSA9PlxuICAgIHByb3BzLmlzRGlzYWJsZWQgfHwgcHJvcHMuaXNSZWFkT25seSA/ICdub3QtYWxsb3dlZCcgOiAnaW5oZXJpdCd9O1xuYDtcblxuY29uc3QgVG9nZ2xlQnV0dG9uV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGZsZXg6IDA7XG4gIGRpc3BsYXk6IGZsZXg7XG5gO1xuXG5leHBvcnQgeyBFZGl0b3JMYW5ndWFnZUxhYmVsLCBFZGl0b3JXcmFwcGVyLCBUb2dnbGVCdXR0b25XcmFwcGVyIH07XG4iXX0= */"));
|
|
114
104
|
|
|
115
|
-
|
|
105
|
+
const ToggleButtonWrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
116
106
|
target: "ew063c0"
|
|
117
107
|
} : {
|
|
118
108
|
target: "ew063c0",
|
|
@@ -132,15 +122,15 @@ function ownKeys$3(object, enumerableOnly) { var keys = _Object$keys__default["d
|
|
|
132
122
|
function _objectSpread$3(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$3(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$3(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
133
123
|
|
|
134
124
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
135
|
-
|
|
125
|
+
const HOTKEYS = {
|
|
136
126
|
'mod+b': 'bold',
|
|
137
127
|
'mod+i': 'italic',
|
|
138
128
|
'mod+u': 'underline',
|
|
139
129
|
'mod+`': 'code'
|
|
140
130
|
};
|
|
141
|
-
|
|
131
|
+
const COLLAPSED_HEIGHT = 32;
|
|
142
132
|
|
|
143
|
-
|
|
133
|
+
const LeftColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
144
134
|
target: "el9zors2"
|
|
145
135
|
} : {
|
|
146
136
|
target: "el9zors2",
|
|
@@ -155,7 +145,7 @@ var LeftColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NOD
|
|
|
155
145
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
156
146
|
});
|
|
157
147
|
|
|
158
|
-
|
|
148
|
+
const RightColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
159
149
|
target: "el9zors1"
|
|
160
150
|
} : {
|
|
161
151
|
target: "el9zors1",
|
|
@@ -170,7 +160,7 @@ var RightColumn = /*#__PURE__*/_styled__default["default"]("div", process.env.NO
|
|
|
170
160
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
171
161
|
});
|
|
172
162
|
|
|
173
|
-
|
|
163
|
+
const Row = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
174
164
|
target: "el9zors0"
|
|
175
165
|
} : {
|
|
176
166
|
target: "el9zors0",
|
|
@@ -185,13 +175,9 @@ var Row = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV =
|
|
|
185
175
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
186
176
|
});
|
|
187
177
|
|
|
188
|
-
|
|
189
|
-
return jsxRuntime.jsx(richTextUtils.Element, _objectSpread$3({}, props));
|
|
190
|
-
};
|
|
178
|
+
const renderElement = props => jsxRuntime.jsx(richTextUtils.Element, _objectSpread$3({}, props));
|
|
191
179
|
|
|
192
|
-
|
|
193
|
-
return jsxRuntime.jsx(richTextUtils.Leaf, _objectSpread$3({}, props));
|
|
194
|
-
};
|
|
180
|
+
const renderLeaf = props => jsxRuntime.jsx(richTextUtils.Leaf, _objectSpread$3({}, props));
|
|
195
181
|
|
|
196
182
|
var _ref = process.env.NODE_ENV === "production" ? {
|
|
197
183
|
name: "bcltzc",
|
|
@@ -203,36 +189,34 @@ var _ref = process.env.NODE_ENV === "production" ? {
|
|
|
203
189
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
204
190
|
};
|
|
205
191
|
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
192
|
+
const Editor = /*#__PURE__*/react.forwardRef((props, forwardedRef) => {
|
|
193
|
+
const intl = reactIntl.useIntl();
|
|
194
|
+
const ref = react.useRef();
|
|
209
195
|
|
|
210
|
-
|
|
211
|
-
|
|
196
|
+
const _useTheme = designSystem.useTheme(),
|
|
197
|
+
isNewTheme = _useTheme.isNewTheme;
|
|
212
198
|
|
|
213
|
-
|
|
199
|
+
const createEditorWithPlugins = pipe__default["default"](slateReact.withReact, slateHistory.withHistory); // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
214
200
|
|
|
215
|
-
|
|
216
|
-
return createEditorWithPlugins(slate.createEditor());
|
|
217
|
-
}, []);
|
|
201
|
+
const editor = react.useMemo(() => createEditorWithPlugins(slate.createEditor()), []);
|
|
218
202
|
|
|
219
203
|
if (props.showExpandIcon) {
|
|
220
204
|
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.onClickExpand === 'function', 'Editor: "onClickExpand" is required when showExpandIcon is true') : void 0;
|
|
221
205
|
}
|
|
222
206
|
|
|
223
|
-
|
|
224
|
-
|
|
225
|
-
|
|
226
|
-
|
|
207
|
+
const _useState = react.useState(false),
|
|
208
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
209
|
+
renderToggleButton = _useState2[0],
|
|
210
|
+
setRenderToggleButton = _useState2[1];
|
|
227
211
|
|
|
228
|
-
|
|
229
|
-
|
|
212
|
+
const toggleLanguage = props.toggleLanguage;
|
|
213
|
+
const onToggle = react.useCallback(() => {
|
|
230
214
|
toggleLanguage(props.language);
|
|
231
215
|
}, [toggleLanguage, props.language]);
|
|
232
|
-
|
|
216
|
+
const updateRenderToggleButton = react.useCallback(() => {
|
|
233
217
|
var _ref$current;
|
|
234
218
|
|
|
235
|
-
|
|
219
|
+
const doesExceedCollapsedHeightLimit = Number((_ref$current = ref.current) === null || _ref$current === void 0 ? void 0 : _ref$current.clientHeight) > COLLAPSED_HEIGHT;
|
|
236
220
|
|
|
237
221
|
if (doesExceedCollapsedHeightLimit && !renderToggleButton) {
|
|
238
222
|
setRenderToggleButton(true);
|
|
@@ -242,14 +226,14 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
242
226
|
setRenderToggleButton(false);
|
|
243
227
|
}
|
|
244
228
|
}, [setRenderToggleButton, renderToggleButton]);
|
|
245
|
-
react.useEffect(
|
|
229
|
+
react.useEffect(() => {
|
|
246
230
|
updateRenderToggleButton();
|
|
247
231
|
}, [editor, updateRenderToggleButton]); // resetting
|
|
248
232
|
|
|
249
|
-
|
|
233
|
+
const resetValue = react.useCallback(newValue => {
|
|
250
234
|
var _newValue$props$langu;
|
|
251
235
|
|
|
252
|
-
|
|
236
|
+
const newStringValue = typeof newValue === 'string' ? newValue : (_newValue$props$langu = newValue === null || newValue === void 0 ? void 0 : newValue[props.language]) !== null && _newValue$props$langu !== void 0 ? _newValue$props$langu : '';
|
|
253
237
|
richTextUtils.resetEditor(editor, newStringValue);
|
|
254
238
|
}, [editor, props.language]);
|
|
255
239
|
/*
|
|
@@ -259,12 +243,12 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
259
243
|
e.g. <button onMouseDown={() => ref.current?.resetValue("<p><strong>Value after reset</strong></p>")}>Reset</button>
|
|
260
244
|
*/
|
|
261
245
|
|
|
262
|
-
react.useImperativeHandle(forwardedRef,
|
|
246
|
+
react.useImperativeHandle(forwardedRef, () => {
|
|
263
247
|
return {
|
|
264
|
-
resetValue
|
|
248
|
+
resetValue
|
|
265
249
|
};
|
|
266
250
|
});
|
|
267
|
-
|
|
251
|
+
const shouldToggleButtonTakeSpace =
|
|
268
252
|
/*
|
|
269
253
|
- if hasLanguagesControl and there are no errors/warnings to display
|
|
270
254
|
- then the toggleButton is absolutely positioned
|
|
@@ -279,14 +263,14 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
279
263
|
isClosed: !props.isOpen,
|
|
280
264
|
onToggle: onToggle,
|
|
281
265
|
isDefaultClosed: !props.defaultExpandMultilineText,
|
|
282
|
-
children:
|
|
283
|
-
|
|
266
|
+
children: _ref2 => {
|
|
267
|
+
let isOpen = _ref2.isOpen,
|
|
284
268
|
toggle = _ref2.toggle,
|
|
285
269
|
containerStyles = _ref2.containerStyles,
|
|
286
270
|
registerContentNode = _ref2.registerContentNode;
|
|
287
|
-
|
|
271
|
+
const refObj = {
|
|
288
272
|
containerRef: ref,
|
|
289
|
-
registerContentNode
|
|
273
|
+
registerContentNode
|
|
290
274
|
};
|
|
291
275
|
return jsxRuntime.jsxs(Stack__default["default"], {
|
|
292
276
|
scale: "xs",
|
|
@@ -326,7 +310,7 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
326
310
|
placeholder: props.placeholder,
|
|
327
311
|
autoFocus: props.isAutofocused,
|
|
328
312
|
onBlur: props.onBlur,
|
|
329
|
-
onFocus:
|
|
313
|
+
onFocus: event => {
|
|
330
314
|
var _props$onFocus;
|
|
331
315
|
|
|
332
316
|
(_props$onFocus = props.onFocus) === null || _props$onFocus === void 0 ? void 0 : _props$onFocus.call(props, event); // opens the input if it regains focus and it's closed
|
|
@@ -338,11 +322,11 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
338
322
|
},
|
|
339
323
|
readOnly: props.isReadOnly,
|
|
340
324
|
disabled: props.isDisabled,
|
|
341
|
-
onKeyDown:
|
|
342
|
-
for (
|
|
325
|
+
onKeyDown: event => {
|
|
326
|
+
for (const hotkey in HOTKEYS) {
|
|
343
327
|
if (isHotkey__default["default"](hotkey, event)) {
|
|
344
328
|
event.preventDefault();
|
|
345
|
-
|
|
329
|
+
const mark = HOTKEYS[hotkey];
|
|
346
330
|
richTextUtils.toggleMark(editor, mark);
|
|
347
331
|
break;
|
|
348
332
|
}
|
|
@@ -350,7 +334,7 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
350
334
|
}
|
|
351
335
|
})), props.children, jsxRuntime.jsx(richTextUtils.HiddenInput, {
|
|
352
336
|
isFocused: slateReact.ReactEditor.isFocused(editor),
|
|
353
|
-
handleFocus:
|
|
337
|
+
handleFocus: () => {
|
|
354
338
|
richTextUtils.focusEditor(editor);
|
|
355
339
|
},
|
|
356
340
|
id: props.id,
|
|
@@ -368,7 +352,7 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
368
352
|
// TODO: revisit the logic and the implementation to maybe avoid having to apply this style.
|
|
369
353
|
, {
|
|
370
354
|
css: /*#__PURE__*/react$1.css("margin-top:", shouldToggleButtonTakeSpace ? 'inherit' : '0px !important', ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AA4SsB","file":"editor.tsx","sourcesContent":["//TODO: @redesign cleanup\nimport {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  useMemo,\n  useImperativeHandle,\n  forwardRef,\n  type ReactNode,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n  type FocusEventHandler,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { warning, filterDataAttributes } from '@commercetools-uikit/utils';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n  Element,\n  Leaf,\n  toggleMark,\n  resetEditor,\n  focusEditor,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  Editable,\n  withReact,\n  Slate,\n  ReactEditor,\n  type RenderElementProps,\n  type RenderLeafProps,\n} from 'slate-react';\nimport { createEditor, type Descendant } from 'slate';\nimport { withHistory } from 'slate-history';\nimport isHotkey from 'is-hotkey';\nimport pipe from 'lodash/fp/pipe';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst HOTKEYS = {\n  'mod+b': 'bold',\n  'mod+i': 'italic',\n  'mod+u': 'underline',\n  'mod+`': 'code',\n};\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nexport type TEditorProps = {\n  children?: ReactNode;\n  name?: string;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n  value: Descendant[];\n  onChange: (state: Descendant[]) => void;\n  onFocus?: FocusEventHandler<HTMLDivElement>;\n  onBlur?: FocusEventHandler<HTMLDivElement>;\n  isAutofocused?: boolean;\n  placeholder?: string;\n  ref?: Ref<unknown>;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst renderElement = (props: RenderElementProps) => <Element {...props} />;\nconst renderLeaf = (props: RenderLeafProps) => <Leaf {...props} />;\n\nconst Editor = forwardRef((props: TEditorProps, forwardedRef) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const { isNewTheme } = useTheme();\n\n  const createEditorWithPlugins = pipe(withReact, withHistory);\n  // eslint-disable-next-line react-hooks/exhaustive-deps\n  const editor = useMemo(() => createEditorWithPlugins(createEditor()), []);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [editor, updateRenderToggleButton]);\n\n  // resetting\n  const resetValue = useCallback(\n    (newValue: string | Record<string, string>) => {\n      const newStringValue =\n        typeof newValue === 'string'\n          ? newValue\n          : newValue?.[props.language] ?? '';\n\n      resetEditor(editor, newStringValue);\n    },\n    [editor, props.language]\n  );\n  /*\n  Resetting the editor requires access to `editor` object returned from `useSlate` hook.\n  Therefore, `reset` function is attached to the passed `ref` object via `useImperativeHandle`\n  to be called from the parent component.\n  e.g. <button onMouseDown={() => ref.current?.resetValue(\"<p><strong>Value after reset</strong></p>\")}>Reset</button>\n  */\n  useImperativeHandle(forwardedRef, () => {\n    return {\n      resetValue,\n    };\n  });\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n\n    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <Slate\n                editor={editor}\n                value={props.value}\n                onChange={props.onChange}\n              >\n                <EditorLanguageLabel\n                  htmlFor={props.id}\n                  isDisabled={props.isDisabled}\n                  isReadOnly={props.isReadOnly}\n                  isNewTheme={isNewTheme}\n                >\n                  {/* FIXME: add proper tone for disabled when tones are refactored */}\n                  <Text.Detail tone=\"secondary\">\n                    {props.language.toUpperCase()}\n                  </Text.Detail>\n                </EditorLanguageLabel>\n                <RichTextBody\n                  // @ts-ignore\n                  ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                  styles={{\n                    container: css`\n                      flex: auto;\n                      width: 0;\n                      border-top-left-radius: 0;\n                      border-bottom-left-radius: 0;\n                    `,\n                  }}\n                  hasError={props.hasError}\n                  isDisabled={props.isDisabled}\n                  hasWarning={props.hasWarning}\n                  isReadOnly={Boolean(props.isReadOnly)}\n                  showExpandIcon={Boolean(props.showExpandIcon)}\n                  onClickExpand={props.onClickExpand}\n                  containerStyles={containerStyles}\n                >\n                  <Editable\n                    {...filterDataAttributes(props)}\n                    name={props.name}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    placeholder={props.placeholder}\n                    autoFocus={props.isAutofocused}\n                    onBlur={props.onBlur}\n                    onFocus={(event) => {\n                      props.onFocus?.(event);\n                      // opens the input if it regains focus and it's closed\n                      if (!isOpen) {\n                        toggle();\n                        focusEditor(editor);\n                      }\n                    }}\n                    readOnly={props.isReadOnly}\n                    disabled={props.isDisabled}\n                    onKeyDown={(event) => {\n                      for (const hotkey in HOTKEYS) {\n                        if (isHotkey(hotkey, event)) {\n                          event.preventDefault();\n                          const mark = HOTKEYS[hotkey as keyof typeof HOTKEYS];\n                          toggleMark(editor, mark);\n                          break;\n                        }\n                      }\n                    }}\n                  />\n                  {props.children}\n                  <HiddenInput\n                    isFocused={ReactEditor.isFocused(editor)}\n                    handleFocus={() => {\n                      focusEditor(editor);\n                    }}\n                    id={props.id}\n                    disabled={props.isDisabled}\n                    readOnly={props.isReadOnly}\n                  />\n                </RichTextBody>\n              </Slate>\n            </EditorWrapper>\n            <Row\n              // NOTE: applying this style withing the `styled` component results in the production\n              // bundle to apply the style in the wrong order.\n              // For instance, we need to override the marging of the spacing component, which also\n              // uses `!important`.\n              // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n              // does the trick.\n              // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n              css={css`\n                margin-top: ${shouldToggleButtonTakeSpace\n                  ? 'inherit'\n                  : '0px !important'};\n              `}\n            >\n              {(() => {\n                if (props.error)\n                  return (\n                    <LeftColumn>\n                      <div>{props.error}</div>\n                    </LeftColumn>\n                  );\n                if (props.warning)\n                  return (\n                    <LeftColumn>\n                      <div>{props.warning}</div>\n                    </LeftColumn>\n                  );\n                return null;\n              })()}\n              {renderToggleButton && (\n                <RightColumn>\n                  <ToggleButtonWrapper\n                    css={[\n                      !shouldToggleButtonTakeSpace &&\n                        css`\n                          position: absolute;\n                          top: 0;\n                          right: 0;\n                          margin-top: ${designTokens.spacing10};\n                        `,\n                    ]}\n                  >\n                    <FlatButton\n                      onClick={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n});\nEditor.displayName = 'Editor';\n\nexport default Editor;\n"]} */"),
|
|
371
|
-
children: [
|
|
355
|
+
children: [(() => {
|
|
372
356
|
if (props.error) return jsxRuntime.jsx(LeftColumn, {
|
|
373
357
|
children: jsxRuntime.jsx("div", {
|
|
374
358
|
children: props.error
|
|
@@ -380,7 +364,7 @@ var Editor = /*#__PURE__*/react.forwardRef(function (props, forwardedRef) {
|
|
|
380
364
|
})
|
|
381
365
|
});
|
|
382
366
|
return null;
|
|
383
|
-
}(), renderToggleButton && jsxRuntime.jsx(RightColumn, {
|
|
367
|
+
})(), renderToggleButton && jsxRuntime.jsx(RightColumn, {
|
|
384
368
|
children: jsxRuntime.jsx(ToggleButtonWrapper, {
|
|
385
369
|
css: [!shouldToggleButtonTakeSpace && /*#__PURE__*/react$1.css("position:absolute;top:0;right:0;margin-top:", designSystem.designTokens.spacing10, ";" + (process.env.NODE_ENV === "production" ? "" : ";label:Editor;"), process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAsU2B","file":"editor.tsx","sourcesContent":["//TODO: @redesign cleanup\nimport {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  useMemo,\n  useImperativeHandle,\n  forwardRef,\n  type ReactNode,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n  type FocusEventHandler,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { warning, filterDataAttributes } from '@commercetools-uikit/utils';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n  Element,\n  Leaf,\n  toggleMark,\n  resetEditor,\n  focusEditor,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  Editable,\n  withReact,\n  Slate,\n  ReactEditor,\n  type RenderElementProps,\n  type RenderLeafProps,\n} from 'slate-react';\nimport { createEditor, type Descendant } from 'slate';\nimport { withHistory } from 'slate-history';\nimport isHotkey from 'is-hotkey';\nimport pipe from 'lodash/fp/pipe';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst HOTKEYS = {\n  'mod+b': 'bold',\n  'mod+i': 'italic',\n  'mod+u': 'underline',\n  'mod+`': 'code',\n};\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nexport type TEditorProps = {\n  children?: ReactNode;\n  name?: string;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n  value: Descendant[];\n  onChange: (state: Descendant[]) => void;\n  onFocus?: FocusEventHandler<HTMLDivElement>;\n  onBlur?: FocusEventHandler<HTMLDivElement>;\n  isAutofocused?: boolean;\n  placeholder?: string;\n  ref?: Ref<unknown>;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst renderElement = (props: RenderElementProps) => <Element {...props} />;\nconst renderLeaf = (props: RenderLeafProps) => <Leaf {...props} />;\n\nconst Editor = forwardRef((props: TEditorProps, forwardedRef) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const { isNewTheme } = useTheme();\n\n  const createEditorWithPlugins = pipe(withReact, withHistory);\n  // eslint-disable-next-line react-hooks/exhaustive-deps\n  const editor = useMemo(() => createEditorWithPlugins(createEditor()), []);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [editor, updateRenderToggleButton]);\n\n  // resetting\n  const resetValue = useCallback(\n    (newValue: string | Record<string, string>) => {\n      const newStringValue =\n        typeof newValue === 'string'\n          ? newValue\n          : newValue?.[props.language] ?? '';\n\n      resetEditor(editor, newStringValue);\n    },\n    [editor, props.language]\n  );\n  /*\n  Resetting the editor requires access to `editor` object returned from `useSlate` hook.\n  Therefore, `reset` function is attached to the passed `ref` object via `useImperativeHandle`\n  to be called from the parent component.\n  e.g. <button onMouseDown={() => ref.current?.resetValue(\"<p><strong>Value after reset</strong></p>\")}>Reset</button>\n  */\n  useImperativeHandle(forwardedRef, () => {\n    return {\n      resetValue,\n    };\n  });\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n\n    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <Slate\n                editor={editor}\n                value={props.value}\n                onChange={props.onChange}\n              >\n                <EditorLanguageLabel\n                  htmlFor={props.id}\n                  isDisabled={props.isDisabled}\n                  isReadOnly={props.isReadOnly}\n                  isNewTheme={isNewTheme}\n                >\n                  {/* FIXME: add proper tone for disabled when tones are refactored */}\n                  <Text.Detail tone=\"secondary\">\n                    {props.language.toUpperCase()}\n                  </Text.Detail>\n                </EditorLanguageLabel>\n                <RichTextBody\n                  // @ts-ignore\n                  ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                  styles={{\n                    container: css`\n                      flex: auto;\n                      width: 0;\n                      border-top-left-radius: 0;\n                      border-bottom-left-radius: 0;\n                    `,\n                  }}\n                  hasError={props.hasError}\n                  isDisabled={props.isDisabled}\n                  hasWarning={props.hasWarning}\n                  isReadOnly={Boolean(props.isReadOnly)}\n                  showExpandIcon={Boolean(props.showExpandIcon)}\n                  onClickExpand={props.onClickExpand}\n                  containerStyles={containerStyles}\n                >\n                  <Editable\n                    {...filterDataAttributes(props)}\n                    name={props.name}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    placeholder={props.placeholder}\n                    autoFocus={props.isAutofocused}\n                    onBlur={props.onBlur}\n                    onFocus={(event) => {\n                      props.onFocus?.(event);\n                      // opens the input if it regains focus and it's closed\n                      if (!isOpen) {\n                        toggle();\n                        focusEditor(editor);\n                      }\n                    }}\n                    readOnly={props.isReadOnly}\n                    disabled={props.isDisabled}\n                    onKeyDown={(event) => {\n                      for (const hotkey in HOTKEYS) {\n                        if (isHotkey(hotkey, event)) {\n                          event.preventDefault();\n                          const mark = HOTKEYS[hotkey as keyof typeof HOTKEYS];\n                          toggleMark(editor, mark);\n                          break;\n                        }\n                      }\n                    }}\n                  />\n                  {props.children}\n                  <HiddenInput\n                    isFocused={ReactEditor.isFocused(editor)}\n                    handleFocus={() => {\n                      focusEditor(editor);\n                    }}\n                    id={props.id}\n                    disabled={props.isDisabled}\n                    readOnly={props.isReadOnly}\n                  />\n                </RichTextBody>\n              </Slate>\n            </EditorWrapper>\n            <Row\n              // NOTE: applying this style withing the `styled` component results in the production\n              // bundle to apply the style in the wrong order.\n              // For instance, we need to override the marging of the spacing component, which also\n              // uses `!important`.\n              // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n              // does the trick.\n              // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n              css={css`\n                margin-top: ${shouldToggleButtonTakeSpace\n                  ? 'inherit'\n                  : '0px !important'};\n              `}\n            >\n              {(() => {\n                if (props.error)\n                  return (\n                    <LeftColumn>\n                      <div>{props.error}</div>\n                    </LeftColumn>\n                  );\n                if (props.warning)\n                  return (\n                    <LeftColumn>\n                      <div>{props.warning}</div>\n                    </LeftColumn>\n                  );\n                return null;\n              })()}\n              {renderToggleButton && (\n                <RightColumn>\n                  <ToggleButtonWrapper\n                    css={[\n                      !shouldToggleButtonTakeSpace &&\n                        css`\n                          position: absolute;\n                          top: 0;\n                          right: 0;\n                          margin-top: ${designTokens.spacing10};\n                        `,\n                    ]}\n                  >\n                    <FlatButton\n                      onClick={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n});\nEditor.displayName = 'Editor';\n\nexport default Editor;\n"]} */"), process.env.NODE_ENV === "production" ? "" : ";label:Editor;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["editor.tsx"],"names":[],"mappings":"AAoUoB","file":"editor.tsx","sourcesContent":["//TODO: @redesign cleanup\nimport {\n  useRef,\n  useState,\n  useCallback,\n  useEffect,\n  useMemo,\n  useImperativeHandle,\n  forwardRef,\n  type ReactNode,\n  type LegacyRef,\n  type RefObject,\n  type Ref,\n  type FocusEventHandler,\n} from 'react';\nimport { css } from '@emotion/react';\nimport styled from '@emotion/styled';\nimport { useIntl } from 'react-intl';\nimport { designTokens, useTheme } from '@commercetools-uikit/design-system';\nimport { warning, filterDataAttributes } from '@commercetools-uikit/utils';\nimport CollapsibleMotion from '@commercetools-uikit/collapsible-motion';\nimport Stack from '@commercetools-uikit/spacings-stack';\nimport { AngleUpIcon, AngleDownIcon } from '@commercetools-uikit/icons';\nimport Text from '@commercetools-uikit/text';\nimport FlatButton from '@commercetools-uikit/flat-button';\nimport { messagesMultilineInput } from '@commercetools-uikit/input-utils';\nimport {\n  RichTextBody,\n  HiddenInput,\n  Element,\n  Leaf,\n  toggleMark,\n  resetEditor,\n  focusEditor,\n} from '@commercetools-uikit/rich-text-utils';\nimport {\n  Editable,\n  withReact,\n  Slate,\n  ReactEditor,\n  type RenderElementProps,\n  type RenderLeafProps,\n} from 'slate-react';\nimport { createEditor, type Descendant } from 'slate';\nimport { withHistory } from 'slate-history';\nimport isHotkey from 'is-hotkey';\nimport pipe from 'lodash/fp/pipe';\nimport {\n  EditorWrapper,\n  EditorLanguageLabel,\n  ToggleButtonWrapper,\n} from './editor.styles';\n\nconst HOTKEYS = {\n  'mod+b': 'bold',\n  'mod+i': 'italic',\n  'mod+u': 'underline',\n  'mod+`': 'code',\n};\n\nconst COLLAPSED_HEIGHT = 32;\n\nconst LeftColumn = styled.div`\n  flex: 1;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst RightColumn = styled.div`\n  position: relative;\n  flex: 0;\n  display: flex;\n  align-items: flex-start;\n`;\n\nconst Row = styled.div`\n  display: flex;\n  justify-content: flex-end;\n`;\n\nexport type TEditorProps = {\n  children?: ReactNode;\n  name?: string;\n  id?: string;\n  isOpen: boolean;\n  isDisabled?: boolean;\n  isReadOnly?: boolean;\n  hasWarning?: boolean;\n  hasError?: boolean;\n  error?: ReactNode;\n  warning?: ReactNode;\n  defaultExpandMultilineText: boolean;\n  toggleLanguage: (language: string) => void;\n  language: string;\n  showExpandIcon: boolean;\n  onClickExpand?: () => boolean;\n  hasLanguagesControl?: boolean;\n  value: Descendant[];\n  onChange: (state: Descendant[]) => void;\n  onFocus?: FocusEventHandler<HTMLDivElement>;\n  onBlur?: FocusEventHandler<HTMLDivElement>;\n  isAutofocused?: boolean;\n  placeholder?: string;\n  ref?: Ref<unknown>;\n};\n\ntype TNodeRefObject = {\n  clientHeight: number;\n} & LegacyRef<HTMLDivElement>;\n\ntype TRichTextEditorBodyRef = {\n  registerContentNode: TNodeRefObject;\n  containerRef: RefObject<HTMLDivElement>;\n};\n\nconst renderElement = (props: RenderElementProps) => <Element {...props} />;\nconst renderLeaf = (props: RenderLeafProps) => <Leaf {...props} />;\n\nconst Editor = forwardRef((props: TEditorProps, forwardedRef) => {\n  const intl = useIntl();\n  const ref = useRef<HTMLDivElement>();\n  const { isNewTheme } = useTheme();\n\n  const createEditorWithPlugins = pipe(withReact, withHistory);\n  // eslint-disable-next-line react-hooks/exhaustive-deps\n  const editor = useMemo(() => createEditorWithPlugins(createEditor()), []);\n\n  if (props.showExpandIcon) {\n    warning(\n      typeof props.onClickExpand === 'function',\n      'Editor: \"onClickExpand\" is required when showExpandIcon is true'\n    );\n  }\n\n  const [renderToggleButton, setRenderToggleButton] = useState(false);\n\n  const { toggleLanguage } = props;\n  const onToggle = useCallback(() => {\n    toggleLanguage(props.language);\n  }, [toggleLanguage, props.language]);\n\n  const updateRenderToggleButton = useCallback(() => {\n    const doesExceedCollapsedHeightLimit =\n      Number(ref.current?.clientHeight) > COLLAPSED_HEIGHT;\n\n    if (doesExceedCollapsedHeightLimit && !renderToggleButton) {\n      setRenderToggleButton(true);\n    }\n    if (!doesExceedCollapsedHeightLimit && renderToggleButton) {\n      setRenderToggleButton(false);\n    }\n  }, [setRenderToggleButton, renderToggleButton]);\n\n  useEffect(() => {\n    updateRenderToggleButton();\n  }, [editor, updateRenderToggleButton]);\n\n  // resetting\n  const resetValue = useCallback(\n    (newValue: string | Record<string, string>) => {\n      const newStringValue =\n        typeof newValue === 'string'\n          ? newValue\n          : newValue?.[props.language] ?? '';\n\n      resetEditor(editor, newStringValue);\n    },\n    [editor, props.language]\n  );\n  /*\n  Resetting the editor requires access to `editor` object returned from `useSlate` hook.\n  Therefore, `reset` function is attached to the passed `ref` object via `useImperativeHandle`\n  to be called from the parent component.\n  e.g. <button onMouseDown={() => ref.current?.resetValue(\"<p><strong>Value after reset</strong></p>\")}>Reset</button>\n  */\n  useImperativeHandle(forwardedRef, () => {\n    return {\n      resetValue,\n    };\n  });\n\n  const shouldToggleButtonTakeSpace =\n    /*\n      - if hasLanguagesControl and there are no errors/warnings to display\n      - then the toggleButton is absolutely positioned\n      This is because the toggle button is placed next to the LocalizedInputToggle without being siblings in the DOM.\n      If there is a error or warning showing,\n      then it can be placed statically because it will then be a sibling to the error/warning message\n      and LocalizedInputToggle is placed below the errors/warnings.\n    */\n\n    (renderToggleButton && !props.hasLanguagesControl) ||\n    props.error ||\n    props.warning;\n\n  return (\n    <CollapsibleMotion\n      minHeight={COLLAPSED_HEIGHT}\n      isClosed={!props.isOpen}\n      onToggle={onToggle}\n      isDefaultClosed={!props.defaultExpandMultilineText}\n    >\n      {({ isOpen, toggle, containerStyles, registerContentNode }) => {\n        const refObj = {\n          containerRef: ref,\n          registerContentNode,\n        };\n\n        return (\n          <Stack scale=\"xs\">\n            <EditorWrapper\n              key={props.language}\n              isDisabled={props.isDisabled}\n              isReadOnly={props.isReadOnly}\n            >\n              <Slate\n                editor={editor}\n                value={props.value}\n                onChange={props.onChange}\n              >\n                <EditorLanguageLabel\n                  htmlFor={props.id}\n                  isDisabled={props.isDisabled}\n                  isReadOnly={props.isReadOnly}\n                  isNewTheme={isNewTheme}\n                >\n                  {/* FIXME: add proper tone for disabled when tones are refactored */}\n                  <Text.Detail tone=\"secondary\">\n                    {props.language.toUpperCase()}\n                  </Text.Detail>\n                </EditorLanguageLabel>\n                <RichTextBody\n                  // @ts-ignore\n                  ref={refObj as unknown as Ref<TRichTextEditorBodyRef>}\n                  styles={{\n                    container: css`\n                      flex: auto;\n                      width: 0;\n                      border-top-left-radius: 0;\n                      border-bottom-left-radius: 0;\n                    `,\n                  }}\n                  hasError={props.hasError}\n                  isDisabled={props.isDisabled}\n                  hasWarning={props.hasWarning}\n                  isReadOnly={Boolean(props.isReadOnly)}\n                  showExpandIcon={Boolean(props.showExpandIcon)}\n                  onClickExpand={props.onClickExpand}\n                  containerStyles={containerStyles}\n                >\n                  <Editable\n                    {...filterDataAttributes(props)}\n                    name={props.name}\n                    renderElement={renderElement}\n                    renderLeaf={renderLeaf}\n                    placeholder={props.placeholder}\n                    autoFocus={props.isAutofocused}\n                    onBlur={props.onBlur}\n                    onFocus={(event) => {\n                      props.onFocus?.(event);\n                      // opens the input if it regains focus and it's closed\n                      if (!isOpen) {\n                        toggle();\n                        focusEditor(editor);\n                      }\n                    }}\n                    readOnly={props.isReadOnly}\n                    disabled={props.isDisabled}\n                    onKeyDown={(event) => {\n                      for (const hotkey in HOTKEYS) {\n                        if (isHotkey(hotkey, event)) {\n                          event.preventDefault();\n                          const mark = HOTKEYS[hotkey as keyof typeof HOTKEYS];\n                          toggleMark(editor, mark);\n                          break;\n                        }\n                      }\n                    }}\n                  />\n                  {props.children}\n                  <HiddenInput\n                    isFocused={ReactEditor.isFocused(editor)}\n                    handleFocus={() => {\n                      focusEditor(editor);\n                    }}\n                    id={props.id}\n                    disabled={props.isDisabled}\n                    readOnly={props.isReadOnly}\n                  />\n                </RichTextBody>\n              </Slate>\n            </EditorWrapper>\n            <Row\n              // NOTE: applying this style withing the `styled` component results in the production\n              // bundle to apply the style in the wrong order.\n              // For instance, we need to override the marging of the spacing component, which also\n              // uses `!important`.\n              // Anyway, apparently by passing the style as a `css` prop to the `styled` component\n              // does the trick.\n              // TODO: revisit the logic and the implementation to maybe avoid having to apply this style.\n              css={css`\n                margin-top: ${shouldToggleButtonTakeSpace\n                  ? 'inherit'\n                  : '0px !important'};\n              `}\n            >\n              {(() => {\n                if (props.error)\n                  return (\n                    <LeftColumn>\n                      <div>{props.error}</div>\n                    </LeftColumn>\n                  );\n                if (props.warning)\n                  return (\n                    <LeftColumn>\n                      <div>{props.warning}</div>\n                    </LeftColumn>\n                  );\n                return null;\n              })()}\n              {renderToggleButton && (\n                <RightColumn>\n                  <ToggleButtonWrapper\n                    css={[\n                      !shouldToggleButtonTakeSpace &&\n                        css`\n                          position: absolute;\n                          top: 0;\n                          right: 0;\n                          margin-top: ${designTokens.spacing10};\n                        `,\n                    ]}\n                  >\n                    <FlatButton\n                      onClick={toggle}\n                      label={intl.formatMessage(\n                        isOpen\n                          ? messagesMultilineInput.collapse\n                          : messagesMultilineInput.expand\n                      )}\n                      icon={\n                        isOpen ? (\n                          <AngleUpIcon size=\"small\" />\n                        ) : (\n                          <AngleDownIcon size=\"small\" />\n                        )\n                      }\n                    />\n                  </ToggleButtonWrapper>\n                </RightColumn>\n              )}\n            </Row>\n          </Stack>\n        );\n      }}\n    </CollapsibleMotion>\n  );\n});\nEditor.displayName = 'Editor';\n\nexport default Editor;\n"]} */"],
|
|
386
370
|
children: jsxRuntime.jsx(FlatButton__default["default"], {
|
|
@@ -404,20 +388,18 @@ var Editor$1 = Editor;
|
|
|
404
388
|
|
|
405
389
|
function ownKeys$2(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
406
390
|
|
|
407
|
-
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var
|
|
391
|
+
function _objectSpread$2(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$2(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$2(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
408
392
|
|
|
409
393
|
function _createSuper(Derived) { var hasNativeReflectConstruct = _isNativeReflectConstruct(); return function _createSuperInternal() { var Super = _getPrototypeOf(Derived), result; if (hasNativeReflectConstruct) { var NewTarget = _getPrototypeOf(this).constructor; result = _Reflect$construct__default["default"](Super, arguments, NewTarget); } else { result = Super.apply(this, arguments); } return _possibleConstructorReturn(this, result); }; }
|
|
410
394
|
|
|
411
395
|
function _isNativeReflectConstruct() { if (typeof Reflect === "undefined" || !_Reflect$construct__default["default"]) return false; if (_Reflect$construct__default["default"].sham) return false; if (typeof Proxy === "function") return true; try { Boolean.prototype.valueOf.call(_Reflect$construct__default["default"](Boolean, [], function () {})); return true; } catch (e) { return false; } }
|
|
412
396
|
|
|
413
|
-
|
|
397
|
+
let RichTextInput = /*#__PURE__*/function (_PureComponent) {
|
|
414
398
|
_inherits(RichTextInput, _PureComponent);
|
|
415
399
|
|
|
416
400
|
var _super = _createSuper(RichTextInput);
|
|
417
401
|
|
|
418
402
|
function RichTextInput() {
|
|
419
|
-
var _context;
|
|
420
|
-
|
|
421
403
|
var _this;
|
|
422
404
|
|
|
423
405
|
_classCallCheck(this, RichTextInput);
|
|
@@ -426,19 +408,19 @@ var RichTextInput = /*#__PURE__*/function (_PureComponent) {
|
|
|
426
408
|
args[_key] = arguments[_key];
|
|
427
409
|
}
|
|
428
410
|
|
|
429
|
-
_this = _super.call
|
|
411
|
+
_this = _super.call(this, ...args);
|
|
430
412
|
_this.serializedValue = _this.props.value || '';
|
|
431
413
|
_this.internalSlateValue = richTextUtils.validSlateStateAdapter(richTextUtils.html.deserialize(_this.props.value || ''));
|
|
432
414
|
|
|
433
|
-
_this.onValueChange =
|
|
434
|
-
|
|
415
|
+
_this.onValueChange = state => {
|
|
416
|
+
const serializedValue = richTextUtils.html.serialize(state); // because we are not using setState, we need to make sure that
|
|
435
417
|
// we perform an update when the slate value changes
|
|
436
418
|
// as this can contain things like cursor location
|
|
437
419
|
// in this case, the internalSlateValue would change
|
|
438
420
|
// but the serializedValue would NOT change.
|
|
439
421
|
|
|
440
|
-
|
|
441
|
-
|
|
422
|
+
const hasInternalSlateValueChanged = _this.internalSlateValue !== state;
|
|
423
|
+
const hasSerializedValueChanged = serializedValue !== _this.serializedValue;
|
|
442
424
|
_this.internalSlateValue = richTextUtils.validSlateStateAdapter(state);
|
|
443
425
|
_this.serializedValue = serializedValue; // the consumer only cares about the serializedValue, so it doesn't make sense to call
|
|
444
426
|
// onChange unless this value changes.
|
|
@@ -523,11 +505,9 @@ RichTextInput.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
|
523
505
|
warning: _pt__default["default"].node,
|
|
524
506
|
error: _pt__default["default"].string
|
|
525
507
|
} : {};
|
|
526
|
-
|
|
527
|
-
|
|
528
|
-
|
|
529
|
-
}, props));
|
|
530
|
-
});
|
|
508
|
+
const RichTextInputWithRef = /*#__PURE__*/react.forwardRef((props, ref) => jsxRuntime.jsx(RichTextInput, _objectSpread$2({
|
|
509
|
+
parentRef: ref
|
|
510
|
+
}, props)));
|
|
531
511
|
RichTextInputWithRef.displayName = 'RichTextInputWithRef';
|
|
532
512
|
var RichTextInput$1 = RichTextInputWithRef;
|
|
533
513
|
|
|
@@ -535,11 +515,9 @@ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["d
|
|
|
535
515
|
|
|
536
516
|
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
537
517
|
|
|
538
|
-
|
|
539
|
-
|
|
540
|
-
|
|
541
|
-
});
|
|
542
|
-
};
|
|
518
|
+
const RequiredValueErrorMessage = () => jsxRuntime.jsx(messages.ErrorMessage, {
|
|
519
|
+
children: jsxRuntime.jsx(reactIntl.FormattedMessage, _objectSpread$1({}, inputUtils.messagesLocalizedInput.missingRequiredField))
|
|
520
|
+
});
|
|
543
521
|
|
|
544
522
|
RequiredValueErrorMessage.displayName = 'RequiredValueErrorMessage';
|
|
545
523
|
var RequiredValueErrorMessage$1 = RequiredValueErrorMessage;
|
|
@@ -547,22 +525,26 @@ var RequiredValueErrorMessage$1 = RequiredValueErrorMessage;
|
|
|
547
525
|
function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
548
526
|
|
|
549
527
|
function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var _context6, _context7; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context6 = ownKeys(Object(source), !0)).call(_context6, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context7 = ownKeys(Object(source))).call(_context7, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
550
|
-
|
|
528
|
+
const defaultProps = {
|
|
551
529
|
horizontalConstraint: 'scale',
|
|
552
530
|
showExpandIcon: false
|
|
553
531
|
};
|
|
554
532
|
|
|
555
|
-
|
|
533
|
+
const expandedTranslationsReducer = (state, action) => {
|
|
556
534
|
switch (action.type) {
|
|
557
535
|
case 'toggle':
|
|
558
|
-
return _objectSpread(_objectSpread({}, state), {},
|
|
536
|
+
return _objectSpread(_objectSpread({}, state), {}, {
|
|
537
|
+
[action.payload]: !state[action.payload]
|
|
538
|
+
});
|
|
559
539
|
|
|
560
540
|
case 'toggleAll':
|
|
561
541
|
{
|
|
562
542
|
var _context;
|
|
563
543
|
|
|
564
|
-
|
|
565
|
-
return _objectSpread(
|
|
544
|
+
const newState = _reduceInstanceProperty__default["default"](_context = _Object$keys__default["default"](state)).call(_context, (translations, locale) => {
|
|
545
|
+
return _objectSpread({
|
|
546
|
+
[locale]: true
|
|
547
|
+
}, translations);
|
|
566
548
|
}, {});
|
|
567
549
|
|
|
568
550
|
return newState;
|
|
@@ -579,7 +561,7 @@ var expandedTranslationsReducer = function expandedTranslationsReducer(state, ac
|
|
|
579
561
|
// languages.
|
|
580
562
|
|
|
581
563
|
|
|
582
|
-
|
|
564
|
+
const LocalizedRichTextInput = /*#__PURE__*/react.forwardRef((props, ref) => {
|
|
583
565
|
var _context2;
|
|
584
566
|
|
|
585
567
|
if (!props.isReadOnly) {
|
|
@@ -594,46 +576,44 @@ var LocalizedRichTextInput = /*#__PURE__*/react.forwardRef(function (props, ref)
|
|
|
594
576
|
process.env.NODE_ENV !== "production" ? utils.warning(typeof props.defaultExpandLanguages !== 'boolean', 'LocalizedRichTextInput: "defaultExpandLanguages" does not have any effect when "hideLanguageExpansionControls" is set.') : void 0;
|
|
595
577
|
}
|
|
596
578
|
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
}, {});
|
|
579
|
+
const initialExpandedTranslationsState = _reduceInstanceProperty__default["default"](_context2 = _Object$keys__default["default"](props.value)).call(_context2, (translations, locale) => _objectSpread(_objectSpread({}, translations), {}, {
|
|
580
|
+
[locale]: Boolean(props.defaultExpandMultilineText)
|
|
581
|
+
}), {});
|
|
600
582
|
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
583
|
+
const _useReducer = react.useReducer(expandedTranslationsReducer, initialExpandedTranslationsState),
|
|
584
|
+
_useReducer2 = _slicedToArray(_useReducer, 2),
|
|
585
|
+
expandedTranslationsState = _useReducer2[0],
|
|
586
|
+
expandedTranslationsDispatch = _useReducer2[1];
|
|
605
587
|
|
|
606
|
-
|
|
588
|
+
const defaultExpansionState = Boolean(props.hideLanguageExpansionControls || props.defaultExpandLanguages);
|
|
607
589
|
|
|
608
|
-
|
|
609
|
-
|
|
610
|
-
|
|
611
|
-
|
|
590
|
+
const _useToggleState = hooks.useToggleState(defaultExpansionState),
|
|
591
|
+
_useToggleState2 = _slicedToArray(_useToggleState, 2),
|
|
592
|
+
areLanguagesOpened = _useToggleState2[0],
|
|
593
|
+
toggleLanguages = _useToggleState2[1];
|
|
612
594
|
|
|
613
|
-
|
|
595
|
+
const toggleLanguage = react.useCallback(language => {
|
|
614
596
|
expandedTranslationsDispatch({
|
|
615
597
|
type: 'toggle',
|
|
616
598
|
payload: language
|
|
617
599
|
});
|
|
618
600
|
}, [expandedTranslationsDispatch]);
|
|
619
|
-
|
|
620
|
-
|
|
621
|
-
|
|
622
|
-
|
|
623
|
-
|
|
624
|
-
|
|
625
|
-
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
});
|
|
631
|
-
};
|
|
601
|
+
const createChangeHandler = react.useCallback(language => state => {
|
|
602
|
+
var _props$onChange, _context3, _context4;
|
|
603
|
+
|
|
604
|
+
(_props$onChange = props.onChange) === null || _props$onChange === void 0 ? void 0 : _props$onChange.call(props, {
|
|
605
|
+
target: {
|
|
606
|
+
id: props !== null && props !== void 0 && props.id ? _concatInstanceProperty__default["default"](_context3 = "".concat(props.id, ".")).call(_context3, language) : '',
|
|
607
|
+
name: props !== null && props !== void 0 && props.name ? _concatInstanceProperty__default["default"](_context4 = "".concat(props.name, ".")).call(_context4, language) : '',
|
|
608
|
+
language,
|
|
609
|
+
value: state
|
|
610
|
+
}
|
|
611
|
+
});
|
|
632
612
|
}, // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
633
613
|
[props.id, props.name, props.onChange]);
|
|
634
|
-
|
|
635
|
-
|
|
636
|
-
|
|
614
|
+
const languages = localizedUtils.sortLanguages(props.selectedLanguage, _Object$keys__default["default"](props.value));
|
|
615
|
+
const hasErrorInRemainingLanguages = props.hasError || localizedUtils.getHasErrorOnRemainingLanguages(props.errors, props.selectedLanguage);
|
|
616
|
+
const hasWarningInRemainingLanguages = props.hasWarning || localizedUtils.getHasWarningOnRemainingLanguages(props.warnings, props.selectedLanguage);
|
|
637
617
|
|
|
638
618
|
if (hasErrorInRemainingLanguages || hasWarningInRemainingLanguages) {
|
|
639
619
|
if (!areLanguagesOpened) {
|
|
@@ -643,30 +623,30 @@ var LocalizedRichTextInput = /*#__PURE__*/react.forwardRef(function (props, ref)
|
|
|
643
623
|
}
|
|
644
624
|
}
|
|
645
625
|
|
|
646
|
-
|
|
647
|
-
|
|
626
|
+
const langRefs = react.useRef(new _Map__default["default"]());
|
|
627
|
+
const resetValue = react.useCallback(newValue => {
|
|
648
628
|
var _context5;
|
|
649
629
|
|
|
650
|
-
_forEachInstanceProperty__default["default"](_context5 = langRefs.current).call(_context5,
|
|
630
|
+
_forEachInstanceProperty__default["default"](_context5 = langRefs.current).call(_context5, langRef => {
|
|
651
631
|
langRef.resetValue(newValue);
|
|
652
632
|
});
|
|
653
633
|
}, []);
|
|
654
|
-
react.useImperativeHandle(ref,
|
|
634
|
+
react.useImperativeHandle(ref, () => {
|
|
655
635
|
return {
|
|
656
|
-
resetValue
|
|
636
|
+
resetValue
|
|
657
637
|
};
|
|
658
638
|
});
|
|
659
|
-
|
|
639
|
+
const shouldRenderLanguagesControl = languages.length > 1 && !props.hideLanguageExpansionControls;
|
|
660
640
|
return jsxRuntime.jsx(Constraints__default["default"].Horizontal, {
|
|
661
641
|
max: props.horizontalConstraint,
|
|
662
642
|
children: jsxRuntime.jsxs(Stack__default["default"], {
|
|
663
643
|
scale: "xs",
|
|
664
644
|
children: [jsxRuntime.jsx(Stack__default["default"], {
|
|
665
|
-
children: _mapInstanceProperty__default["default"](languages).call(languages,
|
|
666
|
-
|
|
645
|
+
children: _mapInstanceProperty__default["default"](languages).call(languages, (language, index) => {
|
|
646
|
+
const isFirstLanguage = index === 0;
|
|
667
647
|
if (!isFirstLanguage && !areLanguagesOpened) return null;
|
|
668
|
-
|
|
669
|
-
|
|
648
|
+
const isLastLanguage = index === languages.length - 1;
|
|
649
|
+
const hasLanguagesControl = isFirstLanguage && !areLanguagesOpened || isLastLanguage;
|
|
670
650
|
return react$1.createElement(RichTextInput$1, _objectSpread(_objectSpread({}, utils.filterDataAttributes(props)), {}, {
|
|
671
651
|
key: language,
|
|
672
652
|
id: localizedUtils.getId(props.id, language),
|
|
@@ -689,9 +669,7 @@ var LocalizedRichTextInput = /*#__PURE__*/react.forwardRef(function (props, ref)
|
|
|
689
669
|
onClickExpand: props.onClickExpand,
|
|
690
670
|
hasLanguagesControl: hasLanguagesControl,
|
|
691
671
|
defaultExpandMultilineText: Boolean(props.defaultExpandMultilineText),
|
|
692
|
-
ref:
|
|
693
|
-
return langRefs.current.set(language, el);
|
|
694
|
-
}
|
|
672
|
+
ref: el => langRefs.current.set(language, el)
|
|
695
673
|
}, localizedUtils.createLocalizedDataAttributes(props, language)));
|
|
696
674
|
})
|
|
697
675
|
}), shouldRenderLanguagesControl && jsxRuntime.jsx(inputUtils.LocalizedInputToggle, {
|
|
@@ -715,7 +693,7 @@ LocalizedRichTextInput.isTouched = localizedUtils.isTouched;
|
|
|
715
693
|
var LocalizedRichTextInput$1 = LocalizedRichTextInput;
|
|
716
694
|
|
|
717
695
|
// NOTE: This string will be replaced on build time with the package version.
|
|
718
|
-
var version = "
|
|
696
|
+
var version = "16.0.0";
|
|
719
697
|
|
|
720
698
|
exports["default"] = LocalizedRichTextInput$1;
|
|
721
699
|
exports.version = version;
|