From ff233ba2895e99954eb7eaa49766d47ed2fc1185 Mon Sep 17 00:00:00 2001 From: Foster Hangdaan Date: Fri, 8 Nov 2024 17:42:43 -0500 Subject: [PATCH] refactor: Move deps into import map --- deno.json | 7 +++++++ deno.lock | 8 ++++++++ deps.ts | 43 ------------------------------------------- mod.ts | 7 ++++--- tests/mod.test.ts | 15 ++++++--------- tests/utils.ts | 23 +++++++++-------------- 6 files changed, 34 insertions(+), 69 deletions(-) delete mode 100644 deps.ts diff --git a/deno.json b/deno.json index c90acde..9aa47df 100644 --- a/deno.json +++ b/deno.json @@ -4,5 +4,12 @@ "tasks": { "check": "deno fmt --check && deno lint && deno check .", "test": "deno test --allow-read=. --allow-write=./tests/site/_site,./tests/__snapshots__ --deny-env" + }, + "imports": { + "@std/assert": "jsr:@std/assert@1.0.7", + "@std/path": "jsr:@std/path@1.0.8", + "@std/testing": "jsr:@std/testing@1.0.4", + "@valibot/valibot": "jsr:@valibot/valibot@0.42.1", + "lume/": "https://deno.land/x/lume@v2.4.1/" } } diff --git a/deno.lock b/deno.lock index a015b51..a6aa433 100644 --- a/deno.lock +++ b/deno.lock @@ -412,5 +412,13 @@ "https://deno.land/x/vento@v1.12.11/src/loader.ts": "c05add67f582e937ee611852075ce2cc038b5e80e3e609eef96fa5ed74a5086c", "https://deno.land/x/vento@v1.12.11/src/tokenizer.ts": "127ddad02054f63b8b646e4dfbf555e1e34e9b8dcbd58d86b3729a4de95abd27", "https://deno.land/x/vento@v1.12.11/src/transformer.ts": "587a0b107a2bd1437a3093c4c44c07e4fdf3abfaaf8e845767b69bd34a039154" + }, + "workspace": { + "dependencies": [ + "jsr:@std/assert@1.0.7", + "jsr:@std/path@1.0.8", + "jsr:@std/testing@1.0.4", + "jsr:@valibot/valibot@0.42.1" + ] } } diff --git a/deps.ts b/deps.ts deleted file mode 100644 index b6e97f8..0000000 --- a/deps.ts +++ /dev/null @@ -1,43 +0,0 @@ -/* - * Copyright 2024 Foster Hangdaan - * - * Licensed under the Apache License, Version 2.0 (the "License"); - * you may not use this file except in compliance with the License. - * You may obtain a copy of the License at - * - * http://www.apache.org/licenses/LICENSE-2.0 - * - * Unless required by applicable law or agreed to in writing, software - * distributed under the License is distributed on an "AS IS" BASIS, - * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. - * See the License for the specific language governing permissions and - * limitations under the License. - */ - -// Lume -export { - default as LumeSite, - type SiteOptions as LumeSiteOptions, -} from "https://deno.land/x/lume@v2.4.1/core/site.ts"; -export { - default as lume, - type PluginOptions as LumePluginOptions, -} from "https://deno.land/x/lume@v2.4.1/mod.ts"; -export { - type DeepPartial as LumeDeepPartial, -} from "https://deno.land/x/lume@v2.4.1/core/utils/object.ts"; -export { - type Writer as LumeWriter, -} from "https://deno.land/x/lume@v2.4.1/core/writer.ts"; - -// STD Assert -export { assertExists, assertInstanceOf } from "jsr:@std/assert@1.0.7"; - -// STD Testing -export { assertSnapshot } from "jsr:@std/testing@1.0.4/snapshot"; - -// STD Path -export { fromFileUrl, join } from "jsr:@std/path@1.0.8"; - -// Valibot -export * as valibot from "jsr:@valibot/valibot@0.42.1"; diff --git a/mod.ts b/mod.ts index 1683c75..4a2c83c 100644 --- a/mod.ts +++ b/mod.ts @@ -14,8 +14,9 @@ * limitations under the License. */ +import * as v from "@valibot/valibot"; +import Site from "lume/core/site.ts"; import diagrams from "./resources/diagrams.json" with { type: "json" }; -import { LumeSite, valibot as v } from "./deps.ts"; import { deflateSync } from "node:zlib"; const textEncoder = new TextEncoder(); @@ -66,10 +67,10 @@ const OptionsSchema = v.optional( export type Options = v.InferInput; -export default function (options?: Options): (site: LumeSite) => void { +export default function (options?: Options): (site: Site) => void { const opts = v.parse(OptionsSchema, options); - return (site: LumeSite) => { + return (site: Site) => { site.process([".html"], (pages) => { pages.forEach((page) => { diagrams.forEach((diagram) => { diff --git a/tests/mod.test.ts b/tests/mod.test.ts index ed44014..cb44f94 100644 --- a/tests/mod.test.ts +++ b/tests/mod.test.ts @@ -15,13 +15,10 @@ */ import mod from "../mod.ts"; +import { ValiError } from "@valibot/valibot"; +import { assertExists, assertInstanceOf } from "@std/assert"; +import { assertSnapshot } from "@std/testing/snapshot"; import { getSite } from "./utils.ts"; -import { - assertExists, - assertInstanceOf, - assertSnapshot, - valibot, -} from "../deps.ts"; Deno.test("Error thrown on invalid options", async (t) => { await t.step("Invalid server", () => { @@ -32,7 +29,7 @@ Deno.test("Error thrown on invalid options", async (t) => { error = err; } assertExists(error); - assertInstanceOf(error, valibot.ValiError); + assertInstanceOf(error, ValiError); }); await t.step("Invalid enabledDiagrams", () => { @@ -43,7 +40,7 @@ Deno.test("Error thrown on invalid options", async (t) => { error = err; } assertExists(error); - assertInstanceOf(error, valibot.ValiError); + assertInstanceOf(error, ValiError); }); await t.step("Invalid format", () => { @@ -55,7 +52,7 @@ Deno.test("Error thrown on invalid options", async (t) => { error = err; } assertExists(error); - assertInstanceOf(error, valibot.ValiError); + assertInstanceOf(error, ValiError); }); }); diff --git a/tests/utils.ts b/tests/utils.ts index f2f22ca..c5f20c1 100644 --- a/tests/utils.ts +++ b/tests/utils.ts @@ -14,20 +14,15 @@ * limitations under the License. */ -import { - fromFileUrl, - join, - lume, - type LumeDeepPartial, - type LumePluginOptions, - LumeSite, - type LumeSiteOptions, - type LumeWriter, -} from "../deps.ts"; +import Site, { SiteOptions } from "lume/core/site.ts"; +import lume, { PluginOptions } from "lume/mod.ts"; +import { DeepPartial } from "lume/core/utils/object.ts"; +import { Writer } from "lume/core/writer.ts"; +import { fromFileUrl, join } from "@std/path"; const cwd = fromFileUrl(import.meta.resolve("./")); -class TestWriter implements LumeWriter { +class TestWriter implements Writer { savePages() { return Promise.resolve([]); } @@ -46,9 +41,9 @@ class TestWriter implements LumeWriter { } export function getSite( - siteOptions: LumeDeepPartial = {}, - pluginOptions: LumePluginOptions = {}, -): LumeSite { + siteOptions: DeepPartial = {}, + pluginOptions: PluginOptions = {}, +): Site { siteOptions.cwd = join(cwd, "site"); const site = lume(