Задать вопрос
  • Фильтр таблицы HTML по checkbox?

    Alex_18
    @Alex_18 Автор вопроса
    Спасибо, я уже читал об этом плагине, действительно очень классный плагин, но к сожалению я не нашел функции фильтра по checkbox.
  • Как в WordPress рубрики добавить иконки?

    Alex_18
    @Alex_18
    Роман Вопроскин,
    Добавь это в functions.php

    Вывод картинки делается это через родную функцию WordPress get_term_meta(),

    ID картинок (вложений) сохраняется в метаполе термина _thumbnail_id, его и будем получать.
    <?php
    
    /**
     * Возможность загружать изображения для элементов указанных таксономий: категории, метки.
     *
     * Пример получения ID и URL картинки термина:
     * $image_id = get_term_meta( $term_id, '_thumbnail_id', 1 );
     * $image_url = wp_get_attachment_image_url( $image_id, 'thumbnail' );
     *
     * @author: Kama (http://wp-kama.ru)
     *
     * @ver: 2.8
     */
    if( is_admin() && ! class_exists('Term_Meta_Image') ){
    	// init
    	//add_action('current_screen', 'Term_Meta_Image_init');
    	add_action('admin_init', 'Term_Meta_Image_init');
    	function Term_Meta_Image_init(){
    		$GLOBALS['Term_Meta_Image'] = new Term_Meta_Image();
    	}
    
    	class Term_Meta_Image {
    
    		// для каких таксономий включить код. По умолчанию для всех публичных
    		static $taxes = array(); // пример: array('category', 'post_tag');
    
    		// название мета ключа
    		static $meta_key = '_thumbnail_id';
    
    		// URL пустой картинки
    		static $add_img_url = '';
    
    		public function __construct(){
    			if( isset($GLOBALS['Term_Meta_Image']) ) return $GLOBALS['Term_Meta_Image']; // once
    
    			$taxes = self::$taxes ? self::$taxes : get_taxonomies( array( 'public'=>true ), 'names' );
    
    			foreach( $taxes as $taxname ){
    				add_action("{$taxname}_add_form_fields",   array( & $this, 'add_term_image' ),     10, 2 );
    				add_action("{$taxname}_edit_form_fields",  array( & $this, 'update_term_image' ),  10, 2 );
    				add_action("created_{$taxname}",           array( & $this, 'save_term_image' ),    10, 2 );
    				add_action("edited_{$taxname}",            array( & $this, 'updated_term_image' ), 10, 2 );
    
    				add_filter("manage_edit-{$taxname}_columns",  array( & $this, 'add_image_column' ) );
    				add_filter("manage_{$taxname}_custom_column", array( & $this, 'fill_image_column' ), 10, 3 );
    			}
    		}
    
    		## поля при создании термина
    		public function add_term_image( $taxonomy ){
    			wp_enqueue_media(); // подключим стили медиа, если их нет
    
    			add_action('admin_print_footer_scripts', array( & $this, 'add_script' ), 99 );
    			$this->css();
    			?>
    			<div class="form-field term-group">
    				<label><?php _e('Image', 'default'); ?></label>
    				<div class="term__image__wrapper">
    					<a class="termeta_img_button" href="#">
    						<img src="<?php echo self::$add_img_url ?>" alt="">
    					</a>
    					<input type="button" class="button button-secondary termeta_img_remove" value="<?php _e( 'Remove', 'default' ); ?>" />
    				</div>
    
    				<input type="hidden" id="term_imgid" name="term_imgid" value="">
    			</div>
    			<?php
    		}
    
    		## поля при редактировании термина
    		public function update_term_image( $term, $taxonomy ){
    			wp_enqueue_media(); // подключим стили медиа, если их нет
    
    			add_action('admin_print_footer_scripts', array( & $this, 'add_script' ), 99 );
    
    			$image_id = get_term_meta( $term->term_id, self::$meta_key, true );
    			$image_url = $image_id ? wp_get_attachment_image_url( $image_id, 'thumbnail' ) : self::$add_img_url;
    			$this->css();
    			?>
    			<tr class="form-field term-group-wrap">
    				<th scope="row"><?php _e( 'Image', 'default' ); ?></th>
    				<td>
    					<div class="term__image__wrapper">
    						<a class="termeta_img_button" href="#">
    							<?php echo '<img src="'. $image_url .'" alt="">'; ?>
    						</a>
    						<input type="button" class="button button-secondary termeta_img_remove" value="<?php _e( 'Remove', 'default' ); ?>" />
    					</div>
    
    					<input type="hidden" id="term_imgid" name="term_imgid" value="<?php echo $image_id; ?>">
    				</td>
    			</tr>
    			<?php
    		}
    
    		public function css(){
    			?>
    			<style>
    				.termeta_img_button{ display:inline-block; margin-right:1em; }
    				.termeta_img_button img{ display:block; float:left; margin:0; padding:0; min-width:100px; max-width:150px; height:auto; background:rgba(0,0,0,.07); }
    				.termeta_img_button:hover img{ opacity:.8; }
    				.termeta_img_button:after{ content:''; display:table; clear:both; }
    			</style>
    			<?php
    		}
    
    		## Add script
    		public function add_script(){
    			// выходим если не на нужной странице таксономии
    			//$cs = get_current_screen();
    			//if( ! in_array($cs->base, array('edit-tags','term')) || ! in_array($cs->taxonomy, (array) $this->for_taxes) )
    			//  return;
    
    			$title = __('Featured Image', 'default');
    			$button_txt = __('Set featured image', 'default');
    			?>
    			<script>
    			jQuery(document).ready(function($){
    				var frame,
    					$imgwrap = $('.term__image__wrapper'),
    					$imgid   = $('#term_imgid');
    
    				// добавление
    				$('.termeta_img_button').click( function(ev){
    					ev.preventDefault();
    
    					if( frame ){ frame.open(); return; }
    
    					// задаем media frame
    					frame = wp.media.frames.questImgAdd = wp.media({
    						states: [
    							new wp.media.controller.Library({
    								title:    '<?php echo $title ?>',
    								library:   wp.media.query({ type: 'image' }),
    								multiple: false,
    								//date:   false
    							})
    						],
    						button: {
    							text: '<?php echo $button_txt ?>', // Set the text of the button.
    						}
    					});
    
    					// выбор
    					frame.on('select', function(){
    						var selected = frame.state().get('selection').first().toJSON();
    						if( selected ){
    							$imgid.val( selected.id );
    							$imgwrap.find('img').attr('src', selected.sizes.thumbnail.url );
    						}
    					} );
    
    					// открываем
    					frame.on('open', function(){
    						if( $imgid.val() ) frame.state().get('selection').add( wp.media.attachment( $imgid.val() ) );
    					});
    
    					frame.open();
    				});
    
    				// удаление
    				$('.termeta_img_remove').click(function(){
    					$imgid.val('');
    					$imgwrap.find('img').attr('src','<?php echo self::$add_img_url ?>');
    				});
    			});
    			</script>
    
    			<?php
    		}
    
    		## Добавляет колонку картинки в таблицу терминов
    		public function add_image_column( $columns ){
    			// подправим ширину колонки через css
    			add_action('admin_notices', function(){
    				echo '<style>.column-image{ width:50px; text-align:center; }</style>';
    			});
    
    			$num = 1; // после какой по счету колонки вставлять
    
    			$new_columns = array( 'image'=>'' ); // колонка без названия...
    
    			return array_slice( $columns, 0, $num ) + $new_columns + array_slice( $columns, $num );
    		}
    
    		public function fill_image_column( $string, $column_name, $term_id ){
    			// если есть картинка
    			if( $image_id = get_term_meta( $term_id, self::$meta_key, 1 ) )
    				$string = '<img src="'. wp_get_attachment_image_url( $image_id, 'thumbnail' ) .'" width="50" height="50" alt="" style="border-radius:4px;" />';
    
    			return $string;
    		}
    
    		## Save the form field
    		public function save_term_image( $term_id, $tt_id ){
    			if( isset($_POST['term_imgid']) && $image = (int) $_POST['term_imgid'] )
    				add_term_meta( $term_id, self::$meta_key, $image, true );
    		}
    
    		## Update the form field value
    		public function updated_term_image( $term_id, $tt_id ){
    			if( ! isset($_POST['term_imgid']) ) return;
    
    			if( $image = (int) $_POST['term_imgid'] )
    				update_term_meta( $term_id, self::$meta_key, $image );
    			else
    				delete_term_meta( $term_id, self::$meta_key );
    		}
    
    	}
    
    }
    /**
     * 2.8 - исправил ошибку удаления картинки.
     */
  • Как в WordPress рубрики добавить иконки?

    Alex_18
    @Alex_18
    Роман Вопроскин, Для рубрики как и для записи так же можно добавить миниатюру, а затем ее выводить как иконку.
  • Как вывести результат js скрипта?

    Alex_18
    @Alex_18 Автор вопроса
    Роман, Хранится в html Обновления вносятся руками.
  • Как вывести результат js скрипта?

    Alex_18
    @Alex_18 Автор вопроса
    Н@Stalker_RED, Нет такой возможности так как Таблица хранится на компьютере и регулярно добавляется.
  • Как вывести результат js скрипта?

    Alex_18
    @Alex_18 Автор вопроса
    Огромное спасибо то что нужно.