import {loadFonts} from './base';

export const getInfo = () => ({
	fontFamily: 'Zain',
	importName: 'Zain',
	version: 'v4',
	url: 'https://fonts.googleapis.com/css2?family=Zain:ital,wght@0,200;0,300;0,400;0,700;0,800;0,900;1,300;1,400',
	unicodeRanges: {
		arabic:
			'U+0600-06FF, U+0750-077F, U+0870-088E, U+0890-0891, U+0897-08E1, U+08E3-08FF, U+200C-200E, U+2010-2011, U+204F, U+2E41, U+FB50-FDFF, U+FE70-FE74, U+FE76-FEFC, U+102E0-102FB, U+10E60-10E7E, U+10EC2-10EC4, U+10EFC-10EFF, U+1EE00-1EE03, U+1EE05-1EE1F, U+1EE21-1EE22, U+1EE24, U+1EE27, U+1EE29-1EE32, U+1EE34-1EE37, U+1EE39, U+1EE3B, U+1EE42, U+1EE47, U+1EE49, U+1EE4B, U+1EE4D-1EE4F, U+1EE51-1EE52, U+1EE54, U+1EE57, U+1EE59, U+1EE5B, U+1EE5D, U+1EE5F, U+1EE61-1EE62, U+1EE64, U+1EE67-1EE6A, U+1EE6C-1EE72, U+1EE74-1EE77, U+1EE79-1EE7C, U+1EE7E, U+1EE80-1EE89, U+1EE8B-1EE9B, U+1EEA1-1EEA3, U+1EEA5-1EEA9, U+1EEAB-1EEBB, U+1EEF0-1EEF1',
		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: {
		italic: {
			'300': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/sykx-y9lm7soMND1OSiH_PLAnlQ.woff2',
				latin:
					'https://fonts.gstatic.com/s/zain/v4/sykx-y9lm7soMND1OSiH-fLA.woff2',
			},
			'400': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/syky-y9lm7soMND9lwqSxtM.woff2',
				latin: 'https://fonts.gstatic.com/s/zain/v4/syky-y9lm7soMND9kgqS.woff2',
			},
		},
		normal: {
			'200': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOBrshSi3--rE.woff2',
				latin:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOBrshS23-w.woff2',
			},
			'300': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOH7vhSi3--rE.woff2',
				latin:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOH7vhS23-w.woff2',
			},
			'400': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/syk8-y9lm7soMNDNkBKW.woff2',
				latin: 'https://fonts.gstatic.com/s/zain/v4/syk8-y9lm7soMNXNkA.woff2',
			},
			'700': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOG7ohSi3--rE.woff2',
				latin:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOG7ohS23-w.woff2',
			},
			'800': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOHLrhSi3--rE.woff2',
				latin:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOHLrhS23-w.woff2',
			},
			'900': {
				arabic:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOFbqhSi3--rE.woff2',
				latin:
					'https://fonts.gstatic.com/s/zain/v4/sykz-y9lm7soOFbqhS23-w.woff2',
			},
		},
	},
	subsets: ['arabic', 'latin'],
});

export const fontFamily = 'Zain' as const;

type Variants = {
	italic: {
		weights: '300' | '400';
		subsets: 'arabic' | 'latin';
	};
	normal: {
		weights: '200' | '300' | '400' | '700' | '800' | '900';
		subsets: 'arabic' | '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);
};
