Preload woff2 font files

This commit is contained in:
Haishan 2022-08-27 16:30:18 +08:00
parent ad8afef2e2
commit 96fc7b7998
4 changed files with 30 additions and 4 deletions

View file

@ -67,5 +67,8 @@ export async function updateProviderByName(config: ClashAPIConfig, name: string)
export async function healthcheckProviderByName(config: ClashAPIConfig, name: string) { export async function healthcheckProviderByName(config: ClashAPIConfig, name: string) {
const { url, init } = getURLAndInit(config); const { url, init } = getURLAndInit(config);
const options = { ...init, method: 'GET' }; const options = { ...init, method: 'GET' };
return await fetch(url + '/providers/proxies/' + encodeURIComponent(name) + '/healthcheck', options); return await fetch(
url + '/providers/proxies/' + encodeURIComponent(name) + '/healthcheck',
options
);
} }

View file

@ -1,6 +1,12 @@
import 'modern-normalize/modern-normalize.css'; import 'modern-normalize/modern-normalize.css';
import './misc/i18n'; import './misc/i18n';
import '@fontsource/roboto-mono/latin-400.css';
import '@fontsource/inter/latin-400.css';
import '@fontsource/inter/latin-800.css';
import inter400 from '@fontsource/inter/files/inter-latin-400-normal.woff2';
import inter800 from '@fontsource/inter/files/inter-latin-800-normal.woff2';
import robotoMono400 from '@fontsource/roboto-mono/files/roboto-mono-latin-400-normal.woff2';
import * as React from 'react'; import * as React from 'react';
import { createRoot } from 'react-dom/client'; import { createRoot } from 'react-dom/client';
import Modal from 'react-modal'; import Modal from 'react-modal';
@ -8,9 +14,28 @@ import Modal from 'react-modal';
import Root from './components/Root'; import Root from './components/Root';
import * as swRegistration from './swRegistration'; import * as swRegistration from './swRegistration';
init();
const rootEl = document.getElementById('app'); const rootEl = document.getElementById('app');
const root = createRoot(rootEl); const root = createRoot(rootEl);
function insertLinkElement(href: string) {
const l = document.createElement('link');
l.href = href;
l.rel = 'preload';
l.as = 'font';
l.crossOrigin = '';
document.head.appendChild(l);
}
function init() {
// preload woff2 font files
insertLinkElement(inter400);
insertLinkElement(inter800);
insertLinkElement(robotoMono400);
}
Modal.setAppElement(rootEl); Modal.setAppElement(rootEl);
root.render( root.render(

View file

@ -1,7 +1,4 @@
import './Root.scss'; import './Root.scss';
import '@fontsource/roboto-mono/latin-400.css';
import '@fontsource/inter/latin-400.css';
import '@fontsource/inter/latin-800.css';
import { QueryClientProvider } from '@tanstack/react-query'; import { QueryClientProvider } from '@tanstack/react-query';
import * as React from 'react'; import * as React from 'react';

1
src/custom.d.ts vendored
View file

@ -10,6 +10,7 @@ declare module '*.module.scss' {
const classes: { [key: string]: string }; const classes: { [key: string]: string };
export default classes; export default classes;
} }
declare module '*.woff2';
interface Window { interface Window {
i18n: any; i18n: any;