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_format 및 limit 가 옵션입니다. 이 루트 요소에있는 필드는 유형, 크기, 레이블, 기본값 및 옵션을 결정합니다. 필드 유형에 따라 다른 필드가 변경 될 수 있습니다. 예를 들어 선택 필드에는 옵션 목록이 필요합니다.
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 | 유효성 검사가있는 이메일 주소 필드를 포함합니다. |
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 유형을 지정하는 토글 효과를 나타냅니다. |