기본 갤러리 설정에 사용자 정의 필드 추가


14

나는 이미 해결책을 찾았고 해결되지 않거나 쓸모없는 주제를 많이 발견했습니다.

사용자 정의 워드 프레스 갤러리 옵션 | 기본 갤러리의 맞춤 입력란

그러나 갤러리 바로 가기에 속성을 추가하기 위해 일부 사용자 정의 필드 (확인란, 사이클 버튼 등)를 추가하고 싶습니다. 누군가 스니핑을 가지고 있습니까?


편집 : 마지막으로 나는이 https://wordpress.org/support/topic/how-to-add-fields-to-gallery-settings을 발견 하고 내가 원하는 모든 것을했습니다. :) 숙성


편집 : 상단 링크를 기반으로 다음 줄을 썼습니다.

add_action('print_media_templates', function(){
?>
<script type="text/html" id="tmpl-custom-gallery-setting">
    <h3 style="z-index: -1;">___________________________________________________________________________________________</h3>
    <h3>Custom Settings</h3>

    <label class="setting">
        <span><?php _e('Text'); ?></span>
        <input type="text" value="" data-setting="ds_text" style="float:left;">
    </label>

    <label class="setting">
        <span><?php _e('Textarea'); ?></span>
        <textarea value="" data-setting="ds_textarea" style="float:left;"></textarea>
    </label>

    <label class="setting">
        <span><?php _e('Number'); ?></span>
        <input type="number" value="" data-setting="ds_number" style="float:left;" min="1" max="9">
    </label>

    <label class="setting">
      <span><?php _e('Select'); ?></span>
      <select data-setting="ds_select">
        <option value="option1"> 'Option-1' </option>
        <option value="option2"> 'Option-2' </option>
      </select>
    </label>

    <label class="setting">
        <span><?php _e('Bool'); ?></span>
        <input type="checkbox" data-setting="ds_bool">
    </label>

</script>

<script>

    jQuery(document).ready(function()
    {
        _.extend(wp.media.gallery.defaults, {
        ds_text: 'no text',
        ds_textarea: 'no more text',
        ds_number: "3",
        ds_select: 'option1',
        ds_bool: false,
        ds_text1: 'dummdideldei'
        });

        wp.media.view.Settings.Gallery = wp.media.view.Settings.Gallery.extend({
        template: function(view){
          return wp.media.template('gallery-settings')(view)
               + wp.media.template('custom-gallery-setting')(view);
        }
        });

    });

</script>
<?php

});

ui 사용자 짧은 코드 인터페이스 짧은 코드

숫자 필드는 짧은 코드로 채워지지 않습니다. HTML 입력 태그 유형 "number"는 "value"에 대해 정수만 허용하기 때문입니다. ds_number의 문자열을 int로 변경하려면 코드에 무엇을 추가해야합니까?

인사말 rownn


2
작동 여부에 관계없이 코드를 게시하십시오.
s_ha_dum

나는 잡혔다! 코드가 없습니다. 나는 싹둑을 요구하는 두꺼운 방법을 알고 있지만 전혀 모른다. : / 작동 코드를 분석하여 작동 방식을 확인하고 싶었습니다. 추가 및 저장을 위해 add_action ()으로 관리해야한다는 것을 알고 있지만 특정 장소에서 특정 유형을 만드는 방법을 모르겠습니다.
rownn

@rownn, 질문을 편집하는 대신 코드를 답변으로 게시해야합니다. 그런 다음 수락하십시오. :)
Jen

답변:


1

코드 주셔서 감사합니다. 이 문제를 더 조사했습니다 (정수 형식 문제는 아닙니다). 내가 숫자 필드에 대해 생각해 낸 유일한 해결책은 더 많은 WP JS를 원숭이 패치하는 것입니다. 다음은 모든 입력 유형을 지원하는 수정 된 전체 코드입니다.

add_action('print_media_templates', function(){
?>
<script type="text/html" id="tmpl-custom-gallery-setting">
    <h3>Custom Settings</h3>

    <label class="setting">
        <span><?php _e('Text'); ?></span>
        <input type="text" value="" data-setting="ds_text" style="float:left;">
    </label>

    <label class="setting">
        <span><?php _e('Textarea'); ?></span>
        <textarea value="" data-setting="ds_textarea" style="float:left;"></textarea>
    </label>

    <label class="setting">
        <span><?php _e('Number'); ?></span>
        <input type="number" value="" data-setting="ds_number" style="float:left;" min="1" max="9">
    </label>

    <label class="setting">
      <span><?php _e('Select'); ?></span>
      <select data-setting="ds_select">
        <option value="option1"> 'Option-1' </option>
        <option value="option2"> 'Option-2' </option>
      </select>
    </label>

    <label class="setting">
        <span><?php _e('Bool'); ?></span>
        <input type="checkbox" data-setting="ds_bool">
    </label>

</script>

<script>

    jQuery(document).ready(function()
    {
        _.extend(wp.media.gallery.defaults, {
        ds_text: 'no text',
        ds_textarea: 'no more text',
        ds_number: "3",
        ds_select: 'option1',
        ds_bool: false,
        ds_text1: 'dummdideldei'
        });

        wp.media.view.Settings.Gallery = wp.media.view.Settings.Gallery.extend({
        template: function(view){
          return wp.media.template('gallery-settings')(view)
               + wp.media.template('custom-gallery-setting')(view);
        },
        // this is function copies from WP core /wp-includes/js/media-views.js?ver=4.6.1
        update: function( key ) {
          var value = this.model.get( key ),
            $setting = this.$('[data-setting="' + key + '"]'),
            $buttons, $value;

          // Bail if we didn't find a matching setting.
          if ( ! $setting.length ) {
            return;
          }

          // Attempt to determine how the setting is rendered and update
          // the selected value.

          // Handle dropdowns.
          if ( $setting.is('select') ) {
            $value = $setting.find('[value="' + value + '"]');

            if ( $value.length ) {
              $setting.find('option').prop( 'selected', false );
              $value.prop( 'selected', true );
            } else {
              // If we can't find the desired value, record what *is* selected.
              this.model.set( key, $setting.find(':selected').val() );
            }

          // Handle button groups.
          } else if ( $setting.hasClass('button-group') ) {
            $buttons = $setting.find('button').removeClass('active');
            $buttons.filter( '[value="' + value + '"]' ).addClass('active');

          // Handle text inputs and textareas.
          } else if ( $setting.is('input[type="text"], textarea') ) {
            if ( ! $setting.is(':focus') ) {
              $setting.val( value );
            }
          // Handle checkboxes.
          } else if ( $setting.is('input[type="checkbox"]') ) {
            $setting.prop( 'checked', !! value && 'false' !== value );
          }
          // HERE the only modification I made
          else {
            $setting.val( value ); // treat any other input type same as text inputs
          }
          // end of that modification
        },
        });
    });

</script>
<?php

1
"wp.media.gallery.defaults"는 이제 "wp.media.galleryDefaults"입니다
locomo
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.