index.html 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540
  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="{{url_for('static', filename='katex/katex.min.css')}}">
  8. <script src="{{url_for('static', filename='katex/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-search" 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}}/n/1">역사</a>
  56. <!-- <a class="menu-item" href="/xref/{{page}}">역링크</a> -->
  57. <a class="menu-item" style="{{style}}" href="/w/{{uppage}}">상위</a>
  58. </nav>
  59. </div>
  60. <h1 class="title">{{title}} <sub>{{acl}}</sub></h1>
  61. {% if redirect %}
  62. {% autoescape false %}
  63. <li style="margin-top: -20px;">{{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. {% if preview == 1 %}
  89. <h1 class="title">{{title}} <sub>(미리보기)</sub></h1>
  90. {% else %}
  91. <h1 class="title">{{title}} <sub>(수정)</sub></h1>
  92. {% endif %}
  93. {% if notice %}
  94. <br>
  95. <span>{{notice}}</span>
  96. <br>
  97. <br>
  98. {% endif %}
  99. <form id="usrform" name="f1" method="POST" action="/edit/{{page}}">
  100. <textarea rows="30" cols="100" name="content" form="usrform">{{data}}</textarea>
  101. <input name="send" style="margin-top:10px;width:100%" type="text">
  102. <br>
  103. <br>
  104. <div class="form-actions">
  105. <button class="btn btn-primary" type="submit" onclick="f1.action='/edit/{{page}}';">저장</button>
  106. <button class="btn" type="submit" onclick="f1.action='/preview/{{page}}';">미리보기</button>
  107. </div>
  108. </form>
  109. {% if preview == 1 %}
  110. {% autoescape false %}
  111. {{enddata}}
  112. {% endautoescape %}
  113. {% endif %}
  114. {% elif tn == 3 %}
  115. <h1 class="title">{{title}}</h1>
  116. <table style="width: 100%;">
  117. <tbody>
  118. <tr>
  119. <td style="text-align: center;width:33.33%;">문서명</td>
  120. <td style="text-align: center;width:33.33%;">기여자</td>
  121. <td style="text-align: center;width:33.33%;">시간</td>
  122. </tr>
  123. </tbody>
  124. </table>
  125. {% autoescape false %}
  126. {{rows}}
  127. {% endautoescape %}
  128. {% elif tn == 4 %}
  129. <h1 class="title">{{title}}</h1>
  130. {% autoescape false %}
  131. {{rows}}
  132. {% endautoescape %}
  133. {% elif tn == 5 %}
  134. <div id="tool">
  135. <nav class="menu">
  136. <a class="menu-item selected" href="#">역사</a>
  137. <a class="menu-item" href="/w/{{page}}">문서</a>
  138. </nav>
  139. </div>
  140. <h1 class="title">{{title}} <sub>(역사)</sub></h1>
  141. <form class="usrform" method='POST' action='/history/{{page}}/n/1'>
  142. <select name="a">
  143. {% autoescape false %}
  144. {{select}}
  145. {% endautoescape %}
  146. </select>
  147. <select name="b">
  148. {% autoescape false %}
  149. {{select}}
  150. {% endautoescape %}
  151. </select>
  152. <button class="btn btn-primary" type='submit'>리비전 비교</button>
  153. <br>
  154. <br>
  155. <table style="width: 100%;">
  156. <tbody>
  157. <tr>
  158. <td style="text-align: center;width:33.33%;">판</td>
  159. <td style="text-align: center;width:33.33%;">기여자</td>
  160. <td style="text-align: center;width:33.33%;">시간</td>
  161. </tr>
  162. </tbody>
  163. </table>
  164. {% autoescape false %}
  165. {{rows}}
  166. {% endautoescape %}
  167. {% elif tn == 6 %}
  168. <div id="tool">
  169. <nav class="menu">
  170. <a class="menu-item selected" href="#" onclick="return false">옛문서</a>
  171. <a class="menu-item" href="javascript:history.back(-1);">뒤로가기</a>
  172. </nav>
  173. </div>
  174. <h1 class="title">{{title}} <sub>(옛문서)</sub></h1>
  175. <div>
  176. {% autoescape false %}
  177. {{data}}
  178. {% endautoescape %}
  179. </div>
  180. {% elif tn == 7 %}
  181. <div id="tool">
  182. <nav class="menu">
  183. <a class="menu-item selected" href="#" onclick="return false">raw</a>
  184. <a class="menu-item" href="/w/{{page}}">문서</a>
  185. </nav>
  186. </div>
  187. <h1 class="title">{{title}} <sub>(raw)</sub></h1>
  188. <div>
  189. {% autoescape false %}
  190. {{data}}
  191. {% endautoescape %}
  192. </div>
  193. {% elif tn == 8 %}
  194. <h1 class="title">{{title}} <sub>(삭제)</sub></h1>
  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="/delete/{{page}}">
  202. {{plus}}
  203. <br>
  204. <br>
  205. <button class="btn btn-primary" type="submit">삭제</button>
  206. </form>
  207. {% elif tn == 9 %}
  208. <h1 class="title">{{title}} <sub>(이동)</sub></h1>
  209. <div id="tool">
  210. <nav class="menu">
  211. <a class="menu-item selected" href="#" onclick="return false">이동</a>
  212. <a class="menu-item" href="/w/{{page}}">문서</a>
  213. </nav>
  214. </div>
  215. <form id="usrform" method="POST" action="/move/{{page}}">
  216. {{plus}}
  217. <br>
  218. <br>
  219. <input class="form-control input-sm" value="{{title}}" name="title" type="text">
  220. <br>
  221. <br>
  222. <button class="btn btn-primary" type="submit">이동</button>
  223. </form>
  224. {% elif tn == 10 %}
  225. <h1 class="title">{{title}} <sub>(토론 목록)</sub></h1>
  226. {% if list == 1 %}
  227. <div id="tool">
  228. <nav class="menu">
  229. <a class="menu-item selected" href="#" onclick="return false">토론 목록</a>
  230. <a class="menu-item" href="/w/{{page}}">문서</a>
  231. </nav>
  232. </div>
  233. {% else %}
  234. <div id="tool">
  235. <nav class="menu">
  236. <a class="menu-item selected" href="#" onclick="return false">닫힌 토론 목록</a>
  237. <a class="menu-item" href="/topic/{{page}}">토론 목록</a>
  238. </nav>
  239. </div>
  240. {% endif %}
  241. <form id="usrform" method="POST" action="/topic/{{page}}">
  242. {% autoescape false %}
  243. {{plus}}
  244. {% endautoescape %}
  245. {% if list == 1 %}
  246. <br>
  247. <a href="/topic/{{page}}/close">(닫힌 토론 보기)</a>
  248. <br>
  249. <br>
  250. <input class="form-control" name="topic" style="width: 100%">
  251. <br>
  252. <br>
  253. <button class="btn btn-primary" type="submit">새토론</button>
  254. {% endif %}
  255. </form>
  256. {% elif tn == 11 %}
  257. <h1 class="title">{{title}} <sub>(토론)</sub></h1>
  258. <div id="tool">
  259. <nav class="menu">
  260. <a class="menu-item selected" href="#" onclick="return false">토론</a>
  261. <a class="menu-item" href="/topic/{{page}}">토론 목록</a>
  262. </nav>
  263. </div>
  264. <h2>{{sub}}</h2>
  265. <br>
  266. {% autoescape false %}
  267. {{rows}}
  268. {% endautoescape %}
  269. {% if ban == 1 %}
  270. {% else %}
  271. <form id="usrform" method="POST" action="/topic/{{page}}/sub/{{suburl}}">
  272. <br>
  273. <textarea rows="10" cols="100" name="content" form="usrform"></textarea>
  274. <br>
  275. <br>
  276. <button class="btn btn-primary" type="submit">전송</button>
  277. </form>
  278. {% endif %}
  279. {% elif tn == 12 %}
  280. <h1 class="title">{{title}}</h1>
  281. <table style="width: 100%;">
  282. <tbody>
  283. <tr>
  284. <td style="text-align: center;width:50%;">토론명</td>
  285. <td style="text-align: center;width:50%;">시간</td>
  286. </tr>
  287. </tbody>
  288. </table>
  289. {% autoescape false %}
  290. {{rows}}
  291. {% endautoescape %}
  292. {% elif tn == 13 %}
  293. <h1 class="title">{{title}} <sub>(되돌리기)</sub></h1>
  294. <div id="tool">
  295. <nav class="menu">
  296. <a class="menu-item selected" href="#" onclick="return false">되돌리기</a>
  297. <a class="menu-item" href="javascript:history.back(-1);">뒤로가기</a>
  298. </nav>
  299. </div>
  300. <form id="usrform" method="POST" action="/revert/{{page}}/r/{{r}}">
  301. {{plus}}
  302. <br>
  303. <br>
  304. <button class="btn btn-primary" type="submit">되돌리기</button>
  305. </form>
  306. {% elif tn == 14 %}
  307. <h1 class="title">{{title}}</h1>
  308. <div>
  309. <h2 style="margin-top: -5px;">0.1 (알파)</h2>
  310. <li>문서 보기와 편집</li>
  311. <li>기타 문서</li>
  312. <li>랜덤 구현</li>
  313. <h2>0.2 ~ 0.9 (베타)</h2>
  314. <li>그 외 엄청나게 많은 기능 구현 (기존 <a class="out_link" href="https://github.com/2DU/OWNET">Ownet</a> 기능에서 로그인 필요한 기능 빼고 구현)</li>
  315. <h2>1.0</h2>
  316. <li>로그인 구현</li>
  317. <h2>1.1</h2>
  318. <li>차단 구현</li>
  319. <li>토론 닫기, 정지</li>
  320. <li>블라인드 구현</li>
  321. <li>ACL 기능 구현</li>
  322. <li>어드민 부여 구현</li>
  323. <h2>1.2</h2>
  324. <li>미리보기 구현</li>
  325. <li>대역 차단 구현</li>
  326. <li>diff 구현</li>
  327. <li>파일 업로드 개선</li>
  328. <li>파일 업로드 구현</li>
  329. <li>기본적인 다중 검사 기능</li>
  330. <h2>1.3</h2>
  331. <li>토론 목록 보강</li>
  332. <li>토론에 문법 지원</li>
  333. <li>비 효율적으로 돌아가던거 수정</li>
  334. <li>하위 문서 지원</li>
  335. <li>관리자 기능의 접근성 향상</li>
  336. <li>대규모도 편하게 접근되게</li>
  337. <h2>1.4</h2>
  338. <li>사용자 문서</li>
  339. <li>사문 접근성</li>
  340. <li>검색 기능 수정</li>
  341. <li>상위 문서 바로가기</li>
  342. <li>유저 기록 보기</li>
  343. <h2>1.5 (진행중)</h2>
  344. <li>디자인 변경 (진행중)</li>
  345. <li>관리자 기능 접근성</li>
  346. <li>파일 문서 생성</li>
  347. <h2>계속</h2>
  348. <li>버그 수정</li>
  349. <li>파서 제작 (90%)</li>
  350. <h2>보류</h2>
  351. <li>설계 약간 변경 (느린 pymysql 대신에 다른 패키지를 쓰려고 했으나 어차피 곧 pypy 신 버전 나올테고 설치도 복잡해지니 보류)</li>
  352. <br>
  353. <h2>파이나무 라이선스</h2>
  354. <li>BSD 3-Clause License</li>
  355. <h2>외부 파일 라이선스</h2>
  356. <li>인용문 아이콘 <a class="out_link" href="http://www.flaticon.com/free-icon/quote-left_25672">Dave Gandy</a> CC 3.0 BY</li>
  357. <li>일부 파일 <a class="out_link" href="https://twitter.com/Basix1120">Basix</a></li>
  358. <br>
  359. <h2>기타</h2>
  360. <li>현재 버전 1.5.4 - Beta <s>정식 버전은 10.0이라더라.</s></li>
  361. <br>
  362. <h2>개발 이념</h2>
  363. <li>나(2DU) 쓰기 편한 엔진을 만들자</li>
  364. </div>
  365. {% elif tn == 15 %}
  366. <h1 class="title">{{title}}</h1>
  367. {% if title == '회원가입' %}
  368. <form id="usrform" method="POST" action="/register">
  369. {% else %}
  370. <form id="usrform" method="POST" action="/login">
  371. {% endif %}
  372. <span>아이디</span>
  373. <br>
  374. <br>
  375. <input name="id" type="text">
  376. <br>
  377. <br>
  378. <span>비밀번호</span>
  379. <br>
  380. <br>
  381. <input name="pw" type="password">
  382. <br>
  383. <br>
  384. <button class="btn btn-primary" type="submit">{{enter}}</button>
  385. </form>
  386. {% elif tn == 16 %}
  387. <h1 class="title">{{title}} <sub>(차단)</sub></h1>
  388. <form id="usrform" method="POST" action="/ban/{{page}}">
  389. {% if now == '차단' or now == '대역 차단' %}
  390. <input class="form-control" name="end" style="width: 100%">
  391. <br>
  392. <br>
  393. <span>아무것도 안 적으면 무기한 차단 입니다.</span>
  394. <br>
  395. <br>
  396. <span>차단 일 지정시 형식은 YYYY-MM-DD로 기록 해야합니다. (예시: 2017-01-20, 2017-10-15)</span>
  397. <br>
  398. <br>
  399. <span>지금 시각은 {{today}} 입니다.</span>
  400. <br>
  401. <br>
  402. <input class="form-control" name="why" style="width: 100%">
  403. <br>
  404. <br>
  405. <span>사유를 쓰는 곳 입니다.</span>
  406. {% if allif == 1 %}
  407. <br>
  408. <br>
  409. <input type="checkbox" name="band">
  410. <span>대역 차단</span>
  411. </input>
  412. {% endif %}
  413. <br>
  414. <br>
  415. {% endif %}
  416. <button class="btn btn-primary" type="submit">{{now}}</button>
  417. </form>
  418. {% elif tn == 17 %}
  419. <h1 class="title">{{title}}</h1>
  420. <div>
  421. <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>
  422. <h2>기초 문법</h2>
  423. <li>~~취소선~~ --취소선--</li>
  424. <li>'''강조'''</li>
  425. <li>''기울이기''</li>
  426. <li>__언더 바__</li>
  427. <li>^^윗 첨자^^</li>
  428. <li>,,아랫 첨자,,</li>
  429. <h2>문단 문법</h2>
  430. <li>[목차]</li>
  431. <li>= 1단계 문단 =</li>
  432. <li>== 2단계 문단 ==</li>
  433. <li>=== 3단계 문단 ===</li>
  434. <li>==== 4단계 문단 ====</li>
  435. <li>===== 5단계 문단 =====</li>
  436. <li>====== 6단계 문단 ======</li>
  437. <h2>링크 문법</h2>
  438. <li>[[내부 링크]]</li>
  439. <li>[[내부 링크|보이는 내용]]</li>
  440. <li>[[외부 링크]]</li>
  441. <li>[[외부 링크|보이는 내용]]</li>
  442. <h2>유튜브 문법</h2>
  443. <li>[youtube(코드)]</li>
  444. <li>[youtube(코드, width=가로, height=세로)]</li>
  445. <li>[youtube(코드, height=세로, width=가로)]</li>
  446. <h2>각주 문법</h2>
  447. <li>[* 내용]</li>
  448. <li>[*이름 내용]</li>
  449. <li>[각주]</li>
  450. <h2>넘겨주기 문법</h2>
  451. <li>#redirect 문서명</li>
  452. <li>#넘겨주기 문서명</li>
  453. </div>
  454. {% elif tn == 18 %}
  455. <h1 class="title">{{title}} <sub>(권한 부여)</sub></h1>
  456. <form id="usrform" method="POST" action="/admin/{{page}}">
  457. {% if now == '권한 부여' %}
  458. <select name="select">
  459. <option value="admin" selected="selected">관리자</option>
  460. <option value="ownet">소유자</option>
  461. </select>
  462. <br>
  463. <br>
  464. {% endif %}
  465. <button class="btn btn-primary" type="submit">{{now}}</button>
  466. </form>
  467. {% elif tn == 19 %}
  468. <h1 class="title">{{title}} <sub>(ACL)</sub></h1>
  469. <p>{{now}}</p>
  470. <form id="usrform" method="POST" action="/acl/{{page}}">
  471. <select name="select">
  472. <option value="admin" selected="selected">관리자만</option>
  473. <option value="user">유저 이상</option>
  474. <option value="normal">일반</option>
  475. </select>
  476. <br>
  477. <br>
  478. <button class="btn btn-primary" type="submit">ACL 변경</button>
  479. </form>
  480. {% elif tn == 20 %}
  481. <h1 class="title">{{title}}</h1>
  482. <table style="width: 100%;">
  483. <tbody>
  484. <tr>
  485. <td style="text-align: center;width:20%;">차단자</td>
  486. <td style="text-align: center;width:20%;">관리자</td>
  487. <td style="text-align: center;width:20%;">언제까지</td>
  488. <td style="text-align: center;width:20%;">왜</td>
  489. <td style="text-align: center;width:20%;">시간</td>
  490. </tr>
  491. </tbody>
  492. </table>
  493. {% autoescape false %}
  494. {{rows}}
  495. {% endautoescape %}
  496. {% elif tn == 21 %}
  497. <h1 class="title">{{title}}</h1>
  498. <div>
  499. <form action="" method=post enctype=multipart/form-data>
  500. <input type=file name=file>
  501. <input type=submit value=Upload>
  502. </form>
  503. </div>
  504. <span>{{number}}MB 이하 파일만 업로드 가능하고 jpg png gif jpeg만 가능 합니다.</span>
  505. {% elif tn == 22 %}
  506. <h1 class="title">{{title}}</h1>
  507. <table style="width: 100%;">
  508. <tbody>
  509. <tr>
  510. <td style="text-align: center;width:33.33%;">유저</td>
  511. <td style="text-align: center;width:33.33%;">아이피</td>
  512. <td style="text-align: center;width:33.33%;">언제</td>
  513. </tr>
  514. </tbody>
  515. </table>
  516. {% autoescape false %}
  517. {{rows}}
  518. {% endautoescape %}
  519. {% else %}
  520. <div id="tool">
  521. <nav class="menu">
  522. <a class="menu-item selected" href="#" onclick="return false">{{title}}</a>
  523. <a class="menu-item" href="javascript:history.back(-1);">뒤로가기</a>
  524. </nav>
  525. </div>
  526. <h1 class="title">{{title}}</h1>
  527. <div>
  528. {% autoescape false %}
  529. {{data}}
  530. {% endautoescape %}
  531. </div>
  532. {% endif %}
  533. <hr id="last">
  534. <p>{{license}}</p>
  535. <div id="powered">
  536. <a href="https://github.com/2DU/PYnamu"><img src="{{url_for('static', filename='images/on2.png')}}" width="100px"></a>
  537. </div>
  538. </div>
  539. </body>
  540. </html>