Some checks failed
Branch Build CE / Build Setup (push) Has been cancelled
Branch Build CE / Build-Push Admin Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Web Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Space Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Live Collaboration Docker Image (push) Has been cancelled
Branch Build CE / Build-Push API Server Docker Image (push) Has been cancelled
Branch Build CE / Build-Push Proxy Docker Image (push) Has been cancelled
Branch Build CE / Build-Push AIO Docker Image (push) Has been cancelled
Branch Build CE / Upload Build Assets (push) Has been cancelled
Branch Build CE / Build Release (push) Has been cancelled
CodeQL / Analyze (javascript) (push) Has been cancelled
CodeQL / Analyze (python) (push) Has been cancelled
Codespell / Check for spelling errors (push) Has been cancelled
Sync Repositories / sync_changes (push) Has been cancelled
Synced from upstream: 8853637e981ed7d8a6cff32bd98e7afe20f54362
56 lines
1.4 KiB
TypeScript
56 lines
1.4 KiB
TypeScript
"use client";
|
|
|
|
import { useEffect } from "react";
|
|
|
|
type ScriptProps = {
|
|
src?: string;
|
|
id?: string;
|
|
strategy?: "beforeInteractive" | "afterInteractive" | "lazyOnload" | "worker";
|
|
onLoad?: () => void;
|
|
onError?: () => void;
|
|
children?: string;
|
|
defer?: boolean;
|
|
[key: string]: any;
|
|
};
|
|
|
|
// Minimal shim for next/script that creates a script tag
|
|
const Script: React.FC<ScriptProps> = ({ src, id, strategy: _strategy, onLoad, onError, children, ...rest }) => {
|
|
useEffect(() => {
|
|
if (src) {
|
|
const script = document.createElement("script");
|
|
if (id) script.id = id;
|
|
script.src = src;
|
|
if (onLoad) script.onload = onLoad;
|
|
if (onError) script.onerror = onError;
|
|
Object.keys(rest).forEach((key) => {
|
|
script.setAttribute(key, rest[key]);
|
|
});
|
|
document.body.appendChild(script);
|
|
|
|
return () => {
|
|
if (script.parentNode) {
|
|
document.body.removeChild(script);
|
|
}
|
|
};
|
|
} else if (children) {
|
|
const script = document.createElement("script");
|
|
if (id) script.id = id;
|
|
script.textContent = children;
|
|
Object.keys(rest).forEach((key) => {
|
|
script.setAttribute(key, rest[key]);
|
|
});
|
|
document.body.appendChild(script);
|
|
|
|
return () => {
|
|
if (script.parentNode) {
|
|
document.body.removeChild(script);
|
|
}
|
|
};
|
|
}
|
|
}, [src, id, children, onLoad, onError, rest]);
|
|
|
|
return null;
|
|
};
|
|
|
|
export default Script;
|