Grav-테마 사용자 지정
이 장에서는 Theme Customization. 테마를 사용자 지정하는 방법에는 여러 가지가 있습니다. Grav는 테마를 쉽게 사용자 지정할 수있는 다양한 기능과 몇 가지 기능을 제공합니다.
맞춤 CSS
당신은 자신을 제공 할 수 있습니다 custom.css테마를 사용자 지정하는 파일입니다. 반물질 주제는css/custom.css 사용을 통해 파일 Asset Manager. CSS 파일에 대한 참조가 없으면Asset ManagerHTML에 대한 참조를 추가하지 않습니다. Antimatter에서 CSS 파일 만들기css/폴더는 기본 CSS를 재정의합니다. 예를 들면-
custom.css
body a {
color: #FFFF00;
}
기본 링크 색상은 재정의되고 노란색으로 설정됩니다.
커스텀 SCSS / LESS
사용자 정의 CSS 파일을 제공하는 또 다른 방법은 custom.scss파일. SCSS (구문 론적으로 최고 스타일 시트) 는 통신, 변수, 중첩 된 구조, 수입, 파셜의 사용을 통해 효율적으로 CSS를 구축하고 믹스 인을 할 수있는 CSS 프리 프로세서입니다. 반물질은 SCSS를 사용하여 작성되었습니다.
SCSS를 사용하려면 SCSS 컴파일러가 필요합니다. 명령 줄 도구와 GUI 응용 프로그램을 사용하여 모든 플랫폼에 SCSS 컴파일러를 설치할 수 있습니다. 반물질은scss/ 모든 폴더를 .scss파일. 컴파일 된 파일은css-compiled/ 폴더.
그만큼 SCSS 파일은 다음 명령을 사용하여 수행 할 수있는 업데이트를 감시해야합니다.
scss --watch scss:css-compiled
위의 명령은 SCSS 컴파일러에게 scss라는 디렉토리를 감시하도록 지시합니다. css-compiled 폴더가 업데이트되면 SCSS 컴파일러가이를 컴파일해야합니다.
사용자 지정 SCSS 코드를 scss/template/_custom.scss파일. 이 파일에 코드를 보관하면 많은 이점이 있습니다.
SCSS 파일 및 기타 CSS 파일의 모든 업데이트는 css-compiled/template.css 파일
테마에서 사용되는 모든 SCSS에 액세스하고 사용할 수있는 모든 변수와 믹스 인을 사용할 수 있습니다.
보다 쉬운 개발을 위해 표준 SCSS의 모든 기능에 액세스 할 수 있습니다.
예 _custom.scss 파일은 다음과 같습니다-
body {
a {
color: darken($core-accent, 20%);
}
}
테마를 업그레이드하면 모든 사용자 지정 CSS가 무시됩니다. 이것은 테마를 사용자 정의하기 위해이 방법을 선택하는 주요 단점입니다. 이것은 테마 상속을 사용하여 해결할 수 있습니다.
테마 상속
Theme Inheritance테마를 수정하거나 사용자 정의하는 가장 좋은 방법이며 몇 가지 설정으로 수행 할 수 있습니다. 기본 아이디어는 테마가 상속되는 기본 테마로 정의되고 일부 비트 만 수정할 수 있고 나머지는 기본 테마에서 처리한다는 것입니다. 테마 상속 사용의 장점은 기본 테마가 업데이트 될 때마다 사용자 지정된 상속 된 테마가 직접 영향을받지 않는다는 것입니다. 이를 수행하려면 다음 단계를 수행해야합니다.
새 테마를 저장하려면 mytheme/ 내부 /user/themes/ 폴더.
다음으로 새 테마 YAML 파일을 만들어야합니다. mytheme.yaml 새로 만들어진 아래 /user/themes/mytheme/ 다음 내용이있는 폴더.
streams:
schemes:
theme:
type: ReadOnlyStream
prefixes:
'':
- user/themes/mytheme
- user/themes/antimatter
라는 YAML 파일을 만듭니다. blueprints.yaml 아래의 /user/themes/mytheme/ 다음 내용이있는 폴더.
name: MyTheme
version: 1.0.0
description: "Extending Antimatter"
icon: crosshairs
author:
name: Team Grav
email: [email protected]
url: http://getgrav.org
이제 테마를 정의하는 방법을 이해합니다. blueprints.yaml기본 요소로 구성됩니다. 양식 기능을 제어하기 위해 양식 정의에 대한 자세한 정보를 제공 할 수 있습니다. 그만큼blueprints.yaml 이에 대한 자세한 내용은 파일을 검토 할 수 있습니다.
당신의 user/config/system.yaml 파일 편집 pages: theme: 아래와 같이 기본 테마를 새 테마로 변경하는 옵션.
pages:
theme: mytheme
이제 새로운 테마가 생성되고 Antimatter가이 새로운 테마의 기본 테마가됩니다. mytheme테마. 특정 SCSS를 수정하려면 SCSS 컴파일러를 구성해야합니다.mytheme 주제는 먼저 반물질 주제입니다.
다음 설정을 사용합니다-
먼저 복사 template.scss 에 배치되는 파일 antimatter/scss/ 폴더에 붙여 넣으십시오. mytheme/scss/폴더. 이 파일에는@import 같은 다양한 파일에 대한 호출 template/_custom.scss 및 하위 파일.
그만큼 load-path ~에 중점을 두다 antimatter/scss/많은 수의 SCSS 파일이 포함 된 폴더. SCSS 컴파일러를 실행하려면 다음을 제공해야합니다.load-path to it as shown below.
scss --load-path ../antimatter/scss --watch scss:css-compiled
이제 _custom.scss 아래에 mytheme/scss/template/. 이 파일에는 모든 수정 사항이 포함됩니다.
사용자 지정 SCSS 파일이 변경되면 자동으로 모든 SCSS 파일이 template.css 아래에있는 mytheme/css-compiled/ 폴더와 Grav가이를 정확하게 참조합니다.