<?php /** * The plugin bootstrap file * * This file is read by WordPress to generate the plugin information in the plugin * admin area. This file also includes all of the dependencies used by the plugin, * registers the activation and deactivation functions, and defines a function * that starts the plugin. * * @link https://example.com * @since 1.0.0 * @package Plugin_Name * * @wordpress-plugin */ /** * Plugin Name: arcHIVE - website options Plugin URI: https://arc-hive.zone/ Description: All the <strong>options</strong> for <strong>arcHIVE website</strong> wich do not come by default with Wordpress. Version: 0.1 Author URI: https://vitrubio.net/ Author: jorge - vitrubio.net License: GPL 3.0 Date: 2021 04 14 License URI:https://www.gnu.org/licenses/gpl-3.0.html Text Domain: arcHIVE_plugin_txtdomain Domain Path: /languages */ /** * if ever read this never forget to check * howto write a pluggin by Wordpress.org * https://codex.wordpress.org/Writing_a_Plugin * and the best practices * https://developer.wordpress.org/plugins/plugin-basics/best-practices/ * and some resources * https://themefoundation.com/wordpress-meta-boxes-guide/ */ defined( 'ABSPATH' ) or die( 'No script kiddies please!' ); /* * * Load translation, if it exists * * * * * * * * * * * * * * * * * * */ function arcHIVE_plugin_init() { $plugin_dir = basename(dirname(__FILE__)); load_plugin_textdomain( 'arcHIVE_plugin_txtdomain', null, $plugin_dir.'/assets/languages/' ); } add_action('plugins_loaded', 'arcHIVE_plugin_init'); /* * * Add mimetypes support: svg * * * * * * * * * * * * * * * * * * */ function arcHIVE_enable_mime_types( $mimes ) { $mimes['svg'] = 'image/svg+xml'; return $mimes; } add_filter('upload_mimes', 'arcHIVE_enable_mime_types'); /* * * add settings link in pluggin page * * * * * * * * * * * * * * * * * * */ // function arcHIVE_plugin_plugin_action_links($links, $file) { // $this_plugin = basename(plugin_dir_url(__FILE__)) . '/arcHIVE-theme-plugin.php'; // if($file == $this_plugin) { // $links[] = '<a href="admin.php?page=arcHIVE-options">' . __('Settings', 'arcHIVE_plugin_txtdomain') . '</a>'; // } // return $links; // } // add_filter('plugin_action_links', 'arcHIVE_plugin_plugin_action_links', 10, 2); // /** * Registers stylesheet for a custom plugin. */ function arcHIVE_wp_plugin_styles_admin() { add_editor_style( 'assets/css/arcHIVE-wp-plugin.css' ); } add_action( 'admin_init', 'arcHIVE_wp_plugin_styles_admin' ); /** * Proper way to enqueue scripts and styles */ //function arcHIVE_theme_plugin_styles_public() { // $this_plugin = basename(plugin_dir_url(__FILE__)); // wp_enqueue_style( 'arcHIVE-theme-plugin', plugin_dir_url(__FILE__) . 'assets/css/arcHIVE-theme-plugin.css' ); // // wp_enqueue_script( 'script-name', get_template_directory_uri() . '/js/example.js', array(), '1.0.0', true ); //} // //add_action( 'wp_enqueue_scripts', 'arcHIVE_theme_plugin_styles_public' ); // /* * * Custom button in TINYMCE editor for styling * * * * * * * * * * * * * * * * * * * * * * */ // as read on // https://codex.wordpress.org/Plugin_API/Filter_Reference/mce_buttons,_mce_buttons_2,_mce_buttons_3,_mce_buttons_4 // https://www.wpbeginner.com/wp-tutorials/how-to-add-custom-styles-to-wordpress-visual-editor/ // https://kinsta.com/blog/wordpress-tinymce-editor/ // // // // Callback function to insert 'styleselect' into the $buttons array // if ( ! function_exists( 'arcHIVE_mce_buttons' ) ) : // function arcHIVE_mce_buttons( $buttons ) { // // array_unshift( $buttons, 'styleselect', 'removeformat' ); // array_push( $buttons, 'styleselect', 'removeformat' ); // return $buttons; // } // endif; // // Register our callback to the appropriate filter // add_filter( 'mce_buttons_2', 'arcHIVE_mce_buttons' ); // // // Callback function to filter the MCE settings // if ( ! function_exists( 'arcHIVE_mce_before_init_insert_formats' ) ) : // function arcHIVE_mce_before_init_insert_formats( $init_array ) { // // // Define the style_formats array // $style_formats=array( // // // Each array child is a format with it's own settings // array( // 'title' => 'button', // 'block' => 'span', // 'classes' => 'button', // 'wrapper' => true, // ), // array( // 'title' => 'button secondary', // 'block' => 'span', // 'classes' => 'button secondary', // 'wrapper' => true, // ), // array( // 'title' => 'button hollow', // 'block' => 'span', // 'classes' => 'button hollow primary', // 'wrapper' => true, // ), // array( // 'title' => 'button hollow secondary', // 'block' => 'span', // 'classes' => 'button hollow secondary', // 'wrapper' => true, // ), // // // ); // // // Insert the array, JSON ENCODED, into 'style_formats' // $init_array['style_formats'] = json_encode( $style_formats ); // return $init_array; // } // endif; // // // Attach callback to 'tiny_mce_before_init' // add_filter( 'tiny_mce_before_init', 'arcHIVE_mce_before_init_insert_formats' ); // // function arcHIVE_mce_buttons_3( $buttons ) { // $buttons[] = 'superscript'; // $buttons[] = 'subscript'; // $buttons[] = 'cut' ; // $buttons[] = 'copy' ; // $buttons[] = 'paste' ; // $buttons[] = 'hr' ; // $buttons[] = 'backcolor' ; // $buttons[] = 'newdocuement' ; // $buttons[] = 'formatselect' ; // $buttons[] = 'fontselect' ; // $buttons[] = 'fontsizeselect' ; // $buttons[] = 'styleselect' ; // return $buttons; // } // add_filter( 'mce_buttons_3', 'arcHIVE_mce_buttons_3' ); /** * * Custom settings page * * * * * * * * * * * * * * * * * * / * * @internal never define functions inside callbacks. * these functions could be run multiple times; this would result in a fatal error. * https://developer.wordpress.org/plugins/settings/custom-settings-page/ */ /** * custom option and settings */ // function arcHIVE_settings_init() { // // register a new setting for "arcHIVE" page // register_setting( 'arcHIVE_settings', 'arcHIVE_options' ); // // // register a new section in the "arcHIVE" page // add_settings_section( // 'arcHIVE_section_olderthandate', // __( 'arcHIVEs Options.', 'arcHIVE_plugin_txtdomain' ), // 'arcHIVE_section_olderthandate_cb', // 'arcHIVE_settings' // ); // // // register a new field in the "arcHIVE_section_olderthandate" section, inside the "arcHIVE" page // add_settings_field( // 'arcHIVE_field_olderthandate', // as of WP 4.6 this value is used only internally // // use $args' label_for to populate the id inside the callback // __( 'Hide content older than...', 'arcHIVE_plugin_txtdomain' ), // 'arcHIVE_field_olderthandate_cb', // 'arcHIVE_settings', // 'arcHIVE_section_olderthandate', // [ // 'label_for' => 'arcHIVE_field_olderthandate', // 'class' => 'arcHIVE_row', // 'arcHIVE_custom_data' => 'custom', // ] // ); // } // /** * register our arcHIVE_settings_init to the admin_init action hook */ // add_action( 'admin_init', 'arcHIVE_settings_init' ); /** * custom option and settings: * callback functions */ // // // olderthandate section cb // // // section callbacks can accept an $args parameter, which is an array. // // $args have the following keys defined: title, id, callback. // // the values are defined at the add_settings_section() function. // function arcHIVE_section_olderthandate_cb( $args ) { // ?> // <p id="<?php echo esc_attr( $args['id'] ); ?>"> // <?php esc_html_e( 'Here you should set the options for the older content to be marked as it.', 'arcHIVE_plugin_txtdomain' ); ?> // </p> // <?php // } // // // daysback field cb // // // field callbacks can accept an $args parameter, which is an array. // // $args is defined at the add_settings_field() function. // // wordpress has magic interaction with the following keys: label_for, class. // // the "label_for" key value is used for the "for" attribute of the <label>. // // the "class" key value is used for the "class" attribute of the <tr> containing the field. // // you can add custom key value pairs to be used inside your callbacks. // function arcHIVE_field_olderthandate_cb( $args ) { // // get the value of the setting we've registered with register_setting() // $options = get_option( 'arcHIVE_options' ); // // output the field // ?> // // <p class="description"> // <?php _e( 'You should set up the <b>number of days</b> from today to the past or the date from wich will be <b>considered old posts</b>. Then the class <span style="font-family:monospace;">oldpost</span> will be added to the post and pages so you can apply a css style to your theme.', 'arcHIVE_plugin_txtdomain' ); ?> // </p> // <form id="arcHIVE-oldpost-numberofdays" class="arcHIVE-oldpost-numberofdays"> // <label for="arcHIVE-oldpost-numberofdays">Number of days:</label> // <input type="number" id="arcHIVE-oldpost-numberofdays" name="arcHIVE-oldpost-numberofdays" min="1" max="100"> // </form> // <form id="arcHIVE-oldpost-enddate" class="arcHIVE-oldpost-enddate"> // <label for="arcHIVE-oldpost-enddate">Start date:</label> // <input type="date" id="arcHIVE-oldpost-enddate" name="arcHIVE-oldpost-endate" value=""> // </form> // // <!-- borrar desde aqui --> // <p> // label_for:<?php echo esc_attr( $args['label_for'] ); ?> // <br /> // arcHIVE_custom_data:<?php echo esc_attr( $args['arcHIVE_custom_data'] ); ?> // <br /> // class:<?php echo esc_attr( $args['class'] ); ?> // <br /> // <?php esc_html_e( 'daysback', 'arcHIVE_plugin_txtdomain' ); ?> // <br /> // // </p> // <!-- borrar hasta aqui --> // // <?php // } // /** * top level menu * https://developer.wordpress.org/reference/functions/add_menu_page/ */ // function arcHIVE_options_page() { // // add top level menu page // add_menu_page( // $page_title = 'arcHIVE Options', // $page_title // $menu_title = 'arcHIVE', //$menu_title // $capability = 'manage_options', //'edit_others_posts', // $capability // $menu_slug = 'arcHIVE-options', // $menu_slug // $function = 'arcHIVE_options_page_html', //$function // $icon_url = 'dashicons-rest-api',// $icon_url //https://developer.wordpress.org/resource/dashicons/#menu // $position = '50'// $position // ); // } // /** * register our arcHIVE_options_page to the admin_menu action hook */ // add_action( 'admin_menu', 'arcHIVE_options_page' ); /** * top level menu: * callback functions */ // function arcHIVE_options_page_html() { // // check user capabilities // if ( ! current_user_can( 'manage_options' ) ) { // ?> // <p class="description"> // <?php esc_html_e( 'Sorry, you do not have permission to edit this settings, please, contact any admin to get granted.', 'arcHIVE_plugin_txtdomain' ); ?> // </p> // <?php // return; // } // // // add error/update messages // // // check if the user have submitted the settings // // wordpress will add the "settings-updated" $_GET parameter to the url // if ( isset( $_GET['settings-updated'] ) ) { // // add settings saved message with the class of "updated" // add_settings_error( 'arcHIVE_messages', 'arcHIVE_message', __( 'Settings Saved', 'arcHIVE_plugin_txtdomain' ), 'updated' ); // } // // // show error/update messages // settings_errors( 'arcHIVE_messages' ); // ?> // <div class="wrap"> // <h1><?php echo esc_html( get_admin_page_title() ); ?></h1> // <form action="options.php" method="post"> // <?php // // output security fields for the registered setting "arcHIVE" // settings_fields( 'arcHIVE_settings' ); // // output setting sections and their fields // // (sections are registered for "arcHIVE", each field is registered to a specific section) // do_settings_sections( 'arcHIVE_settings' ); // // output save settings button // submit_button( 'Save Settings' ); // ?> // </form> // </div> // <?php // }