@uipath/apollo-react 3.66.1 → 3.68.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 (38) hide show
  1. package/dist/canvas/components/StickyNoteNode/FormattingToolbar.cjs +149 -0
  2. package/dist/canvas/components/StickyNoteNode/FormattingToolbar.d.ts +12 -0
  3. package/dist/canvas/components/StickyNoteNode/FormattingToolbar.d.ts.map +1 -0
  4. package/dist/canvas/components/StickyNoteNode/FormattingToolbar.js +115 -0
  5. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.cjs +75 -12
  6. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.d.ts.map +1 -1
  7. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.js +75 -12
  8. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.styles.cjs +54 -7
  9. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.styles.d.ts +16 -0
  10. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.styles.d.ts.map +1 -1
  11. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.styles.js +40 -2
  12. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.types.d.ts +6 -0
  13. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.types.d.ts.map +1 -1
  14. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.utils.cjs +8 -0
  15. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.utils.d.ts +2 -0
  16. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.utils.d.ts.map +1 -1
  17. package/dist/canvas/components/StickyNoteNode/StickyNoteNode.utils.js +3 -1
  18. package/dist/canvas/components/StickyNoteNode/markdown-formatting/detectActiveFormats.cjs +69 -0
  19. package/dist/canvas/components/StickyNoteNode/markdown-formatting/detectActiveFormats.d.ts +11 -0
  20. package/dist/canvas/components/StickyNoteNode/markdown-formatting/detectActiveFormats.d.ts.map +1 -0
  21. package/dist/canvas/components/StickyNoteNode/markdown-formatting/detectActiveFormats.js +32 -0
  22. package/dist/canvas/components/StickyNoteNode/markdown-formatting/index.cjs +68 -0
  23. package/dist/canvas/components/StickyNoteNode/markdown-formatting/index.d.ts +4 -0
  24. package/dist/canvas/components/StickyNoteNode/markdown-formatting/index.d.ts.map +1 -0
  25. package/dist/canvas/components/StickyNoteNode/markdown-formatting/index.js +4 -0
  26. package/dist/canvas/components/StickyNoteNode/markdown-formatting/inlineFormatting.cjs +173 -0
  27. package/dist/canvas/components/StickyNoteNode/markdown-formatting/inlineFormatting.d.ts +5 -0
  28. package/dist/canvas/components/StickyNoteNode/markdown-formatting/inlineFormatting.d.ts.map +1 -0
  29. package/dist/canvas/components/StickyNoteNode/markdown-formatting/inlineFormatting.js +133 -0
  30. package/dist/canvas/components/StickyNoteNode/markdown-formatting/listFormatting.cjs +175 -0
  31. package/dist/canvas/components/StickyNoteNode/markdown-formatting/listFormatting.d.ts +8 -0
  32. package/dist/canvas/components/StickyNoteNode/markdown-formatting/listFormatting.d.ts.map +1 -0
  33. package/dist/canvas/components/StickyNoteNode/markdown-formatting/listFormatting.js +126 -0
  34. package/dist/canvas/components/StickyNoteNode/useMarkdownShortcuts.cjs +62 -0
  35. package/dist/canvas/components/StickyNoteNode/useMarkdownShortcuts.d.ts +4 -0
  36. package/dist/canvas/components/StickyNoteNode/useMarkdownShortcuts.d.ts.map +1 -0
  37. package/dist/canvas/components/StickyNoteNode/useMarkdownShortcuts.js +28 -0
  38. package/package.json +1 -1
@@ -33,18 +33,21 @@ var __webpack_require__ = {};
33
33
  var __webpack_exports__ = {};
34
34
  __webpack_require__.r(__webpack_exports__);
35
35
  __webpack_require__.d(__webpack_exports__, {
36
- ColorPickerPanel: ()=>ColorPickerPanel,
37
- StickyNoteTextArea: ()=>StickyNoteTextArea,
36
+ stickyNoteGlobalStyles: ()=>stickyNoteGlobalStyles,
38
37
  STICKY_NOTE_BELOW_EDGE_Z_INDEX: ()=>STICKY_NOTE_BELOW_EDGE_Z_INDEX,
39
38
  StickyNoteMarkdown: ()=>StickyNoteMarkdown,
40
- TopCornerIndicators: ()=>TopCornerIndicators,
41
- stickyNoteGlobalStyles: ()=>stickyNoteGlobalStyles,
42
39
  RESIZE_CONTROL_Z_INDEX: ()=>RESIZE_CONTROL_Z_INDEX,
43
40
  StickyNoteWrapper: ()=>StickyNoteWrapper,
44
41
  ResizeHandle: ()=>ResizeHandle,
45
42
  StickyNoteContainer: ()=>StickyNoteContainer,
46
- ColorOption: ()=>ColorOption,
47
- BottomCornerIndicators: ()=>BottomCornerIndicators
43
+ ToolbarSeparator: ()=>ToolbarSeparator,
44
+ BottomCornerIndicators: ()=>BottomCornerIndicators,
45
+ StickyNoteTextArea: ()=>StickyNoteTextArea,
46
+ FormattingToolbarContainer: ()=>FormattingToolbarContainer,
47
+ ColorPickerPanel: ()=>ColorPickerPanel,
48
+ FormattingButton: ()=>FormattingButton,
49
+ TopCornerIndicators: ()=>TopCornerIndicators,
50
+ ColorOption: ()=>ColorOption
48
51
  });
49
52
  const react_namespaceObject = require("@emotion/react");
50
53
  const styled_namespaceObject = require("@emotion/styled");
@@ -98,7 +101,9 @@ const StickyNoteContainer = styled_default().div`
98
101
  background-color: ${(props)=>props.backgroundColor};
99
102
  border-radius: 16px;
100
103
  border: 2px solid ${(props)=>props.borderColor};
101
- padding: 16px;
104
+ padding: ${(props)=>props.isEditing ? '8px' : '16px'} 16px 16px 16px;
105
+ display: flex;
106
+ flex-direction: column;
102
107
  cursor: ${(props)=>props.isEditing ? 'text' : 'move'};
103
108
  position: relative;
104
109
  /* Ensure resize handles are clickable */
@@ -111,6 +116,8 @@ const StickyNoteContainer = styled_default().div`
111
116
  }
112
117
  `;
113
118
  const StickyNoteTextArea = styled_default().textarea`
119
+ flex: 1;
120
+ min-height: 0;
114
121
  ${stickyNoteContentStyles}
115
122
 
116
123
  background: transparent;
@@ -132,6 +139,8 @@ const StickyNoteTextArea = styled_default().textarea`
132
139
  }
133
140
  `;
134
141
  const StickyNoteMarkdown = styled_default().div`
142
+ flex: 1;
143
+ min-height: 0;
135
144
  ${stickyNoteContentStyles}
136
145
 
137
146
  word-wrap: break-word;
@@ -365,9 +374,43 @@ const ColorOption = styled_default().button`
365
374
  outline-offset: 1px;
366
375
  }
367
376
  `;
377
+ const FormattingToolbarContainer = styled_default().div`
378
+ display: flex;
379
+ align-items: center;
380
+ gap: 1px;
381
+ padding-bottom: 4px;
382
+ margin-bottom: 8px;
383
+ border-bottom: 1px solid ${(props)=>`color-mix(in srgb, ${props.borderColor} 30%, transparent)`};
384
+ flex-shrink: 0;
385
+ `;
386
+ const FormattingButton = styled_default().button`
387
+ width: 28px;
388
+ height: 28px;
389
+ display: flex;
390
+ align-items: center;
391
+ justify-content: center;
392
+ border: none;
393
+ border-radius: 4px;
394
+ cursor: pointer;
395
+ padding: 0;
396
+ color: var(--uix-canvas-foreground);
397
+ background: ${(props)=>props.isActive ? 'color-mix(in srgb, var(--uix-canvas-primary) 30%, transparent)' : 'transparent'};
398
+
399
+ &:hover {
400
+ background: ${(props)=>props.isActive ? 'color-mix(in srgb, var(--uix-canvas-primary) 40%, transparent)' : 'color-mix(in srgb, var(--uix-canvas-foreground) 10%, transparent)'};
401
+ }
402
+ `;
403
+ const ToolbarSeparator = styled_default().div`
404
+ width: 1px;
405
+ height: 16px;
406
+ background: color-mix(in srgb, var(--uix-canvas-foreground) 15%, transparent);
407
+ margin: 0 4px;
408
+ `;
368
409
  exports.BottomCornerIndicators = __webpack_exports__.BottomCornerIndicators;
369
410
  exports.ColorOption = __webpack_exports__.ColorOption;
370
411
  exports.ColorPickerPanel = __webpack_exports__.ColorPickerPanel;
412
+ exports.FormattingButton = __webpack_exports__.FormattingButton;
413
+ exports.FormattingToolbarContainer = __webpack_exports__.FormattingToolbarContainer;
371
414
  exports.RESIZE_CONTROL_Z_INDEX = __webpack_exports__.RESIZE_CONTROL_Z_INDEX;
372
415
  exports.ResizeHandle = __webpack_exports__.ResizeHandle;
373
416
  exports.STICKY_NOTE_BELOW_EDGE_Z_INDEX = __webpack_exports__.STICKY_NOTE_BELOW_EDGE_Z_INDEX;
@@ -375,12 +418,15 @@ exports.StickyNoteContainer = __webpack_exports__.StickyNoteContainer;
375
418
  exports.StickyNoteMarkdown = __webpack_exports__.StickyNoteMarkdown;
376
419
  exports.StickyNoteTextArea = __webpack_exports__.StickyNoteTextArea;
377
420
  exports.StickyNoteWrapper = __webpack_exports__.StickyNoteWrapper;
421
+ exports.ToolbarSeparator = __webpack_exports__.ToolbarSeparator;
378
422
  exports.TopCornerIndicators = __webpack_exports__.TopCornerIndicators;
379
423
  exports.stickyNoteGlobalStyles = __webpack_exports__.stickyNoteGlobalStyles;
380
424
  for(var __rspack_i in __webpack_exports__)if (-1 === [
381
425
  "BottomCornerIndicators",
382
426
  "ColorOption",
383
427
  "ColorPickerPanel",
428
+ "FormattingButton",
429
+ "FormattingToolbarContainer",
384
430
  "RESIZE_CONTROL_Z_INDEX",
385
431
  "ResizeHandle",
386
432
  "STICKY_NOTE_BELOW_EDGE_Z_INDEX",
@@ -388,6 +434,7 @@ for(var __rspack_i in __webpack_exports__)if (-1 === [
388
434
  "StickyNoteMarkdown",
389
435
  "StickyNoteTextArea",
390
436
  "StickyNoteWrapper",
437
+ "ToolbarSeparator",
391
438
  "TopCornerIndicators",
392
439
  "stickyNoteGlobalStyles"
393
440
  ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
@@ -53,4 +53,20 @@ export declare const ColorOption: import("@emotion/styled").StyledComponent<{
53
53
  color: string;
54
54
  isSelected: boolean;
55
55
  }, import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {}>;
56
+ export declare const FormattingToolbarContainer: import("@emotion/styled").StyledComponent<{
57
+ theme?: import("@emotion/react").Theme;
58
+ as?: React.ElementType;
59
+ } & {
60
+ borderColor: string;
61
+ }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
62
+ export declare const FormattingButton: import("@emotion/styled").StyledComponent<{
63
+ theme?: import("@emotion/react").Theme;
64
+ as?: React.ElementType;
65
+ } & {
66
+ isActive: boolean;
67
+ }, import("react").DetailedHTMLProps<import("react").ButtonHTMLAttributes<HTMLButtonElement>, HTMLButtonElement>, {}>;
68
+ export declare const ToolbarSeparator: import("@emotion/styled").StyledComponent<{
69
+ theme?: import("@emotion/react").Theme;
70
+ as?: React.ElementType;
71
+ }, import("react").DetailedHTMLProps<import("react").HTMLAttributes<HTMLDivElement>, HTMLDivElement>, {}>;
56
72
  //# sourceMappingURL=StickyNoteNode.styles.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"StickyNoteNode.styles.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/StickyNoteNode/StickyNoteNode.styles.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,8BAA8B,MAAM,CAAC;AA4BlD,eAAO,MAAM,sBAAsB,MAAM,CAAC;AAE1C,eAAO,MAAM,sBAAsB,2CAUlC,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;yGAI7B,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;;iBACjB,MAAM;qBACF,MAAM;eACZ,OAAO;eACP,OAAO;yGAqBnB,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;;eAAgC,OAAO;2HAoBrE,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;yGA4H9B,CAAC;AAEF,eAAO,MAAM,YAAY;;;;eAA2B,OAAO;aAAW,MAAM;yGAW3E,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;;eAA2B,OAAO;yGA+BjE,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;eAA2B,OAAO;yGA+BpE,CAAC;AAEF,eAAO,MAAM,gBAAgB;;UAa5B,CAAC;AAEF,eAAO,MAAM,WAAW;;;;WAA0B,MAAM;gBAAc,OAAO;qHAkB5E,CAAC"}
1
+ {"version":3,"file":"StickyNoteNode.styles.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/StickyNoteNode/StickyNoteNode.styles.ts"],"names":[],"mappings":"AAKA,eAAO,MAAM,8BAA8B,MAAM,CAAC;AA4BlD,eAAO,MAAM,sBAAsB,MAAM,CAAC;AAE1C,eAAO,MAAM,sBAAsB,2CAUlC,CAAC;AAEF,eAAO,MAAM,iBAAiB;;;yGAI7B,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;;iBACjB,MAAM;qBACF,MAAM;eACZ,OAAO;eACP,OAAO;yGAuBnB,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;;eAAgC,OAAO;2HAsBrE,CAAC;AAEF,eAAO,MAAM,kBAAkB;;;yGA8H9B,CAAC;AAEF,eAAO,MAAM,YAAY;;;;eAA2B,OAAO;aAAW,MAAM;yGAW3E,CAAC;AAEF,eAAO,MAAM,mBAAmB;;;;eAA2B,OAAO;yGA+BjE,CAAC;AAEF,eAAO,MAAM,sBAAsB;;;;eAA2B,OAAO;yGA+BpE,CAAC;AAEF,eAAO,MAAM,gBAAgB;;UAa5B,CAAC;AAEF,eAAO,MAAM,WAAW;;;;WAA0B,MAAM;gBAAc,OAAO;qHAkB5E,CAAC;AAEF,eAAO,MAAM,0BAA0B;;;;iBAA6B,MAAM;yGAQzE,CAAC;AAEF,eAAO,MAAM,gBAAgB;;;;cAA6B,OAAO;qHAsBhE,CAAC;AAEF,eAAO,MAAM,gBAAgB;;;yGAK5B,CAAC"}
@@ -49,7 +49,9 @@ const StickyNoteContainer = styled.div`
49
49
  background-color: ${(props)=>props.backgroundColor};
50
50
  border-radius: 16px;
51
51
  border: 2px solid ${(props)=>props.borderColor};
52
- padding: 16px;
52
+ padding: ${(props)=>props.isEditing ? '8px' : '16px'} 16px 16px 16px;
53
+ display: flex;
54
+ flex-direction: column;
53
55
  cursor: ${(props)=>props.isEditing ? 'text' : 'move'};
54
56
  position: relative;
55
57
  /* Ensure resize handles are clickable */
@@ -62,6 +64,8 @@ const StickyNoteContainer = styled.div`
62
64
  }
63
65
  `;
64
66
  const StickyNoteTextArea = styled.textarea`
67
+ flex: 1;
68
+ min-height: 0;
65
69
  ${stickyNoteContentStyles}
66
70
 
67
71
  background: transparent;
@@ -83,6 +87,8 @@ const StickyNoteTextArea = styled.textarea`
83
87
  }
84
88
  `;
85
89
  const StickyNoteMarkdown = styled.div`
90
+ flex: 1;
91
+ min-height: 0;
86
92
  ${stickyNoteContentStyles}
87
93
 
88
94
  word-wrap: break-word;
@@ -316,4 +322,36 @@ const ColorOption = styled.button`
316
322
  outline-offset: 1px;
317
323
  }
318
324
  `;
319
- export { BottomCornerIndicators, ColorOption, ColorPickerPanel, RESIZE_CONTROL_Z_INDEX, ResizeHandle, STICKY_NOTE_BELOW_EDGE_Z_INDEX, StickyNoteContainer, StickyNoteMarkdown, StickyNoteTextArea, StickyNoteWrapper, TopCornerIndicators, stickyNoteGlobalStyles };
325
+ const FormattingToolbarContainer = styled.div`
326
+ display: flex;
327
+ align-items: center;
328
+ gap: 1px;
329
+ padding-bottom: 4px;
330
+ margin-bottom: 8px;
331
+ border-bottom: 1px solid ${(props)=>`color-mix(in srgb, ${props.borderColor} 30%, transparent)`};
332
+ flex-shrink: 0;
333
+ `;
334
+ const FormattingButton = styled.button`
335
+ width: 28px;
336
+ height: 28px;
337
+ display: flex;
338
+ align-items: center;
339
+ justify-content: center;
340
+ border: none;
341
+ border-radius: 4px;
342
+ cursor: pointer;
343
+ padding: 0;
344
+ color: var(--uix-canvas-foreground);
345
+ background: ${(props)=>props.isActive ? 'color-mix(in srgb, var(--uix-canvas-primary) 30%, transparent)' : 'transparent'};
346
+
347
+ &:hover {
348
+ background: ${(props)=>props.isActive ? 'color-mix(in srgb, var(--uix-canvas-primary) 40%, transparent)' : 'color-mix(in srgb, var(--uix-canvas-foreground) 10%, transparent)'};
349
+ }
350
+ `;
351
+ const ToolbarSeparator = styled.div`
352
+ width: 1px;
353
+ height: 16px;
354
+ background: color-mix(in srgb, var(--uix-canvas-foreground) 15%, transparent);
355
+ margin: 0 4px;
356
+ `;
357
+ export { BottomCornerIndicators, ColorOption, ColorPickerPanel, FormattingButton, FormattingToolbarContainer, RESIZE_CONTROL_Z_INDEX, ResizeHandle, STICKY_NOTE_BELOW_EDGE_Z_INDEX, StickyNoteContainer, StickyNoteMarkdown, StickyNoteTextArea, StickyNoteWrapper, ToolbarSeparator, TopCornerIndicators, stickyNoteGlobalStyles };
@@ -12,4 +12,10 @@ export interface StickyNoteData extends Record<string, unknown> {
12
12
  autoFocus?: boolean;
13
13
  }
14
14
  export declare function withAlpha(hex: string, alpha?: number): string;
15
+ export type TextSelection = {
16
+ value: string;
17
+ selectionStart: number;
18
+ selectionEnd: number;
19
+ };
20
+ export type FormattingAction = 'bold' | 'italic' | 'strikethrough' | 'bulletList' | 'numberedList';
15
21
  //# sourceMappingURL=StickyNoteNode.types.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"StickyNoteNode.types.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/StickyNoteNode/StickyNoteNode.types.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,kBAAkB;;;;;;CAMrB,CAAC;AAEX,MAAM,MAAM,eAAe,GAAG,MAAM,OAAO,kBAAkB,CAAC;AAE9D,MAAM,WAAW,cAAe,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAC7D,KAAK,CAAC,EAAE,eAAe,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAWD,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,GAAE,MAA6B,GAAG,MAAM,CAyBnF"}
1
+ {"version":3,"file":"StickyNoteNode.types.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/StickyNoteNode/StickyNoteNode.types.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,kBAAkB;;;;;;CAMrB,CAAC;AAEX,MAAM,MAAM,eAAe,GAAG,MAAM,OAAO,kBAAkB,CAAC;AAE9D,MAAM,WAAW,cAAe,SAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC;IAC7D,KAAK,CAAC,EAAE,eAAe,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,CAAC;IAEjB,SAAS,CAAC,EAAE,OAAO,CAAC;CACrB;AAWD,wBAAgB,SAAS,CAAC,GAAG,EAAE,MAAM,EAAE,KAAK,GAAE,MAA6B,GAAG,MAAM,CAyBnF;AAGD,MAAM,MAAM,aAAa,GAAG;IAC1B,KAAK,EAAE,MAAM,CAAC;IACd,cAAc,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AAGF,MAAM,MAAM,gBAAgB,GAAG,MAAM,GAAG,QAAQ,GAAG,eAAe,GAAG,YAAY,GAAG,cAAc,CAAC"}
@@ -24,6 +24,8 @@ var __webpack_require__ = {};
24
24
  var __webpack_exports__ = {};
25
25
  __webpack_require__.r(__webpack_exports__);
26
26
  __webpack_require__.d(__webpack_exports__, {
27
+ getModifierKey: ()=>getModifierKey,
28
+ isMac: ()=>isMac,
27
29
  preserveNewlines: ()=>preserveNewlines
28
30
  });
29
31
  const preserveNewlines = (markdown)=>{
@@ -39,8 +41,14 @@ const preserveNewlines = (markdown)=>{
39
41
  result = result.replace(/%%CODE_BLOCK_(\d+)%%/g, (_, i)=>codeBlocks[Number(i)] ?? '');
40
42
  return result;
41
43
  };
44
+ const isMac = ()=>"u" > typeof navigator && navigator.platform.includes('Mac');
45
+ const getModifierKey = ()=>isMac() ? '⌘' : 'Ctrl';
46
+ exports.getModifierKey = __webpack_exports__.getModifierKey;
47
+ exports.isMac = __webpack_exports__.isMac;
42
48
  exports.preserveNewlines = __webpack_exports__.preserveNewlines;
43
49
  for(var __rspack_i in __webpack_exports__)if (-1 === [
50
+ "getModifierKey",
51
+ "isMac",
44
52
  "preserveNewlines"
45
53
  ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
46
54
  Object.defineProperty(exports, '__esModule', {
@@ -1,2 +1,4 @@
1
1
  export declare const preserveNewlines: (markdown: string) => string;
2
+ export declare const isMac: () => boolean;
3
+ export declare const getModifierKey: () => string;
2
4
  //# sourceMappingURL=StickyNoteNode.utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"StickyNoteNode.utils.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/StickyNoteNode/StickyNoteNode.utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,gBAAgB,GAAI,UAAU,MAAM,KAAG,MAqBnD,CAAC"}
1
+ {"version":3,"file":"StickyNoteNode.utils.d.ts","sourceRoot":"","sources":["../../../../src/canvas/components/StickyNoteNode/StickyNoteNode.utils.ts"],"names":[],"mappings":"AAEA,eAAO,MAAM,gBAAgB,GAAI,UAAU,MAAM,KAAG,MAqBnD,CAAC;AAOF,eAAO,MAAM,KAAK,QAAO,OAExB,CAAC;AAOF,eAAO,MAAM,cAAc,QAAO,MAEjC,CAAC"}
@@ -11,4 +11,6 @@ const preserveNewlines = (markdown)=>{
11
11
  result = result.replace(/%%CODE_BLOCK_(\d+)%%/g, (_, i)=>codeBlocks[Number(i)] ?? '');
12
12
  return result;
13
13
  };
14
- export { preserveNewlines };
14
+ const isMac = ()=>"u" > typeof navigator && navigator.platform.includes('Mac');
15
+ const getModifierKey = ()=>isMac() ? '⌘' : 'Ctrl';
16
+ export { getModifierKey, isMac, preserveNewlines };
@@ -0,0 +1,69 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ detectActiveFormats: ()=>detectActiveFormats,
28
+ activeFormatsEqual: ()=>activeFormatsEqual
29
+ });
30
+ const external_listFormatting_cjs_namespaceObject = require("./listFormatting.cjs");
31
+ function activeFormatsEqual(a, b) {
32
+ return a.bold === b.bold && a.italic === b.italic && a.strikethrough === b.strikethrough && a.bulletList === b.bulletList && a.numberedList === b.numberedList;
33
+ }
34
+ function detectActiveFormats(input) {
35
+ const { value, selectionStart } = input;
36
+ const lineStart = value.lastIndexOf('\n', selectionStart - 1) + 1;
37
+ let lineEnd = value.indexOf('\n', selectionStart);
38
+ if (-1 === lineEnd) lineEnd = value.length;
39
+ const currentLine = value.slice(lineStart, lineEnd);
40
+ const cursorInLine = selectionStart - lineStart;
41
+ const textBefore = currentLine.slice(0, cursorInLine);
42
+ const textAfter = currentLine.slice(cursorInLine);
43
+ const bold = /\*\*(?:[^*\n]|\*(?!\*))*$/.test(textBefore) && /^(?:[^*\n]|\*(?!\*))*\*\*/.test(textAfter);
44
+ const strikethrough = /~~[^~\n]*$/.test(textBefore) && /^[^~\n]*~~/.test(textAfter);
45
+ const italicBefore = /(?<!\*)\*(?!\*)(?:[^*\n]|\*\*)*$/.test(textBefore);
46
+ const italicAfter = /^(?:[^*\n]|\*\*)*(?<!\*)\*(?!\*)/.test(textAfter);
47
+ let italic = italicBefore && italicAfter;
48
+ if (!italic && bold) {
49
+ const beforeStars = /(\*{3,})[^*\n]*$/.exec(textBefore);
50
+ const afterStars = /^[^*\n]*(\*{3,})/.exec(textAfter);
51
+ if (beforeStars && afterStars && beforeStars[1].length % 2 === 1 && afterStars[1].length % 2 === 1) italic = true;
52
+ }
53
+ return {
54
+ bold,
55
+ italic,
56
+ strikethrough,
57
+ bulletList: external_listFormatting_cjs_namespaceObject.BULLET_PREFIX.test(currentLine),
58
+ numberedList: external_listFormatting_cjs_namespaceObject.NUMBERED_PREFIX.test(currentLine)
59
+ };
60
+ }
61
+ exports.activeFormatsEqual = __webpack_exports__.activeFormatsEqual;
62
+ exports.detectActiveFormats = __webpack_exports__.detectActiveFormats;
63
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
64
+ "activeFormatsEqual",
65
+ "detectActiveFormats"
66
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
67
+ Object.defineProperty(exports, '__esModule', {
68
+ value: true
69
+ });
@@ -0,0 +1,11 @@
1
+ import type { TextSelection } from '../StickyNoteNode.types';
2
+ export type ActiveFormats = {
3
+ bold: boolean;
4
+ italic: boolean;
5
+ strikethrough: boolean;
6
+ bulletList: boolean;
7
+ numberedList: boolean;
8
+ };
9
+ export declare function activeFormatsEqual(a: ActiveFormats, b: ActiveFormats): boolean;
10
+ export declare function detectActiveFormats(input: TextSelection): ActiveFormats;
11
+ //# sourceMappingURL=detectActiveFormats.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"detectActiveFormats.d.ts","sourceRoot":"","sources":["../../../../../src/canvas/components/StickyNoteNode/markdown-formatting/detectActiveFormats.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AAG7D,MAAM,MAAM,aAAa,GAAG;IAC1B,IAAI,EAAE,OAAO,CAAC;IACd,MAAM,EAAE,OAAO,CAAC;IAChB,aAAa,EAAE,OAAO,CAAC;IACvB,UAAU,EAAE,OAAO,CAAC;IACpB,YAAY,EAAE,OAAO,CAAC;CACvB,CAAC;AAEF,wBAAgB,kBAAkB,CAAC,CAAC,EAAE,aAAa,EAAE,CAAC,EAAE,aAAa,GAAG,OAAO,CAQ9E;AAED,wBAAgB,mBAAmB,CAAC,KAAK,EAAE,aAAa,GAAG,aAAa,CA4CvE"}
@@ -0,0 +1,32 @@
1
+ import { BULLET_PREFIX, NUMBERED_PREFIX } from "./listFormatting.js";
2
+ function activeFormatsEqual(a, b) {
3
+ return a.bold === b.bold && a.italic === b.italic && a.strikethrough === b.strikethrough && a.bulletList === b.bulletList && a.numberedList === b.numberedList;
4
+ }
5
+ function detectActiveFormats(input) {
6
+ const { value, selectionStart } = input;
7
+ const lineStart = value.lastIndexOf('\n', selectionStart - 1) + 1;
8
+ let lineEnd = value.indexOf('\n', selectionStart);
9
+ if (-1 === lineEnd) lineEnd = value.length;
10
+ const currentLine = value.slice(lineStart, lineEnd);
11
+ const cursorInLine = selectionStart - lineStart;
12
+ const textBefore = currentLine.slice(0, cursorInLine);
13
+ const textAfter = currentLine.slice(cursorInLine);
14
+ const bold = /\*\*(?:[^*\n]|\*(?!\*))*$/.test(textBefore) && /^(?:[^*\n]|\*(?!\*))*\*\*/.test(textAfter);
15
+ const strikethrough = /~~[^~\n]*$/.test(textBefore) && /^[^~\n]*~~/.test(textAfter);
16
+ const italicBefore = /(?<!\*)\*(?!\*)(?:[^*\n]|\*\*)*$/.test(textBefore);
17
+ const italicAfter = /^(?:[^*\n]|\*\*)*(?<!\*)\*(?!\*)/.test(textAfter);
18
+ let italic = italicBefore && italicAfter;
19
+ if (!italic && bold) {
20
+ const beforeStars = /(\*{3,})[^*\n]*$/.exec(textBefore);
21
+ const afterStars = /^[^*\n]*(\*{3,})/.exec(textAfter);
22
+ if (beforeStars && afterStars && beforeStars[1].length % 2 === 1 && afterStars[1].length % 2 === 1) italic = true;
23
+ }
24
+ return {
25
+ bold,
26
+ italic,
27
+ strikethrough,
28
+ bulletList: BULLET_PREFIX.test(currentLine),
29
+ numberedList: NUMBERED_PREFIX.test(currentLine)
30
+ };
31
+ }
32
+ export { activeFormatsEqual, detectActiveFormats };
@@ -0,0 +1,68 @@
1
+ "use strict";
2
+ var __webpack_require__ = {};
3
+ (()=>{
4
+ __webpack_require__.d = (exports1, definition)=>{
5
+ for(var key in definition)if (__webpack_require__.o(definition, key) && !__webpack_require__.o(exports1, key)) Object.defineProperty(exports1, key, {
6
+ enumerable: true,
7
+ get: definition[key]
8
+ });
9
+ };
10
+ })();
11
+ (()=>{
12
+ __webpack_require__.o = (obj, prop)=>Object.prototype.hasOwnProperty.call(obj, prop);
13
+ })();
14
+ (()=>{
15
+ __webpack_require__.r = (exports1)=>{
16
+ if ("u" > typeof Symbol && Symbol.toStringTag) Object.defineProperty(exports1, Symbol.toStringTag, {
17
+ value: 'Module'
18
+ });
19
+ Object.defineProperty(exports1, '__esModule', {
20
+ value: true
21
+ });
22
+ };
23
+ })();
24
+ var __webpack_exports__ = {};
25
+ __webpack_require__.r(__webpack_exports__);
26
+ __webpack_require__.d(__webpack_exports__, {
27
+ detectActiveFormats: ()=>external_detectActiveFormats_cjs_namespaceObject.detectActiveFormats,
28
+ toggleItalic: ()=>external_inlineFormatting_cjs_namespaceObject.toggleItalic,
29
+ toggleStrikethrough: ()=>external_inlineFormatting_cjs_namespaceObject.toggleStrikethrough,
30
+ toggleBulletList: ()=>external_listFormatting_cjs_namespaceObject.toggleBulletList,
31
+ toggleNumberedList: ()=>external_listFormatting_cjs_namespaceObject.toggleNumberedList,
32
+ BULLET_PREFIX: ()=>external_listFormatting_cjs_namespaceObject.BULLET_PREFIX,
33
+ activeFormatsEqual: ()=>external_detectActiveFormats_cjs_namespaceObject.activeFormatsEqual,
34
+ NUMBERED_PREFIX: ()=>external_listFormatting_cjs_namespaceObject.NUMBERED_PREFIX,
35
+ continueListOnEnter: ()=>external_listFormatting_cjs_namespaceObject.continueListOnEnter,
36
+ toggleBold: ()=>external_inlineFormatting_cjs_namespaceObject.toggleBold,
37
+ NUMBERED_PREFIX_FULL: ()=>external_listFormatting_cjs_namespaceObject.NUMBERED_PREFIX_FULL
38
+ });
39
+ const external_detectActiveFormats_cjs_namespaceObject = require("./detectActiveFormats.cjs");
40
+ const external_inlineFormatting_cjs_namespaceObject = require("./inlineFormatting.cjs");
41
+ const external_listFormatting_cjs_namespaceObject = require("./listFormatting.cjs");
42
+ exports.BULLET_PREFIX = __webpack_exports__.BULLET_PREFIX;
43
+ exports.NUMBERED_PREFIX = __webpack_exports__.NUMBERED_PREFIX;
44
+ exports.NUMBERED_PREFIX_FULL = __webpack_exports__.NUMBERED_PREFIX_FULL;
45
+ exports.activeFormatsEqual = __webpack_exports__.activeFormatsEqual;
46
+ exports.continueListOnEnter = __webpack_exports__.continueListOnEnter;
47
+ exports.detectActiveFormats = __webpack_exports__.detectActiveFormats;
48
+ exports.toggleBold = __webpack_exports__.toggleBold;
49
+ exports.toggleBulletList = __webpack_exports__.toggleBulletList;
50
+ exports.toggleItalic = __webpack_exports__.toggleItalic;
51
+ exports.toggleNumberedList = __webpack_exports__.toggleNumberedList;
52
+ exports.toggleStrikethrough = __webpack_exports__.toggleStrikethrough;
53
+ for(var __rspack_i in __webpack_exports__)if (-1 === [
54
+ "BULLET_PREFIX",
55
+ "NUMBERED_PREFIX",
56
+ "NUMBERED_PREFIX_FULL",
57
+ "activeFormatsEqual",
58
+ "continueListOnEnter",
59
+ "detectActiveFormats",
60
+ "toggleBold",
61
+ "toggleBulletList",
62
+ "toggleItalic",
63
+ "toggleNumberedList",
64
+ "toggleStrikethrough"
65
+ ].indexOf(__rspack_i)) exports[__rspack_i] = __webpack_exports__[__rspack_i];
66
+ Object.defineProperty(exports, '__esModule', {
67
+ value: true
68
+ });
@@ -0,0 +1,4 @@
1
+ export { type ActiveFormats, activeFormatsEqual, detectActiveFormats } from './detectActiveFormats';
2
+ export { toggleBold, toggleItalic, toggleStrikethrough } from './inlineFormatting';
3
+ export { BULLET_PREFIX, continueListOnEnter, NUMBERED_PREFIX, NUMBERED_PREFIX_FULL, toggleBulletList, toggleNumberedList, } from './listFormatting';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/canvas/components/StickyNoteNode/markdown-formatting/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,aAAa,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AACpG,OAAO,EAAE,UAAU,EAAE,YAAY,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AACnF,OAAO,EACL,aAAa,EACb,mBAAmB,EACnB,eAAe,EACf,oBAAoB,EACpB,gBAAgB,EAChB,kBAAkB,GACnB,MAAM,kBAAkB,CAAC"}
@@ -0,0 +1,4 @@
1
+ import { activeFormatsEqual, detectActiveFormats } from "./detectActiveFormats.js";
2
+ import { toggleBold, toggleItalic, toggleStrikethrough } from "./inlineFormatting.js";
3
+ import { BULLET_PREFIX, NUMBERED_PREFIX, NUMBERED_PREFIX_FULL, continueListOnEnter, toggleBulletList, toggleNumberedList } from "./listFormatting.js";
4
+ export { BULLET_PREFIX, NUMBERED_PREFIX, NUMBERED_PREFIX_FULL, activeFormatsEqual, continueListOnEnter, detectActiveFormats, toggleBold, toggleBulletList, toggleItalic, toggleNumberedList, toggleStrikethrough };