@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 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.jsxs)("div", { children: [
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__ */ jsxs7("div", { children: [
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 Fragment3, jsx as jsx14, jsxs as jsxs13 } from "react/jsx-runtime";
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(Fragment3, { children: [
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: [
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bbearai/react",
3
- "version": "0.3.0",
3
+ "version": "0.3.1",
4
4
  "description": "BugBear React components for web apps",
5
5
  "main": "./dist/index.js",
6
6
  "module": "./dist/index.mjs",