@pega/cosmos-react-rte 9.0.0-build.9.9 → 9.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.
Files changed (191) hide show
  1. package/lib/components/DynamicContentEditor/DynamicContentEditor.d.ts +4 -2
  2. package/lib/components/DynamicContentEditor/DynamicContentEditor.d.ts.map +1 -1
  3. package/lib/components/DynamicContentEditor/DynamicContentEditor.js +64 -59
  4. package/lib/components/DynamicContentEditor/DynamicContentEditor.js.map +1 -1
  5. package/lib/components/Editor/Editor.context.d.ts +6 -6
  6. package/lib/components/Editor/Editor.context.d.ts.map +1 -1
  7. package/lib/components/Editor/Editor.context.js +1 -1
  8. package/lib/components/Editor/Editor.context.js.map +1 -1
  9. package/lib/components/Editor/Editor.d.ts +1 -10
  10. package/lib/components/Editor/Editor.d.ts.map +1 -1
  11. package/lib/components/Editor/Editor.js +301 -490
  12. package/lib/components/Editor/Editor.js.map +1 -1
  13. package/lib/components/Editor/Editor.styles.d.ts +37 -7
  14. package/lib/components/Editor/Editor.styles.d.ts.map +1 -1
  15. package/lib/components/Editor/Editor.styles.js +60 -30
  16. package/lib/components/Editor/Editor.styles.js.map +1 -1
  17. package/lib/components/Editor/Editor.test-ids.d.ts +2 -1
  18. package/lib/components/Editor/Editor.test-ids.d.ts.map +1 -1
  19. package/lib/components/Editor/Editor.test-ids.js +2 -0
  20. package/lib/components/Editor/Editor.test-ids.js.map +1 -1
  21. package/lib/components/Editor/Editor.types.d.ts +34 -14
  22. package/lib/components/Editor/Editor.types.d.ts.map +1 -1
  23. package/lib/components/Editor/Editor.types.js.map +1 -1
  24. package/lib/components/Editor/IframeTiptapEditor.d.ts +30 -0
  25. package/lib/components/Editor/IframeTiptapEditor.d.ts.map +1 -0
  26. package/lib/components/Editor/IframeTiptapEditor.js +695 -0
  27. package/lib/components/Editor/IframeTiptapEditor.js.map +1 -0
  28. package/lib/components/Editor/ImageActionButtons.d.ts +20 -0
  29. package/lib/components/Editor/ImageActionButtons.d.ts.map +1 -0
  30. package/lib/components/Editor/ImageActionButtons.js +84 -0
  31. package/lib/components/Editor/ImageActionButtons.js.map +1 -0
  32. package/lib/components/Editor/ImageEditDialog.d.ts +17 -0
  33. package/lib/components/Editor/ImageEditDialog.d.ts.map +1 -0
  34. package/lib/components/Editor/ImageEditDialog.js +90 -0
  35. package/lib/components/Editor/ImageEditDialog.js.map +1 -0
  36. package/lib/components/Editor/TableCellMenu.d.ts +35 -0
  37. package/lib/components/Editor/TableCellMenu.d.ts.map +1 -0
  38. package/lib/components/Editor/TableCellMenu.js +120 -0
  39. package/lib/components/Editor/TableCellMenu.js.map +1 -0
  40. package/lib/components/Editor/Toolbar/AIRewriteButton.d.ts +17 -0
  41. package/lib/components/Editor/Toolbar/AIRewriteButton.d.ts.map +1 -0
  42. package/lib/components/Editor/Toolbar/AIRewriteButton.js +79 -0
  43. package/lib/components/Editor/Toolbar/AIRewriteButton.js.map +1 -0
  44. package/lib/components/Editor/Toolbar/AlignmentSelect.d.ts +8 -0
  45. package/lib/components/Editor/Toolbar/AlignmentSelect.d.ts.map +1 -0
  46. package/lib/components/Editor/Toolbar/AlignmentSelect.js +137 -0
  47. package/lib/components/Editor/Toolbar/AlignmentSelect.js.map +1 -0
  48. package/lib/components/Editor/Toolbar/AnchorButton.d.ts +3 -4
  49. package/lib/components/Editor/Toolbar/AnchorButton.d.ts.map +1 -1
  50. package/lib/components/Editor/Toolbar/AnchorButton.js +156 -82
  51. package/lib/components/Editor/Toolbar/AnchorButton.js.map +1 -1
  52. package/lib/components/Editor/Toolbar/ColorPickerButton.d.ts +9 -0
  53. package/lib/components/Editor/Toolbar/ColorPickerButton.d.ts.map +1 -0
  54. package/lib/components/Editor/Toolbar/ColorPickerButton.js +190 -0
  55. package/lib/components/Editor/Toolbar/ColorPickerButton.js.map +1 -0
  56. package/lib/components/Editor/Toolbar/FontFamilySelect.d.ts +8 -0
  57. package/lib/components/Editor/Toolbar/FontFamilySelect.d.ts.map +1 -0
  58. package/lib/components/Editor/Toolbar/FontFamilySelect.js +150 -0
  59. package/lib/components/Editor/Toolbar/FontFamilySelect.js.map +1 -0
  60. package/lib/components/Editor/Toolbar/FontSizeSelect.d.ts +8 -0
  61. package/lib/components/Editor/Toolbar/FontSizeSelect.d.ts.map +1 -0
  62. package/lib/components/Editor/Toolbar/FontSizeSelect.js +145 -0
  63. package/lib/components/Editor/Toolbar/FontSizeSelect.js.map +1 -0
  64. package/lib/components/Editor/Toolbar/ImageButton.d.ts +5 -5
  65. package/lib/components/Editor/Toolbar/ImageButton.d.ts.map +1 -1
  66. package/lib/components/Editor/Toolbar/ImageButton.js +131 -18
  67. package/lib/components/Editor/Toolbar/ImageButton.js.map +1 -1
  68. package/lib/components/Editor/Toolbar/SourceCodeButton.d.ts +8 -0
  69. package/lib/components/Editor/Toolbar/SourceCodeButton.d.ts.map +1 -0
  70. package/lib/components/Editor/Toolbar/SourceCodeButton.js +49 -0
  71. package/lib/components/Editor/Toolbar/SourceCodeButton.js.map +1 -0
  72. package/lib/components/Editor/Toolbar/TableButton.d.ts +8 -0
  73. package/lib/components/Editor/Toolbar/TableButton.d.ts.map +1 -0
  74. package/lib/components/Editor/Toolbar/TableButton.js +291 -0
  75. package/lib/components/Editor/Toolbar/TableButton.js.map +1 -0
  76. package/lib/components/Editor/Toolbar/TextSelect.d.ts +4 -5
  77. package/lib/components/Editor/Toolbar/TextSelect.d.ts.map +1 -1
  78. package/lib/components/Editor/Toolbar/TextSelect.js +61 -30
  79. package/lib/components/Editor/Toolbar/TextSelect.js.map +1 -1
  80. package/lib/components/Editor/Toolbar/Toolbar.d.ts +17 -6
  81. package/lib/components/Editor/Toolbar/Toolbar.d.ts.map +1 -1
  82. package/lib/components/Editor/Toolbar/Toolbar.js +169 -47
  83. package/lib/components/Editor/Toolbar/Toolbar.js.map +1 -1
  84. package/lib/components/Editor/Toolbar/Toolbar.test-ids.d.ts +2 -2
  85. package/lib/components/Editor/Toolbar/Toolbar.test-ids.d.ts.map +1 -1
  86. package/lib/components/Editor/Toolbar/Toolbar.test-ids.js +17 -1
  87. package/lib/components/Editor/Toolbar/Toolbar.test-ids.js.map +1 -1
  88. package/lib/components/Editor/Toolbar/WordCount.d.ts +8 -0
  89. package/lib/components/Editor/Toolbar/WordCount.d.ts.map +1 -0
  90. package/lib/components/Editor/Toolbar/WordCount.js +31 -0
  91. package/lib/components/Editor/Toolbar/WordCount.js.map +1 -0
  92. package/lib/components/Editor/extensions/FontSize.d.ts +21 -0
  93. package/lib/components/Editor/extensions/FontSize.d.ts.map +1 -0
  94. package/lib/components/Editor/extensions/FontSize.js +42 -0
  95. package/lib/components/Editor/extensions/FontSize.js.map +1 -0
  96. package/lib/components/Editor/extensions/PreserveDiv.d.ts +13 -0
  97. package/lib/components/Editor/extensions/PreserveDiv.d.ts.map +1 -0
  98. package/lib/components/Editor/extensions/PreserveDiv.js +73 -0
  99. package/lib/components/Editor/extensions/PreserveDiv.js.map +1 -0
  100. package/lib/components/Editor/extensions/TableCellSelection.d.ts +4 -0
  101. package/lib/components/Editor/extensions/TableCellSelection.d.ts.map +1 -0
  102. package/lib/components/Editor/extensions/TableCellSelection.js +53 -0
  103. package/lib/components/Editor/extensions/TableCellSelection.js.map +1 -0
  104. package/lib/components/Editor/extensions/TextIndent.d.ts +22 -0
  105. package/lib/components/Editor/extensions/TextIndent.d.ts.map +1 -0
  106. package/lib/components/Editor/extensions/TextIndent.js +137 -0
  107. package/lib/components/Editor/extensions/TextIndent.js.map +1 -0
  108. package/lib/components/Editor/hooks/useCloseOnEditorClick.d.ts +5 -0
  109. package/lib/components/Editor/hooks/useCloseOnEditorClick.d.ts.map +1 -0
  110. package/lib/components/Editor/hooks/useCloseOnEditorClick.js +18 -0
  111. package/lib/components/Editor/hooks/useCloseOnEditorClick.js.map +1 -0
  112. package/lib/components/Editor/hooks/useEscapeKey.d.ts +4 -0
  113. package/lib/components/Editor/hooks/useEscapeKey.d.ts.map +1 -0
  114. package/lib/components/Editor/hooks/useEscapeKey.js +24 -0
  115. package/lib/components/Editor/hooks/useEscapeKey.js.map +1 -0
  116. package/lib/components/Editor/hooks/useIframeSetup.d.ts +54 -0
  117. package/lib/components/Editor/hooks/useIframeSetup.d.ts.map +1 -0
  118. package/lib/components/Editor/hooks/useIframeSetup.js +284 -0
  119. package/lib/components/Editor/hooks/useIframeSetup.js.map +1 -0
  120. package/lib/components/Editor/hooks/useImageActions.d.ts +19 -0
  121. package/lib/components/Editor/hooks/useImageActions.d.ts.map +1 -0
  122. package/lib/components/Editor/hooks/useImageActions.js +198 -0
  123. package/lib/components/Editor/hooks/useImageActions.js.map +1 -0
  124. package/lib/components/Editor/hooks/useTableCellMenu.d.ts +22 -0
  125. package/lib/components/Editor/hooks/useTableCellMenu.d.ts.map +1 -0
  126. package/lib/components/Editor/hooks/useTableCellMenu.js +120 -0
  127. package/lib/components/Editor/hooks/useTableCellMenu.js.map +1 -0
  128. package/lib/components/Editor/iframeContentStyles.d.ts +10 -0
  129. package/lib/components/Editor/iframeContentStyles.d.ts.map +1 -0
  130. package/lib/components/Editor/iframeContentStyles.js +162 -0
  131. package/lib/components/Editor/iframeContentStyles.js.map +1 -0
  132. package/lib/components/Editor/index.d.ts +2 -0
  133. package/lib/components/Editor/index.d.ts.map +1 -1
  134. package/lib/components/Editor/index.js +1 -0
  135. package/lib/components/Editor/index.js.map +1 -1
  136. package/lib/components/Editor/sanitize.d.ts +3 -0
  137. package/lib/components/Editor/sanitize.d.ts.map +1 -0
  138. package/lib/components/Editor/sanitize.js +11 -0
  139. package/lib/components/Editor/sanitize.js.map +1 -0
  140. package/lib/components/Editor/utils/htmlPlaceholder.d.ts +69 -0
  141. package/lib/components/Editor/utils/htmlPlaceholder.d.ts.map +1 -0
  142. package/lib/components/Editor/utils/htmlPlaceholder.js +154 -0
  143. package/lib/components/Editor/utils/htmlPlaceholder.js.map +1 -0
  144. package/lib/components/RichTextEditor/DecoratorComponents/Table.d.ts +6 -4
  145. package/lib/components/RichTextEditor/DecoratorComponents/Table.d.ts.map +1 -1
  146. package/lib/components/RichTextEditor/DecoratorComponents/Table.js +10 -8
  147. package/lib/components/RichTextEditor/DecoratorComponents/Table.js.map +1 -1
  148. package/lib/components/RichTextEditor/RichTextEditor.d.ts.map +1 -1
  149. package/lib/components/RichTextEditor/RichTextEditor.js +15 -2
  150. package/lib/components/RichTextEditor/RichTextEditor.js.map +1 -1
  151. package/lib/components/RichTextEditor/RichTextEditor.styles.d.ts +5 -5
  152. package/lib/components/RichTextEditor/RichTextEditor.styles.d.ts.map +1 -1
  153. package/lib/components/RichTextEditor/RichTextEditor.styles.js +3 -5
  154. package/lib/components/RichTextEditor/RichTextEditor.styles.js.map +1 -1
  155. package/lib/components/RichTextEditor/RichTextEditor.types.d.ts +5 -0
  156. package/lib/components/RichTextEditor/RichTextEditor.types.d.ts.map +1 -1
  157. package/lib/components/RichTextEditor/RichTextEditor.types.js.map +1 -1
  158. package/lib/components/RichTextEditor/RichTextViewer.d.ts.map +1 -1
  159. package/lib/components/RichTextEditor/RichTextViewer.js +9 -2
  160. package/lib/components/RichTextEditor/RichTextViewer.js.map +1 -1
  161. package/lib/components/RichTextEditor/Toolbar/Toolbar.js +1 -1
  162. package/lib/components/RichTextEditor/Toolbar/Toolbar.js.map +1 -1
  163. package/lib/components/RichTextEditor/Toolbar/Toolbar.types.d.ts +4 -4
  164. package/lib/components/RichTextEditor/Toolbar/Toolbar.types.d.ts.map +1 -1
  165. package/lib/components/RichTextEditor/Toolbar/Toolbar.types.js.map +1 -1
  166. package/lib/components/RichTextEditor/Toolbar/ToolbarButton.d.ts.map +1 -1
  167. package/lib/components/RichTextEditor/Toolbar/ToolbarButton.js +41 -26
  168. package/lib/components/RichTextEditor/Toolbar/ToolbarButton.js.map +1 -1
  169. package/lib/components/RichTextEditor/utils/htmlConverter.d.ts +2 -0
  170. package/lib/components/RichTextEditor/utils/htmlConverter.d.ts.map +1 -1
  171. package/lib/components/RichTextEditor/utils/htmlConverter.js +12 -0
  172. package/lib/components/RichTextEditor/utils/htmlConverter.js.map +1 -1
  173. package/lib/components/RichTextEditor/utils/interactionRenderer.d.ts.map +1 -1
  174. package/lib/components/RichTextEditor/utils/interactionRenderer.js +20 -19
  175. package/lib/components/RichTextEditor/utils/interactionRenderer.js.map +1 -1
  176. package/lib/components/RichTextEditor/utils/markdownConverter.d.ts.map +1 -1
  177. package/lib/components/RichTextEditor/utils/markdownConverter.js +131 -30
  178. package/lib/components/RichTextEditor/utils/markdownConverter.js.map +1 -1
  179. package/lib/components/RichTextEditor/utils/renderers.d.ts +5 -3
  180. package/lib/components/RichTextEditor/utils/renderers.d.ts.map +1 -1
  181. package/lib/components/RichTextEditor/utils/renderers.js +62 -34
  182. package/lib/components/RichTextEditor/utils/renderers.js.map +1 -1
  183. package/lib/components/RichTextEditor/utils/slateConverter.d.ts +4 -3
  184. package/lib/components/RichTextEditor/utils/slateConverter.d.ts.map +1 -1
  185. package/lib/components/RichTextEditor/utils/slateConverter.js +86 -38
  186. package/lib/components/RichTextEditor/utils/slateConverter.js.map +1 -1
  187. package/package.json +30 -8
  188. package/lib/components/Editor/ImageEditor.d.ts +0 -10
  189. package/lib/components/Editor/ImageEditor.d.ts.map +0 -1
  190. package/lib/components/Editor/ImageEditor.js +0 -292
  191. package/lib/components/Editor/ImageEditor.js.map +0 -1
@@ -0,0 +1,291 @@
1
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { useRef, useState, useEffect, useCallback, useMemo } from 'react';
3
+ import styled, { css } from 'styled-components';
4
+ import { mix } from 'polished';
5
+ import { Popover, Icon, registerIcon, useOuterEvent, Button, Menu, defaultThemeProp, useI18n, Tooltip, Flex, Text, isInstance, tryCatch } from '@pega/cosmos-react-core';
6
+ import * as tableIcon from '@pega/cosmos-react-core/lib/components/Icon/icons/table.icon';
7
+ import useEscapeKey from '../hooks/useEscapeKey';
8
+ import useCloseOnEditorClick from '../hooks/useCloseOnEditorClick';
9
+ registerIcon(tableIcon);
10
+ const StyledTableButton = styled(Button)(({ theme, $active }) => {
11
+ const activeColor = tryCatch(() => mix(0.85, theme.base.palette['primary-background'], theme.base.palette.interactive));
12
+ return css `
13
+ color: ${theme.base.palette['foreground-color']};
14
+ display: inline-flex;
15
+ align-items: center;
16
+ justify-content: center;
17
+ height: calc(3.5 * ${theme.base.spacing});
18
+ min-width: calc(3.5 * ${theme.base.spacing});
19
+ padding: 0;
20
+
21
+ ${$active &&
22
+ css `
23
+ background-color: ${activeColor};
24
+ color: ${theme.base.palette.interactive};
25
+ `}
26
+ `;
27
+ });
28
+ StyledTableButton.defaultProps = defaultThemeProp;
29
+ const StyledGridContainer = styled.div(({ theme }) => {
30
+ return css `
31
+ padding: ${theme.base.spacing};
32
+ `;
33
+ });
34
+ StyledGridContainer.defaultProps = defaultThemeProp;
35
+ const StyledGrid = styled.div(({ theme }) => {
36
+ return css `
37
+ display: grid;
38
+ grid-template-columns: repeat(10, 1fr);
39
+ gap: calc(0.25 * ${theme.base.spacing});
40
+ margin-bottom: calc(0.5 * ${theme.base.spacing});
41
+ `;
42
+ });
43
+ StyledGrid.defaultProps = defaultThemeProp;
44
+ const StyledCell = styled.button.attrs({ type: 'button' })(({ theme, $isSelected }) => {
45
+ return css `
46
+ width: calc(2 * ${theme.base.spacing});
47
+ height: calc(2 * ${theme.base.spacing});
48
+ border: calc(0.125 * ${theme.base.spacing}) solid
49
+ ${theme.components['form-control']['border-color']};
50
+ background-color: ${$isSelected
51
+ ? theme.base.palette.interactive
52
+ : theme.components['form-control']['background-color']};
53
+ cursor: pointer;
54
+ padding: 0;
55
+
56
+ &:hover {
57
+ background-color: ${mix(0.7, theme.base.palette.interactive, theme.base.palette['primary-background'])};
58
+ }
59
+
60
+ &:focus {
61
+ outline: none;
62
+ box-shadow: inset 0 0 0 calc(0.25 * ${theme.base.spacing}) ${theme.base.palette.interactive};
63
+ }
64
+ `;
65
+ });
66
+ StyledCell.defaultProps = defaultThemeProp;
67
+ const StyledMenuContainer = styled.div(() => {
68
+ return css `
69
+ min-width: 12ch;
70
+ `;
71
+ });
72
+ StyledMenuContainer.defaultProps = defaultThemeProp;
73
+ const StyledButtonGroup = styled.div(({ theme }) => {
74
+ return css `
75
+ display: flex;
76
+ gap: calc(0.5 * ${theme.base.spacing});
77
+ justify-content: flex-start;
78
+ margin: calc(0.5 * ${theme.base.spacing}) ${theme.base.spacing} 0;
79
+ `;
80
+ });
81
+ StyledButtonGroup.defaultProps = defaultThemeProp;
82
+ const TableButton = ({ editor, ...restProps }) => {
83
+ const t = useI18n();
84
+ const [open, setOpen] = useState(false);
85
+ const [hoveredCell, setHoveredCell] = useState(null);
86
+ const [isInTable, setIsInTable] = useState(false);
87
+ const [selectedSize, setSelectedSize] = useState({
88
+ row: 1,
89
+ col: 1
90
+ });
91
+ const isInTableRef = useRef(false);
92
+ const justOpenedRef = useRef(false);
93
+ const buttonRef = useRef(null);
94
+ const popoverRef = useRef(null);
95
+ const gridContainerRef = useRef(null);
96
+ const menuRef = useRef(null);
97
+ const firstCellCallbackRef = useCallback((node) => {
98
+ if (node && open && !isInTable) {
99
+ node.focus();
100
+ }
101
+ }, [open, isInTable]);
102
+ // Check if cursor is inside a table (check for tableCell since that's where cursor sits)
103
+ const checkIsInTable = useCallback(() => {
104
+ return (editor.isActive('table') || editor.isActive('tableCell') || editor.isActive('tableHeader'));
105
+ }, [editor]);
106
+ // Update state on editor changes - store in ref so it's never lost
107
+ useEffect(() => {
108
+ const updateState = () => {
109
+ const inTable = checkIsInTable();
110
+ isInTableRef.current = inTable;
111
+ setIsInTable(inTable);
112
+ };
113
+ updateState();
114
+ editor.on('selectionUpdate', updateState);
115
+ editor.on('transaction', updateState);
116
+ return () => {
117
+ editor.off('selectionUpdate', updateState);
118
+ editor.off('transaction', updateState);
119
+ };
120
+ }, [editor, checkIsInTable]);
121
+ useOuterEvent('mousedown', [buttonRef, popoverRef], () => {
122
+ if (open) {
123
+ setOpen(false);
124
+ }
125
+ });
126
+ const handleEscapeClose = useCallback(() => {
127
+ setOpen(false);
128
+ buttonRef.current?.focus();
129
+ }, []);
130
+ useEscapeKey(open, handleEscapeClose, editor);
131
+ useCloseOnEditorClick(open, handleEscapeClose);
132
+ const insertTable = useCallback((rows, cols) => {
133
+ editor.chain().focus().insertTable({ rows, cols, withHeaderRow: false }).run();
134
+ setOpen(false);
135
+ }, [editor]);
136
+ const addRow = () => {
137
+ editor.chain().focus().addRowAfter().run();
138
+ setOpen(false);
139
+ };
140
+ const addColumn = () => {
141
+ editor.chain().focus().addColumnAfter().run();
142
+ setOpen(false);
143
+ };
144
+ const deleteRow = () => {
145
+ editor.chain().focus().deleteRow().run();
146
+ setOpen(false);
147
+ };
148
+ const deleteColumn = () => {
149
+ editor.chain().focus().deleteColumn().run();
150
+ setOpen(false);
151
+ };
152
+ const deleteTable = () => {
153
+ editor.chain().focus().deleteTable().run();
154
+ setOpen(false);
155
+ };
156
+ const getTableSizeLabel = (rows, cols) => `${rows} x ${cols}`;
157
+ const handleCellKeyDown = useCallback((e) => {
158
+ switch (e.key) {
159
+ case 'ArrowRight':
160
+ e.preventDefault();
161
+ setSelectedSize(prev => ({ ...prev, col: Math.min(prev.col + 1, 9) }));
162
+ break;
163
+ case 'ArrowLeft':
164
+ e.preventDefault();
165
+ setSelectedSize(prev => ({ ...prev, col: Math.max(prev.col - 1, 0) }));
166
+ break;
167
+ case 'ArrowDown':
168
+ e.preventDefault();
169
+ setSelectedSize(prev => ({ ...prev, row: Math.min(prev.row + 1, 9) }));
170
+ break;
171
+ case 'ArrowUp':
172
+ e.preventDefault();
173
+ setSelectedSize(prev => ({ ...prev, row: Math.max(prev.row - 1, 0) }));
174
+ break;
175
+ case 'Enter':
176
+ e.preventDefault();
177
+ setSelectedSize(prev => {
178
+ insertTable(prev.row + 1, prev.col + 1);
179
+ return prev;
180
+ });
181
+ break;
182
+ case 'Escape':
183
+ e.preventDefault();
184
+ setOpen(false);
185
+ buttonRef.current?.focus();
186
+ break;
187
+ default:
188
+ break;
189
+ }
190
+ }, [insertTable]);
191
+ // Memoize cells to avoid re-rendering all 100 cells on every state change
192
+ const cells = useMemo(() => {
193
+ const result = [];
194
+ for (let row = 0; row < 10; row += 1) {
195
+ for (let col = 0; col < 10; col += 1) {
196
+ const isHovered = hoveredCell && row <= hoveredCell.row && col <= hoveredCell.col;
197
+ const isKeyboardSelected = !hoveredCell && row <= selectedSize.row && col <= selectedSize.col;
198
+ const isFirstCell = row === 0 && col === 0;
199
+ result.push(_jsx(StyledCell, { ref: isFirstCell ? firstCellCallbackRef : undefined, tabIndex: isFirstCell ? 0 : -1, "$isSelected": isHovered || isKeyboardSelected, onMouseEnter: () => setHoveredCell({ row, col }), onClick: () => {
200
+ setSelectedSize({ row, col });
201
+ insertTable(row + 1, col + 1);
202
+ }, onKeyDown: handleCellKeyDown, "aria-label": t('rte_table_size', [row + 1, col + 1]) }, `${row}-${col}`));
203
+ }
204
+ }
205
+ return result;
206
+ }, [hoveredCell, selectedSize, firstCellCallbackRef, handleCellKeyDown, insertTable, t]);
207
+ // Reset selected size to 2x2 default when opening
208
+ useEffect(() => {
209
+ if (open && !isInTable) {
210
+ setSelectedSize({ row: 1, col: 1 });
211
+ }
212
+ }, [open, isInTable]);
213
+ const getGridLabel = () => {
214
+ if (hoveredCell) {
215
+ return getTableSizeLabel(hoveredCell.row + 1, hoveredCell.col + 1);
216
+ }
217
+ if (selectedSize) {
218
+ return getTableSizeLabel(selectedSize.row + 1, selectedSize.col + 1);
219
+ }
220
+ return '1 x 1';
221
+ };
222
+ const gridLabel = getGridLabel();
223
+ const handleCancel = () => {
224
+ setOpen(false);
225
+ buttonRef.current?.focus();
226
+ };
227
+ return (_jsxs(_Fragment, { children: [_jsx(StyledTableButton, { ...restProps, variant: 'simple', type: 'button', icon: false, ref: buttonRef, "data-toolbar-item": 'true', "$active": isInTable, onMouseDown: (e) => {
228
+ e.preventDefault();
229
+ }, onKeyDown: (e) => {
230
+ if (e.key === 'Escape' && open) {
231
+ e.preventDefault();
232
+ setOpen(false);
233
+ }
234
+ }, onFocus: (e) => {
235
+ e.preventDefault();
236
+ e.stopPropagation();
237
+ }, onBlur: (e) => {
238
+ // Skip blur handling if we just opened the popover
239
+ if (justOpenedRef.current)
240
+ return;
241
+ const { relatedTarget } = e;
242
+ // Close if focus moves outside button/popover, or if relatedTarget is null (e.g., clicking into iframe)
243
+ // Check gridContainerRef separately since Popover uses a portal
244
+ if (!isInstance(relatedTarget, Node) ||
245
+ (!buttonRef.current?.contains(relatedTarget) &&
246
+ !popoverRef.current?.contains(relatedTarget) &&
247
+ !gridContainerRef.current?.contains(relatedTarget) &&
248
+ !menuRef.current?.contains(relatedTarget))) {
249
+ setOpen(false);
250
+ }
251
+ }, onClick: (e) => {
252
+ e.preventDefault();
253
+ e.stopPropagation();
254
+ setIsInTable(isInTableRef.current);
255
+ if (!open) {
256
+ justOpenedRef.current = true;
257
+ setTimeout(() => {
258
+ justOpenedRef.current = false;
259
+ }, 100);
260
+ }
261
+ setOpen(!open);
262
+ }, "aria-expanded": open, "aria-label": t('rte_table'), "aria-haspopup": true, children: _jsx(Icon, { name: 'table' }) }), buttonRef.current && (_jsx(Tooltip, { target: buttonRef.current, showDelay: 'none', hideDelay: 'none', children: t('rte_table') })), _jsx(Popover, { show: open, target: buttonRef.current, placement: 'bottom-start', ref: popoverRef, children: isInTable ? (_jsx(StyledMenuContainer, { children: _jsx(Menu, { ref: menuRef, focusControlEl: buttonRef.current ?? undefined, items: [
263
+ { id: 'add-row', primary: t('rte_add_row') },
264
+ { id: 'add-column', primary: t('rte_add_column') },
265
+ { id: 'delete-row', primary: t('rte_delete_row') },
266
+ { id: 'delete-column', primary: t('rte_delete_column') },
267
+ { id: 'delete-table', primary: t('rte_delete_table') }
268
+ ], onItemClick: (id) => {
269
+ switch (id) {
270
+ case 'add-row':
271
+ addRow();
272
+ break;
273
+ case 'add-column':
274
+ addColumn();
275
+ break;
276
+ case 'delete-row':
277
+ deleteRow();
278
+ break;
279
+ case 'delete-column':
280
+ deleteColumn();
281
+ break;
282
+ case 'delete-table':
283
+ deleteTable();
284
+ break;
285
+ default:
286
+ break;
287
+ }
288
+ } }) })) : (_jsx(StyledGridContainer, { children: _jsxs(Flex, { container: { direction: 'column', gap: 1 }, children: [_jsx(Text, { variant: 'h2', children: t('rte_insert_table') }), _jsx(StyledGrid, { ref: gridContainerRef, onMouseLeave: () => setHoveredCell(null), children: cells }), _jsx(Text, { variant: 'secondary', children: gridLabel }), _jsxs(StyledButtonGroup, { children: [_jsx(Button, { variant: 'secondary', onClick: handleCancel, children: t('cancel') }), _jsx(Button, { variant: 'primary', onClick: () => insertTable(selectedSize.row + 1, selectedSize.col + 1), children: t('submit') })] })] }) })) })] }));
289
+ };
290
+ export default TableButton;
291
+ //# sourceMappingURL=TableButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TableButton.js","sourceRoot":"","sources":["../../../../src/components/Editor/Toolbar/TableButton.tsx"],"names":[],"mappings":"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","sourcesContent":["import { useRef, useState, useEffect, useCallback, useMemo } from 'react';\nimport type { MouseEvent, KeyboardEvent, FocusEvent } from 'react';\nimport type { Editor as TiptapEditor } from '@tiptap/core';\nimport styled, { css } from 'styled-components';\nimport { mix } from 'polished';\n\nimport {\n Popover,\n Icon,\n registerIcon,\n useOuterEvent,\n Button,\n Menu,\n defaultThemeProp,\n useI18n,\n Tooltip,\n Flex,\n Text,\n isInstance,\n tryCatch\n} from '@pega/cosmos-react-core';\nimport * as tableIcon from '@pega/cosmos-react-core/lib/components/Icon/icons/table.icon';\n\nimport useEscapeKey from '../hooks/useEscapeKey';\nimport useCloseOnEditorClick from '../hooks/useCloseOnEditorClick';\n\nregisterIcon(tableIcon);\n\nconst StyledTableButton = styled(Button)<{ $active?: boolean }>(({ theme, $active }) => {\n const activeColor = tryCatch(() =>\n mix(0.85, theme.base.palette['primary-background'], theme.base.palette.interactive)\n );\n return css`\n color: ${theme.base.palette['foreground-color']};\n display: inline-flex;\n align-items: center;\n justify-content: center;\n height: calc(3.5 * ${theme.base.spacing});\n min-width: calc(3.5 * ${theme.base.spacing});\n padding: 0;\n\n ${$active &&\n css`\n background-color: ${activeColor};\n color: ${theme.base.palette.interactive};\n `}\n `;\n});\n\nStyledTableButton.defaultProps = defaultThemeProp;\n\nconst StyledGridContainer = styled.div(({ theme }) => {\n return css`\n padding: ${theme.base.spacing};\n `;\n});\n\nStyledGridContainer.defaultProps = defaultThemeProp;\n\nconst StyledGrid = styled.div(({ theme }) => {\n return css`\n display: grid;\n grid-template-columns: repeat(10, 1fr);\n gap: calc(0.25 * ${theme.base.spacing});\n margin-bottom: calc(0.5 * ${theme.base.spacing});\n `;\n});\n\nStyledGrid.defaultProps = defaultThemeProp;\n\nconst StyledCell = styled.button.attrs({ type: 'button' })<{ $isSelected?: boolean }>(\n ({ theme, $isSelected }) => {\n return css`\n width: calc(2 * ${theme.base.spacing});\n height: calc(2 * ${theme.base.spacing});\n border: calc(0.125 * ${theme.base.spacing}) solid\n ${theme.components['form-control']['border-color']};\n background-color: ${$isSelected\n ? theme.base.palette.interactive\n : theme.components['form-control']['background-color']};\n cursor: pointer;\n padding: 0;\n\n &:hover {\n background-color: ${mix(\n 0.7,\n theme.base.palette.interactive,\n theme.base.palette['primary-background']\n )};\n }\n\n &:focus {\n outline: none;\n box-shadow: inset 0 0 0 calc(0.25 * ${theme.base.spacing}) ${theme.base.palette.interactive};\n }\n `;\n }\n);\n\nStyledCell.defaultProps = defaultThemeProp;\n\nconst StyledMenuContainer = styled.div(() => {\n return css`\n min-width: 12ch;\n `;\n});\n\nStyledMenuContainer.defaultProps = defaultThemeProp;\n\nconst StyledButtonGroup = styled.div(({ theme }) => {\n return css`\n display: flex;\n gap: calc(0.5 * ${theme.base.spacing});\n justify-content: flex-start;\n margin: calc(0.5 * ${theme.base.spacing}) ${theme.base.spacing} 0;\n `;\n});\n\nStyledButtonGroup.defaultProps = defaultThemeProp;\n\ninterface TableButtonProps {\n editor: TiptapEditor;\n 'data-testid'?: string;\n}\n\nconst TableButton = ({ editor, ...restProps }: TableButtonProps) => {\n const t = useI18n();\n const [open, setOpen] = useState(false);\n const [hoveredCell, setHoveredCell] = useState<{ row: number; col: number } | null>(null);\n const [isInTable, setIsInTable] = useState(false);\n const [selectedSize, setSelectedSize] = useState<{ row: number; col: number }>({\n row: 1,\n col: 1\n });\n const isInTableRef = useRef(false);\n const justOpenedRef = useRef(false);\n const buttonRef = useRef<HTMLButtonElement>(null);\n const popoverRef = useRef<HTMLDivElement>(null);\n const gridContainerRef = useRef<HTMLDivElement>(null);\n const menuRef = useRef<HTMLDivElement>(null);\n\n const firstCellCallbackRef = useCallback(\n (node: HTMLButtonElement | null) => {\n if (node && open && !isInTable) {\n node.focus();\n }\n },\n [open, isInTable]\n );\n\n // Check if cursor is inside a table (check for tableCell since that's where cursor sits)\n const checkIsInTable = useCallback(() => {\n return (\n editor.isActive('table') || editor.isActive('tableCell') || editor.isActive('tableHeader')\n );\n }, [editor]);\n\n // Update state on editor changes - store in ref so it's never lost\n useEffect(() => {\n const updateState = () => {\n const inTable = checkIsInTable();\n isInTableRef.current = inTable;\n setIsInTable(inTable);\n };\n updateState();\n editor.on('selectionUpdate', updateState);\n editor.on('transaction', updateState);\n return () => {\n editor.off('selectionUpdate', updateState);\n editor.off('transaction', updateState);\n };\n }, [editor, checkIsInTable]);\n\n useOuterEvent('mousedown', [buttonRef, popoverRef], () => {\n if (open) {\n setOpen(false);\n }\n });\n\n const handleEscapeClose = useCallback(() => {\n setOpen(false);\n buttonRef.current?.focus();\n }, []);\n\n useEscapeKey(open, handleEscapeClose, editor);\n useCloseOnEditorClick(open, handleEscapeClose);\n\n const insertTable = useCallback(\n (rows: number, cols: number) => {\n editor.chain().focus().insertTable({ rows, cols, withHeaderRow: false }).run();\n setOpen(false);\n },\n [editor]\n );\n\n const addRow = () => {\n editor.chain().focus().addRowAfter().run();\n setOpen(false);\n };\n\n const addColumn = () => {\n editor.chain().focus().addColumnAfter().run();\n setOpen(false);\n };\n\n const deleteRow = () => {\n editor.chain().focus().deleteRow().run();\n setOpen(false);\n };\n\n const deleteColumn = () => {\n editor.chain().focus().deleteColumn().run();\n setOpen(false);\n };\n\n const deleteTable = () => {\n editor.chain().focus().deleteTable().run();\n setOpen(false);\n };\n\n const getTableSizeLabel = (rows: number, cols: number) => `${rows} x ${cols}`;\n\n const handleCellKeyDown = useCallback(\n (e: KeyboardEvent) => {\n switch (e.key) {\n case 'ArrowRight':\n e.preventDefault();\n setSelectedSize(prev => ({ ...prev, col: Math.min(prev.col + 1, 9) }));\n break;\n case 'ArrowLeft':\n e.preventDefault();\n setSelectedSize(prev => ({ ...prev, col: Math.max(prev.col - 1, 0) }));\n break;\n case 'ArrowDown':\n e.preventDefault();\n setSelectedSize(prev => ({ ...prev, row: Math.min(prev.row + 1, 9) }));\n break;\n case 'ArrowUp':\n e.preventDefault();\n setSelectedSize(prev => ({ ...prev, row: Math.max(prev.row - 1, 0) }));\n break;\n case 'Enter':\n e.preventDefault();\n setSelectedSize(prev => {\n insertTable(prev.row + 1, prev.col + 1);\n return prev;\n });\n break;\n case 'Escape':\n e.preventDefault();\n setOpen(false);\n buttonRef.current?.focus();\n break;\n default:\n break;\n }\n },\n [insertTable]\n );\n\n // Memoize cells to avoid re-rendering all 100 cells on every state change\n const cells = useMemo(() => {\n const result: JSX.Element[] = [];\n for (let row = 0; row < 10; row += 1) {\n for (let col = 0; col < 10; col += 1) {\n const isHovered = hoveredCell && row <= hoveredCell.row && col <= hoveredCell.col;\n const isKeyboardSelected =\n !hoveredCell && row <= selectedSize.row && col <= selectedSize.col;\n const isFirstCell = row === 0 && col === 0;\n result.push(\n <StyledCell\n key={`${row}-${col}`}\n ref={isFirstCell ? firstCellCallbackRef : undefined}\n tabIndex={isFirstCell ? 0 : -1}\n $isSelected={isHovered || isKeyboardSelected}\n onMouseEnter={() => setHoveredCell({ row, col })}\n onClick={() => {\n setSelectedSize({ row, col });\n insertTable(row + 1, col + 1);\n }}\n onKeyDown={handleCellKeyDown}\n aria-label={t('rte_table_size', [row + 1, col + 1])}\n />\n );\n }\n }\n return result;\n }, [hoveredCell, selectedSize, firstCellCallbackRef, handleCellKeyDown, insertTable, t]);\n\n // Reset selected size to 2x2 default when opening\n useEffect(() => {\n if (open && !isInTable) {\n setSelectedSize({ row: 1, col: 1 });\n }\n }, [open, isInTable]);\n\n const getGridLabel = () => {\n if (hoveredCell) {\n return getTableSizeLabel(hoveredCell.row + 1, hoveredCell.col + 1);\n }\n if (selectedSize) {\n return getTableSizeLabel(selectedSize.row + 1, selectedSize.col + 1);\n }\n return '1 x 1';\n };\n const gridLabel = getGridLabel();\n\n const handleCancel = () => {\n setOpen(false);\n buttonRef.current?.focus();\n };\n\n return (\n <>\n <StyledTableButton\n {...restProps}\n variant='simple'\n type='button'\n icon={false}\n ref={buttonRef}\n data-toolbar-item='true'\n $active={isInTable}\n onMouseDown={(e: MouseEvent) => {\n e.preventDefault();\n }}\n onKeyDown={(e: KeyboardEvent) => {\n if (e.key === 'Escape' && open) {\n e.preventDefault();\n setOpen(false);\n }\n }}\n onFocus={(e: FocusEvent) => {\n e.preventDefault();\n e.stopPropagation();\n }}\n onBlur={(e: FocusEvent) => {\n // Skip blur handling if we just opened the popover\n if (justOpenedRef.current) return;\n\n const { relatedTarget } = e;\n // Close if focus moves outside button/popover, or if relatedTarget is null (e.g., clicking into iframe)\n // Check gridContainerRef separately since Popover uses a portal\n if (\n !isInstance(relatedTarget, Node) ||\n (!buttonRef.current?.contains(relatedTarget) &&\n !popoverRef.current?.contains(relatedTarget) &&\n !gridContainerRef.current?.contains(relatedTarget) &&\n !menuRef.current?.contains(relatedTarget))\n ) {\n setOpen(false);\n }\n }}\n onClick={(e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setIsInTable(isInTableRef.current);\n if (!open) {\n justOpenedRef.current = true;\n setTimeout(() => {\n justOpenedRef.current = false;\n }, 100);\n }\n setOpen(!open);\n }}\n aria-expanded={open}\n aria-label={t('rte_table')}\n aria-haspopup\n >\n <Icon name='table' />\n </StyledTableButton>\n {buttonRef.current && (\n <Tooltip target={buttonRef.current} showDelay='none' hideDelay='none'>\n {t('rte_table')}\n </Tooltip>\n )}\n <Popover show={open} target={buttonRef.current} placement='bottom-start' ref={popoverRef}>\n {isInTable ? (\n <StyledMenuContainer>\n <Menu\n ref={menuRef}\n focusControlEl={buttonRef.current ?? undefined}\n items={[\n { id: 'add-row', primary: t('rte_add_row') },\n { id: 'add-column', primary: t('rte_add_column') },\n { id: 'delete-row', primary: t('rte_delete_row') },\n { id: 'delete-column', primary: t('rte_delete_column') },\n { id: 'delete-table', primary: t('rte_delete_table') }\n ]}\n onItemClick={(id: string) => {\n switch (id) {\n case 'add-row':\n addRow();\n break;\n case 'add-column':\n addColumn();\n break;\n case 'delete-row':\n deleteRow();\n break;\n case 'delete-column':\n deleteColumn();\n break;\n case 'delete-table':\n deleteTable();\n break;\n default:\n break;\n }\n }}\n />\n </StyledMenuContainer>\n ) : (\n <StyledGridContainer>\n <Flex container={{ direction: 'column', gap: 1 }}>\n <Text variant='h2'>{t('rte_insert_table')}</Text>\n <StyledGrid ref={gridContainerRef} onMouseLeave={() => setHoveredCell(null)}>\n {cells}\n </StyledGrid>\n <Text variant='secondary'>{gridLabel}</Text>\n <StyledButtonGroup>\n <Button variant='secondary' onClick={handleCancel}>\n {t('cancel')}\n </Button>\n <Button\n variant='primary'\n onClick={() => insertTable(selectedSize.row + 1, selectedSize.col + 1)}\n >\n {t('submit')}\n </Button>\n </StyledButtonGroup>\n </Flex>\n </StyledGridContainer>\n )}\n </Popover>\n </>\n );\n};\n\nexport default TableButton;\n"]}
@@ -1,5 +1,4 @@
1
- import type { FC } from 'react';
2
- import type { Editor } from 'tinymce';
1
+ import type { Editor as TiptapEditor } from '@tiptap/core';
3
2
  import type { TranslationFunction, TranslationPack } from '@pega/cosmos-react-core';
4
3
  declare const formatMapping: {
5
4
  readonly p: "normal";
@@ -21,9 +20,9 @@ export declare const getTextFormats: (t: TranslationFunction<TranslationPack>, o
21
20
  subText: string;
22
21
  type: FormatType;
23
22
  }[];
24
- declare const TextSelect: FC<{
23
+ declare const TextSelect: ({ osx, editor, ...restProps }: {
25
24
  osx: boolean;
26
- editor: Editor;
27
- }>;
25
+ editor: TiptapEditor;
26
+ }) => import("react/jsx-runtime").JSX.Element;
28
27
  export default TextSelect;
29
28
  //# sourceMappingURL=TextSelect.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TextSelect.d.ts","sourceRoot":"","sources":["../../../../src/components/Editor/Toolbar/TextSelect.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,EAAE,EAAyC,MAAM,OAAO,CAAC;AACvE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,SAAS,CAAC;AAetC,OAAO,KAAK,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAkCpF,QAAA,MAAM,aAAa;;;;;;;;;;;CAWT,CAAC;AAQX,KAAK,UAAU,GAAG,MAAM,OAAO,aAAa,CAAC;AAC7C,KAAK,MAAM,GAAG,CAAC,OAAO,aAAa,CAAC,CAAC,UAAU,CAAC,CAAC;AAMjD,eAAO,MAAM,cAAc,GACzB,GAAG,mBAAmB,CAAC,eAAe,CAAC,EACvC,MAAK,OAAe,KACnB;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,UAAU,CAAA;CAAE,EAiCjE,CAAC;AAEF,QAAA,MAAM,UAAU,EAAE,EAAE,CAAC;IAAE,GAAG,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,MAAM,CAAA;CAAE,CA2IpD,CAAC;AAEF,eAAe,UAAU,CAAC"}
1
+ {"version":3,"file":"TextSelect.d.ts","sourceRoot":"","sources":["../../../../src/components/Editor/Toolbar/TextSelect.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,MAAM,IAAI,YAAY,EAAE,MAAM,cAAc,CAAC;AAgB3D,OAAO,KAAK,EAAE,mBAAmB,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAsCpF,QAAA,MAAM,aAAa;;;;;;;;;;;CAWT,CAAC;AAEX,KAAK,UAAU,GAAG,MAAM,OAAO,aAAa,CAAC;AAC7C,KAAK,MAAM,GAAG,CAAC,OAAO,aAAa,CAAC,CAAC,UAAU,CAAC,CAAC;AAMjD,eAAO,MAAM,cAAc,GACzB,GAAG,mBAAmB,CAAC,eAAe,CAAC,EACvC,MAAK,OAAe,KACnB;IAAE,EAAE,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAC;IAAC,OAAO,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,UAAU,CAAA;CAAE,EAiCjE,CAAC;AAEF,QAAA,MAAM,UAAU,GAAI,+BAA+B;IAAE,GAAG,EAAE,OAAO,CAAC;IAAC,MAAM,EAAE,YAAY,CAAA;CAAE,4CAiKxF,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -1,9 +1,11 @@
1
1
  import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
2
- import { useRef, useState, useMemo } from 'react';
2
+ import { useRef, useState, useMemo, useCallback } from 'react';
3
3
  import styled, { css } from 'styled-components';
4
- import { Popover, Icon, registerIcon, useOuterEvent, Menu, Button, defaultThemeProp, useI18n, Tooltip, calculateFontSize } from '@pega/cosmos-react-core';
4
+ import { Popover, Icon, registerIcon, useOuterEvent, Menu, Button, defaultThemeProp, useI18n, Tooltip, calculateFontSize, isInstance } from '@pega/cosmos-react-core';
5
5
  import * as arrowMicroDownIcon from '@pega/cosmos-react-core/lib/components/Icon/icons/arrow-micro-down.icon';
6
6
  import { getKeyCommand } from '../../RichTextEditor/Toolbar/utils';
7
+ import useEscapeKey from '../hooks/useEscapeKey';
8
+ import useCloseOnEditorClick from '../hooks/useCloseOnEditorClick';
7
9
  registerIcon(arrowMicroDownIcon);
8
10
  const StyledTextSelect = styled(Button)(({ theme }) => {
9
11
  const fontSizes = calculateFontSize(theme.base['font-size'], theme.base['font-scale']);
@@ -29,6 +31,7 @@ StyledTextSelect.defaultProps = defaultThemeProp;
29
31
  const StyledSelectMenu = styled.div `
30
32
  min-width: 20ch;
31
33
  `;
34
+ StyledSelectMenu.defaultProps = defaultThemeProp;
32
35
  const formatMapping = {
33
36
  p: 'normal',
34
37
  li: 'normal',
@@ -41,9 +44,6 @@ const formatMapping = {
41
44
  h4: 'heading-4',
42
45
  '': 'normal'
43
46
  };
44
- const normalTags = new Set(Object.entries(formatMapping)
45
- .filter(([, value]) => value === 'normal')
46
- .map(([key]) => key));
47
47
  const getTextCommand = (num, osx) => {
48
48
  return getKeyCommand(osx, ({ ctrl, alt }) => `${ctrl}${alt}${num}`);
49
49
  };
@@ -92,42 +92,60 @@ const TextSelect = ({ osx, editor, ...restProps }) => {
92
92
  const textFormats = useMemo(() => {
93
93
  return getTextFormats(t, osx);
94
94
  }, [t, osx]);
95
- useOuterEvent('click', [buttonRef, popoverRef, menuRef], () => {
95
+ useOuterEvent('mousedown', [buttonRef, popoverRef, menuRef], () => {
96
96
  setOpen(false);
97
97
  });
98
- const onTextSelect = (type, e) => {
98
+ const handleEscapeClose = useCallback(() => {
99
+ setOpen(false);
100
+ buttonRef.current?.focus();
101
+ }, []);
102
+ useEscapeKey(open, handleEscapeClose, editor);
103
+ useCloseOnEditorClick(open, handleEscapeClose);
104
+ const onTextSelect = (id, e) => {
99
105
  e.stopPropagation();
100
106
  e.preventDefault();
101
- editor.execCommand('FormatBlock', false, type);
107
+ // Tiptap API
108
+ const chain = editor.chain().focus();
109
+ if (id === 'p') {
110
+ chain.setParagraph().run();
111
+ }
112
+ else if (id === 'h1') {
113
+ chain.setHeading({ level: 1 }).run();
114
+ }
115
+ else if (id === 'h2') {
116
+ chain.setHeading({ level: 2 }).run();
117
+ }
118
+ else if (id === 'h3') {
119
+ chain.setHeading({ level: 3 }).run();
120
+ }
121
+ else if (id === 'h4') {
122
+ chain.setHeading({ level: 4 }).run();
123
+ }
102
124
  if (!openedByClick.current) {
103
125
  buttonRef.current?.focus();
104
126
  }
105
127
  setOpen(false);
106
128
  selecting.current = true;
107
129
  setTimeout(() => {
108
- if (!editor.hasFocus() && openedByClick.current) {
109
- editor.focus();
130
+ selecting.current = false;
131
+ if (!editor.isFocused && openedByClick.current) {
132
+ editor.commands.focus();
110
133
  }
111
134
  }, 0);
112
135
  };
113
- const getParentTextFormat = (el) => {
114
- const elTagName = el.nodeName.toLowerCase();
115
- if (formatMapping[elTagName]) {
116
- return elTagName;
117
- }
118
- if (el.parentNode) {
119
- return getParentTextFormat(el.parentNode);
120
- }
121
- return undefined;
122
- };
123
136
  const activeFormat = () => {
124
- const tag = editor.hasFocus()
125
- ? getParentTextFormat(editor.selection.getNode())
126
- : editor.contentDocument?.body?.firstChild?.nodeName.toLowerCase();
127
- if (tag && normalTags.has(tag)) {
137
+ // Tiptap API
138
+ if (editor.isActive('heading', { level: 1 }))
139
+ return 'h1';
140
+ if (editor.isActive('heading', { level: 2 }))
141
+ return 'h2';
142
+ if (editor.isActive('heading', { level: 3 }))
143
+ return 'h3';
144
+ if (editor.isActive('heading', { level: 4 }))
145
+ return 'h4';
146
+ if (editor.isActive('paragraph'))
128
147
  return 'p';
129
- }
130
- return tag;
148
+ return 'p';
131
149
  };
132
150
  const formatText = (() => {
133
151
  const activeFormatType = activeFormat();
@@ -139,11 +157,12 @@ const TextSelect = ({ osx, editor, ...restProps }) => {
139
157
  return unknown;
140
158
  return textFormats.find(({ id }) => id === format)?.text ?? unknown;
141
159
  })();
142
- return (_jsxs(_Fragment, { children: [_jsxs(StyledTextSelect, { ...restProps, variant: 'simple', type: 'button', icon: false, ref: buttonRef, onMouseDown: (e) => {
160
+ return (_jsxs(_Fragment, { children: [_jsxs(StyledTextSelect, { ...restProps, variant: 'simple', type: 'button', icon: false, ref: buttonRef, "data-toolbar-item": 'true', onMouseDown: (e) => {
143
161
  e.preventDefault();
144
- e.stopPropagation();
145
- setOpen(true);
146
- openedByClick.current = true;
162
+ if (!open) {
163
+ openedByClick.current = true;
164
+ }
165
+ setOpen(!open);
147
166
  }, onKeyDown: (e) => {
148
167
  if (e.key === 'Enter' && !selecting.current) {
149
168
  e.preventDefault();
@@ -157,9 +176,21 @@ const TextSelect = ({ osx, editor, ...restProps }) => {
157
176
  else if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {
158
177
  setOpen(false);
159
178
  }
179
+ else if (e.key === 'Escape' && open) {
180
+ e.preventDefault();
181
+ setOpen(false);
182
+ }
160
183
  }, onFocus: (e) => {
161
184
  e.preventDefault();
162
185
  e.stopPropagation();
186
+ }, onBlur: (e) => {
187
+ const { relatedTarget } = e;
188
+ if (isInstance(relatedTarget, Node) &&
189
+ !buttonRef.current?.contains(relatedTarget) &&
190
+ !popoverRef.current?.contains(relatedTarget) &&
191
+ !menuRef.current?.contains(relatedTarget)) {
192
+ setOpen(false);
193
+ }
163
194
  }, onClick: (e) => e.stopPropagation(), "aria-expanded": open, "aria-label": `${t('rte_text_formatting_toolbar')}. ${t('rte_heading_style')}. ${formatText} ${t('selected').toLocaleLowerCase()}`, "aria-haspopup": true, children: [_jsx("span", { children: formatText }), _jsx(Icon, { name: 'arrow-micro-down' })] }), buttonRef.current && (_jsx(Tooltip, { target: buttonRef.current, showDelay: 'none', hideDelay: 'none', children: t('rte_heading_style') })), _jsx(Popover, { show: open, as: StyledSelectMenu, target: buttonRef.current, placement: 'bottom-start', ref: popoverRef, children: _jsx(Menu, { items: textFormats.map(({ text, type, subText }) => ({
164
195
  id: type,
165
196
  primary: text,
@@ -1 +1 @@
1
- {"version":3,"file":"TextSelect.js","sourceRoot":"","sources":["../../../../src/components/Editor/Toolbar/TextSelect.tsx"],"names":[],"mappings":"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","sourcesContent":["import { useRef, useState, useMemo } from 'react';\nimport type { FC, MouseEvent, KeyboardEvent, FocusEvent } from 'react';\nimport type { Editor } from 'tinymce';\nimport styled, { css } from 'styled-components';\n\nimport {\n Popover,\n Icon,\n registerIcon,\n useOuterEvent,\n Menu,\n Button,\n defaultThemeProp,\n useI18n,\n Tooltip,\n calculateFontSize\n} from '@pega/cosmos-react-core';\nimport type { TranslationFunction, TranslationPack } from '@pega/cosmos-react-core';\nimport * as arrowMicroDownIcon from '@pega/cosmos-react-core/lib/components/Icon/icons/arrow-micro-down.icon';\n\nimport { getKeyCommand } from '../../RichTextEditor/Toolbar/utils';\n\nregisterIcon(arrowMicroDownIcon);\n\nconst StyledTextSelect = styled(Button)(({ theme }) => {\n const fontSizes = calculateFontSize(theme.base['font-size'], theme.base['font-scale']);\n return css`\n color: ${theme.base.palette['foreground-color']};\n display: inline-flex;\n align-items: center;\n border-radius: calc(0.25 * ${theme.base['border-radius']});\n height: calc(4 * ${theme.base.spacing});\n padding: calc(0.5 * ${theme.base.spacing});\n font-size: ${fontSizes.xxs};\n\n span {\n white-space: nowrap;\n }\n\n :focus {\n box-shadow: ${theme.base.shadow.focus};\n }\n `;\n});\n\nStyledTextSelect.defaultProps = defaultThemeProp;\n\nconst StyledSelectMenu = styled.div`\n min-width: 20ch;\n`;\n\nconst formatMapping = {\n p: 'normal',\n li: 'normal',\n ul: 'normal',\n ol: 'normal',\n div: 'normal',\n h1: 'heading-1',\n h2: 'heading-2',\n h3: 'heading-3',\n h4: 'heading-4',\n '': 'normal'\n} as const;\n\nconst normalTags = new Set(\n Object.entries(formatMapping)\n .filter(([, value]) => value === 'normal')\n .map(([key]) => key)\n);\n\ntype FormatType = keyof typeof formatMapping;\ntype Format = (typeof formatMapping)[FormatType];\n\nconst getTextCommand = (num: number, osx: boolean) => {\n return getKeyCommand(osx, ({ ctrl, alt }) => `${ctrl}${alt}${num}`);\n};\n\nexport const getTextFormats = (\n t: TranslationFunction<TranslationPack>,\n osx: boolean = false\n): { id: Format; text: string; subText: string; type: FormatType }[] => {\n return [\n {\n id: 'normal',\n text: t('rte_heading_style_normal'),\n subText: getTextCommand(0, osx),\n type: 'p'\n },\n {\n id: 'heading-1',\n text: t('rte_heading_style_heading_1'),\n subText: getTextCommand(1, osx),\n type: 'h1'\n },\n {\n id: 'heading-2',\n text: t('rte_heading_style_heading_2'),\n subText: getTextCommand(2, osx),\n type: 'h2'\n },\n {\n id: 'heading-3',\n text: t('rte_heading_style_heading_3'),\n subText: getTextCommand(3, osx),\n type: 'h3'\n },\n {\n id: 'heading-4',\n text: t('rte_heading_style_heading_4'),\n subText: getTextCommand(4, osx),\n type: 'h4'\n }\n ];\n};\n\nconst TextSelect: FC<{ osx: boolean; editor: Editor }> = ({ osx, editor, ...restProps }) => {\n const t = useI18n();\n const [open, setOpen] = useState(false);\n const selecting = useRef(false);\n const openedByClick = useRef(false);\n const buttonRef = useRef<HTMLButtonElement>(null);\n const popoverRef = useRef(null);\n const menuRef = useRef(null);\n\n const textFormats = useMemo(() => {\n return getTextFormats(t, osx);\n }, [t, osx]);\n\n useOuterEvent('click', [buttonRef, popoverRef, menuRef], () => {\n setOpen(false);\n });\n\n const onTextSelect = (type: FormatType, e: MouseEvent) => {\n e.stopPropagation();\n e.preventDefault();\n editor.execCommand('FormatBlock', false, type);\n if (!openedByClick.current) {\n buttonRef.current?.focus();\n }\n setOpen(false);\n selecting.current = true;\n setTimeout(() => {\n if (!editor.hasFocus() && openedByClick.current) {\n editor.focus();\n }\n }, 0);\n };\n\n const getParentTextFormat = (el: Element | Node): FormatType | undefined => {\n const elTagName = el.nodeName.toLowerCase() as FormatType;\n if (formatMapping[elTagName]) {\n return elTagName;\n }\n if (el.parentNode) {\n return getParentTextFormat(el.parentNode);\n }\n return undefined;\n };\n\n const activeFormat = (): FormatType | undefined => {\n const tag = editor.hasFocus()\n ? getParentTextFormat(editor.selection.getNode())\n : (editor.contentDocument?.body?.firstChild?.nodeName.toLowerCase() as\n | FormatType\n | undefined);\n\n if (tag && normalTags.has(tag)) {\n return 'p';\n }\n\n return tag;\n };\n\n const formatText = (() => {\n const activeFormatType = activeFormat();\n\n const unknown = t('rte_heading_style_unknown');\n\n if (!activeFormatType) return unknown;\n\n const format = formatMapping[activeFormatType];\n\n if (!format) return unknown;\n\n return textFormats.find(({ id }) => id === format)?.text ?? unknown;\n })();\n\n return (\n <>\n <StyledTextSelect\n {...restProps}\n variant='simple'\n type='button'\n icon={false}\n ref={buttonRef}\n onMouseDown={(e: MouseEvent) => {\n e.preventDefault();\n e.stopPropagation();\n setOpen(true);\n openedByClick.current = true;\n }}\n onKeyDown={(e: KeyboardEvent) => {\n if (e.key === 'Enter' && !selecting.current) {\n e.preventDefault();\n setOpen(true);\n openedByClick.current = false;\n } else if (e.key === 'Enter') {\n e.preventDefault();\n selecting.current = false;\n } else if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {\n setOpen(false);\n }\n }}\n onFocus={(e: FocusEvent) => {\n e.preventDefault();\n e.stopPropagation();\n }}\n onClick={(e: MouseEvent) => e.stopPropagation()}\n aria-expanded={open}\n aria-label={`${t('rte_text_formatting_toolbar')}. ${t(\n 'rte_heading_style'\n )}. ${formatText} ${t('selected').toLocaleLowerCase()}`}\n aria-haspopup\n >\n <span>{formatText}</span>\n <Icon name='arrow-micro-down' />\n </StyledTextSelect>\n {buttonRef.current && (\n <Tooltip target={buttonRef.current} showDelay='none' hideDelay='none'>\n {t('rte_heading_style')}\n </Tooltip>\n )}\n <Popover\n show={open}\n as={StyledSelectMenu}\n target={buttonRef.current}\n placement='bottom-start'\n ref={popoverRef}\n >\n <Menu\n items={textFormats.map(({ text, type, subText }) => ({\n id: type,\n primary: text,\n secondary: [subText],\n selected: type === activeFormat()\n }))}\n focusControlEl={buttonRef.current ?? undefined}\n mode='single-select'\n ref={menuRef}\n onItemClick={onTextSelect as (id: string, e: MouseEvent) => void}\n />\n </Popover>\n </>\n );\n};\n\nexport default TextSelect;\n"]}
1
+ {"version":3,"file":"TextSelect.js","sourceRoot":"","sources":["../../../../src/components/Editor/Toolbar/TextSelect.tsx"],"names":[],"mappings":"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","sourcesContent":["import { useRef, useState, useMemo, useCallback } from 'react';\nimport type { MouseEvent, KeyboardEvent, FocusEvent } from 'react';\nimport type { Editor as TiptapEditor } from '@tiptap/core';\nimport styled, { css } from 'styled-components';\n\nimport {\n Popover,\n Icon,\n registerIcon,\n useOuterEvent,\n Menu,\n Button,\n defaultThemeProp,\n useI18n,\n Tooltip,\n calculateFontSize,\n isInstance\n} from '@pega/cosmos-react-core';\nimport type { TranslationFunction, TranslationPack } from '@pega/cosmos-react-core';\nimport * as arrowMicroDownIcon from '@pega/cosmos-react-core/lib/components/Icon/icons/arrow-micro-down.icon';\n\nimport { getKeyCommand } from '../../RichTextEditor/Toolbar/utils';\nimport useEscapeKey from '../hooks/useEscapeKey';\nimport useCloseOnEditorClick from '../hooks/useCloseOnEditorClick';\n\nregisterIcon(arrowMicroDownIcon);\n\nconst StyledTextSelect = styled(Button)(({ theme }) => {\n const fontSizes = calculateFontSize(theme.base['font-size'], theme.base['font-scale']);\n return css`\n color: ${theme.base.palette['foreground-color']};\n display: inline-flex;\n align-items: center;\n border-radius: calc(0.25 * ${theme.base['border-radius']});\n height: calc(4 * ${theme.base.spacing});\n padding: calc(0.5 * ${theme.base.spacing});\n font-size: ${fontSizes.xxs};\n\n span {\n white-space: nowrap;\n }\n\n :focus {\n box-shadow: ${theme.base.shadow.focus};\n }\n `;\n});\n\nStyledTextSelect.defaultProps = defaultThemeProp;\n\nconst StyledSelectMenu = styled.div`\n min-width: 20ch;\n`;\n\nStyledSelectMenu.defaultProps = defaultThemeProp;\n\nconst formatMapping = {\n p: 'normal',\n li: 'normal',\n ul: 'normal',\n ol: 'normal',\n div: 'normal',\n h1: 'heading-1',\n h2: 'heading-2',\n h3: 'heading-3',\n h4: 'heading-4',\n '': 'normal'\n} as const;\n\ntype FormatType = keyof typeof formatMapping;\ntype Format = (typeof formatMapping)[FormatType];\n\nconst getTextCommand = (num: number, osx: boolean) => {\n return getKeyCommand(osx, ({ ctrl, alt }) => `${ctrl}${alt}${num}`);\n};\n\nexport const getTextFormats = (\n t: TranslationFunction<TranslationPack>,\n osx: boolean = false\n): { id: Format; text: string; subText: string; type: FormatType }[] => {\n return [\n {\n id: 'normal',\n text: t('rte_heading_style_normal'),\n subText: getTextCommand(0, osx),\n type: 'p'\n },\n {\n id: 'heading-1',\n text: t('rte_heading_style_heading_1'),\n subText: getTextCommand(1, osx),\n type: 'h1'\n },\n {\n id: 'heading-2',\n text: t('rte_heading_style_heading_2'),\n subText: getTextCommand(2, osx),\n type: 'h2'\n },\n {\n id: 'heading-3',\n text: t('rte_heading_style_heading_3'),\n subText: getTextCommand(3, osx),\n type: 'h3'\n },\n {\n id: 'heading-4',\n text: t('rte_heading_style_heading_4'),\n subText: getTextCommand(4, osx),\n type: 'h4'\n }\n ];\n};\n\nconst TextSelect = ({ osx, editor, ...restProps }: { osx: boolean; editor: TiptapEditor }) => {\n const t = useI18n();\n const [open, setOpen] = useState(false);\n const selecting = useRef(false);\n const openedByClick = useRef(false);\n const buttonRef = useRef<HTMLButtonElement>(null);\n const popoverRef = useRef<HTMLDivElement>(null);\n const menuRef = useRef<HTMLDivElement>(null);\n\n const textFormats = useMemo(() => {\n return getTextFormats(t, osx);\n }, [t, osx]);\n\n useOuterEvent('mousedown', [buttonRef, popoverRef, menuRef], () => {\n setOpen(false);\n });\n\n const handleEscapeClose = useCallback(() => {\n setOpen(false);\n buttonRef.current?.focus();\n }, []);\n\n useEscapeKey(open, handleEscapeClose, editor);\n useCloseOnEditorClick(open, handleEscapeClose);\n\n const onTextSelect = (id: string, e: MouseEvent) => {\n e.stopPropagation();\n e.preventDefault();\n // Tiptap API\n const chain = editor.chain().focus();\n if (id === 'p') {\n chain.setParagraph().run();\n } else if (id === 'h1') {\n chain.setHeading({ level: 1 }).run();\n } else if (id === 'h2') {\n chain.setHeading({ level: 2 }).run();\n } else if (id === 'h3') {\n chain.setHeading({ level: 3 }).run();\n } else if (id === 'h4') {\n chain.setHeading({ level: 4 }).run();\n }\n if (!openedByClick.current) {\n buttonRef.current?.focus();\n }\n setOpen(false);\n selecting.current = true;\n setTimeout(() => {\n selecting.current = false;\n if (!editor.isFocused && openedByClick.current) {\n editor.commands.focus();\n }\n }, 0);\n };\n\n const activeFormat = (): FormatType | undefined => {\n // Tiptap API\n if (editor.isActive('heading', { level: 1 })) return 'h1';\n if (editor.isActive('heading', { level: 2 })) return 'h2';\n if (editor.isActive('heading', { level: 3 })) return 'h3';\n if (editor.isActive('heading', { level: 4 })) return 'h4';\n if (editor.isActive('paragraph')) return 'p';\n return 'p';\n };\n\n const formatText = (() => {\n const activeFormatType = activeFormat();\n\n const unknown = t('rte_heading_style_unknown');\n\n if (!activeFormatType) return unknown;\n\n const format = formatMapping[activeFormatType];\n\n if (!format) return unknown;\n\n return textFormats.find(({ id }) => id === format)?.text ?? unknown;\n })();\n\n return (\n <>\n <StyledTextSelect\n {...restProps}\n variant='simple'\n type='button'\n icon={false}\n ref={buttonRef}\n data-toolbar-item='true'\n onMouseDown={(e: MouseEvent) => {\n e.preventDefault();\n if (!open) {\n openedByClick.current = true;\n }\n setOpen(!open);\n }}\n onKeyDown={(e: KeyboardEvent) => {\n if (e.key === 'Enter' && !selecting.current) {\n e.preventDefault();\n setOpen(true);\n openedByClick.current = false;\n } else if (e.key === 'Enter') {\n e.preventDefault();\n selecting.current = false;\n } else if (e.key === 'ArrowLeft' || e.key === 'ArrowRight') {\n setOpen(false);\n } else if (e.key === 'Escape' && open) {\n e.preventDefault();\n setOpen(false);\n }\n }}\n onFocus={(e: FocusEvent) => {\n e.preventDefault();\n e.stopPropagation();\n }}\n onBlur={(e: FocusEvent) => {\n const { relatedTarget } = e;\n if (\n isInstance(relatedTarget, Node) &&\n !buttonRef.current?.contains(relatedTarget) &&\n !popoverRef.current?.contains(relatedTarget) &&\n !menuRef.current?.contains(relatedTarget)\n ) {\n setOpen(false);\n }\n }}\n onClick={(e: MouseEvent) => e.stopPropagation()}\n aria-expanded={open}\n aria-label={`${t('rte_text_formatting_toolbar')}. ${t(\n 'rte_heading_style'\n )}. ${formatText} ${t('selected').toLocaleLowerCase()}`}\n aria-haspopup\n >\n <span>{formatText}</span>\n <Icon name='arrow-micro-down' />\n </StyledTextSelect>\n {buttonRef.current && (\n <Tooltip target={buttonRef.current} showDelay='none' hideDelay='none'>\n {t('rte_heading_style')}\n </Tooltip>\n )}\n <Popover\n show={open}\n as={StyledSelectMenu}\n target={buttonRef.current}\n placement='bottom-start'\n ref={popoverRef}\n >\n <Menu\n items={textFormats.map(({ text, type, subText }) => ({\n id: type,\n primary: text,\n secondary: [subText],\n selected: type === activeFormat()\n }))}\n focusControlEl={buttonRef.current ?? undefined}\n mode='single-select'\n ref={menuRef}\n onItemClick={onTextSelect}\n />\n </Popover>\n </>\n );\n};\n\nexport default TextSelect;\n"]}
@@ -1,17 +1,28 @@
1
- import type { FC } from 'react';
2
- import type { Editor } from 'tinymce';
3
- import type { TestIdProp } from '@pega/cosmos-react-core';
1
+ import type { ReactNode } from 'react';
2
+ import type { Editor as TiptapEditor } from '@tiptap/core';
3
+ import type { AIAction, TestIdProp } from '@pega/cosmos-react-core';
4
4
  import type { Features } from '../../RichTextEditor/Toolbar/Toolbar.types';
5
5
  import type { CustomAction } from '../Editor.types';
6
6
  import type { elements } from './Toolbar.test-ids';
7
7
  export interface ToolbarProps extends TestIdProp<typeof elements> {
8
8
  features: Features[];
9
9
  sticky?: boolean;
10
- editor: Editor;
10
+ editor: TiptapEditor;
11
11
  customActions?: CustomAction[];
12
+ imageInsertionMode: 'file' | 'url' | 'all';
13
+ onRewriteClick?: (originalText: string, rewriteAction: AIAction, additionalInstructions: string, onSuccess: (rewrittenText: string) => void) => void;
14
+ renderSuggestionEditor?: (props: {
15
+ defaultValue?: string;
16
+ disabled: boolean;
17
+ readOnly: boolean;
18
+ onGetContent: (getContent: () => string) => void;
19
+ onContentChange: (hasContent: boolean) => void;
20
+ }) => ReactNode;
21
+ sourceMode?: boolean;
22
+ onSourceModeToggle?: (isSourceMode: boolean) => void;
12
23
  }
13
- declare const _default: FC<ToolbarProps> & {
14
- getTestIds: (testIdProp?: TestIdProp["testId"]) => import("@pega/cosmos-react-core").TestIdsRecord<readonly ["toolbar", "text-styles", "bold", "italic", "strike-through", "bulleted-list", "numbered-list", "indent", "unindent", "link", "image"]>;
24
+ declare const _default: (({ testId, features, sticky, editor, customActions, imageInsertionMode, onRewriteClick, renderSuggestionEditor, sourceMode, onSourceModeToggle, ...restProps }: ToolbarProps) => import("react/jsx-runtime").JSX.Element) & {
25
+ getTestIds: (testIdProp?: TestIdProp["testId"]) => import("@pega/cosmos-react-core").TestIdsRecord<readonly ["toolbar", "text-styles", "bold", "italic", "strike-through", "underline", "subscript", "superscript", "font-family", "font-size", "text-color", "background-color", "alignment", "align-left", "align-center", "align-right", "bulleted-list", "numbered-list", "indent", "unindent", "table", "link", "image", "source-code", "ai-rewrite", "overflow", "word-count"]>;
15
26
  };
16
27
  export default _default;
17
28
  //# sourceMappingURL=Toolbar.d.ts.map