텍스트큐브 1.7.6 버그 패치 2
버그 많은 텍스트큐브
일단 위지윅모드의 기본 편집 모드가 바뀌는 현상은 텍스트큐브의 버그때문이다. 환경 설정에서 위지윅편집기의 기본 편집 모드를 HTML로 설정하고 글 편집창에서 위지윅모드로 전환(Edit 단추 클릭)하면 FM_Modern 플러그인 설정이 삭제된다. 플러그인의 설정이 삭제됐기 때문에 이 뒤로는 FM_Modern 플러그인의 기본 편집 모드인 위지윅모드로 동작한다. 확인해 본 결과 이 문제는 두 가지 방법으로 해결이 가능했다.
버그 많은 텍스트큐브
텍스트큐브 1.7.6에는 마음에 드는 기능도 많지만 버그도 많다. 지난 글에서는
그러나 이 방법을 사용하면 여러 개의 파일을 업로드할 수 있는 플래시 업로더를 사용할 수 없는 문제가 발생한다. 따라서 내가 선택한 방법은 'FM_Modern 플러그인'의 기본 설정 모드를 위지윅이 아니라 HTML 모드로 동작하도록 바꿔 해결했다. 절차는 다음과 같다.
자신이 좋아하는 편집기로
plugins/FM_Modern/index.php
파일을 열고FM_Modern_editorinit
함수의 기본값 설정 부분을 다음처럼 바꾼다.변경전 $config = array('paragraphdelim' => 'BR', 'defaultmode' => 'WYSIWYG'); 변경후 $config = array('paragraphdelim' => 'BR', 'defaultmode' => 'TEXTAREA');
마찬 가지로 좋아하는 편집기로
plugins/FM_Modern/index.xml
파일을 열고 index.xml 파일을 다음처럼 바꾼다. XML 파일은 굳이 패치할 필요는 없다.변경전 <field title="기본 작성 모드" type="select" name="defaultmode"> <op value="WYSIWYG" checked="checked"><![CDATA[위지윅 편집기]]></op> <op value="TEXTAREA"><![CDATA[HTML 직접 편집]]></op> </field> 변경후 <field title="기본 작성 모드" type="select" name="defaultmode"> <op value="WYSIWYG"><![CDATA[위지윅 편집기]]></op> <op value="TEXTAREA" checked="checked"><![CDATA[HTML 직접 편집]]></op> </field>
위지윅편집기의 데이타변경 패치
1.7.6을 사용하면서 또 마음에 들지 않는 부분은 <b>
와 같은 태그를 <strong>
과 같은 의미 단위의 태그로 자동으로 바꿔주는 기능이다. <b>
태그를 사용하는 것 보다는 <strong>
와 같은 태그를 사용하는 것이 검색 엔진 최적화(SEO: Search Enginge Optimization)에는 더 도움이 된다. 따라서 자동으로 바꿔 주는 기능이나 과거 <span>
태그를 이용해서 지정하던 속성을 <strong>
와 같은 의미있는 태그를 이용하도록 한 점은 상당히 높은 점수를 주고 싶다. 그러나 난 기본적으로 '위지윅편집기는 사용자가 입력한 데이타를 바꾸지 않아야 한다'고 생각한다. 또 자동으로 바꾸는 부분은 꼭 옵션으로 사용자가 선택할 수 있도록 하는 것이 옳다고 생각한다.
<b>
태그를 자동으로 <strong>
태그로 바꾸는 것은 좋지만 여기에도 버그가 있다. <blockquote>
태그 내에 <b>
태그가 있으면 다음 그림처럼 <strongBLOCKQUOTE>
태그로 바뀐다. 물론 <blockquote>
태그 내의 <b>
태그는 처리가 되지 않기 때문에 <blockquote>
태그내에 <b>
태그가 있으면 이 뒤의 모든 글씨가 굵은 글씨로 표시되는 문제가 발생한다.
따라서 이 부분 역시 직접 패치했다. 패치하는 방법은 다음과 같다. 좋아하는 편집기를 이용해서 plugins/FM_Modern/editor.js
파일을 열고 다음처럼 태그를 자동으로 바꾸는 부분을 주석처리한다.
if(isWYSIWYG) { // var html = this.contentDocument.body.innerHTML; } else { // var html = this.textarea.value; (...중략...) if(isWYSIWYG) { // this.contentDocument.body.innerHTML = html; } else { // this.textarea.value = html; }
이렇게 하면 태그를 자동으로 바꾸는 기능도 동작하지 않기 때문에 예전처럼 HTML 편집기를 기본으로 사용하는 것과 거의 비슷한 효과를 얻을 수 있다.
관련 글타래- 텍스트큐브 1.7.6 버그 패치 텍스트큐브는 트랙백을 보내는 것이 상당히 어렵다. 정확이 이야... 새창
- 텍스트큐브를 1.7.6으로 판올림해야 하는 이유 나는 프로그램을 좋아한다. 따라서 대부분의 프로그램... 새창
- 텍스트큐브의 트랙백 문제 `sendTrackback`이 실행되는 도중 오류가 발생하는 것으로 추정하고 ... 새창
- 블로거뉴스 플러그인이 오동작하는 경우 개방된 블로거뉴스의 파워는 엄청나다. 다른 곳에서는 상상하... 새창
- 텍스트큐브 1.7.1로 판올림 1.7로의 판올림을 원한 이유는 1.7에서는 1.6에 비해 개선된 기능... 새창