Remove skip agent logic from main entry

cgen-ab086bcfc0d24b64bbd013b3af4af5f6
This commit is contained in:
Builder.io 2025-10-14 01:25:19 +00:00
parent b809ced5f1
commit e5867c2f49

View file

@ -3,18 +3,6 @@ import { createRoot } from "react-dom/client";
import App from "./App";
import ErrorBoundary from "./components/ErrorBoundary";
declare global {
interface Window {
SkipAgent?: {
embed: (
agentId: string,
options?: Record<string, unknown>,
) => Promise<unknown>;
};
__aethexSkipAgentInit?: boolean;
}
}
const container = document.getElementById("root");
if (!container) {
throw new Error("Root element not found");
@ -28,320 +16,3 @@ root.render(
</ErrorBoundary>
</StrictMode>,
);
const SKIP_AGENT_ID = "vVEuropu5l7xvT4Swwif";
const SKIP_AGENT_SRC = "https://helloskip.com/agent.js";
const SKIP_AGENT_SCRIPT_ID = "aethex-skip-agent-runtime";
const SKIP_AGENT_THEME_ID = "aethex-skip-agent-theme";
const SKIP_AGENT_EMBED_OPTIONS = {
buttonSize: 66,
iframeWidth: 448,
iframeHeight: "85vh",
buttonPosition: "bottom-right",
buttonOffset: { x: 32, y: 32 },
animationDuration: 240,
tooltipText: "Need a hand?\nAeThex Copilot is live.",
tooltipColor: "#16122A",
zIndex: 2_147_483_000,
};
const SKIP_AGENT_THEME = `
.skip-agent-button {
background-image: linear-gradient(135deg, hsl(var(--aethex-600)) 0%, hsl(var(--neon-blue)) 48%, hsl(var(--neon-purple)) 100%) !important;
border-radius: 1.25rem !important;
border: 1px solid hsla(252, 88%, 68%, 0.35) !important;
box-shadow:
0 18px 38px rgba(24, 18, 54, 0.65),
0 0 0 1px rgba(126, 106, 255, 0.28) !important;
color: hsl(var(--primary-foreground)) !important;
backdrop-filter: blur(18px);
transition: transform 0.3s ease, box-shadow 0.3s ease, filter 0.3s ease !important;
}
.skip-agent-button:hover {
transform: translateY(-2px) scale(1.04) !important;
box-shadow:
0 24px 48px rgba(26, 20, 66, 0.7),
0 0 0 1px rgba(126, 106, 255, 0.42) !important;
}
.skip-agent-button:active {
transform: translateY(1px) scale(0.97) !important;
}
.skip-agent-button:focus-visible {
outline: 2px solid hsl(var(--neon-blue)) !important;
outline-offset: 4px !important;
}
.skip-agent-button svg {
width: 26px !important;
height: 26px !important;
stroke: currentColor !important;
stroke-width: 1.6 !important;
fill: none !important;
}
.skip-agent-tooltip {
background: rgba(14, 12, 28, 0.93) !important;
color: hsl(var(--foreground)) !important;
border: 1px solid hsla(252, 88%, 68%, 0.35) !important;
box-shadow: 0 18px 34px rgba(8, 6, 24, 0.7) !important;
backdrop-filter: blur(20px);
font-family: inherit !important;
font-size: 0.75rem !important;
letter-spacing: 0.04em !important;
text-transform: uppercase;
line-height: 1.25rem !important;
white-space: pre-line;
}
.skip-agent-iframe-container {
background: rgba(9, 11, 22, 0.92) !important;
border-radius: 1.5rem !important;
border: 1px solid hsla(252, 88%, 68%, 0.28) !important;
box-shadow:
0 40px 72px rgba(5, 8, 24, 0.75),
0 0 0 1px rgba(126, 106, 255, 0.22) !important;
backdrop-filter: blur(26px);
overflow: hidden !important;
}
.skip-agent-iframe {
background: transparent !important;
}
.skip-agent-overlay {
background: radial-gradient(circle at 85% 15%, rgba(102, 76, 255, 0.35), rgba(5, 8, 20, 0.85)) !important;
backdrop-filter: blur(6px);
}
.skip-agent-close {
top: 18px !important;
right: 18px !important;
width: 40px !important;
height: 40px !important;
display: inline-flex !important;
align-items: center !important;
justify-content: center !important;
border-radius: 9999px !important;
border: 1px solid hsla(252, 88%, 68%, 0.35) !important;
background: rgba(20, 16, 36, 0.85) !important;
color: hsl(var(--foreground)) !important;
font-size: 18px !important;
transition: transform 0.2s ease, box-shadow 0.2s ease !important;
}
.skip-agent-close:hover {
transform: rotate(90deg) scale(1.05) !important;
box-shadow: 0 12px 28px rgba(32, 24, 76, 0.55) !important;
}
.skip-agent-close:focus-visible {
outline: 2px solid hsl(var(--neon-blue)) !important;
outline-offset: 3px !important;
}
.skip-agent-loading {
background: linear-gradient(135deg, rgba(18, 14, 34, 0.92), rgba(10, 12, 26, 0.88)) !important;
border-radius: 1.25rem !important;
border: 1px solid hsla(252, 88%, 68%, 0.25) !important;
padding: 1.5rem !important;
gap: 0.75rem !important;
box-shadow: inset 0 0 0 1px rgba(126, 106, 255, 0.2) !important;
}
.skip-agent-spinner {
border: 3px solid rgba(126, 106, 255, 0.15) !important;
border-top-color: hsl(var(--neon-blue)) !important;
}
.skip-agent-loading-text {
color: hsl(var(--muted-foreground)) !important;
font-size: 0.75rem !important;
letter-spacing: 0.2em !important;
text-transform: uppercase !important;
}
@media (prefers-reduced-motion: reduce) {
.skip-agent-button,
.skip-agent-iframe-container,
.skip-agent-overlay {
transition: none !important;
}
}
@media (max-width: 768px) {
.skip-agent-button {
width: 60px !important;
height: 60px !important;
border-radius: 1rem !important;
}
.skip-agent-iframe-container {
border-radius: 1.25rem !important;
inset-inline: 16px !important;
}
}
`;
const createSkipAgentTheme = () => {
if (typeof document === "undefined") return;
if (document.getElementById(SKIP_AGENT_THEME_ID)) return;
const style = document.createElement("style");
style.id = SKIP_AGENT_THEME_ID;
style.textContent = SKIP_AGENT_THEME;
document.head.appendChild(style);
};
const SKIP_AGENT_ORIGIN = new URL(SKIP_AGENT_SRC).origin;
const isSkipAgentReachable = async (): Promise<boolean> => {
const controller = new AbortController();
const timeout = window.setTimeout(() => controller.abort(), 4000);
try {
const response = await fetch(
`${SKIP_AGENT_ORIGIN}/api/agent/status?agentId=${encodeURIComponent(SKIP_AGENT_ID)}`,
{
method: "GET",
mode: "cors",
credentials: "omit",
headers: {
Accept: "application/json",
},
cache: "no-store",
signal: controller.signal,
},
);
window.clearTimeout(timeout);
if (!response.ok) {
throw new Error(`Skip agent status request failed with ${response.status}`);
}
const payload = (await response.json().catch(() => null)) as
| { active?: boolean }
| null;
if (payload && payload.active === false) {
throw new Error("Skip agent is inactive");
}
return true;
} catch (error) {
window.clearTimeout(timeout);
console.warn(
"Skip Agent status endpoint unreachable; skipping embed to prevent runtime errors:",
error,
);
return false;
}
};
const embedSkipAgent = async () => {
if (typeof window === "undefined" || typeof document === "undefined") {
return;
}
if (!window.SkipAgent?.embed) {
return;
}
if (window.__aethexSkipAgentInit) {
return;
}
const reachable = await isSkipAgentReachable();
if (!reachable) {
return;
}
try {
await window.SkipAgent.embed(SKIP_AGENT_ID, SKIP_AGENT_EMBED_OPTIONS);
window.__aethexSkipAgentInit = true;
createSkipAgentTheme();
} catch (error) {
window.__aethexSkipAgentInit = false;
console.warn("Skip Agent embed failed:", error);
}
};
const loadSkipAgent = async (): Promise<void> => {
if (typeof window === "undefined" || typeof document === "undefined") {
return;
}
if (!("fetch" in window)) {
return;
}
if (!navigator.onLine) {
window.addEventListener(
"online",
() => {
void loadSkipAgent();
},
{ once: true },
);
return;
}
if (window.SkipAgent?.embed) {
await embedSkipAgent();
return;
}
const existingScript = document.getElementById(
SKIP_AGENT_SCRIPT_ID,
) as HTMLScriptElement | null;
if (existingScript) {
existingScript.addEventListener(
"load",
() => {
void embedSkipAgent();
},
{ once: true },
);
return;
}
try {
const controller = new AbortController();
const timeout = window.setTimeout(() => controller.abort(), 5000);
const response = await fetch(SKIP_AGENT_SRC, { signal: controller.signal });
window.clearTimeout(timeout);
if (!response.ok) {
throw new Error("Failed to download HelloSkip agent script");
}
const scriptText = await response.text();
const blobUrl = URL.createObjectURL(
new Blob([scriptText], { type: "application/javascript" }),
);
const script = document.createElement("script");
script.id = SKIP_AGENT_SCRIPT_ID;
script.async = true;
script.src = blobUrl;
script.onload = () => {
URL.revokeObjectURL(blobUrl);
void embedSkipAgent();
};
script.onerror = (event) => {
URL.revokeObjectURL(blobUrl);
window.__aethexSkipAgentInit = false;
console.warn("HelloSkip agent failed to execute", event);
};
document.body.appendChild(script);
} catch (error) {
window.__aethexSkipAgentInit = false;
console.warn("Skipped loading HelloSkip agent:", error);
}
};
void loadSkipAgent();