index.html 16 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483
  1. <html>
  2. <head>
  3. <title>{{title}}</title>
  4. <link rel="stylesheet" href="{{url_for('static', filename='primer.css')}}">
  5. <link rel="stylesheet" href="{{url_for('static', filename='style.css')}}">
  6. <link rel="stylesheet" href="{{url_for('static', filename='font-awesome/css/font-awesome.min.css')}}">
  7. <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.5.1/katex.min.css">
  8. <script src="https://cdnjs.cloudflare.com/ajax/libs/KaTeX/0.5.1/katex.min.js"></script>
  9. <link rel="shortcut icon" href="{{url_for('static', filename='images/on.ico')}}">
  10. <meta name="viewport" content="width=device-width, initial-scale=1">
  11. </head>
  12. <body>
  13. <br>
  14. <div class="one-fifth column">
  15. <div id="top">
  16. <a href="/" id="logo">{{logo}}</a>
  17. <div>
  18. <a href="/recentchanges" id="RecentChanges"><i class="fa fa-refresh" aria-hidden="true"></i><span id="is_mobile">최근 변경</span></a>
  19. <a href="/recentdiscuss" id="RecentChanges"><i class="fa fa-comment" aria-hidden="true"></i><span id="is_mobile">최근 토론</span></a>
  20. <a href="/random" id="log"><i class="fa fa-random" aria-hidden="true"></i></a>
  21. <a href="/user" id="log"><i class="fa fa-user" aria-hidden="true"></i></a>
  22. <a href="/other" id="log"><i class="fa fa-cogs" aria-hidden="true"></i></a>
  23. </div>
  24. <form method="POST" action="/search" id="search">
  25. <div class="input-group">
  26. <input class="form-control" name="search" type="text">
  27. <span class="input-group-button"><button class="btn"><i class="fa fa-long-arrow-left" aria-hidden="true"></i></button></span>
  28. </div>
  29. </form>
  30. </div>
  31. </div>
  32. <div class="scroll-buttons">
  33. <a class="scroll-toc" href="#toc"><i class="fa fa-list-alt" aria-hidden="true"></i></a>
  34. <a class="scroll-button" href="#top" id="left"><i class="fa fa-arrow-up" aria-hidden="true"></i></a>
  35. <a class="scroll-bottom" href="#powered" id="right"><i class="fa fa-arrow-down" aria-hidden="true"></i></a>
  36. </div>
  37. <div id="left_bar">
  38. <a href="#">맨 위로</a>
  39. <br>
  40. <br>
  41. {% autoescape false %}
  42. {{left}}
  43. {% endautoescape %}
  44. </div>
  45. <div class="four-fifths column">
  46. {% if tn == 1 %}
  47. <div id="tool">
  48. <nav class="menu">
  49. <a class="menu-item selected" href="#" onclick="return false">문서</a>
  50. <a class="menu-item" href="/edit/{{page}}">수정</a>
  51. <a class="menu-item" href="/topic/{{page}}">토론</a>
  52. <a class="menu-item" href="/delete/{{page}}">삭제</a>
  53. <a class="menu-item" href="/move/{{page}}">이동</a>
  54. <a class="menu-item" href="/raw/{{page}}">Raw</a>
  55. <a class="menu-item" href="/history/{{page}}">역사</a>
  56. <a class="menu-item" href="/xref/{{page}}">역링크</a>
  57. </nav>
  58. </div>
  59. <h1 class="titlee">{{title}}</h1>
  60. <h2 class="titlee"><span style="margin-left:5px">{{acl}}</span></h2>
  61. {% if redirect %}
  62. {% autoescape false %}
  63. <li>{{redirect}}</li>
  64. <br>
  65. {% endautoescape %}
  66. {% endif %}
  67. <div>
  68. {% autoescape false %}
  69. {{data}}
  70. {% endautoescape %}
  71. </div>
  72. {% elif tn == 2 %}
  73. {% if preview == 1 %}
  74. <div id="tool">
  75. <nav class="menu">
  76. <a class="menu-item selected" href="#">미리보기</a>
  77. <a class="menu-item" href="/w/{{page}}">문서</a>
  78. </nav>
  79. </div>
  80. {% else %}
  81. <div id="tool">
  82. <nav class="menu">
  83. <a class="menu-item selected" href="#">수정</a>
  84. <a class="menu-item" href="/w/{{page}}">문서</a>
  85. </nav>
  86. </div>
  87. {% endif %}
  88. <h1 class="title">{{title}}</h1>
  89. {% if preview == 1 %}
  90. <h2 class="title"><span style="margin-left:5px"></span>(미리보기)</h2>
  91. {% else %}
  92. <h2 class="title"><span style="margin-left:5px"></span>(수정)</h2>
  93. {% endif %}
  94. <form id="usrform" name="f1" method="POST" action="/edit/{{page}}">
  95. <textarea rows="30" cols="100" name="content" form="usrform">{{data}}</textarea>
  96. <input name="send" style="margin-top:10px;width:100%" type="text">
  97. <br>
  98. <br>
  99. <div class="form-actions">
  100. <button class="btn btn-primary" type="submit" onclick="f1.action='/edit/{{page}}';">저장</button>
  101. <button class="btn" type="submit" onclick="f1.action='/preview/{{page}}';">미리보기</button>
  102. </div>
  103. </form>
  104. {% if preview == 1 %}
  105. {% autoescape false %}
  106. {{enddata}}
  107. {% endautoescape %}
  108. {% endif %}
  109. {% elif tn == 3 %}
  110. <h1 class="title">{{title}}</h1>
  111. <table style="width: 100%;">
  112. <tbody>
  113. <tr>
  114. <td style="text-align: center;width:33.33%;">문서명</td>
  115. <td style="text-align: center;width:33.33%;">기여자</td>
  116. <td style="text-align: center;width:33.33%;">시간</td>
  117. </tr>
  118. </tbody>
  119. </table>
  120. {% autoescape false %}
  121. {{rows}}
  122. {% endautoescape %}
  123. {% elif tn == 4 %}
  124. <h1 class="title">{{title}}</h1>
  125. {% autoescape false %}
  126. {{rows}}
  127. {% endautoescape %}
  128. {% elif tn == 5 %}
  129. <div id="tool">
  130. <nav class="menu">
  131. <a class="menu-item selected" href="#">역사</a>
  132. <a class="menu-item" href="/w/{{page}}">문서</a>
  133. </nav>
  134. </div>
  135. <h1 class="title">{{title}}</h1>
  136. <h2 class="titlee"><span style="margin-left:5px"></span>(역사)</h2>
  137. <table style="width: 100%;">
  138. <tbody>
  139. <tr>
  140. <td style="text-align: center;width:33.33%;">판</td>
  141. <td style="text-align: center;width:33.33%;">기여자</td>
  142. <td style="text-align: center;width:33.33%;">시간</td>
  143. </tr>
  144. </tbody>
  145. </table>
  146. {% autoescape false %}
  147. {{rows}}
  148. {% endautoescape %}
  149. {% elif tn == 6 %}
  150. <div id="tool">
  151. <nav class="menu">
  152. <a class="menu-item selected" href="#" onclick="return false">옛문서</a>
  153. <a class="menu-item" href="/history/{{page}}">목록</a>
  154. </nav>
  155. </div>
  156. <h1 class="titlee">{{title}}</h1>
  157. <h2 class="titlee"><span style="margin-left:5px"></span>(옛문서)</h2>
  158. <div>
  159. {% autoescape false %}
  160. {{data}}
  161. {% endautoescape %}
  162. </div>
  163. {% elif tn == 7 %}
  164. <div id="tool">
  165. <nav class="menu">
  166. <a class="menu-item selected" href="#" onclick="return false">raw</a>
  167. <a class="menu-item" href="/w/{{page}}">문서</a>
  168. </nav>
  169. </div>
  170. <h1 class="title">{{title}}</h1>
  171. <h2 class="title"><span style="margin-left:5px"></span>(raw)</h2>
  172. <div>
  173. {% autoescape false %}
  174. {{data}}
  175. {% endautoescape %}
  176. </div>
  177. {% elif tn == 8 %}
  178. <h1 class="title">{{title}}</h1>
  179. <h2 class="title"><span style="margin-left:5px"></span>(삭제)</h2>
  180. <div id="tool">
  181. <nav class="menu">
  182. <a class="menu-item selected" href="#" onclick="return false">삭제</a>
  183. <a class="menu-item" href="/w/{{page}}">문서</a>
  184. </nav>
  185. </div>
  186. <form id="usrform" method="POST" action="/delete/{{page}}">
  187. {{plus}}
  188. <br>
  189. <br>
  190. <button class="btn btn-primary" type="submit">삭제</button>
  191. </form>
  192. {% elif tn == 9 %}
  193. <h1 class="title">{{title}}</h1>
  194. <h2 class="title"><span style="margin-left:5px"></span>(이동)</h2>
  195. <div id="tool">
  196. <nav class="menu">
  197. <a class="menu-item selected" href="#" onclick="return false">이동</a>
  198. <a class="menu-item" href="/w/{{page}}">문서</a>
  199. </nav>
  200. </div>
  201. <form id="usrform" method="POST" action="/move/{{page}}">
  202. {{plus}}
  203. <br>
  204. <br>
  205. <input class="form-control input-sm" value="{{title}}" name="title" type="text">
  206. <br>
  207. <br>
  208. <button class="btn btn-primary" type="submit">이동</button>
  209. </form>
  210. {% elif tn == 10 %}
  211. <h1 class="title">{{title}}</h1>
  212. <h2 class="title"><span style="margin-left:5px"></span>(토론 목록)</h2>
  213. {% if list == 1 %}
  214. <div id="tool">
  215. <nav class="menu">
  216. <a class="menu-item selected" href="#" onclick="return false">토론 목록</a>
  217. <a class="menu-item" href="/w/{{page}}">문서</a>
  218. </nav>
  219. </div>
  220. {% else %}
  221. <div id="tool">
  222. <nav class="menu">
  223. <a class="menu-item selected" href="#" onclick="return false">닫힌 토론 목록</a>
  224. <a class="menu-item" href="/topic/{{page}}">토론 목록</a>
  225. </nav>
  226. </div>
  227. {% endif %}
  228. <form id="usrform" method="POST" action="/topic/{{page}}">
  229. {% autoescape false %}
  230. {{plus}}
  231. {% endautoescape %}
  232. {% if list == 1 %}
  233. <br>
  234. <a href="/topic/{{page}}/close">(닫힌 토론 보기)</a>
  235. <br>
  236. <br>
  237. <input class="form-control" name="topic" style="width: 100%">
  238. <br>
  239. <br>
  240. <button class="btn btn-primary" type="submit">새토론</button>
  241. {% endif %}
  242. </form>
  243. {% elif tn == 11 %}
  244. <h1 class="titlee">{{title}}</h1>
  245. <h2 class="titlee"><span style="margin-left:5px"></span>(토론)</h2>
  246. <div id="tool">
  247. <nav class="menu">
  248. <a class="menu-item selected" href="#" onclick="return false">토론</a>
  249. <a class="menu-item" href="/topic/{{page}}">토론 목록</a>
  250. </nav>
  251. </div>
  252. <h2>{{sub}}</h2>
  253. <br>
  254. {% autoescape false %}
  255. {{rows}}
  256. {% endautoescape %}
  257. {% if ban == 1 %}
  258. {% else %}
  259. <form id="usrform" method="POST" action="/topic/{{page}}/sub/{{suburl}}">
  260. <br>
  261. <textarea rows="10" cols="100" name="content" form="usrform"></textarea>
  262. <br>
  263. <br>
  264. <button class="btn btn-primary" type="submit">전송</button>
  265. </form>
  266. {% endif %}
  267. {% elif tn == 12 %}
  268. <h1 class="title">{{title}}</h1>
  269. <table style="width: 100%;">
  270. <tbody>
  271. <tr>
  272. <td style="text-align: center;width:50%;">토론명</td>
  273. <td style="text-align: center;width:50%;">시간</td>
  274. </tr>
  275. </tbody>
  276. </table>
  277. {% autoescape false %}
  278. {{rows}}
  279. {% endautoescape %}
  280. {% elif tn == 13 %}
  281. <h1 class="title">{{title}}</h1>
  282. <h2 class="title"><span style="margin-left:5px"></span>(되돌리기)</h2>
  283. <div id="tool">
  284. <nav class="menu">
  285. <a class="menu-item selected" href="#" onclick="return false">되돌리기</a>
  286. <a class="menu-item" href="/w/{{page}}">문서</a>
  287. </nav>
  288. </div>
  289. <form id="usrform" method="POST" action="/revert/{{page}}/r/{{r}}">
  290. {{plus}}
  291. <br>
  292. <br>
  293. <button class="btn btn-primary" type="submit">되돌리기</button>
  294. </form>
  295. {% elif tn == 14 %}
  296. <h1 class="title">{{title}}</h1>
  297. <div>
  298. <h2 style="margin-top: -5px;">0.1 (알파)</h2>
  299. <li>문서 보기와 편집</li>
  300. <li>기타 문서</li>
  301. <li>랜덤 구현</li>
  302. <h2>0.2 ~ 0.9 (베타)</h2>
  303. <li>그 외 엄청나게 많은 기능 구현 (기존 <a href="https://github.com/2DU/OWNET">Ownet</a> 기능에서 로그인 필요한 기능 빼고 구현)</li>
  304. <h2>1.0</h2>
  305. <li>로그인 구현</li>
  306. <h2>1.1</h2>
  307. <li>차단 구현</li>
  308. <li>토론 닫기, 정지</li>
  309. <li>블라인드 구현</li>
  310. <li>ACL 기능 구현</li>
  311. <li>어드민 부여 구현</li>
  312. <h2>1.2 (진행중)</h2>
  313. <li>미리보기 구현 (완료)</li>
  314. <li>토론 목록 보강</li>
  315. <li>대역 차단 구현</li>
  316. <li>diff 구현</li>
  317. <li>파일 업로드 구현</li>
  318. <li>관리자 기능의 접근성 향상</li>
  319. <li>기본적인 다중 검사 기능</li>
  320. <h2>계속</h2>
  321. <li>버그 수정</li>
  322. <li>파서 제작</li>
  323. <br>
  324. <h2>파이나무 라이선스</h2>
  325. <li>미정</li>
  326. <h2>외부 파일 라이선스</h2>
  327. <li>인용문 아이콘 <a href="http://www.flaticon.com/free-icon/quote-left_25672">Dave Gandy</a> CC 3.0 BY</li>
  328. <li>일부 파일 <a href="https://twitter.com/Basix1120">Basix</a></li>
  329. <br>
  330. <h2>기타</h2>
  331. <li>현재 버전 1.2.4 - Beta</li>
  332. </div>
  333. {% elif tn == 15 %}
  334. <h1 class="title">{{title}}</h1>
  335. {% if title == '회원가입' %}
  336. <form id="usrform" method="POST" action="/register">
  337. {% else %}
  338. <form id="usrform" method="POST" action="/login">
  339. {% endif %}
  340. <span>아이디</span>
  341. <br>
  342. <br>
  343. <input name="id" type="text">
  344. <br>
  345. <br>
  346. <span>비밀번호</span>
  347. <br>
  348. <br>
  349. <input name="pw" type="password">
  350. <br>
  351. <br>
  352. <button class="btn btn-primary" type="submit">{{enter}}</button>
  353. </form>
  354. {% elif tn == 16 %}
  355. <h1 class="title">{{title}}</h1>
  356. <h2 class="title"><span style="margin-left:5px"></span>(차단)</h2>
  357. <form id="usrform" method="POST" action="/ban/{{page}}">
  358. {% if now == '차단' %}
  359. <input class="form-control" name="end" style="width: 100%">
  360. <br>
  361. <br>
  362. <span>아무것도 안 적으면 무기한 차단 입니다.</span>
  363. <br>
  364. <br>
  365. <span>차단 일 지정시 형식은 YYYY-MM-DD로 기록 해야합니다. (예시: 2017-01-20, 2017-10-15)</span>
  366. <br>
  367. <br>
  368. <span>지금 시각은 {{today}} 입니다.</span>
  369. <br>
  370. <br>
  371. <input class="form-control" name="why" style="width: 100%">
  372. <br>
  373. <br>
  374. <span>사유를 쓰는 곳 입니다.</span>
  375. {% if allif == 1 %}
  376. <br>
  377. <br>
  378. <input type="checkbox" name="band">
  379. <span>대역 차단</span>
  380. </input>
  381. {% endif %}
  382. <br>
  383. <br>
  384. {% endif %}
  385. <button class="btn btn-primary" type="submit">{{now}}</button>
  386. </form>
  387. {% elif tn == 17 %}
  388. <h1 class="title">{{title}}</h1>
  389. <div>
  390. <a class="out_link" style="margin-top: -5px;" href="https://namu.wiki/w/%EB%82%98%EB%AC%B4%EC%9C%84%ED%82%A4:%ED%8E%B8%EC%A7%91%20%EB%8F%84%EC%9B%80%EB%A7%90">참조</a>
  391. <h2>기초 문법</h2>
  392. <li>~~취소선~~ --취소선--</li>
  393. <li>'''강조'''</li>
  394. <li>''기울이기''</li>
  395. <li>__언더 바__</li>
  396. <li>^^윗 첨자^^</li>
  397. <li>,,아랫 첨자,,</li>
  398. <h2>문단 문법</h2>
  399. <li>[목차]</li>
  400. <li>= 1단계 문단 =</li>
  401. <li>== 2단계 문단 ==</li>
  402. <li>=== 3단계 문단 ===</li>
  403. <li>==== 4단계 문단 ====</li>
  404. <li>===== 5단계 문단 =====</li>
  405. <li>====== 6단계 문단 ======</li>
  406. <h2>링크 문법</h2>
  407. <li>[[내부 링크]]</li>
  408. <li>[[내부 링크|보이는 내용]]</li>
  409. <li>[[외부 링크]]</li>
  410. <li>[[외부 링크|보이는 내용]]</li>
  411. <h2>유튜브 문법</h2>
  412. <li>[youtube(코드)]</li>
  413. <li>[youtube(코드, width=가로, height=세로)]</li>
  414. <li>[youtube(코드, height=세로, width=가로)]</li>
  415. <h2>각주 문법</h2>
  416. <li>[* 내용]</li>
  417. <li>[*이름 내용]</li>
  418. <li>[각주]</li>
  419. <h2>넘겨주기 문법</h2>
  420. <li>#redirect 문서명</li>
  421. <li>#넘겨주기 문서명</li>
  422. </div>
  423. {% elif tn == 18 %}
  424. <h1 class="title">{{title}}</h1>
  425. <h2 class="title"><span style="margin-left:5px"></span>(권한 부여)</h2>
  426. <form id="usrform" method="POST" action="/admin/{{page}}">
  427. {% if now == '권한 부여' %}
  428. <select name="select">
  429. <option value="admin" selected="selected">관리자</option>
  430. <option value="ownet">소유자</option>
  431. </select>
  432. <br>
  433. <br>
  434. {% endif %}
  435. <button class="btn btn-primary" type="submit">{{now}}</button>
  436. </form>
  437. {% elif tn == 19 %}
  438. <h1 class="title">{{title}}</h1>
  439. <h2 class="title"><span style="margin-left:5px"></span>(ACL)</h2>
  440. <p>{{now}}</p>
  441. <form id="usrform" method="POST" action="/acl/{{page}}">
  442. <select name="select">
  443. <option value="admin" selected="selected">관리자만</option>
  444. <option value="user">유저 이상</option>
  445. <option value="normal">일반</option>
  446. </select>
  447. <br>
  448. <br>
  449. <button class="btn btn-primary" type="submit">ACL 변경</button>
  450. </form>
  451. {% elif tn == 20 %}
  452. <h1 class="title">{{title}}</h1>
  453. <table style="width: 100%;">
  454. <tbody>
  455. <tr>
  456. <td style="text-align: center;width:20%;">차단자</td>
  457. <td style="text-align: center;width:20%;">관리자</td>
  458. <td style="text-align: center;width:20%;">언제까지</td>
  459. <td style="text-align: center;width:20%;">왜</td>
  460. <td style="text-align: center;width:20%;">시간</td>
  461. </tr>
  462. </tbody>
  463. </table>
  464. {% autoescape false %}
  465. {{rows}}
  466. {% endautoescape %}
  467. {% else %}
  468. <h1 class="title">{{title}}</h1>
  469. <h2 class="title"><span style="margin-left:5px"></span></h2>
  470. <div>
  471. {% autoescape false %}
  472. {{data}}
  473. {% endautoescape %}
  474. </div>
  475. {% endif %}
  476. <hr id="last">
  477. <p>{{license}}</p>
  478. <div id="powered">
  479. <a href="https://github.com/2DU/PYnamu"><img src="{{url_for('static', filename='images/on2.png')}}" width="100px"></a>
  480. </div>
  481. </div>
  482. </body>
  483. </html>