aboutsummaryrefslogtreecommitdiff
path: root/examples
diff options
context:
space:
mode:
Diffstat (limited to 'examples')
-rw-r--r--examples/hello-next/bun-framework-next/.npmignore2
-rw-r--r--examples/hello-next/bun-framework-next/bun-error.css289
-rw-r--r--examples/hello-next/bun-framework-next/bun-error.tsx809
-rw-r--r--examples/hello-next/bun-framework-next/bun-error/close.pngbin757 -> 0 bytes
-rw-r--r--examples/hello-next/bun-framework-next/bun-error/error.pngbin717 -> 0 bytes
-rw-r--r--examples/hello-next/bun-framework-next/bun-error/powered-by.pngbin2863 -> 0 bytes
-rw-r--r--examples/hello-next/bun-framework-next/bun-error/powered-by.webpbin1316 -> 0 bytes
-rw-r--r--examples/hello-next/bun-framework-next/bun-runtime-error.ts163
-rw-r--r--examples/hello-next/bun-framework-next/client.development.tsx3
-rw-r--r--examples/hello-next/bun-framework-next/fallback.development.tsx82
-rw-r--r--examples/hello-next/bun-framework-next/index.js0
-rw-r--r--examples/hello-next/bun-framework-next/next-server.tsx0
-rw-r--r--examples/hello-next/bun-framework-next/package.json81
-rw-r--r--examples/hello-next/bun-framework-next/page-loader.ts147
-rw-r--r--examples/hello-next/bun-framework-next/render.tsx0
-rw-r--r--examples/hello-next/bun-framework-next/renderDocument.tsx722
-rw-r--r--examples/hello-next/bun-framework-next/route-loader.ts0
-rw-r--r--examples/hello-next/bun-framework-next/server.development.tsx79
-rw-r--r--examples/hello-next/bun-framework-next/server.production.tsx0
-rw-r--r--examples/hello-next/bun-framework-next/tsconfig.json21
-rw-r--r--examples/hello-next/package.json5
-rw-r--r--examples/hello-next/pages/errortest.tsx14
-rw-r--r--examples/hello-next/pages/index.tsx151
23 files changed, 93 insertions, 2475 deletions
diff --git a/examples/hello-next/bun-framework-next/.npmignore b/examples/hello-next/bun-framework-next/.npmignore
deleted file mode 100644
index dc0954477..000000000
--- a/examples/hello-next/bun-framework-next/.npmignore
+++ /dev/null
@@ -1,2 +0,0 @@
-*.bun
-node_modules \ No newline at end of file
diff --git a/examples/hello-next/bun-framework-next/bun-error.css b/examples/hello-next/bun-framework-next/bun-error.css
deleted file mode 100644
index c5ed9881b..000000000
--- a/examples/hello-next/bun-framework-next/bun-error.css
+++ /dev/null
@@ -1,289 +0,0 @@
-:host {
- --bun-error-color: #e33737;
- --bun-error-monospace: ui-monospace, Menlo, Monaco, "Cascadia Mono",
- "Segoe UI Mono", "Roboto Mono", "Oxygen Mono", "Ubuntu Monospace",
- "Source Code Pro", "Fira Mono", "Droid Sans Mono", "Courier New", monospace;
-}
-
-a {
- color: inherit;
- text-decoration: none;
-}
-
-a:hover {
- text-decoration: underline;
-}
-#BunErrorOverlay-container {
- box-shadow: 0px 16px 24px rgba(0, 0, 0, 0.06), 0px 2px 6px rgba(0, 0, 0, 0.1),
- 0px 0px 1px rgba(0, 0, 0, 0.04);
- backdrop-filter: blur(42px);
- backface-visibility: visible;
- border: inset 1px solid rgba(0, 0, 0, 0.2);
- border-radius: 17px;
- background-color: rgba(255, 255, 255, 0.92);
- width: 480px;
-
- position: fixed;
- top: 120px;
- right: 48px;
- z-index: 999999;
-
- font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica,
- Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
-}
-
-#BunErrorOverlay-container a {
- color: inherit;
-}
-
-.BunError-Summary-ErrorIcon {
- content: url("");
- width: 20px;
- height: 19px;
-
- margin-right: 6px;
- display: block;
-}
-
-.BunError-Summary-CloseIcon {
- content: url("");
- width: 22px;
- height: 22px;
- border-radius: 50%;
- cursor: pointer;
-}
-
-.BunError-Summary-CloseIcon:hover {
- transform: scale(1.2);
-
- background-color: rgb(255, 255, 255);
-}
-
-.BunError-Summary {
- display: grid;
- grid-template-columns: min-content auto min-content;
- grid-template-rows: 46px;
- align-items: center;
- padding: 0 18px;
- border-bottom: 1px solid rgb(220, 220, 220);
-}
-
-.BunError-footer {
- display: grid;
- padding: 12px 18px;
- justify-content: flex-end;
- border-top: 1px solid rgb(220, 220, 220);
- align-items: center;
-}
-
-.BunError-Summary-Title {
- font-weight: 500;
- letter-spacing: 0.36px;
-}
-
-.BunError-ErrorTag,
-.BunError-error-code {
- color: rgb(165, 165, 165);
- font-weight: 500;
- font-size: 12pt;
-}
-
-.BunError-ErrorTag {
- font-size: 14px;
- text-transform: uppercase;
- font-weight: 300;
-}
-
-.BunError-error-header {
- display: flex;
- align-items: center;
- gap: 0.5ch;
-}
-
-.BunError-error-message {
- color: var(--bun-error-color);
- font-size: 16pt;
- font-weight: bold;
-}
-
-.BunError-list {
- margin-top: 14px;
- gap: 14px;
-}
-
-.BunError-error-subtitle,
-.BunError-error-header,
-.BunError-error-message {
- padding-left: 18px;
- padding-right: 18px;
-}
-
-.BunError-error-subtitle {
- font-size: 500;
-}
-
-.BunError-NativeStackTrace {
- margin-top: 0;
- width: 100%;
-}
-
-.BunError-NativeStackTrace-filename {
- padding: 8px 18px;
- white-space: nowrap;
- text-overflow: ellipsis;
- overflow: hidden;
- font-weight: 500;
- letter-spacing: 0.36px;
- margin-bottom: 8px;
- display: block;
-}
-
-.BunError-NativeStackTrace-filename:hover {
- text-decoration: underline;
-}
-
-.BunError-SourceLines-lines {
-}
-
-.BunError-SourceLines {
- display: grid;
- grid-template-columns: min-content auto;
- grid-template-rows: repeat(16px, 6);
- column-gap: 13px;
- font-size: 14px;
- padding-left: 24px;
- align-items: center;
- position: relative;
- overflow-x: auto;
-}
-
-.BunError-SourceLine-text {
- white-space: pre;
- display: block;
-
- font-family: var(--bun-error-monospace);
-}
-
-.BunError-SourceLine-number {
- font-variant: tabular-nums;
- text-align: right;
- user-select: none;
- -webkit-user-select: none;
-}
-
-.BunError-SourceLine-number--empty {
- color: rgb(165, 165, 165);
-}
-
-.BunError-SourceLine-number,
-.BunError-SourceLine-text {
- height: 18px;
-}
-
-.BunError-SourceLines-highlighter--0,
-.BunError-SourceLines-highlighter--1,
-.BunError-SourceLines-highlighter--2,
-.BunError-SourceLines-highlighter--3,
-.BunError-SourceLines-highlighter--4,
-.BunError-SourceLines-highlighter--5 {
- position: absolute;
-}
-
-.BunError-SourceLine-text--highlight {
- color: #e33737;
-}
-
-#BunError-poweredBy {
- height: 16px;
-
- content: url("");
-}
-
-#BunError-SourceLine-text-highlightExpression {
- font-weight: bold;
- text-decoration-style: wavy;
-}
-
-.BunError-JSException--TypeError #BunError-SourceLine-text-highlightExpression {
- border: 1px solid rgba(0, 0, 0, 0.2);
-}
-.BunError-Indented {
- display: inline-block;
- user-select: none;
- -webkit-user-select: none;
-}
-
-.BunError-divet {
- vertical-align: bottom;
- user-select: none;
- -webkit-user-select: none;
-}
-
-.BunError-error-typename {
- font-family: var(--bun-error-monospace);
- color: #e39437;
- font-weight: bold;
-}
-
-.BunError-error-muted {
- font-weight: normal;
- user-select: none;
- -webkit-user-select: none;
-}
-
-.BunError-error-muted,
-.BunError-StackFrame--muted {
- color: rgb(165, 165, 165);
-}
-
-.BunError-NativeStackTrace .BunError-error-typename {
- user-select: none;
- -webkit-user-select: none;
-}
-
-.BunError-StackFrame-link {
-}
-
-.BunError-StackFrame-link-content {
- display: flex;
- gap: 0.25ch;
- white-space: nowrap;
-}
-
-.BunError-StackFrame {
- display: table-row;
-}
-
-.BunError-StackFrame-identifier {
- padding-right: 18px;
- font-size: 0.8em;
- font-family: var(--bun-error-monospace);
- letter-spacing: 0.49px;
-}
-
-.BunError-error-message--mono {
- font-family: var(--bun-error-monospace);
-}
-.BunError-StackFrame-identifier,
-.BunError-StackFrame-link {
- display: table-cell;
- font-weight: 500;
-}
-
-.BunError-BuildError {
- padding-bottom: 18px;
-}
-
-.BunError-StackFrame-link-content {
- font-size: 0.8em;
-}
-
-.BunError-StackFrames {
- display: table;
- table-layout: auto;
- padding: 13px 10px;
- margin: 8px auto;
- border-radius: 4px;
-
- background-color: rgb(244, 244, 244);
-}
diff --git a/examples/hello-next/bun-framework-next/bun-error.tsx b/examples/hello-next/bun-framework-next/bun-error.tsx
deleted file mode 100644
index 5d57dd0ea..000000000
--- a/examples/hello-next/bun-framework-next/bun-error.tsx
+++ /dev/null
@@ -1,809 +0,0 @@
-import type {
- FallbackMessageContainer,
- JSException as JSExceptionType,
- Message,
- SourceLine,
- StackFrame,
- Problems,
- FallbackStep,
- StackTrace,
- Location,
- JSException,
- WebsocketMessageBuildFailure,
-} from "../../../src/api/schema";
-
-import ReactDOM from "react-dom";
-import {
- useCallback,
- useState,
- useEffect,
- useLayoutEffect,
- createContext,
- useContext,
- Children,
-} from "react";
-
-enum StackFrameScope {
- Eval = 1,
- Module = 2,
- Function = 3,
- Global = 4,
- Wasm = 5,
- Constructor = 6,
-}
-
-enum JSErrorCode {
- Error = 0,
- EvalError = 1,
- RangeError = 2,
- ReferenceError = 3,
- SyntaxError = 4,
- TypeError = 5,
- URIError = 6,
- AggregateError = 7,
-
- // StackOverflow & OutOfMemoryError is not an ErrorType in <JavaScriptCore/ErrorType.h> within JSC, so the number here is just totally made up
- OutOfMemoryError = 8,
- BundlerError = 252,
- StackOverflow = 253,
- UserErrorCode = 254,
-}
-
-const JSErrorCodeLabel = {
- 0: "Error",
- 1: "EvalError",
- 2: "RangeError",
- 3: "ReferenceError",
- 4: "SyntaxError",
- 5: "TypeError",
- 6: "URIError",
- 7: "AggregateError",
- 253: "StackOverflow",
- 8: "OutOfMemory",
-};
-
-const BUN_ERROR_CONTAINER_ID = "__bun-error__";
-
-enum RuntimeType {
- Nothing = 0x0,
- Function = 0x1,
- Undefined = 0x2,
- Null = 0x4,
- Boolean = 0x8,
- AnyInt = 0x10,
- Number = 0x20,
- String = 0x40,
- Object = 0x80,
- Symbol = 0x100,
- BigInt = 0x200,
-}
-
-enum ErrorTagType {
- build,
- resolve,
- server,
- client,
- hmr,
-}
-
-const ErrorTag = ({ type }: { type: ErrorTagType }) => (
- <div className={`BunError-ErrorTag BunError-ErrorTag--${ErrorTagType[type]}`}>
- {ErrorTagType[type]}
- </div>
-);
-
-const errorTags = [
- <ErrorTag type={ErrorTagType.build}></ErrorTag>,
- <ErrorTag type={ErrorTagType.resolve}></ErrorTag>,
- <ErrorTag type={ErrorTagType.server}></ErrorTag>,
- <ErrorTag type={ErrorTagType.client}></ErrorTag>,
- <ErrorTag type={ErrorTagType.hmr}></ErrorTag>,
-];
-
-const normalizedFilename = (filename: string, cwd: string): string => {
- if (filename.startsWith(cwd)) {
- return filename.substring(cwd.length);
- }
-
- return filename;
-};
-
-const blobFileURL = (filename: string): string => {
- return new URL("/blob:" + filename, location.href).href;
-};
-
-const srcFileURL = (filename: string, line: number, column: number): string => {
- if (filename.endsWith(".bun")) {
- return new URL("/" + filename, location.href).href;
- }
-
- var base = `/src:${filename}`;
- if (line > -1) {
- base = base + `:${line}`;
-
- if (column > -1) {
- base = base + `:${column}`;
- }
- }
-
- return new URL(base, location.href).href;
-};
-
-class FancyTypeError {
- constructor(exception: JSException) {
- this.runtimeType = exception.runtime_type || 0;
- this.runtimeTypeName = RuntimeType[this.runtimeType] || "undefined";
- this.message = exception.message;
- this.explain = "";
-
- this.normalize(exception);
- }
-
- runtimeType: RuntimeType;
- explain: string;
- runtimeTypeName: string;
- message: string;
-
- normalize(exception: JSException) {
- let i = exception.message.lastIndexOf(" is ");
- if (i === -1) return;
- const partial = exception.message.substring(i + " is ".length);
- const nextWord = /(["a-zA-Z0-9_\.]+)\)$/.exec(partial);
- if (nextWord && nextWord[0]) {
- this.runtimeTypeName = nextWord[0];
- this.runtimeTypeName = this.runtimeTypeName.substring(
- 0,
- this.runtimeTypeName.length - 1
- );
- switch (this.runtimeTypeName.toLowerCase()) {
- case "undefined": {
- this.runtimeType = RuntimeType.Undefined;
- break;
- }
- case "null": {
- this.runtimeType = RuntimeType.Null;
- break;
- }
- case "string": {
- this.runtimeType = RuntimeType.String;
- break;
- }
- case "true":
- case "false": {
- this.runtimeType = RuntimeType.Boolean;
- break;
- }
-
- case "number":
- this.runtimeType = RuntimeType.Number;
- break;
-
- case "bigint":
- this.runtimeType = RuntimeType.BigInt;
- break;
-
- case "symbol":
- this.runtimeType = RuntimeType.Symbol;
- break;
- default: {
- this.runtimeType = RuntimeType.Object;
- break;
- }
- }
- this.message = exception.message.substring(0, i);
- this.message = this.message.substring(
- 0,
- this.message.lastIndexOf("(In ")
- );
- }
- }
-}
-
-var onClose = dismissError;
-
-const IndentationContext = createContext(0);
-const SourceLines = ({
- sourceLines,
- highlight = -1,
- highlightColumnStart = 0,
- highlightColumnEnd = Infinity,
- children,
-}: {
- sourceLines: SourceLine[];
- highlightColumnStart: number;
- highlightColumnEnd: number;
- highlight: number;
-}) => {
- let start = sourceLines.length;
- let end = 0;
- let dedent = Infinity;
- let originalLines = new Array(sourceLines.length);
- let _i = 0;
- for (let i = 0; i < sourceLines.length; i++) {
- // bun only prints \n, no \r\n, so this should work fine
- sourceLines[i].text = sourceLines[i].text.replaceAll("\n", "");
-
- // This will now only trim spaces (and vertical tab character which never prints)
- const left = sourceLines[i].text.trimLeft();
-
- if (left.length > 0) {
- start = Math.min(start, i);
- end = Math.max(end, i + 1);
-
- dedent = Math.min(sourceLines[i].text.length - left.length, dedent);
- }
- }
-
- const _sourceLines = sourceLines.slice(start, end);
- const childrenArray = children || [];
- const numbers = new Array(_sourceLines.length + childrenArray.length);
- const lines = new Array(_sourceLines.length + childrenArray.length);
-
- let highlightI = 0;
- for (let i = 0; i < _sourceLines.length; i++) {
- const { line, text } = _sourceLines[i];
- const classes = {
- empty: text.trim().length === 0,
- highlight: highlight + 1 === line || _sourceLines.length === 1,
- };
- if (classes.highlight) highlightI = i;
- const _text = classes.empty ? "" : text.substring(dedent);
- lines[i] = (
- <div
- key={i}
- className={`BunError-SourceLine-text ${
- classes.empty ? "BunError-SourceLine-text--empty" : ""
- } ${classes.highlight ? "BunError-SourceLine-text--highlight" : ""}`}
- >
- {classes.highlight ? (
- <>
- {_text.substring(0, highlightColumnStart - dedent)}
- <span id="BunError-SourceLine-text-highlightExpression">
- {_text.substring(
- highlightColumnStart - dedent,
- highlightColumnEnd - dedent
- )}
- </span>
- {_text.substring(highlightColumnEnd - dedent)}
- </>
- ) : (
- _text
- )}
- </div>
- );
- numbers[i] = (
- <div
- key={line}
- className={`BunError-SourceLine-number ${
- classes.empty ? "BunError-SourceLine-number--empty" : ""
- } ${classes.highlight ? "BunError-SourceLine-number--highlight" : ""}`}
- >
- {line}
- </div>
- );
-
- if (classes.highlight && children) {
- i++;
-
- numbers.push(
- ...childrenArray.map((child, index) => (
- <div
- key={"highlight-number-" + index}
- className={`BunError-SourceLine-number ${
- classes.empty ? "BunError-SourceLine-number--empty" : ""
- } ${
- classes.highlight ? "BunError-SourceLine-number--highlight" : ""
- }`}
- ></div>
- ))
- );
- lines.push(
- ...childrenArray.map((child, index) => (
- <div
- key={"highlight-line-" + index}
- className={`BunError-SourceLine-text`}
- >
- {childrenArray[index]}
- </div>
- ))
- );
- }
- }
-
- return (
- <IndentationContext.Provider value={dedent}>
- <div className="BunError-SourceLines">
- <div
- className={`BunError-SourceLines-highlighter--${highlightI}`}
- ></div>
-
- <div className="BunError-SourceLines-numbers">{numbers}</div>
- <div className="BunError-SourceLines-lines">{lines}</div>
- </div>
- </IndentationContext.Provider>
- );
-};
-
-const BuildErrorSourceLines = ({ location }: { location: Location }) => {
- const { line, line_text, column, file } = location;
- const sourceLines: SourceLine[] = [{ line, text: line_text }];
- return (
- <SourceLines
- sourceLines={sourceLines}
- highlight={line}
- highlightColumnStart={column}
- highlightColumnEnd={column}
- />
- );
-};
-
-const BuildErrorStackTrace = ({ location }: { location: Location }) => {
- const { cwd } = useContext(ErrorGroupContext);
- const filename = normalizedFilename(location.file, cwd);
- const { line, column } = location;
- return (
- <div className={`BunError-NativeStackTrace`}>
- <a
- href={srcFileURL(filename, line, column)}
- target="_blank"
- className="BunError-NativeStackTrace-filename"
- >
- {filename}:{line}:{column}
- </a>
- <BuildErrorSourceLines location={location} />
- </div>
- );
-};
-
-const StackFrameIdentifier = ({
- functionName,
- scope,
-}: {
- functionName?: string;
- scope: StackFrameScope;
-}) => {
- switch (scope) {
- case StackFrameScope.Constructor: {
- return functionName ? `new ${functionName}` : "new (anonymous)";
- break;
- }
-
- case StackFrameScope.Eval: {
- return "eval";
- break;
- }
-
- case StackFrameScope.Module: {
- return "(esm)";
- break;
- }
-
- case StackFrameScope.Global: {
- return "(global)";
- break;
- }
-
- case StackFrameScope.Wasm: {
- return "(wasm)";
- break;
- }
-
- default: {
- return functionName ? functionName : "λ()";
- break;
- }
- }
-};
-
-const NativeStackFrame = ({
- frame,
- isTop,
-}: {
- frame: StackFrame;
- isTop: boolean;
-}) => {
- const { cwd } = useContext(ErrorGroupContext);
- const {
- file,
- function_name: functionName,
- position: { line, column_start: column },
- scope,
- } = frame;
- const fileName = normalizedFilename(file, cwd);
- return (
- <div
- className={`BunError-StackFrame ${
- fileName.endsWith(".bun") ? "BunError-StackFrame--muted" : ""
- }`}
- >
- <div
- title={StackFrameScope[scope]}
- className="BunError-StackFrame-identifier"
- >
- <StackFrameIdentifier functionName={functionName} scope={scope} />
- </div>
-
- <a
- target="_blank"
- href={blobFileURL(fileName)}
- className="BunError-StackFrame-link"
- >
- <div className="BunError-StackFrame-link-content">
- <div className={`BunError-StackFrame-file`}>{fileName}</div>
- {line > -1 && (
- <div className="BunError-StackFrame-line">:{line + 1}</div>
- )}
- {column > -1 && (
- <div className="BunError-StackFrame-column">:{column}</div>
- )}
- </div>
- </a>
- </div>
- );
-};
-
-const NativeStackFrames = ({ frames }) => {
- const items = new Array(frames.length);
- for (let i = 0; i < frames.length; i++) {
- items[i] = <NativeStackFrame key={i} frame={frames[i]} />;
- }
-
- return <div className="BunError-StackFrames">{items}</div>;
-};
-
-const NativeStackTrace = ({
- frames,
- sourceLines,
- children,
-}: {
- frames: StackFrame[];
- sourceLines: SourceLine[];
-}) => {
- const { file = "", position } = frames[0];
- const { cwd } = useContext(ErrorGroupContext);
- const filename = normalizedFilename(file, cwd);
- return (
- <div className={`BunError-NativeStackTrace`}>
- <a
- href={blobFileURL(filename)}
- target="_blank"
- className="BunError-NativeStackTrace-filename"
- >
- {filename}:{position.line + 1}:{position.column_start}
- </a>
- {sourceLines.length > 0 && (
- <SourceLines
- highlight={position.line}
- sourceLines={sourceLines}
- highlightColumnStart={position.column_start}
- highlightColumnEnd={position.column_stop}
- >
- {children}
- </SourceLines>
- )}
- {frames.length > 0 && <NativeStackFrames frames={frames} />}
- </div>
- );
-};
-
-const divet = <span className="BunError-divet">^</span>;
-const DivetRange = ({ start, stop }) => {
- const length = Math.max(stop - start, 0);
- if (length === 0) return null;
- return (
- <span
- className="BunError-DivetRange"
- style={{ width: `${length - 1}ch` }}
- ></span>
- );
-};
-
-const Indent = ({ by, children }) => {
- const amount = useContext(IndentationContext);
- return (
- <>
- {` `.repeat(by - amount)}
- {children}
- </>
- );
-};
-
-const JSException = ({ value }: { value: JSExceptionType }) => {
- switch (value.code) {
- case JSErrorCode.TypeError: {
- const fancyTypeError = new FancyTypeError(value);
-
- if (fancyTypeError.runtimeType !== RuntimeType.Nothing) {
- return (
- <div
- className={`BunError-JSException BunError-JSException--TypeError`}
- >
- <div className="BunError-error-header">
- <div className={`BunError-error-code`}>TypeError</div>
- {errorTags[ErrorTagType.server]}
- </div>
-
- <div className={`BunError-error-message`}>
- {fancyTypeError.message}
- </div>
-
- {fancyTypeError.runtimeTypeName.length && (
- <div className={`BunError-error-subtitle`}>
- It's{" "}
- <span className="BunError-error-typename">
- {fancyTypeError.runtimeTypeName}
- </span>
- .
- </div>
- )}
-
- {value.stack && (
- <NativeStackTrace
- frames={value.stack.frames}
- sourceLines={value.stack.source_lines}
- >
- <Indent by={value.stack.frames[0].position.column_start}>
- <span className="BunError-error-typename">
- {fancyTypeError.runtimeTypeName}
- </span>
- </Indent>
- </NativeStackTrace>
- )}
- </div>
- );
- }
- }
-
- default: {
- const newline = value.message.indexOf("\n");
- if (newline > -1) {
- const subtitle = value.message.substring(newline + 1).trim();
- const message = value.message.substring(0, newline).trim();
- if (subtitle.length) {
- return (
- <div className={`BunError-JSException`}>
- <div className="BunError-error-header">
- <div className={`BunError-error-code`}>{value.name}</div>
- {errorTags[ErrorTagType.server]}
- </div>
-
- <div className={`BunError-error-message`}>{message}</div>
- <div className={`BunError-error-subtitle`}>{subtitle}</div>
-
- {value.stack && (
- <NativeStackTrace
- frames={value.stack.frames}
- sourceLines={value.stack.source_lines}
- />
- )}
- </div>
- );
- }
- }
-
- return (
- <div className={`BunError-JSException`}>
- <div className="BunError-error-header">
- <div className={`BunError-error-code`}>{value.name}</div>
- {errorTags[ErrorTagType.server]}
- </div>
-
- <div className={`BunError-error-message`}>{value.message}</div>
-
- {value.stack && (
- <NativeStackTrace
- frames={value.stack.frames}
- sourceLines={value.stack.source_lines}
- />
- )}
- </div>
- );
- }
- }
-};
-
-const Summary = ({
- errorCount,
- onClose,
-}: {
- errorCount: number;
- onClose: Function;
-}) => {
- return (
- <div className="BunError-Summary">
- <div className="BunError-Summary-ErrorIcon"></div>
- <div className="BunError-Summary-Title">
- {errorCount}&nbsp;error{errorCount > 1 ? "s" : ""}&nbsp;on this page
- </div>
-
- <div onClick={onClose} className="BunError-Summary-CloseButton">
- <div className="BunError-Summary-CloseIcon"></div>
- </div>
- </div>
- );
-};
-
-const BuildError = ({ message }: { message: Message }) => {
- let title = (message.data.text || "").trim();
- const newline = title.indexOf("\n");
- let subtitle = "";
- if (newline > -1) {
- subtitle = title.slice(newline + 1).trim();
- title = title.slice(0, newline);
- }
- return (
- <div className={`BunError-BuildError BunError-BuildError--build`}>
- <div className="BunError-error-header">
- <div className={`BunError-error-code`}>BuildError</div>
- </div>
-
- <div className={`BunError-error-message`}>{title}</div>
-
- {subtitle.length > 0 && (
- <div className={`BunError-error-subtitle`}>{subtitle}</div>
- )}
-
- {message.data.location && (
- <BuildErrorStackTrace location={message.data.location} />
- )}
- </div>
- );
-};
-
-const ResolveError = ({ message }: { message: Message }) => {
- const { cwd } = useContext(ErrorGroupContext);
- let title = (message.data.text || "").trim();
- const newline = title.indexOf("\n");
- let subtitle = null;
- if (newline > -1) {
- subtitle = title.slice(newline + 1).trim();
- title = title.slice(0, newline);
- }
-
- return (
- <div className={`BunError-BuildError BunError-BuildError--resolve`}>
- <div className="BunError-error-header">
- <div className={`BunError-error-code`}>ResolveError</div>
- </div>
-
- <div className={`BunError-error-message`}>
- Can't import{" "}
- <span className="BunError-error-message--mono">
- {message.on.resolve}
- </span>
- </div>
-
- {subtitle && <div className={`BunError-error-subtitle`}>{subtitle}</div>}
-
- {message.data.location && (
- <BuildErrorStackTrace location={message.data.location} />
- )}
- </div>
- );
-};
-const OverlayMessageContainer = ({
- problems,
- reason,
- router,
-}: FallbackMessageContainer) => {
- return (
- <div id="BunErrorOverlay-container">
- <div className="BunError-content">
- <div className="BunError-header">
- <Summary
- errorCount={problems.exceptions.length + problems.build.errors}
- onClose={onClose}
- problems={problems}
- reason={reason}
- />
- </div>
- <div className={`BunError-list`}>
- {problems.exceptions.map((problem, index) => (
- <JSException key={index} value={problem} />
- ))}
- {problems.build.msgs.map((buildMessage, index) => {
- if (buildMessage.on.build) {
- return <BuildError key={index} message={buildMessage} />;
- } else if (buildMessage.on.resolve) {
- return <ResolveError key={index} message={buildMessage} />;
- } else {
- throw new Error("Unknown build message type");
- }
- })}
- </div>
- <div className="BunError-footer">
- <div id="BunError-poweredBy"></div>
- </div>
- </div>
- </div>
- );
-};
-
-const BuildFailureMessageContainer = ({
- messages,
-}: {
- messages: Message[];
-}) => {
- return (
- <div id="BunErrorOverlay-container">
- <div className="BunError-content">
- <div className="BunError-header">
- <Summary onClose={onClose} errorCount={messages.length} />
- </div>
- <div className={`BunError-list`}>
- {messages.map((buildMessage, index) => {
- if (buildMessage.on.build) {
- return <BuildError key={index} message={buildMessage} />;
- } else if (buildMessage.on.resolve) {
- return <ResolveError key={index} message={buildMessage} />;
- } else {
- throw new Error("Unknown build message type");
- }
- })}
- </div>
- <div className="BunError-footer">
- <div id="BunError-poweredBy"></div>
- </div>
- </div>
- </div>
- );
-};
-
-const ErrorGroupContext = createContext<{ cwd: string }>(null);
-var reactRoot;
-
-function renderWithFunc(func) {
- if (!reactRoot) {
- const root = document.createElement("div");
- root.id = "__bun__error-root";
-
- reactRoot = document.createElement("div");
- reactRoot.id = BUN_ERROR_CONTAINER_ID;
- reactRoot.style.visibility = "hidden";
- const link = document.createElement("link");
- link.rel = "stylesheet";
- link.href = new URL("/bun:erro.css", document.baseURI).href;
- link.onload = () => {
- reactRoot.style.visibility = "visible";
- };
-
- const shadowRoot = root.attachShadow({ mode: "open" });
- shadowRoot.appendChild(link);
- shadowRoot.appendChild(reactRoot);
-
- document.body.appendChild(root);
- ReactDOM.render(func(), reactRoot);
-
- debugger;
- } else {
- ReactDOM.render(func(), reactRoot);
- }
-}
-
-export function renderFallbackError(fallback: FallbackMessageContainer) {
- return renderWithFunc(() => (
- <ErrorGroupContext.Provider value={fallback}>
- <OverlayMessageContainer {...fallback} />
- </ErrorGroupContext.Provider>
- ));
-}
-
-export function dismissError() {
- if (reactRoot) {
- ReactDOM.unmountComponentAtNode(reactRoot);
- const root = document.getElementById("__bun__error-root");
- if (root) root.remove();
- reactRoot = null;
- }
-}
-
-globalThis.renderBuildFailure = (
- failure: WebsocketMessageBuildFailure,
- cwd: string
-) => {
- renderWithFunc(() => (
- <ErrorGroupContext.Provider value={{ cwd }}>
- <BuildFailureMessageContainer messages={failure.log.msgs} />
- </ErrorGroupContext.Provider>
- ));
-};
diff --git a/examples/hello-next/bun-framework-next/bun-error/close.png b/examples/hello-next/bun-framework-next/bun-error/close.png
deleted file mode 100644
index 11e513a1b..000000000
--- a/examples/hello-next/bun-framework-next/bun-error/close.png
+++ /dev/null
Binary files differ
diff --git a/examples/hello-next/bun-framework-next/bun-error/error.png b/examples/hello-next/bun-framework-next/bun-error/error.png
deleted file mode 100644
index c35e01a2b..000000000
--- a/examples/hello-next/bun-framework-next/bun-error/error.png
+++ /dev/null
Binary files differ
diff --git a/examples/hello-next/bun-framework-next/bun-error/powered-by.png b/examples/hello-next/bun-framework-next/bun-error/powered-by.png
deleted file mode 100644
index 7e71f1357..000000000
--- a/examples/hello-next/bun-framework-next/bun-error/powered-by.png
+++ /dev/null
Binary files differ
diff --git a/examples/hello-next/bun-framework-next/bun-error/powered-by.webp b/examples/hello-next/bun-framework-next/bun-error/powered-by.webp
deleted file mode 100644
index 0f48488ea..000000000
--- a/examples/hello-next/bun-framework-next/bun-error/powered-by.webp
+++ /dev/null
Binary files differ
diff --git a/examples/hello-next/bun-framework-next/bun-runtime-error.ts b/examples/hello-next/bun-framework-next/bun-runtime-error.ts
deleted file mode 100644
index 331040b36..000000000
--- a/examples/hello-next/bun-framework-next/bun-runtime-error.ts
+++ /dev/null
@@ -1,163 +0,0 @@
-// Based on https://github.com/stacktracejs/error-stack-parser/blob/master/error-stack-parser.js
-
-import type {
- StackFrame as StackFrameType,
- StackFramePosition,
- StackFrameScope,
-} from "../../../src/api/schema";
-
-export class StackFrame implements StackFrameType {
- function_name: string;
- file: string;
- position: StackFramePosition;
- scope: StackFrameScope;
- lineText: string = "";
- constructor({
- functionName: function_name = "",
- fileName: file = "",
- lineNumber: line = -1,
- columnNumber: column = -1,
- source = "",
- }) {
- this.function_name = function_name;
- this.file = file;
- if (source) this.lineText = source;
- this.scope = 3;
- this.position = {
- line: line,
- source_offset: -1,
- line_start: -1,
- line_stop: -1,
- column_start: column,
- column_stop: -1,
- expression_start: -1,
- expression_stop: -1,
- };
- }
-}
-
-const FIREFOX_SAFARI_STACK_REGEXP = /(^|@)\S+:\d+/;
-const CHROME_IE_STACK_REGEXP = /^\s*at .*(\S+:\d+|\(native\))/m;
-const SAFARI_NATIVE_CODE_REGEXP = /^(eval@)?(\[native code])?$/;
-
-export default class RuntimeError {
- original: Error;
- stack: StackFrame[];
-
- static from(error: Error) {
- const runtime = new RuntimeError();
- runtime.original = error;
- runtime.stack = this.parseStack(error);
- return RuntimeError;
- }
-
- /**
- * Given an Error object, extract the most information from it.
- *
- * @param {Error} error object
- * @return {Array} of StackFrames
- */
- static parseStack(error) {
- if (error.stack && error.stack.match(CHROME_IE_STACK_REGEXP)) {
- return this.parseV8OrIE(error);
- } else if (error.stack) {
- return this.parseFFOrSafari(error);
- } else {
- return [];
- }
- }
-
- // Separate line and column numbers from a string of the form: (URI:Line:Column)
- static extractLocation(urlLike) {
- // Fail-fast but return locations like "(native)"
- if (urlLike.indexOf(":") === -1) {
- return [urlLike];
- }
-
- var regExp = /(.+?)(?::(\d+))?(?::(\d+))?$/;
- var parts = regExp.exec(urlLike.replace(/[()]/g, ""));
- return [parts[1], parts[2] || undefined, parts[3] || undefined];
- }
-
- static parseV8OrIE(error) {
- var filtered = error.stack.split("\n").filter(function (line) {
- return !!line.match(CHROME_IE_STACK_REGEXP);
- }, this);
-
- return filtered.map(function (line) {
- if (line.indexOf("(eval ") > -1) {
- // Throw away eval information until we implement stacktrace.js/stackframe#8
- line = line
- .replace(/eval code/g, "eval")
- .replace(/(\(eval at [^()]*)|(\),.*$)/g, "");
- }
- var sanitizedLine = line.replace(/^\s+/, "").replace(/\(eval code/g, "(");
-
- // capture and preseve the parenthesized location "(/foo/my bar.js:12:87)" in
- // case it has spaces in it, as the string is split on \s+ later on
- var location = sanitizedLine.match(/ (\((.+):(\d+):(\d+)\)$)/);
-
- // remove the parenthesized location from the line, if it was matched
- sanitizedLine = location
- ? sanitizedLine.replace(location[0], "")
- : sanitizedLine;
-
- var tokens = sanitizedLine.split(/\s+/).slice(1);
- // if a location was matched, pass it to extractLocation() otherwise pop the last token
- var locationParts = this.extractLocation(
- location ? location[1] : tokens.pop()
- );
- var functionName = tokens.join(" ") || undefined;
- var fileName =
- ["eval", "<anonymous>"].indexOf(locationParts[0]) > -1
- ? undefined
- : locationParts[0];
-
- return new StackFrame({
- functionName: functionName,
- fileName: fileName,
- lineNumber: locationParts[1],
- columnNumber: locationParts[2],
- source: line,
- });
- }, this);
- }
-
- static parseFFOrSafari(error) {
- var filtered = error.stack.split("\n").filter(function (line) {
- return !line.match(SAFARI_NATIVE_CODE_REGEXP);
- }, this);
-
- return filtered.map(function (line) {
- // Throw away eval information until we implement stacktrace.js/stackframe#8
- if (line.indexOf(" > eval") > -1) {
- line = line.replace(
- / line (\d+)(?: > eval line \d+)* > eval:\d+:\d+/g,
- ":$1"
- );
- }
-
- if (line.indexOf("@") === -1 && line.indexOf(":") === -1) {
- // Safari eval frames only have function names and nothing else
- return new StackFrame({
- functionName: line,
- });
- } else {
- var functionNameRegex = /((.*".+"[^@]*)?[^@]*)(?:@)/;
- var matches = line.match(functionNameRegex);
- var functionName = matches && matches[1] ? matches[1] : undefined;
- var locationParts = this.extractLocation(
- line.replace(functionNameRegex, "")
- );
-
- return new StackFrame({
- functionName: functionName,
- fileName: locationParts[0],
- lineNumber: locationParts[1],
- columnNumber: locationParts[2],
- source: line,
- });
- }
- }, this);
- }
-}
diff --git a/examples/hello-next/bun-framework-next/client.development.tsx b/examples/hello-next/bun-framework-next/client.development.tsx
index 0d019e175..f8fd054c3 100644
--- a/examples/hello-next/bun-framework-next/client.development.tsx
+++ b/examples/hello-next/bun-framework-next/client.development.tsx
@@ -1,7 +1,8 @@
-import "./bun-error";
globalThis.global = globalThis;
globalThis.Bun_disableCSSImports = true;
+import "./bun-error";
+
import * as React from "react";
var onlyChildPolyfill = React.Children.only;
React.Children.only = function (children) {
diff --git a/examples/hello-next/bun-framework-next/fallback.development.tsx b/examples/hello-next/bun-framework-next/fallback.development.tsx
deleted file mode 100644
index 1cd5f847e..000000000
--- a/examples/hello-next/bun-framework-next/fallback.development.tsx
+++ /dev/null
@@ -1,82 +0,0 @@
-import { insertStyleSheet } from "./page-loader";
-import type {
- FallbackMessageContainer,
- FallbackStep,
-} from "../../../src/api/schema";
-
-var once = false;
-function insertGlobalStyleSheet(detail) {
- if (!once) {
- document.head.insertAdjacentHTML(
- "beforeend",
- `<meta name="next-head-count" content="${document.head.childElementCount}">`
- );
- once = true;
- }
- pageLoader.cssQueue.push(insertStyleSheet(detail).then(() => {}));
-}
-
-[...globalThis["__BUN"].allImportedStyles].map((detail) =>
- insertGlobalStyleSheet(detail)
-);
-
-document.addEventListener("onimportcss", insertGlobalStyleSheet, {
- passive: true,
-});
-
-import { renderError, _boot, pageLoader } from "./client.development";
-import { renderFallbackError } from "bun-error";
-
-function renderFallback({
- router,
- reason,
- problems,
-}: FallbackMessageContainer) {
- const route = router.routes[router.route];
-
- if (!document.getElementById("__next")) {
- const next = document.createElement("div");
- next.id = "__next";
- document.body.prepend(next);
- }
-
- document.removeEventListener("onimportcss", insertGlobalStyleSheet);
- document.addEventListener("onimportcss", pageLoader.onImportCSS, {
- passive: true,
- });
-
- globalThis.__NEXT_DATA__.pages["/_app"] = [
- ...globalThis.__NEXT_DATA__.pages["/_app"],
- ...globalThis["__BUN"].allImportedStyles,
- ];
-
- return import(route)
- .then((Namespace) => {
- return _boot(Namespace, true);
- })
- .then(() => {
- const cssQueue = pageLoader.cssQueue.slice();
- pageLoader.cssQueue = [];
- return Promise.all([...cssQueue]);
- })
- .finally(() => {
- document.body.style.visibility = "visible";
- document.removeEventListener("onimportcss", pageLoader.onImportCSS);
- });
-}
-
-export default function render(props: FallbackMessageContainer) {
- renderFallback(props).then(
- () => {
- Promise.all(pageLoader.cssQueue).finally(() => {
- renderFallbackError(props);
- document.body.style.visibility = "visible";
- });
- },
- (err) => {
- Promise.all(pageLoader.cssQueue).finally(() => {
- renderFallbackError(props);
- });
- }
- );
-}
diff --git a/examples/hello-next/bun-framework-next/index.js b/examples/hello-next/bun-framework-next/index.js
deleted file mode 100644
index e69de29bb..000000000
--- a/examples/hello-next/bun-framework-next/index.js
+++ /dev/null
diff --git a/examples/hello-next/bun-framework-next/next-server.tsx b/examples/hello-next/bun-framework-next/next-server.tsx
deleted file mode 100644
index e69de29bb..000000000
--- a/examples/hello-next/bun-framework-next/next-server.tsx
+++ /dev/null
diff --git a/examples/hello-next/bun-framework-next/package.json b/examples/hello-next/bun-framework-next/package.json
deleted file mode 100644
index af6286343..000000000
--- a/examples/hello-next/bun-framework-next/package.json
+++ /dev/null
@@ -1,81 +0,0 @@
-{
- "name": "bun-framework-next",
- "version": "0.0.0-18",
- "description": "",
- "framework": {
- "displayName": "Next.js",
- "static": "public",
- "assetPrefix": "_next/",
- "router": {
- "dir": [
- "pages",
- "src/pages"
- ],
- "extensions": [
- ".js",
- ".ts",
- ".tsx",
- ".jsx"
- ]
- },
- "css": "onimportcss",
- "development": {
- "client": "client.development.tsx",
- "fallback": "fallback.development.tsx",
- "server": "server.development.tsx",
- "css": "onimportcss",
- "define": {
- "client": {
- ".env": "NEXT_PUBLIC_",
- "defaults": {
- "process.env.__NEXT_TRAILING_SLASH": "false",
- "process.env.NODE_ENV": "\"development\"",
- "process.env.__NEXT_ROUTER_BASEPATH": "''",
- "process.env.__NEXT_SCROLL_RESTORATION": "false",
- "process.env.__NEXT_I18N_SUPPORT": "false",
- "process.env.__NEXT_HAS_REWRITES": "false",
- "process.env.__NEXT_ANALYTICS_ID": "null",
- "process.env.__NEXT_OPTIMIZE_CSS": "false",
- "process.env.__NEXT_CROSS_ORIGIN": "''",
- "process.env.__NEXT_STRICT_MODE": "false",
- "process.env.__NEXT_IMAGE_OPTS": "null"
- }
- },
- "server": {
- ".env": "NEXT_",
- "defaults": {
- "process.env.__NEXT_TRAILING_SLASH": "false",
- "process.env.__NEXT_OPTIMIZE_FONTS": "false",
- "process.env.NODE_ENV": "\"development\"",
- "process.env.__NEXT_OPTIMIZE_IMAGES": "false",
- "process.env.__NEXT_OPTIMIZE_CSS": "false",
- "process.env.__NEXT_ROUTER_BASEPATH": "''",
- "process.env.__NEXT_SCROLL_RESTORATION": "false",
- "process.env.__NEXT_I18N_SUPPORT": "false",
- "process.env.__NEXT_HAS_REWRITES": "false",
- "process.env.__NEXT_ANALYTICS_ID": "null",
- "process.env.__NEXT_CROSS_ORIGIN": "''",
- "process.env.__NEXT_STRICT_MODE": "false",
- "process.env.__NEXT_IMAGE_OPTS": "null",
- "global": "globalThis",
- "window": "undefined"
- }
- }
- }
- },
- "production": {
- "client": "client.production.tsx",
- "server": "server.production.tsx",
- "fallback": "fallback.production.tsx",
- "css": "onimportcss"
- }
- },
- "scripts": {
- "test": "echo \"Error: no test specified\" && exit 1"
- },
- "author": "",
- "license": "ISC",
- "dependencies": {
- "react-is": "^17.0.2"
- }
-}
diff --git a/examples/hello-next/bun-framework-next/page-loader.ts b/examples/hello-next/bun-framework-next/page-loader.ts
deleted file mode 100644
index fc07578db..000000000
--- a/examples/hello-next/bun-framework-next/page-loader.ts
+++ /dev/null
@@ -1,147 +0,0 @@
-import NextPageLoader from "next/dist/client/page-loader";
-import getAssetPathFromRoute from "next/dist/shared/lib/router/utils/get-asset-path-from-route";
-// import createRouteLoader from "./route-loader";
-
-export function insertStyleSheet(url: string) {
- if (document.querySelector(`link[href="${url}"]`)) {
- return Promise.resolve();
- }
-
- return new Promise((resolve, reject) => {
- const link = document.createElement("link");
- link.rel = "stylesheet";
-
- link.onload = () => resolve();
- link.onerror = () => reject();
-
- link.href = url;
-
- // if (headCount) {
- // document.head.insertBefore(headCount, link);
- // } else {
- document.head.appendChild(link);
- // }
- });
-}
-
-export default class PageLoader extends NextPageLoader {
- public routeLoader: RouteLoader;
-
- constructor(_, __, pages) {
- super(_, __);
-
- // TODO: assetPrefix?
- // this.routeLoader = {}; //createRouteLoader("");
-
- // Rewrite the pages object to omit the entry script
- // At this point, the entry point has been loaded so we don't want to do that again.
- for (let name in pages) {
- for (let i = 0; i < pages[name].length; i += 1) {
- const lastDot = pages[name][i].lastIndexOf(".");
- if (lastDot == -1) continue;
- if (
- pages[name][i].substring(lastDot - ".entry".length, lastDot) !==
- ".entry"
- )
- continue;
-
- pages[name][i] =
- pages[name][i].substring(0, lastDot - ".entry".length) +
- pages[name][i].substring(lastDot);
- }
- }
-
- this.pages = pages;
- this.pageList = Object.keys(this.pages);
- }
-
- pageList: string[];
- pages: Record<string, string[]>;
-
- getPageList() {
- return this.pageList;
- }
-
- cssQueue = [];
-
- onImportCSS = (event) => {
- this.cssQueue.push(
- insertStyleSheet(event.detail).then(
- () => {},
- () => {}
- )
- );
- };
-
- prefetch(route) {
- return Promise.resolve({});
- }
-
- async loadPage(route: string): Promise<GoodPageCache> {
- const assets =
- this.pages[route] || this.pages[getAssetPathFromRoute(route)];
-
- var src;
- console.log(getAssetPathFromRoute(route), assets);
- for (let asset of assets) {
- if (!asset.endsWith(".css")) {
- src = asset;
- break;
- }
- }
- console.assert(src, "Invalid or unknown route passed to loadPage");
-
- document.removeEventListener("onimportcss", this.onImportCSS);
- this.cssQueue.length = 0;
- document.addEventListener("onimportcss", this.onImportCSS, {
- passive: true,
- });
-
- try {
- const res = await import(src);
-
- if (this.cssQueue.length > 0) {
- await Promise.all(this.cssQueue);
- this.cssQueue.length = 0;
- }
-
- document.removeEventListener("onimportcss", this.onImportCSS);
-
- if (this.cssQueue.length > 0) {
- await Promise.all(this.cssQueue);
-
- this.cssQueue.length = 0;
- }
-
- return {
- page: res.default,
- mod: res,
- styleSheets: [],
- __N_SSG: false,
- __N_SSP: false,
- };
- } catch (exception) {
- console.error({ exception });
- }
-
- // return this.routeLoader.loadRoute(route).then((res) => {
- // debugger;
- // if ("component" in res) {
- // return {
- // page: res.component,
- // mod: res.exports,
- // styleSheets: res.styles.map((o) => ({
- // href: o.href,
- // text: o.content,
- // })),
- // };
- // }
- // throw res.error;
- // });
- }
-
- // not used in development!
- // prefetch(route: string): Promise<void> {
- // return this.routeLoader.prefetch(route);
- // }
-}
diff --git a/examples/hello-next/bun-framework-next/render.tsx b/examples/hello-next/bun-framework-next/render.tsx
deleted file mode 100644
index e69de29bb..000000000
--- a/examples/hello-next/bun-framework-next/render.tsx
+++ /dev/null
diff --git a/examples/hello-next/bun-framework-next/renderDocument.tsx b/examples/hello-next/bun-framework-next/renderDocument.tsx
deleted file mode 100644
index 356ff788b..000000000
--- a/examples/hello-next/bun-framework-next/renderDocument.tsx
+++ /dev/null
@@ -1,722 +0,0 @@
-import * as App from "next/app";
-import { AmpStateContext } from "next/dist/shared/lib/amp-context";
-import { HeadManagerContext } from "next/dist/shared/lib/head-manager-context";
-import Loadable from "next/dist/shared/lib/loadable";
-import { LoadableContext } from "next/dist/shared/lib/loadable-context";
-import { RouterContext } from "next/dist/shared/lib/router-context";
-import { NextRouter } from "next/dist/shared/lib/router/router";
-import {
- AppType,
- ComponentsEnhancer,
- DocumentInitialProps,
- DocumentProps,
- DocumentType,
- getDisplayName,
- loadGetInitialProps,
- NextComponentType,
- RenderPage,
- RenderPageResult,
- HtmlContext,
-} from "next/dist/shared/lib/utils";
-import * as NextDocument from "next/document";
-import * as ReactDOMServer from "react-dom/server.browser";
-import * as url from "url";
-import * as React from "react";
-import * as ReactIs from "react-is";
-import { BODY_RENDER_TARGET } from "next/constants";
-
-const dev = process.env.NODE_ENV === "development";
-
-type ParsedUrlQuery = Record<string, string | string[]>;
-
-const isJSFile = (file: string) =>
- file.endsWith(".js") ||
- file.endsWith(".jsx") ||
- file.endsWith(".mjs") ||
- file.endsWith(".ts") ||
- file.endsWith(".tsx");
-
-const notImplementedProxy = (base) =>
- new Proxy(
- {},
- {
- deleteProperty: function (target, prop) {
- return undefined;
- },
- enumerate: function (oTarget, sKey) {
- return [].entries();
- },
- ownKeys: function (oTarget, sKey) {
- return [].values();
- },
- has: function (oTarget, sKey) {
- return false;
- },
- defineProperty: function (oTarget, sKey, oDesc) {
- return undefined;
- },
- getOwnPropertyDescriptor: function (oTarget, sKey) {
- return undefined;
- },
- get(this, prop) {
- throw new ReferenceError(
- `${base} is not available for this environment.`
- );
- },
- set(this, prop, value) {
- throw new ReferenceError(
- `${base} is not available for this environment.`
- );
- },
- }
- );
-
-globalThis.fetch = (url, options) => {
- return Promise.reject(new Error(`fetch is not implemented yet. sorry!!`));
-};
-
-function getScripts(files: DocumentFiles) {
- const { context, props } = this;
- const {
- assetPrefix,
- buildManifest,
- isDevelopment,
- devOnlyCacheBusterQueryString,
- disableOptimizedLoading,
- } = context;
- const normalScripts = files.allFiles.filter(isJSFile);
- const lowPriorityScripts = buildManifest.lowPriorityFiles?.filter(isJSFile);
-
- return [...normalScripts, ...lowPriorityScripts].map((file) => {
- return (
- <script
- key={file}
- src={`${encodeURI(file)}${devOnlyCacheBusterQueryString}`}
- nonce={props.nonce}
- async
- crossOrigin={props.crossOrigin || process.env.__NEXT_CROSS_ORIGIN}
- type="module"
- />
- );
- });
-}
-
-// function fixLink(from: string) {
-// if (from.startsWith("/_next/http://") || from.startsWith("/_next/https://"))
-// return from.substring("/_next".length);
-// return from;
-// }
-
-// function cloneWithOverwrittenLink(element: React.ReactElement<any>) {
-// const props = { ...element.props };
-// if ("href" in element.props) {
-// props.href = fixLink(props.href);
-// }
-
-// if ("n-href" in element.props) {
-// props["n-href"] = fixLink(props["n-href"]);
-// }
-
-// if ("n-src" in element.props) {
-// props["n-src"] = fixLink(props["n-src"]);
-// }
-
-// if ("src" in element.props) {
-// props["src"] = fixLink(props.src);
-// }
-
-// return React.cloneElement(element, props);
-// }
-
-interface DomainLocale {
- defaultLocale: string;
- domain: string;
- http?: true;
- locales?: string[];
-}
-
-function renderDocument(
- Document: DocumentType,
- {
- buildManifest,
- docComponentsRendered,
- props,
- docProps,
- pathname,
- query,
- buildId,
- canonicalBase,
- assetPrefix,
- runtimeConfig,
- nextExport,
- autoExport,
- isFallback,
- dynamicImportsIds,
- dangerousAsPath,
- err,
- dev,
- ampPath,
- ampState,
- inAmpMode,
- hybridAmp,
- dynamicImports,
- headTags,
- gsp,
- gssp,
- customServer,
- gip,
- appGip,
- unstable_runtimeJS,
- unstable_JsPreload,
- devOnlyCacheBusterQueryString,
- scriptLoader,
- locale,
- locales,
- defaultLocale,
- domainLocales,
- isPreview,
- disableOptimizedLoading,
- }: RenderOpts & {
- props: any;
- docComponentsRendered: DocumentProps["docComponentsRendered"];
- docProps: DocumentInitialProps;
- pathname: string;
- query: ParsedUrlQuery;
- dangerousAsPath: string;
- ampState: any;
- ampPath: string;
- inAmpMode: boolean;
- hybridAmp: boolean;
- dynamicImportsIds: (string | number)[];
- dynamicImports: string[];
- headTags: any;
- isFallback?: boolean;
- gsp?: boolean;
- gssp?: boolean;
- customServer?: boolean;
- gip?: boolean;
- appGip?: boolean;
- devOnlyCacheBusterQueryString: string;
- scriptLoader: any;
- isPreview?: boolean;
- autoExport?: boolean;
- }
-): string {
- const htmlProps = {
- __NEXT_DATA__: {
- props, // The result of getInitialProps
- page: pathname, // The rendered page
- query, // querystring parsed / passed by the user
- buildId, // buildId is used to facilitate caching of page bundles, we send it to the client so that pageloader knows where to load bundles
- assetPrefix: assetPrefix === "" ? undefined : assetPrefix, // send assetPrefix to the client side when configured, otherwise don't sent in the resulting HTML
- runtimeConfig, // runtimeConfig if provided, otherwise don't sent in the resulting HTML
- nextExport, // If this is a page exported by `next export`
- autoExport, // If this is an auto exported page
- isFallback,
- dynamicIds:
- dynamicImportsIds.length === 0 ? undefined : dynamicImportsIds,
- err: err || undefined, // err: err ? serializeError(dev, err) : undefined, // Error if one happened, otherwise don't sent in the resulting HTML
- gsp, // whether the page is getStaticProps
- gssp, // whether the page is getServerSideProps
- customServer, // whether the user is using a custom server
- gip, // whether the page has getInitialProps
- appGip, // whether the _app has getInitialProps
- locale,
- locales,
- defaultLocale,
- domainLocales,
- isPreview,
-
- pages: buildManifest.pages,
- },
- buildManifest,
- docComponentsRendered,
- dangerousAsPath,
- canonicalBase,
- ampPath,
- inAmpMode,
- isDevelopment: !!dev,
- hybridAmp,
- dynamicImports,
- assetPrefix,
- headTags,
- unstable_runtimeJS,
- unstable_JsPreload,
- devOnlyCacheBusterQueryString,
- scriptLoader,
- locale,
- disableOptimizedLoading,
- ...docProps,
- };
- return (
- "<!DOCTYPE html>" +
- ReactDOMServer.renderToStaticMarkup(
- <AmpStateContext.Provider value={ampState}>
- <HtmlContext.Provider value={htmlProps}>
- <Document {...htmlProps} {...docProps}></Document>
- </HtmlContext.Provider>
- </AmpStateContext.Provider>
- )
- );
-}
-
-class ServerRouter implements NextRouter {
- route: string;
- pathname: string;
- query: ParsedUrlQuery;
- asPath: string;
- basePath: string;
- events: any;
- isFallback: boolean;
- locale?: string;
- isReady: boolean;
- locales?: string[];
- defaultLocale?: string;
- domainLocales?: DomainLocale[];
- isPreview: boolean;
- isLocaleDomain: boolean;
-
- constructor(
- pathname: string,
- query: ParsedUrlQuery,
- as: string,
- { isFallback }: { isFallback: boolean },
- isReady: boolean,
- basePath: string,
- locale?: string,
- locales?: string[],
- defaultLocale?: string,
- domainLocales?: DomainLocale[],
- isPreview?: boolean,
- isLocaleDomain?: boolean
- ) {
- this.route = pathname.replace(/\/$/, "") || "/";
- this.pathname = pathname;
- this.query = query;
- this.asPath = as;
- this.isFallback = isFallback;
- this.basePath = basePath;
- this.locale = locale;
- this.locales = locales;
- this.defaultLocale = defaultLocale;
- this.isReady = isReady;
- this.domainLocales = domainLocales;
- this.isPreview = !!isPreview;
- this.isLocaleDomain = !!isLocaleDomain;
- }
-
- push(): any {
- noRouter();
- }
- replace(): any {
- noRouter();
- }
- reload() {
- noRouter();
- }
- back() {
- noRouter();
- }
- prefetch(): any {
- noRouter();
- }
- beforePopState() {
- noRouter();
- }
-}
-
-function noRouter() {
- const message =
- 'No router instance found. you should only use "next/router" inside the client side of your app. https://nextjs.org/docs/messages/no-router-instance';
- throw new Error(message);
-}
-
-function enhanceComponents(
- options: ComponentsEnhancer,
- App: AppType,
- Component: NextComponentType
-): {
- App: AppType;
- Component: NextComponentType;
-} {
- // For backwards compatibility
- if (typeof options === "function") {
- return {
- App,
- Component: options(Component),
- };
- }
-
- return {
- App: options.enhanceApp ? options.enhanceApp(App) : App,
- Component: options.enhanceComponent
- ? options.enhanceComponent(Component)
- : Component,
- };
-}
-
-Object.defineProperty(NextDocument.Head.prototype, "getScripts", {
- get() {
- return getScripts;
- },
-});
-Object.defineProperty(NextDocument.NextScript.prototype, "getScripts", {
- get() {
- return getScripts;
- },
-});
-
-export async function render({
- route,
- PageNamespace,
- AppNamespace,
- appStylesheets = [],
- pageStylesheets = [],
- DocumentNamespace = null,
- buildId,
- routePaths = [],
-}: {
- buildId: number;
- route: any;
- PageNamespace: { default: NextComponentType<any> };
- AppNamespace: { default: NextComponentType<any> } | null;
- DocumentNamespace: Object | null;
- appStylesheets: string[];
- pageStylesheets: string[];
- routePaths: string[];
-}): Promise<Response> {
- const { default: Component, getStaticProps = null } = PageNamespace || {};
- const { default: AppComponent_ } = AppNamespace || {};
- var query = Object.assign({}, route.query);
-
- // These are reversed in our Router versus Next.js...mostly due to personal preference.
- const pathname = "/" + route.name;
- var asPath = route.pathname;
- const pages = {};
-
- for (let path of routePaths) {
- const filePath = path.substring(
- path.indexOf("_next/pages/") + "_next/pages".length
- );
- const name = filePath.substring(0, filePath.indexOf("."));
- pages[name] = [path];
- }
-
- pages[pathname] = [route.scriptSrc, ...pageStylesheets];
-
- if (appStylesheets.length > 0) {
- if (pages["/_app"]) {
- pages["/_app"].push(...appStylesheets);
- } else {
- pages["/_app"] = appStylesheets;
- }
- }
-
- const AppComponent = AppComponent_ || App.default;
- const Document =
- (DocumentNamespace && DocumentNamespace.default) || NextDocument.default;
- // Document.Html.prototype.getScripts = getScripts;
- // }
-
- const callMiddleware = async (method: string, args: any[], props = false) => {
- let results: any = props ? {} : [];
-
- if ((Document as any)[`${method}Middleware`]) {
- let middlewareFunc = await (Document as any)[`${method}Middleware`];
- middlewareFunc = middlewareFunc.default || middlewareFunc;
-
- const curResults = await middlewareFunc(...args);
- if (props) {
- for (const result of curResults) {
- results = {
- ...results,
- ...result,
- };
- }
- } else {
- results = curResults;
- }
- }
- return results;
- };
-
- const headTags = (...args: any) => callMiddleware("headTags", args);
-
- if (!ReactIs.isValidElementType(Component)) {
- const exportNames = Object.keys(PageNamespace || {});
-
- const reactComponents = exportNames.filter(ReactIs.isValidElementType);
- if (reactComponents.length > 2) {
- throw new Error(
- `\"export default\" missing in ${
- route.filePath
- }.\nTry exporting one of ${reactComponents.join(", ")}\n`
- );
- } else if (reactComponents.length === 2) {
- throw new Error(
- `\"export default\" missing in ${route.filePath}.\n\nTry exporting <${reactComponents[0]} /> or <${reactComponents[1]} />\n`
- );
- } else if (reactComponents.length == 1) {
- throw new Error(
- `\"export default\" missing in ${route.filePath}. Try adding this to the bottom of the file:\n\n export default ${reactComponents[0]};\n`
- );
- } else if (reactComponents.length == 0) {
- throw new Error(
- `\"export default\" missing in ${route.filePath}. Try exporting a React component.\n`
- );
- }
- }
-
- const isFallback = !!query.__nextFallback;
- delete query.__nextFallback;
- delete query.__nextLocale;
- delete query.__nextDefaultLocale;
-
- const isSSG = !!getStaticProps;
- const isBuildTimeSSG = isSSG && false;
- const defaultAppGetInitialProps =
- App.getInitialProps === (App as any).origGetInitialProps;
-
- const hasPageGetInitialProps = !!(Component as any).getInitialProps;
- const pageIsDynamic = route.kind === "dynamic";
- const isAutoExport = false;
-
- if (isAutoExport || isFallback) {
- // // remove query values except ones that will be set during export
- // query = {
- // ...(query.amp
- // ? {
- // amp: query.amp,
- // }
- // : {}),
- // };
- asPath = `${asPath}${
- // ensure trailing slash is present for non-dynamic auto-export pages
- asPath.endsWith("/") && asPath !== "/" && !pageIsDynamic ? "/" : ""
- }`;
- }
-
- let head: JSX.Element[] = [
- <meta charSet="utf-8" />,
- <meta name="viewport" content="width=device-width" />,
- ];
-
- const nextExport = isAutoExport || isFallback;
- const reactLoadableModules: string[] = [];
- var scriptLoader = {};
- const AppContainer = ({ children }: any) => (
- <RouterContext.Provider value={router}>
- {/* <AmpStateContext.Provider value={ampState}> */}
- <HeadManagerContext.Provider
- value={{
- updateHead: (state) => {
- head = state;
- },
- updateScripts: (scripts) => {
- scriptLoader = scripts;
- },
- scripts: {},
- mountedInstances: new Set(),
- }}
- >
- <LoadableContext.Provider
- value={(moduleName) => reactLoadableModules.push(moduleName)}
- >
- {children}
- </LoadableContext.Provider>
- </HeadManagerContext.Provider>
- {/* </AmpStateContext.Provider> */}
- </RouterContext.Provider>
- );
-
- await Loadable.preloadAll(); // Make sure all dynamic imports are loaded
-
- const router = new ServerRouter(
- pathname,
- query,
- asPath,
- {
- isFallback: isFallback,
- },
- true,
- Bun.origin,
- null,
- [], // renderOpts.locales,
- null, //renderOpts.defaultLocale,
- [], // renderOpts.domainLocales,
- false,
- false
- );
-
- const ctx = {
- err: null,
- req: undefined,
- res: undefined,
- pathname,
- query,
- asPath,
- locale: null,
- locales: [],
- defaultLocale: null,
- AppTree: (props: any) => {
- return (
- <AppContainer>
- <App {...props} Component={Component} router={router} />
- </AppContainer>
- );
- },
- };
-
- var props = await loadGetInitialProps(AppComponent, {
- AppTree: ctx.AppTree,
- Component,
- router,
- ctx,
- });
-
- // This isn't correct.
- // We don't call getServerSideProps on clients.
- const getServerSideProps = PageNamespace.getServerSideProps;
- if (typeof getServerSideProps === "function") {
- const result = await getServerSideProps({
- params: route.params,
- query: route.query,
- req: notImplementedProxy("req"),
- res: notImplementedProxy("res"),
- resolvedUrl: route.pathname,
- preview: false,
- previewData: null,
- locale: null,
- locales: [],
- defaultLocale: null,
- });
-
- if (result) {
- if ("props" in result) {
- if (typeof result.props === "object") {
- Object.assign(props, result.props);
- }
- }
- }
- }
-
- const renderToString = ReactDOMServer.renderToString;
- const ErrorDebug = null;
-
- const renderPage: RenderPage = (
- options: ComponentsEnhancer = {}
- ): RenderPageResult | Promise<RenderPageResult> => {
- if (ctx.err && ErrorDebug) {
- const htmlOrPromise = renderToString(<ErrorDebug error={ctx.err} />);
- return typeof htmlOrPromise === "string"
- ? { html: htmlOrPromise, head }
- : htmlOrPromise.then((html) => ({
- html,
- head,
- }));
- }
-
- if (dev && (props.router || props.Component)) {
- throw new Error(
- `'router' and 'Component' can not be returned in getInitialProps from _app.js https://nextjs.org/docs/messages/cant-override-next-props`
- );
- }
-
- const { App: EnhancedApp, Component: EnhancedComponent } =
- enhanceComponents(options, AppComponent, Component);
-
- const htmlOrPromise = renderToString(
- <AppContainer>
- <EnhancedApp Component={EnhancedComponent} router={router} {...props} />
- </AppContainer>
- );
- return typeof htmlOrPromise === "string"
- ? { html: htmlOrPromise, head }
- : htmlOrPromise.then((html) => ({
- html,
- head,
- }));
- };
-
- const documentCtx = { ...ctx, renderPage };
- const docProps: DocumentInitialProps = await loadGetInitialProps(
- Document,
- documentCtx
- );
-
- if (!docProps || typeof docProps.html !== "string") {
- const message = `"${getDisplayName(
- Document
- )}.getInitialProps()" should resolve to an object with a "html" prop set with a valid html string`;
- throw new Error(message);
- }
-
- const renderOpts = {
- params: route.params,
- };
- // renderOpts.params = _params || params;
-
- // parsedUrl.pathname = denormalizePagePath(parsedUrl.pathname!);
- // renderOpts.resolvedUrl = formatUrl({
- // ...parsedUrl,
- // query: origQuery,
- // });
- const docComponentsRendered: DocumentProps["docComponentsRendered"] = {};
-
- const isPreview = false;
-
- let html = renderDocument(Document, {
- docComponentsRendered,
- ...renderOpts,
- disableOptimizedLoading: false,
- canonicalBase: Bun.origin,
- buildManifest: {
- devFiles: [],
- allFiles: [],
- polyfillFiles: [],
- lowPriorityFiles: [],
- pages: pages,
- },
- // Only enabled in production as development mode has features relying on HMR (style injection for example)
- unstable_runtimeJS: true,
- // process.env.NODE_ENV === "production"
- // ? pageConfig.unstable_runtimeJS
- // : undefined,
- // unstable_JsPreload: pageConfig.unstable_JsPreload,
- unstable_JsPreload: true,
- dangerousAsPath: router.asPath,
- ampState: undefined,
- props,
- assetPrefix: "",
- headTags: await headTags(documentCtx),
- isFallback,
- docProps,
- pathname,
- ampPath: undefined,
- query,
- inAmpMode: false,
- hybridAmp: undefined,
- dynamicImportsIds: [], // Array.from(dynamicImportsIds),
- dynamicImports: [], //Array.from(dynamicImports),
- gsp: !!getStaticProps ? true : undefined,
- gssp: !!getServerSideProps ? true : undefined,
- gip: hasPageGetInitialProps ? true : undefined,
- appGip: !defaultAppGetInitialProps ? true : undefined,
- devOnlyCacheBusterQueryString: "",
- scriptLoader,
- isPreview: isPreview === true ? true : undefined,
- autoExport: isAutoExport === true ? true : undefined,
- nextExport: nextExport === true ? true : undefined,
- });
- const bodyRenderIdx = html.indexOf(BODY_RENDER_TARGET);
- html =
- html.substring(0, bodyRenderIdx) +
- (false ? "<!-- __NEXT_DATA__ -->" : "") +
- docProps.html +
- html.substring(bodyRenderIdx + BODY_RENDER_TARGET.length);
- return new Response(
- html
- .replaceAll("/_next/http://", "http://")
- .replaceAll("/_next/https://", "https://")
- );
-}
diff --git a/examples/hello-next/bun-framework-next/route-loader.ts b/examples/hello-next/bun-framework-next/route-loader.ts
deleted file mode 100644
index e69de29bb..000000000
--- a/examples/hello-next/bun-framework-next/route-loader.ts
+++ /dev/null
diff --git a/examples/hello-next/bun-framework-next/server.development.tsx b/examples/hello-next/bun-framework-next/server.development.tsx
deleted file mode 100644
index e3cd24e01..000000000
--- a/examples/hello-next/bun-framework-next/server.development.tsx
+++ /dev/null
@@ -1,79 +0,0 @@
-import * as React from "react";
-import { Buffer } from "buffer";
-globalThis.Buffer = Buffer;
-
-class URL {
- constructor(base, source) {
- this.pathname = source;
- this.href = base + source;
- }
-}
-var onlyChildPolyfill = React.Children.only;
-React.Children.only = function (children) {
- if (children && typeof children === "object" && children.length == 1) {
- return onlyChildPolyfill(children[0]);
- }
-
- return onlyChildPolyfill(children);
-};
-globalThis.URL = URL;
-globalThis.global = globalThis;
-import { render } from "./renderDocument";
-
-let buildId = 0;
-
-var DocumentLoaded = false;
-var DocumentNamespace;
-
-import(Bun.routesDir + "_document").then(
- (doc) => {
- DocumentNamespace = doc;
- DocumentLoaded = true;
- },
- (err) => {
- if (err instanceof ResolveError) {
- DocumentLoaded = true;
- } else {
- console.error(err);
- }
- }
-);
-
-addEventListener("fetch", async (event: FetchEvent) => {
- var route = Bun.match(event);
-
- // This imports the currently matched route.
- const PageNamespace = await import(route.filePath);
-
- // This returns all .css files that were imported in the line above.
- // It's recursive, so any file that imports a CSS file will be included.
- const pageStylesheets = (Bun.getImportedStyles() as string[]).slice();
-
- var appRoute;
-
- try {
- appRoute = await import(Bun.routesDir + "_app");
- } catch (exception) {
- appRoute = null;
- }
- const appStylesheets = (Bun.getImportedStyles() as string[]).slice();
-
- event.respondWith(
- render({
- route,
- PageNamespace,
- appStylesheets,
- pageStylesheets,
- DocumentNamespace,
- AppNamespace: appRoute,
- buildId,
- routePaths: Bun.getRouteFiles(),
- })
- );
- buildId++;
-});
-
-// typescript isolated modules
-export {};
-
-declare var Bun: any;
diff --git a/examples/hello-next/bun-framework-next/server.production.tsx b/examples/hello-next/bun-framework-next/server.production.tsx
deleted file mode 100644
index e69de29bb..000000000
--- a/examples/hello-next/bun-framework-next/server.production.tsx
+++ /dev/null
diff --git a/examples/hello-next/bun-framework-next/tsconfig.json b/examples/hello-next/bun-framework-next/tsconfig.json
deleted file mode 100644
index d14767c9f..000000000
--- a/examples/hello-next/bun-framework-next/tsconfig.json
+++ /dev/null
@@ -1,21 +0,0 @@
-{
- "compilerOptions": {
- "target": "esnext",
- "lib": ["dom", "dom.iterable", "esnext", "WebWorker"],
- "allowJs": true,
- "skipLibCheck": true,
- "strict": false,
- "forceConsistentCasingInFileNames": true,
- "noEmit": true,
- "esModuleInterop": true,
- "module": "esnext",
- "moduleResolution": "Node",
- "resolveJsonModule": true,
- "isolatedModules": true,
- "jsx": "preserve",
- "baseUrl": ".",
- "paths": {}
- },
- "include": ["next-env.d.ts", "**/*.ts", "**/*.tsx"],
- "exclude": ["node_modules"]
-}
diff --git a/examples/hello-next/package.json b/examples/hello-next/package.json
index 1ce5e4982..e49602501 100644
--- a/examples/hello-next/package.json
+++ b/examples/hello-next/package.json
@@ -4,6 +4,9 @@
"main": "index.js",
"license": "MIT",
"dependencies": {
+ "@jarred/react-static-tweets": "0.5.8",
+ "@jarred/static-tweets": "^0.5.8",
+ "date-fns": "^2.23.0",
"isomorphic-fetch": "^3.0.0",
"next": "^11.1.0",
"parcel": "2.0.0-rc.0",
@@ -11,8 +14,6 @@
"react": "^17.0.2",
"react-dom": "^17.0.2",
"react-is": "^17.0.2",
- "react-static-tweets": "^0.5.4",
- "static-tweets": "^0.5.5",
"whatwg-url": "^9.1.0"
},
"devDependencies": {
diff --git a/examples/hello-next/pages/errortest.tsx b/examples/hello-next/pages/errortest.tsx
deleted file mode 100644
index 49a293df7..000000000
--- a/examples/hello-next/pages/errortest.tsx
+++ /dev/null
@@ -1,14 +0,0 @@
-import IndexPage from "pages/index";
-
-export default function ErrorTestPage() {
- class Wow {}
-
- const ladee = "",
- foo = { bar: { boom: new Wow() } };
-
- if (typeof window === "undefined") {
- const Doge = import("wow/such-esm/very-import");
- }
-
- return <IndexPage />;
-}
diff --git a/examples/hello-next/pages/index.tsx b/examples/hello-next/pages/index.tsx
index 7a2eb9f64..52b8f1f1f 100644
--- a/examples/hello-next/pages/index.tsx
+++ b/examples/hello-next/pages/index.tsx
@@ -1,80 +1,105 @@
import Head from "next/head";
-import Image from "next/image";
-import styles from "../styles/Home.module.css";
import Link from "next/link";
import { useRouter } from "next/router";
-import Title, { TitleEnum } from "../components/Title";
import React from "react";
+import {
+ Tweet,
+ TwitterContextProvider,
+} from "@jarred/react-static-tweets/src/index";
+import "@jarred/react-static-tweets/styles.css";
+import { fetchTweetAst } from "@jarred/static-tweets/src/fetchTweetAst";
+import { SWRConfig } from "swr";
+import styles from "../styles/Home.module.css";
-export default function Home({}) {
- const router = useRouter();
+export async function getStaticProps(ctx) {
+ return {
+ props: {
+ tweetAst: await fetchTweetAst("1390084458724741121"),
+ },
+ };
+}
+export default function Home({ tweetAst }) {
return (
- <div className={styles.container}>
- <Head>
- <title>Fo</title>
- <meta name="description" content="Generated by create next app" />
- <link rel="icon" href="/favicon.ico" />
- </Head>
+ <SWRConfig value={{ fallback: { [tweetAst[0].data.id]: tweetAst } }}>
+ <TwitterContextProvider
+ value={{
+ tweetAstMap: { [tweetAst[0].data.id]: tweetAst },
+ }}
+ >
+ <div className={styles.container}>
+ <Head>
+ <title>Fo</title>
+ <meta name="description" content="Generated by create next app" />
+ <link rel="icon" href="/favicon.ico" />
+ </Head>
- <main className={styles.main}>
- <h1 className={styles.title}>
- Welcome to <a href="https://nextjs.org">Next.js!</a>
- </h1>
+ <main className={styles.main}>
+
+ {/* <h1 className={styles.title}>
+ Welcome to <a href="https://nextjs.org">Next.js!</a>
+ </h1>
- <p className={styles.description}>
- Get started by editing{" "}
- <code className={styles.code}>pages/index.js</code>
- </p>
+ <p className={styles.description}>
+ Get started by editing{" "}
+ <code className={styles.code}>pages/index.js</code>
+ </p>
- <div className={styles.grid}>
- <Link href="/second">
- <div className={styles.card}>
- <h2>Second Page &rarr;</h2>
- <p>Link</p>
- </div>
- </Link>
+ <div className={styles.grid}>
+ <Link href="/second">
+ <div className={styles.card}>
+ <h2>Second Page &rarr;</h2>
+ <p>Link</p>
+ </div>
+ </Link>
- <a
- onClick={() => router.push("/foo/bar/third")}
- className={styles.card}
- >
- <h2>Third Page &rarr;</h2>
- <p>button, router.push()</p>
- </a>
+ <a
+ onClick={() => router.push("/foo/bar/third")}
+ className={styles.card}
+ >
+ <h2>Third Page &rarr;</h2>
+ <p>button, router.push()</p>
+ </a>
- <a
- href="https://github.com/vercel/next.js/tree/master/examples"
- className={styles.card}
- >
- <h2>Examples &rarr;</h2>
- <p>Discover and deploy boilerplate example Next.js projects.</p>
- </a>
+ <a
+ href="https://github.com/vercel/next.js/tree/master/examples"
+ className={styles.card}
+ >
+ <h2>Examples &rarr;</h2>
+ <p>Discover and deploy boilerplate example Next.js projects.</p>
+ </a>
- <a
- href="https://vercel.com/new?utm_source=create-next-app&utm_medium=default-template&utm_campaign=create-next-app"
- className={styles.card}
- >
- <h2>Deploy &rarr;</h2>
- <p>
- Instantly deploy your Next.js site to a public URL with Vercel.
- </p>
- </a>
+ <a
+ href="https://vercel.com/new?utm_source=create-next-app&utm_medium=default-template&utm_campaign=create-next-app"
+ className={styles.card}
+ >
+ <h2>Deploy &rarr;</h2>
+ <p>
+ Instantly deploy your Next.js site to a public URL with
+ Vercel.
+ </p>
+ </a>
+ </div> */}
+ </main>
+
+ {/* <footer className={styles.footer}>
+ <a
+ href="https://vercel.com?utm_source=create-next-app&utm_medium=default-template&utm_campaign=create-next-app"
+ target="_blank"
+ rel="noopener noreferrer"
+ >
+ Powered by{" "}
+ <span className={styles.logo}>
+ <img
+ src="/vercel.svg"
+ alt="Vercel Logo"
+ width={72}
+ height={16}
+ />
+ </span>
+ </a>
+ </footer> */}
</div>
- </main>
- <footer className={styles.footer}>
- <a
- href="https://vercel.com?utm_source=create-next-app&utm_medium=default-template&utm_campaign=create-next-app"
- target="_blank"
- rel="noopener noreferrer"
- >
- Powered by{" "}
- <span className={styles.logo}>
- <img src="/vercel.svg" alt="Vercel Logo" width={72} height={16} />
- </span>
- </a>
- </footer>
- </div>
);
}