Compare commits

..

No commits in common. "3c7f94cf8e2b5070415f1cc78facd1672a170ab2" and "a7dedf56408225d5ef6b7baac8f583e0a4f123f1" have entirely different histories.

4 changed files with 24 additions and 70 deletions

View file

@ -10,8 +10,7 @@
<span> <span>
Transform <a href="https://fonts.google.com/">Google Fonts</a> links to a CSS from a <a href="https://cdn.sofiaritz.com/fonts/">Google Fonts binary mirror</a>. Transform <a href="https://fonts.google.com/">Google Fonts</a> links to a CSS from a <a href="https://cdn.sofiaritz.com/fonts/">Google Fonts binary mirror</a>.
Created by <a href="https://sofiaritz.com">Sofía Aritz</a>. Created by <a href="https://sofiaritz.com">Sofía Aritz</a>.
</span><br> </span>
<span>Source code available here: <a href="https://git.sofiaritz.com/sofia/gfonts-interface">sofia/gfonts-interface@git.sofiaritz.com</a>.</span>
</header> </header>
<div class="page-container"> <div class="page-container">
<main id="app"></main> <main id="app"></main>

View file

@ -2,7 +2,7 @@
import {css2_to_cssfile} from "./lib/utils.ts"; import {css2_to_cssfile} from "./lib/utils.ts";
import PreCopy from "./lib/PreCopy.svelte"; import PreCopy from "./lib/PreCopy.svelte";
let gf_input = "https://fonts.googleapis.com/css2?family=Roboto+Mono:ital@0;1&family=Roboto:ital@0;1&display=swap" let gf_input = "https://fonts.googleapis.com/css2?family=Fira+Sans:ital,wght@0,300;1,200;1,500&family=Poppins:wght@300;400&family=Wix+Madefor+Display:wght@700&display=swap"
let mirror_input = "https://cdn.sofiaritz.com/fonts" let mirror_input = "https://cdn.sofiaritz.com/fonts"
let output = new Promise(resolve => resolve(null)) let output = new Promise(resolve => resolve(null))

View file

@ -14,11 +14,9 @@ export function parse_family(input: string): Family {
let font = rfont.replaceAll("+", "").toLowerCase() let font = rfont.replaceAll("+", "").toLowerCase()
let variants: Variant[] = [] let variants: Variant[] = []
if(rvariants != null && rvariants.length > 0) { if(rvariants != null && rvariants.length > 0) {
let rfragments = rvariants.split("@").filter(v => v.length > 0) let rfragments = rvariants.split("wght@").filter(v => v.length > 0)
let fragments let fragments
let with_weight = rfragments[0].includes("wght") if (rfragments[0].startsWith("ital")) {
let with_ital = rfragments[0].includes("ital")
if (with_ital || with_weight) {
fragments = rfragments[1] fragments = rfragments[1]
} else { } else {
fragments = rfragments[0] fragments = rfragments[0]
@ -26,7 +24,6 @@ export function parse_family(input: string): Family {
let rsubvariants = fragments.split(";") let rsubvariants = fragments.split(";")
for (let rvariant of rsubvariants) { for (let rvariant of rsubvariants) {
if (with_weight) {
if (rvariant.includes(",")) { if (rvariant.includes(",")) {
let variant = rvariant.split(",") let variant = rvariant.split(",")
variants.push({ variants.push({
@ -39,15 +36,6 @@ export function parse_family(input: string): Family {
style: "normal", style: "normal",
}) })
} }
} else if(with_ital) {
let italvariants = rvariant.split(",")
for (let variant of italvariants) {
variants.push({
weight: 400,
style: Number(variant) === 1 ? "italic" : "normal"
})
}
}
} }
} else { } else {
// TODO(sofia@git.sofiaritz.com): Is this the default value? // TODO(sofia@git.sofiaritz.com): Is this the default value?

View file

@ -28,47 +28,14 @@ function to_array(v) {
} }
} }
function font_base_url(font, folder, mirror) { function font_base_url(font, mirror) {
return `${mirror}/${folder}/${font}` return `${mirror}/ofl/${font}`
} }
async function get_font_metadata(font, mirror) { async function get_font_metadata(font, mirror) {
let base_url let response = await (await fetch(font_base_url(font, mirror) + "/METADATA.pb"))
let response .text()
// TODO(sofia@git.sofiaritz.com): Improve this re-trying logic. This feels wrong 😭
try {
base_url = font_base_url(font, "ofl", mirror)
let rresponse = await (await fetch(base_url + "/METADATA.pb"))
if (rresponse.ok) {
response = await rresponse.text()
} else {
throw new Error("Font not found.")
}
} catch (e) {
try {
base_url = font_base_url(font, "ufl", mirror)
let rresponse = await (await fetch(base_url + "/METADATA.pb"))
if (rresponse.ok) {
response = await rresponse.text()
} else {
throw new Error("Font not found.")
}
} catch (e) {
try {
base_url = font_base_url(font, "apache", mirror)
let rresponse = await (await fetch(base_url + "/METADATA.pb"))
if (rresponse.ok) {
response = await rresponse.text()
} else {
throw new Error("Font not found.")
}
} catch (e) {
console.error("Font not found.")
throw new Error(`"${font}" not found in mirror "${mirror}".`)
}
}
}
return {base_url, parsed: parse(response)} return parse(response)
} }
export async function css2_to_cssfile(css2_url, mirror): Promise<string> { export async function css2_to_cssfile(css2_url, mirror): Promise<string> {
@ -83,18 +50,18 @@ export async function css2_to_cssfile(css2_url, mirror): Promise<string> {
.map(v => v.replace("?family=", "")) .map(v => v.replace("?family=", ""))
.map(parse_family) .map(parse_family)
.map(async (v) => { .map(async (v) => {
let {base_url, parsed: metadata} = await get_font_metadata(v.font, mirror) let metadata = await get_font_metadata(v.font, mirror)
let fonts = [] let fonts = []
for (let variant of v.variants) { for (let variant of v.variants) {
let { weight, style }: Variant = variant let { weight, style }: Variant = variant
let rfonts = to_array(metadata.fonts) let rfonts = to_array(metadata.fonts)
let matched = false let matched = false
for (let font of rfonts) { for (let font of rfonts) {
if (font.weight === weight && matched === false) { if (font.weight === weight) {
if (style === "italic") { if (style === "italic") {
fonts.push({ fonts.push({
name: metadata.name, name: metadata.name,
path: base_url + "/" + font.filename, path: font_base_url(v.font, mirror) + "/" + font.filename,
weight, weight,
style, style,
}) })
@ -106,7 +73,7 @@ export async function css2_to_cssfile(css2_url, mirror): Promise<string> {
if (matched === false) { if (matched === false) {
fonts.push({ fonts.push({
name: metadata.name, name: metadata.name,
path: base_url + "/" + rfonts[0].filename, path: font_base_url(v.font, mirror) + "/" + rfonts[0].filename,
weight, weight,
style, style,
}) })