back-compat.php 2.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879
  1. <?php
  2. /**
  3. * Twenty Nineteen back compat functionality
  4. *
  5. * Prevents Twenty Nineteen 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_Nineteen
  11. * @since Twenty Nineteen 1.0.0
  12. */
  13. /**
  14. * Prevent switching to Twenty Nineteen on old versions of WordPress.
  15. *
  16. * Switches to the default theme.
  17. *
  18. * @since Twenty Nineteen 1.0.0
  19. */
  20. function twentynineteen_switch_theme() {
  21. switch_theme( WP_DEFAULT_THEME );
  22. unset( $_GET['activated'] );
  23. add_action( 'admin_notices', 'twentynineteen_upgrade_notice' );
  24. }
  25. add_action( 'after_switch_theme', 'twentynineteen_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 Nineteen on WordPress versions prior to 4.7.
  31. *
  32. * @since Twenty Nineteen 1.0.0
  33. *
  34. * @global string $wp_version WordPress version.
  35. */
  36. function twentynineteen_upgrade_notice() {
  37. /* translators: %s: WordPress version. */
  38. $message = sprintf( __( 'Twenty Nineteen requires at least WordPress version 4.7. You are running version %s. Please upgrade and try again.', 'twentynineteen' ), $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 Nineteen 1.0.0
  45. *
  46. * @global string $wp_version WordPress version.
  47. */
  48. function twentynineteen_customize() {
  49. wp_die(
  50. sprintf(
  51. /* translators: %s: WordPress version. */
  52. __( 'Twenty Nineteen requires at least WordPress version 4.7. You are running version %s. Please upgrade and try again.', 'twentynineteen' ),
  53. $GLOBALS['wp_version']
  54. ),
  55. '',
  56. array(
  57. 'back_link' => true,
  58. )
  59. );
  60. }
  61. add_action( 'load-customize.php', 'twentynineteen_customize' );
  62. /**
  63. * Prevents the Theme Preview from being loaded on WordPress versions prior to 4.7.
  64. *
  65. * @since Twenty Nineteen 1.0.0
  66. *
  67. * @global string $wp_version WordPress version.
  68. */
  69. function twentynineteen_preview() {
  70. if ( isset( $_GET['preview'] ) ) {
  71. /* translators: %s: WordPress version. */
  72. wp_die( sprintf( __( 'Twenty Nineteen requires at least WordPress version 4.7. You are running version %s. Please upgrade and try again.', 'twentynineteen' ), $GLOBALS['wp_version'] ) );
  73. }
  74. }
  75. add_action( 'template_redirect', 'twentynineteen_preview' );