리치 텍스트 편집기 구성

리치 텍스트 편집기(RTE)는 작성자가 텍스트 컨텐츠를 편집하는 다양한 기능을 제공합니다. 아이콘, 선택 상자, 도구 모음 및 메뉴는 WYSIWYG 텍스트 편집 환경을 위해 제공됩니다. 관리자는 작성 구성 요소에서 사용할 수 있는 기능을 활성화, 비활성화 및 확장하도록 RTE를 구성합니다. 작성자가 웹 컨텐츠를 작성하는 데 RTE를 사용하는 방법을 참조하십시오.

구성하는 데 필요한 RTE 개념과 단계는 아래에 나와 있습니다.

RTE 개념 이해 필요한 기능 활성화 개별 기능 구성
인터페이스 이해 구성 위치 이해 및 설정 플러그인 구성
편집 모드 유형 플러그인 활성화 기능 속성 설정
플러그인 기본 정보 RTE 도구 모음 구성 붙여넣기 모드 구성

작성자가 사용할 수 있는 사용자 인터페이스 이해

RTE 인터페이스는 작성 환경을 위한 반응형 디자인을 제공합니다. 인터페이스는 터치 및 데스크톱 장치에서 사용하도록 설계되었습니다.

리치 텍스트 편집기 도구 모음

그림:사용 가능한 모든 옵션이 활성화된 리치 텍스트 편집기 도구 모음

도구 모음은 WYSIWYG 작성 환경에 대한 옵션을 제공합니다. Experience Manager 관리자는 인터페이스의 도구 모음에서 사용할 수 있는 옵션을 구성할 수 있습니다. 포괄적인 편집 옵션 세트는 기본적으로 Experience Manager에서 사용할 수 있습니다. 개발자는 Experience Manager을 사용자 지정하여 편집 옵션을 더 추가할 수 있습니다.

다양한 편집 모드

작성자는 다른 구성 요소 모드를 사용하여 Experience Manager에서 텍스트 컨텐츠를 만들고 편집할 수 있습니다. 컨텐츠 작성 및 서식 지정을 위한 도구 모음 옵션과 다른 편집 모드에서 RTE 지원 구성 요소의 사용자 경험은 RTE 구성에 따라 달라집니다.

편집 모드 편집 영역 활성화할 권장 기능
인라인 즉석 편집 기능을 통해 간단한 편집 작업을 수행할 수 있습니다.대화 상자를 열지 않고 형식을 지정합니다. 최소 RTE 기능.
RTE 전체 화면 전체 페이지를 다룹니다. 모든 필수 RTE 기능.
대화 상자 대화 상자는 페이지 컨텐츠 위에 있지만 전체 페이지를 포함하지 않습니다. 신중하게 기능을 사용할 수 있습니다.
대화 상자 전체 화면 전체 화면 모드와 동일합니다.는 RTE와 함께 대화 상자의 필드를 포함합니다. 모든 필수 RTE 기능.
노트

소스 편집 기능은 인라인 편집 모드에서 사용할 수 없습니다. 전체 화면 모드에서는 이미지를 드래그할 수 없습니다. 다른 모든 기능은 모든 모드에서 작동합니다.

인라인 편집

페이지 내에서 컨텐츠를 편집하려면 느리게 두 번 클릭하여 컨텐츠를 엽니다. 기본 옵션이 포함된 작은 도구 모음이 표시됩니다.

도구 모음에서 기본 옵션을 사용하여 인라인 편집

그림:도구 모음에서 기본 옵션을 사용하여 인라인 편집.

전체 화면 편집

Experience Manager 구성 요소는 페이지 컨텐츠를 숨기고 사용 가능한 화면을 차지하는 전체 화면 보기에서 열 수 있습니다. 가장 많은 편집 옵션을 제공하므로 인라인 편집의 세부 버전을 전체 화면 편집해 보십시오. 아이콘을 클릭하여 인라인 편집 모드를 사용할 때 작은 도구 모음에서 전체 화면에서 RTE를 열 수 있습니다.

대화 상자 전체 화면 모드에서 세부 RTE 도구 모음과 함께 대화 상자에서 사용할 수 있는 옵션 및 구성 요소도 사용할 수 있습니다. 이 변수는 다른 구성 요소와 함께 RTE가 포함된 대화 상자에만 적용할 수 있습니다.

전체 화면 모드에서 편집할 때 세부 RTE 도구 모음

그림:전체 화면 모드로 편집할 때 세부 RTE 도구 모음

대화 상자 편집

구성 요소를 두 번 클릭하면 컨텐츠를 편집할 수 있는 대화 상자가 열립니다. 대화 상자가 기존 페이지 맨 위에 열립니다. 일부 특정 시나리오에서는 대화 상자가 팝업 창으로 열립니다. 예를 들어 텍스트 구성 요소가 다중 열 페이지 레이아웃의 열에 속하고 대화 상자에 사용할 수 있는 영역은 더 작아집니다.

대화 상자 편집 모드

그림:대화 상자 편집 모드.

RTE 플러그인 및 관련 기능 정보

기능은 각 플러그인을 통해 사용할 수 있으며, 각 플러그인은 다음과 같습니다.

  • features 속성,

    • 해당 플러그인의 기본 기능을 활성화하거나 비활성화하는 데 사용됩니다.
    • 표준화된 절차를 사용하여 구성했습니다.
  • 적절한 경우 보다 많은 속성 및 옵션을 사용하여 별도의 구성을 필요로 합니다.

해당 플러그인과 관련된 노드의 features 속성 값으로 RTE의 기본 기능이 활성화되거나 비활성화됩니다.

다음 표에는 현재 플러그인이 표시되어 있습니다.

  • API 설명서에 대한 링크가 있는 플러그인 ID입니다. 플러그인을 활성화할 때 ID가 노드 이름으로 사용됩니다.
  • features 속성에 대해 허용되는 값입니다.
  • 플러그인에서 제공하는 기능에 대한 설명입니다.
플러그인 ID 기능 설명
편집 cut, copy, paste-default, paste-plaintext, paste-wordhtml 잘라내기, 복사 및 세 가지 붙여넣기 모드.
칠드레플레이스 find, replace 찾기 및 바꾸기
포맷 bold, italic, underline 기본 텍스트 서식.
이미지 image 기본 이미지 지원(컨텐츠 또는 컨텐츠 파인더에서 드래그). 브라우저에 따라 작성자를 위한 다양한 동작이 지원됩니다
- 이 값을 정의하려면 탭 크기를 참조하십시오.
정당화 justifyleft, justifycenter, justifyright 단락 맞춤.
링크 modifylink, unlink, anchor 하이퍼링크 및 앵커.
목록 ordered, unordered, indent, outdent 이 플러그인은 들여쓰기 및 목록 모두 제어합니다.중첩된 목록을 포함합니다.
misctools specialchars, sourceedit 기타 도구를 사용하여 작성자는 특수 문자를 입력하거나 HTML 소스를 편집할 수 있습니다. 또한 목록을 정의하려는 경우 특수 문자 범위를 추가할 수 있습니다.
Paraformat paraformat 기본 단락 형식은 단락, 머리글 1, 제목 2 및 제목 3(<p>, <h1>, <h2><h3>)입니다. 단락 형식을 더 추가하거나 목록을 확장할 수 있습니다.
맞춤법 검사 checktext 언어 인식 맞춤법 검사기입니다.
스타일 styles CSS 클래스를 사용하는 스타일링을 지원합니다. 텍스트에 사용할 고유한 스타일 범위를 추가(또는 확장)하려면 새 텍스트 스타일을 추가합니다.
아래 첨자 subscript, superscript 기본 형식에 대한 확장, 하위 스크립트 및 슈퍼 스크립트 추가.
table, removetable, insertrow, removerow, insertcolumn, removecolumn, cellprops, mergecells, splitcell, selectrow, selectcolumns 전체 표 또는 개별 셀에 대해 고유한 스타일을 추가하려면 표 스타일 구성을 참조하십시오.
실행 취소 undo, redo 실행 취소 및 다시 실행 작업의 기록 크기입니다.
노트

전체 화면 플러그인은 대화 상자 모드에서 지원되지 않습니다. dialogFullScreen 설정을 사용하여 전체 화면 모드에 대한 도구 모음을 구성합니다.

구성 경로 및 위치 이해

RTE 편집의 모드 및 작성자를 위해 제공하는 인터페이스가 RTE 플러그인🔗을(를) 활성화할 때 구성 세부 사항의 위치를 결정합니다. 위치는 다음과 같습니다.

  • 인라인 모드:cq:editConfig/cq:inplaceEditing
  • 전체 화면 모드: cq:editConfig/cq:inplaceEditing.
  • 대화 상자 모드:cq:dialog
  • 전체 화면 대화 상자 모드:cq:dialog
노트

cq:inplaceEditing 아래에 있는 노드의 이름을 config(으)로 지정하지 마십시오. cq:inplaceEditing 노드에서 다음 속성을 정의합니다.

  • 이름: configPath
  • 유형: String
  • :실제 구성이 들어 있는 노드의 경로

RTE 구성 노드의 이름을 config로 지정하지 마십시오. 그렇지 않으면 content-author 그룹의 사용자가 아닌 관리자에게만 RTE 구성이 적용됩니다.

대화 상자 편집 모드에 적용되는 다음 속성을 구성합니다.

  • useFixedInlineToolbar:떠다니는 대신 RTE 도구 모음을 고정시킬 수 있습니다. sling:resourceType= cq/gui/components/authoring/dialog/richtext 을 사용하여 RTE 노드에 정의된 이 부울 속성을 True 로 설정합니다. 이 속성을 True으로 설정하면 foundation-contentloaded 이벤트에서 리치 텍스트 편집이 시작됩니다. 이를 방지하려면 customStart 속성을 True(으)로 설정하고 rte-start 이벤트를 트리거하여 RTE 편집을 시작합니다. 이 속성이 true이면 RTE가 클릭 시 시작되지 않으며 이것은 기본 동작입니다.

  • customStart:이벤트를 트리거하여 RTE를 시작할 시기를 True제어하려면 RTE 노드에 정의된 이 부울 속성을 로 설정합니다 rte-start.

  • rte-start:RTE 편집을 시작할 contenteditable-div 때 RTE에서 이 이벤트를 트리거합니다. customStarttrue로 설정된 경우에만 작동합니다.

터치 사용 대화 상자에서 RTE를 사용하는 경우 문제를 방지하려면 속성 useFixedInlineToolbartrue로 설정하십시오.

플러그인을 활성화하여 RTE 기능 활성화

RTE 기능은 각각 기능 속성이 있는 일련의 플러그인을 통해 사용할 수 있습니다. 각 플러그인의 다양한 기능을 활성화하거나 비활성화하도록 기능 속성을 구성할 수 있습니다.

RTE 플러그인의 자세한 구성은 RTE 플러그인을 활성화하고 구성하는 방법을 참조하십시오.

코어 구성 요소 텍스트 구성 요소를 사용하면 템플릿 편집기에서 사용자 인터페이스를 컨텐츠 정책으로 사용하여 많은 RTE 플러그인을 구성할 수 있으므로 기술 구성이 필요하지 않습니다. 컨텐츠 정책은 이 문서에 설명된 대로 RTE UI 구성에서 사용할 수 있습니다. 자세한 내용은 페이지 템플릿 만들기핵심 구성 요소 개발자 설명서를 참조하십시오.

참조용으로 기본 텍스트 구성 요소(표준 설치의 일부로 제공됨)는 다음 위치에서 찾을 수 있습니다.

  • /libs/wcm/foundation/components/text
  • /libs/foundation/components/text

자체 텍스트 구성 요소를 만들려면 이러한 구성 요소를 편집하는 대신 위의 구성 요소를 복사하십시오.

RTE 도구 모음 구성

Experience Manager 다양한 편집 모드에 대해 리치 텍스트 편집기의 인터페이스를 다르게 구성할 수 있습니다. 기본 설정은 아래에 제공됩니다. 요구 사항에 따라 이러한 기본값을 대체할 수 있습니다. 작성자에게 제공할 도구 모음 기능만 사용자 지정합니다. 도구 모음 구성을 모두 지정할 필요는 없습니다.

dialogFullScreen에 대한 도구 모음을 구성하려면 다음 샘플 구성을 사용합니다.

<uiSettings jcr:primaryType="nt:unstructured">
  <cui jcr:primaryType="nt:unstructured">
    <inline
      jcr:primaryType="nt:unstructured"
      toolbar="[format#bold,format#italic,format#underline,#justify,#lists,links#modifylink,links#unlink,#paraformat]">
      <popovers jcr:primaryType="nt:unstructured">
        <justify
          jcr:primaryType="nt:unstructured"
          items="[justify#justifyleft,justify#justifycenter,justify#justifyright,justify#justifyjustify]"
          ref="justify"/>
        <lists
          jcr:primaryType="nt:unstructured"
          items="[lists#unordered,lists#ordered,lists#outdent,lists#indent]"
          ref="lists"/>
        <paraformat
          jcr:primaryType="nt:unstructured"
          items="paraformat:getFormats:paraformat-pulldown"
          ref="paraformat"/>
      </popovers>
    </inline>
    <dialogFullScreen
      jcr:primaryType="nt:unstructured"
      toolbar="[format#bold,format#italic,format#underline,justify#justifyleft,justify#justifycenter,justify#justifyright,justify#justifyjustify,lists#unordered,lists#ordered,lists#outdent,lists#indent,links#modifylink,links#unlink,table#createoredit,#paraformat,image#imageProps]">
      <popovers jcr:primaryType="nt:unstructured">
        <paraformat
          jcr:primaryType="nt:unstructured"
          items="paraformat:getFormats:paraformat-pulldown"
          ref="paraformat"/>
      </popovers>
    </dialogFullScreen>
    <tableEditOptions
      jcr:primaryType="nt:unstructured"
      toolbar="[table#insertcolumn-before,table#insertcolumn-after,table#removecolumn,-,table#insertrow-before,table#insertrow-after,table#removerow,-,table#mergecells-right,table#mergecells-down,table#mergecells,table#splitcell-horizontal,table#splitcell-vertical,-,table#selectrow,table#selectcolumn,-,table#ensureparagraph,-,table#modifytableandcell,table#removetable,-,undo#undo,undo#redo,-,table#exitTableEditing,-]">
    </tableEditOptions>
  </cui>
</uiSettings>

인라인 모드 및 전체 화면 모드에 다른 사용자 인터페이스 설정이 사용됩니다. 도구 모음 속성은 도구 모음의 옵션을 지정합니다.

예를 들어 옵션 자체가 기능(예: Bold)이면 PluginName#FeatureName(예: links#modifylink)로 지정됩니다.

옵션이 팝업(플러그인의 일부 기능 포함)인 경우 #PluginName(예: #format)으로 지정됩니다.

옵션 그룹 사이의 구분자(|)는 -로 지정할 수 있습니다.

인라인 또는 전체 화면 모드 아래의 팝업 노드에는 사용 중인 팝업 오버의 목록이 포함되어 있습니다. popovers 노드 아래의 각 하위 노드의 이름은 플러그인(예: 형식)의 이름을 따릅니다. 여기에는 플러그인의 기능 목록(예: format#bold)이 포함된 'items' 속성이 있습니다.

RTE 사용자 인터페이스 설정 및 컨텐츠 정책

관리자는 위에서 설명한 대로 구성을 수행하는 대신 컨텐츠 정책을 사용하여 RTE 옵션을 제어할 수 있습니다. 컨텐츠 정책은 편집 가능한 템플릿의 일부로 사용할 때 구성 요소의 디자인 속성을 정의합니다. 예를 들어 RTE를 사용하는 텍스트 구성 요소를 편집 가능한 템플릿에 사용하는 경우 컨텐츠 정책에 따라 굵게 옵션을 사용할 수 있고 몇 가지 단락 서식 옵션을 사용할 수 있음을 정의할 수 있습니다. 컨텐츠 정책은 재사용 가능하며, 여러 템플릿에 적용할 수 있습니다.

사용자 인터페이스 구성에서 컨텐츠 정책으로의 다운스트림으로 이동하는 RTE에서 사용할 수 있는 옵션입니다.

  • 사용자 인터페이스 구성 설정은 컨텐츠 정책에 사용할 수 있는 옵션을 정의합니다.
  • RTE의 사용자 인터페이스 구성이 제거되었거나 항목을 활성화하지 않으면 컨텐츠 정책에서 구성할 수 없습니다.
  • 작성자는 사용자 인터페이스 구성 및 컨텐츠 정책에 의해 사용 가능한 기능에만 액세스할 수 있습니다.

예를 들어 텍스트 코어 구성 요소 설명서가 표시됩니다.

도구 모음 아이콘과 명령 간 매핑 사용자 정의

RTE 도구 모음에 표시되는 Coral 아이콘과 사용 가능한 명령 간의 매핑을 사용자 지정할 수 있습니다. Coral 아이콘 외에 다른 아이콘은 사용할 수 없습니다.

  1. uiSettings/cui 아래에 icons 노드를 만듭니다.

  2. 아래에 개별 아이콘의 노드를 만듭니다.

  3. 각 개별 아이콘 노드에서 Coral 아이콘과 아이콘에 매핑할 명령을 지정합니다.

다음은 명령 BoldtextItalic이라는 Coral 아이콘에 매핑하는 샘플 코드 조각입니다.

<text jcr:primaryType="nt:unstructured" sling:resourceType="cq/gui/components/authoring/dialog/richtext" name="./text" useFixedInlineToolbar="{Boolean}true">
    <rtePlugins jcr:primaryType="nt:unstructured">
        <format jcr:primaryType="nt:unstructured" features="bold,italic"/>
    </rtePlugins>
    <uiSettings jcr:primaryType="nt:unstructured">
        <cui jcr:primaryType="nt:unstructured">
            <inline jcr:primaryType="nt:unstructured"
                toolbar="[format#bold,format#italic,format#underline,links#modifylink,links#unlink]">
            </inline>
            <icons jcr:primaryType="nt:unstructured">
                <bold jcr:primaryType="nt:unstructured"
                    command="format#bold"
                    icon="textItalic"/>
            </icons>
        </cui>
    </uiSettings>
</text>

알려진 제한 사항

Experience Manager RTE 기능에는 다음과 같은 제한 사항이 있습니다.

  • RTE 기능은 Experience Manager 구성 요소 대화 상자에서만 지원됩니다. RTE는 마법사 또는 Foundation 양식에서 지원되지 않습니다.

  • Experience Manager 은 하이브리드 장치에서 작동하지 않습니다.

  • RTE 구성 노드 config 이름을 지정하지 마십시오. 그렇지 않으면 content-author 그룹의 사용자가 아닌 관리자에게만 RTE 구성이 적용됩니다.

  • RTE는 인라인 프레임 또는 iframe에 컨텐츠를 포함할 수 없습니다.

우수 사례 및 팁

  • 부동 대화 상자의 경우 팝업 대화 상자 없이 플러그인만 활성화합니다. 팝업이 없는 플러그인의 크기는 더 작으며 부동 대화 상자에 가장 적합합니다.
  • Paste 플러그인과 같은 큰 팝업에서 전체 화면 대화 상자 모드 또는 전체 화면 모드에서만 플러그인을 활성화합니다. 큰 팝업이 있는 플러그인에는 제작 환경을 잘 제공하기 위해 더 많은 화면 부동산이 필요합니다.
  • CoralUI3 RTE용 사용자 지정 플러그인을 사용하는 경우 rte.coralui3 라이브러리를 사용하십시오.

이 페이지에서는