์ํ์ฝ๋ฉ ๋ง์ธ๋๋งต ๋ผ์ด๋ธ๋ฌ๋ฆฌ cytoscape ์ฌ์ฉ๋ฒ
๐ ๋ฐ๋จ
์ํ์ฝ๋ฉ์ ์ ์ํด์ ์์ ์๊ฐ ์น์ ์ผ๋ก ๊ฐ๋ฉด ์์ ๊ฐ์ ๊ด๊ณ๋ฅผ ํ์ธํ ์ ์๋ ๋ง์ธ๋ ๋งต์ด ์์ต๋๋ค.
๊ฐ์ธ์ ์ผ๋ก ๊ณต๋ถํ ๊ฒ๋ค์ ํ๋ฆ์ ์์ ๊ฐ์ด ์ ๋ฆฌํ๋ฉด ์ข์ ๊ฒ ๊ฐ์์ต๋๋ค.
๊ทธ๋์ ํด๋น ๋ผ์ด๋ธ๋ฌ๋ฆฌ๊ฐ cytoscape๋ผ๋ ๊ฒ์ ํ์ธ ํ ์ด๋ฅผ ํ์ฉํด ๋น์ทํ ์ฌ์ดํธ๋ฅผ ๊ฐ๋ฐ์ ํด๋ดค์ต๋๋ค.
๊ทธ๋ฌ๋ cytoscape ๊ด๋ จํ ๋ณ๋์ ํ๊ธ ์ ๋ณด๊ฐ ์์ด ์์ด๋ฅผ ์ ๋ชปํ๋ ์ ๋ ์๋ง์ ์ฝ์ง์ ์๊ฐ์ ๊ฑฐ์ณ์ผ ํ๊ธฐ์ ๋ค๋ฅธ ๋ถ๋ค์ ํด๋น ๋ผ์ด๋ธ๋ฌ๋ฆฌ๋ฅผ ์ข ๋ ํธํ๊ฒ ์ฐ์ค ์ ์๋๋ก ๊ฐ๋ฐํ๋ฉด์ ์๊ฒ ๋ ๊ฒ๋ค์ ํ๊ธ๊ธฐ๋ก์ผ๋ก ๋จ๊น๋๋ค. ๋์์ด ๋์์ผ๋ฉด ์ข๊ฒ ์ต๋๋ค!
๐งต ์ด๊ธฐ ์ค์
ํด์ Visual Studio Code ๊ธฐ์ค์ผ๋ก ์ค๋ช
๋๋ฆฌ๊ณ NPM์ ์ค์น๋์ด ์๋ค๊ณ ๊ฐ์ ํ๊ฒ ์ต๋๋ค.
๋จผ์ ํ์ํ ํจํค์ง๋ฅผ ์ค์นํด์ผ ํฉ๋๋ค. ํฐ๋ฏธ๋์ ์ด์ด์
npm init -y
๋ก ์ด๊ธฐํ ํ ํ
npm install @babel/core @babel/preset-env @babel/preset-react babel-loader clean-webpack-plugin css-loader html-loader file-loader html-webpack-plugin mini-css-extract-plugin webpack webpack-cli webpack-dev-server cytoscape
๋ฅผ ์ ๋ ฅํด ํ์ํ ํจํค์ง๋ค์ ์ค์นํด ์ค๋๋ค. ๊ทธ ๋ค์์
์์ ๊ฐ์ด ๊ฒฝ๋ก๋ฅผ ๊ตฌ์ฑํ๊ณ ํ์ผ์ ์์ฑํฉ๋๋ค. ๋ด์ฉ์ ์๋์ ๊ฐ์ต๋๋ค.
index.html
style.css
index.js
.babelrc
// .babelrc
{
"presets": [
"@babel/preset-env"
]
}
.gitignore
node_modules
package.json
webpack.config.js
์์ ๊ฐ์ด ์ค์ ํด ์ค ๋ค์
npm run start
์์ ํค์๋๋ฅผ ์ ๋ ฅํ ํ http://localhost:9000/ ๋ก ์ ์ํ๋ฉด
์์ ๊ฐ์ ํ๋ฉด์ด ์ถ๋ ฅ๋๊ณ , ์ด๋ฌ๋ฉด ์ด์ ์ธํ ์ ๋๋ฌ์ต๋๋ค.
๐ฅ cytoscape ํ์ฉ๋ฒ
๐น ๋ฐ์ดํฐ ๊ตฌ์ฑ
cytoscape๋ฅผ ํ์ฉํ๊ธฐ ์ํด์ ๋จผ์ node์ edge๋ฅผ ๊ตฌ์ฑํด์ผ ํฉ๋๋ค.
๋จผ์ ๊ฑฐ์ ์ด ๋๋ node๋
"data": {
"id": 'id',
"url": '๋งํฌ๊ฑธ๊ณ ์ถ์ ์ฃผ์(์ต์
)'
"label": 'ํ์ํ๊ณ ์ถ์ ๋ด์ฉ(์ต์
)'
}
์ ๊ฐ์ ํํ๋ก ๊ตฌ์ฑํด์ฃผ๋ฉด ๋๊ณ ์ฐ๊ฒฐ์ ์ธ edge๋
"data": {
"id": 'id',
"source": '์ฐ๊ฒฐํ ๋
ธ๋ ์ค ํ์์ ๋ node id',
"target":'์ฐ๊ฒฐํ ๋
ธ๋ ์ค ์์์ ๋ node id'
}
ํํ๋ก ์ ๋ ฅํ๋ฉด ๋ฉ๋๋ค.
source์ ํ์์ ๋ node๋ฅผ, target์ ์์์ ๋ node๋ฅผ ๋ฌ์ผ ํ๋ค๋ ๋ถ๋ถ์ด ์์ํ์ค ํ ์ง๋ง(์ ๋ ์ด๊ฒ ์ด์ํ์ต๋๋ค) ๊ทธ ์ด์ ๋ ์ ์ ํ 'depth์ ๋ฐ๋ผ node์ ํฌ๊ธฐ๋ฅผ ๋ค๋ฅด๊ฒ' ์ฑํฐ์์ ํ์ธํ์ค ์ ์์ต๋๋ค.
๊ทธ ์ธ์ ์ฃผ์ํ ์ ์ id์ ๊ณต๋ฐฑ๊ณผ .์ด ํฌํจ๋๋ฉด ์๋ฉ๋๋ค. ํฌํจํด๋ ๋น์ฅ ๋ ๋๋ง์ ๋ฌธ์ ๊ฐ ์์ง๋ง ํฌํจ๋์ด ์์ผ๋ฉด cytoscape๊ฐ ์ ๊ณตํ๋ ํจ์ ์ค id๋ก node๋ฅผ ๊ฒ์ํ๋ ํจ์๋ฅผ ์ธ ๋ ์๋ฌ๊ฐ ๋๋ ํฌํจํ์ง ๋ง์๋ค.
์ด ์ ์ ์ฃผ์ํด์ node์ edge๋ฅผ ๊ตฌ์ฑํ ํ ๋ฐฐ์ด๋ก cytoscape ํจ์ ๋ด๋ถ์ elements ๋ถ๋ถ์ ์ ๋ ฅํด์ฃผ๋ฉด ๋ฉ๋๋ค. ์ ํ์์ ๋ฐ๋ผ ๊ตฌ์ฑํ๊ณ ์ ๋ ฅํ ์์ค๋ ์๋์ ๊ฐ์ต๋๋ค.
๊ทธ๋ฌ๋ ์์ ๊ฐ์ด ์ ๋ ฅํ๋ฉด
๋ณด๋ค์ํผ ํ๋ฉด์ด seomal.org์์ ๋ณด๋ ๊ฒ๊ณผ๋ ๋ง์ด ๋ค๋ฅธ ํ๋ฉด์ด ๋์ต๋๋ค. ์ฐจ๊ทผ ์ฐจ๊ทผ ์ซ์๊ฐ ๋ด ์๋ค.
๐ id๊ฐ ์๋ ๋ผ๋ฒจ์ด ํ์๋๊ฒ
๋จผ์ node ์์ id๊ฐ ์๋ ์ฐ๋ฆฌ๊ฐ ์ ๋ ฅํ ๋ผ๋ฒจ์ด ํ์๋๋๋ก ํด๋ด ์๋ค. ๋ฐฉ๋ฒ์ ๊ฐ๋จํฉ๋๋ค. index.js ํ๋จ style ์ชฝ์์ node์ style์ ์ค์ ํ๋ ๋ถ๋ถ์ ๋ณด๋ฉด label์ด data(id)๋ก ๋์ด ์๋๋ฐ ์ด๊ฑธ data(label)๋ก ๋ฐ๊ฟ์ฃผ๋ฉด
id๊ฐ ์๋ label์ด node์ ์ด๋ฆ์ผ๋ก ๋์ค๋ ๊ฑธ ๋ณผ ์ ์์ต๋๋ค.
๐ edge styling
๋ค์์ผ๋ก๋ edge์ ์คํ์ผ๋ง์ ํด๋ณด์ฃ . ๋จผ์ edge์ ๋ฐฉํฅ์ ํ์ํด๋ด ์๋ค. ์ด ์ค์ ์ style์์ edge์ style์ ์ค์ ํ๋ ๋ถ๋ถ์ ๊ฐ์ ํตํด ์ ์ดํ ์ ์์ต๋๋ค.
๋จผ์ ์ธํ ๋์ด ์๋ ์ํ์์ 'curve-style'์ ๊ฐ์ 'bezier'๋ก ์ฃผ๋ฉด ํ์ดํ๊ฐ ๋ฑ์ฅํฉ๋๋ค.
๊ทธ๋ฐ๋ฐ ํ์ดํ ๋ฐฉํฅ์ด ์์๋ฅผ ๊ฐ๋ฅดํค๊ณ ์๋๊ฒ ๋ญ๊ฐ ์ด์ํ์ฃ ? ๊ณ ์ณ๋ด
์๋ค.
target-arrow-shape์ target-arrow-color์์ source-arrow-shape์ source-arrow-color๋ก์.
๊ทธ๋ ๊ฒ ํด์ฃผ๋ฉด ํ์ดํ ๋ฐฉํฅ์ด ๋ฐ๋๋๋ค.
๋ง์ง๋ง์ผ๋ก ํ์ดํ ๋ชจ์๋ ๋ฐ๊ฟ๋ด ์๋ค. ํ์ดํ ๋ชจ์์ ์ฌ๊ธฐ์ ํ์ธ ๊ฐ๋ฅํฉ๋๋ค.
์ vee๊ฐ ๋ง์์ ๋ค๋๊ตฐ์. ์ ์ฉํ๋ฉด
์ข ๋ ๋ ์นด๋ก์ด ํ์ดํ ๋ชจ์์ผ๋ก ์ ๋ฐ๋์์ต๋๋ค.
data ๋ถ๋ถ์ ์๋ตํ ์ฌ๊ธฐ๊น์ง์ ์ ์ฒด ์ฝ๋๋ ์๋์ ๊ฐ์ต๋๋ค.
๐ layout ์ค์
๋ค์์ผ๋ก๋ layout์ ์ค์ ํด์ ~์ธ๋ฐ์์ด~ ์ ๋ ฌ๋์ด ์๋ ํํ๋ฅผ ์ข ๋ ๋ง์ธ๋๋งต์ค๋ฝ๊ฒ ๋ฐ๊ฟ๋ด
์๋ค
layout์ ํํ๋ค์ ์ฌ๊ธฐ์ ํ์ธํ ์ ์์ต๋๋ค. ์ cose-bilkent๊ฐ ๋ง์์ ๋๋ค์. ์ด๊ฑธ ์ฌ์ฉํด๋ณด๊ฒ ์ต๋๋ค.
๋จผ์ ์ค์น๋ฅผ ํด์ค์ผํฉ๋๋ค. ํฐ๋ฏธ๋์ ํ๋ ๋ ์ฌ์๊ณ
npm install cytoscape-cose-bilkent
์ ์ ๋ ฅํด ํด๋น layout์ ์ค์นํฉ๋๋ค. ์ดํ์ index.js ์ต์๋จ์ผ๋ก ์ด๋ํด์
์์ ๊ฐ์ด cytoscape-cose-bilkent๋ฅผ import ํ๊ณ ์ฌ์ฉํ๋๋ก ์ ์ธํ ํ
node์ edge์ style๊ด๋ จ ์ค์ ์ ํด์คฌ๋ ๋ถ๋ถ ์๋ ์๋ layout์ ๋ฐ๊ฟ์ฃผ๋ฉด
๋ง์นจ๋ด ๋ง์ธ๋๋งต ๊ฐ์ ํํ๊ฐ ๋ํ๋ฌ์ต๋๋ค!
๐งฒ ํ์ดํผ ๋งํฌ ์ฐ๊ฒฐ
์ด์ node๋ฅผ ํด๋ฆญํ๋ฉด ๋ฐ์ดํฐ ๊ตฌ์ฑ๋ ์ ๋ ฅํด์ค url์ด ์์ฐฝ์์ ์ด๋ฆฌ๊ฒ ์ค์ ํด ์ค์๋ค.
cytoscape์๋ on() ๋ฉ์๋๋ฅผ ์ด์ฉํด ์ด๋ฒคํธ๋ฅผ ๋ถ์ฌํ ์ ์์ต๋๋ค.
tap์ ์ธ์๋ก ์ค์ ํด๋ฆญ์ด๋ฒคํธ๋ฅผ ์ฃผ๊ณ ํด๋น url์ด ์์ฐฝ์ผ๋ก ์ฐ๊ฒฐ๋๊ฒ ์ค์ ํด์ฃผ๋ฉด
ํด๋ฆญ์ ๋งํฌ๋ก ์ฐ๊ฒฐ๋๋ ์ด๋ฒคํธ๊ฐ ์ ์๋ํฉ๋๋ค.
๐ depth์ ๋ฐ๋ผ node์ ํฌ๊ธฐ๋ฅผ ๋ค๋ฅด๊ฒ
์ด์ depth์ ๋ฐ๋ผ node์ ํฌ๊ธฐ๋ฅผ ๋ค๋ฅด๊ฒ ๋ง๋ค์ด ๋ด
์๋ค.
๋จผ์ ์ด๊ฑธ ์ํด์ ๋์ผํ data๋ฅผ elements๋ก ๊ฐ๋ cytoscape ๊ฐ์ฒด๊ฐ ํ๋ ๋ ์์ด์ผ ํฉ๋๋ค.
data์ cy ์ฌ์ด์ ํฌ๊ธฐ ๋ณ๊ฒฝ์ ์ํ ์ฝ๋๋ฅผ ์ถ๊ฐํ๊ณ , cy์style๋ถ๋ถ์ ๊ฐ์ width, height, font-size๋ฅผ ๋ณ๊ฒฝํด์ฃผ๋ฉด
๋ง์นจ๋ด depth์ ๋ฐ๋ผ ํฌ๊ธฐ๊ฐ ์ฐจ๋ฑ ์ ์ฉ๋๋ ๋ถ๋ถ๊น์ง๋ ๊ตฌํ์ด ๋๋ฌ์ต๋๋ค.
์์์๋ ์ ์์ง๋ง ๋ง์ฝ node id์ ๊ณต๋ฐฑ์ด๋ . ์ด ๋ค์ด๊ฐ ์์ผ๋ฉด ์ด ๋ถ๋ถ์์ ์๋ฌ๊ฐ ๋ฐ์ํฉ๋๋ค.
target์ผ๋ก depth๊ฐ ๊น์ ์๋ก rank ๊ฐ์ด ๋๊ฒ ์ ์ฉ๋๋๊ตฐ์.
์์์ source์ target์ ๊ฑฐ๊พธ๋ก ์ ์ ์ด์ ๊ฐ ์ด rank ๊ฐ ๋งํผ node์ ํฌ๊ธฐ๋ฅผ ์ค์ ํ๊ธฐ ์ํด์์
๋๋ค
โจ ๋ง์ฐ์ค ์ธ / ์์์ ํ์ด๋ผ์ดํธ ์ ์ฉ / ํด์
์ด์ ๋ง์ฐ์ค ์ธ / ์์์ ํ์ด๋ผ์ดํธ ์ ์ฉ / ํด์ ๊ธฐ๋ฅ์ ๊ตฌํํด๋ด
์๋ค.
๋ง์ฐ์ค ์ธ/์์ ๊ฐ์ง ๋ ๋ชจ๋ ํด๋ฆญ์ ํ์ดํผ๋งํฌ ์ฐ๊ฒฐ ๊ธฐ๋ฅ ๊ตฌํ๋ ์ฌ์ฉํ on ๋ฉ์๋๋ฅผ ์ฌ์ฉํฉ๋๋ค.
๋จผ์ ์์ ๊ฐ์ด ์์ฑํด ์ ๊ฐ์งํ๋์ง ํ์ธํด์ค์๋ค.
์ ์๋ํ๋ค๋ฉด ๋ค์์ node์ edge์ style์ ๋ฐ๊ฟ์ค ํจ์๋ฅผ ์์ฑํ ์ฐจ๋กํฉ๋๋ค.
๋จผ์ ์ฌ์ฉํ ์๊ณผ ํฌ๊ธฐ๊ฐ๋ค์ ๋ณ์๋ก ๊บผ๋ ์๋ค. ์์ ์ ์ฌ๊ธฐ์ ์ ํํ์ต๋๋ค. ์ ํ node์ ํฌ๊ธฐ์ ์, font ํฌ๊ธฐ, edge & ํ์ดํ ํฌ๊ธฐ์ ์ ๋ฑ๋ฑ์ ์ค์ ํด
์์ ์์น์ ์์ฑํด์ค๋๋ค. ๊ฐ์ ๋ณ์๋ก ๋นผ๋์ผ๋ ํ๋์ฝ๋ฉ ๋์ด ์๋ style ๊ฐ๋ ๋ณ๊ฒฝ์ ํด์ค์ผ๊ฒ ์ฃ
์์ ๊ฐ์ด ๋ฐ๊ฟจ์ผ๋ฉด ์ด์ ์ด ๋ค๊ฐ์ ํจ์๋ฅผ ๋ง๋ค์ด์ผ ํฉ๋๋ค. ๊ฐ๊ฐ์ ์ด๋ฆ๊ณผ ์ญํ ์ ์๋์ ๊ฐ์ต๋๋ค.
- setDimStyle(target_cy, style)
๋ชจ๋ node์ edge๋ฅผ ์ฐํ๊ฒ ๋ง๋๋ ์ญํ ์ ํฉ๋๋ค. - setFocus(target_element, successorColor, predecessorsColor, edgeWidth, arrowScale)
์ ํํ node ์ edge, ๊ทธ๋ฆฌ๊ณ ์ํ์ node์ edge๋ฅผ ํฌ๊ธฐ์ ์์ผ๋ก ๊ตฌ๋ถํ๋ ์ญํ ์ ํฉ๋๋ค. - setOpacityElement(target_element, degree)
opacity๋ฅผ ํ์ฉํด ๋ฐ๋ก ์ด์ํ ์ฐ๊ด๊ด๊ณ์ ๊ทธ๋ ์ง ์์ ์ฐ๊ด ๊ด๊ณ๋ฅผ ๊ตฌ๋ถํ๋ ์ญํ ์ ํฉ๋๋ค. - setResetFocus(target_cy)
node๋ฅผ ์ ํํ๊ธฐ ์ ์ ์ํ๋ก ๋๋๋ฆฌ๋ ์ญํ ์ ํฉ๋๋ค.
ํจ์์ ์์ธ ์ฝ๋๋ ์๋์ ๊ฐ์ต๋๋ค
์ด์ฒ๋ผ ์์ฑํด์ฃผ์๊ณ , ํจ์๋ฅผ ๋ง๋ค์์ผ๋ ์ฌ์ฉํด์ผ๊ฒ ์ฃ . ์๊น ๋ง๋ค์ด ๋ mouse in๊ณผ out์ ๊ฐ์งํ๋ ๋ถ๋ถ์
์์ ๊ฐ์ด ํจ์๋ฅผ ์ธํ ํด์ค๋๋ค. ๊ทธ๋ฌ๋ฉด
์ธ ์์ ์ด๋ฒคํธ๊ฐ ์ ์๋ํฉ๋๋ค!
๐ ๋ธ๋ผ์ฐ์ ํฌ๊ธฐ ๋ณ๊ฒฝ์ cytoscape ํฌ๊ธฐ ์กฐ์
์ด์ ๋ธ๋ผ์ฐ์ ํฌ๊ธฐ ๋ณ๊ฒฝ์ cytoscape์ ํฌ๊ธฐ๊ฐ ์๋์ผ๋ก ์กฐ์ ๋๊ฒ ํด๋ด ์๋ค. seomal.org์ ๊ฒฝ์ฐ
์์ ๊ฐ์ด ๋ธ๋ผ์ฐ์ ์ ํฌ๊ธฐ๊ฐ ๋ณ๊ฒฝ๋๋ ๊ฒฝ์ฐ cytoscape์ ํฌ๊ธฐ๊ฐ ์๋์ผ๋ก ๋ณํ์ง๋ง
์ฐ๋ฆฐ ๊ฐ๋ฐ์ ๋๊ตฌ๋ฅผ ์ด์ด๋ ์๋ฌด ๋ณํ๊ฐ ์์ต๋๋ค. ์ด ๊ธฐ๋ฅ์ ์ถ๊ฐํด๋ด ์๋ค. ์ ์ฉ์ ๊ฐ๋จํฉ๋๋ค.
์์ ๊ฐ์ ์ฝ๋๋ฅผ ์ถ๊ฐํด์ฃผ๋ฉด
๋ธ๋ผ์ฐ์ ํฌ๊ธฐ ๋ณ๊ฒฝ์ cytoscape ํฌ๊ธฐ๊ฐ ์๋์ผ๋ก ์ ๋ณ๊ฒฝ๋ฉ๋๋ค!
์ ์ฝ๋์์ clearTimout๊ณผ setTimout ๋ถ๋ถ์ ์ ์ธํ๋ฉด resize ๊ฐ์ง๋ ๋๋๋ฐ cy.fit() ์คํ์ ์๋๋๊ตฐ์. ์ผ๋จ ์ฌ๊ธฐ๋ฅผ ์ฐธ๊ณ ํด ํด๊ฒฐ์ ํ๋๋ฐ ์ด๋ ๊ฒ ์๋ํ๋ ์์ธํ ์ด์ ๋ฅผ ์๋ ๋ถ ํน์ ๊ณ์๋ฉด ๋๊ธ ๋ถํ๋๋ฆฝ๋๋ค!
๐ซ data ์ถ์ถ
๊ธฐ๋ฅ์ ๋ค ๊ตฌํํ์ผ๋ ์ด์ ๋ง์ง๋ง์ผ๋ก ํ์ผ์ ์ ๋ฆฌํ๊ธฐ ์ํด data๋ฅผ ๋ณ๋์ json ํ์ผ๋ก ์ถ์ถํด๋ด ์๋ค.
์์ ๊ฐ์ด model ํด๋ ํ์์ data.json ํ์ผ์ ๋ง๋ค๊ณ
๊ทธ ๋ค์์ webpack.config.js ํ์ผ๋ก ๊ฐ์ module - rules์
์์ฒ๋ผ json ๊ด๋ จ ์ค์ ์ ์ถ๊ฐํด์ค๋๋ค. ์ดํ์ index.js ์์ data ๋ณ์๋ก ๋ฐ๋
const data = [...];
[ ] ์ ํฌํจํ์ฌ ๊ทธ ์์ ์๋ ๋ชจ๋ ๋ฐ์ดํฐ๋ค์ ๋ณต์ฌํด์ model - data.json์ ๋ถ์ฌ๋ฃ๊ธฐ ํด์ค๋๋ค.
์ดํ์ index.js ์๋จ์ data.json ๊ฒฝ๋ก๋ฅผ ์ํฌํธ ํด์ฃผ๊ณ import ๋ถ๋ถ์ ์ ์ธํ ๊ธฐ์กด ์ฝ๋๋ฅผ data.json fetch ํจ์ ์์ผ๋ก ์ง์ด๋ฃ์ผ๋ฉด
ํ๋ฉด์ด ์ ๋์ต๋๋ค! ์ดํ์ gh pages๋ netlify๋ฅผ ํ์ฉํด ๋ฐฐํฌ ํ ์ฌ์ฉํ์๋ฉด ๋ฉ๋๋ค!
๐ ๋ง์น๋ฉฐ
ํด๋น ํ๋ก์ ํธ์ ์งํ ๊ณผ์ ์ github project์ ์ ๋ฆฌํด๋๊ณ ์์ค์ฝ๋๋ repository์ ์ฌ๋ ค๋์ผ๋
์ค๋ช
์ด ๋ถ์กฑํ๋ ๋ถ๋ถ์ ์ด ๋ ๊ณณ์ ์ฐธ๊ณ ํด์ฃผ์๊ณ ์ง๋ฌธ์ ๋๊ธ์ ๋จ๊ฒจ์ฃผ์ธ์!
๋ชจ์ชผ๋ก ๋์์ด ๋์์ผ๋ฉด ์ข๊ฒ ์ต๋๋ค!