@taskp3/react 0.1.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 (142) hide show
  1. package/README.md +258 -0
  2. package/dist/changelog-hooks.d.ts +46 -0
  3. package/dist/changelog-hooks.d.ts.map +1 -0
  4. package/dist/changelog-hooks.js +163 -0
  5. package/dist/changelog-hooks.js.map +1 -0
  6. package/dist/changelog.d.ts +17 -0
  7. package/dist/changelog.d.ts.map +1 -0
  8. package/dist/changelog.js +86 -0
  9. package/dist/changelog.js.map +1 -0
  10. package/dist/context.d.ts +33 -0
  11. package/dist/context.d.ts.map +1 -0
  12. package/dist/context.js +62 -0
  13. package/dist/context.js.map +1 -0
  14. package/dist/fetch.d.ts +3 -0
  15. package/dist/fetch.d.ts.map +1 -0
  16. package/dist/fetch.js +19 -0
  17. package/dist/fetch.js.map +1 -0
  18. package/dist/hooks.d.ts +50 -0
  19. package/dist/hooks.d.ts.map +1 -0
  20. package/dist/hooks.js +140 -0
  21. package/dist/hooks.js.map +1 -0
  22. package/dist/icons.d.ts +52 -0
  23. package/dist/icons.d.ts.map +1 -0
  24. package/dist/icons.js +40 -0
  25. package/dist/icons.js.map +1 -0
  26. package/dist/index.d.ts +33 -0
  27. package/dist/index.d.ts.map +1 -0
  28. package/dist/index.js +43 -0
  29. package/dist/index.js.map +1 -0
  30. package/dist/loom-recorder.d.ts +9 -0
  31. package/dist/loom-recorder.d.ts.map +1 -0
  32. package/dist/loom-recorder.js +92 -0
  33. package/dist/loom-recorder.js.map +1 -0
  34. package/dist/past-submissions.d.ts +10 -0
  35. package/dist/past-submissions.d.ts.map +1 -0
  36. package/dist/past-submissions.js +198 -0
  37. package/dist/past-submissions.js.map +1 -0
  38. package/dist/recorder/audio.d.ts +6 -0
  39. package/dist/recorder/audio.d.ts.map +1 -0
  40. package/dist/recorder/audio.js +30 -0
  41. package/dist/recorder/audio.js.map +1 -0
  42. package/dist/recorder/capture.d.ts +6 -0
  43. package/dist/recorder/capture.d.ts.map +1 -0
  44. package/dist/recorder/capture.js +32 -0
  45. package/dist/recorder/capture.js.map +1 -0
  46. package/dist/recorder/finalize-recording-worker-source.d.ts +2 -0
  47. package/dist/recorder/finalize-recording-worker-source.d.ts.map +1 -0
  48. package/dist/recorder/finalize-recording-worker-source.js +6 -0
  49. package/dist/recorder/finalize-recording-worker-source.js.map +1 -0
  50. package/dist/recorder/finalize-recording-worker.d.ts +2 -0
  51. package/dist/recorder/finalize-recording-worker.d.ts.map +1 -0
  52. package/dist/recorder/finalize-recording-worker.js +16 -0
  53. package/dist/recorder/finalize-recording-worker.js.map +1 -0
  54. package/dist/recorder/finalizeRecording.d.ts +12 -0
  55. package/dist/recorder/finalizeRecording.d.ts.map +1 -0
  56. package/dist/recorder/finalizeRecording.js +92 -0
  57. package/dist/recorder/finalizeRecording.js.map +1 -0
  58. package/dist/recorder/finalizeRecordingInWorker.d.ts +3 -0
  59. package/dist/recorder/finalizeRecordingInWorker.d.ts.map +1 -0
  60. package/dist/recorder/finalizeRecordingInWorker.js +49 -0
  61. package/dist/recorder/finalizeRecordingInWorker.js.map +1 -0
  62. package/dist/recorder/index.d.ts +7 -0
  63. package/dist/recorder/index.d.ts.map +1 -0
  64. package/dist/recorder/index.js +14 -0
  65. package/dist/recorder/index.js.map +1 -0
  66. package/dist/recorder/session.d.ts +19 -0
  67. package/dist/recorder/session.d.ts.map +1 -0
  68. package/dist/recorder/session.js +237 -0
  69. package/dist/recorder/session.js.map +1 -0
  70. package/dist/recorder/support.d.ts +8 -0
  71. package/dist/recorder/support.d.ts.map +1 -0
  72. package/dist/recorder/support.js +41 -0
  73. package/dist/recorder/support.js.map +1 -0
  74. package/dist/recorder/timer-worker.d.ts +5 -0
  75. package/dist/recorder/timer-worker.d.ts.map +1 -0
  76. package/dist/recorder/timer-worker.js +28 -0
  77. package/dist/recorder/timer-worker.js.map +1 -0
  78. package/dist/recorder/types.d.ts +26 -0
  79. package/dist/recorder/types.d.ts.map +1 -0
  80. package/dist/recorder/types.js +3 -0
  81. package/dist/recorder/types.js.map +1 -0
  82. package/dist/recorder-preview-player.d.ts +9 -0
  83. package/dist/recorder-preview-player.d.ts.map +1 -0
  84. package/dist/recorder-preview-player.js +136 -0
  85. package/dist/recorder-preview-player.js.map +1 -0
  86. package/dist/screen-recorder-context.d.ts +16 -0
  87. package/dist/screen-recorder-context.d.ts.map +1 -0
  88. package/dist/screen-recorder-context.js +124 -0
  89. package/dist/screen-recorder-context.js.map +1 -0
  90. package/dist/screen-recorder.d.ts +16 -0
  91. package/dist/screen-recorder.d.ts.map +1 -0
  92. package/dist/screen-recorder.js +126 -0
  93. package/dist/screen-recorder.js.map +1 -0
  94. package/dist/styles.d.ts +3 -0
  95. package/dist/styles.d.ts.map +1 -0
  96. package/dist/styles.js +841 -0
  97. package/dist/styles.js.map +1 -0
  98. package/dist/triage-attachments.d.ts +5 -0
  99. package/dist/triage-attachments.d.ts.map +1 -0
  100. package/dist/triage-attachments.js +44 -0
  101. package/dist/triage-attachments.js.map +1 -0
  102. package/dist/triage-button.d.ts +26 -0
  103. package/dist/triage-button.d.ts.map +1 -0
  104. package/dist/triage-button.js +228 -0
  105. package/dist/triage-button.js.map +1 -0
  106. package/dist/triage-rich-content.d.ts +6 -0
  107. package/dist/triage-rich-content.d.ts.map +1 -0
  108. package/dist/triage-rich-content.js +121 -0
  109. package/dist/triage-rich-content.js.map +1 -0
  110. package/dist/triage-slate-editor.d.ts +8 -0
  111. package/dist/triage-slate-editor.d.ts.map +1 -0
  112. package/dist/triage-slate-editor.js +112 -0
  113. package/dist/triage-slate-editor.js.map +1 -0
  114. package/dist/triage-slate.d.ts +20 -0
  115. package/dist/triage-slate.d.ts.map +1 -0
  116. package/dist/triage-slate.js +64 -0
  117. package/dist/triage-slate.js.map +1 -0
  118. package/dist/triage-ui-controller.d.ts +52 -0
  119. package/dist/triage-ui-controller.d.ts.map +1 -0
  120. package/dist/triage-ui-controller.js +146 -0
  121. package/dist/triage-ui-controller.js.map +1 -0
  122. package/dist/triage-ui-notifications.d.ts +5 -0
  123. package/dist/triage-ui-notifications.d.ts.map +1 -0
  124. package/dist/triage-ui-notifications.js +10 -0
  125. package/dist/triage-ui-notifications.js.map +1 -0
  126. package/dist/use-past-submissions.d.ts +43 -0
  127. package/dist/use-past-submissions.d.ts.map +1 -0
  128. package/dist/use-past-submissions.js +240 -0
  129. package/dist/use-past-submissions.js.map +1 -0
  130. package/dist/use-recorder-controller.d.ts +33 -0
  131. package/dist/use-recorder-controller.d.ts.map +1 -0
  132. package/dist/use-recorder-controller.js +309 -0
  133. package/dist/use-recorder-controller.js.map +1 -0
  134. package/dist/use-screen-recorder.d.ts +25 -0
  135. package/dist/use-screen-recorder.d.ts.map +1 -0
  136. package/dist/use-screen-recorder.js +34 -0
  137. package/dist/use-screen-recorder.js.map +1 -0
  138. package/dist/whats-new.d.ts +16 -0
  139. package/dist/whats-new.d.ts.map +1 -0
  140. package/dist/whats-new.js +72 -0
  141. package/dist/whats-new.js.map +1 -0
  142. package/package.json +58 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.js","sourceRoot":"","sources":["../src/styles.ts"],"names":[],"mappings":";;AAEA,gCAo0BC;AAp0BD,SAAgB,UAAU,CAAC,CAAwB;IACjD,OAAO;;;;;;;aAOI,CAAC,CAAC,MAAM;;;;;;;gBAOL,CAAC,CAAC,YAAY;WACnB,CAAC,CAAC,aAAa;iBACT,CAAC,CAAC,UAAU;;;;;;;;;gBASb,CAAC,CAAC,iBAAiB;;;;;;;;;;aAUtB,CAAC,CAAC,MAAM,GAAG,CAAC;WACd,CAAC,CAAC,UAAU;;;mBAGJ,CAAC,CAAC,YAAY;;iBAEhB,CAAC,CAAC,UAAU;;;;;;;;;;;;;;;;;;gBAkBb,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAuCX,CAAC,CAAC,YAAY;;;;;;;;;;;;mBAYd,CAAC,CAAC,YAAY,GAAG,CAAC;;iBAEpB,CAAC,CAAC,UAAU;;;;;;;;;gBASb,CAAC,CAAC,YAAY;WACnB,CAAC,CAAC,YAAY;;;;;;;;;;;mBAWN,CAAC,CAAC,YAAY;iBAChB,CAAC,CAAC,UAAU;;;;;;;;;;qCAUQ,CAAC,CAAC,YAAY;;;;;;mBAMhC,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAsCd,CAAC,CAAC,YAAY;iBAChB,CAAC,CAAC,UAAU;;;;;;;;;iCASI,CAAC,CAAC,YAAY,YAAY,CAAC,CAAC,aAAa;sDACpB,CAAC,CAAC,iBAAiB;;;;;;;;;;;;;;;;;;;;;;;;;;;;aA4B5D,CAAC,CAAC,MAAM,GAAG,CAAC;;;;;;;;;;;;mBAYN,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;wBAgCT,CAAC,CAAC,UAAU;;;;;2DAKuB,CAAC,CAAC,YAAY;;;;;;4BAM7C,CAAC,CAAC,YAAY;6BACb,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;wCAsBH,CAAC,CAAC,MAAM,GAAG,EAAE;;;;;;;qCAOhB,CAAC,CAAC,YAAY,GAAG,CAAC;;;iBAGtC,CAAC,CAAC,UAAU;;;;;;;;;;;;;;;;;;;;;;;;mBAwBV,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;aAgCpB,CAAC,CAAC,MAAM,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;iBAgCR,CAAC,CAAC,UAAU;;;;;;;mBAOV,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAsFf,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;gBAsChB,CAAC,CAAC,YAAY,YAAY,CAAC,CAAC,aAAa;iBACxC,CAAC,CAAC,UAAU;;;qCAGQ,CAAC,CAAC,iBAAiB;;;;;;;;;;;iBAWvC,CAAC,CAAC,UAAU;;;;;;;;;;;;aAYhB,CAAC,CAAC,MAAM,GAAG,EAAE;;;;;;;;;;mBAUP,CAAC,CAAC,YAAY,GAAG,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;mBA2BlB,CAAC,CAAC,YAAY;;;iBAGhB,CAAC,CAAC,UAAU;;;;;;;;;;;;;;;;;;;;;;mBAsBV,CAAC,CAAC,YAAY;;;;;;;kBAOf,CAAC,CAAC,YAAY;gBAChB,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;WA8DnB,CAAC,CAAC,YAAY;;;;;;;;;;;;;mBAaN,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;mBAmBd,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;mBAyCd,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;;;;mBAwBd,CAAC,CAAC,YAAY;;;;;;;;;mBASd,CAAC,CAAC,YAAY;;;;;;;;;;;;;;;;;;;;;kBAqBf,CAAC,CAAC,YAAY;WACrB,CAAC,CAAC,YAAY;gBACT,CAAC,CAAC,YAAY;;;;;;;;;;;;CAY7B,CAAC;AACF,CAAC"}
@@ -0,0 +1,5 @@
1
+ import type { TriageFileRecord } from "@taskp3/sdk";
2
+ export declare function TriageAttachments({ files }: {
3
+ files?: TriageFileRecord[];
4
+ }): import("react/jsx-runtime").JSX.Element | null;
5
+ //# sourceMappingURL=triage-attachments.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-attachments.d.ts","sourceRoot":"","sources":["../src/triage-attachments.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,aAAa,CAAC;AAgEpD,wBAAgB,iBAAiB,CAAC,EAAE,KAAK,EAAE,EAAE;IAAE,KAAK,CAAC,EAAE,gBAAgB,EAAE,CAAA;CAAE,kDAU1E"}
@@ -0,0 +1,44 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TriageAttachments = TriageAttachments;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const hooks_1 = require("./hooks");
7
+ function formatFileSize(size) {
8
+ if (!size)
9
+ return "0 KB";
10
+ if (size < 1024 * 1024)
11
+ return `${(size / 1024).toFixed(1)} KB`;
12
+ return `${(size / (1024 * 1024)).toFixed(1)} MB`;
13
+ }
14
+ function AttachmentItem({ file }) {
15
+ const { getFile } = (0, hooks_1.useTriage)();
16
+ const [url, setUrl] = (0, react_1.useState)();
17
+ (0, react_1.useEffect)(() => {
18
+ let cancelled = false;
19
+ void getFile(file.id)
20
+ .then((result) => {
21
+ if (!cancelled) {
22
+ setUrl(result.presignedUrl);
23
+ }
24
+ })
25
+ .catch(() => {
26
+ if (!cancelled) {
27
+ setUrl(undefined);
28
+ }
29
+ });
30
+ return () => {
31
+ cancelled = true;
32
+ };
33
+ }, [file.id, getFile]);
34
+ const isImage = file.contentType?.startsWith("image/");
35
+ const isVideo = file.contentType?.startsWith("video/");
36
+ const isAudio = file.contentType?.startsWith("audio/");
37
+ return ((0, jsx_runtime_1.jsxs)("div", { className: "p3-ps-attachment", children: [(0, jsx_runtime_1.jsxs)("div", { className: "p3-ps-attachment-header", children: [(0, jsx_runtime_1.jsxs)("div", { children: [(0, jsx_runtime_1.jsx)("div", { className: "p3-ps-attachment-name", children: file.name }), (0, jsx_runtime_1.jsxs)("div", { className: "p3-ps-attachment-meta", children: [formatFileSize(file.size), " \u2022 ", file.contentType || "file"] })] }), url && ((0, jsx_runtime_1.jsx)("a", { className: "p3-btn p3-btn--outline", href: url, target: "_blank", rel: "noreferrer", children: "Open" }))] }), url && isImage && (0, jsx_runtime_1.jsx)("img", { className: "p3-ps-attachment-image", src: url, alt: file.name }), url && isVideo && (0, jsx_runtime_1.jsx)("video", { className: "p3-ps-attachment-media", src: url, controls: true }), url && isAudio && (0, jsx_runtime_1.jsx)("audio", { className: "p3-ps-attachment-media", src: url, controls: true })] }));
38
+ }
39
+ function TriageAttachments({ files }) {
40
+ if (!files?.length)
41
+ return null;
42
+ return ((0, jsx_runtime_1.jsx)("div", { className: "p3-ps-attachments", children: files.map((file) => ((0, jsx_runtime_1.jsx)(AttachmentItem, { file: file }, file.id))) }));
43
+ }
44
+ //# sourceMappingURL=triage-attachments.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-attachments.js","sourceRoot":"","sources":["../src/triage-attachments.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,26 @@
1
+ import type { TriageSubmissionType } from "@taskp3/sdk";
2
+ import { type TriageUiController } from "./triage-ui-controller";
3
+ export interface TriageButtonProps {
4
+ /** @default "bottom-right" */
5
+ position?: "bottom-right" | "bottom-left";
6
+ /** @default ["Problem","Question","Feedback"] */
7
+ categories?: (TriageSubmissionType | string)[];
8
+ /** @default "Help With" */
9
+ buttonText?: string;
10
+ /** @default true */
11
+ enableFileUpload?: boolean;
12
+ /** @default true */
13
+ enableScreenRecording?: boolean;
14
+ /** @default true */
15
+ enablePastSubmissions?: boolean;
16
+ /** Optional shared UI controller for host-managed triage shell state. */
17
+ controller?: TriageUiController;
18
+ /** Title used by the integrated past submissions modal. */
19
+ pastSubmissionsTitle?: string;
20
+ /** Fires after a successful submission */
21
+ onSubmitSuccess?: (data: unknown) => void;
22
+ /** Fires on submission error */
23
+ onSubmitError?: (error: Error) => void;
24
+ }
25
+ export declare function TriageButton({ position, categories, buttonText, enableFileUpload, enableScreenRecording, enablePastSubmissions, controller, pastSubmissionsTitle, onSubmitSuccess, onSubmitError, }: TriageButtonProps): import("react/jsx-runtime").JSX.Element;
26
+ //# sourceMappingURL=triage-button.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-button.d.ts","sourceRoot":"","sources":["../src/triage-button.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,aAAa,CAAC;AAcxD,OAAO,EAEL,KAAK,kBAAkB,EACxB,MAAM,wBAAwB,CAAC;AA2BhC,MAAM,WAAW,iBAAiB;IAChC,8BAA8B;IAC9B,QAAQ,CAAC,EAAE,cAAc,GAAG,aAAa,CAAC;IAC1C,iDAAiD;IACjD,UAAU,CAAC,EAAE,CAAC,oBAAoB,GAAG,MAAM,CAAC,EAAE,CAAC;IAC/C,2BAA2B;IAC3B,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,oBAAoB;IACpB,gBAAgB,CAAC,EAAE,OAAO,CAAC;IAC3B,oBAAoB;IACpB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,oBAAoB;IACpB,qBAAqB,CAAC,EAAE,OAAO,CAAC;IAChC,yEAAyE;IACzE,UAAU,CAAC,EAAE,kBAAkB,CAAC;IAChC,2DAA2D;IAC3D,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAC9B,0CAA0C;IAC1C,eAAe,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,IAAI,CAAC;IAC1C,gCAAgC;IAChC,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;CACxC;AAED,wBAAgB,YAAY,CAAC,EAC3B,QAAyB,EACzB,UAAgD,EAChD,UAAwB,EACxB,gBAAuB,EACvB,qBAA4B,EAC5B,qBAA4B,EAC5B,UAAU,EACV,oBAAoB,EACpB,eAAe,EACf,aAAa,GACd,EAAE,iBAAiB,2CA2YnB"}
@@ -0,0 +1,228 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TriageButton = TriageButton;
4
+ const jsx_runtime_1 = require("react/jsx-runtime");
5
+ const react_1 = require("react");
6
+ const hooks_1 = require("./hooks");
7
+ const icons_1 = require("./icons");
8
+ const screen_recorder_1 = require("./screen-recorder");
9
+ const past_submissions_1 = require("./past-submissions");
10
+ const triage_ui_controller_1 = require("./triage-ui-controller");
11
+ const triage_ui_notifications_1 = require("./triage-ui-notifications");
12
+ const loom_recorder_1 = require("./loom-recorder");
13
+ const CATEGORY_META = {
14
+ Problem: {
15
+ icon: (0, jsx_runtime_1.jsx)(icons_1.WarningIcon, { size: 15 }),
16
+ hint: "Describe your problem and include selections you made so we can reproduce the behavior.",
17
+ placeholder: "Describe your problem...",
18
+ },
19
+ Question: {
20
+ icon: (0, jsx_runtime_1.jsx)(icons_1.QuestionIcon, { size: 15 }),
21
+ hint: "Ask your question and provide context or details that will help understand your inquiry.",
22
+ placeholder: "Ask a question...",
23
+ },
24
+ Feedback: {
25
+ icon: (0, jsx_runtime_1.jsx)(icons_1.ChatIcon, { size: 15 }),
26
+ hint: "Share feedback and include examples or suggestions to help improve your experience.",
27
+ placeholder: "Share feedback...",
28
+ },
29
+ };
30
+ const DRAFT_STORAGE_KEY = "taskp3-triage-draft";
31
+ function TriageButton({ position = "bottom-right", categories = ["Problem", "Question", "Feedback"], buttonText = "Help With", enableFileUpload = true, enableScreenRecording = true, enablePastSubmissions = true, controller, pastSubmissionsTitle, onSubmitSuccess, onSubmitError, }) {
32
+ const { createTask, uploadFile } = (0, hooks_1.useTriage)();
33
+ const defaultController = (0, triage_ui_controller_1.useTriageUiController)({
34
+ initialActiveCategory: categories[0],
35
+ });
36
+ const ui = controller ?? defaultController;
37
+ const [submitting, setSubmitting] = (0, react_1.useState)(false);
38
+ const [uploadingCount, setUploadingCount] = (0, react_1.useState)(0);
39
+ const fileRef = (0, react_1.useRef)(null);
40
+ const isLeft = position === "bottom-left";
41
+ const posClass = isLeft ? " p3-trigger--left" : "";
42
+ const panelPosClass = isLeft ? " p3-panel--left" : "";
43
+ const open = ui.open;
44
+ const minimized = ui.minimized;
45
+ const historyOpen = ui.historyOpen;
46
+ const activeCategory = ui.activeCategory;
47
+ const description = ui.description;
48
+ const uploads = ui.composerUploads;
49
+ const reset = (0, react_1.useCallback)(() => {
50
+ ui.setDescription("");
51
+ ui.setComposerUploads([]);
52
+ ui.setActiveCategory(categories[0]);
53
+ }, [categories, ui]);
54
+ const dismissPanel = (0, react_1.useCallback)(() => {
55
+ ui.setOpen(false);
56
+ ui.setMinimized(false);
57
+ ui.setHistoryOpen(false);
58
+ ui.consumeTriageTaskId();
59
+ }, [ui]);
60
+ const handleClose = (0, react_1.useCallback)(() => {
61
+ dismissPanel();
62
+ }, [dismissPanel]);
63
+ const handleHistoryClose = (0, react_1.useCallback)(() => {
64
+ ui.setHistoryOpen(false);
65
+ ui.consumeTriageTaskId();
66
+ }, [ui]);
67
+ const handleFiles = (0, react_1.useCallback)(async (files) => {
68
+ setUploadingCount((c) => c + files.length);
69
+ try {
70
+ const results = await Promise.all(Array.from(files).map(async (f) => {
71
+ const res = await uploadFile(f);
72
+ return { id: res.file.id, name: f.name, size: f.size, type: f.type };
73
+ }));
74
+ ui.setComposerUploads((prev) => [...prev, ...results]);
75
+ ui.notify({
76
+ kind: "success",
77
+ scope: "upload",
78
+ message: `Successfully uploaded ${files.length} file(s).`,
79
+ });
80
+ }
81
+ catch {
82
+ ui.notify({
83
+ kind: "error",
84
+ scope: "upload",
85
+ message: "Failed to upload attachment.",
86
+ });
87
+ // swallow — caller can use onSubmitError for create; file errors are non-fatal
88
+ }
89
+ finally {
90
+ setUploadingCount((c) => c - files.length);
91
+ }
92
+ }, [ui, uploadFile]);
93
+ const handleSubmit = (0, react_1.useCallback)(async () => {
94
+ if (!description.trim())
95
+ return;
96
+ setSubmitting(true);
97
+ try {
98
+ const screenRecordingUpload = uploads.find((file) => typeof file.recordingDurationSeconds === "number"
99
+ && file.recordingDurationSeconds > 0);
100
+ const data = await createTask({
101
+ description,
102
+ type: activeCategory,
103
+ path: typeof window !== "undefined" ? window.location.href : undefined,
104
+ fileIds: uploads.map((f) => f.id),
105
+ metaData: screenRecordingUpload
106
+ ? {
107
+ screenRecordingDurationSeconds: screenRecordingUpload.recordingDurationSeconds,
108
+ screenRecordingMimeType: screenRecordingUpload.recordingMimeType,
109
+ screenRecordingConversionMode: screenRecordingUpload.recordingConversionMode,
110
+ }
111
+ : undefined,
112
+ });
113
+ ui.notify({
114
+ kind: "success",
115
+ scope: "submission",
116
+ message: `Your ${activeCategory.toLowerCase()} has been received.`,
117
+ });
118
+ reset();
119
+ dismissPanel();
120
+ onSubmitSuccess?.(data);
121
+ }
122
+ catch (err) {
123
+ const error = err instanceof Error ? err : new Error(String(err));
124
+ ui.notify({
125
+ kind: "error",
126
+ scope: "submission",
127
+ message: `Your ${activeCategory.toLowerCase()} failed to be received.`,
128
+ error,
129
+ });
130
+ onSubmitError?.(error);
131
+ }
132
+ finally {
133
+ setSubmitting(false);
134
+ }
135
+ }, [description, activeCategory, uploads, createTask, onSubmitSuccess, onSubmitError, ui]);
136
+ const handleRecordingAttach = (0, react_1.useCallback)(async (blob, metadata) => {
137
+ const ext = metadata?.fileExtension
138
+ || (blob.type.includes("mp4") ? "mp4" : "webm");
139
+ const file = new File([blob], `recording-${Date.now()}.${ext}`, {
140
+ type: metadata?.mimeType || blob.type || "video/webm",
141
+ });
142
+ setUploadingCount((c) => c + 1);
143
+ try {
144
+ const res = await uploadFile(file);
145
+ ui.setComposerUploads((prev) => [
146
+ ...prev,
147
+ {
148
+ id: res.file.id,
149
+ name: file.name,
150
+ size: file.size,
151
+ type: file.type,
152
+ recordingDurationSeconds: metadata?.durationSeconds,
153
+ recordingMimeType: metadata?.mimeType,
154
+ recordingConversionMode: metadata?.conversionMode,
155
+ },
156
+ ]);
157
+ }
158
+ catch {
159
+ ui.notify({
160
+ kind: "error",
161
+ scope: "upload",
162
+ message: "Failed to upload screen recording.",
163
+ });
164
+ // non-fatal — user can retry
165
+ }
166
+ finally {
167
+ setUploadingCount((c) => c - 1);
168
+ }
169
+ }, [uploadFile, ui]);
170
+ const meta = CATEGORY_META[activeCategory] ?? CATEGORY_META.Problem;
171
+ (0, react_1.useEffect)(() => {
172
+ if (typeof window === "undefined")
173
+ return;
174
+ try {
175
+ const stored = window.localStorage.getItem(DRAFT_STORAGE_KEY);
176
+ if (!stored)
177
+ return;
178
+ const parsed = JSON.parse(stored);
179
+ if (typeof parsed.description === "string") {
180
+ ui.setDescription(parsed.description);
181
+ }
182
+ if (typeof parsed.activeCategory === "string"
183
+ && categories.includes(parsed.activeCategory)) {
184
+ ui.setActiveCategory(parsed.activeCategory);
185
+ }
186
+ }
187
+ catch {
188
+ // Ignore restore failures.
189
+ }
190
+ }, [categories, ui]);
191
+ (0, react_1.useEffect)(() => {
192
+ if (typeof window === "undefined")
193
+ return;
194
+ if (!description.trim() && activeCategory === categories[0]) {
195
+ window.localStorage.removeItem(DRAFT_STORAGE_KEY);
196
+ return;
197
+ }
198
+ window.localStorage.setItem(DRAFT_STORAGE_KEY, JSON.stringify({ description, activeCategory }));
199
+ }, [activeCategory, categories, description]);
200
+ return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(triage_ui_notifications_1.TriageUiNotifications, { controller: ui }), (0, jsx_runtime_1.jsxs)("button", { type: "button", className: `p3-trigger${posClass}`, onClick: () => {
201
+ if (open && minimized) {
202
+ ui.setMinimized(false);
203
+ return;
204
+ }
205
+ if (open) {
206
+ handleClose();
207
+ return;
208
+ }
209
+ ui.setOpen(true);
210
+ }, "aria-label": "Open help menu", children: [(0, jsx_runtime_1.jsx)(icons_1.QuestionIcon, { size: 16 }), buttonText] }), open && ((0, jsx_runtime_1.jsxs)("div", { className: `p3-panel${panelPosClass}`, children: [(0, jsx_runtime_1.jsxs)("div", { className: "p3-header", children: [(0, jsx_runtime_1.jsxs)("span", { className: "p3-header-title", children: [(0, jsx_runtime_1.jsx)(icons_1.QuestionIcon, { size: 15 }), " Help With"] }), (0, jsx_runtime_1.jsxs)("span", { className: "p3-header-actions", children: [(0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-icon-btn", onClick: () => ui.setMinimized(!minimized), "aria-label": minimized ? "Expand" : "Minimize", children: minimized ? (0, jsx_runtime_1.jsx)(icons_1.MaximizeIcon, { size: 14 }) : (0, jsx_runtime_1.jsx)(icons_1.MinimizeIcon, { size: 14 }) }), (0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-icon-btn", onClick: handleClose, "aria-label": "Close", children: (0, jsx_runtime_1.jsx)(icons_1.CloseIcon, { size: 14 }) })] })] }), !minimized && ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsxs)("div", { className: "p3-body", children: [categories.length > 1 && ((0, jsx_runtime_1.jsx)("div", { className: "p3-tabs", children: categories.map((cat) => {
211
+ const m = CATEGORY_META[cat];
212
+ return ((0, jsx_runtime_1.jsxs)("button", { type: "button", className: "p3-tab", "data-active": cat === activeCategory, onClick: () => ui.setActiveCategory(cat), children: [m?.icon, " ", cat] }, cat));
213
+ }) })), (0, jsx_runtime_1.jsx)("p", { className: "p3-hint", children: meta.hint }), (0, jsx_runtime_1.jsx)("textarea", { className: "p3-textarea", placeholder: meta.placeholder, value: description, onChange: (e) => ui.setDescription(e.target.value), onPaste: async (e) => {
214
+ if (enableFileUpload && e.clipboardData.files.length > 0) {
215
+ e.preventDefault();
216
+ await handleFiles(e.clipboardData.files);
217
+ }
218
+ } }), uploads.length > 0 && ((0, jsx_runtime_1.jsx)("div", { className: "p3-files", children: uploads.map((f) => ((0, jsx_runtime_1.jsxs)("div", { className: "p3-file", children: [(0, jsx_runtime_1.jsxs)("span", { className: "p3-file-name", children: [(0, jsx_runtime_1.jsx)(icons_1.FileIcon, {}), " ", f.name] }), (0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-icon-btn", onClick: () => ui.setComposerUploads((prev) => prev.filter((u) => u.id !== f.id)), "aria-label": `Remove ${f.name}`, children: (0, jsx_runtime_1.jsx)(icons_1.CloseIcon, { size: 12 }) })] }, f.id))) }))] }), (0, jsx_runtime_1.jsxs)("div", { className: "p3-footer", children: [(0, jsx_runtime_1.jsxs)("div", { className: "p3-footer-left", children: [enableFileUpload && ((0, jsx_runtime_1.jsxs)("button", { type: "button", className: "p3-btn p3-btn--ghost", onClick: () => fileRef.current?.click(), disabled: uploadingCount > 0, children: [(0, jsx_runtime_1.jsx)(icons_1.PaperclipIcon, { size: 14 }), uploadingCount > 0 ? "Uploading..." : "Attach"] })), enableScreenRecording && ((0, jsx_runtime_1.jsx)(screen_recorder_1.ScreenRecorder, { onAttach: handleRecordingAttach, target: "submission" })), (0, jsx_runtime_1.jsx)(loom_recorder_1.LoomRecorder, { visible: open && !minimized, buttonLabel: "Loom", onInsert: (sharedUrl) => {
219
+ ui.setDescription((current) => current
220
+ ? `${current}\n\nLoom Video: ${sharedUrl}`
221
+ : `Loom Video: ${sharedUrl}`);
222
+ } }), enablePastSubmissions && ((0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-btn p3-btn--ghost", onClick: () => ui.setHistoryOpen(true), children: "View Past Submissions" }))] }), (0, jsx_runtime_1.jsxs)("div", { className: "p3-footer-right", children: [(0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-btn p3-btn--outline", onClick: dismissPanel, children: "Cancel" }), (0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-btn p3-btn--primary", disabled: submitting || !description.trim(), onClick: handleSubmit, children: submitting ? "Submitting..." : "Submit" })] })] })] }))] })), enableFileUpload && ((0, jsx_runtime_1.jsx)("input", { ref: fileRef, type: "file", multiple: true, accept: "*/*", style: { display: "none" }, onChange: (e) => {
223
+ if (e.target.files)
224
+ handleFiles(e.target.files);
225
+ e.target.value = "";
226
+ } })), enablePastSubmissions && ((0, jsx_runtime_1.jsx)(past_submissions_1.PastSubmissions, { open: historyOpen, onClose: handleHistoryClose, title: pastSubmissionsTitle, triageTaskId: ui.triageTaskId, controller: ui }))] }));
227
+ }
228
+ //# sourceMappingURL=triage-button.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-button.js","sourceRoot":"","sources":["../src/triage-button.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ export declare function TriageRichContent({ content, fallback, className, }: {
2
+ content?: string;
3
+ fallback?: string;
4
+ className?: string;
5
+ }): import("react/jsx-runtime").JSX.Element;
6
+ //# sourceMappingURL=triage-rich-content.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-rich-content.d.ts","sourceRoot":"","sources":["../src/triage-rich-content.tsx"],"names":[],"mappings":"AAkHA,wBAAgB,iBAAiB,CAAC,EAChC,OAAO,EACP,QAAQ,EACR,SAAS,GACV,EAAE;IACD,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,2CAQA"}
@@ -0,0 +1,121 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || (function () {
19
+ var ownKeys = function(o) {
20
+ ownKeys = Object.getOwnPropertyNames || function (o) {
21
+ var ar = [];
22
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
23
+ return ar;
24
+ };
25
+ return ownKeys(o);
26
+ };
27
+ return function (mod) {
28
+ if (mod && mod.__esModule) return mod;
29
+ var result = {};
30
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
31
+ __setModuleDefault(result, mod);
32
+ return result;
33
+ };
34
+ })();
35
+ Object.defineProperty(exports, "__esModule", { value: true });
36
+ exports.TriageRichContent = TriageRichContent;
37
+ const jsx_runtime_1 = require("react/jsx-runtime");
38
+ const react_1 = __importStar(require("react"));
39
+ function renderText(node, key) {
40
+ let content = node.text ?? "";
41
+ if (node.code)
42
+ content = (0, jsx_runtime_1.jsx)("code", { children: content });
43
+ if (node.underline)
44
+ content = (0, jsx_runtime_1.jsx)("u", { children: content });
45
+ if (node.italic)
46
+ content = (0, jsx_runtime_1.jsx)("em", { children: content });
47
+ if (node.bold)
48
+ content = (0, jsx_runtime_1.jsx)("strong", { children: content });
49
+ return (0, jsx_runtime_1.jsx)(react_1.default.Fragment, { children: content }, key);
50
+ }
51
+ function renderChildren(children) {
52
+ return children?.map((child, index) => renderNode(child, index)) ?? null;
53
+ }
54
+ function getLoomEmbedUrl(url) {
55
+ if (!url)
56
+ return null;
57
+ const match = url.match(/loom\.com\/share\/([a-zA-Z0-9-]+)/);
58
+ return match ? `https://www.loom.com/embed/${match[1]}` : null;
59
+ }
60
+ function renderNode(node, key) {
61
+ if (typeof node.text === "string" && !node.children) {
62
+ return renderText(node, key);
63
+ }
64
+ const children = renderChildren(node.children);
65
+ switch (node.type) {
66
+ case "heading-one":
67
+ return (0, jsx_runtime_1.jsx)("h4", { children: children }, key);
68
+ case "heading-two":
69
+ return (0, jsx_runtime_1.jsx)("h5", { children: children }, key);
70
+ case "heading-three":
71
+ return (0, jsx_runtime_1.jsx)("h6", { children: children }, key);
72
+ case "block-quote":
73
+ case "blockquote":
74
+ return (0, jsx_runtime_1.jsx)("blockquote", { children: children }, key);
75
+ case "bulleted-list":
76
+ case "unordered-list":
77
+ return (0, jsx_runtime_1.jsx)("ul", { children: children }, key);
78
+ case "numbered-list":
79
+ case "ordered-list":
80
+ return (0, jsx_runtime_1.jsx)("ol", { children: children }, key);
81
+ case "list-item":
82
+ return (0, jsx_runtime_1.jsx)("li", { children: children }, key);
83
+ case "link":
84
+ return ((0, jsx_runtime_1.jsx)("a", { href: node.url, target: "_blank", rel: "noreferrer", children: children }, key));
85
+ case "loom":
86
+ if (getLoomEmbedUrl(node.url)) {
87
+ return ((0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("iframe", { src: getLoomEmbedUrl(node.url) ?? undefined, title: "Loom recording", allowFullScreen: true, style: {
88
+ width: "100%",
89
+ minHeight: 280,
90
+ border: 0,
91
+ borderRadius: 8,
92
+ } }) }, key));
93
+ }
94
+ return ((0, jsx_runtime_1.jsx)("p", { children: (0, jsx_runtime_1.jsx)("a", { href: node.url, target: "_blank", rel: "noreferrer", children: node.url || "Open Loom recording" }) }, key));
95
+ case "code":
96
+ case "code-block":
97
+ return ((0, jsx_runtime_1.jsx)("pre", { children: (0, jsx_runtime_1.jsx)("code", { children: children }) }, key));
98
+ case "paragraph":
99
+ default:
100
+ return (0, jsx_runtime_1.jsx)("p", { children: children }, key);
101
+ }
102
+ }
103
+ function parseSlateContent(content) {
104
+ if (!content?.trim())
105
+ return null;
106
+ try {
107
+ const parsed = JSON.parse(content);
108
+ return Array.isArray(parsed) ? parsed : null;
109
+ }
110
+ catch {
111
+ return null;
112
+ }
113
+ }
114
+ function TriageRichContent({ content, fallback, className, }) {
115
+ const parsed = (0, react_1.useMemo)(() => parseSlateContent(content), [content]);
116
+ if (!parsed) {
117
+ return (0, jsx_runtime_1.jsx)("div", { className: className, children: fallback ?? content ?? "" });
118
+ }
119
+ return (0, jsx_runtime_1.jsx)("div", { className: className, children: parsed.map((node, index) => renderNode(node, index)) });
120
+ }
121
+ //# sourceMappingURL=triage-rich-content.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-rich-content.js","sourceRoot":"","sources":["../src/triage-rich-content.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkHA,8CAgBC;;AAlID,+CAAuC;AAavC,SAAS,UAAU,CAAC,IAAe,EAAE,GAAc;IACjD,IAAI,OAAO,GAAoB,IAAI,CAAC,IAAI,IAAI,EAAE,CAAC;IAE/C,IAAI,IAAI,CAAC,IAAI;QAAE,OAAO,GAAG,2CAAO,OAAO,GAAQ,CAAC;IAChD,IAAI,IAAI,CAAC,SAAS;QAAE,OAAO,GAAG,wCAAI,OAAO,GAAK,CAAC;IAC/C,IAAI,IAAI,CAAC,MAAM;QAAE,OAAO,GAAG,yCAAK,OAAO,GAAM,CAAC;IAC9C,IAAI,IAAI,CAAC,IAAI;QAAE,OAAO,GAAG,6CAAS,OAAO,GAAU,CAAC;IAEpD,OAAO,uBAAC,eAAK,CAAC,QAAQ,cAAY,OAAO,IAAb,GAAG,CAA4B,CAAC;AAC9D,CAAC;AAED,SAAS,cAAc,CAAC,QAAiC;IACvD,OAAO,QAAQ,EAAE,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC,IAAI,IAAI,CAAC;AAC3E,CAAC;AAED,SAAS,eAAe,CAAC,GAAY;IACnC,IAAI,CAAC,GAAG;QAAE,OAAO,IAAI,CAAC;IACtB,MAAM,KAAK,GAAG,GAAG,CAAC,KAAK,CAAC,mCAAmC,CAAC,CAAC;IAC7D,OAAO,KAAK,CAAC,CAAC,CAAC,8BAA8B,KAAK,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;AACjE,CAAC;AAED,SAAS,UAAU,CAAC,IAAe,EAAE,GAAc;IACjD,IAAI,OAAO,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;QACpD,OAAO,UAAU,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;IAC/B,CAAC;IAED,MAAM,QAAQ,GAAG,cAAc,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAE/C,QAAQ,IAAI,CAAC,IAAI,EAAE,CAAC;QAClB,KAAK,aAAa;YAChB,OAAO,yCAAe,QAAQ,IAAd,GAAG,CAAiB,CAAC;QACvC,KAAK,aAAa;YAChB,OAAO,yCAAe,QAAQ,IAAd,GAAG,CAAiB,CAAC;QACvC,KAAK,eAAe;YAClB,OAAO,yCAAe,QAAQ,IAAd,GAAG,CAAiB,CAAC;QACvC,KAAK,aAAa,CAAC;QACnB,KAAK,YAAY;YACf,OAAO,iDAAuB,QAAQ,IAAd,GAAG,CAAyB,CAAC;QACvD,KAAK,eAAe,CAAC;QACrB,KAAK,gBAAgB;YACnB,OAAO,yCAAe,QAAQ,IAAd,GAAG,CAAiB,CAAC;QACvC,KAAK,eAAe,CAAC;QACrB,KAAK,cAAc;YACjB,OAAO,yCAAe,QAAQ,IAAd,GAAG,CAAiB,CAAC;QACvC,KAAK,WAAW;YACd,OAAO,yCAAe,QAAQ,IAAd,GAAG,CAAiB,CAAC;QACvC,KAAK,MAAM;YACT,OAAO,CACL,8BAAa,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,MAAM,EAAC,QAAQ,EAAC,GAAG,EAAC,YAAY,YAC1D,QAAQ,IADH,GAAG,CAEP,CACL,CAAC;QACJ,KAAK,MAAM;YACT,IAAI,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC9B,OAAO,CACL,0CACE,mCACE,GAAG,EAAE,eAAe,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,SAAS,EAC3C,KAAK,EAAC,gBAAgB,EACtB,eAAe,QACf,KAAK,EAAE;4BACL,KAAK,EAAE,MAAM;4BACb,SAAS,EAAE,GAAG;4BACd,MAAM,EAAE,CAAC;4BACT,YAAY,EAAE,CAAC;yBAChB,GACD,IAXM,GAAG,CAYP,CACP,CAAC;YACJ,CAAC;YACD,OAAO,CACL,wCACE,8BAAG,IAAI,EAAE,IAAI,CAAC,GAAG,EAAE,MAAM,EAAC,QAAQ,EAAC,GAAG,EAAC,YAAY,YAChD,IAAI,CAAC,GAAG,IAAI,qBAAqB,GAChC,IAHE,GAAG,CAIP,CACL,CAAC;QACJ,KAAK,MAAM,CAAC;QACZ,KAAK,YAAY;YACf,OAAO,CACL,0CACE,2CAAO,QAAQ,GAAQ,IADf,GAAG,CAEP,CACP,CAAC;QACJ,KAAK,WAAW,CAAC;QACjB;YACE,OAAO,wCAAc,QAAQ,IAAd,GAAG,CAAgB,CAAC;IACvC,CAAC;AACH,CAAC;AAED,SAAS,iBAAiB,CAAC,OAAgB;IACzC,IAAI,CAAC,OAAO,EAAE,IAAI,EAAE;QAAE,OAAO,IAAI,CAAC;IAElC,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;QACnC,OAAO,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAAC;IAC/C,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,SAAgB,iBAAiB,CAAC,EAChC,OAAO,EACP,QAAQ,EACR,SAAS,GAKV;IACC,MAAM,MAAM,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEpE,IAAI,CAAC,MAAM,EAAE,CAAC;QACZ,OAAO,gCAAK,SAAS,EAAE,SAAS,YAAG,QAAQ,IAAI,OAAO,IAAI,EAAE,GAAO,CAAC;IACtE,CAAC;IAED,OAAO,gCAAK,SAAS,EAAE,SAAS,YAAG,MAAM,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,UAAU,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC,GAAO,CAAC;AACjG,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { TriageSlateValue } from "./triage-slate";
2
+ export declare function TriageSlateEditor({ value, onChange, placeholder, onPasteFiles, }: {
3
+ value: TriageSlateValue;
4
+ onChange: (value: TriageSlateValue) => void;
5
+ placeholder?: string;
6
+ onPasteFiles?: (files: File[]) => Promise<void> | void;
7
+ }): import("react/jsx-runtime").JSX.Element;
8
+ //# sourceMappingURL=triage-slate-editor.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"triage-slate-editor.d.ts","sourceRoot":"","sources":["../src/triage-slate-editor.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAsB,gBAAgB,EAAE,MAAM,gBAAgB,CAAC;AA0G3E,wBAAgB,iBAAiB,CAAC,EAChC,KAAK,EACL,QAAQ,EACR,WAAW,EACX,YAAY,GACb,EAAE;IACD,KAAK,EAAE,gBAAgB,CAAC;IACxB,QAAQ,EAAE,CAAC,KAAK,EAAE,gBAAgB,KAAK,IAAI,CAAC;IAC5C,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;CACxD,2CA6EA"}
@@ -0,0 +1,112 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.TriageSlateEditor = TriageSlateEditor;
7
+ const jsx_runtime_1 = require("react/jsx-runtime");
8
+ const react_1 = __importDefault(require("react"));
9
+ const slate_1 = require("slate");
10
+ const slate_react_1 = require("slate-react");
11
+ const slate_history_1 = require("slate-history");
12
+ const LIST_TYPES = ["bulleted-list", "numbered-list"];
13
+ function isMarkActive(editor, format) {
14
+ const marks = slate_1.Editor.marks(editor);
15
+ return marks ? marks[format] === true : false;
16
+ }
17
+ function toggleMark(editor, format) {
18
+ const active = isMarkActive(editor, format);
19
+ if (active) {
20
+ slate_1.Editor.removeMark(editor, format);
21
+ }
22
+ else {
23
+ slate_1.Editor.addMark(editor, format, true);
24
+ }
25
+ }
26
+ function isBlockActive(editor, format) {
27
+ const matches = slate_1.Editor.nodes(editor, {
28
+ match: (node) => !slate_1.Editor.isEditor(node)
29
+ && slate_1.Element.isElement(node)
30
+ && node.type === format,
31
+ });
32
+ return !!matches.next().value;
33
+ }
34
+ function toggleBlock(editor, format) {
35
+ const active = isBlockActive(editor, format);
36
+ const isList = LIST_TYPES.includes(format);
37
+ slate_1.Transforms.unwrapNodes(editor, {
38
+ match: (node) => !slate_1.Editor.isEditor(node)
39
+ && slate_1.Element.isElement(node)
40
+ && LIST_TYPES.includes(node.type),
41
+ split: true,
42
+ });
43
+ slate_1.Transforms.setNodes(editor, {
44
+ type: active ? "paragraph" : isList ? "list-item" : format,
45
+ });
46
+ if (!active && isList) {
47
+ slate_1.Transforms.wrapNodes(editor, {
48
+ type: format,
49
+ children: [],
50
+ });
51
+ }
52
+ }
53
+ function ToolbarButton({ active, label, onMouseDown, }) {
54
+ return ((0, jsx_runtime_1.jsx)("button", { type: "button", className: "p3-rte-btn", "data-active": active, onMouseDown: onMouseDown, children: label }));
55
+ }
56
+ function renderElement(props) {
57
+ const { attributes, children, element } = props;
58
+ switch (element.type) {
59
+ case "bulleted-list":
60
+ return (0, jsx_runtime_1.jsx)("ul", { ...attributes, children: children });
61
+ case "numbered-list":
62
+ return (0, jsx_runtime_1.jsx)("ol", { ...attributes, children: children });
63
+ case "list-item":
64
+ return (0, jsx_runtime_1.jsx)("li", { ...attributes, children: children });
65
+ case "blockquote":
66
+ return (0, jsx_runtime_1.jsx)("blockquote", { ...attributes, children: children });
67
+ default:
68
+ return (0, jsx_runtime_1.jsx)("p", { ...attributes, children: children });
69
+ }
70
+ }
71
+ function renderLeaf(props) {
72
+ const { attributes, children, leaf } = props;
73
+ let rendered = children;
74
+ if (leaf.bold)
75
+ rendered = (0, jsx_runtime_1.jsx)("strong", { children: rendered });
76
+ if (leaf.italic)
77
+ rendered = (0, jsx_runtime_1.jsx)("em", { children: rendered });
78
+ if (leaf.underline)
79
+ rendered = (0, jsx_runtime_1.jsx)("u", { children: rendered });
80
+ if (leaf.code)
81
+ rendered = (0, jsx_runtime_1.jsx)("code", { children: rendered });
82
+ return (0, jsx_runtime_1.jsx)("span", { ...attributes, children: rendered });
83
+ }
84
+ function TriageSlateEditor({ value, onChange, placeholder, onPasteFiles, }) {
85
+ const editor = react_1.default.useMemo(() => (0, slate_history_1.withHistory)((0, slate_react_1.withReact)((0, slate_1.createEditor)())), []);
86
+ return ((0, jsx_runtime_1.jsx)("div", { className: "p3-rte", children: (0, jsx_runtime_1.jsxs)(slate_react_1.Slate, { editor: editor, initialValue: value, onChange: (nextValue) => onChange(nextValue), children: [(0, jsx_runtime_1.jsxs)("div", { className: "p3-rte-toolbar", children: [(0, jsx_runtime_1.jsx)(ToolbarButton, { label: "B", active: isMarkActive(editor, "bold"), onMouseDown: (event) => {
87
+ event.preventDefault();
88
+ toggleMark(editor, "bold");
89
+ } }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "I", active: isMarkActive(editor, "italic"), onMouseDown: (event) => {
90
+ event.preventDefault();
91
+ toggleMark(editor, "italic");
92
+ } }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "U", active: isMarkActive(editor, "underline"), onMouseDown: (event) => {
93
+ event.preventDefault();
94
+ toggleMark(editor, "underline");
95
+ } }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "Code", active: isMarkActive(editor, "code"), onMouseDown: (event) => {
96
+ event.preventDefault();
97
+ toggleMark(editor, "code");
98
+ } }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "\u2022 List", active: isBlockActive(editor, "bulleted-list"), onMouseDown: (event) => {
99
+ event.preventDefault();
100
+ toggleBlock(editor, "bulleted-list");
101
+ } }), (0, jsx_runtime_1.jsx)(ToolbarButton, { label: "1. List", active: isBlockActive(editor, "numbered-list"), onMouseDown: (event) => {
102
+ event.preventDefault();
103
+ toggleBlock(editor, "numbered-list");
104
+ } })] }), (0, jsx_runtime_1.jsx)(slate_react_1.Editable, { className: "p3-rte-editor", placeholder: placeholder, renderElement: renderElement, renderLeaf: renderLeaf, spellCheck: true, onPaste: (event) => {
105
+ const files = Array.from(event.clipboardData.files ?? []);
106
+ if (files.length > 0 && onPasteFiles) {
107
+ event.preventDefault();
108
+ void onPasteFiles(files);
109
+ }
110
+ } })] }) }));
111
+ }
112
+ //# sourceMappingURL=triage-slate-editor.js.map