диалог ckeditor и jquery UI не работает - PullRequest
2 голосов
/ 22 февраля 2012

Я без конца пытался, теперь вы разрешили эту крайне неприятную ситуацию, с которой я столкнулся.Я пытаюсь заставить ckEditor работать в диалоговом окне jQuery UI.Редактор включен отлично, и он заменяет текстовое поле на оболочку ckeditor, но я не могу редактировать / добавлять контент в блоке контента.Единственное работающее решение, которое я видел сейчас, было, если я нажму на «Исходный код» в редакторе и открою его, я смогу добавить к нему контент.не добавлено никакой дополнительной информации / кода.Есть идеи?

Ответы [ 3 ]

2 голосов
/ 07 ноября 2013

Для версий jQuery-UI (1.10+) и jQuery (1.10+) и CKEditor 3.6, это решение , кажется, работает:

_moveToTop: function( event, silent ) {
    var $parent = this.uiDialog.parent();
    var $elementsOnSameLevel = $parent.children();

    var heighestZIndex = 0;
    $.each($elementsOnSameLevel, function(index, element) {
        var zIndexOfElement = $(element).css('z-index');
        if (zIndexOfElement) {
            var zIndexOfElementAsNumber = parseInt(zIndexOfElement) || 0;
            if (zIndexOfElementAsNumber > heighestZIndex) {
                heighestZIndex = zIndexOfElementAsNumber;
            }
        }
    });
    var currentZIndex = this.uiDialog.css('z-index');

    var moved;
    if (currentZIndex >= heighestZIndex) {
        moved = false;
    } else {
        this.uiDialog.css('z-index', heighestZIndex + 1);
        moved = true;
    }

    if ( moved && !silent ) {
        this._trigger( "focus", event );
    }

    return moved;
}

Вы можете либо отредактировать файл в строке (не рекомендуется), либо просто переопределить стандартную функциональность jQuery-UI в отдельном файле JS, который загружается после jQuery-UI, но до создания диалогового окна.

$.widget("ui.dialog", $.ui.dialog, {
    _moveToTop: function( event, silent ) {
        //Logic from above
    }
});
2 голосов
/ 04 апреля 2012

была такая же проблема,

удаление эффектов из модала помогло: Удалено:

show: "scale",
hide: "puff",

Теперь мой звонок выглядит так:

$("#report").dialog({
        title: "<?php echo caption("REPORT_EDITOR"); ?>",
        bgiframe: true,
          autoOpen: false,
          width: 990,
          height: 620,
          modal: true,

          draggable: true,
          resizable: true,
          resizeStop: function(event, ui) {
              var y = $(event.target).height();
              repEditor.resize( "99%", y - 10 );
          },

          buttons: {
            'Close': function() {
              $(this).dialog('close');
            }
          } 
        });
0 голосов
/ 06 марта 2013

В качестве альтернативы для сохранения анимации «show» и «hide», создайте свой экземпляр редактора после завершения события «show» с функцией обратного вызова для завершения: опция «show»

$("#report").dialog({
    title: "<?php echo caption("REPORT_EDITOR"); ?>",
    bgiframe: true,
      autoOpen: false,
      width: 990,
      height: 620,
      modal: true,

      // start my suggestion
      show: {
          effect: "scale",
          complete: function() {
            $( "#selector" ).ckeditor();
          }
      },

      hide: "puff",
      // end my suggestion

      draggable: true,
      resizable: true,
      resizeStop: function(event, ui) {
          var y = $(event.target).height();
          repEditor.resize( "99%", y - 10 );
      },

      buttons: {
        'Close': function() {
          $(this).dialog('close');
        }
      } 
    });
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...