사용자 지정 적응형 양식 테마 만들기 creating-custom-adaptive-form-themes

CAUTION
Adobe Experience Manager(AEM) Forms은 적응형 양식 테마를 만들고 수정하는 테마 편집기 기능을 제공합니다. 테마 편집기가 없는 버전에서 업그레이드하고 Less/CSS 파일(사전 테마 편집기 메서드)을 사용하여 만든 테마에 대한 기존 투자가 있는 경우에만 이 문서에 나열된 단계를 수행하십시오.

사전 요구 사항 prerequisites

적응형 양식 테마 adaptive-form-theme

적응형 양식 테마 ​는 적응형 양식의 스타일(모양 및 느낌)을 정의하는 데 사용하는 AEM 클라이언트 라이브러리입니다.

적응형 템플릿 ​을(를) 만들고 테마를 템플릿에 적용합니다. 그런 다음 이 사용자 지정 템플릿을 사용하여 적응형 양식 ​을 만들 수 있습니다.

적응형 양식 및 클라이언트 라이브러리

적응형 양식 테마를 만들려면 to-create-an-adaptive-form-theme

NOTE
다음 절차에서는 노드, 등록 정보 및 폴더와 같은 AEM 객체에 대한 샘플 이름을 사용하여 설명합니다.
이름을 사용하여 이 단계를 수행하면 결과 템플릿이 다음 스냅샷과 유사하게 표시됩니다.

포리스트 테마 적응형 양식 스냅숏
그림: 포리스트 테마 샘플

  1. /apps 노드 아래에 cq:ClientLibraryFolder 유형의 노드를 만듭니다.

    예를 들어 다음 노드를 만듭니다.

    /apps/myAfThemes/forestTheme

  2. 다중 값 문자열 속성 categories을(를) 노드에 추가하고 값을 적절하게 설정합니다.

    예를 들어 속성을 af.theme.forest(으)로 설정합니다.

    CRX 저장소 스냅숏

  3. lesscss 폴더 두 개와 css.txt 파일을 1단계에서 만든 노드에 추가합니다.

    • less 폴더: .css 스타일을 관리하는 데 사용되는 less 변수와 less mixins을(를) 정의하는 less 변수 파일을 포함합니다.

      이 폴더는 less개의 변수 파일, less개의 mixin 파일, mixin을 사용하여 스타일을 정의하는 less개의 파일 및 변수로 구성됩니다. 그런 다음 이 less 파일을 모두 style.less로 가져옵니다.

    • css폴더: 테마에 사용할 정적 스타일을 정의하는 .css 파일을 포함합니다.

    변수 파일 감소: CSS 스타일 정의에 사용되는 변수를 정의하거나 재정의하는 파일입니다.

    적응형 양식은 다음 .less개 파일에 정의된 기본 변수를 제공합니다.

    • /apps/clientlibs/fd/af/guidetheme/common/less/globalvariables.less
    • /apps/clientlibs/fd/af/guidetheme/common/less/layoutvariables.less

    적응형 양식은 또한 다음에 정의된 서드파티 변수를 제공합니다.

    /apps/clientlibs/fd/af/third-party/less/variables.less

    적응형 양식과 함께 제공된 less 변수를 사용하거나, 이러한 변수를 재정의하거나, 새 less 변수를 만들 수 있습니다.

    note note
    NOTE
    전처리가 덜 된 파일을 가져오는 동안 import 문에서 파일의 상대 경로를 지정합니다.

    샘플 재정의 변수:

    code language-css
    @button-background-color: rgb(19, 102, 44);
    @button-border-color: rgb(19, 102, 44);
    @button-border-size: 0px;
    @button-padding: 10px 15px;
    @button-font-color: #ffffff;
    

    less변수를 재정의하려면 다음을 수행하십시오.

    1. 기본 적응형 양식 변수 가져오기:

      /apps/clientlibs/fd/af/guidetheme/common/less/globalvariables.less/apps/clientlibs/fd/af/guidetheme/common/less/layoutvariables.less

    2. 그런 다음 재정의된 변수를 포함하는 더 적은 파일을 가져옵니다.

    샘플 새 변수 정의:

    code language-css
    @button-focus-bg-color: rgb(40, 208, 90);
    @button-hover-bg-color: rgb(30, 156, 67);
    

    적은 mixin 파일: 변수를 인수로 사용하는 함수를 정의할 수 있습니다. 이러한 함수의 출력은 결과 스타일입니다. CSS 스타일이 반복되지 않도록 다양한 스타일 내에서 이러한 mixin을 사용하십시오.

    적응형 양식은에 정의된 즉시 사용 가능한 mixin을 제공합니다.

    • /apps/clientlibs/fd/af/guidetheme/common/less/adaptiveforms-mixins.less

    적응형 양식은 또한 다음에 정의된 서드파티 mixin을 제공합니다.

    • /apps/clientlibs/fd/af/third-party/less/mixins.less

    샘플 mixin 정의:

    code language-css
    .rounded-corners (@radius) {
      -webkit-border-radius: @radius;
      -moz-border-radius: @radius;
      -ms-border-radius: @radius;
      -o-border-radius: @radius;
      border-radius: @radius;
    }
    
    .border(@color, @type, @size) {
       border: @color @size @type;
    }
    

    Styles.less 파일: 이 파일을 사용하여 클라이언트 라이브러리에서 사용해야 하는 모든 less 파일(변수, mixin, 스타일)을 포함합니다.

    다음 샘플 styles.less 파일에서 가져오기 문은 임의의 순서로 배치할 수 있습니다.

    다음 .less개의 파일을 가져오는 문은 필수입니다.

    • globalvariables.less
    • layoutvariables.less
    • components.less
    • layouts.less
    code language-css
    @import "../../../clientlibs/fd/af/guidetheme/common/less/globalvariables.less";
    @import "../../../clientlibs/fd/af/guidetheme/common/less/layoutvariables.less";
    @import "forestTheme-variables";
    @import "../../../clientlibs/fd/af/guidetheme/common/less/components.less";
    @import "../../../clientlibs/fd/af/guidetheme/common/less/layouts.less";
    
    /* custom styles */
    
    .guidetoolbar {
      input[type="button"], button, .button {
        .rounded-corners (@button-radius);
        &:hover {
          background-color: @button-hover-bg-color;
        }
        &:focus {
          background-color: @button-focus-bg-color;
        }
      }
    }
    
    form {
        background-image: url(../images/forest.png);
     background-repeat: no-repeat;
     background-size: 100%;
    }
    

    css.txt에 라이브러리에 대해 다운로드할 .css 파일의 경로가 포함되어 있습니다.

    예:

    code language-javascript
    #base=/apps/clientlibs/fd/af/third-party/css
    bootstrap.css
    
    #base=less
    styles.less
    
    #base=/apps/clientlibs/fd/xfaforms/xfalib/css
    datepicker.css
    listboxwidget.css
    scribble.css
    dialog.css
    
    note note
    NOTE
    styles.less 파일은 필수가 아닙니다. 즉, 사용자 지정 스타일, 변수 또는 mixin을 정의하지 않은 경우 이 파일을 만들 필요가 없습니다.
    그러나 css.txt 파일에서 style.less 파일을 만들지 않은 경우에는 다음 줄의 주석 처리를 제거해야 합니다.
    #base=less
    다음 줄을 주석 처리합니다.
    styles.less

적응형 양식에서 테마를 사용하려면 to-use-a-theme-in-an-adaptive-form

적응형 양식 테마를 만든 후 다음 단계를 수행하여 적응형 양식에서 이 테마를 사용합니다.

  1. 에서 만든 테마를 포함하여 적응형 양식 테마 섹션을 만들려면 cq:Component 유형의 사용자 지정 페이지를 만드십시오.

    예, /apps/myAfCustomizations/myAfPages/forestPage

    1. sling:resourceSuperType 속성을 추가하고 해당 값을 fd/af/components/page/base(으)로 설정합니다.

      CRX 저장소 스냅숏

    2. 페이지에서 테마를 사용하려면 재정의 파일 library.jsp를 노드에 추가해야 합니다.

      그런 다음에서 만든 테마를 가져와서 이 문서의 적응형 양식 테마 섹션을 만들 수 있습니다.

      다음 샘플 코드 조각은 af.theme.forest 테마를 가져옵니다.

      code language-jsp
      <%@include file="/libs/fd/af/components/guidesglobal.jsp"%>
      <cq:includeClientLib categories="af.theme.forest"/>
      
    3. 선택 사항: 사용자 지정 페이지에서 필요에 따라 header.jsp, footer.jsp 및 body.jsp를 재정의합니다.

  2. jcr:content가 이전 단계에서 만든 사용자 지정 페이지(예: myAfCustomizations/myAfPages/forestPage))를 가리키는 사용자 지정 템플릿(예: /apps/myAfCustomizations/myAfTemplates/forestTemplate)을 만듭니다.

    CRX 저장소 스냅숏

  3. 이전 단계에서 만든 템플릿을 사용하여 적응형 양식을 만듭니다. 적응형 양식의 모양과 느낌은 이 문서의 적응형 양식 테마 섹션을 만들기 위해 에서 만든 테마로 정의됩니다.

recommendation-more-help
19ffd973-7af2-44d0-84b5-d547b0dffee2