functions.php 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492
  1. <?php
  2. /**
  3. * Seedlet functions and definitions
  4. *
  5. * @link https://developer.wordpress.org/themes/basics/theme-functions/
  6. *
  7. * @package Seedlet
  8. * @since 1.1.0
  9. */
  10. /**
  11. * seedlet only works in WordPress 4.7 or later.
  12. */
  13. if ( version_compare( $GLOBALS['wp_version'], '4.7', '<' ) ) {
  14. require get_template_directory() . '/inc/back-compat.php';
  15. return;
  16. }
  17. if ( ! function_exists( 'seedlet_setup' ) ) :
  18. /**
  19. * Sets up theme defaults and registers support for various WordPress features.
  20. *
  21. * Note that this function is hooked into the after_setup_theme hook, which
  22. * runs before the init hook. The init hook is too late for some features, such
  23. * as indicating support for post thumbnails.
  24. */
  25. function seedlet_setup() {
  26. /*
  27. * Make theme available for translation.
  28. * Translations can be filed in the /languages/ directory.
  29. * If you're building a theme based on seedlet, use a find and replace
  30. * to change 'seedlet' to the name of your theme in all the template files.
  31. */
  32. load_theme_textdomain( 'seedlet', get_template_directory() . '/languages' );
  33. // Add default posts and comments RSS feed links to head.
  34. add_theme_support( 'automatic-feed-links' );
  35. /*
  36. * Let WordPress manage the document title.
  37. * By adding theme support, we declare that this theme does not use a
  38. * hard-coded <title> tag in the document head, and expect WordPress to
  39. * provide it for us.
  40. */
  41. add_theme_support( 'title-tag' );
  42. /*
  43. * Enable support for Post Thumbnails on posts and pages.
  44. *
  45. * @link https://developer.wordpress.org/themes/functionality/featured-images-post-thumbnails/
  46. */
  47. add_theme_support( 'post-thumbnails' );
  48. set_post_thumbnail_size( 1568, 9999 );
  49. // This theme uses wp_nav_menu() in two locations.
  50. register_nav_menus(
  51. array(
  52. 'primary' => __( 'Primary Navigation', 'seedlet' ),
  53. 'footer' => __( 'Footer Navigation', 'seedlet' ),
  54. 'social' => __( 'Social Links Navigation', 'seedlet' ),
  55. )
  56. );
  57. /*
  58. * Switch default core markup for search form, comment form, and comments
  59. * to output valid HTML5.
  60. */
  61. add_theme_support(
  62. 'html5',
  63. array(
  64. 'search-form',
  65. 'comment-form',
  66. 'comment-list',
  67. 'gallery',
  68. 'caption',
  69. 'style',
  70. 'script',
  71. 'navigation-widgets',
  72. )
  73. );
  74. /**
  75. * Add support for core custom logo.
  76. *
  77. * @link https://codex.wordpress.org/Theme_Logo
  78. */
  79. add_theme_support(
  80. 'custom-logo',
  81. array(
  82. 'height' => 240,
  83. 'width' => 240,
  84. 'flex-width' => false,
  85. 'flex-height' => false,
  86. )
  87. );
  88. // Add theme support for selective refresh for widgets.
  89. add_theme_support( 'customize-selective-refresh-widgets' );
  90. // Add support for Block Styles.
  91. add_theme_support( 'wp-block-styles' );
  92. // Add support for full and wide align images.
  93. add_theme_support( 'align-wide' );
  94. // Add support for editor styles.
  95. add_theme_support( 'editor-styles' );
  96. $editor_stylesheet_path = './assets/css/style-editor.css';
  97. // Note, the is_IE global variable is defined by WordPress and is used
  98. // to detect if the current browser is internet explorer.
  99. global $is_IE;
  100. if ( $is_IE ) {
  101. $editor_stylesheet_path = './assets/css/ie-editor.css';
  102. }
  103. // Enqueue editor styles.
  104. add_editor_style(
  105. array(
  106. seedlet_fonts_url(),
  107. $editor_stylesheet_path,
  108. )
  109. );
  110. // Add custom editor font sizes.
  111. add_theme_support(
  112. 'editor-font-sizes',
  113. array(
  114. array(
  115. 'name' => __( 'Tiny', 'seedlet' ),
  116. 'shortName' => __( 'XS', 'seedlet' ),
  117. 'size' => 14,
  118. 'slug' => 'tiny',
  119. ),
  120. array(
  121. 'name' => __( 'Small', 'seedlet' ),
  122. 'shortName' => __( 'S', 'seedlet' ),
  123. 'size' => 16,
  124. 'slug' => 'small',
  125. ),
  126. array(
  127. 'name' => __( 'Normal', 'seedlet' ),
  128. 'shortName' => __( 'M', 'seedlet' ),
  129. 'size' => 18,
  130. 'slug' => 'normal',
  131. ),
  132. array(
  133. 'name' => __( 'Large', 'seedlet' ),
  134. 'shortName' => __( 'L', 'seedlet' ),
  135. 'size' => 24,
  136. 'slug' => 'large',
  137. ),
  138. array(
  139. 'name' => __( 'Huge', 'seedlet' ),
  140. 'shortName' => __( 'XL', 'seedlet' ),
  141. 'size' => 28,
  142. 'slug' => 'huge',
  143. ),
  144. )
  145. );
  146. // Editor color palette.
  147. $colors_theme_mod = get_theme_mod( 'custom_colors_active' );
  148. $primary = ( ! empty( $colors_theme_mod ) && 'default' === $colors_theme_mod || empty( get_theme_mod( 'seedlet_--global--color-primary' ) ) ) ? '#000000' : get_theme_mod( 'seedlet_--global--color-primary' );
  149. $secondary = ( ! empty( $colors_theme_mod ) && 'default' === $colors_theme_mod || empty( get_theme_mod( 'seedlet_--global--color-secondary' ) ) ) ? '#3C8067' : get_theme_mod( 'seedlet_--global--color-secondary' );
  150. $foreground = ( ! empty( $colors_theme_mod ) && 'default' === $colors_theme_mod || empty( get_theme_mod( 'seedlet_--global--color-foreground' ) ) ) ? '#333333' : get_theme_mod( 'seedlet_--global--color-foreground' );
  151. $tertiary = ( ! empty( $colors_theme_mod ) && 'default' === $colors_theme_mod || empty( get_theme_mod( 'seedlet_--global--color-tertiary' ) ) ) ? '#FAFBF6' : get_theme_mod( 'seedlet_--global--color-tertiary' );
  152. $background = ( ! empty( $colors_theme_mod ) && 'default' === $colors_theme_mod || empty( get_theme_mod( 'seedlet_--global--color-background' ) ) ) ? '#FFFFFF' : get_theme_mod( 'seedlet_--global--color-background' );
  153. add_theme_support(
  154. 'editor-color-palette',
  155. array(
  156. array(
  157. 'name' => __( 'Primary', 'seedlet' ),
  158. 'slug' => 'primary',
  159. 'color' => $primary,
  160. ),
  161. array(
  162. 'name' => __( 'Secondary', 'seedlet' ),
  163. 'slug' => 'secondary',
  164. 'color' => $secondary,
  165. ),
  166. array(
  167. 'name' => __( 'Foreground', 'seedlet' ),
  168. 'slug' => 'foreground',
  169. 'color' => $foreground,
  170. ),
  171. array(
  172. 'name' => __( 'Tertiary', 'seedlet' ),
  173. 'slug' => 'tertiary',
  174. 'color' => $tertiary,
  175. ),
  176. array(
  177. 'name' => __( 'Background', 'seedlet' ),
  178. 'slug' => 'background',
  179. 'color' => $background,
  180. ),
  181. )
  182. );
  183. $gradient_color_a = $secondary;
  184. $gradient_color_b = $tertiary;
  185. add_theme_support(
  186. 'editor-gradient-presets',
  187. array(
  188. array(
  189. 'name' => __( 'Diagonal', 'seedlet' ),
  190. 'gradient' => 'linear-gradient(to bottom right, ' . $gradient_color_a . ' 49.9%, ' . $gradient_color_b . ' 50%)',
  191. 'slug' => 'hard-diagonal',
  192. ),
  193. array(
  194. 'name' => __( 'Diagonal inverted', 'seedlet' ),
  195. 'gradient' => 'linear-gradient(to top left, ' . $gradient_color_a . ' 49.9%, ' . $gradient_color_b . ' 50%)',
  196. 'slug' => 'hard-diagonal-inverted',
  197. ),
  198. array(
  199. 'name' => __( 'Horizontal', 'seedlet' ),
  200. 'gradient' => 'linear-gradient(to bottom, ' . $gradient_color_a . ' 50%, ' . $gradient_color_b . ' 50%)',
  201. 'slug' => 'hard-horizontal',
  202. ),
  203. array(
  204. 'name' => __( 'Horizontal inverted', 'seedlet' ),
  205. 'gradient' => 'linear-gradient(to top, ' . $gradient_color_a . ' 50%, ' . $gradient_color_b . ' 50%)',
  206. 'slug' => 'hard-horizontal-inverted',
  207. ),
  208. array(
  209. 'name' => __( 'Diagonal gradient', 'seedlet' ),
  210. 'gradient' => 'linear-gradient(to bottom right, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  211. 'slug' => 'diagonal',
  212. ),
  213. array(
  214. 'name' => __( 'Diagonal inverted gradient', 'seedlet' ),
  215. 'gradient' => 'linear-gradient(to top left, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  216. 'slug' => 'diagonal-inverted',
  217. ),
  218. array(
  219. 'name' => __( 'Horizontal gradient', 'seedlet' ),
  220. 'gradient' => 'linear-gradient(to bottom, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  221. 'slug' => 'horizontal',
  222. ),
  223. array(
  224. 'name' => __( 'Horizontal inverted gradient', 'seedlet' ),
  225. 'gradient' => 'linear-gradient(to top, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  226. 'slug' => 'horizontal-inverted',
  227. ),
  228. array(
  229. 'name' => __( 'Stripe', 'seedlet' ),
  230. 'gradient' => 'linear-gradient(to bottom, transparent 20%, ' . $gradient_color_a . ' 20%, ' . $gradient_color_a . ' 80%, transparent 80%)',
  231. 'slug' => 'stripe',
  232. ),
  233. )
  234. );
  235. // Add support for responsive embedded content.
  236. add_theme_support( 'responsive-embeds' );
  237. // Add support for custom line height controls.
  238. add_theme_support( 'custom-line-height' );
  239. // Add support for experimental link color control.
  240. add_theme_support( 'experimental-link-color' );
  241. // Add support for experimental cover block spacing.
  242. add_theme_support( 'experimental-custom-spacing' );
  243. // Add support for custom units.
  244. add_theme_support( 'custom-units' );
  245. // Add support for WordPress.com Global Styles.
  246. add_theme_support(
  247. 'jetpack-global-styles',
  248. array(
  249. 'enable_theme_default' => true,
  250. )
  251. );
  252. }
  253. endif;
  254. add_action( 'after_setup_theme', 'seedlet_setup' );
  255. /**
  256. * Add Google webfonts, if necessary
  257. *
  258. * - See: http://themeshaper.com/2014/08/13/how-to-add-google-fonts-to-wordpress-themes/
  259. */
  260. function seedlet_fonts_url() {
  261. $fonts_url = '';
  262. /* Translators: If there are characters in your language that are not
  263. * supported by Fira Sans, translate this to 'off'. Do not translate
  264. * into your own language.
  265. */
  266. $fira_sans = esc_html_x( 'on', 'Fira Sans: on or off', 'seedlet' );
  267. /* Translators: If there are characters in your language that are not
  268. * supported by Playfair Display, translate this to 'off'. Do not translate
  269. * into your own language.
  270. */
  271. $playfair_display = esc_html_x( 'on', 'Playfair Display: on or off', 'seedlet' );
  272. if ( 'off' !== $fira_sans || 'off' !== $playfair_display ) {
  273. $font_families = array();
  274. if ( 'off' !== $fira_sans ) {
  275. $font_families[] = 'Fira Sans:ital,wght@0,400;0,500;1,400';
  276. }
  277. if ( 'off' !== $playfair_display ) {
  278. $font_families[] = 'Playfair Display:ital,wght@0,400;0,700;1,400';
  279. }
  280. $query_args = array(
  281. 'family' => urlencode( implode( '|', $font_families ) ),
  282. 'subset' => urlencode( 'latin,latin-ext' ),
  283. );
  284. $fonts_url = add_query_arg( $query_args, 'https://fonts.googleapis.com/css' );
  285. }
  286. return esc_url_raw( $fonts_url );
  287. }
  288. /**
  289. * Register widget area.
  290. *
  291. * @link https://developer.wordpress.org/themes/functionality/sidebars/#registering-a-sidebar
  292. */
  293. function seedlet_widgets_init() {
  294. register_sidebar(
  295. array(
  296. 'name' => __( 'Footer', 'seedlet' ),
  297. 'id' => 'sidebar-1',
  298. 'description' => __( 'Add widgets here to appear in your footer.', 'seedlet' ),
  299. 'before_widget' => '<section id="%1$s" class="widget %2$s">',
  300. 'after_widget' => '</section>',
  301. 'before_title' => '<h2 class="widget-title">',
  302. 'after_title' => '</h2>',
  303. )
  304. );
  305. }
  306. add_action( 'widgets_init', 'seedlet_widgets_init' );
  307. /**
  308. * Set the content width in pixels, based on the theme's design and stylesheet.
  309. *
  310. * Priority 0 to make it available to lower priority callbacks.
  311. *
  312. * @global int $content_width Content width.
  313. */
  314. function seedlet_content_width() {
  315. // This variable is intended to be overruled from themes.
  316. // Open WPCS issue: {@link https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards/issues/1043}.
  317. // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound
  318. $GLOBALS['content_width'] = apply_filters( 'seedlet_content_width', 620 );
  319. }
  320. add_action( 'after_setup_theme', 'seedlet_content_width', 0 );
  321. /**
  322. * Enqueue scripts and styles.
  323. */
  324. function seedlet_scripts() {
  325. // Enqueue Google fonts
  326. wp_enqueue_style( 'seedlet-fonts', seedlet_fonts_url(), array(), null );
  327. // Theme styles
  328. wp_enqueue_style( 'seedlet-style', get_template_directory_uri() . '/style.css', array(), wp_get_theme()->get( 'Version' ) );
  329. // Navigation styles
  330. wp_enqueue_style( 'seedlet-style-navigation', get_template_directory_uri() . '/assets/css/style-navigation.css', array(), wp_get_theme()->get( 'Version' ) );
  331. // RTL styles
  332. wp_style_add_data( 'seedlet-style', 'rtl', 'replace' );
  333. wp_style_add_data( 'seedlet-style-navigation', 'rtl', 'replace' );
  334. // Print styles
  335. wp_enqueue_style( 'seedlet-print-style', get_template_directory_uri() . '/assets/css/print.css', array(), wp_get_theme()->get( 'Version' ), 'print' );
  336. // Threaded comment reply styles
  337. if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) {
  338. wp_enqueue_script( 'comment-reply' );
  339. }
  340. // Main navigation scripts
  341. wp_enqueue_script( 'seedlet-primary-navigation-script', get_template_directory_uri() . '/assets/js/primary-navigation.js', array(), wp_get_theme()->get( 'Version' ), true );
  342. // Note, the is_IE global variable is defined by WordPress and is used
  343. // to detect if the current browser is internet explorer.
  344. global $is_IE;
  345. if ( $is_IE ) {
  346. // If IE 11 or below, use a ponyfill to add CSS Variable support
  347. wp_register_script( 'css-vars-ponyfill', get_stylesheet_directory_uri() . '/assets/js/css-vars-ponyfill2.js' );
  348. wp_enqueue_script(
  349. 'ie11-fix',
  350. get_stylesheet_directory_uri() . '/assets/js/ie11-fix.js',
  351. array( 'css-vars-ponyfill' ),
  352. '1.0'
  353. );
  354. }
  355. }
  356. add_action( 'wp_enqueue_scripts', 'seedlet_scripts' );
  357. /**
  358. * Fix skip link focus in IE11.
  359. *
  360. * This does not enqueue the script because it is tiny and because it is only for IE11,
  361. * thus it does not warrant having an entire dedicated blocking script being loaded.
  362. *
  363. * @link https://git.io/vWdr2
  364. */
  365. function seedlet_skip_link_focus_fix() {
  366. // The following is minified via `terser --compress --mangle -- js/skip-link-focus-fix.js`.
  367. ?>
  368. <script>
  369. /(trident|msie)/i.test(navigator.userAgent)&&document.getElementById&&window.addEventListener&&window.addEventListener("hashchange",function(){var t,e=location.hash.substring(1);/^[A-z0-9_-]+$/.test(e)&&(t=document.getElementById(e))&&(/^(?:a|select|input|button|textarea)$/i.test(t.tagName)||(t.tabIndex=-1),t.focus())},!1);
  370. </script>
  371. <?php
  372. }
  373. add_action( 'wp_print_footer_scripts', 'seedlet_skip_link_focus_fix' );
  374. if ( ! function_exists( 'seedlet_author_bio' ) ) {
  375. /**
  376. * Implements the Jetpack Author bio
  377. */
  378. function seedlet_author_bio() {
  379. if ( ! function_exists( 'jetpack_author_bio' ) ) {
  380. if ( ! is_singular( 'attachment' ) ) {
  381. get_template_part( 'template-parts/post/author-bio' );
  382. }
  383. } else {
  384. jetpack_author_bio();
  385. }
  386. }
  387. }
  388. /**
  389. * SVG Icons class.
  390. */
  391. require get_template_directory() . '/classes/class-seedlet-svg-icons.php';
  392. /**
  393. * Custom colors class.
  394. */
  395. if ( ! class_exists( 'Colors_Manager' ) ) { // Check for presence of wpcom color manager to avoid duplicate color customization functionality.
  396. require get_template_directory() . '/classes/class-seedlet-custom-colors.php';
  397. }
  398. /**
  399. * Enhance the theme by hooking into WordPress.
  400. */
  401. require get_template_directory() . '/inc/template-functions.php';
  402. /**
  403. * SVG Icons related functions.
  404. */
  405. require get_template_directory() . '/inc/icon-functions.php';
  406. /**
  407. * Custom template tags for the theme.
  408. */
  409. require get_template_directory() . '/inc/template-tags.php';
  410. /**
  411. * Customizer additions.
  412. */
  413. require get_template_directory() . '/inc/customizer.php';
  414. /**
  415. * Block Patterns.
  416. */
  417. require get_template_directory() . '/inc/block-patterns.php';
  418. /**
  419. * Block Styles.
  420. */
  421. require get_template_directory() . '/inc/block-styles.php';
  422. /**
  423. * Load WooCommerce compatibility file.
  424. */
  425. if ( class_exists( 'WooCommerce' ) ) {
  426. require get_template_directory() . '/inc/woocommerce.php';
  427. }
  428. /**
  429. * Load Jetpack compatibility file.
  430. */
  431. require get_template_directory() . '/inc/jetpack.php';