Table of contents
스킨 제작 방법
스킨 타겟
이 문서는 스킨 생성 커맨드를 사용한 보편적인 방법의 스킨 제작 방법을 설명합니다.
스킨은 항상 그 스킨이 사용되는 대상(타겟)이 있습니다. 예를 들어 게시판 스킨은 게시판이 대상이 되며, 회원 프로필 스킨은 회원 프로필 컨트롤러가 대상이 됩니다. 또 특정 위젯이 대상이 될 수도 있습니다. 게시판, 회원 프로필 컨트롤러, 위젯과 같이 스킨이 적용되는 대상을 '스킨 타겟'이라고 합니다. 모든 스킨은 스킨 타겟을 반드시 지정해야 합니다.
XE의 구성요소중 HTML을 출력하는 모든 구성요소는 스킨 타겟이 될 수 있습니다. 스킨 타겟은 HTML을 출력할 때, 스킨 시스템이 적용될 수 있도록 구현되어야 하며, 스킨 타겟 아이디를 지정해 주어야 합니다.
빈 스킨생성 (터미널 환경)
스킨 생성 커맨드를 사용하려면 우선 스킨이 소속될 플러그인이 마련되어 있어야 합니다. 아직 플러그인이 준비되지 않았다면, 플러그인 개발 시작하기 문서를 참고하여 플러그인을 생성하길 바랍니다. 또, 스킨 타겟의 아이디를 미리 알고 있어야 합니다.
소속될 플러그인과 스킨 타겟 아이디가 준비되었다면 아래 커맨드를 사용하여 빈 스킨을 생성합니다.
$ php artisan make:skin <plugin> <name> <target>
plugin
는 스킨 소속될 플러그인입니다. 플러그인이 위치한 디렉토리 이름을 입력해줍니다.
name
에는 스킨의 제목을 지정해 주십시오. 지정한 스킨 제목은 스킨 선택시 스킨의 이름으로 표시됩니다.
target
는 스킨 타겟 아이디를 지정해주십시오.
만약 my_plugin
플러그인(플러그인 개발 시작하기의 예제를 그대로 사용합니다.)에 스킨을 넣고, 스킨 이름을 나만의 프로필 스킨
으로 지정하고 싶다면, 아래와 같이 커맨드를 실행하시면 됩니다. 커맨드를 실행하면 생성되는 스킨의 개략적인 정보를 터미널에서 볼 수 있습니다. 회원 프로필 컨트롤러의 스킨 타겟 아이디는 member/profile
입니다.
$ php artisan make:skin my_plugin Profile member/profile
[New skin info]
plugin: my_plugin
path: src/Skins/Profile
class file: src/Skins/Profile/ProfileSkin.php
class name: GilDongHong\XePlugin\MyPlugin\Skins\Profile\ProfileSkin
id: member/profile/skin/my_plugin@profile
title: Profile Skin
description: The Skin supported by My_plugin plugin.
Do you want to add skin? [yes|no]:
> yes
Generating autoload files
Skin is created successfully.
빈 스킨생성 (웹 환경)
스킨 컴포넌트 아이디
스킨도 컴포넌트이므로 컴포넌트 아이디를 가지고 있어야 합니다. 스킨의 컴포넌트 아이디는 아래 규칙을 따라야 합니다.
<skin_target_id>/skin/<plugin_id>@<pure_id>
위의 예시에서 생성한 스킨의 아이디는 member/profile/skin/my_plugin@profile
입니다.
스킨 등록
스킨 생성 커맨드를 사용할 경우, 자동으로 스킨을 등록해 줍니다. 플러그인의 composer.json
파일에 아래와 같이 컴포넌트 정보가 등록되어 있습니다.
// plugins/my_plugin/composer.json
...
"extra": {
"xpressengine": {
"title": "my plugin",
"component": {
"member/profile/skin/my_plugin@profile": {
"name": "Profile skin",
"description": "The skin supported by My_plugin plugin.",
"class": "GilDongHong\\XePlugin\\MyPlugin\\Skins\\Profile\\ProfileSkin"
}
}
}
}
autoload
항목을 생성하지 않아도 src폴더안에 skin이 배치되어있기 때문 플러그인에서 자동으로 class를 로드합니다.
스킨의 출력
하나의 스킨은 하나 이상의 페이지의 출력을 담당할 수 있습니다. 출력하는 페이지의 갯수는 스킨 타겟에 따라 다릅니다. 게시판의 경우, 글보기, 글쓰기, 글목록 등의 페이지를 가지고 있는데, 스킨은 게시판이 필요로 하는 모든 페이지의 출력을 담당합니다.