Some checks failed
Test examples / Test Examples (20) (push) Has been cancelled
Test examples / Test Examples (22) (push) Has been cancelled
Lock Threads / action (push) Has been cancelled
Trigger Release / start (push) Has been cancelled
Stale issue handler / stale (push) Has been cancelled
Update Font Data / create-pull-request (push) Has been cancelled
build-and-deploy / deploy-target (push) Has been cancelled
build-and-deploy / build (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-musl - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-unknown-linux-gnu - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-pc-windows-msvc - node@16 (push) Has been cancelled
build-and-deploy / stable - aarch64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / stable - x86_64-apple-darwin - node@16 (push) Has been cancelled
build-and-deploy / build-wasm (nodejs) (push) Has been cancelled
build-and-deploy / build-wasm (web) (push) Has been cancelled
build-and-deploy / Deploy preview tarball (push) Has been cancelled
build-and-deploy / Potentially publish release (push) Has been cancelled
build-and-deploy / publish-turbopack-npm-packages (push) Has been cancelled
build-and-deploy / Deploy examples (push) Has been cancelled
build-and-deploy / thank you, build (push) Has been cancelled
build-and-deploy / Upload Turbopack Bytesize metrics to Datadog (push) Has been cancelled
Rspack Next.js development integration tests / Rspack integration tests (push) Has been cancelled
Rspack Next.js production integration tests / Rspack integration tests (push) Has been cancelled
Turbopack Next.js development integration tests / Next.js integration tests (push) Has been cancelled
Turbopack Next.js production integration tests / Next.js integration tests (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack development test manifest (push) Has been cancelled
Update Rspack test manifest / Update and upload Rspack production test manifest (push) Has been cancelled
Upload bundler test manifests to areweturboyet.com / Upload test results (push) Has been cancelled
Update React / create-pull-request (push) Has been cancelled
test-e2e-project-reset-cron / reset-test-project (push) Has been cancelled
Notify about the top 15 issues/PRs/feature requests (most reacted) in the last 90 days / run (push) Has been cancelled
70 lines
2.0 KiB
TypeScript
70 lines
2.0 KiB
TypeScript
import { type ClassValue, clsx } from 'clsx'
|
|
import { twMerge } from 'tailwind-merge'
|
|
import { SpecialModule } from './types'
|
|
import { NetworkError } from './errors'
|
|
import { AnalyzeData, SourceIndex } from './analyze-data'
|
|
|
|
export function cn(...inputs: ClassValue[]) {
|
|
return twMerge(clsx(inputs))
|
|
}
|
|
|
|
export async function fetchStrict(url: string): Promise<Response> {
|
|
let res: Response
|
|
try {
|
|
res = await fetch(url)
|
|
} catch (err) {
|
|
throw new NetworkError(`Failed to fetch ${url}`, { cause: err })
|
|
}
|
|
|
|
if (!res.ok) {
|
|
throw new Error(`Failed to fetch ${url}: ${res.status} ${res.statusText}`)
|
|
}
|
|
return res
|
|
}
|
|
|
|
export async function jsonFetcher<T>(url: string): Promise<T> {
|
|
const res = await fetchStrict(url)
|
|
return res.json() as Promise<T>
|
|
}
|
|
|
|
export function getSpecialModuleType(
|
|
analyzeData: AnalyzeData | undefined,
|
|
sourceIndex: SourceIndex | null
|
|
): SpecialModule | null {
|
|
if (!analyzeData || sourceIndex == null) return null
|
|
|
|
const path = analyzeData.source(sourceIndex)?.path || ''
|
|
if (path.endsWith('polyfill-module.js')) {
|
|
return SpecialModule.POLYFILL_MODULE
|
|
} else if (path.endsWith('polyfill-nomodule.js')) {
|
|
return SpecialModule.POLYFILL_NOMODULE
|
|
}
|
|
|
|
return null
|
|
}
|
|
|
|
export function formatBytes(bytes: number): string {
|
|
if (bytes === 0) return '0 B'
|
|
if (bytes < 1024) return `${bytes} B`
|
|
if (bytes < 1024 * 1024) return `${(bytes / 1024).toFixed(2)} KB`
|
|
if (bytes < 1024 * 1024 * 1024)
|
|
return `${(bytes / (1024 * 1024)).toFixed(2)} MB`
|
|
return `${(bytes / (1024 * 1024 * 1024)).toFixed(2)} GB`
|
|
}
|
|
|
|
let IDENT_ATTRIBUTES_REGEXP =
|
|
/^(.+?)(?: \{(.*)\})?(?: \[(.*)\])?(?: \((.*?)\))?(?: <(.*?)>)?$/
|
|
|
|
export function splitIdent(ident: string): {
|
|
fullPath: string
|
|
templateArgs: string
|
|
layer: string
|
|
moduleType: string
|
|
treeShaking: string
|
|
} {
|
|
let [match, fullPath, templateArgs, layer, moduleType, treeShaking] =
|
|
IDENT_ATTRIBUTES_REGEXP.exec(ident) || ['']
|
|
ident = ident.substring(0, ident.length - match.length)
|
|
return { fullPath, templateArgs, layer, moduleType, treeShaking }
|
|
}
|