featurely-site-manager 1.1.17 → 1.1.18
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 +6 -6
- package/dist/index.mjs +6 -6
- package/package.json +1 -1
package/dist/index.js
CHANGED
|
@@ -484,13 +484,13 @@ var _SiteManager = class _SiteManager {
|
|
|
484
484
|
}
|
|
485
485
|
} catch (fetchError) {
|
|
486
486
|
const sentViaBeacon = typeof navigator !== "undefined" && typeof navigator.sendBeacon === "function" && navigator.sendBeacon(url, payload);
|
|
487
|
+
const errMsg = fetchError instanceof Error ? fetchError.message : String(fetchError);
|
|
487
488
|
if (!sentViaBeacon) {
|
|
488
|
-
const errMsg = fetchError instanceof Error ? fetchError.message : String(fetchError);
|
|
489
489
|
console.error(`[Featurely] Failed to send analytics event "${event.eventName}":`, fetchError);
|
|
490
490
|
this.debugLog("error", `[analytics] send failed for "${event.eventName}": ${errMsg}`);
|
|
491
491
|
this.errorCount++;
|
|
492
492
|
} else {
|
|
493
|
-
this.debugLog("warn", `[analytics] fetch failed for "${event.eventName}", delivered via sendBeacon`);
|
|
493
|
+
this.debugLog("warn", `[analytics] fetch failed for "${event.eventName}" (${errMsg}), delivered via sendBeacon`);
|
|
494
494
|
}
|
|
495
495
|
}
|
|
496
496
|
}
|
|
@@ -653,7 +653,7 @@ var _SiteManager = class _SiteManager {
|
|
|
653
653
|
}
|
|
654
654
|
}
|
|
655
655
|
} else if (tab === "logs") {
|
|
656
|
-
const logs = this.debugLogs
|
|
656
|
+
const logs = this.debugLogs;
|
|
657
657
|
const errorsInLog = logs.filter((l) => l.level === "error").length;
|
|
658
658
|
const clearBtn = `<button data-action="clear-logs" style="background:rgba(255,255,255,0.08);border:none;color:${MUTED};cursor:pointer;font-size:9px;font-family:inherit;padding:2px 7px;border-radius:3px">Clear</button>`;
|
|
659
659
|
const copyBtn = `<button data-action="copy-logs" style="background:rgba(255,255,255,0.08);border:none;color:${MUTED};cursor:pointer;font-size:9px;font-family:inherit;padding:2px 7px;border-radius:3px">Copy</button>`;
|
|
@@ -662,10 +662,10 @@ var _SiteManager = class _SiteManager {
|
|
|
662
662
|
if (logs.length === 0) {
|
|
663
663
|
content = logHeader + `<div style="color:${MUTED};padding:12px;text-align:center">No logs yet</div>`;
|
|
664
664
|
} else {
|
|
665
|
-
content = logHeader + logs.map((l) => {
|
|
665
|
+
content = logHeader + `<div style="user-select:text;-webkit-user-select:text">` + logs.map((l) => {
|
|
666
666
|
const c = l.level === "error" ? RED : l.level === "warn" ? YELLOW : "#a5b4fc";
|
|
667
|
-
return `<div style="padding:2px 0;display:flex;gap:6px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,0.03)"><span style="color:${MUTED};white-space:nowrap;font-size:9px">${l.ts}</span><span style="color:${c};flex:1;word-break:break-word">${l.msg}</span></div>`;
|
|
668
|
-
}).join("")
|
|
667
|
+
return `<div style="padding:2px 0;display:flex;gap:6px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,0.03)"><span style="color:${MUTED};white-space:nowrap;font-size:9px">${l.ts}</span><span style="color:${c};flex:1;word-break:break-word;cursor:text">${l.msg}</span></div>`;
|
|
668
|
+
}).join("") + `</div>`;
|
|
669
669
|
}
|
|
670
670
|
} else if (tab === "network") {
|
|
671
671
|
const calls = this.networkLog.slice(0, 20);
|
package/dist/index.mjs
CHANGED
|
@@ -449,13 +449,13 @@ var _SiteManager = class _SiteManager {
|
|
|
449
449
|
}
|
|
450
450
|
} catch (fetchError) {
|
|
451
451
|
const sentViaBeacon = typeof navigator !== "undefined" && typeof navigator.sendBeacon === "function" && navigator.sendBeacon(url, payload);
|
|
452
|
+
const errMsg = fetchError instanceof Error ? fetchError.message : String(fetchError);
|
|
452
453
|
if (!sentViaBeacon) {
|
|
453
|
-
const errMsg = fetchError instanceof Error ? fetchError.message : String(fetchError);
|
|
454
454
|
console.error(`[Featurely] Failed to send analytics event "${event.eventName}":`, fetchError);
|
|
455
455
|
this.debugLog("error", `[analytics] send failed for "${event.eventName}": ${errMsg}`);
|
|
456
456
|
this.errorCount++;
|
|
457
457
|
} else {
|
|
458
|
-
this.debugLog("warn", `[analytics] fetch failed for "${event.eventName}", delivered via sendBeacon`);
|
|
458
|
+
this.debugLog("warn", `[analytics] fetch failed for "${event.eventName}" (${errMsg}), delivered via sendBeacon`);
|
|
459
459
|
}
|
|
460
460
|
}
|
|
461
461
|
}
|
|
@@ -618,7 +618,7 @@ var _SiteManager = class _SiteManager {
|
|
|
618
618
|
}
|
|
619
619
|
}
|
|
620
620
|
} else if (tab === "logs") {
|
|
621
|
-
const logs = this.debugLogs
|
|
621
|
+
const logs = this.debugLogs;
|
|
622
622
|
const errorsInLog = logs.filter((l) => l.level === "error").length;
|
|
623
623
|
const clearBtn = `<button data-action="clear-logs" style="background:rgba(255,255,255,0.08);border:none;color:${MUTED};cursor:pointer;font-size:9px;font-family:inherit;padding:2px 7px;border-radius:3px">Clear</button>`;
|
|
624
624
|
const copyBtn = `<button data-action="copy-logs" style="background:rgba(255,255,255,0.08);border:none;color:${MUTED};cursor:pointer;font-size:9px;font-family:inherit;padding:2px 7px;border-radius:3px">Copy</button>`;
|
|
@@ -627,10 +627,10 @@ var _SiteManager = class _SiteManager {
|
|
|
627
627
|
if (logs.length === 0) {
|
|
628
628
|
content = logHeader + `<div style="color:${MUTED};padding:12px;text-align:center">No logs yet</div>`;
|
|
629
629
|
} else {
|
|
630
|
-
content = logHeader + logs.map((l) => {
|
|
630
|
+
content = logHeader + `<div style="user-select:text;-webkit-user-select:text">` + logs.map((l) => {
|
|
631
631
|
const c = l.level === "error" ? RED : l.level === "warn" ? YELLOW : "#a5b4fc";
|
|
632
|
-
return `<div style="padding:2px 0;display:flex;gap:6px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,0.03)"><span style="color:${MUTED};white-space:nowrap;font-size:9px">${l.ts}</span><span style="color:${c};flex:1;word-break:break-word">${l.msg}</span></div>`;
|
|
633
|
-
}).join("")
|
|
632
|
+
return `<div style="padding:2px 0;display:flex;gap:6px;align-items:flex-start;border-bottom:1px solid rgba(255,255,255,0.03)"><span style="color:${MUTED};white-space:nowrap;font-size:9px">${l.ts}</span><span style="color:${c};flex:1;word-break:break-word;cursor:text">${l.msg}</span></div>`;
|
|
633
|
+
}).join("") + `</div>`;
|
|
634
634
|
}
|
|
635
635
|
} else if (tab === "network") {
|
|
636
636
|
const calls = this.networkLog.slice(0, 20);
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "featurely-site-manager",
|
|
3
|
-
"version": "1.1.
|
|
3
|
+
"version": "1.1.18",
|
|
4
4
|
"description": "Complete site management SDK for maintenance mode, status messages, feature flags, version checking, and analytics",
|
|
5
5
|
"main": "dist/index.js",
|
|
6
6
|
"module": "dist/index.mjs",
|