μ΄ νν 리μΌμμλ Obsidianμ© ν λ§ κ°λ°μ μμνλ λ°©λ²μ λ°°μλλ€. ν λ§λ₯Ό μ¬μ©νλ©΄ CSSλ₯Ό μ¬μ©νμ¬ Obsidianμ λͺ¨μκ³Ό λλμ μ¬μ©μ μ μν μ μμ΅λλ€.
νμ΅ λ΄μ©
μ΄ νν 리μΌμ μλ£νλ©΄ λ€μμ ν μ μκ² λ©λλ€:
- Obsidian ν λ§ κ°λ°μ μν νκ²½ ꡬμ±
- CSS λ³μλ₯Ό μ¬μ©νμ¬ Obsidianμ λͺ¨μ λ³κ²½
- λΌμ΄νΈ λ° λ€ν¬ μμ ꡬμ±νλ₯Ό λͺ¨λ μ§μνλ ν λ§ λ§λ€κΈ°
νμ 쑰건
μ΄ νν 리μΌμ μλ£νλ €λ©΄ λ€μμ΄ νμν©λλ€:
- λ‘컬 λ¨Έμ μ μ€μΉλ Git
- Visual Studio Codeμ κ°μ μ½λ μλν°
1λ¨κ³: μν ν λ§ λ€μ΄λ‘λ
μ΄ λ¨κ³μμλ Obsidianμ΄ μ°Ύμ μ μλλ‘ λ³ΌνΈμ .obsidian
λλ ν 리 λ΄ themes
λλ ν 리μ μν ν
λ§λ₯Ό λ€μ΄λ‘λν©λλ€.
μ΄ νν 리μΌμμ μ¬μ©ν μν ν λ§λ GitHub μ μ₯μμμ μ¬μ©ν μ μμ΅λλ€.
-
ν°λ―Έλ μ°½μ μ΄κ³ νλ‘μ νΈ λλ ν 리λ₯Ό
themes
λλ ν λ¦¬λ‘ λ³κ²½ν©λλ€.cd path/to/vault/.obsidian/themes
-
Gitμ μ¬μ©νμ¬ μν ν λ§λ₯Ό 볡μ ν©λλ€.
git clone https://github.com/obsidianmd/obsidian-sample-theme.git "Sample Theme"
GitHub ν νλ¦Ώ μ μ₯μ
μν ν λ§μ μ μ₯μλ GitHub ν νλ¦Ώ μ μ₯μμ΄λ―λ‘ μν ν λ§μμ μμ λ§μ μ μ₯μλ₯Ό λ§λ€ μ μμ΅λλ€. λ°©λ²μ μμλ³΄λ €λ©΄ ν νλ¦Ώμμ μ μ₯μ λ§λ€κΈ°λ₯Ό μ°Έμ‘°νμΈμ.
μν ν λ§λ₯Ό 볡μ ν λλ μμ μ μ μ₯μ URLμ μ¬μ©νλ κ²μ μμ§ λ§μΈμ.
2λ¨κ³: ν λ§ νμ±ν
- Obsidianμμ μ€μ μ μ½λλ€.
- μ¬μ΄λ λ©λ΄μμ λͺ¨μμ μ νν©λλ€.
- ν λ§ μμ λλ‘λ€μ΄ λͺ©λ‘μμ Sample Themeμ μ νν©λλ€.
μν ν λ§λ₯Ό νμ±ννμ΅λλ€. λ€μμΌλ‘ λͺ κ°μ§ λ³κ²½ μ¬νμ μ μ©ν΄ λ³΄κ² μ΅λλ€.
3λ¨κ³: λ§€λνμ€νΈ μ λ°μ΄νΈ
μ΄ λ¨κ³μμλ λ§€λνμ€νΈ manifest.json
μ μ
λ°μ΄νΈνμ¬ ν
λ§ μ΄λ¦μ λ³κ²½ν©λλ€. λ§€λνμ€νΈμλ ν
λ§μ μ΄λ¦κ³Ό μ€λͺ
κ°μ μ λ³΄κ° ν¬ν¨λμ΄ μμ΅λλ€.
-
μ½λ μλν°μμ
manifest.json
μ μ½λλ€. -
name
μ"Disco Lights"
μ κ°μ μ¬μ©μ μΉνμ μΈ μ΄λ¦μΌλ‘ λ³κ²½ν©λλ€. -
themes
μλμ ν λ§ λλ ν 리 μ΄λ¦μ λμΌν μ΄λ¦μΌλ‘ λ³κ²½ν©λλ€. ν λ§ λλ ν 리 μ΄λ¦μmanifest.json
μname
μμ±κ³Ό μ νν μΌμΉν΄μΌ ν©λλ€.mv "Sample Theme" "Disco Lights"
-
λ§€λνμ€νΈμ μ λ³κ²½ μ¬νμ λ‘λνλ €λ©΄ Obsidianμ λ€μ μμν©λλ€.
μ€μ β λͺ¨μ β ν λ§λ‘ λμκ°μ ν λ§ μ΄λ¦μ΄ λ³κ²½λ κ²μ νμΈνμΈμ.
manifest.json
μ λ³κ²½ν λλ§λ€ Obsidianμ λ€μ μμνλ κ²μ μμ§ λ§μΈμ.
4λ¨κ³: κΈκΌ΄ λ³κ²½
Obsidianμ CSS λ³μλ₯Ό μ¬μ©νμ¬ μ¬μ©μ μΈν°νμ΄μ€λ₯Ό μ€νμΌλ§ν©λλ€. μ΄ λ¨κ³μμλ CSS λ³μλ₯Ό μ¬μ©νμ¬ μλν°μ κΈκΌ΄μ λ³κ²½ν©λλ€.
-
μλ₯Ό λ€μ΄ βν λ§ κ°λ°βμ΄λΌλ μ λ ΈνΈλ₯Ό λ§λλλ€.
-
λ ΈνΈμ λ€μ ν μ€νΈλ₯Ό μ λ ₯ν©λλ€:
ν λ§λ₯Ό μ¬μ©νλ©΄ [Obsidian](https://obsidian.md)μ μνλ λλ‘ κΎΈλ° μ μμ΅λλ€.
-
theme.css
μ λ€μμ μΆκ°ν©λλ€:body { --font-text-theme: Georgia, serif; }
μλν°λ μ μν κΈκΌ΄μ μ¬μ©νμ¬ λ ΈνΈλ₯Ό νμν©λλ€.
5λ¨κ³: λ°°κ²½μ λ³κ²½
ν
λ§λ λΌμ΄νΈ λ° λ€ν¬ μμ ꡬμ±νλ₯Ό λͺ¨λ μ§μν μ μμ΅λλ€. .theme-dark
λλ .theme-light
μλμ CSS λ³μλ₯Ό μ μνμΈμ.
-
theme.css
μ λ€μμ μΆκ°ν©λλ€:.theme-dark { --background-primary: #18004F; --background-secondary: #220070; } .theme-light { --background-primary: #ECE4FF; --background-secondary: #D9C9FF; }
-
Obsidianμμ μ€μ μ μ½λλ€.
-
λͺ¨μ μλμμ κΈ°λ³Έ μμ ꡬμ±νλ₯Ό βλΌμ΄νΈβμ βλ€ν¬β μ¬μ΄μμ μ νν©λλ€.
Obsidianμ΄ μ νν μμ ꡬμ±νμ λ°λΌ μμμ μ ννλ κ²μ λ³Ό μ μμ΅λλ€. λ κ·Ήμ μΈ λ³νλ₯Ό μν΄ μμμ red
, green
λλ blue
λ‘ λ³κ²½ν΄ 보μΈμ.
6λ¨κ³: μ λ ₯ νλ νΈλ² ν λ리 μμ λ³κ²½
:root
μ νμλ ν
λ§ λ΄μ λͺ¨λ μμ μμμμ λ³μμ μ‘μΈμ€νλ €λ κ²½μ° μΌλ°μ μΌλ‘ μ¬μ©λ©λλ€. μ΄ μ νμλ μ’
μ’
νλ¬κ·ΈμΈ λ³μλ‘ μ±μμ§λλ€.
μ¬μ©λ²μ μ€λͺ νλ μλ λ€μκ³Ό κ°μ΅λλ€:
Example
μ€μ λ° λ ΈνΈ λ΄μ©κ³Ό κ°μ΄ Obsidian λ΄ λ€μν μμΉμμ μ°Ύμ μ μλ μ λ ₯ νλλ₯Ό μκ°ν΄ λ³΄κ² μ΅λλ€. μ΄ μ λ ₯ νλμ νΉμ ν λ³μλ₯Ό μ μνλ €λ©΄
:root
μ νμλ₯Ό μ¬μ©ν μ μμ΅λλ€.:root { --input-focus-border-color: Highlight; --input-focus-outline: 1px solid Canvas; --input-unfocused-border-color: transparent; --input-disabled-border-color: transparent; --input-hover-border-color: black; /* 루νΈμ λν κΈ°λ³Έ μ λ ₯ λ³μ */ }
μ΄μ CSSμμ νΈλ² ν λ리 μμμ μμ ν΄ λ³΄κ² μ΅λλ€:
:root {
--input-hover-border-color: red;
/* κ²μμμμ λΉ¨κ°μμΌλ‘ λ³κ²½ */
}
μ΄ μ λ°μ΄νΈλ₯Ό ν΅ν΄ μ λ ₯ νλ μλ‘ λ§μ°μ€λ₯Ό κ°μ Έκ°λ©΄ ν λ리 μμμ΄ λ°μ λΉ¨κ°μμΌλ‘ λ³κ²½λ©λλ€.
Tip
λΌμ΄νΈ λ° λ€ν¬ ν λ§ λͺ¨λμμ λμΌνκ² μ μ§λμ΄μΌ νλ μ€νμΌμ μ μν λλ
body
μ νμλ₯Ό μ¬μ©νλ κ²μ΄ μ’μ΅λλ€.λΌμ΄νΈ λ° λ€ν¬ ν λ§ κ°μ μ νν λ μ€νμΌμ΄ λ³κ²½λκΈ°λ₯Ό μνλ κ²½μ°μλ§
.theme-dark
λλ.theme-light
μ νμλ₯Ό μ¬μ©νμΈμ.λν
:root
λ₯Ό μ μ€νκ³ κ³ λ €νμ¬ μ¬μ©νλ κ²μ΄ μ€μν©λλ€. λ³μλ₯Όbody
,.theme-dark
λλ.theme-light
μ νμ λ΄μ λ°°μΉν μ μλ€λ©΄ κ·Έλ κ² νλ κ²μ΄ μ’μ΅λλ€.
7λ¨κ³: μ¬μ© μ€μΈ CSS λ³μ μ°ΎκΈ°
Obsidianμ μ¬μ©μ μΈν°νμ΄μ€μ λ€μν λΆλΆμ μ¬μ©μ μ μνκΈ° μν΄ 400κ° μ΄μμ λ€μν CSS λ³μλ₯Ό λ ΈμΆν©λλ€. μ΄λ¬ν λ³μ μ€ λ€μλ CSS variablesμμ μ°Ύμ μ μμ΅λλ€.
λλ μ±μ κ²μ¬νμ¬ νΉμ μμλ₯Ό μ€νμΌλ§νλ λ° μ¬μ©λλ λ³μλ₯Ό μ°Ύμ μ μμ΅λλ€. μ΄ λ¨κ³μμλ 리본 λ°°κ²½μ λ³κ²½νκΈ° μν CSS λ³μλ₯Ό μ°Ύμ΅λλ€.
- Obsidianμμ
Ctrl
+Shift
+I
(macOSμμλCmd
+Option
+I
)λ₯Ό λλ¬ κ°λ°μ λꡬλ₯Ό μ½λλ€. - μμ€ νμ μ½λλ€.
- νμ΄μ§ β top β obsidian.md μλμμ app.cssλ₯Ό μ νν©λλ€.
app.css
μ 맨 μλ‘ μ€ν¬λ‘€νμ¬ μ¬μ© κ°λ₯ν λͺ¨λ CSS λ³μλ₯Ό μ°Ύμ΅λλ€.Ctrl
+F
(macOSμμλCmd
+F
)λ₯Ό λλ₯΄κ³ β βribbon-βμ μ λ ₯νμ¬ λ¦¬λ³Έκ³Ό κ΄λ ¨λ λ³μλ₯Ό κ²μν©λλ€. λ κ°μ 곡백μ μ¬μ©μ²κ° μλ μ μλ₯Ό λ°νν©λλ€.
κ²°κ³Ό μ€ νλλ --ribbon-background
μ΄λ©°, μ λ§ν΄ 보μ
λλ€. νμ€ν νλ €λ©΄ HTMLμ κ²μ¬νμ¬ νΉμ μμμμ μ¬μ©νλ CSS λ³μλ₯Ό μ°Ύμ μλ μμ΅λλ€.
- κ°λ°μ λꡬμ μΌμͺ½ μλ¨ λͺ¨μ리μμ μ¬κ°ν μμ 컀μκ° μλ μμ΄μ½μ μ νν©λλ€.
- Obsidian μ°½ μΌμͺ½μ 리본 μ€μμ μ νν©λλ€.
κ°λ°μ λꡬ μ€λ₯Έμͺ½μ μ€νμΌ νμμ μ νν μμμ μ μ©λ CSS(μ: background-color: var(--ribbon-background)
)λ₯Ό λ³Ό μ μμ΅λλ€.
μ΄μ --ribbon-background
κ° λ¦¬λ³Έ λ°°κ²½μμ μ μ΄νλ€λ κ²μ μμμΌλ―λ‘ theme.css
μ λ€μμ μΆκ°ν©λλ€:
body {
--ribbon-background: magenta;
}
κ²°λ‘
μ΄ νν 리μΌμμλ 첫 λ²μ§Έ Obsidian ν λ§λ₯Ό λ§λ€μμ΅λλ€. ν λ§λ₯Ό μμ νκ³ λ€μ λ‘λνμ¬ Obsidian λ΄μμ λ³κ²½ μ¬νμ λ°μνμ΅λλ€. λν μ¬μ©μ μΈν°νμ΄μ€μ νΉμ λΆλΆμ μ€νμΌλ§νκΈ° μν CSS λ³μλ₯Ό μ°Ύλ λ°©λ²λ λ°°μ μ΅λλ€.