An 적응형 양식 테마 는 적응형 양식의 스타일(모양 및 느낌)을 정의하는 데 사용하는 AEM 클라이언트 라이브러리입니다.
다음을 생성함: 적응형 템플릿 템플릿에 테마를 적용할 수 있습니다. 그런 다음 이 사용자 지정 템플릿을 사용하여 적응형 양식.
다음 절차에서는 노드, 등록 정보 및 폴더와 같은 AEM 객체에 대한 샘플 이름을 사용하여 설명합니다.
이름을 사용하여 이 단계를 수행하면 결과 템플릿이 다음 스냅샷과 유사하게 표시됩니다.
그림: 포리스트 테마 샘플
유형의 노드 만들기 cq:ClientLibraryFolder
다음 아래에 /apps
노드.
예를 들어 다음 노드를 만듭니다.
/apps/myAfThemes/forestTheme
다중 값 문자열 속성 추가 categories
을 노드에 추가하고 값을 적절하게 설정합니다.
예를 들어 속성을 다음으로 설정합니다. af.theme.forest
.
두 개의 폴더 추가, less
및 css
및 파일 css.txt
1단계에서 생성된 노드로:
less
폴더: 다음을 포함 less
변수를 정의할 변수 파일입니다. less
변수 및 less mixins
.css 스타일을 관리하는 데 사용됩니다.
이 폴더는 다음으로 구성됩니다. less
변수 파일, less
mixin 파일, less
mixin 및 변수를 사용하여 스타일을 정의하는 파일입니다. 이렇게 적은 파일은 모두 styles.less로 가져옵니다.
css
folder: 테마에 사용할 정적 스타일을 정의하는 .css 파일을 포함합니다.
변수 파일 줄이기: CSS 스타일 정의에 사용되는 변수를 정의하거나 재정의하는 파일입니다.
적응형 양식은 다음 .less 파일에 정의된 OOTB 변수를 제공합니다.
/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
적응형 양식과 함께 제공되는 더 적은 변수를 사용하거나, 이러한 변수를 재정의하거나, 더 적은 변수를 새로 만들 수 있습니다.
전처리가 덜 된 파일을 가져오는 동안 import 문에서 파일의 상대 경로를 지정합니다.
샘플 재정의 변수:
@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
변수:
기본 적응형 양식 변수 가져오기:
/apps/clientlibs/fd/af/guidetheme/common/less/globalvariables.less/apps/clientlibs/fd/af/guidetheme/common/less/layoutvariables.less
그런 다음 재정의된 변수를 포함하는 더 적은 파일을 가져옵니다.
샘플 새 변수 정의:
@button-focus-bg-color: rgb(40, 208, 90);
@button-hover-bg-color: rgb(30, 156, 67);
Mixin 파일 줄이기: 변수를 인수로 사용하는 함수를 정의할 수 있습니다. 이러한 함수의 출력은 결과 스타일입니다. CSS 스타일이 반복되지 않도록 하려면 이러한 mixin을 다른 스타일 내에서 사용하십시오.
적응형 양식은 다음에 정의된 OOTB mixin을 제공합니다.
/apps/clientlibs/fd/af/guidetheme/common/less/adaptiveforms-mixins.less
적응형 양식은 또한 다음에 정의된 서드파티 mixin을 제공합니다.
/apps/clientlibs/fd/af/third-party/less/mixins.less
샘플 mixin 정의:
.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 파일: 이 파일을 사용하여 클라이언트 라이브러리에서 사용해야 하는 적은 파일(변수, mixin, 스타일)을 모두 포함합니다.
다음 샘플에서 styles.less
파일에서 가져오기 문은 임의의 순서로 배치할 수 있습니다.
다음 .less 파일을 가져오는 문은 필수입니다.
globalvariables.less
layoutvariables.less
components.less
layouts.less
@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 파일의 경로를 포함합니다.
예:
#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
styles.less 파일은 필수가 아닙니다. 즉, 사용자 지정 스타일, 변수 또는 mixin을 정의하지 않은 경우 이 파일을 만들 필요가 없습니다.
하지만 style.less 파일을 만들지 않은 경우 css.txt 파일에서 다음 줄의 주석 처리를 제거해야 합니다.
#base=less
다음 줄을 주석 처리합니다.
styles.less
적응형 양식 테마를 만든 후 다음 단계를 수행하여 적응형 양식에서 이 테마를 사용합니다.
에서 만든 테마를 포함하려면 적응형 양식 테마를 만들려면 섹션, 유형의 사용자 정의 페이지 만들기 cq:Component
.
예, /apps/myAfCustomizations/myAfPages/forestPage
추가 sling:resourceSuperType
속성 및 해당 값을 로 설정 fd/af/components/page/base
.
페이지의 테마를 사용하려면 재정의 파일 library.jsp를 노드에 추가해야 합니다.
그런 다음에서 만든 테마를 가져와서 이 문서의 적응형 양식 테마 섹션을 만듭니다.
다음 샘플 코드 조각은 af.theme.forest
테마.
<%@include file="/libs/fd/af/components/guidesglobal.jsp"%>
<cq:includeClientLib categories="af.theme.forest"/>
선택 사항: 사용자 지정 페이지에서 필요에 따라 header.jsp, footer.jsp 및 body.jsp를 재정의합니다.
사용자 지정 템플릿 만들기(예: /apps/myAfCustomizations/myAfTemplates/forestTemplate
)의 jcr:content가 이전 단계에서 생성된 사용자 지정 페이지를 가리킵니다(예: myAfCustomizations/myAfPages/forestPage)
.
이전 단계에서 만든 템플릿을 사용하여 적응형 양식을 만듭니다. 적응형 양식의 모양과 느낌은 이 문서의 적응형 양식 테마 섹션을 만들기에에서 만든 테마로 정의됩니다.