@autobe/ui 0.19.1 → 0.20.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/lib/AutoBeChatUploadSendButton.d.ts +15 -0
- package/lib/AutoBeChatUploadSendButton.js +38 -0
- package/lib/AutoBeChatUploadSendButton.js.map +1 -0
- package/lib/AutoBeFileUploadBox.d.ts +10 -0
- package/lib/AutoBeFileUploadBox.js +68 -0
- package/lib/AutoBeFileUploadBox.js.map +1 -0
- package/lib/AutoBeVoiceRecoderButton.d.ts +11 -0
- package/lib/AutoBeVoiceRecoderButton.js +58 -0
- package/lib/AutoBeVoiceRecoderButton.js.map +1 -0
- package/lib/events/AutoBeCompleteEventMovie.d.ts +7 -0
- package/lib/events/AutoBeCompleteEventMovie.js +210 -0
- package/lib/events/AutoBeCompleteEventMovie.js.map +1 -0
- package/lib/events/AutoBeProgressEventMovie.js +2 -61
- package/lib/events/AutoBeProgressEventMovie.js.map +1 -1
- package/lib/events/AutoBeScenarioEventMovie.js +2 -44
- package/lib/events/AutoBeScenarioEventMovie.js.map +1 -1
- package/lib/events/AutoBeValidateEventMovie.d.ts +6 -0
- package/lib/events/AutoBeValidateEventMovie.js +115 -0
- package/lib/events/AutoBeValidateEventMovie.js.map +1 -0
- package/lib/events/common/CollapsibleEventGroup.d.ts +28 -0
- package/lib/events/common/CollapsibleEventGroup.js +89 -0
- package/lib/events/common/CollapsibleEventGroup.js.map +1 -0
- package/lib/events/common/EventCard.d.ts +13 -0
- package/lib/events/common/EventCard.js +43 -0
- package/lib/events/common/EventCard.js.map +1 -0
- package/lib/events/common/EventContent.d.ts +11 -0
- package/lib/events/common/EventContent.js +14 -0
- package/lib/events/common/EventContent.js.map +1 -0
- package/lib/events/common/EventHeader.d.ts +15 -0
- package/lib/events/common/EventHeader.js +41 -0
- package/lib/events/common/EventHeader.js.map +1 -0
- package/lib/events/common/EventIcon.d.ts +11 -0
- package/lib/events/common/EventIcon.js +50 -0
- package/lib/events/common/EventIcon.js.map +1 -0
- package/lib/events/common/ProgressBar.d.ts +14 -0
- package/lib/events/common/ProgressBar.js +33 -0
- package/lib/events/common/ProgressBar.js.map +1 -0
- package/lib/events/common/index.d.ts +6 -0
- package/lib/events/common/index.js +16 -0
- package/lib/events/common/index.js.map +1 -0
- package/lib/events/groups/ValidateEventGroup.d.ts +12 -0
- package/lib/events/groups/ValidateEventGroup.js +78 -0
- package/lib/events/groups/ValidateEventGroup.js.map +1 -0
- package/lib/events/groups/index.d.ts +1 -0
- package/lib/events/groups/index.js +6 -0
- package/lib/events/groups/index.js.map +1 -0
- package/lib/events/index.d.ts +5 -0
- package/lib/events/index.js +25 -1
- package/lib/events/index.js.map +1 -1
- package/lib/events/utils/eventGrouper.d.ts +20 -0
- package/lib/events/utils/eventGrouper.js +74 -0
- package/lib/events/utils/eventGrouper.js.map +1 -0
- package/lib/events/utils/index.d.ts +1 -0
- package/lib/events/utils/index.js +6 -0
- package/lib/events/utils/index.js.map +1 -0
- package/lib/index.d.ts +3 -0
- package/lib/index.js +7 -1
- package/lib/index.js.map +1 -1
- package/lib/utils/AutoBeFileUploader.d.ts +28 -0
- package/lib/utils/AutoBeFileUploader.js +237 -0
- package/lib/utils/AutoBeFileUploader.js.map +1 -0
- package/lib/utils/AutoBeVoiceRecorder.d.ts +7 -0
- package/lib/utils/AutoBeVoiceRecorder.js +94 -0
- package/lib/utils/AutoBeVoiceRecorder.js.map +1 -0
- package/lib/utils/index.d.ts +3 -0
- package/lib/utils/index.js +20 -0
- package/lib/utils/index.js.map +1 -0
- package/package.json +17 -2
- package/src/AutoBeChatUploadSendButton.tsx +66 -0
- package/src/AutoBeFileUploadBox.tsx +124 -0
- package/src/AutoBeVoiceRecoderButton.tsx +100 -0
- package/src/events/AutoBeCompleteEventMovie.tsx +402 -0
- package/src/events/AutoBeProgressEventMovie.tsx +12 -125
- package/src/events/AutoBeScenarioEventMovie.tsx +5 -93
- package/src/events/AutoBeValidateEventMovie.tsx +326 -0
- package/src/events/README.md +169 -0
- package/src/events/common/CollapsibleEventGroup.tsx +220 -0
- package/src/events/common/EventCard.tsx +61 -0
- package/src/events/common/EventContent.tsx +31 -0
- package/src/events/common/EventHeader.tsx +85 -0
- package/src/events/common/EventIcon.tsx +82 -0
- package/src/events/common/ProgressBar.tsx +63 -0
- package/src/events/common/index.ts +13 -0
- package/src/events/groups/ValidateEventGroup.tsx +150 -0
- package/src/events/groups/index.ts +4 -0
- package/src/events/index.ts +14 -0
- package/src/events/utils/eventGrouper.tsx +118 -0
- package/src/events/utils/index.ts +1 -0
- package/src/index.ts +6 -0
- package/src/utils/AutoBeFileUploader.ts +279 -0
- package/src/utils/AutoBeVoiceRecorder.ts +95 -0
- package/src/utils/index.ts +3 -0
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
/** Props interface for AutoBeChatUploadSendButton component */
|
|
2
|
+
interface IAutoBeChatUploadSendButtonProps {
|
|
3
|
+
/** Function to trigger conversation */
|
|
4
|
+
onClick?: (event: React.MouseEvent<HTMLButtonElement>) => Promise<void>;
|
|
5
|
+
/** Whether the button is enabled */
|
|
6
|
+
enabled: boolean;
|
|
7
|
+
}
|
|
8
|
+
/**
|
|
9
|
+
* Chat upload send button component for triggering conversations
|
|
10
|
+
*
|
|
11
|
+
* @param props - Component props
|
|
12
|
+
* @returns JSX element representing the send button
|
|
13
|
+
*/
|
|
14
|
+
export declare const AutoBeChatUploadSendButton: (props: IAutoBeChatUploadSendButtonProps) => import("react/jsx-runtime").JSX.Element;
|
|
15
|
+
export default AutoBeChatUploadSendButton;
|
|
@@ -0,0 +1,38 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AutoBeChatUploadSendButton = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
/**
|
|
6
|
+
* Chat upload send button component for triggering conversations
|
|
7
|
+
*
|
|
8
|
+
* @param props - Component props
|
|
9
|
+
* @returns JSX element representing the send button
|
|
10
|
+
*/
|
|
11
|
+
const AutoBeChatUploadSendButton = (props) => {
|
|
12
|
+
const baseStyles = {
|
|
13
|
+
padding: "6px",
|
|
14
|
+
border: "none",
|
|
15
|
+
borderRadius: "50%", // 4px에서 50%로 변경하여 둥글게
|
|
16
|
+
backgroundColor: props.enabled ? "#1976d2" : "#e0e0e0",
|
|
17
|
+
color: props.enabled ? "#ffffff" : "#9e9e9e",
|
|
18
|
+
cursor: props.enabled ? "pointer" : "not-allowed",
|
|
19
|
+
display: "inline-flex",
|
|
20
|
+
alignItems: "center",
|
|
21
|
+
justifyContent: "center",
|
|
22
|
+
transition: "background-color 0.3s ease",
|
|
23
|
+
outline: "none",
|
|
24
|
+
width: "32px",
|
|
25
|
+
height: "32px",
|
|
26
|
+
};
|
|
27
|
+
const hoverStyles = Object.assign(Object.assign({}, baseStyles), { backgroundColor: props.enabled ? "#1565c0" : "#e0e0e0" });
|
|
28
|
+
return ((0, jsx_runtime_1.jsx)("button", { style: baseStyles, onClick: (e) => { var _a; return void ((_a = props.onClick) === null || _a === void 0 ? void 0 : _a.call(props, e)); }, disabled: !props.enabled, onMouseEnter: (e) => {
|
|
29
|
+
if (props.enabled) {
|
|
30
|
+
Object.assign(e.currentTarget.style, hoverStyles);
|
|
31
|
+
}
|
|
32
|
+
}, onMouseLeave: (e) => {
|
|
33
|
+
Object.assign(e.currentTarget.style, baseStyles);
|
|
34
|
+
}, children: (0, jsx_runtime_1.jsx)("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "currentColor", style: { display: "block" }, children: (0, jsx_runtime_1.jsx)("path", { d: "M4 12l1.41 1.41L11 7.83V20h2V7.83l5.59 5.58L20 12l-8-8-8 8z" }) }) }));
|
|
35
|
+
};
|
|
36
|
+
exports.AutoBeChatUploadSendButton = AutoBeChatUploadSendButton;
|
|
37
|
+
exports.default = exports.AutoBeChatUploadSendButton;
|
|
38
|
+
//# sourceMappingURL=AutoBeChatUploadSendButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AutoBeChatUploadSendButton.js","sourceRoot":"","sources":["../src/AutoBeChatUploadSendButton.tsx"],"names":[],"mappings":";;;;AAQA;;;;;GAKG;AACI,MAAM,0BAA0B,GAAG,CACxC,KAAuC,EACvC,EAAE;IACF,MAAM,UAAU,GAAwB;QACtC,OAAO,EAAE,KAAK;QACd,MAAM,EAAE,MAAM;QACd,YAAY,EAAE,KAAK,EAAE,sBAAsB;QAC3C,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QACtD,KAAK,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS;QAC5C,MAAM,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,aAAa;QACjD,OAAO,EAAE,aAAa;QACtB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,UAAU,EAAE,4BAA4B;QACxC,OAAO,EAAE,MAAM;QACf,KAAK,EAAE,MAAM;QACb,MAAM,EAAE,MAAM;KACf,CAAC;IAEF,MAAM,WAAW,mCACZ,UAAU,KACb,eAAe,EAAE,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,GACvD,CAAC;IAEF,OAAO,CACL,mCACE,KAAK,EAAE,UAAU,EACjB,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE,WAAC,OAAA,KAAK,CAAA,MAAA,KAAK,CAAC,OAAO,sDAAG,CAAC,CAAC,CAAA,CAAA,EAAA,EACvC,QAAQ,EAAE,CAAC,KAAK,CAAC,OAAO,EACxB,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;YAClB,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;gBAClB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;YACpD,CAAC;QACH,CAAC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;YAClB,MAAM,CAAC,MAAM,CAAC,CAAC,CAAC,aAAa,CAAC,KAAK,EAAE,UAAU,CAAC,CAAC;QACnD,CAAC,YAED,gCACE,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,IAAI,EAAC,cAAc,EACnB,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE,YAE3B,iCAAM,CAAC,EAAC,6DAA6D,GAAG,GACpE,GACC,CACV,CAAC;AACJ,CAAC,CAAC;AAjDW,QAAA,0BAA0B,8BAiDrC;AAEF,kBAAe,kCAA0B,CAAC"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { ReactNode } from "react";
|
|
2
|
+
export declare const AutoBeFileUploadBox: (props: AutoBeFileUploadBox.IProps) => import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
export default AutoBeFileUploadBox;
|
|
4
|
+
export declare namespace AutoBeFileUploadBox {
|
|
5
|
+
interface IProps {
|
|
6
|
+
extensionError: ReactNode | null;
|
|
7
|
+
onClick: () => void;
|
|
8
|
+
enabled: boolean;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
@@ -0,0 +1,68 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.AutoBeFileUploadBox = void 0;
|
|
4
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
+
const react_1 = require("react");
|
|
6
|
+
const AutoBeFileUploadBox = (props) => {
|
|
7
|
+
const [isHovered, setIsHovered] = (0, react_1.useState)(false);
|
|
8
|
+
const hasError = !!props.extensionError;
|
|
9
|
+
const getButtonStyles = () => {
|
|
10
|
+
const baseStyles = {
|
|
11
|
+
display: "inline-flex",
|
|
12
|
+
alignItems: "center",
|
|
13
|
+
justifyContent: "center",
|
|
14
|
+
width: "40px",
|
|
15
|
+
height: "40px",
|
|
16
|
+
padding: "0",
|
|
17
|
+
border: "1px solid",
|
|
18
|
+
borderRadius: "50%",
|
|
19
|
+
cursor: props.enabled ? "pointer" : "not-allowed",
|
|
20
|
+
backgroundColor: hasError ? "#fef2f2" : "transparent",
|
|
21
|
+
borderColor: hasError ? "#f87171" : isHovered ? "#3b82f6" : "#d1d5db",
|
|
22
|
+
opacity: props.enabled ? 1 : 0.5,
|
|
23
|
+
transition: "all 0.3s ease",
|
|
24
|
+
position: "relative",
|
|
25
|
+
};
|
|
26
|
+
if (isHovered && props.enabled) {
|
|
27
|
+
return Object.assign(Object.assign({}, baseStyles), { backgroundColor: hasError ? "#fef2f2" : "#f3f4f6", borderColor: hasError ? "#f87171" : "#3b82f6" });
|
|
28
|
+
}
|
|
29
|
+
return baseStyles;
|
|
30
|
+
};
|
|
31
|
+
const iconColor = hasError ? "#ef4444" : "#6b7280";
|
|
32
|
+
return ((0, jsx_runtime_1.jsxs)("div", { style: { position: "relative", display: "inline-block" }, children: [(0, jsx_runtime_1.jsx)("button", { onClick: props.onClick, disabled: !props.enabled, style: getButtonStyles(), onMouseEnter: () => {
|
|
33
|
+
setIsHovered(true);
|
|
34
|
+
}, onMouseLeave: () => {
|
|
35
|
+
setIsHovered(false);
|
|
36
|
+
}, children: hasError ? (
|
|
37
|
+
// Error Icon (SVG)
|
|
38
|
+
(0, jsx_runtime_1.jsx)("svg", { width: "20", height: "20", viewBox: "0 0 24 24", fill: "currentColor", style: { color: iconColor }, children: (0, jsx_runtime_1.jsx)("path", { d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm1 15h-2v-2h2v2zm0-4h-2V7h2v6z" }) })) : (
|
|
39
|
+
// Add Icon (SVG)
|
|
40
|
+
(0, jsx_runtime_1.jsx)("svg", { width: "20", height: "20", viewBox: "0 0 24 24", fill: "currentColor", style: { color: iconColor }, children: (0, jsx_runtime_1.jsx)("path", { d: "M19 13h-6v6h-2v-6H5v-2h6V5h2v6h6v2z" }) })) }), hasError && ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
41
|
+
position: "absolute",
|
|
42
|
+
bottom: "100%",
|
|
43
|
+
left: "50%",
|
|
44
|
+
transform: "translateX(-50%)",
|
|
45
|
+
marginBottom: "8px",
|
|
46
|
+
padding: "8px 12px",
|
|
47
|
+
backgroundColor: "#ef4444",
|
|
48
|
+
color: "#ffffff",
|
|
49
|
+
borderRadius: "6px",
|
|
50
|
+
fontSize: "14px",
|
|
51
|
+
whiteSpace: "nowrap",
|
|
52
|
+
zIndex: 1000,
|
|
53
|
+
boxShadow: "0 2px 8px rgba(0, 0, 0, 0.15)",
|
|
54
|
+
}, children: [props.extensionError, (0, jsx_runtime_1.jsx)("div", { style: {
|
|
55
|
+
position: "absolute",
|
|
56
|
+
top: "100%",
|
|
57
|
+
left: "50%",
|
|
58
|
+
transform: "translateX(-50%)",
|
|
59
|
+
width: 0,
|
|
60
|
+
height: 0,
|
|
61
|
+
borderLeft: "6px solid transparent",
|
|
62
|
+
borderRight: "6px solid transparent",
|
|
63
|
+
borderTop: "6px solid #ef4444",
|
|
64
|
+
} })] }))] }));
|
|
65
|
+
};
|
|
66
|
+
exports.AutoBeFileUploadBox = AutoBeFileUploadBox;
|
|
67
|
+
exports.default = exports.AutoBeFileUploadBox;
|
|
68
|
+
//# sourceMappingURL=AutoBeFileUploadBox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AutoBeFileUploadBox.js","sourceRoot":"","sources":["../src/AutoBeFileUploadBox.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import { AutoBeUserMessageAudioContent } from "@autobe/interface";
|
|
2
|
+
export declare const AutoBeVoiceRecoderButton: (props: AutoBeVoiceRecoderButton.IProps) => import("react/jsx-runtime").JSX.Element;
|
|
3
|
+
export declare namespace AutoBeVoiceRecoderButton {
|
|
4
|
+
interface IProps {
|
|
5
|
+
enabled: boolean;
|
|
6
|
+
onComplete: (content: {
|
|
7
|
+
file: File;
|
|
8
|
+
content: AutoBeUserMessageAudioContent;
|
|
9
|
+
}) => void;
|
|
10
|
+
}
|
|
11
|
+
}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
+
exports.AutoBeVoiceRecoderButton = void 0;
|
|
13
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
14
|
+
const react_1 = require("react");
|
|
15
|
+
const AutoBeVoiceRecorder_1 = require("./utils/AutoBeVoiceRecorder");
|
|
16
|
+
const AutoBeVoiceRecoderButton = (props) => {
|
|
17
|
+
const [isRecording, setIsRecording] = (0, react_1.useState)(false);
|
|
18
|
+
const [mediaRecorder, setMediaRecorder] = (0, react_1.useState)(null);
|
|
19
|
+
const startRecording = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
20
|
+
const recorder = yield AutoBeVoiceRecorder_1.AutoBeVoiceRecorder.start(props.onComplete);
|
|
21
|
+
recorder.start();
|
|
22
|
+
setMediaRecorder(recorder);
|
|
23
|
+
setIsRecording(true);
|
|
24
|
+
});
|
|
25
|
+
const stopRecording = () => {
|
|
26
|
+
if (mediaRecorder && mediaRecorder.state !== "inactive") {
|
|
27
|
+
mediaRecorder.stop();
|
|
28
|
+
setIsRecording(false);
|
|
29
|
+
}
|
|
30
|
+
};
|
|
31
|
+
const baseStyles = {
|
|
32
|
+
padding: "6px",
|
|
33
|
+
border: "1px solid",
|
|
34
|
+
borderColor: isRecording ? "#f44336" : "#e0e0e0",
|
|
35
|
+
borderRadius: "4px",
|
|
36
|
+
backgroundColor: isRecording ? "#ffebee" : "transparent",
|
|
37
|
+
color: isRecording ? "#f44336" : "#1976d2",
|
|
38
|
+
cursor: props.enabled ? "pointer" : "not-allowed",
|
|
39
|
+
display: "inline-flex",
|
|
40
|
+
alignItems: "center",
|
|
41
|
+
justifyContent: "center",
|
|
42
|
+
transition: "all 0.3s ease",
|
|
43
|
+
outline: "none",
|
|
44
|
+
width: "32px",
|
|
45
|
+
height: "32px",
|
|
46
|
+
opacity: props.enabled ? 1 : 0.5,
|
|
47
|
+
};
|
|
48
|
+
const hoverStyles = Object.assign(Object.assign({}, baseStyles), { backgroundColor: isRecording ? "#f44336" : "#f5f5f5", borderColor: isRecording ? "#d32f2f" : "#1976d2", color: isRecording ? "#ffffff" : "#1976d2" });
|
|
49
|
+
return ((0, jsx_runtime_1.jsx)("button", { style: baseStyles, onClick: isRecording ? stopRecording : () => void startRecording(), disabled: !props.enabled, onMouseEnter: (e) => {
|
|
50
|
+
if (props.enabled) {
|
|
51
|
+
Object.assign(e.currentTarget.style, hoverStyles);
|
|
52
|
+
}
|
|
53
|
+
}, onMouseLeave: (e) => {
|
|
54
|
+
Object.assign(e.currentTarget.style, baseStyles);
|
|
55
|
+
}, children: isRecording ? ((0, jsx_runtime_1.jsx)("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "currentColor", style: { display: "block" }, children: (0, jsx_runtime_1.jsx)("path", { d: "M6 6h12v12H6z" }) })) : ((0, jsx_runtime_1.jsx)("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "currentColor", style: { display: "block" }, children: (0, jsx_runtime_1.jsx)("path", { d: "M12 2c1.1 0 2 .9 2 2v6c0 1.1-.9 2-2 2s-2-.9-2-2V4c0-1.1.9-2 2-2zm5.3 6.7c.4-.4 1-.4 1.4 0 .4.4.4 1 0 1.4l-1.9 1.9c.03.33.05.66.05 1v.5c0 2.8-2.2 5-5 5s-5-2.2-5-5v-.5c0-.34.02-.67.05-1L4.9 10.1c-.4-.4-.4-1 0-1.4.4-.4 1-.4 1.4 0l1.9 1.9c1.8-1.6 4.3-1.6 6.1 0l1.9-1.9zM19 10.5v.5c0 3.9-3.1 7-7 7s-7-3.1-7-7v-.5c0-.8.7-1.5 1.5-1.5s1.5.7 1.5 1.5v.5c0 2.2 1.8 4 4 4s4-1.8 4-4v-.5c0-.8.7-1.5 1.5-1.5s1.5.7 1.5 1.5z" }) })) }));
|
|
56
|
+
};
|
|
57
|
+
exports.AutoBeVoiceRecoderButton = AutoBeVoiceRecoderButton;
|
|
58
|
+
//# sourceMappingURL=AutoBeVoiceRecoderButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AutoBeVoiceRecoderButton.js","sourceRoot":"","sources":["../src/AutoBeVoiceRecoderButton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import { AutoBeAnalyzeCompleteEvent, AutoBeInterfaceCompleteEvent, AutoBePrismaCompleteEvent, AutoBeRealizeCompleteEvent, AutoBeTestCompleteEvent, IAutoBeGetFilesOptions } from "@autobe/interface";
|
|
2
|
+
export interface IAutoBeCompleteEventMovieProps {
|
|
3
|
+
getFiles: (options?: Partial<IAutoBeGetFilesOptions>) => Promise<Record<string, string>>;
|
|
4
|
+
event: AutoBeAnalyzeCompleteEvent | AutoBePrismaCompleteEvent | AutoBeInterfaceCompleteEvent | AutoBeTestCompleteEvent | AutoBeRealizeCompleteEvent;
|
|
5
|
+
}
|
|
6
|
+
export declare const AutoBeCompleteEventMovie: (props: IAutoBeCompleteEventMovieProps) => import("react/jsx-runtime").JSX.Element | null;
|
|
7
|
+
export default AutoBeCompleteEventMovie;
|
|
@@ -0,0 +1,210 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
3
|
+
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
4
|
+
return new (P || (P = Promise))(function (resolve, reject) {
|
|
5
|
+
function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
|
|
6
|
+
function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
|
|
7
|
+
function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
|
|
8
|
+
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
|
+
});
|
|
10
|
+
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
14
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
15
|
+
exports.AutoBeCompleteEventMovie = void 0;
|
|
16
|
+
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
17
|
+
const sdk_1 = __importDefault(require("@stackblitz/sdk"));
|
|
18
|
+
const jszip_1 = __importDefault(require("jszip"));
|
|
19
|
+
const react_1 = require("react");
|
|
20
|
+
const tstl_1 = require("tstl");
|
|
21
|
+
const common_1 = require("./common");
|
|
22
|
+
const AutoBeCompleteEventMovie = (props) => {
|
|
23
|
+
const stage = getStage(props.event);
|
|
24
|
+
const [size, setSize] = (0, react_1.useState)(null);
|
|
25
|
+
const [downloading, setDownloading] = (0, react_1.useState)(false);
|
|
26
|
+
const getFiles = (dbms) => __awaiter(void 0, void 0, void 0, function* () {
|
|
27
|
+
setDownloading(true);
|
|
28
|
+
try {
|
|
29
|
+
const result = yield props.getFiles({
|
|
30
|
+
dbms,
|
|
31
|
+
stage,
|
|
32
|
+
});
|
|
33
|
+
return result;
|
|
34
|
+
}
|
|
35
|
+
catch (error) {
|
|
36
|
+
throw error;
|
|
37
|
+
}
|
|
38
|
+
finally {
|
|
39
|
+
setDownloading(false);
|
|
40
|
+
}
|
|
41
|
+
});
|
|
42
|
+
const openStackBlitz = () => __awaiter(void 0, void 0, void 0, function* () {
|
|
43
|
+
const files = Object.fromEntries(Object.entries(yield getFiles("sqlite")).filter(([key, value]) => key.startsWith("autobe/") === false &&
|
|
44
|
+
new TextEncoder().encode(value).length < 512 * 1024));
|
|
45
|
+
const size = Object.values(files)
|
|
46
|
+
.map((str) => new TextEncoder().encode(str).length)
|
|
47
|
+
.reduce((a, b) => a + b, 0);
|
|
48
|
+
setSize(size);
|
|
49
|
+
sdk_1.default.openProject({
|
|
50
|
+
title: `AutoBE Generated Backend Server (${props.event.type})`,
|
|
51
|
+
template: "node",
|
|
52
|
+
files,
|
|
53
|
+
}, {
|
|
54
|
+
newWindow: true,
|
|
55
|
+
});
|
|
56
|
+
});
|
|
57
|
+
const download = (dbms) => __awaiter(void 0, void 0, void 0, function* () {
|
|
58
|
+
const zip = new jszip_1.default();
|
|
59
|
+
const directory = new tstl_1.VariadicSingleton((location) => {
|
|
60
|
+
const separated = location.split("/");
|
|
61
|
+
if (separated.length === 1)
|
|
62
|
+
return zip.folder(separated[0]);
|
|
63
|
+
const parent = directory.get(separated.slice(0, -1).join("/"));
|
|
64
|
+
return parent.folder(separated.at(-1));
|
|
65
|
+
});
|
|
66
|
+
for (const [file, content] of Object.entries(yield getFiles(dbms))) {
|
|
67
|
+
const separated = file.split("/");
|
|
68
|
+
if (separated.length === 1)
|
|
69
|
+
zip.file(file, content);
|
|
70
|
+
else {
|
|
71
|
+
const folder = directory.get(separated.slice(0, -1).join("/"));
|
|
72
|
+
folder.file(separated.at(-1), content);
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
const data = yield zip.generateAsync({ type: "blob" });
|
|
76
|
+
const url = URL.createObjectURL(data);
|
|
77
|
+
const a = document.createElement("a");
|
|
78
|
+
a.href = url;
|
|
79
|
+
a.download = `AutoBE.${props.event.type}.zip`;
|
|
80
|
+
document.body.appendChild(a);
|
|
81
|
+
a.click();
|
|
82
|
+
document.body.removeChild(a);
|
|
83
|
+
URL.revokeObjectURL(url);
|
|
84
|
+
});
|
|
85
|
+
const title = getTitle(props.event);
|
|
86
|
+
if (title === null)
|
|
87
|
+
return null;
|
|
88
|
+
return ((0, jsx_runtime_1.jsxs)(common_1.EventCard, { variant: "success", children: [(0, jsx_runtime_1.jsx)(common_1.EventHeader, { title: `${title} Completed`, timestamp: props.event.created_at, iconType: "success" }), (0, jsx_runtime_1.jsxs)(common_1.EventContent, { children: [(0, jsx_runtime_1.jsxs)("div", { style: { marginBottom: "1rem" }, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
89
|
+
display: "inline-flex",
|
|
90
|
+
alignItems: "center",
|
|
91
|
+
padding: "6px 12px",
|
|
92
|
+
border: "1px solid #4caf50",
|
|
93
|
+
borderRadius: "16px",
|
|
94
|
+
backgroundColor: "transparent",
|
|
95
|
+
color: "#4caf50",
|
|
96
|
+
fontSize: "14px",
|
|
97
|
+
fontWeight: 500,
|
|
98
|
+
gap: "6px",
|
|
99
|
+
marginBottom: "1rem",
|
|
100
|
+
}, children: ["\u2705 ", title, " Completed"] }), (0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsx)("br", {}), title, " has been completed.", getMessage(openStackBlitz, props.event), (0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsx)("br", {}), "Please check the result in the file explorer.", size !== null && size >= LIMIT && ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
101
|
+
backgroundColor: "#fffbeb",
|
|
102
|
+
border: "1px solid #fed7aa",
|
|
103
|
+
borderRadius: "0.5rem",
|
|
104
|
+
padding: "1rem",
|
|
105
|
+
marginTop: "1rem",
|
|
106
|
+
color: "#92400e",
|
|
107
|
+
}, children: [(0, jsx_runtime_1.jsx)("strong", { children: "\u26A0\uFE0F Warning:" }), " This project is too large (", (size / 1024 / 1024).toFixed(1), " MB) for StackBlitz.", (0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsx)("br", {}), "Try downloading it directly instead!"] }))] }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
108
|
+
display: "flex",
|
|
109
|
+
gap: "0.75rem",
|
|
110
|
+
justifyContent: "flex-end",
|
|
111
|
+
flexWrap: "wrap",
|
|
112
|
+
}, children: downloading ? ((0, jsx_runtime_1.jsx)("button", { disabled: true, style: {
|
|
113
|
+
display: "flex",
|
|
114
|
+
alignItems: "center",
|
|
115
|
+
gap: "0.5rem",
|
|
116
|
+
padding: "0.75rem 1rem",
|
|
117
|
+
backgroundColor: "#f3f4f6",
|
|
118
|
+
border: "1px solid #d1d5db",
|
|
119
|
+
borderRadius: "0.5rem",
|
|
120
|
+
cursor: "not-allowed",
|
|
121
|
+
fontSize: "0.875rem",
|
|
122
|
+
color: "#6b7280",
|
|
123
|
+
}, children: "\u23F3 Downloading Source Codes..." })) : props.event.type === "analyzeComplete" ? ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(ActionButton, { icon: "\uD83D\uDCE5", text: "Zip (SQLite)", onClick: () => download("sqlite"), title: stage !== "analyze"
|
|
124
|
+
? "Download SQLite-based backend application (ideal for local development and testing)"
|
|
125
|
+
: "Download requirement analysis report" }), (0, jsx_runtime_1.jsx)(ActionButton, { icon: "\uD83D\uDE80", text: "StackBlitz", onClick: () => openStackBlitz(), variant: size !== null && size >= LIMIT ? "warning" : "primary", title: "Open project in StackBlitz for instant online development and testing" })] })) : ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)(ActionButton, { icon: "\u2601\uFE0F", text: "Zip (Postgres)", onClick: () => download("postgres"), title: "Download PostgreSQL-based backend application (optimized for production deployment)" }), (0, jsx_runtime_1.jsx)(ActionButton, { icon: "\uD83D\uDCE5", text: "Zip (SQLite)", onClick: () => download("sqlite"), title: "Download SQLite-based backend application (ideal for local development and testing)" }), (0, jsx_runtime_1.jsx)(ActionButton, { icon: "\uD83D\uDE80", text: "StackBlitz", onClick: () => openStackBlitz(), variant: size !== null && size >= LIMIT ? "warning" : "primary", title: "Open project in StackBlitz for instant online development and testing" })] })) })] })] }));
|
|
126
|
+
};
|
|
127
|
+
exports.AutoBeCompleteEventMovie = AutoBeCompleteEventMovie;
|
|
128
|
+
const ActionButton = (props) => {
|
|
129
|
+
const { icon, text, onClick, title, variant = "primary" } = props;
|
|
130
|
+
const getButtonStyles = () => {
|
|
131
|
+
const baseStyles = {
|
|
132
|
+
display: "flex",
|
|
133
|
+
alignItems: "center",
|
|
134
|
+
gap: "0.5rem",
|
|
135
|
+
padding: "0.75rem 1rem",
|
|
136
|
+
borderRadius: "0.5rem",
|
|
137
|
+
cursor: "pointer",
|
|
138
|
+
fontSize: "0.875rem",
|
|
139
|
+
fontWeight: 500,
|
|
140
|
+
border: "1px solid",
|
|
141
|
+
transition: "all 0.2s ease",
|
|
142
|
+
};
|
|
143
|
+
if (variant === "warning") {
|
|
144
|
+
return Object.assign(Object.assign({}, baseStyles), { backgroundColor: "#fffbeb", borderColor: "#f59e0b", color: "#92400e" });
|
|
145
|
+
}
|
|
146
|
+
return Object.assign(Object.assign({}, baseStyles), { backgroundColor: "#3b82f6", borderColor: "#3b82f6", color: "#ffffff" });
|
|
147
|
+
};
|
|
148
|
+
return ((0, jsx_runtime_1.jsxs)("button", { onClick: onClick, title: title, style: getButtonStyles(), onMouseEnter: (e) => {
|
|
149
|
+
if (variant === "warning") {
|
|
150
|
+
e.currentTarget.style.backgroundColor = "#fef3c7";
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
e.currentTarget.style.backgroundColor = "#2563eb";
|
|
154
|
+
}
|
|
155
|
+
}, onMouseLeave: (e) => {
|
|
156
|
+
if (variant === "warning") {
|
|
157
|
+
e.currentTarget.style.backgroundColor = "#fffbeb";
|
|
158
|
+
}
|
|
159
|
+
else {
|
|
160
|
+
e.currentTarget.style.backgroundColor = "#3b82f6";
|
|
161
|
+
}
|
|
162
|
+
}, children: [(0, jsx_runtime_1.jsx)("span", { children: icon }), (0, jsx_runtime_1.jsx)("span", { children: text })] }));
|
|
163
|
+
};
|
|
164
|
+
// Helper functions
|
|
165
|
+
function getTitle(event) {
|
|
166
|
+
switch (event.type) {
|
|
167
|
+
case "analyzeComplete":
|
|
168
|
+
return "Analyze";
|
|
169
|
+
case "prismaComplete":
|
|
170
|
+
if (event.compiled.type !== "success")
|
|
171
|
+
return "Prisma (Error)";
|
|
172
|
+
return "Prisma";
|
|
173
|
+
case "interfaceComplete":
|
|
174
|
+
return "Interface";
|
|
175
|
+
case "testComplete":
|
|
176
|
+
return "Test";
|
|
177
|
+
case "realizeComplete":
|
|
178
|
+
return "Realize";
|
|
179
|
+
default:
|
|
180
|
+
event;
|
|
181
|
+
throw new Error("Unknown event type");
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
const getMessage = (openStackBlitz, event) => {
|
|
185
|
+
if (event.type === "prismaComplete" && event.compiled.type === "failure")
|
|
186
|
+
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsx)("br", {}), "Succeeded to compose ", (0, jsx_runtime_1.jsx)("code", { children: "AutoBePrisma.IApplication" }), " typed AST (Abstract Syntax Tree) data, but failed to generate Prisma schema files from it. This is a bug of ", (0, jsx_runtime_1.jsx)("code", { children: "@autobe" }), ". Please", " ", (0, jsx_runtime_1.jsx)("a", { href: "https://github.com/wrtnlabs/autobe/issues", target: "_blank", style: { color: "#3b82f6", textDecoration: "underline" }, children: "write a bug report to our repository" }), " ", "with the", " ", (0, jsx_runtime_1.jsx)("a", { href: "#", onClick: () => openStackBlitz(), style: { color: "#3b82f6", textDecoration: "underline" }, children: (0, jsx_runtime_1.jsx)("code", { children: "autobe/histories.json" }) }), " ", "file."] }));
|
|
187
|
+
else if ((event.type === "testComplete" || event.type === "realizeComplete") &&
|
|
188
|
+
event.compiled.type !== "success")
|
|
189
|
+
return ((0, jsx_runtime_1.jsxs)(jsx_runtime_1.Fragment, { children: [(0, jsx_runtime_1.jsx)("br", {}), (0, jsx_runtime_1.jsx)("br", {}), "Succeeded to compose", " ", event.type === "testComplete" ? "test functions" : "realize functions", ", but failed to pass the TypeScript compilation. This is a bug of", " ", (0, jsx_runtime_1.jsx)("code", { children: "@autobe" }), ". Please", " ", (0, jsx_runtime_1.jsx)("a", { href: "https://github.com/wrtnlabs/autobe/issues", target: "_blank", style: { color: "#3b82f6", textDecoration: "underline" }, children: "write a bug report to our repository" }), " ", "with the", " ", (0, jsx_runtime_1.jsx)("a", { href: "#", onClick: () => openStackBlitz(), style: { color: "#3b82f6", textDecoration: "underline" }, children: (0, jsx_runtime_1.jsx)("code", { children: "autobe/histories.json" }) }), " ", "file."] }));
|
|
190
|
+
return null;
|
|
191
|
+
};
|
|
192
|
+
const getStage = (event) => {
|
|
193
|
+
if (event.type === "analyzeComplete")
|
|
194
|
+
return "analyze";
|
|
195
|
+
else if (event.type === "prismaComplete")
|
|
196
|
+
return "prisma";
|
|
197
|
+
else if (event.type === "interfaceComplete")
|
|
198
|
+
return "interface";
|
|
199
|
+
else if (event.type === "testComplete")
|
|
200
|
+
return "test";
|
|
201
|
+
else if (event.type === "realizeComplete")
|
|
202
|
+
return "realize";
|
|
203
|
+
else {
|
|
204
|
+
event;
|
|
205
|
+
return undefined;
|
|
206
|
+
}
|
|
207
|
+
};
|
|
208
|
+
const LIMIT = 3 * 1024 * 1024;
|
|
209
|
+
exports.default = exports.AutoBeCompleteEventMovie;
|
|
210
|
+
//# sourceMappingURL=AutoBeCompleteEventMovie.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"AutoBeCompleteEventMovie.js","sourceRoot":"","sources":["../../src/events/AutoBeCompleteEventMovie.tsx"],"names":[],"mappings":"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"}
|
|
@@ -2,69 +2,10 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AutoBeProgressEventMovie = AutoBeProgressEventMovie;
|
|
4
4
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
-
const
|
|
5
|
+
const common_1 = require("./common");
|
|
6
6
|
function AutoBeProgressEventMovie(props) {
|
|
7
7
|
const state = getState(props.event);
|
|
8
|
-
return ((0, jsx_runtime_1.jsxs)("div", { style: {
|
|
9
|
-
backgroundColor: "#f8fafc",
|
|
10
|
-
border: "1px solid #e2e8f0",
|
|
11
|
-
borderRadius: "0.75rem",
|
|
12
|
-
padding: "1.5rem",
|
|
13
|
-
marginBottom: "1rem",
|
|
14
|
-
boxShadow: "0 1px 3px 0 rgb(0 0 0 / 0.1)",
|
|
15
|
-
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
16
|
-
display: "flex",
|
|
17
|
-
alignItems: "center",
|
|
18
|
-
justifyContent: "space-between",
|
|
19
|
-
marginBottom: "1rem",
|
|
20
|
-
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
21
|
-
display: "flex",
|
|
22
|
-
alignItems: "center",
|
|
23
|
-
gap: "0.75rem",
|
|
24
|
-
}, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
25
|
-
width: "2rem",
|
|
26
|
-
height: "2rem",
|
|
27
|
-
backgroundColor: "#4caf50",
|
|
28
|
-
borderRadius: "50%",
|
|
29
|
-
display: "flex",
|
|
30
|
-
alignItems: "center",
|
|
31
|
-
justifyContent: "center",
|
|
32
|
-
}, children: (0, jsx_runtime_1.jsx)("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "currentColor", style: { color: "#ffffff" }, children: (0, jsx_runtime_1.jsx)("path", { d: "M12 2C6.48 2 2 6.48 2 12s4.48 10 10 10 10-4.48 10-10S17.52 2 12 2zm-2 15l-5-5 1.41-1.41L10 14.17l7.59-7.59L19 8l-9 9z" }) }) }), (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("h3", { style: {
|
|
33
|
-
fontSize: "1.125rem",
|
|
34
|
-
fontWeight: "600",
|
|
35
|
-
color: "#1e293b",
|
|
36
|
-
margin: 0,
|
|
37
|
-
marginBottom: "0.25rem",
|
|
38
|
-
}, children: state.title }) })] }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
39
|
-
fontSize: "0.75rem",
|
|
40
|
-
color: "#64748b",
|
|
41
|
-
textAlign: "right",
|
|
42
|
-
}, children: (0, time_1.formatTime)(props.event.created_at) })] }), (0, jsx_runtime_1.jsxs)("div", { style: {
|
|
43
|
-
fontSize: "0.875rem",
|
|
44
|
-
lineHeight: "1.5",
|
|
45
|
-
color: "#475569",
|
|
46
|
-
backgroundColor: "#ffffff",
|
|
47
|
-
padding: "1rem",
|
|
48
|
-
borderRadius: "0.5rem",
|
|
49
|
-
border: "1px solid #e2e8f0",
|
|
50
|
-
}, children: [(0, jsx_runtime_1.jsx)("div", { style: { marginBottom: "1rem" }, children: state.description }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
51
|
-
width: "100%",
|
|
52
|
-
height: "10px",
|
|
53
|
-
backgroundColor: "#e2e8f0",
|
|
54
|
-
borderRadius: "10px",
|
|
55
|
-
overflow: "hidden",
|
|
56
|
-
marginBottom: "0.5rem",
|
|
57
|
-
}, children: (0, jsx_runtime_1.jsx)("div", { style: {
|
|
58
|
-
width: `${Math.round((state.completed / state.total) * 100)}%`,
|
|
59
|
-
height: "100%",
|
|
60
|
-
backgroundColor: "#4caf50",
|
|
61
|
-
borderRadius: "10px",
|
|
62
|
-
transition: "width 0.3s ease",
|
|
63
|
-
} }) }), (0, jsx_runtime_1.jsxs)("div", { style: {
|
|
64
|
-
fontSize: "0.75rem",
|
|
65
|
-
color: "#64748b",
|
|
66
|
-
textAlign: "center",
|
|
67
|
-
}, children: [state.completed, " / ", state.total, " completed"] })] })] }));
|
|
8
|
+
return ((0, jsx_runtime_1.jsxs)(common_1.EventCard, { children: [(0, jsx_runtime_1.jsx)(common_1.EventHeader, { title: state.title, timestamp: props.event.created_at, iconType: "progress" }), (0, jsx_runtime_1.jsxs)(common_1.EventContent, { children: [(0, jsx_runtime_1.jsx)("div", { style: { marginBottom: 0 }, children: state.description }), (0, jsx_runtime_1.jsx)(common_1.ProgressBar, { current: state.completed, total: state.total })] })] }));
|
|
68
9
|
}
|
|
69
10
|
function getState(event) {
|
|
70
11
|
const content = (() => {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"AutoBeProgressEventMovie.js","sourceRoot":"","sources":["../../src/events/AutoBeProgressEventMovie.tsx"],"names":[],"mappings":";;AAIA,
|
|
1
|
+
{"version":3,"file":"AutoBeProgressEventMovie.js","sourceRoot":"","sources":["../../src/events/AutoBeProgressEventMovie.tsx"],"names":[],"mappings":"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"}
|
|
@@ -2,53 +2,11 @@
|
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.AutoBeScenarioEventMovie = void 0;
|
|
4
4
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
5
|
-
const
|
|
5
|
+
const common_1 = require("./common");
|
|
6
6
|
const AutoBeScenarioEventMovie = (props) => {
|
|
7
7
|
const { event } = props;
|
|
8
8
|
const { title, description } = getState(event);
|
|
9
|
-
return ((0, jsx_runtime_1.jsxs)("
|
|
10
|
-
backgroundColor: "#f8fafc",
|
|
11
|
-
border: "1px solid #e2e8f0",
|
|
12
|
-
borderRadius: "0.75rem",
|
|
13
|
-
padding: "1.5rem",
|
|
14
|
-
marginBottom: "1rem",
|
|
15
|
-
boxShadow: "0 1px 3px 0 rgb(0 0 0 / 0.1)",
|
|
16
|
-
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
17
|
-
display: "flex",
|
|
18
|
-
alignItems: "center",
|
|
19
|
-
justifyContent: "space-between",
|
|
20
|
-
marginBottom: "1rem",
|
|
21
|
-
}, children: [(0, jsx_runtime_1.jsxs)("div", { style: {
|
|
22
|
-
display: "flex",
|
|
23
|
-
alignItems: "center",
|
|
24
|
-
gap: "0.75rem",
|
|
25
|
-
}, children: [(0, jsx_runtime_1.jsx)("div", { style: {
|
|
26
|
-
width: "2rem",
|
|
27
|
-
height: "2rem",
|
|
28
|
-
backgroundColor: "#3b82f6",
|
|
29
|
-
borderRadius: "50%",
|
|
30
|
-
display: "flex",
|
|
31
|
-
alignItems: "center",
|
|
32
|
-
justifyContent: "center",
|
|
33
|
-
}, children: (0, jsx_runtime_1.jsx)("svg", { width: "16", height: "16", viewBox: "0 0 24 24", fill: "currentColor", style: { color: "#ffffff" }, children: (0, jsx_runtime_1.jsx)("path", { d: "M12 2l3.09 6.26L22 9.27l-5 4.87 1.18 6.88L12 17.77l-6.18 3.25L7 14.14 2 9.27l6.91-1.01L12 2z" }) }) }), (0, jsx_runtime_1.jsx)("div", { children: (0, jsx_runtime_1.jsx)("h3", { style: {
|
|
34
|
-
fontSize: "1.125rem",
|
|
35
|
-
fontWeight: "600",
|
|
36
|
-
color: "#1e293b",
|
|
37
|
-
margin: 0,
|
|
38
|
-
marginBottom: "0.25rem",
|
|
39
|
-
}, children: title }) })] }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
40
|
-
fontSize: "0.75rem",
|
|
41
|
-
color: "#64748b",
|
|
42
|
-
textAlign: "right",
|
|
43
|
-
}, children: (0, time_1.formatTime)(event.created_at) })] }), (0, jsx_runtime_1.jsx)("div", { style: {
|
|
44
|
-
fontSize: "0.875rem",
|
|
45
|
-
lineHeight: "1.5",
|
|
46
|
-
color: "#475569",
|
|
47
|
-
backgroundColor: "#ffffff",
|
|
48
|
-
padding: "1rem",
|
|
49
|
-
borderRadius: "0.5rem",
|
|
50
|
-
border: "1px solid #e2e8f0",
|
|
51
|
-
}, children: description })] }));
|
|
9
|
+
return ((0, jsx_runtime_1.jsxs)(common_1.EventCard, { children: [(0, jsx_runtime_1.jsx)(common_1.EventHeader, { title: title, timestamp: event.created_at, iconType: "info" }), (0, jsx_runtime_1.jsx)(common_1.EventContent, { children: description })] }));
|
|
52
10
|
};
|
|
53
11
|
exports.AutoBeScenarioEventMovie = AutoBeScenarioEventMovie;
|
|
54
12
|
exports.default = exports.AutoBeScenarioEventMovie;
|