@bbearai/react 0.3.0 → 0.3.1
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/dist/index.js +93 -3
- package/dist/index.mjs +96 -6
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -790,7 +790,10 @@ function TestDetailScreen({ testId, nav }) {
|
|
|
790
790
|
if (!client || !displayedAssignment || isSubmitting) return;
|
|
791
791
|
setIsSubmitting(true);
|
|
792
792
|
try {
|
|
793
|
-
await client.updateAssignmentStatus(displayedAssignment.id, "failed");
|
|
793
|
+
const result = await client.updateAssignmentStatus(displayedAssignment.id, "failed");
|
|
794
|
+
if (!result.success) {
|
|
795
|
+
console.error("BugBear: Failed to mark assignment as failed", result.error);
|
|
796
|
+
}
|
|
794
797
|
await refreshAssignments();
|
|
795
798
|
nav.replace({
|
|
796
799
|
name: "REPORT",
|
|
@@ -2385,6 +2388,7 @@ function ReportScreen({ nav, prefill }) {
|
|
|
2385
2388
|
const observedRoute = (0, import_react8.useRef)(
|
|
2386
2389
|
typeof window !== "undefined" ? window.location.pathname : "unknown"
|
|
2387
2390
|
);
|
|
2391
|
+
const isRetestFailure = prefill?.type === "test_fail";
|
|
2388
2392
|
const isBugType = reportType === "bug" || reportType === "test_fail";
|
|
2389
2393
|
const handleSubmit = async () => {
|
|
2390
2394
|
if (!client || !description.trim() || images.isUploading) return;
|
|
@@ -2433,7 +2437,68 @@ function ReportScreen({ nav, prefill }) {
|
|
|
2433
2437
|
{ sev: "medium", color: "#eab308" },
|
|
2434
2438
|
{ sev: "low", color: "#6b7280" }
|
|
2435
2439
|
];
|
|
2436
|
-
return /* @__PURE__ */ (0, import_jsx_runtime8.
|
|
2440
|
+
return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { children: isRetestFailure ? /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(import_jsx_runtime8.Fragment, { children: [
|
|
2441
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { style: styles2.retestBanner, children: [
|
|
2442
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("span", { style: { fontSize: 16 }, children: "\u{1F504}" }),
|
|
2443
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { children: [
|
|
2444
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.retestTitle, children: "Bug Still Present" }),
|
|
2445
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.retestSubtitle, children: "The fix did not resolve this issue" })
|
|
2446
|
+
] })
|
|
2447
|
+
] }),
|
|
2448
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { style: styles2.section, children: [
|
|
2449
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.label, children: "Severity" }),
|
|
2450
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.severityRow, children: severityOptions.map(({ sev, color }) => /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
|
|
2451
|
+
"button",
|
|
2452
|
+
{
|
|
2453
|
+
onClick: () => setSeverity(sev),
|
|
2454
|
+
style: {
|
|
2455
|
+
...styles2.sevButton,
|
|
2456
|
+
...severity === sev ? { backgroundColor: `${color}30`, borderColor: color } : {}
|
|
2457
|
+
},
|
|
2458
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("span", { style: { ...styles2.sevText, ...severity === sev ? { color } : {} }, children: sev })
|
|
2459
|
+
},
|
|
2460
|
+
sev
|
|
2461
|
+
)) })
|
|
2462
|
+
] }),
|
|
2463
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsxs)("div", { style: styles2.section, children: [
|
|
2464
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.label, children: "What went wrong?" }),
|
|
2465
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
|
|
2466
|
+
"textarea",
|
|
2467
|
+
{
|
|
2468
|
+
style: styles2.descInput,
|
|
2469
|
+
value: description,
|
|
2470
|
+
onChange: (e) => setDescription(e.target.value),
|
|
2471
|
+
placeholder: "Describe what you observed. What still doesn't work?",
|
|
2472
|
+
rows: 4
|
|
2473
|
+
}
|
|
2474
|
+
)
|
|
2475
|
+
] }),
|
|
2476
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
|
|
2477
|
+
ImagePickerButtons,
|
|
2478
|
+
{
|
|
2479
|
+
images: images.images,
|
|
2480
|
+
maxImages: 5,
|
|
2481
|
+
onPickGallery: images.pickFromGallery,
|
|
2482
|
+
onPickCamera: images.pickFromCamera,
|
|
2483
|
+
onRemove: images.removeImage,
|
|
2484
|
+
label: "Attachments (optional)"
|
|
2485
|
+
}
|
|
2486
|
+
),
|
|
2487
|
+
error && /* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.errorBanner, children: error }),
|
|
2488
|
+
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)(
|
|
2489
|
+
"button",
|
|
2490
|
+
{
|
|
2491
|
+
style: {
|
|
2492
|
+
...styles2.submitButton,
|
|
2493
|
+
...styles2.submitButtonRetest,
|
|
2494
|
+
...!description.trim() || submitting || images.isUploading ? styles2.submitButtonDisabled : {}
|
|
2495
|
+
},
|
|
2496
|
+
onClick: handleSubmit,
|
|
2497
|
+
disabled: !description.trim() || submitting || images.isUploading,
|
|
2498
|
+
children: images.isUploading ? "Uploading images..." : submitting ? "Submitting..." : error ? "Retry" : "Submit Failed Retest"
|
|
2499
|
+
}
|
|
2500
|
+
)
|
|
2501
|
+
] }) : /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(import_jsx_runtime8.Fragment, { children: [
|
|
2437
2502
|
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.label, children: "What are you reporting?" }),
|
|
2438
2503
|
/* @__PURE__ */ (0, import_jsx_runtime8.jsx)("div", { style: styles2.typeRow, children: typeOptions.map(({ type, label, icon }) => /* @__PURE__ */ (0, import_jsx_runtime8.jsxs)(
|
|
2439
2504
|
"button",
|
|
@@ -2540,7 +2605,7 @@ function ReportScreen({ nav, prefill }) {
|
|
|
2540
2605
|
children: images.isUploading ? "Uploading images..." : submitting ? "Submitting..." : error ? "Retry" : "Submit Report"
|
|
2541
2606
|
}
|
|
2542
2607
|
)
|
|
2543
|
-
] });
|
|
2608
|
+
] }) });
|
|
2544
2609
|
}
|
|
2545
2610
|
var styles2 = {
|
|
2546
2611
|
label: {
|
|
@@ -2663,6 +2728,31 @@ var styles2 = {
|
|
|
2663
2728
|
submitButtonDisabled: {
|
|
2664
2729
|
opacity: 0.5,
|
|
2665
2730
|
cursor: "not-allowed"
|
|
2731
|
+
},
|
|
2732
|
+
submitButtonRetest: {
|
|
2733
|
+
backgroundColor: "#b45309"
|
|
2734
|
+
},
|
|
2735
|
+
retestBanner: {
|
|
2736
|
+
display: "flex",
|
|
2737
|
+
flexDirection: "row",
|
|
2738
|
+
alignItems: "center",
|
|
2739
|
+
gap: 10,
|
|
2740
|
+
backgroundColor: "#422006",
|
|
2741
|
+
border: "1px solid #854d0e",
|
|
2742
|
+
borderRadius: 10,
|
|
2743
|
+
padding: "12px 14px",
|
|
2744
|
+
marginBottom: 20
|
|
2745
|
+
},
|
|
2746
|
+
retestTitle: {
|
|
2747
|
+
fontSize: 15,
|
|
2748
|
+
fontWeight: 600,
|
|
2749
|
+
color: "#fbbf24",
|
|
2750
|
+
lineHeight: "20px"
|
|
2751
|
+
},
|
|
2752
|
+
retestSubtitle: {
|
|
2753
|
+
fontSize: 12,
|
|
2754
|
+
color: "#d97706",
|
|
2755
|
+
lineHeight: "16px"
|
|
2666
2756
|
}
|
|
2667
2757
|
};
|
|
2668
2758
|
|
package/dist/index.mjs
CHANGED
|
@@ -761,7 +761,10 @@ function TestDetailScreen({ testId, nav }) {
|
|
|
761
761
|
if (!client || !displayedAssignment || isSubmitting) return;
|
|
762
762
|
setIsSubmitting(true);
|
|
763
763
|
try {
|
|
764
|
-
await client.updateAssignmentStatus(displayedAssignment.id, "failed");
|
|
764
|
+
const result = await client.updateAssignmentStatus(displayedAssignment.id, "failed");
|
|
765
|
+
if (!result.success) {
|
|
766
|
+
console.error("BugBear: Failed to mark assignment as failed", result.error);
|
|
767
|
+
}
|
|
765
768
|
await refreshAssignments();
|
|
766
769
|
nav.replace({
|
|
767
770
|
name: "REPORT",
|
|
@@ -2343,7 +2346,7 @@ var styles = {
|
|
|
2343
2346
|
|
|
2344
2347
|
// src/widget/screens/ReportScreen.tsx
|
|
2345
2348
|
import { useState as useState6, useRef as useRef2 } from "react";
|
|
2346
|
-
import { jsx as jsx8, jsxs as jsxs7 } from "react/jsx-runtime";
|
|
2349
|
+
import { Fragment as Fragment3, jsx as jsx8, jsxs as jsxs7 } from "react/jsx-runtime";
|
|
2347
2350
|
function ReportScreen({ nav, prefill }) {
|
|
2348
2351
|
const { client, refreshAssignments, uploadImage } = useBugBear();
|
|
2349
2352
|
const images = useImageAttachments(uploadImage, 5, "screenshots");
|
|
@@ -2356,6 +2359,7 @@ function ReportScreen({ nav, prefill }) {
|
|
|
2356
2359
|
const observedRoute = useRef2(
|
|
2357
2360
|
typeof window !== "undefined" ? window.location.pathname : "unknown"
|
|
2358
2361
|
);
|
|
2362
|
+
const isRetestFailure = prefill?.type === "test_fail";
|
|
2359
2363
|
const isBugType = reportType === "bug" || reportType === "test_fail";
|
|
2360
2364
|
const handleSubmit = async () => {
|
|
2361
2365
|
if (!client || !description.trim() || images.isUploading) return;
|
|
@@ -2404,7 +2408,68 @@ function ReportScreen({ nav, prefill }) {
|
|
|
2404
2408
|
{ sev: "medium", color: "#eab308" },
|
|
2405
2409
|
{ sev: "low", color: "#6b7280" }
|
|
2406
2410
|
];
|
|
2407
|
-
return /* @__PURE__ */
|
|
2411
|
+
return /* @__PURE__ */ jsx8("div", { children: isRetestFailure ? /* @__PURE__ */ jsxs7(Fragment3, { children: [
|
|
2412
|
+
/* @__PURE__ */ jsxs7("div", { style: styles2.retestBanner, children: [
|
|
2413
|
+
/* @__PURE__ */ jsx8("span", { style: { fontSize: 16 }, children: "\u{1F504}" }),
|
|
2414
|
+
/* @__PURE__ */ jsxs7("div", { children: [
|
|
2415
|
+
/* @__PURE__ */ jsx8("div", { style: styles2.retestTitle, children: "Bug Still Present" }),
|
|
2416
|
+
/* @__PURE__ */ jsx8("div", { style: styles2.retestSubtitle, children: "The fix did not resolve this issue" })
|
|
2417
|
+
] })
|
|
2418
|
+
] }),
|
|
2419
|
+
/* @__PURE__ */ jsxs7("div", { style: styles2.section, children: [
|
|
2420
|
+
/* @__PURE__ */ jsx8("div", { style: styles2.label, children: "Severity" }),
|
|
2421
|
+
/* @__PURE__ */ jsx8("div", { style: styles2.severityRow, children: severityOptions.map(({ sev, color }) => /* @__PURE__ */ jsx8(
|
|
2422
|
+
"button",
|
|
2423
|
+
{
|
|
2424
|
+
onClick: () => setSeverity(sev),
|
|
2425
|
+
style: {
|
|
2426
|
+
...styles2.sevButton,
|
|
2427
|
+
...severity === sev ? { backgroundColor: `${color}30`, borderColor: color } : {}
|
|
2428
|
+
},
|
|
2429
|
+
children: /* @__PURE__ */ jsx8("span", { style: { ...styles2.sevText, ...severity === sev ? { color } : {} }, children: sev })
|
|
2430
|
+
},
|
|
2431
|
+
sev
|
|
2432
|
+
)) })
|
|
2433
|
+
] }),
|
|
2434
|
+
/* @__PURE__ */ jsxs7("div", { style: styles2.section, children: [
|
|
2435
|
+
/* @__PURE__ */ jsx8("div", { style: styles2.label, children: "What went wrong?" }),
|
|
2436
|
+
/* @__PURE__ */ jsx8(
|
|
2437
|
+
"textarea",
|
|
2438
|
+
{
|
|
2439
|
+
style: styles2.descInput,
|
|
2440
|
+
value: description,
|
|
2441
|
+
onChange: (e) => setDescription(e.target.value),
|
|
2442
|
+
placeholder: "Describe what you observed. What still doesn't work?",
|
|
2443
|
+
rows: 4
|
|
2444
|
+
}
|
|
2445
|
+
)
|
|
2446
|
+
] }),
|
|
2447
|
+
/* @__PURE__ */ jsx8(
|
|
2448
|
+
ImagePickerButtons,
|
|
2449
|
+
{
|
|
2450
|
+
images: images.images,
|
|
2451
|
+
maxImages: 5,
|
|
2452
|
+
onPickGallery: images.pickFromGallery,
|
|
2453
|
+
onPickCamera: images.pickFromCamera,
|
|
2454
|
+
onRemove: images.removeImage,
|
|
2455
|
+
label: "Attachments (optional)"
|
|
2456
|
+
}
|
|
2457
|
+
),
|
|
2458
|
+
error && /* @__PURE__ */ jsx8("div", { style: styles2.errorBanner, children: error }),
|
|
2459
|
+
/* @__PURE__ */ jsx8(
|
|
2460
|
+
"button",
|
|
2461
|
+
{
|
|
2462
|
+
style: {
|
|
2463
|
+
...styles2.submitButton,
|
|
2464
|
+
...styles2.submitButtonRetest,
|
|
2465
|
+
...!description.trim() || submitting || images.isUploading ? styles2.submitButtonDisabled : {}
|
|
2466
|
+
},
|
|
2467
|
+
onClick: handleSubmit,
|
|
2468
|
+
disabled: !description.trim() || submitting || images.isUploading,
|
|
2469
|
+
children: images.isUploading ? "Uploading images..." : submitting ? "Submitting..." : error ? "Retry" : "Submit Failed Retest"
|
|
2470
|
+
}
|
|
2471
|
+
)
|
|
2472
|
+
] }) : /* @__PURE__ */ jsxs7(Fragment3, { children: [
|
|
2408
2473
|
/* @__PURE__ */ jsx8("div", { style: styles2.label, children: "What are you reporting?" }),
|
|
2409
2474
|
/* @__PURE__ */ jsx8("div", { style: styles2.typeRow, children: typeOptions.map(({ type, label, icon }) => /* @__PURE__ */ jsxs7(
|
|
2410
2475
|
"button",
|
|
@@ -2511,7 +2576,7 @@ function ReportScreen({ nav, prefill }) {
|
|
|
2511
2576
|
children: images.isUploading ? "Uploading images..." : submitting ? "Submitting..." : error ? "Retry" : "Submit Report"
|
|
2512
2577
|
}
|
|
2513
2578
|
)
|
|
2514
|
-
] });
|
|
2579
|
+
] }) });
|
|
2515
2580
|
}
|
|
2516
2581
|
var styles2 = {
|
|
2517
2582
|
label: {
|
|
@@ -2634,6 +2699,31 @@ var styles2 = {
|
|
|
2634
2699
|
submitButtonDisabled: {
|
|
2635
2700
|
opacity: 0.5,
|
|
2636
2701
|
cursor: "not-allowed"
|
|
2702
|
+
},
|
|
2703
|
+
submitButtonRetest: {
|
|
2704
|
+
backgroundColor: "#b45309"
|
|
2705
|
+
},
|
|
2706
|
+
retestBanner: {
|
|
2707
|
+
display: "flex",
|
|
2708
|
+
flexDirection: "row",
|
|
2709
|
+
alignItems: "center",
|
|
2710
|
+
gap: 10,
|
|
2711
|
+
backgroundColor: "#422006",
|
|
2712
|
+
border: "1px solid #854d0e",
|
|
2713
|
+
borderRadius: 10,
|
|
2714
|
+
padding: "12px 14px",
|
|
2715
|
+
marginBottom: 20
|
|
2716
|
+
},
|
|
2717
|
+
retestTitle: {
|
|
2718
|
+
fontSize: 15,
|
|
2719
|
+
fontWeight: 600,
|
|
2720
|
+
color: "#fbbf24",
|
|
2721
|
+
lineHeight: "20px"
|
|
2722
|
+
},
|
|
2723
|
+
retestSubtitle: {
|
|
2724
|
+
fontSize: 12,
|
|
2725
|
+
color: "#d97706",
|
|
2726
|
+
lineHeight: "16px"
|
|
2637
2727
|
}
|
|
2638
2728
|
};
|
|
2639
2729
|
|
|
@@ -3823,7 +3913,7 @@ var styles4 = {
|
|
|
3823
3913
|
var BUGBEAR_LOGO_BASE64 = "";
|
|
3824
3914
|
|
|
3825
3915
|
// src/BugBearPanel.tsx
|
|
3826
|
-
import { Fragment as
|
|
3916
|
+
import { Fragment as Fragment4, jsx as jsx14, jsxs as jsxs13 } from "react/jsx-runtime";
|
|
3827
3917
|
function BugBearIcon({ size = 24 }) {
|
|
3828
3918
|
return /* @__PURE__ */ jsx14(
|
|
3829
3919
|
"img",
|
|
@@ -4106,7 +4196,7 @@ function BugBearPanel({
|
|
|
4106
4196
|
},
|
|
4107
4197
|
children: "\u2190 Back"
|
|
4108
4198
|
}
|
|
4109
|
-
) : /* @__PURE__ */ jsxs13(
|
|
4199
|
+
) : /* @__PURE__ */ jsxs13(Fragment4, { children: [
|
|
4110
4200
|
/* @__PURE__ */ jsx14(BugBearIcon, { size: 28 }),
|
|
4111
4201
|
/* @__PURE__ */ jsxs13("div", { children: [
|
|
4112
4202
|
/* @__PURE__ */ jsxs13("div", { style: { display: "flex", alignItems: "center", gap: 8 }, children: [
|