back-compat.php 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <?php
  2. /**
  3. * Twenty Seventeen back compat functionality
  4. *
  5. * Prevents Twenty Seventeen from running on WordPress versions prior to 4.7,
  6. * since this theme is not meant to be backward compatible beyond that and
  7. * relies on many newer functions and markup changes introduced in 4.7.
  8. *
  9. * @package WordPress
  10. * @subpackage Twenty_Seventeen
  11. * @since Twenty Seventeen 1.0
  12. */
  13. /**
  14. * Prevent switching to Twenty Seventeen on old versions of WordPress.
  15. *
  16. * Switches to the default theme.
  17. *
  18. * @since Twenty Seventeen 1.0
  19. */
  20. function twentyseventeen_switch_theme() {
  21. switch_theme( WP_DEFAULT_THEME );
  22. unset( $_GET['activated'] );
  23. add_action( 'admin_notices', 'twentyseventeen_upgrade_notice' );
  24. }
  25. add_action( 'after_switch_theme', 'twentyseventeen_switch_theme' );
  26. /**
  27. * Adds a message for unsuccessful theme switch.
  28. *
  29. * Prints an update nag after an unsuccessful attempt to switch to
  30. * Twenty Seventeen on WordPress versions prior to 4.7.
  31. *
  32. * @since Twenty Seventeen 1.0
  33. *
  34. * @global string $wp_version WordPress version.
  35. */
  36. function twentyseventeen_upgrade_notice() {
  37. /* translators: %s: The current WordPress version. */
  38. $message = sprintf( __( 'Twenty Seventeen requires at least WordPress version 4.7. You are running version %s. Please upgrade and try again.', 'twentyseventeen' ), $GLOBALS['wp_version'] );
  39. printf( '<div class="error"><p>%s</p></div>', $message );
  40. }
  41. /**
  42. * Prevents the Customizer from being loaded on WordPress versions prior to 4.7.
  43. *
  44. * @since Twenty Seventeen 1.0
  45. *
  46. * @global string $wp_version WordPress version.
  47. */
  48. function twentyseventeen_customize() {
  49. wp_die(
  50. /* translators: %s: The current WordPress version. */
  51. sprintf( __( 'Twenty Seventeen requires at least WordPress version 4.7. You are running version %s. Please upgrade and try again.', 'twentyseventeen' ), $GLOBALS['wp_version'] ),
  52. '',
  53. array(
  54. 'back_link' => true,
  55. )
  56. );
  57. }
  58. add_action( 'load-customize.php', 'twentyseventeen_customize' );
  59. /**
  60. * Prevents the Theme Preview from being loaded on WordPress versions prior to 4.7.
  61. *
  62. * @since Twenty Seventeen 1.0
  63. *
  64. * @global string $wp_version WordPress version.
  65. */
  66. function twentyseventeen_preview() {
  67. if ( isset( $_GET['preview'] ) ) {
  68. /* translators: %s: The current WordPress version. */
  69. wp_die( sprintf( __( 'Twenty Seventeen requires at least WordPress version 4.7. You are running version %s. Please upgrade and try again.', 'twentyseventeen' ), $GLOBALS['wp_version'] ) );
  70. }
  71. }
  72. add_action( 'template_redirect', 'twentyseventeen_preview' );