ok
Direktori : /var/softaculous/sitepad/editor/site-admin/includes/ |
Current File : //var/softaculous/sitepad/editor/site-admin/includes/options.php |
<?php /** * WordPress Options Administration API. * * @package WordPress * @subpackage Administration * @since 4.4.0 */ /** * Output JavaScript to toggle display of additional settings if avatars are disabled. * * @since 4.2.0 */ function options_discussion_add_js() { ?> <script> (function($){ var parent = $( '#show_avatars' ), children = $( '.avatar-settings' ); parent.change(function(){ children.toggleClass( 'hide-if-js', ! this.checked ); }); })(jQuery); </script> <?php } /** * Display JavaScript on the page. * * @since 3.5.0 */ function options_general_add_js() { //Enqueue media. wp_enqueue_media(); ?> <script type="text/javascript"> jQuery(document).ready(function($){ var $siteName = $( '#site-admin-bar-site-name' ).children( 'a' ).first(), homeURL = ( <?php echo wp_json_encode( get_home_url() ); ?> || '' ).replace( /^(https?:\/\/)?(www\.)?/, '' ); $( '#blogname' ).on( 'input', function() { var title = $.trim( $( this ).val() ) || homeURL; // Truncate to 40 characters. if ( 40 < title.length ) { title = title.substring( 0, 40 ) + '\u2026'; } $siteName.text( title ); }); $("input[name='date_format']").click(function(){ if ( "date_format_custom_radio" != $(this).attr("id") ) $( 'input[name="date_format_custom"]' ).val( $( this ).val() ).closest( 'fieldset' ).find( '.example' ).text( $( this ).parent( 'label' ).children( '.format-i18n' ).text() ); }); $( 'input[name="date_format_custom"]' ).on( 'click input', function() { $( '#date_format_custom_radio' ).prop( 'checked', true ); }); $("input[name='time_format']").click(function(){ if ( "time_format_custom_radio" != $(this).attr("id") ) $( 'input[name="time_format_custom"]' ).val( $( this ).val() ).closest( 'fieldset' ).find( '.example' ).text( $( this ).parent( 'label' ).children( '.format-i18n' ).text() ); }); $( 'input[name="time_format_custom"]' ).on( 'click input', function() { $( '#time_format_custom_radio' ).prop( 'checked', true ); }); $("input[name='date_format_custom'], input[name='time_format_custom']").change( function() { var format = $( this ), fieldset = format.closest( 'fieldset' ), example = fieldset.find( '.example' ), spinner = fieldset.find( '.spinner' ); spinner.addClass( 'is-active' ); $.post( ajaxurl, { action: 'date_format_custom' == format.attr( 'name' ) ? 'date_format' : 'time_format', date : format.val() }, function( d ) { spinner.removeClass( 'is-active' ); example.text( d ); } ); }); var languageSelect = $( '#WPLANG' ); $( 'form' ).submit( function() { // Don't show a spinner for English and installed languages, // as there is nothing to download. if ( ! languageSelect.find( 'option:selected' ).data( 'installed' ) ) { $( '#submit', this ).after( '<span class="spinner language-install-spinner is-active" />' ); } }); // Add Favicon Handler $('.sitepad-site-icon-media').on('click', function(){ sitepad_site_icon_controller($(this)); }); // Remove Favicon Handler $('.sitepad-site-icon-remove').on('click', function(){ var wrapper = $(this).closest('.sitepad-site-icon-wrapper'); var preview = wrapper.find('.sitepad-site-icon-preview'); wrapper.find('.sitepad-site-icon-select').show(); preview.hide(); wrapper.find('input[name="site_icon"]').val(''); preview.find('img').attr('src', ''); }); }); function sitepad_site_icon_controller(jEle){ /** * Create a media modal select frame, and store it so the instance can be reused when needed. */ params = { 'width' : 512, 'height' : 512, 'flex_height' : 0, 'flex_width' : 0, }; var setImageFromAttachment = function(image){ image = image || {}; var wrapper = jEle.closest('.sitepad-site-icon-wrapper'); var preview = wrapper.find('.sitepad-site-icon-preview'); wrapper.find('.sitepad-site-icon-select').hide(); preview.show(); wrapper.find('input[name="site_icon"]').val(image.id); preview.find('img').attr('src', image.url); }; var calculateImageSelectOptions = function( attachment, controller ) { var control = controller.get( 'control' ), flexWidth = !! parseInt( 512, 10 ), flexHeight = !! parseInt( 512, 10 ), realWidth = attachment.get( 'width' ), realHeight = attachment.get( 'height' ), xInit = parseInt( 512, 10 ), yInit = parseInt( 512, 10 ), ratio = xInit / yInit, xImg = xInit, yImg = yInit, x1, y1, imgSelectOptions; //controller.set( 'canSkipCrop', ! mustBeCropped( flexWidth, flexHeight, xInit, yInit, realWidth, realHeight ) ); if ( realWidth / realHeight > ratio ) { yInit = realHeight; xInit = yInit * ratio; } else { xInit = realWidth; yInit = xInit / ratio; } x1 = ( realWidth - xInit ) / 2; y1 = ( realHeight - yInit ) / 2; imgSelectOptions = { handles: true, keys: true, instance: true, persistent: true, imageWidth: realWidth, imageHeight: realHeight, minWidth: xImg > xInit ? xInit : xImg, minHeight: yImg > yInit ? yInit : yImg, x1: x1, y1: y1, x2: xInit + x1, y2: yInit + y1 }; if ( flexHeight === false && flexWidth === false ) { imgSelectOptions.aspectRatio = xInit + ':' + yInit; } if ( true === flexHeight ) { delete imgSelectOptions.minHeight; imgSelectOptions.maxWidth = realWidth; } if ( true === flexWidth ) { delete imgSelectOptions.minWidth; imgSelectOptions.maxHeight = realHeight; } return imgSelectOptions; }; var frame = wp.media({ button: { text: 'Select', close: false }, states: [ new wp.media.controller.Library({ title: "<?php echo __('Site Icon'); ?>", library: wp.media.query({ type: 'image' }), multiple: false, date: false, priority: 20, suggestedWidth: 512, suggestedHeight: 512 }), new wp.media.controller.SiteIconCropper({ imgSelectOptions: calculateImageSelectOptions, control: this }) ] }); frame.on( 'select', function(){ var attachment = frame.state().get( 'selection' ).first().toJSON(); if ( params.width === attachment.width && params.height === attachment.height && ! params.flex_width && ! params.flex_height ) { wp.ajax.post( 'crop-image', { nonce: attachment.nonces.edit, id: attachment.id, context: 'site-icon', cropDetails: { x1: 0, y1: 0, width: params.width, height: params.height, dst_width: params.width, dst_height: params.height } } ).done( function( croppedImage ) { setImageFromAttachment( croppedImage ); frame.close(); } ).fail( function() { frame.trigger('content:error:crop'); } ); } else { frame.setState( 'cropper' ); } }); frame.on( 'cropped', function( croppedImage ) { setImageFromAttachment( croppedImage ); }); // Open Library frame.setState( 'library' ).open(); } </script> <?php } /** * Display JavaScript on the page. * * @since 3.5.0 */ function options_reading_add_js() { ?> <script type="text/javascript"> jQuery(document).ready(function($){ var section = $('#front-static-pages'), staticPage = section.find('input:radio[value="page"]'), selects = section.find('select'), check_disabled = function(){ selects.prop( 'disabled', ! staticPage.prop('checked') ); }; check_disabled(); section.find('input:radio').change(check_disabled); }); </script> <?php } /** * Render the site charset setting. * * @since 3.5.0 */ function options_reading_blog_charset() { echo '<input name="blog_charset" type="text" id="blog_charset" value="' . esc_attr( get_option( 'blog_charset' ) ) . '" class="regular-text" />'; echo '<p class="description">' . __( 'The <a href="https://sitepad.com/docs/Glossary#Character_set">character encoding</a> of your site (UTF-8 is recommended)' ) . '</p>'; }