OSDN Git Service

コラムの一覧を表示するプラグインを追加。
[fswiki/sandbox.git] / takezoe / plugin / book / Install.pm
1 ############################################################
2 #
3 # ½ñÀÒ¼¹É®ÍѤΥץ饰¥¤¥ó¤òÄ󶡤·¤Þ¤¹¡£
4 #
5 ############################################################
6 package plugin::book::Install;
7 use strict;
8 use plugin::book::TocParser;
9
10 sub install {
11         my $wiki  = shift;
12         $wiki->add_paragraph_plugin("chapter", "plugin::book::Chapter", "HTML");
13         $wiki->add_paragraph_plugin("section", "plugin::book::Section", "HTML");
14         $wiki->add_inline_plugin("title1", "plugin::book::Title1", "HTML");
15         $wiki->add_inline_plugin("title2", "plugin::book::Title2", "HTML");
16         $wiki->add_inline_plugin("title3", "plugin::book::Title3", "HTML");
17         $wiki->add_paragraph_plugin("caption" ,"plugin::book::Caption" ,"HTML");
18         $wiki->add_paragraph_plugin("toc" ,"plugin::book::Toc" ,"HTML");
19         $wiki->add_inline_plugin("link" ,"plugin::book::Link" ,"HTML");
20         
21         $wiki->add_block_plugin("list" ,"plugin::book::List" ,"HTML");
22         $wiki->add_inline_plugin("code" ,"plugin::book::Code" ,"HTML");
23         
24         $wiki->add_block_plugin("column" ,"plugin::book::Column" ,"HTML");
25         $wiki->add_paragraph_plugin("columnlist", "plugin::book::ColumnList", "HTML");
26         $wiki->add_block_plugin("note" ,"plugin::book::Note" ,"HTML");
27         $wiki->add_block_plugin("box" ,"plugin::book::Box" ,"HTML");
28         
29         $wiki->add_inline_plugin("memo", "plugin::book::Memo", "HTML");
30         $wiki->add_inline_plugin("add", "plugin::book::Add", "HTML");
31         $wiki->add_inline_plugin("del", "plugin::book::Del", "HTML");
32         $wiki->add_paragraph_plugin("memolist", "plugin::book::Memolist", "HTML");
33         
34         $wiki->add_inline_plugin("wordcount", "plugin::book::Wordcount", "HTML");
35         $wiki->add_inline_plugin("pagecount", "plugin::book::Pagecount", "HTML");
36         
37         $wiki->add_hook("chapter", "plugin::book::Title1");
38         $wiki->add_hook("chapter", "plugin::book::Title2");
39         $wiki->add_hook("chapter", "plugin::book::Title3");
40         $wiki->add_hook("chapter", "plugin::book::Caption");
41         
42         $wiki->add_hook("title1", "plugin::book::Title2");
43         $wiki->add_hook("title1", "plugin::book::Title3");
44         $wiki->add_hook("title3", "plugin::book::Title3");
45         
46         $wiki->add_inline_plugin("br", "plugin::book::Br");
47         $wiki->add_paragraph_plugin("keyword" ,"plugin::book::Keyword" ,"HTML");
48         
49         my @paths = split(/\//, $wiki->get_CGI()->path_info());
50         my $path_prefix = '';
51         for(my $i = 0; $i < $#paths; $i++){
52                 $path_prefix .= '../';
53         }
54         $wiki->{book_plugin_path_prefix} = $path_prefix;
55         
56         my $head_info = <<"END_OF_HEAD";
57 <link href="${path_prefix}plugin/book/google-code-prettify/sunburst.css" type="text/css" rel="stylesheet" />
58 <script type="text/javascript" src="${path_prefix}plugin/book/google-code-prettify/prettify.js"></script>
59 <script type="text/javascript">window.onload = function(){ prettyPrint(); }</script>
60 <style type="text/css">
61 div.chapter {
62   text-align: right;
63   padding: 20px;
64   font-size: 200%;
65   font-style: italic;
66 }
67
68 a.xref {
69   background-color: silver;
70 }
71
72 a.xref:link {
73   color: black;
74 }
75
76 a.xref:hover {
77   color: black;
78 }
79
80 a.xref:visited {
81   color: black;
82 }
83
84 span.xref-error {
85   background-color: silver;
86   font-weight: bold;
87 }
88
89 span.memo {
90   background-color: yellow;
91   border: 1px solid #888800;
92   margin-left: 2px;
93   margin-right: 2x;
94 }
95
96 span.delete {
97   color: blue;
98   text-decoration: line-through;
99 }
100
101 span.add {
102   color: red;
103   text-decoration: underline;
104 }
105
106 div.caption {
107   font-size: 80%;
108   font-weight: bold;
109 }
110
111 code {
112  font-weight: bold;
113 /* font-style: italic; */
114  font-family: monospace;
115 }
116
117 img {
118   border: 1px solid silver;
119 }
120
121 div.column {
122   border: 1px solid gray;
123   margin-left: 20px;
124   margin-right: 20px;
125   margin-top: 10px;
126   margin-bottom: 20px;
127 }
128
129 div.column-title {
130   background-color: silver;
131   font-weight: bold;
132   padding: 4px;
133 }
134
135 div.column-body {
136   padding: 4px;
137 }
138
139 div.note {
140   border: 2px dotted #FF8888;
141   background-color: #FFEEEE;
142   margin-bottom: 20px;
143   margin-left: 20px;
144   margin-top: 10px;
145   margin-right: 20px;
146 }
147
148 div.note-title {
149   font-weight: bold;
150   padding: 4px;
151 }
152
153 div.note-body {
154   padding: 4px;
155 }
156
157 span.keyword {
158   background-color: #666688;
159   color: white;
160   padding: 4px;
161 }
162
163 span.keyword a {
164   color: white;
165 }
166
167 div.keyword {
168   padding-top: 4px;
169   padding-left: 4px;
170   padding-right: 4px;
171   padding-bottom: 8px;
172 }
173
174 table.box {
175   width: 100%;
176   border-top: none;\r
177   border-left: none;
178   border-right: none;\r
179   border-bottom: none;\r
180   border-collapse:collapse;\r
181   border-spacing:0;\r
182   empty-cells:show;
183   margin: 2px;
184 }
185
186 table.box th {
187   width: 100px;
188   border-top: 1px solid #88AAFF;
189   border-left: 1px solid #88AAFF;
190   border-right:1px solid #88AAFF;\r
191   border-bottom:1px solid #88AAFF;\r
192   background-position:left top;\r
193   padding:0.3em 1em;\r
194   text-align:center;
195 }
196
197 table.box td {
198   border-top: 1px solid #88AAFF;
199   border-left: none;
200   border-right:1px solid #88AAFF;\r
201   border-bottom:1px solid #88AAFF;\r
202   padding:0.3em 1em;
203 }
204
205 table.box ul {
206   margin-bottom: 0px;
207   margin-left: 0px;
208   padding-left: 10px;
209 }
210
211 table.box p {
212   margin-bottom: 0px;
213   margin-left: 0px;
214   padding-left: 0px;
215 }
216
217 pre.prettyprint strong {
218   background-color: #444444;
219   text-decoration: underline;
220 #  border: 1px solid gray;
221   font-weight: normal;
222 }
223 </style>
224 END_OF_HEAD
225         
226         $wiki->add_head_info($head_info);
227 }
228
229 1;