diff --git a/biome.json b/biome.json index c8a5ab8..c5eb038 100644 --- a/biome.json +++ b/biome.json @@ -15,7 +15,7 @@ "rules": { "recommended": true, "complexity": { - "noThisInStatic": "warn" + "noThisInStatic": "off" } } } diff --git a/netlify/functions/cloudinary/index.js b/netlify/functions/cloudinary/index.js deleted file mode 100644 index 32eb2f2..0000000 --- a/netlify/functions/cloudinary/index.js +++ /dev/null @@ -1,62 +0,0 @@ -import crypto from 'node:crypto'; -import { v2 as cloudinary } from 'cloudinary'; - -const { USE_HIGH_QUALITY = false } = process.env; - -const search = (providerName, videoId) => - cloudinary.search - .expression(`resource_type:"image" AND folder="video_to_markdown/images" AND filename="${providerName}-${videoId}"`) - .sort_by('uploaded_at', 'desc') - .max_results(30) - .execute(); - -const useHighQuality = () => USE_HIGH_QUALITY === 'true'; - -const create = (source, video, options = {}) => - new Promise((resolve, reject) => { - const highQualitySize = 720; - const lowQualitySize = 500; - - // https://cloudinary.com/documentation/image_transformations#adjusting_image_quality - const highQuality = [{ height: highQualitySize }]; - - const lowQuality = [ - { quality: 'auto:low' }, - { if: 'w_gt_h' }, - { height: lowQualitySize }, - { if: 'else' }, - { width: lowQualitySize }, - { if: 'end' }, - ]; - - const overlayHeight = useHighQuality() ? '1.0' : (lowQualitySize / highQualitySize).toFixed(2).toString(); - const transformations = options.showPlayIcon - ? { - overlay: `video_to_markdown:icons:${video.providerName}`, - height: overlayHeight, - flag: 'relative', - gravity: 'center', - } - : {}; - const hash = crypto.createHash('md5').update(JSON.stringify(options)).digest('hex'); - const cloudinaryOptions = { - folder: 'video_to_markdown/images', - public_id: `${video.providerName}--${video.getId()}-${hash}`, - context: `url=${video.url}|provider=${video.providerName}`, - secure: true, - transformation: [...(useHighQuality() ? highQuality : lowQuality), { ...transformations }], - }; - - cloudinary.uploader.upload(source, cloudinaryOptions, (error, result) => { - if (error) { - return reject(error); - } - resolve(result); - }); - }); - -export default { - search, - create, - useHighQuality, -}; diff --git a/netlify/functions/cloudinary/index.ts b/netlify/functions/cloudinary/index.ts new file mode 100644 index 0000000..3cf2260 --- /dev/null +++ b/netlify/functions/cloudinary/index.ts @@ -0,0 +1,60 @@ +import crypto from 'node:crypto'; +import { v2 as cloudinary } from 'cloudinary'; +import type { Options } from '../types'; +import type VideoProvider from '../videoWrapper/VideoProvider'; + +const { USE_HIGH_QUALITY = false } = process.env; + +// const search = (providerName, videoId) => +// cloudinary.search +// .expression(`resource_type:"image" AND folder="video_to_markdown/images" AND filename="${providerName}-${videoId}"`) +// .sort_by('uploaded_at', 'desc') +// .max_results(30) +// .execute(); + +const useHighQuality = () => USE_HIGH_QUALITY === 'true'; + +async function create(source: string, video: VideoProvider, options?: Options) { + const highQualitySize = 720; + const lowQualitySize = 500; + + // https://cloudinary.com/documentation/image_transformations#adjusting_image_quality + const highQuality = [{ height: highQualitySize }]; + + const lowQuality = [ + { quality: 'auto:low' }, + { if: 'w_gt_h' }, + { height: lowQualitySize }, + { if: 'else' }, + { width: lowQualitySize }, + { if: 'end' }, + ]; + + const overlayHeight = useHighQuality() ? '1.0' : (lowQualitySize / highQualitySize).toFixed(2).toString(); + const transformations = options?.showPlayIcon + ? { + overlay: `video_to_markdown:icons:${video.providerName}`, + height: overlayHeight, + flag: 'relative', + gravity: 'center', + } + : {}; + const hash = crypto.createHash('md5').update(JSON.stringify(options)).digest('hex'); + const cloudinaryOptions = { + folder: 'video_to_markdown/images', + public_id: `${video.providerName}--${video.getId()}-${hash}`, + context: `url=${video.url}|provider=${video.providerName}`, + secure: true, + transformation: [...(useHighQuality() ? highQuality : lowQuality), { ...transformations }], + }; + + const cloudinaryResponse = await cloudinary.uploader.upload(source, cloudinaryOptions); + + return cloudinaryResponse; +} + +export default { + // search, + create, + useHighQuality, +}; diff --git a/netlify/functions/image-json.js b/netlify/functions/image-json.ts similarity index 97% rename from netlify/functions/image-json.js rename to netlify/functions/image-json.ts index 87628a3..16888db 100644 --- a/netlify/functions/image-json.js +++ b/netlify/functions/image-json.ts @@ -1,5 +1,3 @@ -// @ts-check - import cloudinary from './cloudinary/index.js'; import { create } from './videoWrapper/index.js'; @@ -30,7 +28,8 @@ export const handler = async (event, context, callback) => { return throwException(422, 'param URL is mandatory.'); } - let video; + let video: Awaited>; + try { video = await create(url, { showPlayIcon: getParam(event, 'showPlayIcon') === 'true', diff --git a/netlify/functions/types.ts b/netlify/functions/types.ts new file mode 100644 index 0000000..78cbb3f --- /dev/null +++ b/netlify/functions/types.ts @@ -0,0 +1,13 @@ +import type VideoProvider from './videoWrapper/VideoProvider'; + +export type ImageService = { + // search: (providerName: string, videoId: string) => Promise; + create: (source: string, video: VideoProvider, options?: Options) => Promise<{ secure_url: string }>; + useHighQuality: () => boolean; +}; + +export type Options = { + showPlayIcon?: boolean; + image?: string; + ImageService?: ImageService; +}; diff --git a/netlify/functions/videoWrapper/Providers/Asciinema.test.js b/netlify/functions/videoWrapper/Providers/Asciinema.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Asciinema.test.js rename to netlify/functions/videoWrapper/Providers/Asciinema.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Asciinema.js b/netlify/functions/videoWrapper/Providers/Asciinema.ts similarity index 85% rename from netlify/functions/videoWrapper/Providers/Asciinema.js rename to netlify/functions/videoWrapper/Providers/Asciinema.ts index 3491c04..42cea2e 100644 --- a/netlify/functions/videoWrapper/Providers/Asciinema.js +++ b/netlify/functions/videoWrapper/Providers/Asciinema.ts @@ -19,6 +19,6 @@ export default class Asciinema extends VideoProvider { } getThumbnail_asVideoUrl() { - return new Promise((resolve) => resolve(`${this.url}.svg`)); + return Promise.resolve(`${this.url}.svg`); } } diff --git a/netlify/functions/videoWrapper/Providers/CleanShotCloud.test.js b/netlify/functions/videoWrapper/Providers/CleanShotCloud.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/CleanShotCloud.test.js rename to netlify/functions/videoWrapper/Providers/CleanShotCloud.test.ts diff --git a/netlify/functions/videoWrapper/Providers/CleanShotCloud.js b/netlify/functions/videoWrapper/Providers/CleanShotCloud.ts similarity index 72% rename from netlify/functions/videoWrapper/Providers/CleanShotCloud.js rename to netlify/functions/videoWrapper/Providers/CleanShotCloud.ts index 083e1d1..68144e3 100644 --- a/netlify/functions/videoWrapper/Providers/CleanShotCloud.js +++ b/netlify/functions/videoWrapper/Providers/CleanShotCloud.ts @@ -23,14 +23,15 @@ export default class CleanShotCloud extends VideoProvider { return fetch(this.url) .then((response) => response.text()) .then((html) => { - return parse(html).querySelector('[property="og:image"]').getAttribute('content'); + return parse(html)?.querySelector('[property="og:image"]')?.getAttribute('content'); }) .then((image) => { if (this.options.showPlayIcon) { return image; } - return image.replace(/\/draw\(image\(.*\),position:center\)/, '').replace(/&?play=1/, ''); - }); + return image?.replace(/\/draw\(image\(.*\),position:center\)/, '').replace(/&?play=1/, ''); + }) + .then((image) => image ?? null); } } diff --git a/netlify/functions/videoWrapper/Providers/Dailymotion.test.js b/netlify/functions/videoWrapper/Providers/Dailymotion.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Dailymotion.test.js rename to netlify/functions/videoWrapper/Providers/Dailymotion.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Dailymotion.js b/netlify/functions/videoWrapper/Providers/Dailymotion.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Dailymotion.js rename to netlify/functions/videoWrapper/Providers/Dailymotion.ts diff --git a/netlify/functions/videoWrapper/Providers/Facebook.test.js b/netlify/functions/videoWrapper/Providers/Facebook.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Facebook.test.js rename to netlify/functions/videoWrapper/Providers/Facebook.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Facebook.js b/netlify/functions/videoWrapper/Providers/Facebook.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Facebook.js rename to netlify/functions/videoWrapper/Providers/Facebook.ts diff --git a/netlify/functions/videoWrapper/Providers/GoogleDrive.test.js b/netlify/functions/videoWrapper/Providers/GoogleDrive.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/GoogleDrive.test.js rename to netlify/functions/videoWrapper/Providers/GoogleDrive.test.ts diff --git a/netlify/functions/videoWrapper/Providers/GoogleDrive.js b/netlify/functions/videoWrapper/Providers/GoogleDrive.ts similarity index 83% rename from netlify/functions/videoWrapper/Providers/GoogleDrive.js rename to netlify/functions/videoWrapper/Providers/GoogleDrive.ts index f3983c1..db51049 100644 --- a/netlify/functions/videoWrapper/Providers/GoogleDrive.js +++ b/netlify/functions/videoWrapper/Providers/GoogleDrive.ts @@ -19,8 +19,6 @@ export default class GoogleDrive extends VideoProvider { } getThumbnail_asVideoUrl() { - return new Promise((resolve) => - resolve(`https://drive.google.com/thumbnail?authuser=0&sz=w1280&id=${this.getId()}`), - ); + return Promise.resolve(`https://drive.google.com/thumbnail?authuser=0&sz=w1280&id=${this.getId()}`); } } diff --git a/netlify/functions/videoWrapper/Providers/Imgur.test.js b/netlify/functions/videoWrapper/Providers/Imgur.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Imgur.test.js rename to netlify/functions/videoWrapper/Providers/Imgur.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Imgur.js b/netlify/functions/videoWrapper/Providers/Imgur.ts similarity index 83% rename from netlify/functions/videoWrapper/Providers/Imgur.js rename to netlify/functions/videoWrapper/Providers/Imgur.ts index 721c16c..b68d9b8 100644 --- a/netlify/functions/videoWrapper/Providers/Imgur.js +++ b/netlify/functions/videoWrapper/Providers/Imgur.ts @@ -15,6 +15,6 @@ export default class Imgur extends VideoProvider { } getThumbnail_asVideoUrl() { - return new Promise((resolve) => resolve(`${this.url}.jpg`)); + return Promise.resolve(`${this.url}.jpg`); } } diff --git a/netlify/functions/videoWrapper/Providers/Loom.test.js b/netlify/functions/videoWrapper/Providers/Loom.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Loom.test.js rename to netlify/functions/videoWrapper/Providers/Loom.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Loom.js b/netlify/functions/videoWrapper/Providers/Loom.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Loom.js rename to netlify/functions/videoWrapper/Providers/Loom.ts diff --git a/netlify/functions/videoWrapper/Providers/OneDrive.test.js b/netlify/functions/videoWrapper/Providers/OneDrive.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/OneDrive.test.js rename to netlify/functions/videoWrapper/Providers/OneDrive.test.ts diff --git a/netlify/functions/videoWrapper/Providers/OneDrive.js b/netlify/functions/videoWrapper/Providers/OneDrive.ts similarity index 95% rename from netlify/functions/videoWrapper/Providers/OneDrive.js rename to netlify/functions/videoWrapper/Providers/OneDrive.ts index e980bef..0635edf 100644 --- a/netlify/functions/videoWrapper/Providers/OneDrive.js +++ b/netlify/functions/videoWrapper/Providers/OneDrive.ts @@ -50,7 +50,7 @@ export default class OneDrive extends VideoProvider { if (redeem != null) { this.log('auth', 'authentication required'); - const [, appId] = text.match(/"clientId":"([\w-]+)"/); + const [, appId] = text.match(/"clientId":"([\w-]+)"/) ?? []; this.log('appId', appId); const auth = await fetch('https://api-badgerp.svc.ms/v1.0/token', { headers: { @@ -109,7 +109,13 @@ export default class OneDrive extends VideoProvider { }); } }) - .then((res) => res.json()) + .then((res) => { + if (res == null) { + throw new Error('Cannot elaborate the request.'); + } + + return res.json(); + }) .then((json) => { const [firstThumbnail] = json.value; diff --git a/netlify/functions/videoWrapper/Providers/PeerTube.test.js b/netlify/functions/videoWrapper/Providers/PeerTube.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/PeerTube.test.js rename to netlify/functions/videoWrapper/Providers/PeerTube.test.ts diff --git a/netlify/functions/videoWrapper/Providers/PeerTube.js b/netlify/functions/videoWrapper/Providers/PeerTube.ts similarity index 73% rename from netlify/functions/videoWrapper/Providers/PeerTube.js rename to netlify/functions/videoWrapper/Providers/PeerTube.ts index 9a7623f..a1796cd 100644 --- a/netlify/functions/videoWrapper/Providers/PeerTube.js +++ b/netlify/functions/videoWrapper/Providers/PeerTube.ts @@ -19,7 +19,7 @@ export default class PeerTube extends VideoProvider { return fetch(this.url) .then((response) => response.text()) .then((html) => { - const platform = htmlMiner(html, (arg) => arg.$('[property="og:platform"]').attr('content')); + const platform = parse(html)?.querySelector('[property="og:platform"]')?.getAttribute('content'); if (platform !== 'PeerTube') { throw new Error(`'og:platform' does not match PeerTube`); @@ -28,7 +28,8 @@ export default class PeerTube extends VideoProvider { return html; }) .then((html) => { - return parse(html).querySelector('[property="og:image"]').getAttribute('content'); - }); + return parse(html)?.querySelector('[property="og:image"]')?.getAttribute('content'); + }) + .then((url) => url ?? null); } } diff --git a/netlify/functions/videoWrapper/Providers/Streamable.js b/netlify/functions/videoWrapper/Providers/Streamable.js deleted file mode 100644 index dabd118..0000000 --- a/netlify/functions/videoWrapper/Providers/Streamable.js +++ /dev/null @@ -1,34 +0,0 @@ -import VideoProvider from '../VideoProvider.js'; - -// https://support.streamable.com/api-documentation - -export default class Streamable extends VideoProvider { - get providerName() { - return 'streamable'; - } - - static get regex() { - return [ - // - //streamable.com/1nvj5i - /https?\:\/\/streamable\.com\/([a-z0-9]+)/, - ]; - } - - getThumbnail_asVideoUrl() { - const endpoint = `https://api.streamable.com/oembed.json?url=https%3A%2F%2Fstreamable.com%2F${this.getId()}`; - - return fetch(endpoint) - .then((response) => response.json()) - .then((json) => { - const cdns = ['-west', '-east']; - const thumbnail_url = `https:${json.thumbnail_url}?height=540`; - - const thumbnails = cdns.map((cdn) => thumbnail_url.replace(new RegExp(cdns.join('|')), cdn)); - - return Promise.all(thumbnails.map((tmb) => fetch(tmb))); - }) - .then((results) => results.filter((result) => result.status === 200)) - .then((results) => results.shift()) - .then((result) => (result ? result.url : Promise.reject())); - } -} diff --git a/netlify/functions/videoWrapper/Providers/Streamable.test.js b/netlify/functions/videoWrapper/Providers/Streamable.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Streamable.test.js rename to netlify/functions/videoWrapper/Providers/Streamable.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Streamable.ts b/netlify/functions/videoWrapper/Providers/Streamable.ts new file mode 100644 index 0000000..61f843c --- /dev/null +++ b/netlify/functions/videoWrapper/Providers/Streamable.ts @@ -0,0 +1,28 @@ +import VideoProvider from '../VideoProvider.js'; + +// https://support.streamable.com/api-documentation + +export default class Streamable extends VideoProvider { + get providerName() { + return 'streamable'; + } + + static get regex() { + return [ + // - //streamable.com/1nvj5i + /https?\:\/\/streamable\.com\/([a-z0-9]+)/, + ]; + } + + needsCloudinary() { + return true; + } + + getThumbnail_asVideoUrl() { + const endpoint = `https://api.streamable.com/oembed.json?url=${encodeURIComponent(`https://streamable.com/${this.getId()}`)}`; + + return fetch(endpoint) + .then((response) => response.json()) + .then((json) => json.thumbnail_url); + } +} diff --git a/netlify/functions/videoWrapper/Providers/TikTok.test.js b/netlify/functions/videoWrapper/Providers/TikTok.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/TikTok.test.js rename to netlify/functions/videoWrapper/Providers/TikTok.test.ts diff --git a/netlify/functions/videoWrapper/Providers/TikTok.js b/netlify/functions/videoWrapper/Providers/TikTok.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/TikTok.js rename to netlify/functions/videoWrapper/Providers/TikTok.ts diff --git a/netlify/functions/videoWrapper/Providers/Video.js b/netlify/functions/videoWrapper/Providers/Video.js deleted file mode 100644 index fddab27..0000000 --- a/netlify/functions/videoWrapper/Providers/Video.js +++ /dev/null @@ -1,22 +0,0 @@ -import VideoProvider from '../VideoProvider.js'; -import { videoRegEx } from '../videoRegEx.js'; - -import crypto from 'node:crypto'; - -export default class Video extends VideoProvider { - get providerName() { - return 'video'; - } - - static get regex() { - return videoRegEx; - } - - static getVideoId(url = '') { - return super.getVideoId(url) ? crypto.createHash('md5').update(url).digest('hex') : undefined; - } - - getThumbnail_asVideoUrl() { - return Promise.resolve(this.options.image); - } -} diff --git a/netlify/functions/videoWrapper/Providers/Video.test.js b/netlify/functions/videoWrapper/Providers/Video.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Video.test.js rename to netlify/functions/videoWrapper/Providers/Video.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Video.ts b/netlify/functions/videoWrapper/Providers/Video.ts new file mode 100644 index 0000000..27deb13 --- /dev/null +++ b/netlify/functions/videoWrapper/Providers/Video.ts @@ -0,0 +1,25 @@ +import VideoProvider from '../VideoProvider.js'; +import { videoRegEx } from '../videoRegEx.js'; + +import crypto from 'node:crypto'; + +export default class Video extends VideoProvider { + get providerName() { + return 'video'; + } + + static get regex() { + return videoRegEx; + } + + static getVideoId(url = '') { + return super.getVideoId(url) ? crypto.createHash('md5').update(url).digest('hex') : undefined; + } + + getThumbnail_asVideoUrl() { + return Promise.resolve(this.options.image ?? image404); + } +} + +const image404 = + ''; diff --git a/netlify/functions/videoWrapper/Providers/Vimeo.test.js b/netlify/functions/videoWrapper/Providers/Vimeo.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Vimeo.test.js rename to netlify/functions/videoWrapper/Providers/Vimeo.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Vimeo.js b/netlify/functions/videoWrapper/Providers/Vimeo.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Vimeo.js rename to netlify/functions/videoWrapper/Providers/Vimeo.ts diff --git a/netlify/functions/videoWrapper/Providers/Wistia.test.js b/netlify/functions/videoWrapper/Providers/Wistia.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Wistia.test.js rename to netlify/functions/videoWrapper/Providers/Wistia.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Wistia.js b/netlify/functions/videoWrapper/Providers/Wistia.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Wistia.js rename to netlify/functions/videoWrapper/Providers/Wistia.ts diff --git a/netlify/functions/videoWrapper/Providers/Youtube.test.js b/netlify/functions/videoWrapper/Providers/Youtube.test.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Youtube.test.js rename to netlify/functions/videoWrapper/Providers/Youtube.test.ts diff --git a/netlify/functions/videoWrapper/Providers/Youtube.js b/netlify/functions/videoWrapper/Providers/Youtube.ts similarity index 100% rename from netlify/functions/videoWrapper/Providers/Youtube.js rename to netlify/functions/videoWrapper/Providers/Youtube.ts diff --git a/netlify/functions/videoWrapper/VideoProvider.js b/netlify/functions/videoWrapper/VideoProvider.ts similarity index 59% rename from netlify/functions/videoWrapper/VideoProvider.js rename to netlify/functions/videoWrapper/VideoProvider.ts index 554ce1a..30cad38 100644 --- a/netlify/functions/videoWrapper/VideoProvider.js +++ b/netlify/functions/videoWrapper/VideoProvider.ts @@ -1,9 +1,14 @@ +import type { Options } from '../types'; + export default class VideoProvider { - static get regex() { + url: string; + options: Options; + + static get regex(): RegExp[] { return []; } - get providerName() { + get providerName(): string | undefined { return undefined; } @@ -11,7 +16,7 @@ export default class VideoProvider { return !!this.getVideoId(url); } - static getVideoId(url = '') { + static getVideoId(url = ''): string | undefined { const id = this.regex .map((rx) => { const [, id] = url.match(rx) || []; @@ -38,23 +43,29 @@ export default class VideoProvider { return this.constructor.getVideoId(this.url); } - getThumbnail_asVideoUrl() { - return new Promise(); + getThumbnail_asVideoUrl(): Promise { + return new Promise(() => {}); } - getThumbnail_asUrl() { + getThumbnail_asUrl(): Promise { return this.getThumbnail_asVideoUrl().then((videoUrl) => { + if (videoUrl == null) { + return null; + } + if (!this.needsCloudinary()) { return videoUrl; } - return this.options.ImageService.create(videoUrl, this, { - showPlayIcon: this.options.showPlayIcon, - }).then((response) => response.secure_url); + return ( + this.options.ImageService?.create(videoUrl, this, { + showPlayIcon: this.options.showPlayIcon, + }).then((response) => response.secure_url) ?? null + ); }); } - constructor(url, options = {}) { + constructor(url: string, options: Options = {}) { if (!this.constructor.check(url)) { throw new Error(`Invalid url for ${this.providerName} provider.`); } diff --git a/netlify/functions/videoWrapper/index.test.js b/netlify/functions/videoWrapper/index.test.ts similarity index 99% rename from netlify/functions/videoWrapper/index.test.js rename to netlify/functions/videoWrapper/index.test.ts index f88842b..86efd06 100644 --- a/netlify/functions/videoWrapper/index.test.js +++ b/netlify/functions/videoWrapper/index.test.ts @@ -1,5 +1,3 @@ -// @ts-check - import { suite } from 'uvu'; import { equal } from 'uvu/assert'; diff --git a/netlify/functions/videoWrapper/index.js b/netlify/functions/videoWrapper/index.ts similarity index 91% rename from netlify/functions/videoWrapper/index.js rename to netlify/functions/videoWrapper/index.ts index 39d87c9..9efb4a7 100644 --- a/netlify/functions/videoWrapper/index.js +++ b/netlify/functions/videoWrapper/index.ts @@ -1,4 +1,4 @@ -// @ts-check +import type { Options } from '../types.js'; function getVideoProviders() { return Promise.all([ @@ -20,7 +20,7 @@ function getVideoProviders() { ]); } -export async function create(url, options) { +export async function create(url: string, options?: Options) { const videoProviders = await getVideoProviders(); const videoProvider = videoProviders.filter((vp) => { return vp.default.check(url); diff --git a/package.json b/package.json index e6f7ebf..f917dec 100644 --- a/package.json +++ b/package.json @@ -50,6 +50,7 @@ "@biomejs/biome": "^1.8.1", "sass": "^1.77.1", "sinon": "^18.0.0", + "tsm": "^2.3.0", "uvu": "^0.5.6" }, "dependencies": { @@ -72,7 +73,7 @@ "predev": "pnpm build-db", "prebuild:client": "pnpm build-db", "prepare": "husky install", - "test": "uvu netlify .test.js", + "test": "uvu -r tsm netlify .test.*s", "format": "pnpm biome format src scripts netlify --write", "lint": "pnpm biome check src scripts netlify", "dep:major": "pnpm dlx npm-check-updates --packageFile '**/package.json' -u", diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 7d3bdb8..5b71eb0 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -35,13 +35,13 @@ importers: version: 1.8.1 '@parcel/packager-raw-url': specifier: ^2.12.0 - version: 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + version: 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/transformer-sass': specifier: ^2.12.0 - version: 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + version: 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/transformer-webmanifest': specifier: ^2.12.0 - version: 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + version: 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) dotenv: specifier: ^16.4.5 version: 16.4.5 @@ -69,6 +69,9 @@ importers: sinon: specifier: ^18.0.0 version: 18.0.0 + tsm: + specifier: ^2.3.0 + version: 2.3.0 uvu: specifier: ^0.5.6 version: 0.5.6 @@ -210,6 +213,12 @@ packages: cpu: [arm64] os: [android] + '@esbuild/android-arm@0.15.18': + resolution: {integrity: sha512-5GT+kcs2WVGjVs7+boataCkO5Fg0y4kCjzkB5bAip7H4jfnOS3dA6KPiww9W1OEKTKeAcUVhdZGvgI65OXmUnw==} + engines: {node: '>=12'} + cpu: [arm] + os: [android] + '@esbuild/android-arm@0.19.11': resolution: {integrity: sha512-5OVapq0ClabvKvQ58Bws8+wkLCV+Rxg7tUVbo9xu034Nm536QTII4YzhaFriQ7rMrorfnFKUsArD2lqKbFY4vw==} engines: {node: '>=12'} @@ -318,6 +327,12 @@ packages: cpu: [ia32] os: [linux] + '@esbuild/linux-loong64@0.15.18': + resolution: {integrity: sha512-L4jVKS82XVhw2nvzLg/19ClLWg0y27ulRwuP7lcyL6AbUWB5aPglXY3M21mauDQMDfRLs8cQmeT03r/+X3cZYQ==} + engines: {node: '>=12'} + cpu: [loong64] + os: [linux] + '@esbuild/linux-loong64@0.19.11': resolution: {integrity: sha512-ppZSSLVpPrwHccvC6nQVZaSHlFsvCQyjnvirnVjbKSHuE5N24Yl8F3UwYUUR1UEPaFObGD2tSvVKbvR+uT1Nrg==} engines: {node: '>=12'} @@ -2424,6 +2439,131 @@ packages: es6-promisify@6.1.1: resolution: {integrity: sha512-HBL8I3mIki5C1Cc9QjKUenHtnG0A5/xA8Q/AllRcfiwl2CZFXGK7ddBiCoRwAix4i2KxcQfjtIVcrVbB3vbmwg==} + esbuild-android-64@0.15.18: + resolution: {integrity: sha512-wnpt3OXRhcjfIDSZu9bnzT4/TNTDsOUvip0foZOUBG7QbSt//w3QV4FInVJxNhKc/ErhUxc5z4QjHtMi7/TbgA==} + engines: {node: '>=12'} + cpu: [x64] + os: [android] + + esbuild-android-arm64@0.15.18: + resolution: {integrity: sha512-G4xu89B8FCzav9XU8EjsXacCKSG2FT7wW9J6hOc18soEHJdtWu03L3TQDGf0geNxfLTtxENKBzMSq9LlbjS8OQ==} + engines: {node: '>=12'} + cpu: [arm64] + os: [android] + + esbuild-darwin-64@0.15.18: + resolution: {integrity: sha512-2WAvs95uPnVJPuYKP0Eqx+Dl/jaYseZEUUT1sjg97TJa4oBtbAKnPnl3b5M9l51/nbx7+QAEtuummJZW0sBEmg==} + engines: {node: '>=12'} + cpu: [x64] + os: [darwin] + + esbuild-darwin-arm64@0.15.18: + resolution: {integrity: sha512-tKPSxcTJ5OmNb1btVikATJ8NftlyNlc8BVNtyT/UAr62JFOhwHlnoPrhYWz09akBLHI9nElFVfWSTSRsrZiDUA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [darwin] + + esbuild-freebsd-64@0.15.18: + resolution: {integrity: sha512-TT3uBUxkteAjR1QbsmvSsjpKjOX6UkCstr8nMr+q7zi3NuZ1oIpa8U41Y8I8dJH2fJgdC3Dj3CXO5biLQpfdZA==} + engines: {node: '>=12'} + cpu: [x64] + os: [freebsd] + + esbuild-freebsd-arm64@0.15.18: + resolution: {integrity: sha512-R/oVr+X3Tkh+S0+tL41wRMbdWtpWB8hEAMsOXDumSSa6qJR89U0S/PpLXrGF7Wk/JykfpWNokERUpCeHDl47wA==} + engines: {node: '>=12'} + cpu: [arm64] + os: [freebsd] + + esbuild-linux-32@0.15.18: + resolution: {integrity: sha512-lphF3HiCSYtaa9p1DtXndiQEeQDKPl9eN/XNoBf2amEghugNuqXNZA/ZovthNE2aa4EN43WroO0B85xVSjYkbg==} + engines: {node: '>=12'} + cpu: [ia32] + os: [linux] + + esbuild-linux-64@0.15.18: + resolution: {integrity: sha512-hNSeP97IviD7oxLKFuii5sDPJ+QHeiFTFLoLm7NZQligur8poNOWGIgpQ7Qf8Balb69hptMZzyOBIPtY09GZYw==} + engines: {node: '>=12'} + cpu: [x64] + os: [linux] + + esbuild-linux-arm64@0.15.18: + resolution: {integrity: sha512-54qr8kg/6ilcxd+0V3h9rjT4qmjc0CccMVWrjOEM/pEcUzt8X62HfBSeZfT2ECpM7104mk4yfQXkosY8Quptug==} + engines: {node: '>=12'} + cpu: [arm64] + os: [linux] + + esbuild-linux-arm@0.15.18: + resolution: {integrity: sha512-UH779gstRblS4aoS2qpMl3wjg7U0j+ygu3GjIeTonCcN79ZvpPee12Qun3vcdxX+37O5LFxz39XeW2I9bybMVA==} + engines: {node: '>=12'} + cpu: [arm] + os: [linux] + + esbuild-linux-mips64le@0.15.18: + resolution: {integrity: sha512-Mk6Ppwzzz3YbMl/ZZL2P0q1tnYqh/trYZ1VfNP47C31yT0K8t9s7Z077QrDA/guU60tGNp2GOwCQnp+DYv7bxQ==} + engines: {node: '>=12'} + cpu: [mips64el] + os: [linux] + + esbuild-linux-ppc64le@0.15.18: + resolution: {integrity: sha512-b0XkN4pL9WUulPTa/VKHx2wLCgvIAbgwABGnKMY19WhKZPT+8BxhZdqz6EgkqCLld7X5qiCY2F/bfpUUlnFZ9w==} + engines: {node: '>=12'} + cpu: [ppc64] + os: [linux] + + esbuild-linux-riscv64@0.15.18: + resolution: {integrity: sha512-ba2COaoF5wL6VLZWn04k+ACZjZ6NYniMSQStodFKH/Pu6RxzQqzsmjR1t9QC89VYJxBeyVPTaHuBMCejl3O/xg==} + engines: {node: '>=12'} + cpu: [riscv64] + os: [linux] + + esbuild-linux-s390x@0.15.18: + resolution: {integrity: sha512-VbpGuXEl5FCs1wDVp93O8UIzl3ZrglgnSQ+Hu79g7hZu6te6/YHgVJxCM2SqfIila0J3k0csfnf8VD2W7u2kzQ==} + engines: {node: '>=12'} + cpu: [s390x] + os: [linux] + + esbuild-netbsd-64@0.15.18: + resolution: {integrity: sha512-98ukeCdvdX7wr1vUYQzKo4kQ0N2p27H7I11maINv73fVEXt2kyh4K4m9f35U1K43Xc2QGXlzAw0K9yoU7JUjOg==} + engines: {node: '>=12'} + cpu: [x64] + os: [netbsd] + + esbuild-openbsd-64@0.15.18: + resolution: {integrity: sha512-yK5NCcH31Uae076AyQAXeJzt/vxIo9+omZRKj1pauhk3ITuADzuOx5N2fdHrAKPxN+zH3w96uFKlY7yIn490xQ==} + engines: {node: '>=12'} + cpu: [x64] + os: [openbsd] + + esbuild-sunos-64@0.15.18: + resolution: {integrity: sha512-On22LLFlBeLNj/YF3FT+cXcyKPEI263nflYlAhz5crxtp3yRG1Ugfr7ITyxmCmjm4vbN/dGrb/B7w7U8yJR9yw==} + engines: {node: '>=12'} + cpu: [x64] + os: [sunos] + + esbuild-windows-32@0.15.18: + resolution: {integrity: sha512-o+eyLu2MjVny/nt+E0uPnBxYuJHBvho8vWsC2lV61A7wwTWC3jkN2w36jtA+yv1UgYkHRihPuQsL23hsCYGcOQ==} + engines: {node: '>=12'} + cpu: [ia32] + os: [win32] + + esbuild-windows-64@0.15.18: + resolution: {integrity: sha512-qinug1iTTaIIrCorAUjR0fcBk24fjzEedFYhhispP8Oc7SFvs+XeW3YpAKiKp8dRpizl4YYAhxMjlftAMJiaUw==} + engines: {node: '>=12'} + cpu: [x64] + os: [win32] + + esbuild-windows-arm64@0.15.18: + resolution: {integrity: sha512-q9bsYzegpZcLziq0zgUi5KqGVtfhjxGbnksaBFYmWLxeV/S1fK4OLdq2DFYnXcLMjlZw2L0jLsk1eGoB522WXQ==} + engines: {node: '>=12'} + cpu: [arm64] + os: [win32] + + esbuild@0.15.18: + resolution: {integrity: sha512-x/R72SmW3sSFRm5zrrIjAhCeQSAWoni3CmHEqfQrZIQTM3lVCdehdwuIqaOtfC2slvpdlLa62GYoN8SxT23m6Q==} + engines: {node: '>=12'} + hasBin: true + esbuild@0.19.11: resolution: {integrity: sha512-HJ96Hev2hX/6i5cDVwcqiJBBtuo9+FeIJOtZ9W1kA5M6AMJRHUZlpYZ1/SbEwtO0ioNAW8rUooVpC/WehY2SfA==} engines: {node: '>=12'} @@ -5072,6 +5212,11 @@ packages: tslib@2.6.2: resolution: {integrity: sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==} + tsm@2.3.0: + resolution: {integrity: sha512-++0HFnmmR+gMpDtKTnW3XJ4yv9kVGi20n+NfyQWB9qwJvTaIWY9kBmzek2YUQK5APTQ/1DTrXmm4QtFPmW9Rzw==} + engines: {node: '>=12'} + hasBin: true + tsutils@3.21.0: resolution: {integrity: sha512-mHKK3iUXL+3UF6xL5k0PEhKRUBKPBCv/+RkEOpjRWxxx27KKRBmmA60A9pgOUvMi8GKhRMPEmjBRPzs2W7O1OA==} engines: {node: '>= 6'} @@ -5556,6 +5701,9 @@ snapshots: '@esbuild/android-arm64@0.21.2': optional: true + '@esbuild/android-arm@0.15.18': + optional: true + '@esbuild/android-arm@0.19.11': optional: true @@ -5610,6 +5758,9 @@ snapshots: '@esbuild/linux-ia32@0.21.2': optional: true + '@esbuild/linux-loong64@0.15.18': + optional: true + '@esbuild/linux-loong64@0.19.11': optional: true @@ -6278,17 +6429,16 @@ snapshots: '@opentelemetry/semantic-conventions@1.24.1': {} - '@parcel/bundler-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/bundler-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 '@parcel/graph': 3.2.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 '@parcel/utils': 2.12.0 nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/cache@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': dependencies: @@ -6304,47 +6454,46 @@ snapshots: dependencies: chalk: 4.1.2 - '@parcel/compressor-raw@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/compressor-raw@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/config-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)(postcss@8.4.38)(typescript@5.4.5)': dependencies: - '@parcel/bundler-default': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/compressor-raw': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/bundler-default': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/compressor-raw': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/core': 2.12.0(@swc/helpers@0.5.11) - '@parcel/namer-default': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/optimizer-css': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/optimizer-htmlnano': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)(postcss@8.4.38)(typescript@5.4.5) - '@parcel/optimizer-image': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/optimizer-svgo': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/namer-default': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/optimizer-css': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/optimizer-htmlnano': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(postcss@8.4.38)(typescript@5.4.5) + '@parcel/optimizer-image': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/optimizer-svgo': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/optimizer-swc': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/packager-css': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/packager-html': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/packager-js': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/packager-raw': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/packager-svg': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/packager-wasm': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/reporter-dev-server': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/resolver-default': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/runtime-browser-hmr': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/runtime-js': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/runtime-react-refresh': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/runtime-service-worker': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-babel': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-css': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-html': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-image': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/packager-css': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/packager-html': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/packager-js': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/packager-raw': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/packager-svg': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/packager-wasm': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/reporter-dev-server': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/resolver-default': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/runtime-browser-hmr': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/runtime-js': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/runtime-react-refresh': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/runtime-service-worker': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-babel': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-css': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-html': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-image': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/transformer-js': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) - '@parcel/transformer-json': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-postcss': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-posthtml': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-raw': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-react-refresh-wrap': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/transformer-svg': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/transformer-json': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-postcss': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-posthtml': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-raw': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-react-refresh-wrap': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/transformer-svg': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@swc/helpers' - cssnano @@ -6366,13 +6515,13 @@ snapshots: '@parcel/graph': 3.2.0 '@parcel/logger': 2.12.0 '@parcel/package-manager': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/profiler': 2.12.0 '@parcel/rust': 2.12.0 '@parcel/source-map': 2.1.1 '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) abortcontroller-polyfill: 1.7.5 base-x: 3.0.9 browserslist: 4.23.0 @@ -6400,7 +6549,7 @@ snapshots: '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 '@parcel/watcher': 2.4.1 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@swc/helpers' @@ -6417,14 +6566,13 @@ snapshots: dependencies: chalk: 4.1.2 - '@parcel/namer-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/namer-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/node-resolver-core@3.3.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: @@ -6438,10 +6586,10 @@ snapshots: transitivePeerDependencies: - '@parcel/core' - '@parcel/optimizer-css@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/optimizer-css@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/source-map': 2.1.1 '@parcel/utils': 2.12.0 browserslist: 4.23.0 @@ -6449,18 +6597,16 @@ snapshots: nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/optimizer-htmlnano@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)(postcss@8.4.38)(typescript@5.4.5)': + '@parcel/optimizer-htmlnano@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(postcss@8.4.38)(typescript@5.4.5)': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) htmlnano: 2.1.1(postcss@8.4.38)(svgo@2.8.0)(typescript@5.4.5) nullthrows: 1.1.1 posthtml: 0.16.6 svgo: 2.8.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - cssnano - postcss - purgecss @@ -6470,31 +6616,28 @@ snapshots: - typescript - uncss - '@parcel/optimizer-image@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/optimizer-image@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/core': 2.12.0(@swc/helpers@0.5.11) '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 '@parcel/utils': 2.12.0 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - transitivePeerDependencies: - - '@swc/helpers' + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) - '@parcel/optimizer-svgo@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/optimizer-svgo@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 svgo: 2.8.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/optimizer-swc@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/source-map': 2.1.1 '@parcel/utils': 2.12.0 '@swc/core': 1.5.7(@swc/helpers@0.5.11) @@ -6512,39 +6655,37 @@ snapshots: '@parcel/node-resolver-core': 3.3.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@swc/core': 1.5.7(@swc/helpers@0.5.11) semver: 7.6.2 transitivePeerDependencies: - '@swc/helpers' - '@parcel/packager-css@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-css@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/source-map': 2.1.1 '@parcel/utils': 2.12.0 lightningcss: 1.24.1 nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/packager-html@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-html@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 nullthrows: 1.1.1 posthtml: 0.16.6 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/packager-js@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-js@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 '@parcel/source-map': 2.1.1 '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) @@ -6553,46 +6694,40 @@ snapshots: nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/packager-raw-url@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-raw-url@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/packager-raw@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-raw@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/packager-svg@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-svg@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 posthtml: 0.16.6 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/packager-wasm@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/packager-wasm@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/plugin@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/plugin@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/profiler@2.12.0': dependencies: @@ -6600,79 +6735,71 @@ snapshots: '@parcel/events': 2.12.0 chrome-trace-event: 1.0.3 - '@parcel/reporter-cli@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/reporter-cli@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 chalk: 4.1.2 term-size: 2.2.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/reporter-dev-server@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/reporter-dev-server@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/reporter-tracer@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/reporter-tracer@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 chrome-trace-event: 1.0.3 nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/resolver-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/resolver-default@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/node-resolver-core': 3.3.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/runtime-browser-hmr@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/runtime-browser-hmr@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/runtime-js@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/runtime-js@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/runtime-react-refresh@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/runtime-react-refresh@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 react-error-overlay: 6.0.9 react-refresh: 0.9.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/runtime-service-worker@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/runtime-service-worker@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/rust@2.12.0': {} @@ -6680,10 +6807,10 @@ snapshots: dependencies: detect-libc: 1.0.3 - '@parcel/transformer-babel@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-babel@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/source-map': 2.1.1 '@parcel/utils': 2.12.0 browserslist: 4.23.0 @@ -6692,12 +6819,11 @@ snapshots: semver: 7.6.2 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-css@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-css@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/source-map': 2.1.1 '@parcel/utils': 2.12.0 browserslist: 4.23.0 @@ -6705,12 +6831,11 @@ snapshots: nullthrows: 1.1.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-html@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-html@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 nullthrows: 1.1.1 posthtml: 0.16.6 @@ -6720,45 +6845,41 @@ snapshots: srcset: 4.0.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-image@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-image@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/core': 2.12.0(@swc/helpers@0.5.11) - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) nullthrows: 1.1.1 - transitivePeerDependencies: - - '@swc/helpers' '@parcel/transformer-js@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/core': 2.12.0(@swc/helpers@0.5.11) '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 '@parcel/source-map': 2.1.1 '@parcel/utils': 2.12.0 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@swc/helpers': 0.5.11 browserslist: 4.23.0 nullthrows: 1.1.1 regenerator-runtime: 0.13.11 semver: 7.6.2 - '@parcel/transformer-json@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-json@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) json5: 2.2.3 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-postcss@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-postcss@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 '@parcel/utils': 2.12.0 clone: 2.1.2 @@ -6767,11 +6888,10 @@ snapshots: semver: 7.6.2 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-posthtml@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-posthtml@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 nullthrows: 1.1.1 posthtml: 0.16.6 @@ -6780,37 +6900,33 @@ snapshots: semver: 7.6.2 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-raw@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-raw@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-react-refresh-wrap@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-react-refresh-wrap@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 react-refresh: 0.9.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-sass@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-sass@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/source-map': 2.1.1 sass: 1.77.1 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-svg@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-svg@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/rust': 2.12.0 nullthrows: 1.1.1 posthtml: 0.16.6 @@ -6819,17 +6935,15 @@ snapshots: semver: 7.6.2 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' - '@parcel/transformer-webmanifest@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/transformer-webmanifest@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@mischnic/json-sourcemap': 0.1.1 '@parcel/diagnostic': 2.12.0 - '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/plugin': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 transitivePeerDependencies: - '@parcel/core' - - '@swc/helpers' '@parcel/types@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': dependencies: @@ -6838,7 +6952,7 @@ snapshots: '@parcel/fs': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/package-manager': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/source-map': 2.1.1 - '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/workers': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) utility-types: 3.11.0 transitivePeerDependencies: - '@parcel/core' @@ -6916,7 +7030,7 @@ snapshots: '@parcel/watcher-win32-ia32': 2.4.1 '@parcel/watcher-win32-x64': 2.4.1 - '@parcel/workers@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11)': + '@parcel/workers@2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))': dependencies: '@parcel/core': 2.12.0(@swc/helpers@0.5.11) '@parcel/diagnostic': 2.12.0 @@ -6925,8 +7039,6 @@ snapshots: '@parcel/types': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/utils': 2.12.0 nullthrows: 1.1.1 - transitivePeerDependencies: - - '@swc/helpers' '@pkgjs/parseargs@0.11.0': optional: true @@ -8199,6 +8311,91 @@ snapshots: es6-promisify@6.1.1: {} + esbuild-android-64@0.15.18: + optional: true + + esbuild-android-arm64@0.15.18: + optional: true + + esbuild-darwin-64@0.15.18: + optional: true + + esbuild-darwin-arm64@0.15.18: + optional: true + + esbuild-freebsd-64@0.15.18: + optional: true + + esbuild-freebsd-arm64@0.15.18: + optional: true + + esbuild-linux-32@0.15.18: + optional: true + + esbuild-linux-64@0.15.18: + optional: true + + esbuild-linux-arm64@0.15.18: + optional: true + + esbuild-linux-arm@0.15.18: + optional: true + + esbuild-linux-mips64le@0.15.18: + optional: true + + esbuild-linux-ppc64le@0.15.18: + optional: true + + esbuild-linux-riscv64@0.15.18: + optional: true + + esbuild-linux-s390x@0.15.18: + optional: true + + esbuild-netbsd-64@0.15.18: + optional: true + + esbuild-openbsd-64@0.15.18: + optional: true + + esbuild-sunos-64@0.15.18: + optional: true + + esbuild-windows-32@0.15.18: + optional: true + + esbuild-windows-64@0.15.18: + optional: true + + esbuild-windows-arm64@0.15.18: + optional: true + + esbuild@0.15.18: + optionalDependencies: + '@esbuild/android-arm': 0.15.18 + '@esbuild/linux-loong64': 0.15.18 + esbuild-android-64: 0.15.18 + esbuild-android-arm64: 0.15.18 + esbuild-darwin-64: 0.15.18 + esbuild-darwin-arm64: 0.15.18 + esbuild-freebsd-64: 0.15.18 + esbuild-freebsd-arm64: 0.15.18 + esbuild-linux-32: 0.15.18 + esbuild-linux-64: 0.15.18 + esbuild-linux-arm: 0.15.18 + esbuild-linux-arm64: 0.15.18 + esbuild-linux-mips64le: 0.15.18 + esbuild-linux-ppc64le: 0.15.18 + esbuild-linux-riscv64: 0.15.18 + esbuild-linux-s390x: 0.15.18 + esbuild-netbsd-64: 0.15.18 + esbuild-openbsd-64: 0.15.18 + esbuild-sunos-64: 0.15.18 + esbuild-windows-32: 0.15.18 + esbuild-windows-64: 0.15.18 + esbuild-windows-arm64: 0.15.18 + esbuild@0.19.11: optionalDependencies: '@esbuild/aix-ppc64': 0.19.11 @@ -10209,9 +10406,9 @@ snapshots: '@parcel/fs': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) '@parcel/logger': 2.12.0 '@parcel/package-manager': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/reporter-cli': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/reporter-dev-server': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) - '@parcel/reporter-tracer': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11))(@swc/helpers@0.5.11) + '@parcel/reporter-cli': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/reporter-dev-server': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) + '@parcel/reporter-tracer': 2.12.0(@parcel/core@2.12.0(@swc/helpers@0.5.11)) '@parcel/utils': 2.12.0 chalk: 4.1.2 commander: 7.2.0 @@ -11199,6 +11396,10 @@ snapshots: tslib@2.6.2: {} + tsm@2.3.0: + dependencies: + esbuild: 0.15.18 + tsutils@3.21.0(typescript@5.4.5): dependencies: tslib: 1.14.1