jointrashposs/content/ko/docs/2.for-users/3.features/theme.md
かっこかり ab4fea3e7e
New Crowdin updates (#86)
* New translations ubuntu-manual.md (Korean)

* New translations 1.index.md (Korean)

* New translations endpoints.md (Korean)

* New translations 1.index.md (Korean)

* New translations silence.md (Korean)

* New translations theme.md (Korean)

* New translations thread-mute.md (Korean)

* New translations timeline.md (Korean)

* New translations webhook.md (Korean)

* New translations widgets.md (Korean)

* New translations word-mute.md (Korean)

* New translations 1.troubleshooting.md (Korean)

* New translations apps.md (Korean)

* New translations donate.md (Korean)

* New translations faq.md (Korean)

* New translations glossary.md (Korean)

* New translations misskey-hub.md (Korean)

* New translations kubernetes.md (Korean)

* New translations cdn.md (Korean)

* New translations nginx.md (Korean)

* New translations push-docker-hub.md (Korean)

* New translations scale-out.md (Korean)

* New translations troubleshooting.md (Korean)

* New translations disable-timelines.md (Korean)

* New translations 1.index.md (Korean)

* New translations libraries.md (Korean)

* New translations permission.md (Korean)

* New translations note-capture-events.md (Korean)

* New translations token.md (Korean)

* New translations 1.index.md (Korean)

* New translations create-plugin.md (Korean)

* New translations plugin-api-reference.md (Korean)

* New translations publish-on-your-website.md (Korean)
2023-12-27 12:38:56 +09:00

111 lines
4.2 KiB
Markdown

# 테마
테마를 설정하여 Misskey 클라이언트의 외관을 변경할 수 있습니다.
## 테마 설정
설정 > 테마
## 테마 만들기
테마 코드는 JSON5로 작성된 테마 객체입니다.
테마는 다음과 같은 객체입니다.
```js
{
id: '17587283-dd92-4a2c-a22c-be0637c9e22a',
name: 'Danboard',
author: 'syuilo',
base: 'light',
props: {
accent: 'rgb(218, 141, 49)',
bg: 'rgb(218, 212, 190)',
fg: 'rgb(115, 108, 92)',
panel: 'rgb(236, 232, 220)',
renote: 'rgb(100, 152, 106)',
link: 'rgb(100, 152, 106)',
mention: '@accent',
hashtag: 'rgb(100, 152, 106)',
header: 'rgba(239, 227, 213, 0.75)',
navBg: 'rgb(216, 206, 182)',
inputBorder: 'rgba(0, 0, 0, 0.1)',
},
}
```
- `id` ... 테마의 고유 ID.UUID를 추천합니다.
- `name` ... 테마 이름
- `author` ... 테마 제작자
- `desc` ... 테마 설명(옵션)
- `base` ... 밝은 테마인지, 어두운 테마인지
- light로 하면 밝은 테마가 되고, dark로 하면 어두운 테마가 됩니다.
- 테마는 여기서 상속된 베이스 테마를 기준으로 합니다.
- `props` ... 테마 스타일 정의。 이제부터 설명하겠습니다.
### 테마 스타일 정의
`props` 아래에는 테마의 스타일을 정의합니다.
키가 CSS의 변수명이 되고, 값으로 내용을 지정합니다.
참고로 이 `props` 객체는 베이스 테마에서 상속됩니다.
베이스 테마는 이 테마의 `base``light`라면 [\_light.json5][_light.json5]이고, `dark`라면 [\_dark.json5][_dark.json5]입니다.
즉, 이 테마 내의 `props``panel`이라는 키가 없어도 거기에는 베이스 테마의 `panel`이 있는 것으로 간주합니다.
[_light.json5]: https://github.com/misskey-dev/misskey/blob/develop/packages/frontend/src/themes/_light.json5
[_dark.json5]: https://github.com/misskey-dev/misskey/blob/develop/packages/frontend/src/themes/_dark.json5
#### 값으로 사용할 수 있는 구문
- 16진수로 표현된 색
- 예: `#00ff00`
- `rgb(r, g, b)` 형식으로 나타낸 색
- 예: `rgb(0, 255, 0)`
- `rgb(r, g, b, a)` 형식으로 표현된 투명도를 포함한 색상
- 예: `rgba(0, 255, 0, 0.5)`
- 다른 키 값 참조
- `@{키 이름}`이라고 쓰면 다른 키의 값을 참조하게 됩니다.`{키 이름}`은 참조하고자 하는 키의 이름으로 대체됩니다.
- 예: `@panel`
- 상수(후술)의 참조
- `${상수명}`이라고 쓰면 상수 참조가 됩니다.`{상수 이름}`은 참조하고자 하는 상수의 이름으로 대체됩니다.
- 예: `$main`
- 함수(후술)
- `:{함수명}<{인수}<{색상}`
#### 상수
'CSS 변수로 출력하고 싶지 않지만 다른 CSS 변수의 값으로 사용하고 싶은' 값이 있을 때는 상수를 사용하면 편리합니다.
키 이름을 `$`로 시작하면 해당 키는 CSS 변수로 출력되지 않습니다.
#### 함수
'버튼 위에 커서를 올렸을 때만 색상을 밝게 하고 싶다'와 같이 기존 색상에서 조금 변경된 색상을 사용하고 싶을 때 이 함수를 사용하면 편리합니다.
`:{함수명}<{인수}<{색상이나 다른 키 참조}`의 형태로 사용할 수 있습니다.
```js
props: {
accent: '#86b300',
accentDarken: ':darken<10<#86b300',
accentLighten: ':lighten<10<@accent'
}
```
##### 사용 가능한 함수
- `lighten` ... 전달받은 색의 밝기(0\~100)에 인수(0\~100)를 더한 색을 반환합니다.
- `darken` ... 전달받은 색의 밝기(0\~100)에 인수(0\~100)를 뺀 색을 반환합니다.
- `alpha` ... 전달받은 색의 투명도를 인수(0.0 \~ 1.0)로 설정한 색을 반환합니다.
- 0.0이면 완전히 투명하고 1.0이면 완전히 불투명합니다.
- `hue` ... 전달받은 색상의 색조(-360 \~ 360)에 대해 인수(-360 \~ 360)의 값만큼 회전시킨 색을 반환합니다.
- `saturate` ... 전달받은 색의 채도(0\~100)에 인수(0\~100)를 더한 색을 반환합니다.
## 테마 배포하기
v2023.11.0 이상에서는 웹 사이트에서 클릭 한 번으로 직접 테마를 설치할 수 있습니다.
테마 설치 기능을 제공하는 경우, 여러분의 사이트에 API를 구현해야 합니다.자세한 내용은 [여기](../../for-developers/publish-on-your-website/)에서 확인할 수 있습니다.