import {loadFonts} from './base';

export const getInfo = () => ({
	fontFamily: 'Gupter',
	importName: 'Gupter',
	version: 'v18',
	url: 'https://fonts.googleapis.com/css2?family=Gupter:ital,wght@0,400;0,500;0,700',
	unicodeRanges: {
		latin:
			'U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD',
	},
	fonts: {
		normal: {
			'400': {
				latin:
					'https://fonts.gstatic.com/s/gupter/v18/2-cm9JNmxJqPO1QkZpy-.woff2',
			},
			'500': {
				latin:
					'https://fonts.gstatic.com/s/gupter/v18/2-cl9JNmxJqPO1Qslb-rVc74.woff2',
			},
			'700': {
				latin:
					'https://fonts.gstatic.com/s/gupter/v18/2-cl9JNmxJqPO1Qs3bmrVc74.woff2',
			},
		},
	},
	subsets: ['latin'],
});

export const fontFamily = 'Gupter' as const;

type Variants = {
	normal: {
		weights: '400' | '500' | '700';
		subsets: 'latin';
	};
};

export const loadFont = <T extends keyof Variants>(
	style?: T,
	options?: {
		weights?: Variants[T]['weights'][];
		subsets?: Variants[T]['subsets'][];
		document?: Document;
		ignoreTooManyRequestsWarning?: boolean;
	},
) => {
	return loadFonts(getInfo(), style, options);
};
