functions.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408
  1. <?php
  2. /**
  3. * Seedlet functions and definitions
  4. *
  5. * @link https://developer.wordpress.org/themes/basics/theme-functions/
  6. *
  7. * @package WordPress
  8. * @subpackage Seedlet
  9. * @since 1.0.0
  10. */
  11. /**
  12. * seedlet only works in WordPress 4.7 or later.
  13. */
  14. if ( version_compare( $GLOBALS['wp_version'], '4.7', '<' ) ) {
  15. require get_template_directory() . '/inc/back-compat.php';
  16. return;
  17. }
  18. if ( ! function_exists( 'seedlet_setup' ) ) :
  19. /**
  20. * Sets up theme defaults and registers support for various WordPress features.
  21. *
  22. * Note that this function is hooked into the after_setup_theme hook, which
  23. * runs before the init hook. The init hook is too late for some features, such
  24. * as indicating support for post thumbnails.
  25. */
  26. function seedlet_setup() {
  27. /*
  28. * Make theme available for translation.
  29. * Translations can be filed in the /languages/ directory.
  30. * If you're building a theme based on seedlet, use a find and replace
  31. * to change 'seedlet' to the name of your theme in all the template files.
  32. */
  33. load_theme_textdomain( 'seedlet', get_template_directory() . '/languages' );
  34. // Add default posts and comments RSS feed links to head.
  35. add_theme_support( 'automatic-feed-links' );
  36. /*
  37. * Let WordPress manage the document title.
  38. * By adding theme support, we declare that this theme does not use a
  39. * hard-coded <title> tag in the document head, and expect WordPress to
  40. * provide it for us.
  41. */
  42. add_theme_support( 'title-tag' );
  43. /*
  44. * Enable support for Post Thumbnails on posts and pages.
  45. *
  46. * @link https://developer.wordpress.org/themes/functionality/featured-images-post-thumbnails/
  47. */
  48. add_theme_support( 'post-thumbnails' );
  49. set_post_thumbnail_size( 1568, 9999 );
  50. // This theme uses wp_nav_menu() in two locations.
  51. register_nav_menus(
  52. array(
  53. 'primary' => __( 'Primary Navigation', 'seedlet' ),
  54. 'footer' => __( 'Footer Navigation', 'seedlet' ),
  55. 'social' => __( 'Social Links Navigation', 'seedlet' ),
  56. )
  57. );
  58. /*
  59. * Switch default core markup for search form, comment form, and comments
  60. * to output valid HTML5.
  61. */
  62. add_theme_support(
  63. 'html5',
  64. array(
  65. 'search-form',
  66. 'comment-form',
  67. 'comment-list',
  68. 'gallery',
  69. 'caption',
  70. 'style',
  71. 'script',
  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. // Enqueue editor styles.
  97. add_editor_style(
  98. array(
  99. apply_filters( 'seedlet_editor_fonts', './assets/css/fonts-editor.css' ),
  100. './assets/css/style-editor.css',
  101. )
  102. );
  103. // Add custom editor font sizes.
  104. add_theme_support(
  105. 'editor-font-sizes',
  106. array(
  107. array(
  108. 'name' => __( 'Tiny', 'seedlet' ),
  109. 'shortName' => __( 'XS', 'seedlet' ),
  110. 'size' => 14,
  111. 'slug' => 'tiny',
  112. ),
  113. array(
  114. 'name' => __( 'Small', 'seedlet' ),
  115. 'shortName' => __( 'S', 'seedlet' ),
  116. 'size' => 16,
  117. 'slug' => 'small',
  118. ),
  119. array(
  120. 'name' => __( 'Normal', 'seedlet' ),
  121. 'shortName' => __( 'M', 'seedlet' ),
  122. 'size' => 18,
  123. 'slug' => 'normal',
  124. ),
  125. array(
  126. 'name' => __( 'Large', 'seedlet' ),
  127. 'shortName' => __( 'L', 'seedlet' ),
  128. 'size' => 24,
  129. 'slug' => 'large',
  130. ),
  131. array(
  132. 'name' => __( 'Huge', 'seedlet' ),
  133. 'shortName' => __( 'XL', 'seedlet' ),
  134. 'size' => 28,
  135. 'slug' => 'huge',
  136. ),
  137. )
  138. );
  139. // Editor color palette.
  140. $colors_theme_mod = get_theme_mod( 'custom_colors_active' );
  141. $primary = ( ! empty( $colors_theme_mod ) &&
  142. 'default' === $colors_theme_mod ||
  143. empty( get_theme_mod( 'seedlet_--global--color-primary' ) ) ) ? '#000000' : get_theme_mod( 'seedlet_--global--color-primary' );
  144. $secondary = ( ! empty( $colors_theme_mod ) &&
  145. 'default' === $colors_theme_mod ||
  146. empty( get_theme_mod( 'seedlet_--global--color-secondary' ) ) ) ? '#3C8067' : get_theme_mod( 'seedlet_--global--color-secondary' );
  147. $foreground = ( ! empty( $colors_theme_mod ) &&
  148. 'default' === $colors_theme_mod ||
  149. empty( get_theme_mod( 'seedlet_--global--color-foreground' ) ) ) ? '#333333' : get_theme_mod( 'seedlet_--global--color-foreground' );
  150. $tertiary = ( ! empty( $colors_theme_mod ) &&
  151. 'default' === $colors_theme_mod ||
  152. empty( get_theme_mod( 'seedlet_--global--color-tertiary' ) ) ) ? '#FAFBF6' : get_theme_mod( 'seedlet_--global--color-tertiary' );
  153. $background = ( ! empty( $colors_theme_mod ) &&
  154. 'default' === $colors_theme_mod ||
  155. empty( get_theme_mod( 'seedlet_--global--color-background' ) ) ) ? '#FFFFFF' : get_theme_mod( 'seedlet_--global--color-background' );
  156. add_theme_support(
  157. 'editor-color-palette',
  158. array(
  159. array(
  160. 'name' => __( 'Primary', 'seedlet' ),
  161. 'slug' => 'primary',
  162. 'color' => $primary
  163. ),
  164. array(
  165. 'name' => __( 'Secondary', 'seedlet' ),
  166. 'slug' => 'secondary',
  167. 'color' => $secondary
  168. ),
  169. array(
  170. 'name' => __( 'Foreground', 'seedlet' ),
  171. 'slug' => 'foreground',
  172. 'color' => $foreground
  173. ),
  174. array(
  175. 'name' => __( 'Tertiary', 'seedlet' ),
  176. 'slug' => 'tertiary',
  177. 'color' => $tertiary
  178. ),
  179. array(
  180. 'name' => __( 'Background', 'seedlet' ),
  181. 'slug' => 'background',
  182. 'color' => $background
  183. ),
  184. )
  185. );
  186. $gradient_color_a = $secondary;
  187. $gradient_color_b = $tertiary;
  188. add_theme_support(
  189. 'editor-gradient-presets',
  190. array(
  191. array(
  192. 'name' => __( 'Diagonal', 'seedlet' ),
  193. 'gradient' => 'linear-gradient(to bottom right, ' . $gradient_color_a . ' 49.9%, ' . $gradient_color_b . ' 50%)',
  194. 'slug' => 'hard-diagonal',
  195. ),
  196. array(
  197. 'name' => __( 'Diagonal inverted', 'seedlet' ),
  198. 'gradient' => 'linear-gradient(to top left, ' . $gradient_color_a . ' 49.9%, ' . $gradient_color_b . ' 50%)',
  199. 'slug' => 'hard-diagonal-inverted',
  200. ),
  201. array(
  202. 'name' => __( 'Horizontal', 'seedlet' ),
  203. 'gradient' => 'linear-gradient(to bottom, ' . $gradient_color_a . ' 50%, ' . $gradient_color_b . ' 50%)',
  204. 'slug' => 'hard-horizontal',
  205. ),
  206. array(
  207. 'name' => __( 'Horizontal inverted', 'seedlet' ),
  208. 'gradient' => 'linear-gradient(to top, ' . $gradient_color_a . ' 50%, ' . $gradient_color_b . ' 50%)',
  209. 'slug' => 'hard-horizontal-inverted',
  210. ),
  211. array(
  212. 'name' => __( 'Diagonal gradient', 'seedlet' ),
  213. 'gradient' => 'linear-gradient(to bottom right, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  214. 'slug' => 'diagonal',
  215. ),
  216. array(
  217. 'name' => __( 'Diagonal inverted gradient', 'seedlet' ),
  218. 'gradient' => 'linear-gradient(to top left, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  219. 'slug' => 'diagonal-inverted',
  220. ),
  221. array(
  222. 'name' => __( 'Horizontal gradient', 'seedlet' ),
  223. 'gradient' => 'linear-gradient(to bottom, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  224. 'slug' => 'horizontal',
  225. ),
  226. array(
  227. 'name' => __( 'Horizontal inverted gradient', 'seedlet' ),
  228. 'gradient' => 'linear-gradient(to top, ' . $gradient_color_a . ', ' . $gradient_color_b . ')',
  229. 'slug' => 'horizontal-inverted',
  230. ),
  231. array(
  232. 'name' => __( 'Stripe', 'seedlet' ),
  233. 'gradient' => 'linear-gradient(to bottom, transparent 20%, ' . $gradient_color_a . ' 20%, ' . $gradient_color_a . ' 80%, transparent 80%)',
  234. 'slug' => 'stripe',
  235. ),
  236. )
  237. );
  238. // Add support for responsive embedded content.
  239. add_theme_support( 'responsive-embeds' );
  240. // Add support for experimental link color control.
  241. add_theme_support( 'experimental-link-color' );
  242. // Add support for WordPress.com Global Styles.
  243. add_theme_support(
  244. 'jetpack-global-styles',
  245. [
  246. 'enable_theme_default' => true,
  247. ]
  248. );
  249. }
  250. endif;
  251. add_action( 'after_setup_theme', 'seedlet_setup' );
  252. /**
  253. * Register widget area.
  254. *
  255. * @link https://developer.wordpress.org/themes/functionality/sidebars/#registering-a-sidebar
  256. */
  257. function seedlet_widgets_init() {
  258. register_sidebar(
  259. array(
  260. 'name' => __( 'Footer', 'seedlet' ),
  261. 'id' => 'sidebar-1',
  262. 'description' => __( 'Add widgets here to appear in your footer.', 'seedlet' ),
  263. 'before_widget' => '<section id="%1$s" class="widget %2$s">',
  264. 'after_widget' => '</section>',
  265. 'before_title' => '<h2 class="widget-title">',
  266. 'after_title' => '</h2>',
  267. )
  268. );
  269. }
  270. add_action( 'widgets_init', 'seedlet_widgets_init' );
  271. /**
  272. * Set the content width in pixels, based on the theme's design and stylesheet.
  273. *
  274. * Priority 0 to make it available to lower priority callbacks.
  275. *
  276. * @global int $content_width Content width.
  277. */
  278. function seedlet_content_width() {
  279. // This variable is intended to be overruled from themes.
  280. // Open WPCS issue: {@link https://github.com/WordPress-Coding-Standards/WordPress-Coding-Standards/issues/1043}.
  281. // phpcs:ignore WordPress.NamingConventions.PrefixAllGlobals.NonPrefixedVariableFound
  282. $GLOBALS['content_width'] = apply_filters( 'seedlet_content_width', 750 );
  283. }
  284. add_action( 'after_setup_theme', 'seedlet_content_width', 0 );
  285. /**
  286. * Enqueue scripts and styles.
  287. */
  288. function seedlet_scripts() {
  289. // Fonts
  290. wp_enqueue_style( 'seedlet-fonts', get_template_directory_uri() . '/assets/css/fonts.css', array(), wp_get_theme()->get( 'Version' ), 'print' );
  291. // Theme styles
  292. if (preg_match('~MSIE|Internet Explorer~i', $_SERVER['HTTP_USER_AGENT']) || (strpos($_SERVER['HTTP_USER_AGENT'], 'Trident/7.0; rv:11.0') !== false)) {
  293. // If IE 11 or below, use a flattened stylesheet with static values replacing CSS Variables
  294. wp_enqueue_style( 'seedlet-style', get_template_directory_uri() . '/assets/css/ie.css', array(), wp_get_theme()->get( 'Version' ) );
  295. } else {
  296. // If not IE, use the standard stylesheet
  297. wp_enqueue_style( 'seedlet-style', get_template_directory_uri() . '/style.css', array(), wp_get_theme()->get( 'Version' ) );
  298. }
  299. // RTL styles
  300. wp_style_add_data( 'seedlet-style', 'rtl', 'replace' );
  301. // Print styles
  302. wp_enqueue_style( 'seedlet-print-style', get_template_directory_uri() . '/assets/css/print.css', array(), wp_get_theme()->get( 'Version' ), 'print' );
  303. // Threaded comment reply styles
  304. if ( is_singular() && comments_open() && get_option( 'thread_comments' ) ) {
  305. wp_enqueue_script( 'comment-reply' );
  306. }
  307. // Main navigation scripts
  308. wp_enqueue_script( 'seedlet-primary-navigation-script', get_template_directory_uri() . '/assets/js/primary-navigation.js', array(), wp_get_theme()->get( 'Version' ), true );
  309. }
  310. add_action( 'wp_enqueue_scripts', 'seedlet_scripts' );
  311. /**
  312. * Allow the editor fonts to be filterable for child themes.
  313. */
  314. function seedlet_filter_fonts_url( $editor_fonts_url ){
  315. return $editor_fonts_url;
  316. }
  317. add_filter( 'seedlet_editor_fonts', 'seedlet_filter_fonts_url' );
  318. /**
  319. * Fix skip link focus in IE11.
  320. *
  321. * This does not enqueue the script because it is tiny and because it is only for IE11,
  322. * thus it does not warrant having an entire dedicated blocking script being loaded.
  323. *
  324. * @link https://git.io/vWdr2
  325. */
  326. function seedlet_skip_link_focus_fix() {
  327. // The following is minified via `terser --compress --mangle -- js/skip-link-focus-fix.js`.
  328. ?>
  329. <script>
  330. /(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);
  331. </script>
  332. <?php
  333. }
  334. add_action( 'wp_print_footer_scripts', 'seedlet_skip_link_focus_fix' );
  335. /**
  336. * SVG Icons class.
  337. */
  338. require get_template_directory() . '/classes/class-seedlet-svg-icons.php';
  339. /**
  340. * Custom colors class.
  341. */
  342. require get_template_directory() . '/classes/class-seedlet-custom-colors.php';
  343. /**
  344. * Enhance the theme by hooking into WordPress.
  345. */
  346. require get_template_directory() . '/inc/template-functions.php';
  347. /**
  348. * SVG Icons related functions.
  349. */
  350. require get_template_directory() . '/inc/icon-functions.php';
  351. /**
  352. * Custom template tags for the theme.
  353. */
  354. require get_template_directory() . '/inc/template-tags.php';
  355. /**
  356. * Customizer additions.
  357. */
  358. require get_template_directory() . '/inc/customizer.php';
  359. /**
  360. * Block Patterns.
  361. */
  362. require get_template_directory() . '/inc/block-patterns.php';
  363. /**
  364. * Load WooCommerce compatibility file.
  365. */
  366. if ( class_exists( 'WooCommerce' ) ) {
  367. require get_template_directory() . '/inc/woocommerce.php';
  368. }