array( 'label' => $i18n['serif'], 'stack' => 'Georgia,Times,"Times New Roman",serif', ), 'sans-serif' => array( 'label' => $i18n['sans-serif'], 'stack' => 'Helvetica,Arial,sans-serif', ), 'monospace' => array( 'label' => $i18n['monospace'], 'stack' => 'Monaco,"Lucida Sans Typewriter","Lucida Typewriter","Courier New",Courier,monospace', ), ); return apply_filters( 'kirki/fonts/standard_fonts', $standard_fonts ); } /** * Return an array of backup fonts based on the font-category * * @return array */ public static function get_backup_fonts() { $backup_fonts = array( 'sans-serif' => 'Helvetica, Arial, sans-serif', 'serif' => 'Georgia, serif', 'display' => '"Comic Sans MS", cursive, sans-serif', 'handwriting' => '"Comic Sans MS", cursive, sans-serif', 'monospace' => '"Lucida Console", Monaco, monospace', ); return apply_filters( 'kirki/fonts/backup_fonts', $backup_fonts ); } /** * Return an array of all available Google Fonts. * * @return array All Google Fonts. */ public static function get_google_fonts() { if ( null === self::$google_fonts || empty( self::$google_fonts ) ) { $fonts = include wp_normalize_path( Kirki::$path . '/includes/webfonts.php' ); $google_fonts = array(); if ( is_array( $fonts ) ) { foreach ( $fonts['items'] as $font ) { $google_fonts[ $font['family'] ] = array( 'label' => $font['family'], 'variants' => $font['variants'], 'subsets' => $font['subsets'], 'category' => $font['category'], ); } } self::$google_fonts = apply_filters( 'kirki/fonts/google_fonts', $google_fonts ); } return self::$google_fonts; } /** * Dummy function to avoid issues with backwards-compatibility. * This is not functional, but it will prevent PHP Fatal errors. * * @static * @access public */ public static function get_google_font_uri() {} /** * Returns an array of all available subsets. * * @static * @access public * @return array */ public static function get_google_font_subsets() { $i18n = Kirki_l10n::get_strings(); return array( // 'all' => $i18n['all'], 'cyrillic' => $i18n['cyrillic'], 'cyrillic-ext' => $i18n['cyrillic-ext'], 'devanagari' => $i18n['devanagari'], 'greek' => $i18n['greek'], 'greek-ext' => $i18n['greek-ext'], 'khmer' => $i18n['khmer'], // 'latin' => $i18n['latin'], 'latin-ext' => $i18n['latin-ext'], 'vietnamese' => $i18n['vietnamese'], 'hebrew' => $i18n['hebrew'], 'arabic' => $i18n['arabic'], 'bengali' => $i18n['bengali'], 'gujarati' => $i18n['gujarati'], 'tamil' => $i18n['tamil'], 'telugu' => $i18n['telugu'], 'thai' => $i18n['thai'], ); } /** * Returns an array of all available variants. * * @static * @access public * @return array */ public static function get_all_variants() { $i18n = Kirki_l10n::get_strings(); return array( '100' => $i18n['ultra-light'], '100italic' => $i18n['ultra-light-italic'], '200' => $i18n['light'], '200italic' => $i18n['light-italic'], '300' => $i18n['book'], '300italic' => $i18n['book-italic'], 'regular' => $i18n['regular'], 'italic' => $i18n['italic'], '500' => $i18n['medium'], '500italic' => $i18n['medium-italic'], '600' => $i18n['semi-bold'], '600italic' => $i18n['semi-bold-italic'], '700' => $i18n['bold'], '700italic' => $i18n['bold-italic'], '800' => $i18n['extra-bold'], '800italic' => $i18n['extra-bold-italic'], '900' => $i18n['ultra-bold'], '900italic' => $i18n['ultra-bold-italic'], ); } /** * Determine if a font-name is a valid google font or not. * * @static * @access public * @param string $fontname The name of the font we want to check. * @return bool */ public static function is_google_font( $fontname ) { return ( array_key_exists( $fontname, self::$google_fonts ) ); } /** * Gets available options for a font. * * @static * @access public * @return array */ public static function get_font_choices() { $fonts = self::get_all_fonts(); $fonts_array = array(); foreach ( $fonts as $key => $args ) { $fonts_array[ $key ] = $key; } return $fonts_array; } } }