@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.
- package/README.md +258 -0
- package/dist/changelog-hooks.d.ts +46 -0
- package/dist/changelog-hooks.d.ts.map +1 -0
- package/dist/changelog-hooks.js +163 -0
- package/dist/changelog-hooks.js.map +1 -0
- package/dist/changelog.d.ts +17 -0
- package/dist/changelog.d.ts.map +1 -0
- package/dist/changelog.js +86 -0
- package/dist/changelog.js.map +1 -0
- package/dist/context.d.ts +33 -0
- package/dist/context.d.ts.map +1 -0
- package/dist/context.js +62 -0
- package/dist/context.js.map +1 -0
- package/dist/fetch.d.ts +3 -0
- package/dist/fetch.d.ts.map +1 -0
- package/dist/fetch.js +19 -0
- package/dist/fetch.js.map +1 -0
- package/dist/hooks.d.ts +50 -0
- package/dist/hooks.d.ts.map +1 -0
- package/dist/hooks.js +140 -0
- package/dist/hooks.js.map +1 -0
- package/dist/icons.d.ts +52 -0
- package/dist/icons.d.ts.map +1 -0
- package/dist/icons.js +40 -0
- package/dist/icons.js.map +1 -0
- package/dist/index.d.ts +33 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +43 -0
- package/dist/index.js.map +1 -0
- package/dist/loom-recorder.d.ts +9 -0
- package/dist/loom-recorder.d.ts.map +1 -0
- package/dist/loom-recorder.js +92 -0
- package/dist/loom-recorder.js.map +1 -0
- package/dist/past-submissions.d.ts +10 -0
- package/dist/past-submissions.d.ts.map +1 -0
- package/dist/past-submissions.js +198 -0
- package/dist/past-submissions.js.map +1 -0
- package/dist/recorder/audio.d.ts +6 -0
- package/dist/recorder/audio.d.ts.map +1 -0
- package/dist/recorder/audio.js +30 -0
- package/dist/recorder/audio.js.map +1 -0
- package/dist/recorder/capture.d.ts +6 -0
- package/dist/recorder/capture.d.ts.map +1 -0
- package/dist/recorder/capture.js +32 -0
- package/dist/recorder/capture.js.map +1 -0
- package/dist/recorder/finalize-recording-worker-source.d.ts +2 -0
- package/dist/recorder/finalize-recording-worker-source.d.ts.map +1 -0
- package/dist/recorder/finalize-recording-worker-source.js +6 -0
- package/dist/recorder/finalize-recording-worker-source.js.map +1 -0
- package/dist/recorder/finalize-recording-worker.d.ts +2 -0
- package/dist/recorder/finalize-recording-worker.d.ts.map +1 -0
- package/dist/recorder/finalize-recording-worker.js +16 -0
- package/dist/recorder/finalize-recording-worker.js.map +1 -0
- package/dist/recorder/finalizeRecording.d.ts +12 -0
- package/dist/recorder/finalizeRecording.d.ts.map +1 -0
- package/dist/recorder/finalizeRecording.js +92 -0
- package/dist/recorder/finalizeRecording.js.map +1 -0
- package/dist/recorder/finalizeRecordingInWorker.d.ts +3 -0
- package/dist/recorder/finalizeRecordingInWorker.d.ts.map +1 -0
- package/dist/recorder/finalizeRecordingInWorker.js +49 -0
- package/dist/recorder/finalizeRecordingInWorker.js.map +1 -0
- package/dist/recorder/index.d.ts +7 -0
- package/dist/recorder/index.d.ts.map +1 -0
- package/dist/recorder/index.js +14 -0
- package/dist/recorder/index.js.map +1 -0
- package/dist/recorder/session.d.ts +19 -0
- package/dist/recorder/session.d.ts.map +1 -0
- package/dist/recorder/session.js +237 -0
- package/dist/recorder/session.js.map +1 -0
- package/dist/recorder/support.d.ts +8 -0
- package/dist/recorder/support.d.ts.map +1 -0
- package/dist/recorder/support.js +41 -0
- package/dist/recorder/support.js.map +1 -0
- package/dist/recorder/timer-worker.d.ts +5 -0
- package/dist/recorder/timer-worker.d.ts.map +1 -0
- package/dist/recorder/timer-worker.js +28 -0
- package/dist/recorder/timer-worker.js.map +1 -0
- package/dist/recorder/types.d.ts +26 -0
- package/dist/recorder/types.d.ts.map +1 -0
- package/dist/recorder/types.js +3 -0
- package/dist/recorder/types.js.map +1 -0
- package/dist/recorder-preview-player.d.ts +9 -0
- package/dist/recorder-preview-player.d.ts.map +1 -0
- package/dist/recorder-preview-player.js +136 -0
- package/dist/recorder-preview-player.js.map +1 -0
- package/dist/screen-recorder-context.d.ts +16 -0
- package/dist/screen-recorder-context.d.ts.map +1 -0
- package/dist/screen-recorder-context.js +124 -0
- package/dist/screen-recorder-context.js.map +1 -0
- package/dist/screen-recorder.d.ts +16 -0
- package/dist/screen-recorder.d.ts.map +1 -0
- package/dist/screen-recorder.js +126 -0
- package/dist/screen-recorder.js.map +1 -0
- package/dist/styles.d.ts +3 -0
- package/dist/styles.d.ts.map +1 -0
- package/dist/styles.js +841 -0
- package/dist/styles.js.map +1 -0
- package/dist/triage-attachments.d.ts +5 -0
- package/dist/triage-attachments.d.ts.map +1 -0
- package/dist/triage-attachments.js +44 -0
- package/dist/triage-attachments.js.map +1 -0
- package/dist/triage-button.d.ts +26 -0
- package/dist/triage-button.d.ts.map +1 -0
- package/dist/triage-button.js +228 -0
- package/dist/triage-button.js.map +1 -0
- package/dist/triage-rich-content.d.ts +6 -0
- package/dist/triage-rich-content.d.ts.map +1 -0
- package/dist/triage-rich-content.js +121 -0
- package/dist/triage-rich-content.js.map +1 -0
- package/dist/triage-slate-editor.d.ts +8 -0
- package/dist/triage-slate-editor.d.ts.map +1 -0
- package/dist/triage-slate-editor.js +112 -0
- package/dist/triage-slate-editor.js.map +1 -0
- package/dist/triage-slate.d.ts +20 -0
- package/dist/triage-slate.d.ts.map +1 -0
- package/dist/triage-slate.js +64 -0
- package/dist/triage-slate.js.map +1 -0
- package/dist/triage-ui-controller.d.ts +52 -0
- package/dist/triage-ui-controller.d.ts.map +1 -0
- package/dist/triage-ui-controller.js +146 -0
- package/dist/triage-ui-controller.js.map +1 -0
- package/dist/triage-ui-notifications.d.ts +5 -0
- package/dist/triage-ui-notifications.d.ts.map +1 -0
- package/dist/triage-ui-notifications.js +10 -0
- package/dist/triage-ui-notifications.js.map +1 -0
- package/dist/use-past-submissions.d.ts +43 -0
- package/dist/use-past-submissions.d.ts.map +1 -0
- package/dist/use-past-submissions.js +240 -0
- package/dist/use-past-submissions.js.map +1 -0
- package/dist/use-recorder-controller.d.ts +33 -0
- package/dist/use-recorder-controller.d.ts.map +1 -0
- package/dist/use-recorder-controller.js +309 -0
- package/dist/use-recorder-controller.js.map +1 -0
- package/dist/use-screen-recorder.d.ts +25 -0
- package/dist/use-screen-recorder.d.ts.map +1 -0
- package/dist/use-screen-recorder.js +34 -0
- package/dist/use-screen-recorder.js.map +1 -0
- package/dist/whats-new.d.ts +16 -0
- package/dist/whats-new.d.ts.map +1 -0
- package/dist/whats-new.js +72 -0
- package/dist/whats-new.js.map +1 -0
- 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 @@
|
|
|
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 @@
|
|
|
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":"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"}
|
|
@@ -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
|