Grav-청사진

Blueprints리소스에 대한 메타 데이터 정보 (정보 출처)입니다. 그것은 두 가지 목적을 제공합니다-

  • 첫 번째는 리소스 ID 자체입니다.
  • 두 번째는 양식에 관한 것입니다.

이 완전한 정보는 각 플러그인 또는 테마 에있는 blueprints.yaml 파일에 저장됩니다 .

자원 아이덴티티

에서 blueprints.yaml 파일의 정체성 각 테마와 플러그인에 대한 정의된다. 청사진이 완벽하게 포맷되고 컴파일되지 않으면 리소스가 Grav 저장소에 추가되지 않습니다.

청사진 예

name: plugin name
version: 0.6.0
description: Adds an advanced plugin to manage your site
icon: empire
author:
   name: Team Grav
   email: [email protected]
   url: http://getGrav.org
homepage: https://github.com/getGrav/Grav-plugin-assets
keywords: assets, plugin, manager, panel
bugs: https://github.com/getGrav/Grav-plugin-assets/issues
readme: https://github.com/getGrav/Grav-plugin-assets/blob/develop/README.md
license: MIT

dependencies:
   - form
   - email
   - login

form:
   validation: loose
   fields:
      Basics:
         type: section
         title: Basics
         underline: false
      enabled:
         type: hidden
         label: Plugin status
         highlight: 1
         default: 0
         options:
            1: Enabled
            0: Disabled
         validate:
            type: bool

다음 몇 가지 속성은 선택 사항이며 일부는 ID와 리소스를 제공하는 데 사용됩니다.

Sr. 아니. 속성 및 설명
1

name*

자원의 이름을 언급하십시오.

2

version*

자원의 버전을 지정합니다.

description*

자원에 대한 간략한 설명을 제공합니다. 200자를 초과 할 수 없습니다.

4

icon*

새 테마 또는 플러그인을 개발하기위한 아이콘 라이브러리를 지정합니다.

5

author.name*

개발자의 이름을 지정합니다.

6

author.email (optional)

개발자의 이메일 주소를 지정합니다.

7

author.url (optional)

개발자의 URL 홈페이지를 지정합니다.

8

homepage (optional)

리소스의 홈페이지에 할당 된 URL을 지정합니다.

9

docs (optional)

리소스에 대해 작성한 문서 링크를 지정합니다.

10

demo (optional)

데모 리소스의 링크를 지정합니다.

11

guide (optional)

리소스에 대한 안내 또는 자습서 링크를 지정합니다.

12

keywords (optional)

리소스와 관련된 키워드 목록을 지정합니다.

13

bugs (optional)

문제 또는 버그를보고 할 수있는 URL을 지정합니다.

14

license (optional)

리소스 라이선스 (예 : MIT, GPL 등)를 지정합니다.

15

dependencies (optional)

플러그인 또는 테마에 필요한 종속성의 이름을 지정합니다.

다음은 로그인 플러그인 청사진의 예입니다.

name: Login
version: 0.3.3
description: Enables user authentication and login screen.
icon: sign-in
author:
   name: Team Grav
   email: [email protected]
   url: http://getGrav.org
keywords: admin, plugin, login
homepage: https://github.com/getGrav/Grav-plugin-login
keywords: login, authentication, admin, security
bugs: https://github.com/Getgrav/Grav-plugin-login/issues
license: MIT

양식

테마 또는 플러그인에 관리자 인터페이스에서 직접 구성 가능한 옵션이 있도록 하려면 blueprints.yaml 파일을 양식으로 채울 수 있습니다 . 이 리소스의 일부는Admin Plugin에 의해 정의되는 Forms 메타 데이터.

다음은 Archives Plugin archives.yaml 파일 의 예입니다 .

enabled: true
built_in_css: true
date_display_format: 'F Y'
show_count: true
limit: 12
order:
   by: date
   dir: desc
filter_combinator: and
filters:
   category: blog

이것은 플러그인의 기본 설정입니다. 관리자 플러그인을 사용하지 않고 구성하려면 사용자는이 파일을/user/config/plugins/archives.yaml폴더를 열고 변경하십시오. archives.yaml 파일을 올바르게 제공 할 수 있습니다 . 사용자의 관리 인터페이스에서 설정을 변경하도록 선택할 수 있습니다.

변경 사항을 저장하면 자동으로 <your_folder_name>/user/config/plugins/archives.yaml.

Archives Plugin 의 blueprint.yaml 파일에는 다음과 같은 구조가 포함되어 있습니다.

name: Archives
version: 1.3.0
description: The **Archives** plugin creates links for pages grouped by month/year
icon: university
author:
   name: Team Grav
   email: [email protected]
   url: http://getGrav.org
homepage: https://github.com/getGrav/Grav-plugin-archives
demo: http://demo.getGrav.org/blog-skeleton
keywords: archives, plugin, blog, month, year, date, navigation, history
bugs: https://github.com/getGrav/Grav-plugin-archives/issues
license: MIT

form:
   validation: strict
   fields:
      enabled:
         type: toggle
         label: Plugin status
         highlight: 1
         default: 1
         options:
            1: Enabled
            0: Disabled
         validate:
            type: bool

      date_display_format:
         type: select
         size: medium
         classes: fancy
         label: Date Format
         default: 'jS M Y'
         options:
            'F jS Y': "January 1st 2014"
            'l jS of F': "Monday 1st of January"
            'D, m M Y': "Mon, 01 Jan 2014"
            'd-m-y': "01-01-14"
            'jS M Y': "10th Feb 2014"

      limit:
         type: text
         size: x-small
         label: Count Limit
         validate:
            type: number
            min: 1

      order.dir:
         type: toggle
         label: Order Direction
         highlight: asc
         default: desc
         options:
            asc: Ascending
            desc: Descending

다음은 archive.yaml 에있는 양식 요소 입니다.

Toggle

enabled:
   type: toggle
   label: Plugin status
   highlight: 1
   default: 1
   options:
      1: Enabled
      0: Disabled
   validate:
      type: bool

Select

date_display_format:
   type: select
   size: medium
   classes: fancy
   label: Date Format
   default: 'jS M Y'
   options:
      'F jS Y': "January 1st 2014"
      'l jS of F': "Monday 1st of January"
      'D, m M Y': "Mon, 01 Jan 2014"
      'd-m-y': "01-01-14"
      'jS M Y': "10th Feb 2014"

Text

limit:
   type: text
   size: x-small
   label: Count Limit
   validate:
      type: number
      min: 1

루트 요소 Enabled, date_display_formatlimit 가 옵션입니다. 이 루트 요소에있는 필드는 유형, 크기, 레이블, 기본값 및 옵션을 결정합니다. 필드 유형에 따라 다른 필드가 변경 될 수 있습니다. 예를 들어 선택 필드에는 옵션 목록이 필요합니다.

Order direction

order.dir:
   type: toggle
   label: Order Direction
   highlight: asc
   default: desc
   options:
      asc: Ascending
      desc: Descending

이 필드는 중첩 된 옵션으로 구성됩니다. plugins / admin / themes / Grav / templates / forms / fields 에서 사용할 수있는 많은 필드 유형이 있습니다 . archive.yaml 파일 에서 볼 수 있듯이 양식 유효성 검사는 엄격으로 설정됩니다. 유효성 검사가 엄격으로 설정되면 모든 옵션에 대해 청사진 양식을 추가해야합니다. 그렇지 않으면 저장하는 동안 오류가 표시됩니다. form.validation은 당신이 관리자 인터페이스 만 두 필드를 정의 할 때 느슨한로 설정할 수 있습니다.

다음 표는 위의 양식 요소와 관련된 필드에 대한 간략한 설명을 제공합니다.

Sr. 아니. 필드 및 설명
1

Type

필드 유형을 나타냅니다.

2

Size

필드의 크기를 지정합니다.

Label

필드에 레이블을 지정합니다.

4

Validate

필드 유형과 필드에 입력 된 최소 길이를 확인합니다.

5

Default

기본 필드를 설정합니다.

6

Options

옵션 목록을 지정합니다.

7

Classes

필드의 클래스를 지정합니다.

관리자에서 사용할 수있는 양식 필드

플러그인 및 테마에서 사용하거나 자체 양식 필드를 만들 수있는 사용 가능한 기본 제공 양식 필드가 많이 있습니다. 다음 표는 사용 가능한 양식 필드를 나열합니다.

공통 양식 필드

Sr. 아니. 필드 및 설명
1

Checkbox

단일 확인란을 표시합니다.

2

Checkboxes

체크 박스 목록을 표시합니다.

Date

날짜 필드를 포함합니다.

4

Datetime

날짜 및 시간 필드를 포함합니다.

5

Email

유효성 검사가있는 이메일 주소 필드를 포함합니다.

6

Password

점 형식으로 표시되는 암호 필드를 포함합니다.

7

Hidden

숨겨진 입력 필드를 포함합니다.

8

Radio

목록에서 하나의 옵션 만 선택할 수 있습니다.

9

Select

이 필드에는 몇 가지 옵션이 있습니다.

10

Spacer

양식에 제목, 텍스트 또는 수평선을 추가합니다.

11

Text

일반 텍스트 필드를 포함합니다.

12

Textarea

여러 줄 텍스트 입력을 포함합니다.

특수 양식 필드

Sr. 아니. 필드 및 설명
1

Array

여러 키 값 행을 추가합니다.

2

Ignore

사용하지 않는 필드는 제거됩니다.

Columns

양식을 여러 열로 나눕니다.

4

Column

단일 열을 표시합니다.

5

Dateformat

날짜 및 시간 형식을 설정합니다.

6

Display

입력 값없이 텍스트 값을 표시합니다.

7

Frontmatter

페이지는 원시 형식으로 표시됩니다.

8

List

키가없는 항목 목록을 표시합니다.

9

Markdown

마크 다운 편집기를 표시합니다.

10

Pages

페이지 목록을 표시합니다.

11

Section

설정 페이지는 섹션으로 나뉘며 각 섹션에는 제목이 있습니다.

12

Selectize

상자를 선택하는 데 사용됩니다.

13

Tabs

설정은 탭 목록으로 나뉩니다.

14

Tab

탭 필드는 탭을 제공하는 데 사용합니다.

15

Taxonomy

분류를 선택하도록 미리 구성된 선택입니다.

16

Toggle

입력의 on 또는 off 유형을 지정하는 토글 효과를 나타냅니다.