Grav-테마 기본 사항

테마는 Grav 사이트의 모양을 제어합니다. Grav의 테마는 강력한 Twig Templating 엔진으로 제작되었습니다 .

콘텐츠 페이지 및 나뭇 가지 템플릿

사용자가 만든 페이지는 이름으로 또는 페이지의 템플릿 헤더 변수를 설정하여 특정 템플릿 파일을 참조합니다. 보다 간단한 유지 관리를 위해 페이지 이름을 사용하는 것이 좋습니다.

Grav Base 패키지를 설치하면 defauld.mduser / pages / 01.home 폴더의 파일. 파일 이름, 즉,default Grav에게이 페이지가 나뭇 가지 템플릿으로 렌더링되어야한다고 알려줍니다. default.html.twig 내부에 배치 themes/<mytheme>/templates 폴더.

예를 들어 다음과 같은 파일이있는 경우 contact.md, 나뭇 가지 템플릿으로 렌더링됩니다. themes/<mytheme>/templates/contact.html.twig.

테마 구성

다음 섹션에서는 테마 구성, 즉 정의, 구성 등에 대해 설명합니다.

정의 및 구성

테마에 대한 정보는 user/themes/antimatter/blueprints.yaml관리 패널에서 사용할 파일 및 양식 정의가 선택적으로 제공됩니다. 다음 내용을 볼 수 있습니다.user/themes/antimatter/blueprints.yaml 파일 Antimatter theme.

name: Antimatter
version: 1.6.0
description: "Antimatter is the default theme included with **Grav**"
icon: empire
author:
   name: Team Grav
   email: [email protected]
   url: http://getgrav.org
homepage: https://github.com/getgrav/grav-theme-antimatter
demo: http://demo.getgrav.org/blog-skeleton
keywords: antimatter, theme, core, modern, fast, responsive, html5, css3
bugs: https://github.com/getgrav/grav-theme-antimatter/issues
license: MIT

form:
   validation: loose
   fields:
      dropdown.enabled:
         type: toggle
         label: Dropdown in navbar
         highlight: 1
         default: 1
         options:
            1: Enabled
            0: Disabled
         validate:
            type: bool

테마 구성 옵션을 사용하려면 다음과 같은 파일에 기본 설정을 제공해야합니다. user/themes/<mytheme>/<mytheme>.yaml.

Example

enable: true

테마 및 플러그인 이벤트

플러그인 아키텍처를 통해 Grav와 상호 작용하는 테마 기능은 Grav의 또 다른 강력한 기능입니다. 이를 달성하려면 간단히user/themes/<mytheme>/<mytheme>.php (예 : antimatter.php 기본 Antimatter 테마) 파일의 경우 다음 형식을 사용하십시오.

<?php
namespace Grav\Theme;

use Grav\Common\Theme;

class MyTheme extends Theme {
   public static function getSubscribedEvents() {
      return [
         'onThemeInitialized' => ['onThemeInitialized', 0]
      ];
   }
   public function onThemeInitialized() {
      if ($this->isAdmin()) {
         $this->active = false;
         return;
      }
      
      $this->enable([
         'onTwigSiteVariables' => ['onTwigSiteVariables', 0]
      ]);
   }
   public function onTwigSiteVariables() {
      $this->grav['assets']
         ->addCss('plugin://css/mytheme-core.css')
         ->addCss('plugin://css/mytheme-custom.css');

      $this->grav['assets']
         ->add('jquery', 101)
         ->addJs('theme://js/jquery.myscript.min.js');
   }
}

템플릿

Grav 테마의 구조에는 각각의 모든 페이지 유형 콘텐츠에 대해 templates / 폴더에 연결된 나뭇 가지 템플릿이 있어야한다는 점을 제외하고는 정해진 규칙이 없습니다.

페이지 콘텐츠와 나뭇 가지 템플릿 간의 긴밀한 결합으로 인해 다운로드 페이지 에서 사용할 수있는 스켈레톤 패키지를 기반으로 일반 테마를 만드는 것이 좋습니다 .

테마에서 모듈 식 템플릿을 지원하려면 다음을 만들어야합니다. modular/폴더에 나뭇 가지 템플릿 파일을 저장합니다. 양식을 지원하려면 다음을 만들어야합니다.form/ 폴더에 양식 템플릿을 저장합니다.

청사진

모든 단일 템플릿 파일에 대한 옵션 및 구성 양식을 정의하려면 blueprints/폴더가 사용됩니다. 이들은 다음을 통해 편집 할 수 없습니다.Administrator Panel선택적으로 사용됩니다. 이 테마는blueprints 폴더.

SCSS / 레스 / CSS

SASS 또는 LESS로 사이트를 개발하려면 다음 위치에 하위 폴더를 만들어야합니다. user/themes/<mytheme>/scss/, 또는 less/ css / 폴더와 함께 LESS를 원한다면.

SASS 또는 LESS에서 컴파일 된 자동 생성 파일의 경우 css-compiled/폴더가 사용됩니다. 반물질 테마에서scss SASS의 변형이 사용됩니다.

컴퓨터에 SASS를 설치하려면 다음 단계를 따르십시오.

  • 테마의 루트에서 아래에 주어진 명령을 입력하여 scss 쉘 스크립트를 실행하십시오.

$ ./scss.sh
  • 직접 실행하려면 다음 명령을 입력하십시오.
$ scss --sourcemap --watch scss:css-compiled

그만큼 css-compiled/ 컴파일 된 모든 scss 파일을 포함하고 css 파일이 테마 내에 생성됩니다.

기타 폴더

별도로 생성하는 것이 좋습니다. images/, fonts/js/ 귀하의 폴더 user/themes/<mytheme>/ 테마에 사용 된 이미지, 글꼴 및 JavaScript 파일을위한 폴더입니다.

테마 예

전체 폴더 구조 Antimatter 지금까지 논의한 테마는 아래와 같습니다.