윤혜원

index.ejs 템플릿 적용하기 성공!

Showing 62 changed files with 7566 additions and 185 deletions
...@@ -3,11 +3,12 @@ ...@@ -3,11 +3,12 @@
3 <component name="ChangeListManager"> 3 <component name="ChangeListManager">
4 <list default="true" id="ffe1a490-8fdb-4611-8537-4d1c03c40b8d" name="Default" comment=""> 4 <list default="true" id="ffe1a490-8fdb-4611-8537-4d1c03c40b8d" name="Default" comment="">
5 <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" /> 5 <change beforePath="$PROJECT_DIR$/.idea/workspace.xml" beforeDir="false" afterPath="$PROJECT_DIR$/.idea/workspace.xml" afterDir="false" />
6 + <change beforePath="$PROJECT_DIR$/app.js" beforeDir="false" afterPath="$PROJECT_DIR$/app.js" afterDir="false" />
7 + <change beforePath="$PROJECT_DIR$/public/stylesheets/style.css" beforeDir="false" afterPath="$PROJECT_DIR$/public/stylesheets/style.css" afterDir="false" />
6 <change beforePath="$PROJECT_DIR$/routes/index.js" beforeDir="false" afterPath="$PROJECT_DIR$/routes/index.js" afterDir="false" /> 8 <change beforePath="$PROJECT_DIR$/routes/index.js" beforeDir="false" afterPath="$PROJECT_DIR$/routes/index.js" afterDir="false" />
7 - <change beforePath="$PROJECT_DIR$/routes/mytoons.js" beforeDir="false" afterPath="$PROJECT_DIR$/routes/mytoons.js" afterDir="false" /> 9 + <change beforePath="$PROJECT_DIR$/views/index.ejs" beforeDir="false" afterPath="$PROJECT_DIR$/views/index.ejs" afterDir="false" />
8 - <change beforePath="$PROJECT_DIR$/routes/setting.js" beforeDir="false" afterPath="$PROJECT_DIR$/routes/setting.js" afterDir="false" />
9 - <change beforePath="$PROJECT_DIR$/routes/toonviewer.js" beforeDir="false" afterPath="$PROJECT_DIR$/routes/toonviewer.js" afterDir="false" />
10 <change beforePath="$PROJECT_DIR$/views/mytoons.ejs" beforeDir="false" afterPath="$PROJECT_DIR$/views/mytoons.ejs" afterDir="false" /> 10 <change beforePath="$PROJECT_DIR$/views/mytoons.ejs" beforeDir="false" afterPath="$PROJECT_DIR$/views/mytoons.ejs" afterDir="false" />
11 + <change beforePath="$PROJECT_DIR$/ytmtDB.zip" beforeDir="false" />
11 </list> 12 </list>
12 <ignored path="$PROJECT_DIR$/out/" /> 13 <ignored path="$PROJECT_DIR$/out/" />
13 <option name="EXCLUDED_CONVERTED_TO_IGNORED" value="true" /> 14 <option name="EXCLUDED_CONVERTED_TO_IGNORED" value="true" />
...@@ -112,31 +113,36 @@ ...@@ -112,31 +113,36 @@
112 <entry key="project.closed" value="3" /> 113 <entry key="project.closed" value="3" />
113 <entry key="project.open.time.10" value="1" /> 114 <entry key="project.open.time.10" value="1" />
114 <entry key="project.open.time.13" value="1" /> 115 <entry key="project.open.time.13" value="1" />
115 - <entry key="project.opened" value="3" /> 116 + <entry key="project.open.time.2" value="1" />
117 + <entry key="project.opened" value="4" />
116 </counts> 118 </counts>
117 </usages-collector> 119 </usages-collector>
118 <usages-collector id="statistics.file.extensions.open"> 120 <usages-collector id="statistics.file.extensions.open">
119 <counts> 121 <counts>
120 - <entry key="ejs" value="4" /> 122 + <entry key="css" value="2" />
121 - <entry key="js" value="2" /> 123 + <entry key="ejs" value="6" />
124 + <entry key="html" value="1" />
125 + <entry key="js" value="9" />
122 </counts> 126 </counts>
123 </usages-collector> 127 </usages-collector>
124 <usages-collector id="statistics.file.types.open"> 128 <usages-collector id="statistics.file.types.open">
125 <counts> 129 <counts>
126 - <entry key="EJS" value="4" /> 130 + <entry key="CSS" value="2" />
127 - <entry key="JavaScript" value="2" /> 131 + <entry key="EJS" value="6" />
132 + <entry key="HTML" value="1" />
133 + <entry key="JavaScript" value="9" />
128 </counts> 134 </counts>
129 </usages-collector> 135 </usages-collector>
130 <usages-collector id="statistics.file.extensions.edit"> 136 <usages-collector id="statistics.file.extensions.edit">
131 <counts> 137 <counts>
132 - <entry key="ejs" value="358" /> 138 + <entry key="ejs" value="453" />
133 - <entry key="js" value="1290" /> 139 + <entry key="js" value="1398" />
134 </counts> 140 </counts>
135 </usages-collector> 141 </usages-collector>
136 <usages-collector id="statistics.file.types.edit"> 142 <usages-collector id="statistics.file.types.edit">
137 <counts> 143 <counts>
138 - <entry key="EJS" value="358" /> 144 + <entry key="EJS" value="453" />
139 - <entry key="JavaScript" value="1290" /> 145 + <entry key="JavaScript" value="1398" />
140 </counts> 146 </counts>
141 </usages-collector> 147 </usages-collector>
142 </session> 148 </session>
...@@ -146,71 +152,38 @@ ...@@ -146,71 +152,38 @@
146 <file pinned="false" current-in-tab="false"> 152 <file pinned="false" current-in-tab="false">
147 <entry file="file://$PROJECT_DIR$/routes/mytoons.js"> 153 <entry file="file://$PROJECT_DIR$/routes/mytoons.js">
148 <provider selected="true" editor-type-id="text-editor"> 154 <provider selected="true" editor-type-id="text-editor">
149 - <state relative-caret-position="171"> 155 + <state relative-caret-position="-152">
150 - <caret line="9" column="27" selection-start-line="9" selection-start-column="27" selection-end-line="9" selection-end-column="27" /> 156 + <caret line="7" column="1" selection-start-line="7" selection-start-column="1" selection-end-line="7" selection-end-column="1" />
151 </state> 157 </state>
152 </provider> 158 </provider>
153 </entry> 159 </entry>
154 </file> 160 </file>
155 <file pinned="false" current-in-tab="false"> 161 <file pinned="false" current-in-tab="false">
156 - <entry file="file://$PROJECT_DIR$/routes/toonviewer.js"> 162 + <entry file="file://$PROJECT_DIR$/views/mytoons.ejs">
157 <provider selected="true" editor-type-id="text-editor"> 163 <provider selected="true" editor-type-id="text-editor">
158 - <state relative-caret-position="133"> 164 + <state relative-caret-position="-1862">
159 - <caret line="7" column="23" selection-start-line="7" selection-start-column="23" selection-end-line="7" selection-end-column="23" /> 165 + <caret line="19" column="4" selection-start-line="19" selection-start-column="4" selection-end-line="19" selection-end-column="4" />
160 </state> 166 </state>
161 </provider> 167 </provider>
162 </entry> 168 </entry>
163 </file> 169 </file>
164 <file pinned="false" current-in-tab="false"> 170 <file pinned="false" current-in-tab="false">
165 - <entry file="file://$PROJECT_DIR$/routes/setting.js"> 171 + <entry file="file://$PROJECT_DIR$/views/index.html">
166 <provider selected="true" editor-type-id="text-editor"> 172 <provider selected="true" editor-type-id="text-editor">
167 - <state relative-caret-position="1007"> 173 + <state relative-caret-position="361">
168 - <caret line="53" column="14" lean-forward="true" selection-start-line="53" selection-start-column="14" selection-end-line="53" selection-end-column="14" /> 174 + <caret line="28" lean-forward="true" selection-start-line="16" selection-end-line="28" />
169 </state> 175 </state>
170 </provider> 176 </provider>
171 </entry> 177 </entry>
172 </file> 178 </file>
173 <file pinned="false" current-in-tab="true"> 179 <file pinned="false" current-in-tab="true">
174 - <entry file="file://$PROJECT_DIR$/views/setting.ejs">
175 - <provider selected="true" editor-type-id="text-editor">
176 - <state relative-caret-position="551">
177 - <caret line="29" column="22" selection-start-line="29" selection-start-column="22" selection-end-line="29" selection-end-column="22" />
178 - </state>
179 - </provider>
180 - </entry>
181 - </file>
182 - <file pinned="false" current-in-tab="false">
183 - <entry file="file://$PROJECT_DIR$/views/toonviewer.ejs">
184 - <provider selected="true" editor-type-id="text-editor">
185 - <state relative-caret-position="152">
186 - <caret line="8" column="21" lean-forward="true" selection-start-line="8" selection-start-column="21" selection-end-line="8" selection-end-column="21" />
187 - </state>
188 - </provider>
189 - </entry>
190 - </file>
191 - <file pinned="false" current-in-tab="false">
192 - <entry file="file://$PROJECT_DIR$/views/mytoons.ejs">
193 - <provider selected="true" editor-type-id="text-editor">
194 - <state relative-caret-position="475">
195 - <caret line="25" column="12" lean-forward="true" selection-start-line="25" selection-start-column="12" selection-end-line="25" selection-end-column="12" />
196 - </state>
197 - </provider>
198 - </entry>
199 - </file>
200 - <file pinned="false" current-in-tab="false">
201 <entry file="file://$PROJECT_DIR$/views/index.ejs"> 180 <entry file="file://$PROJECT_DIR$/views/index.ejs">
202 <provider selected="true" editor-type-id="text-editor"> 181 <provider selected="true" editor-type-id="text-editor">
203 - <state relative-caret-position="1881"> 182 + <state relative-caret-position="361">
204 - <caret line="99" column="14" lean-forward="true" selection-start-line="99" selection-start-column="14" selection-end-line="99" selection-end-column="14" /> 183 + <caret line="46" column="84" lean-forward="true" selection-start-line="46" selection-start-column="84" selection-end-line="46" selection-end-column="84" />
205 - </state> 184 + <folding>
206 - </provider> 185 + <element signature="n#style#0;n#div#2;n#body#0;n#html#0;n#!!top" expanded="true" />
207 - </entry> 186 + </folding>
208 - </file>
209 - <file pinned="false" current-in-tab="false">
210 - <entry file="file://$PROJECT_DIR$/routes/index.js">
211 - <provider selected="true" editor-type-id="text-editor">
212 - <state relative-caret-position="152">
213 - <caret line="8" lean-forward="true" selection-start-line="8" selection-end-line="8" />
214 </state> 187 </state>
215 </provider> 188 </provider>
216 </entry> 189 </entry>
...@@ -227,8 +200,6 @@ ...@@ -227,8 +200,6 @@
227 </component> 200 </component>
228 <component name="FindInProjectRecents"> 201 <component name="FindInProjectRecents">
229 <findStrings> 202 <findStrings>
230 - <find>connection.</find>
231 - <find>connection.end</find>
232 <find>connection.connect()</find> 203 <find>connection.connect()</find>
233 <find>login</find> 204 <find>login</find>
234 <find>done(</find> 205 <find>done(</find>
...@@ -257,6 +228,8 @@ ...@@ -257,6 +228,8 @@
257 <find>로그인</find> 228 <find>로그인</find>
258 <find>console.log(</find> 229 <find>console.log(</find>
259 <find>des</find> 230 <find>des</find>
231 + <find>웹툰</find>
232 + <find>getall</find>
260 </findStrings> 233 </findStrings>
261 <dirStrings> 234 <dirStrings>
262 <dir>$PROJECT_DIR$/views</dir> 235 <dir>$PROJECT_DIR$/views</dir>
...@@ -296,14 +269,14 @@ ...@@ -296,14 +269,14 @@
296 <option value="$PROJECT_DIR$/node_modules/phantomjs/lib/phantom/examples/module.js" /> 269 <option value="$PROJECT_DIR$/node_modules/phantomjs/lib/phantom/examples/module.js" />
297 <option value="$PROJECT_DIR$/views/daum" /> 270 <option value="$PROJECT_DIR$/views/daum" />
298 <option value="$PROJECT_DIR$/views/daum.ejs" /> 271 <option value="$PROJECT_DIR$/views/daum.ejs" />
299 - <option value="$PROJECT_DIR$/views/index.ejs" />
300 <option value="$PROJECT_DIR$/routes/daum.js" /> 272 <option value="$PROJECT_DIR$/routes/daum.js" />
301 - <option value="$PROJECT_DIR$/app.js" />
302 - <option value="$PROJECT_DIR$/routes/index.js" />
303 <option value="$PROJECT_DIR$/routes/mytoons.js" /> 273 <option value="$PROJECT_DIR$/routes/mytoons.js" />
304 <option value="$PROJECT_DIR$/routes/toonviewer.js" /> 274 <option value="$PROJECT_DIR$/routes/toonviewer.js" />
305 <option value="$PROJECT_DIR$/routes/setting.js" /> 275 <option value="$PROJECT_DIR$/routes/setting.js" />
276 + <option value="$PROJECT_DIR$/app.js" />
277 + <option value="$PROJECT_DIR$/routes/index.js" />
306 <option value="$PROJECT_DIR$/views/mytoons.ejs" /> 278 <option value="$PROJECT_DIR$/views/mytoons.ejs" />
279 + <option value="$PROJECT_DIR$/views/index.ejs" />
307 </list> 280 </list>
308 </option> 281 </option>
309 </component> 282 </component>
...@@ -324,9 +297,9 @@ ...@@ -324,9 +297,9 @@
324 </packageJsonPaths> 297 </packageJsonPaths>
325 </component> 298 </component>
326 <component name="ProjectFrameBounds" extendedState="6"> 299 <component name="ProjectFrameBounds" extendedState="6">
327 - <option name="x" value="-9" /> 300 + <option name="x" value="-8" />
328 - <option name="width" value="978" /> 301 + <option name="width" value="977" />
329 - <option name="height" value="1039" /> 302 + <option name="height" value="1038" />
330 </component> 303 </component>
331 <component name="ProjectLevelVcsManager" settingsEditedManually="true" /> 304 <component name="ProjectLevelVcsManager" settingsEditedManually="true" />
332 <component name="ProjectView"> 305 <component name="ProjectView">
...@@ -334,6 +307,7 @@ ...@@ -334,6 +307,7 @@
334 <foldersAlwaysOnTop value="true" /> 307 <foldersAlwaysOnTop value="true" />
335 </navigator> 308 </navigator>
336 <panes> 309 <panes>
310 + <pane id="Scope" />
337 <pane id="ProjectPane"> 311 <pane id="ProjectPane">
338 <subPane> 312 <subPane>
339 <expand> 313 <expand>
...@@ -349,6 +323,17 @@ ...@@ -349,6 +323,17 @@
349 <path> 323 <path>
350 <item name="YTMT" type="b2602c69:ProjectViewProjectNode" /> 324 <item name="YTMT" type="b2602c69:ProjectViewProjectNode" />
351 <item name="YTMT" type="462c0819:PsiDirectoryNode" /> 325 <item name="YTMT" type="462c0819:PsiDirectoryNode" />
326 + <item name="public" type="462c0819:PsiDirectoryNode" />
327 + </path>
328 + <path>
329 + <item name="YTMT" type="b2602c69:ProjectViewProjectNode" />
330 + <item name="YTMT" type="462c0819:PsiDirectoryNode" />
331 + <item name="public" type="462c0819:PsiDirectoryNode" />
332 + <item name="stylesheets" type="462c0819:PsiDirectoryNode" />
333 + </path>
334 + <path>
335 + <item name="YTMT" type="b2602c69:ProjectViewProjectNode" />
336 + <item name="YTMT" type="462c0819:PsiDirectoryNode" />
352 <item name="routes" type="462c0819:PsiDirectoryNode" /> 337 <item name="routes" type="462c0819:PsiDirectoryNode" />
353 </path> 338 </path>
354 <path> 339 <path>
...@@ -360,7 +345,6 @@ ...@@ -360,7 +345,6 @@
360 <select /> 345 <select />
361 </subPane> 346 </subPane>
362 </pane> 347 </pane>
363 - <pane id="Scope" />
364 <pane id="AndroidView" /> 348 <pane id="AndroidView" />
365 <pane id="PackagesPane" /> 349 <pane id="PackagesPane" />
366 </panes> 350 </panes>
...@@ -522,6 +506,7 @@ ...@@ -522,6 +506,7 @@
522 <workItem from="1543588884449" duration="7362000" /> 506 <workItem from="1543588884449" duration="7362000" />
523 <workItem from="1543625351688" duration="5520000" /> 507 <workItem from="1543625351688" duration="5520000" />
524 <workItem from="1543732778568" duration="2000" /> 508 <workItem from="1543732778568" duration="2000" />
509 + <workItem from="1543986114264" duration="3571000" />
525 </task> 510 </task>
526 <task id="LOCAL-00001" summary="초기 commit by intellij"> 511 <task id="LOCAL-00001" summary="초기 commit by intellij">
527 <created>1512174269218</created> 512 <created>1512174269218</created>
...@@ -541,7 +526,7 @@ ...@@ -541,7 +526,7 @@
541 <servers /> 526 <servers />
542 </component> 527 </component>
543 <component name="TimeTrackingManager"> 528 <component name="TimeTrackingManager">
544 - <option name="totallyTimeSpent" value="232161000" /> 529 + <option name="totallyTimeSpent" value="235732000" />
545 </component> 530 </component>
546 <component name="TodoView"> 531 <component name="TodoView">
547 <todo-panel id="selected-file"> 532 <todo-panel id="selected-file">
...@@ -554,6 +539,7 @@ ...@@ -554,6 +539,7 @@
554 </component> 539 </component>
555 <component name="ToolWindowManager"> 540 <component name="ToolWindowManager">
556 <frame x="-7" y="-7" width="1550" height="838" extended-state="6" /> 541 <frame x="-7" y="-7" width="1550" height="838" extended-state="6" />
542 + <editor active="true" />
557 <layout> 543 <layout>
558 <window_info active="true" content_ui="combo" id="Project" order="0" sideWeight="0.48880598" visible="true" weight="0.16523464" /> 544 <window_info active="true" content_ui="combo" id="Project" order="0" sideWeight="0.48880598" visible="true" weight="0.16523464" />
559 <window_info id="Structure" order="1" weight="0.24964234" /> 545 <window_info id="Structure" order="1" weight="0.24964234" />
...@@ -732,66 +718,96 @@ ...@@ -732,66 +718,96 @@
732 </provider> 718 </provider>
733 </entry> 719 </entry>
734 <entry file="file://$USER_HOME$/Desktop/YTMT-master-f6ba581c2d39966c105a13a31a3246237b655d48/YTMT-master-f6ba581c2d39966c105a13a31a3246237b655d48/app.js" /> 720 <entry file="file://$USER_HOME$/Desktop/YTMT-master-f6ba581c2d39966c105a13a31a3246237b655d48/YTMT-master-f6ba581c2d39966c105a13a31a3246237b655d48/app.js" />
735 - <entry file="file://$PROJECT_DIR$/app.js"> 721 + <entry file="file://$PROJECT_DIR$/views/toonviewer.ejs">
736 <provider selected="true" editor-type-id="text-editor"> 722 <provider selected="true" editor-type-id="text-editor">
737 - <state relative-caret-position="146"> 723 + <state relative-caret-position="152">
738 - <caret line="62" column="35" lean-forward="true" selection-start-line="62" selection-start-column="35" selection-end-line="62" selection-end-column="35" /> 724 + <caret line="8" column="21" selection-start-line="8" selection-start-column="21" selection-end-line="8" selection-end-column="21" />
739 </state> 725 </state>
740 </provider> 726 </provider>
741 </entry> 727 </entry>
742 - <entry file="file://$PROJECT_DIR$/routes/mytoons.js"> 728 + <entry file="file://$PROJECT_DIR$/views/setting.ejs">
729 + <provider selected="true" editor-type-id="text-editor">
730 + <state relative-caret-position="589">
731 + <caret line="31" column="15" lean-forward="true" selection-start-line="31" selection-start-column="15" selection-end-line="31" selection-end-column="15" />
732 + </state>
733 + </provider>
734 + </entry>
735 + <entry file="file://$PROJECT_DIR$/routes/setting.js">
743 <provider selected="true" editor-type-id="text-editor"> 736 <provider selected="true" editor-type-id="text-editor">
744 - <state relative-caret-position="171"> 737 + <state relative-caret-position="1007">
745 - <caret line="9" column="27" selection-start-line="9" selection-start-column="27" selection-end-line="9" selection-end-column="27" /> 738 + <caret line="53" column="14" selection-start-line="53" selection-start-column="14" selection-end-line="53" selection-end-column="14" />
746 </state> 739 </state>
747 </provider> 740 </provider>
748 </entry> 741 </entry>
749 <entry file="file://$PROJECT_DIR$/routes/toonviewer.js"> 742 <entry file="file://$PROJECT_DIR$/routes/toonviewer.js">
750 <provider selected="true" editor-type-id="text-editor"> 743 <provider selected="true" editor-type-id="text-editor">
751 - <state relative-caret-position="133"> 744 + <state relative-caret-position="198">
752 - <caret line="7" column="23" selection-start-line="7" selection-start-column="23" selection-end-line="7" selection-end-column="23" /> 745 + <caret line="26" column="7" lean-forward="true" selection-start-line="26" selection-start-column="7" selection-end-line="26" selection-end-column="7" />
753 </state> 746 </state>
754 </provider> 747 </provider>
755 </entry> 748 </entry>
756 - <entry file="file://$PROJECT_DIR$/routes/setting.js"> 749 + <entry file="file://$PROJECT_DIR$/app.js">
757 <provider selected="true" editor-type-id="text-editor"> 750 <provider selected="true" editor-type-id="text-editor">
758 - <state relative-caret-position="1007"> 751 + <state relative-caret-position="274">
759 - <caret line="53" column="14" lean-forward="true" selection-start-line="53" selection-start-column="14" selection-end-line="53" selection-end-column="14" /> 752 + <caret line="71" column="16" lean-forward="true" selection-start-line="71" selection-start-column="16" selection-end-line="71" selection-end-column="16" />
760 </state> 753 </state>
761 </provider> 754 </provider>
762 </entry> 755 </entry>
763 - <entry file="file://$PROJECT_DIR$/views/toonviewer.ejs"> 756 + <entry file="file://$PROJECT_DIR$/routes/index.js">
764 <provider selected="true" editor-type-id="text-editor"> 757 <provider selected="true" editor-type-id="text-editor">
765 - <state relative-caret-position="152"> 758 + <state relative-caret-position="207">
766 - <caret line="8" column="21" lean-forward="true" selection-start-line="8" selection-start-column="21" selection-end-line="8" selection-end-column="21" /> 759 + <caret line="237" column="39" lean-forward="true" selection-start-line="237" selection-start-column="39" selection-end-line="237" selection-end-column="39" />
767 </state> 760 </state>
768 </provider> 761 </provider>
769 </entry> 762 </entry>
770 - <entry file="file://$PROJECT_DIR$/views/mytoons.ejs"> 763 + <entry file="file://$PROJECT_DIR$/views/nivo-lightbox.js">
771 <provider selected="true" editor-type-id="text-editor"> 764 <provider selected="true" editor-type-id="text-editor">
772 - <state relative-caret-position="475"> 765 + <state relative-caret-position="190">
773 - <caret line="25" column="12" lean-forward="true" selection-start-line="25" selection-start-column="12" selection-end-line="25" selection-end-column="12" /> 766 + <caret line="10" lean-forward="true" selection-start-line="10" selection-end-line="10" />
767 + <folding>
768 + <element signature="n#!!doc" expanded="true" />
769 + </folding>
774 </state> 770 </state>
775 </provider> 771 </provider>
776 </entry> 772 </entry>
777 - <entry file="file://$PROJECT_DIR$/views/index.ejs"> 773 + <entry file="file://$PROJECT_DIR$/public/stylesheets/style2.css">
774 + <provider selected="true" editor-type-id="text-editor" />
775 + </entry>
776 + <entry file="file://$PROJECT_DIR$/public/stylesheets/bootstrap.css">
778 <provider selected="true" editor-type-id="text-editor"> 777 <provider selected="true" editor-type-id="text-editor">
779 - <state relative-caret-position="1881"> 778 + <state relative-caret-position="209">
780 - <caret line="99" column="14" lean-forward="true" selection-start-line="99" selection-start-column="14" selection-end-line="99" selection-end-column="14" /> 779 + <caret line="11" column="1" lean-forward="true" selection-start-line="11" selection-start-column="1" selection-end-line="11" selection-end-column="1" />
781 </state> 780 </state>
782 </provider> 781 </provider>
783 </entry> 782 </entry>
784 - <entry file="file://$PROJECT_DIR$/routes/index.js"> 783 + <entry file="file://$PROJECT_DIR$/routes/mytoons.js">
785 <provider selected="true" editor-type-id="text-editor"> 784 <provider selected="true" editor-type-id="text-editor">
786 - <state relative-caret-position="152"> 785 + <state relative-caret-position="-152">
787 - <caret line="8" lean-forward="true" selection-start-line="8" selection-end-line="8" /> 786 + <caret line="7" column="1" selection-start-line="7" selection-start-column="1" selection-end-line="7" selection-end-column="1" />
788 </state> 787 </state>
789 </provider> 788 </provider>
790 </entry> 789 </entry>
791 - <entry file="file://$PROJECT_DIR$/views/setting.ejs"> 790 + <entry file="file://$PROJECT_DIR$/views/mytoons.ejs">
791 + <provider selected="true" editor-type-id="text-editor">
792 + <state relative-caret-position="-1862">
793 + <caret line="19" column="4" selection-start-line="19" selection-start-column="4" selection-end-line="19" selection-end-column="4" />
794 + </state>
795 + </provider>
796 + </entry>
797 + <entry file="file://$PROJECT_DIR$/views/index.html">
798 + <provider selected="true" editor-type-id="text-editor">
799 + <state relative-caret-position="361">
800 + <caret line="28" lean-forward="true" selection-start-line="16" selection-end-line="28" />
801 + </state>
802 + </provider>
803 + </entry>
804 + <entry file="file://$PROJECT_DIR$/views/index.ejs">
792 <provider selected="true" editor-type-id="text-editor"> 805 <provider selected="true" editor-type-id="text-editor">
793 - <state relative-caret-position="551"> 806 + <state relative-caret-position="361">
794 - <caret line="29" column="22" selection-start-line="29" selection-start-column="22" selection-end-line="29" selection-end-column="22" /> 807 + <caret line="46" column="84" lean-forward="true" selection-start-line="46" selection-start-column="84" selection-end-line="46" selection-end-column="84" />
808 + <folding>
809 + <element signature="n#style#0;n#div#2;n#body#0;n#html#0;n#!!top" expanded="true" />
810 + </folding>
795 </state> 811 </state>
796 </provider> 812 </provider>
797 </entry> 813 </entry>
......
...@@ -42,7 +42,7 @@ app.use(express.static(path.join(__dirname, 'public'))); ...@@ -42,7 +42,7 @@ app.use(express.static(path.join(__dirname, 'public')));
42 connection = mysql.createConnection({ 42 connection = mysql.createConnection({
43 host : 'localhost', 43 host : 'localhost',
44 user : 'root', 44 user : 'root',
45 - password : '6377', 45 + password : 'password',
46 port : 3306, 46 port : 3306,
47 database : 'YTMT' 47 database : 'YTMT'
48 }); 48 });
......
This diff could not be displayed because it is too large.
This diff could not be displayed because it is too large.
1 +/*
2 + * Nivo Lightbox Default Theme v1.0
3 + * http://dev7studios.com/nivo-lightbox
4 + *
5 + * Copyright 2013, Dev7studios
6 + * Free to use and abuse under the MIT license.
7 + * http://www.opensource.org/licenses/mit-license.php
8 + */
9 +
10 + .nivo-lightbox-theme-default * {
11 + -webkit-box-sizing: initial !important;
12 + -moz-box-sizing: initial !important;
13 + box-sizing: initial !important;
14 + }
15 +.nivo-lightbox-theme-default.nivo-lightbox-overlay {
16 + background: #666;
17 + background: rgba(0,0,0,0.6);
18 +}
19 +.nivo-lightbox-theme-default .nivo-lightbox-content.nivo-lightbox-loading { background: url(loading.gif) no-repeat 50% 50%; }
20 +
21 +.nivo-lightbox-theme-default .nivo-lightbox-nav {
22 + top: 10%;
23 + width: 8%;
24 + height: 80%;
25 + text-indent: -9999px;
26 + background-repeat: no-repeat;
27 + background-position: 50% 50%;
28 + opacity: 0.5;
29 +}
30 +.nivo-lightbox-theme-default .nivo-lightbox-nav:hover {
31 + opacity: 1;
32 + background-color: transparent;
33 +}
34 +.nivo-lightbox-theme-default .nivo-lightbox-prev {
35 + background-image: url(prev.png);
36 + border-radius: 0 3px 3px 0;
37 +}
38 +.nivo-lightbox-theme-default .nivo-lightbox-next {
39 + background-image: url(next.png);
40 + border-radius: 3px 0 0 3px;
41 +}
42 +
43 +.nivo-lightbox-theme-default .nivo-lightbox-close {
44 + display: block;
45 + background: url(close.png) no-repeat 5px 5px;
46 + width: 16px;
47 + height: 16px;
48 + text-indent: -9999px;
49 + padding: 5px;
50 + opacity: 0.5;
51 +}
52 +.nivo-lightbox-theme-default .nivo-lightbox-close:hover { opacity: 1; }
53 +
54 +.nivo-lightbox-theme-default .nivo-lightbox-title-wrap { bottom: -7%; }
55 +.nivo-lightbox-theme-default .nivo-lightbox-title {
56 + font: 14px/20px 'Helvetica Neue', Helvetica, Arial, sans-serif;
57 + font-style: normal;
58 + font-weight: normal;
59 + background: #000;
60 + color: #fff;
61 + padding: 7px 15px;
62 + border-radius: 30px;
63 +}
64 +
65 +.nivo-lightbox-theme-default .nivo-lightbox-image img {
66 + background: #fff;
67 + -webkit-box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
68 + -moz-box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
69 + box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
70 +}
71 +.nivo-lightbox-theme-default .nivo-lightbox-ajax,
72 +.nivo-lightbox-theme-default .nivo-lightbox-inline {
73 + background: #fff;
74 + padding: 40px;
75 + -webkit-box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
76 + -moz-box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
77 + box-shadow: 0px 1px 1px rgba(0,0,0,0.4);
78 +}
79 +
80 +@media (-webkit-min-device-pixel-ratio: 1.3),
81 + (-o-min-device-pixel-ratio: 2.6/2),
82 + (min--moz-device-pixel-ratio: 1.3),
83 + (min-device-pixel-ratio: 1.3),
84 + (min-resolution: 1.3dppx) {
85 +
86 + .nivo-lightbox-theme-default .nivo-lightbox-content.nivo-lightbox-loading {
87 + background-image: url(loading@2x.gif);
88 + background-size: 32px 32px;
89 + }
90 + .nivo-lightbox-theme-default .nivo-lightbox-prev {
91 + background-image: url(prev@2x.png);
92 + background-size: 48px 48px;
93 + }
94 + .nivo-lightbox-theme-default .nivo-lightbox-next {
95 + background-image: url(next@2x.png);
96 + background-size: 48px 48px;
97 + }
98 + .nivo-lightbox-theme-default .nivo-lightbox-close {
99 + background-image: url(close@2x.png);
100 + background-size: 16px 16px;
101 + }
102 +
103 +}
...\ No newline at end of file ...\ No newline at end of file
1 +/*
2 + * Nivo Lightbox v1.2.0
3 + * http://dev7studios.com/nivo-lightbox
4 + *
5 + * Copyright 2013, Dev7studios
6 + * Free to use and abuse under the MIT license.
7 + * http://www.opensource.org/licenses/mit-license.php
8 + */
9 +
10 +.nivo-lightbox-overlay {
11 + position: fixed;
12 + top: 0;
13 + left: 0;
14 + z-index: 99998;
15 + width: 100%;
16 + height: 100%;
17 + overflow: hidden;
18 + visibility: hidden;
19 + opacity: 0;
20 + -webkit-box-sizing: border-box;
21 + -moz-box-sizing: border-box;
22 + box-sizing: border-box;
23 +}
24 +.nivo-lightbox-overlay.nivo-lightbox-open {
25 + visibility: visible;
26 + opacity: 1;
27 +}
28 +.nivo-lightbox-wrap {
29 + position: absolute;
30 + top: 10%;
31 + bottom: 10%;
32 + left: 10%;
33 + right: 10%;
34 +}
35 +.nivo-lightbox-content {
36 + width: 100%;
37 + height: 100%;
38 +}
39 +.nivo-lightbox-title-wrap {
40 + position: absolute;
41 + bottom: 0;
42 + left: 0;
43 + width: 100%;
44 + z-index: 99999;
45 + text-align: center;
46 +}
47 +.nivo-lightbox-nav { display: none; }
48 +.nivo-lightbox-prev {
49 + position: absolute;
50 + top: 50%;
51 + left: 0;
52 +}
53 +.nivo-lightbox-next {
54 + position: absolute;
55 + top: 50%;
56 + right: 0;
57 +}
58 +.nivo-lightbox-close {
59 + position: absolute;
60 + top: 2%;
61 + right: 2%;
62 +}
63 +
64 +.nivo-lightbox-image { text-align: center; }
65 +.nivo-lightbox-image img {
66 + max-width: 100%;
67 + max-height: 100%;
68 + width: auto;
69 + height: auto;
70 + vertical-align: middle;
71 +}
72 +.nivo-lightbox-content iframe {
73 + width: 100%;
74 + height: 100%;
75 +}
76 +.nivo-lightbox-inline,
77 +.nivo-lightbox-ajax {
78 + max-height: 100%;
79 + overflow: auto;
80 + -webkit-box-sizing: border-box;
81 + -moz-box-sizing: border-box;
82 + box-sizing: border-box;
83 + /* https://bugzilla.mozilla.org/show_bug.cgi?id=308801 */
84 +}
85 +.nivo-lightbox-error {
86 + display: table;
87 + text-align: center;
88 + width: 100%;
89 + height: 100%;
90 + color: #fff;
91 + text-shadow: 0 1px 1px #000;
92 +}
93 +.nivo-lightbox-error p {
94 + display: table-cell;
95 + vertical-align: middle;
96 +}
97 +
98 +/* Effects
99 + **********************************************/
100 +.nivo-lightbox-notouch .nivo-lightbox-effect-fade,
101 +.nivo-lightbox-notouch .nivo-lightbox-effect-fadeScale,
102 +.nivo-lightbox-notouch .nivo-lightbox-effect-slideLeft,
103 +.nivo-lightbox-notouch .nivo-lightbox-effect-slideRight,
104 +.nivo-lightbox-notouch .nivo-lightbox-effect-slideUp,
105 +.nivo-lightbox-notouch .nivo-lightbox-effect-slideDown,
106 +.nivo-lightbox-notouch .nivo-lightbox-effect-fall {
107 + -webkit-transition: all 0.2s ease-in-out;
108 + -moz-transition: all 0.2s ease-in-out;
109 + -ms-transition: all 0.2s ease-in-out;
110 + -o-transition: all 0.2s ease-in-out;
111 + transition: all 0.2s ease-in-out;
112 +}
113 +
114 +/* fadeScale */
115 +.nivo-lightbox-effect-fadeScale .nivo-lightbox-wrap {
116 + -webkit-transition: all 0.3s;
117 + -moz-transition: all 0.3s;
118 + -ms-transition: all 0.3s;
119 + -o-transition: all 0.3s;
120 + transition: all 0.3s;
121 + -webkit-transform: scale(0.7);
122 + -moz-transform: scale(0.7);
123 + -ms-transform: scale(0.7);
124 + transform: scale(0.7);
125 +}
126 +.nivo-lightbox-effect-fadeScale.nivo-lightbox-open .nivo-lightbox-wrap {
127 + -webkit-transform: scale(1);
128 + -moz-transform: scale(1);
129 + -ms-transform: scale(1);
130 + transform: scale(1);
131 +}
132 +
133 +/* slideLeft / slideRight / slideUp / slideDown */
134 +.nivo-lightbox-effect-slideLeft .nivo-lightbox-wrap,
135 +.nivo-lightbox-effect-slideRight .nivo-lightbox-wrap,
136 +.nivo-lightbox-effect-slideUp .nivo-lightbox-wrap,
137 +.nivo-lightbox-effect-slideDown .nivo-lightbox-wrap {
138 + -webkit-transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
139 + -moz-transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
140 + -ms-transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
141 + -o-transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
142 + transition: all 0.3s cubic-bezier(0.25, 0.5, 0.5, 0.9);
143 +}
144 +.nivo-lightbox-effect-slideLeft .nivo-lightbox-wrap {
145 + -webkit-transform: translateX(-10%);
146 + -moz-transform: translateX(-10%);
147 + -ms-transform: translateX(-10%);
148 + transform: translateX(-10%);
149 +}
150 +.nivo-lightbox-effect-slideRight .nivo-lightbox-wrap {
151 + -webkit-transform: translateX(10%);
152 + -moz-transform: translateX(10%);
153 + -ms-transform: translateX(10%);
154 + transform: translateX(10%);
155 +}
156 +.nivo-lightbox-effect-slideLeft.nivo-lightbox-open .nivo-lightbox-wrap,
157 +.nivo-lightbox-effect-slideRight.nivo-lightbox-open .nivo-lightbox-wrap {
158 + -webkit-transform: translateX(0);
159 + -moz-transform: translateX(0);
160 + -ms-transform: translateX(0);
161 + transform: translateX(0);
162 +}
163 +.nivo-lightbox-effect-slideDown .nivo-lightbox-wrap {
164 + -webkit-transform: translateY(-10%);
165 + -moz-transform: translateY(-10%);
166 + -ms-transform: translateY(-10%);
167 + transform: translateY(-10%);
168 +}
169 +.nivo-lightbox-effect-slideUp .nivo-lightbox-wrap {
170 + -webkit-transform: translateY(10%);
171 + -moz-transform: translateY(10%);
172 + -ms-transform: translateY(10%);
173 + transform: translateY(10%);
174 +}
175 +.nivo-lightbox-effect-slideUp.nivo-lightbox-open .nivo-lightbox-wrap,
176 +.nivo-lightbox-effect-slideDown.nivo-lightbox-open .nivo-lightbox-wrap {
177 + -webkit-transform: translateY(0);
178 + -moz-transform: translateY(0);
179 + -ms-transform: translateY(0);
180 + transform: translateY(0);
181 +}
182 +
183 +/* fall */
184 +.nivo-lightbox-body-effect-fall .nivo-lightbox-effect-fall {
185 + -webkit-perspective: 1000px;
186 + -moz-perspective: 1000px;
187 + perspective: 1000px;
188 +}
189 +.nivo-lightbox-effect-fall .nivo-lightbox-wrap {
190 + -webkit-transition: all 0.3s ease-out;
191 + -moz-transition: all 0.3s ease-out;
192 + -ms-transition: all 0.3s ease-out;
193 + -o-transition: all 0.3s ease-out;
194 + transition: all 0.3s ease-out;
195 + -webkit-transform: translateZ(300px);
196 + -moz-transform: translateZ(300px);
197 + -ms-transform: translateZ(300px);
198 + transform: translateZ(300px);
199 +}
200 +.nivo-lightbox-effect-fall.nivo-lightbox-open .nivo-lightbox-wrap {
201 + -webkit-transform: translateZ(0);
202 + -moz-transform: translateZ(0);
203 + -ms-transform: translateZ(0);
204 + transform: translateZ(0);
205 +}
1 -body { 1 +body, html {
2 - padding: 50px; 2 + font-family: 'Raleway', sans-serif;
3 - font: 14px "Lucida Grande", Helvetica, Arial, sans-serif; 3 + text-rendering: optimizeLegibility !important;
4 + -webkit-font-smoothing: antialiased !important;
5 + color: #777;
6 + font-weight: 300;
7 + width: 100% !important;
8 + height: 100% !important;
9 +}
10 +h2 {
11 + margin: 0 0 20px 0;
12 + font-weight: 500;
13 + font-size: 34px;
14 + color: #333;
15 + text-transform: uppercase;
16 +}
17 +h3 {
18 + font-size: 22px;
19 + font-weight: 500;
20 + color: #333;
21 +}
22 +h4 {
23 + font-size: 24px;
24 + text-transform: uppercase;
25 + font-weight: 400;
26 + color: #333;
27 +}
28 +h5 {
29 + text-transform: uppercase;
30 + font-weight: 700;
31 + line-height: 20px;
32 +}
33 +p {
34 + font-size: 16px;
35 +}
36 +p.intro {
37 + margin: 12px 0 0;
38 + line-height: 24px;
4 } 39 }
5 -
6 a { 40 a {
7 - color: #00B7FF; 41 + color: #8eb640;
42 +}
43 +a:hover, a:focus {
44 + text-decoration: none;
45 + color: #222;
46 +}
47 +ul, ol {
48 + list-style: none;
49 +}
50 +.clearfix:after {
51 + visibility: hidden;
52 + display: block;
53 + font-size: 0;
54 + content: " ";
55 + clear: both;
56 + height: 0;
57 +}
58 +.clearfix {
59 + display: inline-block;
60 +}
61 +* html .clearfix {
62 + height: 1%;
63 +}
64 +.clearfix {
65 + display: block;
66 +}
67 +ul, ol {
68 + padding: 0;
69 + webkit-padding: 0;
70 + moz-padding: 0;
71 +}
72 +hr {
73 + height: 2px;
74 + width: 70px;
75 + text-align: center;
76 + position: relative;
77 + background: #8eb640;
78 + margin: 0;
79 + margin-bottom: 40px;
80 + border: 0;
81 +}
82 +.btn:active, .btn.active {
83 + background-image: none;
84 + outline: 0;
85 + -webkit-box-shadow: none;
86 + box-shadow: none;
87 +}
88 +a:focus, .btn:focus, .btn:active:focus, .btn.active:focus, .btn.focus, .btn:active.focus, .btn.active.focus {
89 + outline: none;
90 + outline-offset: none;
91 +}
92 +/* Navigation */
93 +#menu {
94 + padding: 20px;
95 + transition: all 0.8s;
96 +}
97 +#menu.navbar-default {
98 + background-color: rgba(248, 248, 248, 0);
99 + border-color: rgba(231, 231, 231, 0);
100 +}
101 +#menu a.navbar-brand {
102 + font-family: 'Dancing Script', cursive;
103 + font-size: 36px;
104 + color: #8eb640;
105 + font-weight: 700;
106 + letter-spacing: 1px;
107 +}
108 +#menu.navbar-default .navbar-nav > li > a {
109 + text-transform: uppercase;
110 + color: #ddd;
111 + font-weight: 500;
112 + font-size: 15px;
113 + padding: 5px 0;
114 + border: 2px solid transparent;
115 + letter-spacing: 0.5px;
116 + margin: 10px 15px 0 15px;
117 +}
118 +#menu.navbar-default .navbar-nav > li > a:hover {
119 + color: #8eb640;
120 +}
121 +.on {
122 + background-color: #262626 !important;
123 + padding: 0 !important;
124 + padding: 10px 0 !important;
125 +}
126 +.navbar-default .navbar-nav > .active > a, .navbar-default .navbar-nav > .active > a:hover, .navbar-default .navbar-nav > .active > a:focus {
127 + color: #8eb640 !important;
128 + background-color: transparent;
129 +}
130 +.navbar-toggle {
131 + border-radius: 0;
132 +}
133 +.navbar-default .navbar-toggle:hover, .navbar-default .navbar-toggle:focus {
134 + background-color: #8eb640;
135 + border-color: #8eb640;
136 +}
137 +.navbar-default .navbar-toggle:hover>.icon-bar {
138 + background-color: #FFF;
139 +}
140 +.section-title {
141 + margin-bottom: 70px;
142 +}
143 +.section-title .overlay {
144 + padding: 80px 0;
145 + background: rgba(0, 0, 0, 0.7);
146 +}
147 +.section-title p {
148 + font-size: 22px;
149 + color: rgba(255,255,255,0.8);
150 +}
151 +.section-title hr {
152 + margin: 0 auto;
153 + margin-bottom: 40px;
154 +}
155 +.btn-custom {
156 + text-transform: uppercase;
157 + color: #fff;
158 + background-color: #72a411;
159 + border: 0;
160 + padding: 14px 20px;
161 + margin: 0;
162 + font-size: 16px;
163 + font-weight: 500;
164 + letter-spacing: 0.5px;
165 + border-radius: 0;
166 + margin-top: 20px;
167 + transition: all 0.5s;
168 +}
169 +.btn-custom:hover, .btn-custom:focus, .btn-custom.focus, .btn-custom:active, .btn-custom.active {
170 + color: #fff;
171 + background-color: #628d0f;
172 +}
173 +/* Header Section */
174 +.intro {
175 + display: table;
176 + width: 100%;
177 + padding: 0;
178 + background: url(../img/intro-bg.jpg) no-repeat center center;
179 + background-color: #e5e5e5;
180 + -webkit-background-size: cover;
181 + -moz-background-size: cover;
182 + background-size: cover;
183 + -o-background-size: cover;
184 +}
185 +.intro .overlay {
186 + background: rgba(0,0,0,0.4);
187 +}
188 +.intro h1 {
189 + font-family: 'Dancing Script', cursive;
190 + color: #fff;
191 + font-size: 10em;
192 + font-weight: 700;
193 + margin-top: 0;
194 + margin-bottom: 10px;
195 +}
196 +.intro span {
197 + color: #a7c44c;
198 + font-weight: 600;
199 +}
200 +.intro p {
201 + color: #fff;
202 + font-size: 32px;
203 + font-weight: 300;
204 + margin-top: 10px;
205 + margin-bottom: 40px;
206 +}
207 +header .intro-text {
208 + padding-top: 250px;
209 + padding-bottom: 200px;
210 + text-align: center;
211 +}
212 +/* About Section */
213 +#about {
214 + padding: 120px 0;
215 +}
216 +#about h3 {
217 + font-size: 20px;
218 +}
219 +#about .about-text {
220 + margin-left: 10px;
221 +}
222 +#about .about-img {
223 + display: inline-block;
224 + position: relative;
225 +}
226 +#about .about-img:before {
227 + display: block;
228 + content: '';
229 + position: absolute;
230 + top: 8px;
231 + right: 8px;
232 + bottom: 8px;
233 + left: 8px;
234 + border: 1px solid rgba(255, 255, 255, 0.5);
235 +}
236 +#about p {
237 + line-height: 24px;
238 + margin: 15px 0 30px;
239 +}
240 +/* Menu Section */
241 +#restaurant-menu {
242 + padding: 0 0 60px 0;
243 +}
244 +#restaurant-menu .section-title {
245 + background: #444 url(../img/menu-bg.jpg) center center no-repeat fixed;
246 + background-size: cover;
247 +}
248 +#restaurant-menu .section-title h2 {
249 + color: #fff;
250 +}
251 +#restaurant-menu img {
252 + width: 300px;
253 + box-shadow: 15px 0 #a7c44c;
254 +}
255 +#restaurant-menu h3 {
256 + padding: 10px 0;
257 + text-transform: uppercase;
258 +}
259 +#restaurant-menu .menu-section hr {
260 + margin: 0 auto;
261 +}
262 +#restaurant-menu .menu-section {
263 + margin: 0 20px 80px;
264 +}
265 +#restaurant-menu .menu-section-title {
266 + font-size: 26px;
267 + display: block;
268 + font-weight: 500;
269 + color: #444;
270 + margin: 20px 0;
271 + text-align: center;
272 +}
273 +#restaurant-menu .menu-item {
274 + margin: 35px 0;
275 + font-size: 18px;
276 +}
277 +#restaurant-menu .menu-item-name {
278 + font-weight: 600;
279 + font-size: 17px;
280 + color: #555;
281 + border-bottom: 2px dotted rgb(213, 213, 213);
282 +}
283 +#restaurant-menu .menu-item-description {
284 + font-style: italic;
285 + font-size: 15px;
286 +}
287 +#restaurant-menu .menu-item-price {
288 + float: right;
289 + font-weight: 600;
290 + color: #555;
291 + margin-top: -26px;
292 +}
293 +/* Portfolio Section */
294 +#portfolio {
295 + padding: 0 0 120px 0;
296 +}
297 +#portfolio .section-title {
298 + background: #444 url(../img/gallery-bg.jpg) center center no-repeat fixed;
299 + background-size: cover;
300 + margin-bottom: 50px;
301 +}
302 +#portfolio .section-title h2 {
303 + color: #fff;
304 +}
305 +.categories {
306 + padding-bottom: 30px;
307 + text-align: center;
308 +}
309 +ul.cat li {
310 + display: inline-block;
311 +}
312 +ol.type li {
313 + display: inline-block;
314 + margin: 0 10px;
315 + padding: 20px 0;
316 +}
317 +ol.type li a {
318 + color: #999;
319 + font-weight: 500;
320 + font-size: 14px;
321 + padding: 12px 24px;
322 + background: #eee;
323 + border: 0;
324 + border-radius: 0;
325 + text-transform: uppercase;
326 + letter-spacing: 0.5px;
327 +}
328 +ol.type li a.active {
329 + color: #fff;
330 + background-color: #8eb640;
331 +}
332 +ol.type li a:hover {
333 + color: #fff;
334 + background-color: #8eb640;
335 +}
336 +.isotope-item {
337 + z-index: 2
338 +}
339 +.isotope-hidden.isotope-item {
340 + z-index: 1
341 +}
342 +.isotope, .isotope .isotope-item {
343 + /* change duration value to whatever you like */
344 + -webkit-transition-duration: 0.8s;
345 + -moz-transition-duration: 0.8s;
346 + transition-duration: 0.8s;
347 +}
348 +.isotope-item {
349 + margin-right: -1px;
350 + -webkit-backface-visibility: hidden;
351 + backface-visibility: hidden;
352 +}
353 +.isotope {
354 + -webkit-backface-visibility: hidden;
355 + backface-visibility: hidden;
356 + -webkit-transition-property: height, width;
357 + -moz-transition-property: height, width;
358 + transition-property: height, width;
359 +}
360 +.isotope .isotope-item {
361 + -webkit-backface-visibility: hidden;
362 + backface-visibility: hidden;
363 + -webkit-transition-property: -webkit-transform, opacity;
364 + -moz-transition-property: -moz-transform, opacity;
365 + transition-property: transform, opacity;
366 +}
367 +.portfolio-item {
368 + margin: 15px 0;
369 +}
370 +.portfolio-item .hover-bg {
371 + overflow: hidden;
372 + position: relative;
373 +}
374 +.portfolio-item .hover-bg:before {
375 + display: block;
376 + content: '';
377 + position: absolute;
378 + top: 6px;
379 + right: 6px;
380 + bottom: 6px;
381 + left: 6px;
382 + border: 1px solid rgba(255, 255, 255, 0.6);
383 +}
384 +.hover-bg .hover-text {
385 + position: absolute;
386 + text-align: center;
387 + margin: 0 auto;
388 + color: #fff;
389 + background: rgba(0, 0, 0, 0.6);
390 + padding: 30% 0 0 0;
391 + height: 100%;
392 + width: 100%;
393 + opacity: 0;
394 + transition: all 0.5s;
395 +}
396 +.hover-bg .hover-text>h4 {
397 + opacity: 0;
398 + color: #fff;
399 + -webkit-transform: translateY(100%);
400 + transform: translateY(100%);
401 + transition: all 0.3s;
402 + font-size: 17px;
403 + letter-spacing: 0.5px;
404 + font-weight: 500;
405 +}
406 +.hover-bg:hover .hover-text>h4 {
407 + opacity: 1;
408 + -webkit-backface-visibility: hidden;
409 + -webkit-transform: translateY(0);
410 + transform: translateY(0);
411 +}
412 +.hover-bg:hover .hover-text {
413 + opacity: 1;
414 +}
415 +/* Team Section */
416 +#team {
417 + color: #fff;
418 + background: #444 url(../img/team-bg.jpg) center top no-repeat fixed;
419 + background-size: cover;
420 +}
421 +#team .overlay {
422 + padding: 120px 0 80px 0;
423 + background: rgba(0, 0, 0, 0.6);
424 +}
425 +#team h2, #team p {
426 + color: #fff;
427 +}
428 +#team hr {
429 + background: #fff;
430 +}
431 +#team h3 {
432 + color: #fff;
433 + font-weight: 400;
434 + font-size: 20px;
435 + margin: 5px 0;
436 +}
437 +#team img {
438 + width: 280px;
439 +}
440 +#team .thumbnail {
441 + background: transparent;
442 + border: 0;
443 +}
444 +#team .thumbnail .team-img {
445 + display: inline-block;
446 + position: relative;
447 +}
448 +#team .thumbnail .team-img:before {
449 + display: block;
450 + content: '';
451 + position: absolute;
452 + top: 8px;
453 + right: 8px;
454 + bottom: 8px;
455 + left: 8px;
456 + border: 1px solid rgba(255, 255, 255, 0.2);
457 +}
458 +#team .thumbnail .caption {
459 + padding-top: 10px;
460 +}
461 +#team .thumbnail .caption p {
462 + color: rgba(255,255,255,0.7);
463 + padding: 0 10px;
464 + font-size: 15px;
465 +}
466 +/* Call Reservation Section */
467 +#call-reservation {
468 + padding: 90px 0;
469 + color: #fff;
470 + /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#8eb640+50,779936+100 */
471 + background: rgb(142,182,64); /* Old browsers */
472 + background: -moz-linear-gradient(top, rgba(142,182,64,1) 50%, rgba(119,153,54,1) 100%); /* FF3.6-15 */
473 + background: -webkit-linear-gradient(top, rgba(142,182,64,1) 50%, rgba(119,153,54,1) 100%); /* Chrome10-25,Safari5.1-6 */
474 + background: linear-gradient(to bottom, rgba(142,182,64,1) 50%, rgba(119,153,54,1) 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
475 +filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#8eb640', endColorstr='#779936', GradientType=0 ); /* IE6-9 */
476 +}
477 +#call-reservation .overlay {
478 + padding: 80px 0;
479 + background: #8eb640;
480 +}
481 +#call-reservation h2 {
482 + font-family: 'Open Sans', sans-serif;
483 + color: #fff;
484 + font-weight: 400;
485 + margin: 0;
486 +}
487 +#call-reservation hr {
488 + background: #fff;
489 +}
490 +#call-reservation h3 {
491 + color: #fff;
492 + font-weight: 500;
493 + font-size: 20px;
494 + margin: 5px 0;
495 +}
496 +/* Contact Section */
497 +#contact {
498 + padding: 100px 0 60px 0;
499 + background: #F6F6F6;
500 +}
501 +#contact .section-title p {
502 + color: #777;
503 +}
504 +#contact form {
505 + padding: 0;
506 +}
507 +#contact h3 {
508 + text-transform: uppercase;
509 + font-size: 20px;
510 + font-weight: 400;
511 + color: #555;
512 +}
513 +#contact .text-danger {
514 + color: #cc0033;
515 + text-align: left;
516 +}
517 +label {
518 + font-size: 12px;
519 + font-weight: 400;
520 + font-family: 'Open Sans', sans-serif;
521 + float: left;
522 +}
523 +#contact .form-control {
524 + display: block;
525 + width: 100%;
526 + padding: 6px 12px;
527 + font-size: 16px;
528 + line-height: 1.42857143;
529 + color: #444;
530 + background-color: #fff;
531 + background-image: none;
532 + border: 1px solid #ddd;
533 + border-radius: 0;
534 + -webkit-box-shadow: none;
535 + box-shadow: none;
536 + -webkit-transition: none;
537 + -o-transition: none;
538 + transition: none;
539 +}
540 +#contact .form-control:focus {
541 + border-color: #999;
542 + outline: 0;
543 + -webkit-box-shadow: transparent;
544 + box-shadow: transparent;
545 +}
546 +.form-control::-webkit-input-placeholder {
547 +color: #777;
548 +}
549 +.form-control:-moz-placeholder {
550 +color: #777;
551 +}
552 +.form-control::-moz-placeholder {
553 +color: #777;
554 +}
555 +.form-control:-ms-input-placeholder {
556 +color: #777;
557 +}
558 +#contact .contact-item {
559 + margin: 20px 0 40px 0;
560 +}
561 +#contact .contact-item span {
562 + font-weight: 400;
563 + color: #aaa;
564 + text-transform: uppercase;
565 + margin-bottom: 6px;
566 + display: inline-block;
567 +}
568 +#contact .contact-item p {
569 + font-size: 16px;
570 +}
571 +/* Footer Section*/
572 +#footer {
573 + background: #262626;
574 + padding: 50px 0 0 0;
575 +}
576 +#footer h3 {
577 + color: #8eb640;
578 + font-weight: 400;
579 + font-size: 18px;
580 + text-transform: uppercase;
581 + margin-bottom: 20px;
582 +}
583 +#footer .copyrights {
584 + padding: 20px 0;
585 + margin-top: 50px;
586 + /* Permalink - use to edit and share this gradient: http://colorzilla.com/gradient-editor/#779936+0,8eb640+50 */
587 + background: rgb(119,153,54); /* Old browsers */
588 + background: -moz-linear-gradient(top, rgba(119,153,54,1) 0%, rgba(142,182,64,1) 50%); /* FF3.6-15 */
589 + background: -webkit-linear-gradient(top, rgba(119,153,54,1) 0%, rgba(142,182,64,1) 50%); /* Chrome10-25,Safari5.1-6 */
590 + background: linear-gradient(to bottom, rgba(119,153,54,1) 0%, rgba(142,182,64,1) 50%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
591 +filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#779936', endColorstr='#8eb640', GradientType=0 ); /* IE6-9 */
592 +}
593 +#footer .social {
594 + margin: 20px 0 30px 0;
595 +}
596 +#footer .social ul li {
597 + display: inline-block;
598 + margin: 0 20px;
599 +}
600 +#footer .social i.fa {
601 + font-size: 26px;
602 + padding: 4px;
603 + color: #fff;
604 + transition: all 0.3s;
605 +}
606 +#footer .social i.fa:hover {
607 + color: #eee;
608 +}
609 +#footer p {
610 + font-size: 15px;
611 + color: rgba(255,255,255,0.8)
612 +}
613 +#footer a {
614 + color: #f6f6f6;
615 +}
616 +#footer a:hover {
617 + color: #333;
8 } 618 }
......
1 +body {
2 + padding: 50px;
3 + font: 14px "Lucida Grande", Helvetica, Arial, sans-serif;
4 +}
5 +
6 +a {
7 + color: #00B7FF;
8 +}
...@@ -231,6 +231,7 @@ function getAllToons() { ...@@ -231,6 +231,7 @@ function getAllToons() {
231 }); 231 });
232 }); 232 });
233 233
234 +//네이버 웹툰
234 var allWeeklyToonsUrl = "http://comic.naver.com/webtoon/weekday.nhn"; 235 var allWeeklyToonsUrl = "http://comic.naver.com/webtoon/weekday.nhn";
235 request(allWeeklyToonsUrl,function (err, res, html) { 236 request(allWeeklyToonsUrl,function (err, res, html) {
236 if(!err){ 237 if(!err){
...@@ -263,7 +264,7 @@ function getAllToons() { ...@@ -263,7 +264,7 @@ function getAllToons() {
263 if (err) { 264 if (err) {
264 console.log("웹툰 DB 에러 : " + err); 265 console.log("웹툰 DB 에러 : " + err);
265 } else { 266 } else {
266 - console.log("웹툰 DB처리 완료!"); 267 + // console.log("웹툰 DB처리 완료!");
267 } 268 }
268 }); 269 });
269 //}); 270 //});
......
1 +// SmoothScroll for websites v1.2.1
2 +// Licensed under the terms of the MIT license.
3 +
4 +// People involved
5 +// - Balazs Galambosi (maintainer)
6 +// - Michael Herf (Pulse Algorithm)
7 +
8 +(function(){
9 +
10 +// Scroll Variables (tweakable)
11 +var defaultOptions = {
12 +
13 + // Scrolling Core
14 + frameRate : 150, // [Hz]
15 + animationTime : 400, // [px]
16 + stepSize : 120, // [px]
17 +
18 + // Pulse (less tweakable)
19 + // ratio of "tail" to "acceleration"
20 + pulseAlgorithm : true,
21 + pulseScale : 8,
22 + pulseNormalize : 1,
23 +
24 + // Acceleration
25 + accelerationDelta : 20, // 20
26 + accelerationMax : 1, // 1
27 +
28 + // Keyboard Settings
29 + keyboardSupport : true, // option
30 + arrowScroll : 50, // [px]
31 +
32 + // Other
33 + touchpadSupport : true,
34 + fixedBackground : true,
35 + excluded : ""
36 +};
37 +
38 +var options = defaultOptions;
39 +
40 +
41 +// Other Variables
42 +var isExcluded = false;
43 +var isFrame = false;
44 +var direction = { x: 0, y: 0 };
45 +var initDone = false;
46 +var root = document.documentElement;
47 +var activeElement;
48 +var observer;
49 +var deltaBuffer = [ 120, 120, 120 ];
50 +
51 +var key = { left: 37, up: 38, right: 39, down: 40, spacebar: 32,
52 + pageup: 33, pagedown: 34, end: 35, home: 36 };
53 +
54 +
55 +/***********************************************
56 + * SETTINGS
57 + ***********************************************/
58 +
59 +var options = defaultOptions;
60 +
61 +
62 +/***********************************************
63 + * INITIALIZE
64 + ***********************************************/
65 +
66 +/**
67 + * Tests if smooth scrolling is allowed. Shuts down everything if not.
68 + */
69 +function initTest() {
70 +
71 + var disableKeyboard = false;
72 +
73 + // disable keyboard support if anything above requested it
74 + if (disableKeyboard) {
75 + removeEvent("keydown", keydown);
76 + }
77 +
78 + if (options.keyboardSupport && !disableKeyboard) {
79 + addEvent("keydown", keydown);
80 + }
81 +}
82 +
83 +/**
84 + * Sets up scrolls array, determines if frames are involved.
85 + */
86 +function init() {
87 +
88 + if (!document.body) return;
89 +
90 + var body = document.body;
91 + var html = document.documentElement;
92 + var windowHeight = window.innerHeight;
93 + var scrollHeight = body.scrollHeight;
94 +
95 + // check compat mode for root element
96 + root = (document.compatMode.indexOf('CSS') >= 0) ? html : body;
97 + activeElement = body;
98 +
99 + initTest();
100 + initDone = true;
101 +
102 + // Checks if this script is running in a frame
103 + if (top != self) {
104 + isFrame = true;
105 + }
106 +
107 + /**
108 + * This fixes a bug where the areas left and right to
109 + * the content does not trigger the onmousewheel event
110 + * on some pages. e.g.: html, body { height: 100% }
111 + */
112 + else if (scrollHeight > windowHeight &&
113 + (body.offsetHeight <= windowHeight ||
114 + html.offsetHeight <= windowHeight)) {
115 +
116 + html.style.height = 'auto';
117 + setTimeout(refresh, 10);
118 +
119 + // clearfix
120 + if (root.offsetHeight <= windowHeight) {
121 + var underlay = document.createElement("div");
122 + underlay.style.clear = "both";
123 + body.appendChild(underlay);
124 + }
125 + }
126 +
127 + // disable fixed background
128 + if (!options.fixedBackground && !isExcluded) {
129 + body.style.backgroundAttachment = "scroll";
130 + html.style.backgroundAttachment = "scroll";
131 + }
132 +}
133 +
134 +
135 +/************************************************
136 + * SCROLLING
137 + ************************************************/
138 +
139 +var que = [];
140 +var pending = false;
141 +var lastScroll = +new Date;
142 +
143 +/**
144 + * Pushes scroll actions to the scrolling queue.
145 + */
146 +function scrollArray(elem, left, top, delay) {
147 +
148 + delay || (delay = 1000);
149 + directionCheck(left, top);
150 +
151 + if (options.accelerationMax != 1) {
152 + var now = +new Date;
153 + var elapsed = now - lastScroll;
154 + if (elapsed < options.accelerationDelta) {
155 + var factor = (1 + (30 / elapsed)) / 2;
156 + if (factor > 1) {
157 + factor = Math.min(factor, options.accelerationMax);
158 + left *= factor;
159 + top *= factor;
160 + }
161 + }
162 + lastScroll = +new Date;
163 + }
164 +
165 + // push a scroll command
166 + que.push({
167 + x: left,
168 + y: top,
169 + lastX: (left < 0) ? 0.99 : -0.99,
170 + lastY: (top < 0) ? 0.99 : -0.99,
171 + start: +new Date
172 + });
173 +
174 + // don't act if there's a pending queue
175 + if (pending) {
176 + return;
177 + }
178 +
179 + var scrollWindow = (elem === document.body);
180 +
181 + var step = function (time) {
182 +
183 + var now = +new Date;
184 + var scrollX = 0;
185 + var scrollY = 0;
186 +
187 + for (var i = 0; i < que.length; i++) {
188 +
189 + var item = que[i];
190 + var elapsed = now - item.start;
191 + var finished = (elapsed >= options.animationTime);
192 +
193 + // scroll position: [0, 1]
194 + var position = (finished) ? 1 : elapsed / options.animationTime;
195 +
196 + // easing [optional]
197 + if (options.pulseAlgorithm) {
198 + position = pulse(position);
199 + }
200 +
201 + // only need the difference
202 + var x = (item.x * position - item.lastX) >> 0;
203 + var y = (item.y * position - item.lastY) >> 0;
204 +
205 + // add this to the total scrolling
206 + scrollX += x;
207 + scrollY += y;
208 +
209 + // update last values
210 + item.lastX += x;
211 + item.lastY += y;
212 +
213 + // delete and step back if it's over
214 + if (finished) {
215 + que.splice(i, 1); i--;
216 + }
217 + }
218 +
219 + // scroll left and top
220 + if (scrollWindow) {
221 + window.scrollBy(scrollX, scrollY);
222 + }
223 + else {
224 + if (scrollX) elem.scrollLeft += scrollX;
225 + if (scrollY) elem.scrollTop += scrollY;
226 + }
227 +
228 + // clean up if there's nothing left to do
229 + if (!left && !top) {
230 + que = [];
231 + }
232 +
233 + if (que.length) {
234 + requestFrame(step, elem, (delay / options.frameRate + 1));
235 + } else {
236 + pending = false;
237 + }
238 + };
239 +
240 + // start a new queue of actions
241 + requestFrame(step, elem, 0);
242 + pending = true;
243 +}
244 +
245 +
246 +/***********************************************
247 + * EVENTS
248 + ***********************************************/
249 +
250 +/**
251 + * Mouse wheel handler.
252 + * @param {Object} event
253 + */
254 +function wheel(event) {
255 +
256 + if (!initDone) {
257 + init();
258 + }
259 +
260 + var target = event.target;
261 + var overflowing = overflowingAncestor(target);
262 +
263 + // use default if there's no overflowing
264 + // element or default action is prevented
265 + if (!overflowing || event.defaultPrevented ||
266 + isNodeName(activeElement, "embed") ||
267 + (isNodeName(target, "embed") && /\.pdf/i.test(target.src))) {
268 + return true;
269 + }
270 +
271 + var deltaX = event.wheelDeltaX || 0;
272 + var deltaY = event.wheelDeltaY || 0;
273 +
274 + // use wheelDelta if deltaX/Y is not available
275 + if (!deltaX && !deltaY) {
276 + deltaY = event.wheelDelta || 0;
277 + }
278 +
279 + // check if it's a touchpad scroll that should be ignored
280 + if (!options.touchpadSupport && isTouchpad(deltaY)) {
281 + return true;
282 + }
283 +
284 + // scale by step size
285 + // delta is 120 most of the time
286 + // synaptics seems to send 1 sometimes
287 + if (Math.abs(deltaX) > 1.2) {
288 + deltaX *= options.stepSize / 120;
289 + }
290 + if (Math.abs(deltaY) > 1.2) {
291 + deltaY *= options.stepSize / 120;
292 + }
293 +
294 + scrollArray(overflowing, -deltaX, -deltaY);
295 + event.preventDefault();
296 +}
297 +
298 +/**
299 + * Keydown event handler.
300 + * @param {Object} event
301 + */
302 +function keydown(event) {
303 +
304 + var target = event.target;
305 + var modifier = event.ctrlKey || event.altKey || event.metaKey ||
306 + (event.shiftKey && event.keyCode !== key.spacebar);
307 +
308 + // do nothing if user is editing text
309 + // or using a modifier key (except shift)
310 + // or in a dropdown
311 + if ( /input|textarea|select|embed/i.test(target.nodeName) ||
312 + target.isContentEditable ||
313 + event.defaultPrevented ||
314 + modifier ) {
315 + return true;
316 + }
317 + // spacebar should trigger button press
318 + if (isNodeName(target, "button") &&
319 + event.keyCode === key.spacebar) {
320 + return true;
321 + }
322 +
323 + var shift, x = 0, y = 0;
324 + var elem = overflowingAncestor(activeElement);
325 + var clientHeight = elem.clientHeight;
326 +
327 + if (elem == document.body) {
328 + clientHeight = window.innerHeight;
329 + }
330 +
331 + switch (event.keyCode) {
332 + case key.up:
333 + y = -options.arrowScroll;
334 + break;
335 + case key.down:
336 + y = options.arrowScroll;
337 + break;
338 + case key.spacebar: // (+ shift)
339 + shift = event.shiftKey ? 1 : -1;
340 + y = -shift * clientHeight * 0.9;
341 + break;
342 + case key.pageup:
343 + y = -clientHeight * 0.9;
344 + break;
345 + case key.pagedown:
346 + y = clientHeight * 0.9;
347 + break;
348 + case key.home:
349 + y = -elem.scrollTop;
350 + break;
351 + case key.end:
352 + var damt = elem.scrollHeight - elem.scrollTop - clientHeight;
353 + y = (damt > 0) ? damt+10 : 0;
354 + break;
355 + case key.left:
356 + x = -options.arrowScroll;
357 + break;
358 + case key.right:
359 + x = options.arrowScroll;
360 + break;
361 + default:
362 + return true; // a key we don't care about
363 + }
364 +
365 + scrollArray(elem, x, y);
366 + event.preventDefault();
367 +}
368 +
369 +/**
370 + * Mousedown event only for updating activeElement
371 + */
372 +function mousedown(event) {
373 + activeElement = event.target;
374 +}
375 +
376 +
377 +/***********************************************
378 + * OVERFLOW
379 + ***********************************************/
380 +
381 +var cache = {}; // cleared out every once in while
382 +setInterval(function () { cache = {}; }, 10 * 1000);
383 +
384 +var uniqueID = (function () {
385 + var i = 0;
386 + return function (el) {
387 + return el.uniqueID || (el.uniqueID = i++);
388 + };
389 +})();
390 +
391 +function setCache(elems, overflowing) {
392 + for (var i = elems.length; i--;)
393 + cache[uniqueID(elems[i])] = overflowing;
394 + return overflowing;
395 +}
396 +
397 +function overflowingAncestor(el) {
398 + var elems = [];
399 + var rootScrollHeight = root.scrollHeight;
400 + do {
401 + var cached = cache[uniqueID(el)];
402 + if (cached) {
403 + return setCache(elems, cached);
404 + }
405 + elems.push(el);
406 + if (rootScrollHeight === el.scrollHeight) {
407 + if (!isFrame || root.clientHeight + 10 < rootScrollHeight) {
408 + return setCache(elems, document.body); // scrolling root in WebKit
409 + }
410 + } else if (el.clientHeight + 10 < el.scrollHeight) {
411 + overflow = getComputedStyle(el, "").getPropertyValue("overflow-y");
412 + if (overflow === "scroll" || overflow === "auto") {
413 + return setCache(elems, el);
414 + }
415 + }
416 + } while (el = el.parentNode);
417 +}
418 +
419 +
420 +/***********************************************
421 + * HELPERS
422 + ***********************************************/
423 +
424 +function addEvent(type, fn, bubble) {
425 + window.addEventListener(type, fn, (bubble||false));
426 +}
427 +
428 +function removeEvent(type, fn, bubble) {
429 + window.removeEventListener(type, fn, (bubble||false));
430 +}
431 +
432 +function isNodeName(el, tag) {
433 + return (el.nodeName||"").toLowerCase() === tag.toLowerCase();
434 +}
435 +
436 +function directionCheck(x, y) {
437 + x = (x > 0) ? 1 : -1;
438 + y = (y > 0) ? 1 : -1;
439 + if (direction.x !== x || direction.y !== y) {
440 + direction.x = x;
441 + direction.y = y;
442 + que = [];
443 + lastScroll = 0;
444 + }
445 +}
446 +
447 +var deltaBufferTimer;
448 +
449 +function isTouchpad(deltaY) {
450 + if (!deltaY) return;
451 + deltaY = Math.abs(deltaY)
452 + deltaBuffer.push(deltaY);
453 + deltaBuffer.shift();
454 + clearTimeout(deltaBufferTimer);
455 +
456 + var allEquals = (deltaBuffer[0] == deltaBuffer[1] &&
457 + deltaBuffer[1] == deltaBuffer[2]);
458 + var allDivisable = (isDivisible(deltaBuffer[0], 120) &&
459 + isDivisible(deltaBuffer[1], 120) &&
460 + isDivisible(deltaBuffer[2], 120));
461 + return !(allEquals || allDivisable);
462 +}
463 +
464 +function isDivisible(n, divisor) {
465 + return (Math.floor(n / divisor) == n / divisor);
466 +}
467 +
468 +var requestFrame = (function () {
469 + return window.requestAnimationFrame ||
470 + window.webkitRequestAnimationFrame ||
471 + function (callback, element, delay) {
472 + window.setTimeout(callback, delay || (1000/60));
473 + };
474 +})();
475 +
476 +
477 +/***********************************************
478 + * PULSE
479 + ***********************************************/
480 +
481 +/**
482 + * Viscous fluid with a pulse for part and decay for the rest.
483 + * - Applies a fixed force over an interval (a damped acceleration), and
484 + * - Lets the exponential bleed away the velocity over a longer interval
485 + * - Michael Herf, http://stereopsis.com/stopping/
486 + */
487 +function pulse_(x) {
488 + var val, start, expx;
489 + // test
490 + x = x * options.pulseScale;
491 + if (x < 1) { // acceleartion
492 + val = x - (1 - Math.exp(-x));
493 + } else { // tail
494 + // the previous animation ended here:
495 + start = Math.exp(-1);
496 + // simple viscous drag
497 + x -= 1;
498 + expx = 1 - Math.exp(-x);
499 + val = start + (expx * (1 - start));
500 + }
501 + return val * options.pulseNormalize;
502 +}
503 +
504 +function pulse(x) {
505 + if (x >= 1) return 1;
506 + if (x <= 0) return 0;
507 +
508 + if (options.pulseNormalize == 1) {
509 + options.pulseNormalize /= pulse_(1);
510 + }
511 + return pulse_(x);
512 +}
513 +
514 +var isChrome = /chrome/i.test(window.navigator.userAgent);
515 +var isMouseWheelSupported = 'onmousewheel' in document;
516 +
517 +if (isMouseWheelSupported && isChrome) {
518 + addEvent("mousedown", mousedown);
519 + addEvent("mousewheel", wheel);
520 + addEvent("load", init);
521 +};
522 +
523 +})();
...\ No newline at end of file ...\ No newline at end of file
1 +/*!
2 + * Bootstrap v3.3.4 (http://getbootstrap.com)
3 + * Copyright 2011-2015 Twitter, Inc.
4 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
5 + */
6 +
7 +if (typeof jQuery === 'undefined') {
8 + throw new Error('Bootstrap\'s JavaScript requires jQuery')
9 +}
10 +
11 ++function ($) {
12 + 'use strict';
13 + var version = $.fn.jquery.split(' ')[0].split('.')
14 + if ((version[0] < 2 && version[1] < 9) || (version[0] == 1 && version[1] == 9 && version[2] < 1)) {
15 + throw new Error('Bootstrap\'s JavaScript requires jQuery version 1.9.1 or higher')
16 + }
17 +}(jQuery);
18 +
19 +/* ========================================================================
20 + * Bootstrap: transition.js v3.3.4
21 + * http://getbootstrap.com/javascript/#transitions
22 + * ========================================================================
23 + * Copyright 2011-2015 Twitter, Inc.
24 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
25 + * ======================================================================== */
26 +
27 +
28 ++function ($) {
29 + 'use strict';
30 +
31 + // CSS TRANSITION SUPPORT (Shoutout: http://www.modernizr.com/)
32 + // ============================================================
33 +
34 + function transitionEnd() {
35 + var el = document.createElement('bootstrap')
36 +
37 + var transEndEventNames = {
38 + WebkitTransition : 'webkitTransitionEnd',
39 + MozTransition : 'transitionend',
40 + OTransition : 'oTransitionEnd otransitionend',
41 + transition : 'transitionend'
42 + }
43 +
44 + for (var name in transEndEventNames) {
45 + if (el.style[name] !== undefined) {
46 + return { end: transEndEventNames[name] }
47 + }
48 + }
49 +
50 + return false // explicit for ie8 ( ._.)
51 + }
52 +
53 + // http://blog.alexmaccaw.com/css-transitions
54 + $.fn.emulateTransitionEnd = function (duration) {
55 + var called = false
56 + var $el = this
57 + $(this).one('bsTransitionEnd', function () { called = true })
58 + var callback = function () { if (!called) $($el).trigger($.support.transition.end) }
59 + setTimeout(callback, duration)
60 + return this
61 + }
62 +
63 + $(function () {
64 + $.support.transition = transitionEnd()
65 +
66 + if (!$.support.transition) return
67 +
68 + $.event.special.bsTransitionEnd = {
69 + bindType: $.support.transition.end,
70 + delegateType: $.support.transition.end,
71 + handle: function (e) {
72 + if ($(e.target).is(this)) return e.handleObj.handler.apply(this, arguments)
73 + }
74 + }
75 + })
76 +
77 +}(jQuery);
78 +
79 +/* ========================================================================
80 + * Bootstrap: alert.js v3.3.4
81 + * http://getbootstrap.com/javascript/#alerts
82 + * ========================================================================
83 + * Copyright 2011-2015 Twitter, Inc.
84 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
85 + * ======================================================================== */
86 +
87 +
88 ++function ($) {
89 + 'use strict';
90 +
91 + // ALERT CLASS DEFINITION
92 + // ======================
93 +
94 + var dismiss = '[data-dismiss="alert"]'
95 + var Alert = function (el) {
96 + $(el).on('click', dismiss, this.close)
97 + }
98 +
99 + Alert.VERSION = '3.3.4'
100 +
101 + Alert.TRANSITION_DURATION = 150
102 +
103 + Alert.prototype.close = function (e) {
104 + var $this = $(this)
105 + var selector = $this.attr('data-target')
106 +
107 + if (!selector) {
108 + selector = $this.attr('href')
109 + selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
110 + }
111 +
112 + var $parent = $(selector)
113 +
114 + if (e) e.preventDefault()
115 +
116 + if (!$parent.length) {
117 + $parent = $this.closest('.alert')
118 + }
119 +
120 + $parent.trigger(e = $.Event('close.bs.alert'))
121 +
122 + if (e.isDefaultPrevented()) return
123 +
124 + $parent.removeClass('in')
125 +
126 + function removeElement() {
127 + // detach from parent, fire event then clean up data
128 + $parent.detach().trigger('closed.bs.alert').remove()
129 + }
130 +
131 + $.support.transition && $parent.hasClass('fade') ?
132 + $parent
133 + .one('bsTransitionEnd', removeElement)
134 + .emulateTransitionEnd(Alert.TRANSITION_DURATION) :
135 + removeElement()
136 + }
137 +
138 +
139 + // ALERT PLUGIN DEFINITION
140 + // =======================
141 +
142 + function Plugin(option) {
143 + return this.each(function () {
144 + var $this = $(this)
145 + var data = $this.data('bs.alert')
146 +
147 + if (!data) $this.data('bs.alert', (data = new Alert(this)))
148 + if (typeof option == 'string') data[option].call($this)
149 + })
150 + }
151 +
152 + var old = $.fn.alert
153 +
154 + $.fn.alert = Plugin
155 + $.fn.alert.Constructor = Alert
156 +
157 +
158 + // ALERT NO CONFLICT
159 + // =================
160 +
161 + $.fn.alert.noConflict = function () {
162 + $.fn.alert = old
163 + return this
164 + }
165 +
166 +
167 + // ALERT DATA-API
168 + // ==============
169 +
170 + $(document).on('click.bs.alert.data-api', dismiss, Alert.prototype.close)
171 +
172 +}(jQuery);
173 +
174 +/* ========================================================================
175 + * Bootstrap: button.js v3.3.4
176 + * http://getbootstrap.com/javascript/#buttons
177 + * ========================================================================
178 + * Copyright 2011-2015 Twitter, Inc.
179 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
180 + * ======================================================================== */
181 +
182 +
183 ++function ($) {
184 + 'use strict';
185 +
186 + // BUTTON PUBLIC CLASS DEFINITION
187 + // ==============================
188 +
189 + var Button = function (element, options) {
190 + this.$element = $(element)
191 + this.options = $.extend({}, Button.DEFAULTS, options)
192 + this.isLoading = false
193 + }
194 +
195 + Button.VERSION = '3.3.4'
196 +
197 + Button.DEFAULTS = {
198 + loadingText: 'loading...'
199 + }
200 +
201 + Button.prototype.setState = function (state) {
202 + var d = 'disabled'
203 + var $el = this.$element
204 + var val = $el.is('input') ? 'val' : 'html'
205 + var data = $el.data()
206 +
207 + state = state + 'Text'
208 +
209 + if (data.resetText == null) $el.data('resetText', $el[val]())
210 +
211 + // push to event loop to allow forms to submit
212 + setTimeout($.proxy(function () {
213 + $el[val](data[state] == null ? this.options[state] : data[state])
214 +
215 + if (state == 'loadingText') {
216 + this.isLoading = true
217 + $el.addClass(d).attr(d, d)
218 + } else if (this.isLoading) {
219 + this.isLoading = false
220 + $el.removeClass(d).removeAttr(d)
221 + }
222 + }, this), 0)
223 + }
224 +
225 + Button.prototype.toggle = function () {
226 + var changed = true
227 + var $parent = this.$element.closest('[data-toggle="buttons"]')
228 +
229 + if ($parent.length) {
230 + var $input = this.$element.find('input')
231 + if ($input.prop('type') == 'radio') {
232 + if ($input.prop('checked') && this.$element.hasClass('active')) changed = false
233 + else $parent.find('.active').removeClass('active')
234 + }
235 + if (changed) $input.prop('checked', !this.$element.hasClass('active')).trigger('change')
236 + } else {
237 + this.$element.attr('aria-pressed', !this.$element.hasClass('active'))
238 + }
239 +
240 + if (changed) this.$element.toggleClass('active')
241 + }
242 +
243 +
244 + // BUTTON PLUGIN DEFINITION
245 + // ========================
246 +
247 + function Plugin(option) {
248 + return this.each(function () {
249 + var $this = $(this)
250 + var data = $this.data('bs.button')
251 + var options = typeof option == 'object' && option
252 +
253 + if (!data) $this.data('bs.button', (data = new Button(this, options)))
254 +
255 + if (option == 'toggle') data.toggle()
256 + else if (option) data.setState(option)
257 + })
258 + }
259 +
260 + var old = $.fn.button
261 +
262 + $.fn.button = Plugin
263 + $.fn.button.Constructor = Button
264 +
265 +
266 + // BUTTON NO CONFLICT
267 + // ==================
268 +
269 + $.fn.button.noConflict = function () {
270 + $.fn.button = old
271 + return this
272 + }
273 +
274 +
275 + // BUTTON DATA-API
276 + // ===============
277 +
278 + $(document)
279 + .on('click.bs.button.data-api', '[data-toggle^="button"]', function (e) {
280 + var $btn = $(e.target)
281 + if (!$btn.hasClass('btn')) $btn = $btn.closest('.btn')
282 + Plugin.call($btn, 'toggle')
283 + e.preventDefault()
284 + })
285 + .on('focus.bs.button.data-api blur.bs.button.data-api', '[data-toggle^="button"]', function (e) {
286 + $(e.target).closest('.btn').toggleClass('focus', /^focus(in)?$/.test(e.type))
287 + })
288 +
289 +}(jQuery);
290 +
291 +/* ========================================================================
292 + * Bootstrap: carousel.js v3.3.4
293 + * http://getbootstrap.com/javascript/#carousel
294 + * ========================================================================
295 + * Copyright 2011-2015 Twitter, Inc.
296 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
297 + * ======================================================================== */
298 +
299 +
300 ++function ($) {
301 + 'use strict';
302 +
303 + // CAROUSEL CLASS DEFINITION
304 + // =========================
305 +
306 + var Carousel = function (element, options) {
307 + this.$element = $(element)
308 + this.$indicators = this.$element.find('.carousel-indicators')
309 + this.options = options
310 + this.paused = null
311 + this.sliding = null
312 + this.interval = null
313 + this.$active = null
314 + this.$items = null
315 +
316 + this.options.keyboard && this.$element.on('keydown.bs.carousel', $.proxy(this.keydown, this))
317 +
318 + this.options.pause == 'hover' && !('ontouchstart' in document.documentElement) && this.$element
319 + .on('mouseenter.bs.carousel', $.proxy(this.pause, this))
320 + .on('mouseleave.bs.carousel', $.proxy(this.cycle, this))
321 + }
322 +
323 + Carousel.VERSION = '3.3.4'
324 +
325 + Carousel.TRANSITION_DURATION = 600
326 +
327 + Carousel.DEFAULTS = {
328 + interval: 5000,
329 + pause: 'hover',
330 + wrap: true,
331 + keyboard: true
332 + }
333 +
334 + Carousel.prototype.keydown = function (e) {
335 + if (/input|textarea/i.test(e.target.tagName)) return
336 + switch (e.which) {
337 + case 37: this.prev(); break
338 + case 39: this.next(); break
339 + default: return
340 + }
341 +
342 + e.preventDefault()
343 + }
344 +
345 + Carousel.prototype.cycle = function (e) {
346 + e || (this.paused = false)
347 +
348 + this.interval && clearInterval(this.interval)
349 +
350 + this.options.interval
351 + && !this.paused
352 + && (this.interval = setInterval($.proxy(this.next, this), this.options.interval))
353 +
354 + return this
355 + }
356 +
357 + Carousel.prototype.getItemIndex = function (item) {
358 + this.$items = item.parent().children('.item')
359 + return this.$items.index(item || this.$active)
360 + }
361 +
362 + Carousel.prototype.getItemForDirection = function (direction, active) {
363 + var activeIndex = this.getItemIndex(active)
364 + var willWrap = (direction == 'prev' && activeIndex === 0)
365 + || (direction == 'next' && activeIndex == (this.$items.length - 1))
366 + if (willWrap && !this.options.wrap) return active
367 + var delta = direction == 'prev' ? -1 : 1
368 + var itemIndex = (activeIndex + delta) % this.$items.length
369 + return this.$items.eq(itemIndex)
370 + }
371 +
372 + Carousel.prototype.to = function (pos) {
373 + var that = this
374 + var activeIndex = this.getItemIndex(this.$active = this.$element.find('.item.active'))
375 +
376 + if (pos > (this.$items.length - 1) || pos < 0) return
377 +
378 + if (this.sliding) return this.$element.one('slid.bs.carousel', function () { that.to(pos) }) // yes, "slid"
379 + if (activeIndex == pos) return this.pause().cycle()
380 +
381 + return this.slide(pos > activeIndex ? 'next' : 'prev', this.$items.eq(pos))
382 + }
383 +
384 + Carousel.prototype.pause = function (e) {
385 + e || (this.paused = true)
386 +
387 + if (this.$element.find('.next, .prev').length && $.support.transition) {
388 + this.$element.trigger($.support.transition.end)
389 + this.cycle(true)
390 + }
391 +
392 + this.interval = clearInterval(this.interval)
393 +
394 + return this
395 + }
396 +
397 + Carousel.prototype.next = function () {
398 + if (this.sliding) return
399 + return this.slide('next')
400 + }
401 +
402 + Carousel.prototype.prev = function () {
403 + if (this.sliding) return
404 + return this.slide('prev')
405 + }
406 +
407 + Carousel.prototype.slide = function (type, next) {
408 + var $active = this.$element.find('.item.active')
409 + var $next = next || this.getItemForDirection(type, $active)
410 + var isCycling = this.interval
411 + var direction = type == 'next' ? 'left' : 'right'
412 + var that = this
413 +
414 + if ($next.hasClass('active')) return (this.sliding = false)
415 +
416 + var relatedTarget = $next[0]
417 + var slideEvent = $.Event('slide.bs.carousel', {
418 + relatedTarget: relatedTarget,
419 + direction: direction
420 + })
421 + this.$element.trigger(slideEvent)
422 + if (slideEvent.isDefaultPrevented()) return
423 +
424 + this.sliding = true
425 +
426 + isCycling && this.pause()
427 +
428 + if (this.$indicators.length) {
429 + this.$indicators.find('.active').removeClass('active')
430 + var $nextIndicator = $(this.$indicators.children()[this.getItemIndex($next)])
431 + $nextIndicator && $nextIndicator.addClass('active')
432 + }
433 +
434 + var slidEvent = $.Event('slid.bs.carousel', { relatedTarget: relatedTarget, direction: direction }) // yes, "slid"
435 + if ($.support.transition && this.$element.hasClass('slide')) {
436 + $next.addClass(type)
437 + $next[0].offsetWidth // force reflow
438 + $active.addClass(direction)
439 + $next.addClass(direction)
440 + $active
441 + .one('bsTransitionEnd', function () {
442 + $next.removeClass([type, direction].join(' ')).addClass('active')
443 + $active.removeClass(['active', direction].join(' '))
444 + that.sliding = false
445 + setTimeout(function () {
446 + that.$element.trigger(slidEvent)
447 + }, 0)
448 + })
449 + .emulateTransitionEnd(Carousel.TRANSITION_DURATION)
450 + } else {
451 + $active.removeClass('active')
452 + $next.addClass('active')
453 + this.sliding = false
454 + this.$element.trigger(slidEvent)
455 + }
456 +
457 + isCycling && this.cycle()
458 +
459 + return this
460 + }
461 +
462 +
463 + // CAROUSEL PLUGIN DEFINITION
464 + // ==========================
465 +
466 + function Plugin(option) {
467 + return this.each(function () {
468 + var $this = $(this)
469 + var data = $this.data('bs.carousel')
470 + var options = $.extend({}, Carousel.DEFAULTS, $this.data(), typeof option == 'object' && option)
471 + var action = typeof option == 'string' ? option : options.slide
472 +
473 + if (!data) $this.data('bs.carousel', (data = new Carousel(this, options)))
474 + if (typeof option == 'number') data.to(option)
475 + else if (action) data[action]()
476 + else if (options.interval) data.pause().cycle()
477 + })
478 + }
479 +
480 + var old = $.fn.carousel
481 +
482 + $.fn.carousel = Plugin
483 + $.fn.carousel.Constructor = Carousel
484 +
485 +
486 + // CAROUSEL NO CONFLICT
487 + // ====================
488 +
489 + $.fn.carousel.noConflict = function () {
490 + $.fn.carousel = old
491 + return this
492 + }
493 +
494 +
495 + // CAROUSEL DATA-API
496 + // =================
497 +
498 + var clickHandler = function (e) {
499 + var href
500 + var $this = $(this)
501 + var $target = $($this.attr('data-target') || (href = $this.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '')) // strip for ie7
502 + if (!$target.hasClass('carousel')) return
503 + var options = $.extend({}, $target.data(), $this.data())
504 + var slideIndex = $this.attr('data-slide-to')
505 + if (slideIndex) options.interval = false
506 +
507 + Plugin.call($target, options)
508 +
509 + if (slideIndex) {
510 + $target.data('bs.carousel').to(slideIndex)
511 + }
512 +
513 + e.preventDefault()
514 + }
515 +
516 + $(document)
517 + .on('click.bs.carousel.data-api', '[data-slide]', clickHandler)
518 + .on('click.bs.carousel.data-api', '[data-slide-to]', clickHandler)
519 +
520 + $(window).on('load', function () {
521 + $('[data-ride="carousel"]').each(function () {
522 + var $carousel = $(this)
523 + Plugin.call($carousel, $carousel.data())
524 + })
525 + })
526 +
527 +}(jQuery);
528 +
529 +/* ========================================================================
530 + * Bootstrap: collapse.js v3.3.4
531 + * http://getbootstrap.com/javascript/#collapse
532 + * ========================================================================
533 + * Copyright 2011-2015 Twitter, Inc.
534 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
535 + * ======================================================================== */
536 +
537 +
538 ++function ($) {
539 + 'use strict';
540 +
541 + // COLLAPSE PUBLIC CLASS DEFINITION
542 + // ================================
543 +
544 + var Collapse = function (element, options) {
545 + this.$element = $(element)
546 + this.options = $.extend({}, Collapse.DEFAULTS, options)
547 + this.$trigger = $('[data-toggle="collapse"][href="#' + element.id + '"],' +
548 + '[data-toggle="collapse"][data-target="#' + element.id + '"]')
549 + this.transitioning = null
550 +
551 + if (this.options.parent) {
552 + this.$parent = this.getParent()
553 + } else {
554 + this.addAriaAndCollapsedClass(this.$element, this.$trigger)
555 + }
556 +
557 + if (this.options.toggle) this.toggle()
558 + }
559 +
560 + Collapse.VERSION = '3.3.4'
561 +
562 + Collapse.TRANSITION_DURATION = 350
563 +
564 + Collapse.DEFAULTS = {
565 + toggle: true
566 + }
567 +
568 + Collapse.prototype.dimension = function () {
569 + var hasWidth = this.$element.hasClass('width')
570 + return hasWidth ? 'width' : 'height'
571 + }
572 +
573 + Collapse.prototype.show = function () {
574 + if (this.transitioning || this.$element.hasClass('in')) return
575 +
576 + var activesData
577 + var actives = this.$parent && this.$parent.children('.panel').children('.in, .collapsing')
578 +
579 + if (actives && actives.length) {
580 + activesData = actives.data('bs.collapse')
581 + if (activesData && activesData.transitioning) return
582 + }
583 +
584 + var startEvent = $.Event('show.bs.collapse')
585 + this.$element.trigger(startEvent)
586 + if (startEvent.isDefaultPrevented()) return
587 +
588 + if (actives && actives.length) {
589 + Plugin.call(actives, 'hide')
590 + activesData || actives.data('bs.collapse', null)
591 + }
592 +
593 + var dimension = this.dimension()
594 +
595 + this.$element
596 + .removeClass('collapse')
597 + .addClass('collapsing')[dimension](0)
598 + .attr('aria-expanded', true)
599 +
600 + this.$trigger
601 + .removeClass('collapsed')
602 + .attr('aria-expanded', true)
603 +
604 + this.transitioning = 1
605 +
606 + var complete = function () {
607 + this.$element
608 + .removeClass('collapsing')
609 + .addClass('collapse in')[dimension]('')
610 + this.transitioning = 0
611 + this.$element
612 + .trigger('shown.bs.collapse')
613 + }
614 +
615 + if (!$.support.transition) return complete.call(this)
616 +
617 + var scrollSize = $.camelCase(['scroll', dimension].join('-'))
618 +
619 + this.$element
620 + .one('bsTransitionEnd', $.proxy(complete, this))
621 + .emulateTransitionEnd(Collapse.TRANSITION_DURATION)[dimension](this.$element[0][scrollSize])
622 + }
623 +
624 + Collapse.prototype.hide = function () {
625 + if (this.transitioning || !this.$element.hasClass('in')) return
626 +
627 + var startEvent = $.Event('hide.bs.collapse')
628 + this.$element.trigger(startEvent)
629 + if (startEvent.isDefaultPrevented()) return
630 +
631 + var dimension = this.dimension()
632 +
633 + this.$element[dimension](this.$element[dimension]())[0].offsetHeight
634 +
635 + this.$element
636 + .addClass('collapsing')
637 + .removeClass('collapse in')
638 + .attr('aria-expanded', false)
639 +
640 + this.$trigger
641 + .addClass('collapsed')
642 + .attr('aria-expanded', false)
643 +
644 + this.transitioning = 1
645 +
646 + var complete = function () {
647 + this.transitioning = 0
648 + this.$element
649 + .removeClass('collapsing')
650 + .addClass('collapse')
651 + .trigger('hidden.bs.collapse')
652 + }
653 +
654 + if (!$.support.transition) return complete.call(this)
655 +
656 + this.$element
657 + [dimension](0)
658 + .one('bsTransitionEnd', $.proxy(complete, this))
659 + .emulateTransitionEnd(Collapse.TRANSITION_DURATION)
660 + }
661 +
662 + Collapse.prototype.toggle = function () {
663 + this[this.$element.hasClass('in') ? 'hide' : 'show']()
664 + }
665 +
666 + Collapse.prototype.getParent = function () {
667 + return $(this.options.parent)
668 + .find('[data-toggle="collapse"][data-parent="' + this.options.parent + '"]')
669 + .each($.proxy(function (i, element) {
670 + var $element = $(element)
671 + this.addAriaAndCollapsedClass(getTargetFromTrigger($element), $element)
672 + }, this))
673 + .end()
674 + }
675 +
676 + Collapse.prototype.addAriaAndCollapsedClass = function ($element, $trigger) {
677 + var isOpen = $element.hasClass('in')
678 +
679 + $element.attr('aria-expanded', isOpen)
680 + $trigger
681 + .toggleClass('collapsed', !isOpen)
682 + .attr('aria-expanded', isOpen)
683 + }
684 +
685 + function getTargetFromTrigger($trigger) {
686 + var href
687 + var target = $trigger.attr('data-target')
688 + || (href = $trigger.attr('href')) && href.replace(/.*(?=#[^\s]+$)/, '') // strip for ie7
689 +
690 + return $(target)
691 + }
692 +
693 +
694 + // COLLAPSE PLUGIN DEFINITION
695 + // ==========================
696 +
697 + function Plugin(option) {
698 + return this.each(function () {
699 + var $this = $(this)
700 + var data = $this.data('bs.collapse')
701 + var options = $.extend({}, Collapse.DEFAULTS, $this.data(), typeof option == 'object' && option)
702 +
703 + if (!data && options.toggle && /show|hide/.test(option)) options.toggle = false
704 + if (!data) $this.data('bs.collapse', (data = new Collapse(this, options)))
705 + if (typeof option == 'string') data[option]()
706 + })
707 + }
708 +
709 + var old = $.fn.collapse
710 +
711 + $.fn.collapse = Plugin
712 + $.fn.collapse.Constructor = Collapse
713 +
714 +
715 + // COLLAPSE NO CONFLICT
716 + // ====================
717 +
718 + $.fn.collapse.noConflict = function () {
719 + $.fn.collapse = old
720 + return this
721 + }
722 +
723 +
724 + // COLLAPSE DATA-API
725 + // =================
726 +
727 + $(document).on('click.bs.collapse.data-api', '[data-toggle="collapse"]', function (e) {
728 + var $this = $(this)
729 +
730 + if (!$this.attr('data-target')) e.preventDefault()
731 +
732 + var $target = getTargetFromTrigger($this)
733 + var data = $target.data('bs.collapse')
734 + var option = data ? 'toggle' : $this.data()
735 +
736 + Plugin.call($target, option)
737 + })
738 +
739 +}(jQuery);
740 +
741 +/* ========================================================================
742 + * Bootstrap: dropdown.js v3.3.4
743 + * http://getbootstrap.com/javascript/#dropdowns
744 + * ========================================================================
745 + * Copyright 2011-2015 Twitter, Inc.
746 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
747 + * ======================================================================== */
748 +
749 +
750 ++function ($) {
751 + 'use strict';
752 +
753 + // DROPDOWN CLASS DEFINITION
754 + // =========================
755 +
756 + var backdrop = '.dropdown-backdrop'
757 + var toggle = '[data-toggle="dropdown"]'
758 + var Dropdown = function (element) {
759 + $(element).on('click.bs.dropdown', this.toggle)
760 + }
761 +
762 + Dropdown.VERSION = '3.3.4'
763 +
764 + Dropdown.prototype.toggle = function (e) {
765 + var $this = $(this)
766 +
767 + if ($this.is('.disabled, :disabled')) return
768 +
769 + var $parent = getParent($this)
770 + var isActive = $parent.hasClass('open')
771 +
772 + clearMenus()
773 +
774 + if (!isActive) {
775 + if ('ontouchstart' in document.documentElement && !$parent.closest('.navbar-nav').length) {
776 + // if mobile we use a backdrop because click events don't delegate
777 + $('<div class="dropdown-backdrop"/>').insertAfter($(this)).on('click', clearMenus)
778 + }
779 +
780 + var relatedTarget = { relatedTarget: this }
781 + $parent.trigger(e = $.Event('show.bs.dropdown', relatedTarget))
782 +
783 + if (e.isDefaultPrevented()) return
784 +
785 + $this
786 + .trigger('focus')
787 + .attr('aria-expanded', 'true')
788 +
789 + $parent
790 + .toggleClass('open')
791 + .trigger('shown.bs.dropdown', relatedTarget)
792 + }
793 +
794 + return false
795 + }
796 +
797 + Dropdown.prototype.keydown = function (e) {
798 + if (!/(38|40|27|32)/.test(e.which) || /input|textarea/i.test(e.target.tagName)) return
799 +
800 + var $this = $(this)
801 +
802 + e.preventDefault()
803 + e.stopPropagation()
804 +
805 + if ($this.is('.disabled, :disabled')) return
806 +
807 + var $parent = getParent($this)
808 + var isActive = $parent.hasClass('open')
809 +
810 + if ((!isActive && e.which != 27) || (isActive && e.which == 27)) {
811 + if (e.which == 27) $parent.find(toggle).trigger('focus')
812 + return $this.trigger('click')
813 + }
814 +
815 + var desc = ' li:not(.disabled):visible a'
816 + var $items = $parent.find('[role="menu"]' + desc + ', [role="listbox"]' + desc)
817 +
818 + if (!$items.length) return
819 +
820 + var index = $items.index(e.target)
821 +
822 + if (e.which == 38 && index > 0) index-- // up
823 + if (e.which == 40 && index < $items.length - 1) index++ // down
824 + if (!~index) index = 0
825 +
826 + $items.eq(index).trigger('focus')
827 + }
828 +
829 + function clearMenus(e) {
830 + if (e && e.which === 3) return
831 + $(backdrop).remove()
832 + $(toggle).each(function () {
833 + var $this = $(this)
834 + var $parent = getParent($this)
835 + var relatedTarget = { relatedTarget: this }
836 +
837 + if (!$parent.hasClass('open')) return
838 +
839 + $parent.trigger(e = $.Event('hide.bs.dropdown', relatedTarget))
840 +
841 + if (e.isDefaultPrevented()) return
842 +
843 + $this.attr('aria-expanded', 'false')
844 + $parent.removeClass('open').trigger('hidden.bs.dropdown', relatedTarget)
845 + })
846 + }
847 +
848 + function getParent($this) {
849 + var selector = $this.attr('data-target')
850 +
851 + if (!selector) {
852 + selector = $this.attr('href')
853 + selector = selector && /#[A-Za-z]/.test(selector) && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
854 + }
855 +
856 + var $parent = selector && $(selector)
857 +
858 + return $parent && $parent.length ? $parent : $this.parent()
859 + }
860 +
861 +
862 + // DROPDOWN PLUGIN DEFINITION
863 + // ==========================
864 +
865 + function Plugin(option) {
866 + return this.each(function () {
867 + var $this = $(this)
868 + var data = $this.data('bs.dropdown')
869 +
870 + if (!data) $this.data('bs.dropdown', (data = new Dropdown(this)))
871 + if (typeof option == 'string') data[option].call($this)
872 + })
873 + }
874 +
875 + var old = $.fn.dropdown
876 +
877 + $.fn.dropdown = Plugin
878 + $.fn.dropdown.Constructor = Dropdown
879 +
880 +
881 + // DROPDOWN NO CONFLICT
882 + // ====================
883 +
884 + $.fn.dropdown.noConflict = function () {
885 + $.fn.dropdown = old
886 + return this
887 + }
888 +
889 +
890 + // APPLY TO STANDARD DROPDOWN ELEMENTS
891 + // ===================================
892 +
893 + $(document)
894 + .on('click.bs.dropdown.data-api', clearMenus)
895 + .on('click.bs.dropdown.data-api', '.dropdown form', function (e) { e.stopPropagation() })
896 + .on('click.bs.dropdown.data-api', toggle, Dropdown.prototype.toggle)
897 + .on('keydown.bs.dropdown.data-api', toggle, Dropdown.prototype.keydown)
898 + .on('keydown.bs.dropdown.data-api', '[role="menu"]', Dropdown.prototype.keydown)
899 + .on('keydown.bs.dropdown.data-api', '[role="listbox"]', Dropdown.prototype.keydown)
900 +
901 +}(jQuery);
902 +
903 +/* ========================================================================
904 + * Bootstrap: modal.js v3.3.4
905 + * http://getbootstrap.com/javascript/#modals
906 + * ========================================================================
907 + * Copyright 2011-2015 Twitter, Inc.
908 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
909 + * ======================================================================== */
910 +
911 +
912 ++function ($) {
913 + 'use strict';
914 +
915 + // MODAL CLASS DEFINITION
916 + // ======================
917 +
918 + var Modal = function (element, options) {
919 + this.options = options
920 + this.$body = $(document.body)
921 + this.$element = $(element)
922 + this.$dialog = this.$element.find('.modal-dialog')
923 + this.$backdrop = null
924 + this.isShown = null
925 + this.originalBodyPad = null
926 + this.scrollbarWidth = 0
927 + this.ignoreBackdropClick = false
928 +
929 + if (this.options.remote) {
930 + this.$element
931 + .find('.modal-content')
932 + .load(this.options.remote, $.proxy(function () {
933 + this.$element.trigger('loaded.bs.modal')
934 + }, this))
935 + }
936 + }
937 +
938 + Modal.VERSION = '3.3.4'
939 +
940 + Modal.TRANSITION_DURATION = 300
941 + Modal.BACKDROP_TRANSITION_DURATION = 150
942 +
943 + Modal.DEFAULTS = {
944 + backdrop: true,
945 + keyboard: true,
946 + show: true
947 + }
948 +
949 + Modal.prototype.toggle = function (_relatedTarget) {
950 + return this.isShown ? this.hide() : this.show(_relatedTarget)
951 + }
952 +
953 + Modal.prototype.show = function (_relatedTarget) {
954 + var that = this
955 + var e = $.Event('show.bs.modal', { relatedTarget: _relatedTarget })
956 +
957 + this.$element.trigger(e)
958 +
959 + if (this.isShown || e.isDefaultPrevented()) return
960 +
961 + this.isShown = true
962 +
963 + this.checkScrollbar()
964 + this.setScrollbar()
965 + this.$body.addClass('modal-open')
966 +
967 + this.escape()
968 + this.resize()
969 +
970 + this.$element.on('click.dismiss.bs.modal', '[data-dismiss="modal"]', $.proxy(this.hide, this))
971 +
972 + this.$dialog.on('mousedown.dismiss.bs.modal', function () {
973 + that.$element.one('mouseup.dismiss.bs.modal', function (e) {
974 + if ($(e.target).is(that.$element)) that.ignoreBackdropClick = true
975 + })
976 + })
977 +
978 + this.backdrop(function () {
979 + var transition = $.support.transition && that.$element.hasClass('fade')
980 +
981 + if (!that.$element.parent().length) {
982 + that.$element.appendTo(that.$body) // don't move modals dom position
983 + }
984 +
985 + that.$element
986 + .show()
987 + .scrollTop(0)
988 +
989 + that.adjustDialog()
990 +
991 + if (transition) {
992 + that.$element[0].offsetWidth // force reflow
993 + }
994 +
995 + that.$element
996 + .addClass('in')
997 + .attr('aria-hidden', false)
998 +
999 + that.enforceFocus()
1000 +
1001 + var e = $.Event('shown.bs.modal', { relatedTarget: _relatedTarget })
1002 +
1003 + transition ?
1004 + that.$dialog // wait for modal to slide in
1005 + .one('bsTransitionEnd', function () {
1006 + that.$element.trigger('focus').trigger(e)
1007 + })
1008 + .emulateTransitionEnd(Modal.TRANSITION_DURATION) :
1009 + that.$element.trigger('focus').trigger(e)
1010 + })
1011 + }
1012 +
1013 + Modal.prototype.hide = function (e) {
1014 + if (e) e.preventDefault()
1015 +
1016 + e = $.Event('hide.bs.modal')
1017 +
1018 + this.$element.trigger(e)
1019 +
1020 + if (!this.isShown || e.isDefaultPrevented()) return
1021 +
1022 + this.isShown = false
1023 +
1024 + this.escape()
1025 + this.resize()
1026 +
1027 + $(document).off('focusin.bs.modal')
1028 +
1029 + this.$element
1030 + .removeClass('in')
1031 + .attr('aria-hidden', true)
1032 + .off('click.dismiss.bs.modal')
1033 + .off('mouseup.dismiss.bs.modal')
1034 +
1035 + this.$dialog.off('mousedown.dismiss.bs.modal')
1036 +
1037 + $.support.transition && this.$element.hasClass('fade') ?
1038 + this.$element
1039 + .one('bsTransitionEnd', $.proxy(this.hideModal, this))
1040 + .emulateTransitionEnd(Modal.TRANSITION_DURATION) :
1041 + this.hideModal()
1042 + }
1043 +
1044 + Modal.prototype.enforceFocus = function () {
1045 + $(document)
1046 + .off('focusin.bs.modal') // guard against infinite focus loop
1047 + .on('focusin.bs.modal', $.proxy(function (e) {
1048 + if (this.$element[0] !== e.target && !this.$element.has(e.target).length) {
1049 + this.$element.trigger('focus')
1050 + }
1051 + }, this))
1052 + }
1053 +
1054 + Modal.prototype.escape = function () {
1055 + if (this.isShown && this.options.keyboard) {
1056 + this.$element.on('keydown.dismiss.bs.modal', $.proxy(function (e) {
1057 + e.which == 27 && this.hide()
1058 + }, this))
1059 + } else if (!this.isShown) {
1060 + this.$element.off('keydown.dismiss.bs.modal')
1061 + }
1062 + }
1063 +
1064 + Modal.prototype.resize = function () {
1065 + if (this.isShown) {
1066 + $(window).on('resize.bs.modal', $.proxy(this.handleUpdate, this))
1067 + } else {
1068 + $(window).off('resize.bs.modal')
1069 + }
1070 + }
1071 +
1072 + Modal.prototype.hideModal = function () {
1073 + var that = this
1074 + this.$element.hide()
1075 + this.backdrop(function () {
1076 + that.$body.removeClass('modal-open')
1077 + that.resetAdjustments()
1078 + that.resetScrollbar()
1079 + that.$element.trigger('hidden.bs.modal')
1080 + })
1081 + }
1082 +
1083 + Modal.prototype.removeBackdrop = function () {
1084 + this.$backdrop && this.$backdrop.remove()
1085 + this.$backdrop = null
1086 + }
1087 +
1088 + Modal.prototype.backdrop = function (callback) {
1089 + var that = this
1090 + var animate = this.$element.hasClass('fade') ? 'fade' : ''
1091 +
1092 + if (this.isShown && this.options.backdrop) {
1093 + var doAnimate = $.support.transition && animate
1094 +
1095 + this.$backdrop = $('<div class="modal-backdrop ' + animate + '" />')
1096 + .appendTo(this.$body)
1097 +
1098 + this.$element.on('click.dismiss.bs.modal', $.proxy(function (e) {
1099 + if (this.ignoreBackdropClick) {
1100 + this.ignoreBackdropClick = false
1101 + return
1102 + }
1103 + if (e.target !== e.currentTarget) return
1104 + this.options.backdrop == 'static'
1105 + ? this.$element[0].focus()
1106 + : this.hide()
1107 + }, this))
1108 +
1109 + if (doAnimate) this.$backdrop[0].offsetWidth // force reflow
1110 +
1111 + this.$backdrop.addClass('in')
1112 +
1113 + if (!callback) return
1114 +
1115 + doAnimate ?
1116 + this.$backdrop
1117 + .one('bsTransitionEnd', callback)
1118 + .emulateTransitionEnd(Modal.BACKDROP_TRANSITION_DURATION) :
1119 + callback()
1120 +
1121 + } else if (!this.isShown && this.$backdrop) {
1122 + this.$backdrop.removeClass('in')
1123 +
1124 + var callbackRemove = function () {
1125 + that.removeBackdrop()
1126 + callback && callback()
1127 + }
1128 + $.support.transition && this.$element.hasClass('fade') ?
1129 + this.$backdrop
1130 + .one('bsTransitionEnd', callbackRemove)
1131 + .emulateTransitionEnd(Modal.BACKDROP_TRANSITION_DURATION) :
1132 + callbackRemove()
1133 +
1134 + } else if (callback) {
1135 + callback()
1136 + }
1137 + }
1138 +
1139 + // these following methods are used to handle overflowing modals
1140 +
1141 + Modal.prototype.handleUpdate = function () {
1142 + this.adjustDialog()
1143 + }
1144 +
1145 + Modal.prototype.adjustDialog = function () {
1146 + var modalIsOverflowing = this.$element[0].scrollHeight > document.documentElement.clientHeight
1147 +
1148 + this.$element.css({
1149 + paddingLeft: !this.bodyIsOverflowing && modalIsOverflowing ? this.scrollbarWidth : '',
1150 + paddingRight: this.bodyIsOverflowing && !modalIsOverflowing ? this.scrollbarWidth : ''
1151 + })
1152 + }
1153 +
1154 + Modal.prototype.resetAdjustments = function () {
1155 + this.$element.css({
1156 + paddingLeft: '',
1157 + paddingRight: ''
1158 + })
1159 + }
1160 +
1161 + Modal.prototype.checkScrollbar = function () {
1162 + var fullWindowWidth = window.innerWidth
1163 + if (!fullWindowWidth) { // workaround for missing window.innerWidth in IE8
1164 + var documentElementRect = document.documentElement.getBoundingClientRect()
1165 + fullWindowWidth = documentElementRect.right - Math.abs(documentElementRect.left)
1166 + }
1167 + this.bodyIsOverflowing = document.body.clientWidth < fullWindowWidth
1168 + this.scrollbarWidth = this.measureScrollbar()
1169 + }
1170 +
1171 + Modal.prototype.setScrollbar = function () {
1172 + var bodyPad = parseInt((this.$body.css('padding-right') || 0), 10)
1173 + this.originalBodyPad = document.body.style.paddingRight || ''
1174 + if (this.bodyIsOverflowing) this.$body.css('padding-right', bodyPad + this.scrollbarWidth)
1175 + }
1176 +
1177 + Modal.prototype.resetScrollbar = function () {
1178 + this.$body.css('padding-right', this.originalBodyPad)
1179 + }
1180 +
1181 + Modal.prototype.measureScrollbar = function () { // thx walsh
1182 + var scrollDiv = document.createElement('div')
1183 + scrollDiv.className = 'modal-scrollbar-measure'
1184 + this.$body.append(scrollDiv)
1185 + var scrollbarWidth = scrollDiv.offsetWidth - scrollDiv.clientWidth
1186 + this.$body[0].removeChild(scrollDiv)
1187 + return scrollbarWidth
1188 + }
1189 +
1190 +
1191 + // MODAL PLUGIN DEFINITION
1192 + // =======================
1193 +
1194 + function Plugin(option, _relatedTarget) {
1195 + return this.each(function () {
1196 + var $this = $(this)
1197 + var data = $this.data('bs.modal')
1198 + var options = $.extend({}, Modal.DEFAULTS, $this.data(), typeof option == 'object' && option)
1199 +
1200 + if (!data) $this.data('bs.modal', (data = new Modal(this, options)))
1201 + if (typeof option == 'string') data[option](_relatedTarget)
1202 + else if (options.show) data.show(_relatedTarget)
1203 + })
1204 + }
1205 +
1206 + var old = $.fn.modal
1207 +
1208 + $.fn.modal = Plugin
1209 + $.fn.modal.Constructor = Modal
1210 +
1211 +
1212 + // MODAL NO CONFLICT
1213 + // =================
1214 +
1215 + $.fn.modal.noConflict = function () {
1216 + $.fn.modal = old
1217 + return this
1218 + }
1219 +
1220 +
1221 + // MODAL DATA-API
1222 + // ==============
1223 +
1224 + $(document).on('click.bs.modal.data-api', '[data-toggle="modal"]', function (e) {
1225 + var $this = $(this)
1226 + var href = $this.attr('href')
1227 + var $target = $($this.attr('data-target') || (href && href.replace(/.*(?=#[^\s]+$)/, ''))) // strip for ie7
1228 + var option = $target.data('bs.modal') ? 'toggle' : $.extend({ remote: !/#/.test(href) && href }, $target.data(), $this.data())
1229 +
1230 + if ($this.is('a')) e.preventDefault()
1231 +
1232 + $target.one('show.bs.modal', function (showEvent) {
1233 + if (showEvent.isDefaultPrevented()) return // only register focus restorer if modal will actually get shown
1234 + $target.one('hidden.bs.modal', function () {
1235 + $this.is(':visible') && $this.trigger('focus')
1236 + })
1237 + })
1238 + Plugin.call($target, option, this)
1239 + })
1240 +
1241 +}(jQuery);
1242 +
1243 +/* ========================================================================
1244 + * Bootstrap: tooltip.js v3.3.4
1245 + * http://getbootstrap.com/javascript/#tooltip
1246 + * Inspired by the original jQuery.tipsy by Jason Frame
1247 + * ========================================================================
1248 + * Copyright 2011-2015 Twitter, Inc.
1249 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1250 + * ======================================================================== */
1251 +
1252 +
1253 ++function ($) {
1254 + 'use strict';
1255 +
1256 + // TOOLTIP PUBLIC CLASS DEFINITION
1257 + // ===============================
1258 +
1259 + var Tooltip = function (element, options) {
1260 + this.type = null
1261 + this.options = null
1262 + this.enabled = null
1263 + this.timeout = null
1264 + this.hoverState = null
1265 + this.$element = null
1266 +
1267 + this.init('tooltip', element, options)
1268 + }
1269 +
1270 + Tooltip.VERSION = '3.3.4'
1271 +
1272 + Tooltip.TRANSITION_DURATION = 150
1273 +
1274 + Tooltip.DEFAULTS = {
1275 + animation: true,
1276 + placement: 'top',
1277 + selector: false,
1278 + template: '<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',
1279 + trigger: 'hover focus',
1280 + title: '',
1281 + delay: 0,
1282 + html: false,
1283 + container: false,
1284 + viewport: {
1285 + selector: 'body',
1286 + padding: 0
1287 + }
1288 + }
1289 +
1290 + Tooltip.prototype.init = function (type, element, options) {
1291 + this.enabled = true
1292 + this.type = type
1293 + this.$element = $(element)
1294 + this.options = this.getOptions(options)
1295 + this.$viewport = this.options.viewport && $(this.options.viewport.selector || this.options.viewport)
1296 +
1297 + if (this.$element[0] instanceof document.constructor && !this.options.selector) {
1298 + throw new Error('`selector` option must be specified when initializing ' + this.type + ' on the window.document object!')
1299 + }
1300 +
1301 + var triggers = this.options.trigger.split(' ')
1302 +
1303 + for (var i = triggers.length; i--;) {
1304 + var trigger = triggers[i]
1305 +
1306 + if (trigger == 'click') {
1307 + this.$element.on('click.' + this.type, this.options.selector, $.proxy(this.toggle, this))
1308 + } else if (trigger != 'manual') {
1309 + var eventIn = trigger == 'hover' ? 'mouseenter' : 'focusin'
1310 + var eventOut = trigger == 'hover' ? 'mouseleave' : 'focusout'
1311 +
1312 + this.$element.on(eventIn + '.' + this.type, this.options.selector, $.proxy(this.enter, this))
1313 + this.$element.on(eventOut + '.' + this.type, this.options.selector, $.proxy(this.leave, this))
1314 + }
1315 + }
1316 +
1317 + this.options.selector ?
1318 + (this._options = $.extend({}, this.options, { trigger: 'manual', selector: '' })) :
1319 + this.fixTitle()
1320 + }
1321 +
1322 + Tooltip.prototype.getDefaults = function () {
1323 + return Tooltip.DEFAULTS
1324 + }
1325 +
1326 + Tooltip.prototype.getOptions = function (options) {
1327 + options = $.extend({}, this.getDefaults(), this.$element.data(), options)
1328 +
1329 + if (options.delay && typeof options.delay == 'number') {
1330 + options.delay = {
1331 + show: options.delay,
1332 + hide: options.delay
1333 + }
1334 + }
1335 +
1336 + return options
1337 + }
1338 +
1339 + Tooltip.prototype.getDelegateOptions = function () {
1340 + var options = {}
1341 + var defaults = this.getDefaults()
1342 +
1343 + this._options && $.each(this._options, function (key, value) {
1344 + if (defaults[key] != value) options[key] = value
1345 + })
1346 +
1347 + return options
1348 + }
1349 +
1350 + Tooltip.prototype.enter = function (obj) {
1351 + var self = obj instanceof this.constructor ?
1352 + obj : $(obj.currentTarget).data('bs.' + this.type)
1353 +
1354 + if (self && self.$tip && self.$tip.is(':visible')) {
1355 + self.hoverState = 'in'
1356 + return
1357 + }
1358 +
1359 + if (!self) {
1360 + self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
1361 + $(obj.currentTarget).data('bs.' + this.type, self)
1362 + }
1363 +
1364 + clearTimeout(self.timeout)
1365 +
1366 + self.hoverState = 'in'
1367 +
1368 + if (!self.options.delay || !self.options.delay.show) return self.show()
1369 +
1370 + self.timeout = setTimeout(function () {
1371 + if (self.hoverState == 'in') self.show()
1372 + }, self.options.delay.show)
1373 + }
1374 +
1375 + Tooltip.prototype.leave = function (obj) {
1376 + var self = obj instanceof this.constructor ?
1377 + obj : $(obj.currentTarget).data('bs.' + this.type)
1378 +
1379 + if (!self) {
1380 + self = new this.constructor(obj.currentTarget, this.getDelegateOptions())
1381 + $(obj.currentTarget).data('bs.' + this.type, self)
1382 + }
1383 +
1384 + clearTimeout(self.timeout)
1385 +
1386 + self.hoverState = 'out'
1387 +
1388 + if (!self.options.delay || !self.options.delay.hide) return self.hide()
1389 +
1390 + self.timeout = setTimeout(function () {
1391 + if (self.hoverState == 'out') self.hide()
1392 + }, self.options.delay.hide)
1393 + }
1394 +
1395 + Tooltip.prototype.show = function () {
1396 + var e = $.Event('show.bs.' + this.type)
1397 +
1398 + if (this.hasContent() && this.enabled) {
1399 + this.$element.trigger(e)
1400 +
1401 + var inDom = $.contains(this.$element[0].ownerDocument.documentElement, this.$element[0])
1402 + if (e.isDefaultPrevented() || !inDom) return
1403 + var that = this
1404 +
1405 + var $tip = this.tip()
1406 +
1407 + var tipId = this.getUID(this.type)
1408 +
1409 + this.setContent()
1410 + $tip.attr('id', tipId)
1411 + this.$element.attr('aria-describedby', tipId)
1412 +
1413 + if (this.options.animation) $tip.addClass('fade')
1414 +
1415 + var placement = typeof this.options.placement == 'function' ?
1416 + this.options.placement.call(this, $tip[0], this.$element[0]) :
1417 + this.options.placement
1418 +
1419 + var autoToken = /\s?auto?\s?/i
1420 + var autoPlace = autoToken.test(placement)
1421 + if (autoPlace) placement = placement.replace(autoToken, '') || 'top'
1422 +
1423 + $tip
1424 + .detach()
1425 + .css({ top: 0, left: 0, display: 'block' })
1426 + .addClass(placement)
1427 + .data('bs.' + this.type, this)
1428 +
1429 + this.options.container ? $tip.appendTo(this.options.container) : $tip.insertAfter(this.$element)
1430 +
1431 + var pos = this.getPosition()
1432 + var actualWidth = $tip[0].offsetWidth
1433 + var actualHeight = $tip[0].offsetHeight
1434 +
1435 + if (autoPlace) {
1436 + var orgPlacement = placement
1437 + var $container = this.options.container ? $(this.options.container) : this.$element.parent()
1438 + var containerDim = this.getPosition($container)
1439 +
1440 + placement = placement == 'bottom' && pos.bottom + actualHeight > containerDim.bottom ? 'top' :
1441 + placement == 'top' && pos.top - actualHeight < containerDim.top ? 'bottom' :
1442 + placement == 'right' && pos.right + actualWidth > containerDim.width ? 'left' :
1443 + placement == 'left' && pos.left - actualWidth < containerDim.left ? 'right' :
1444 + placement
1445 +
1446 + $tip
1447 + .removeClass(orgPlacement)
1448 + .addClass(placement)
1449 + }
1450 +
1451 + var calculatedOffset = this.getCalculatedOffset(placement, pos, actualWidth, actualHeight)
1452 +
1453 + this.applyPlacement(calculatedOffset, placement)
1454 +
1455 + var complete = function () {
1456 + var prevHoverState = that.hoverState
1457 + that.$element.trigger('shown.bs.' + that.type)
1458 + that.hoverState = null
1459 +
1460 + if (prevHoverState == 'out') that.leave(that)
1461 + }
1462 +
1463 + $.support.transition && this.$tip.hasClass('fade') ?
1464 + $tip
1465 + .one('bsTransitionEnd', complete)
1466 + .emulateTransitionEnd(Tooltip.TRANSITION_DURATION) :
1467 + complete()
1468 + }
1469 + }
1470 +
1471 + Tooltip.prototype.applyPlacement = function (offset, placement) {
1472 + var $tip = this.tip()
1473 + var width = $tip[0].offsetWidth
1474 + var height = $tip[0].offsetHeight
1475 +
1476 + // manually read margins because getBoundingClientRect includes difference
1477 + var marginTop = parseInt($tip.css('margin-top'), 10)
1478 + var marginLeft = parseInt($tip.css('margin-left'), 10)
1479 +
1480 + // we must check for NaN for ie 8/9
1481 + if (isNaN(marginTop)) marginTop = 0
1482 + if (isNaN(marginLeft)) marginLeft = 0
1483 +
1484 + offset.top = offset.top + marginTop
1485 + offset.left = offset.left + marginLeft
1486 +
1487 + // $.fn.offset doesn't round pixel values
1488 + // so we use setOffset directly with our own function B-0
1489 + $.offset.setOffset($tip[0], $.extend({
1490 + using: function (props) {
1491 + $tip.css({
1492 + top: Math.round(props.top),
1493 + left: Math.round(props.left)
1494 + })
1495 + }
1496 + }, offset), 0)
1497 +
1498 + $tip.addClass('in')
1499 +
1500 + // check to see if placing tip in new offset caused the tip to resize itself
1501 + var actualWidth = $tip[0].offsetWidth
1502 + var actualHeight = $tip[0].offsetHeight
1503 +
1504 + if (placement == 'top' && actualHeight != height) {
1505 + offset.top = offset.top + height - actualHeight
1506 + }
1507 +
1508 + var delta = this.getViewportAdjustedDelta(placement, offset, actualWidth, actualHeight)
1509 +
1510 + if (delta.left) offset.left += delta.left
1511 + else offset.top += delta.top
1512 +
1513 + var isVertical = /top|bottom/.test(placement)
1514 + var arrowDelta = isVertical ? delta.left * 2 - width + actualWidth : delta.top * 2 - height + actualHeight
1515 + var arrowOffsetPosition = isVertical ? 'offsetWidth' : 'offsetHeight'
1516 +
1517 + $tip.offset(offset)
1518 + this.replaceArrow(arrowDelta, $tip[0][arrowOffsetPosition], isVertical)
1519 + }
1520 +
1521 + Tooltip.prototype.replaceArrow = function (delta, dimension, isVertical) {
1522 + this.arrow()
1523 + .css(isVertical ? 'left' : 'top', 50 * (1 - delta / dimension) + '%')
1524 + .css(isVertical ? 'top' : 'left', '')
1525 + }
1526 +
1527 + Tooltip.prototype.setContent = function () {
1528 + var $tip = this.tip()
1529 + var title = this.getTitle()
1530 +
1531 + $tip.find('.tooltip-inner')[this.options.html ? 'html' : 'text'](title)
1532 + $tip.removeClass('fade in top bottom left right')
1533 + }
1534 +
1535 + Tooltip.prototype.hide = function (callback) {
1536 + var that = this
1537 + var $tip = $(this.$tip)
1538 + var e = $.Event('hide.bs.' + this.type)
1539 +
1540 + function complete() {
1541 + if (that.hoverState != 'in') $tip.detach()
1542 + that.$element
1543 + .removeAttr('aria-describedby')
1544 + .trigger('hidden.bs.' + that.type)
1545 + callback && callback()
1546 + }
1547 +
1548 + this.$element.trigger(e)
1549 +
1550 + if (e.isDefaultPrevented()) return
1551 +
1552 + $tip.removeClass('in')
1553 +
1554 + $.support.transition && $tip.hasClass('fade') ?
1555 + $tip
1556 + .one('bsTransitionEnd', complete)
1557 + .emulateTransitionEnd(Tooltip.TRANSITION_DURATION) :
1558 + complete()
1559 +
1560 + this.hoverState = null
1561 +
1562 + return this
1563 + }
1564 +
1565 + Tooltip.prototype.fixTitle = function () {
1566 + var $e = this.$element
1567 + if ($e.attr('title') || typeof ($e.attr('data-original-title')) != 'string') {
1568 + $e.attr('data-original-title', $e.attr('title') || '').attr('title', '')
1569 + }
1570 + }
1571 +
1572 + Tooltip.prototype.hasContent = function () {
1573 + return this.getTitle()
1574 + }
1575 +
1576 + Tooltip.prototype.getPosition = function ($element) {
1577 + $element = $element || this.$element
1578 +
1579 + var el = $element[0]
1580 + var isBody = el.tagName == 'BODY'
1581 +
1582 + var elRect = el.getBoundingClientRect()
1583 + if (elRect.width == null) {
1584 + // width and height are missing in IE8, so compute them manually; see https://github.com/twbs/bootstrap/issues/14093
1585 + elRect = $.extend({}, elRect, { width: elRect.right - elRect.left, height: elRect.bottom - elRect.top })
1586 + }
1587 + var elOffset = isBody ? { top: 0, left: 0 } : $element.offset()
1588 + var scroll = { scroll: isBody ? document.documentElement.scrollTop || document.body.scrollTop : $element.scrollTop() }
1589 + var outerDims = isBody ? { width: $(window).width(), height: $(window).height() } : null
1590 +
1591 + return $.extend({}, elRect, scroll, outerDims, elOffset)
1592 + }
1593 +
1594 + Tooltip.prototype.getCalculatedOffset = function (placement, pos, actualWidth, actualHeight) {
1595 + return placement == 'bottom' ? { top: pos.top + pos.height, left: pos.left + pos.width / 2 - actualWidth / 2 } :
1596 + placement == 'top' ? { top: pos.top - actualHeight, left: pos.left + pos.width / 2 - actualWidth / 2 } :
1597 + placement == 'left' ? { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left - actualWidth } :
1598 + /* placement == 'right' */ { top: pos.top + pos.height / 2 - actualHeight / 2, left: pos.left + pos.width }
1599 +
1600 + }
1601 +
1602 + Tooltip.prototype.getViewportAdjustedDelta = function (placement, pos, actualWidth, actualHeight) {
1603 + var delta = { top: 0, left: 0 }
1604 + if (!this.$viewport) return delta
1605 +
1606 + var viewportPadding = this.options.viewport && this.options.viewport.padding || 0
1607 + var viewportDimensions = this.getPosition(this.$viewport)
1608 +
1609 + if (/right|left/.test(placement)) {
1610 + var topEdgeOffset = pos.top - viewportPadding - viewportDimensions.scroll
1611 + var bottomEdgeOffset = pos.top + viewportPadding - viewportDimensions.scroll + actualHeight
1612 + if (topEdgeOffset < viewportDimensions.top) { // top overflow
1613 + delta.top = viewportDimensions.top - topEdgeOffset
1614 + } else if (bottomEdgeOffset > viewportDimensions.top + viewportDimensions.height) { // bottom overflow
1615 + delta.top = viewportDimensions.top + viewportDimensions.height - bottomEdgeOffset
1616 + }
1617 + } else {
1618 + var leftEdgeOffset = pos.left - viewportPadding
1619 + var rightEdgeOffset = pos.left + viewportPadding + actualWidth
1620 + if (leftEdgeOffset < viewportDimensions.left) { // left overflow
1621 + delta.left = viewportDimensions.left - leftEdgeOffset
1622 + } else if (rightEdgeOffset > viewportDimensions.width) { // right overflow
1623 + delta.left = viewportDimensions.left + viewportDimensions.width - rightEdgeOffset
1624 + }
1625 + }
1626 +
1627 + return delta
1628 + }
1629 +
1630 + Tooltip.prototype.getTitle = function () {
1631 + var title
1632 + var $e = this.$element
1633 + var o = this.options
1634 +
1635 + title = $e.attr('data-original-title')
1636 + || (typeof o.title == 'function' ? o.title.call($e[0]) : o.title)
1637 +
1638 + return title
1639 + }
1640 +
1641 + Tooltip.prototype.getUID = function (prefix) {
1642 + do prefix += ~~(Math.random() * 1000000)
1643 + while (document.getElementById(prefix))
1644 + return prefix
1645 + }
1646 +
1647 + Tooltip.prototype.tip = function () {
1648 + return (this.$tip = this.$tip || $(this.options.template))
1649 + }
1650 +
1651 + Tooltip.prototype.arrow = function () {
1652 + return (this.$arrow = this.$arrow || this.tip().find('.tooltip-arrow'))
1653 + }
1654 +
1655 + Tooltip.prototype.enable = function () {
1656 + this.enabled = true
1657 + }
1658 +
1659 + Tooltip.prototype.disable = function () {
1660 + this.enabled = false
1661 + }
1662 +
1663 + Tooltip.prototype.toggleEnabled = function () {
1664 + this.enabled = !this.enabled
1665 + }
1666 +
1667 + Tooltip.prototype.toggle = function (e) {
1668 + var self = this
1669 + if (e) {
1670 + self = $(e.currentTarget).data('bs.' + this.type)
1671 + if (!self) {
1672 + self = new this.constructor(e.currentTarget, this.getDelegateOptions())
1673 + $(e.currentTarget).data('bs.' + this.type, self)
1674 + }
1675 + }
1676 +
1677 + self.tip().hasClass('in') ? self.leave(self) : self.enter(self)
1678 + }
1679 +
1680 + Tooltip.prototype.destroy = function () {
1681 + var that = this
1682 + clearTimeout(this.timeout)
1683 + this.hide(function () {
1684 + that.$element.off('.' + that.type).removeData('bs.' + that.type)
1685 + })
1686 + }
1687 +
1688 +
1689 + // TOOLTIP PLUGIN DEFINITION
1690 + // =========================
1691 +
1692 + function Plugin(option) {
1693 + return this.each(function () {
1694 + var $this = $(this)
1695 + var data = $this.data('bs.tooltip')
1696 + var options = typeof option == 'object' && option
1697 +
1698 + if (!data && /destroy|hide/.test(option)) return
1699 + if (!data) $this.data('bs.tooltip', (data = new Tooltip(this, options)))
1700 + if (typeof option == 'string') data[option]()
1701 + })
1702 + }
1703 +
1704 + var old = $.fn.tooltip
1705 +
1706 + $.fn.tooltip = Plugin
1707 + $.fn.tooltip.Constructor = Tooltip
1708 +
1709 +
1710 + // TOOLTIP NO CONFLICT
1711 + // ===================
1712 +
1713 + $.fn.tooltip.noConflict = function () {
1714 + $.fn.tooltip = old
1715 + return this
1716 + }
1717 +
1718 +}(jQuery);
1719 +
1720 +/* ========================================================================
1721 + * Bootstrap: popover.js v3.3.4
1722 + * http://getbootstrap.com/javascript/#popovers
1723 + * ========================================================================
1724 + * Copyright 2011-2015 Twitter, Inc.
1725 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1726 + * ======================================================================== */
1727 +
1728 +
1729 ++function ($) {
1730 + 'use strict';
1731 +
1732 + // POPOVER PUBLIC CLASS DEFINITION
1733 + // ===============================
1734 +
1735 + var Popover = function (element, options) {
1736 + this.init('popover', element, options)
1737 + }
1738 +
1739 + if (!$.fn.tooltip) throw new Error('Popover requires tooltip.js')
1740 +
1741 + Popover.VERSION = '3.3.4'
1742 +
1743 + Popover.DEFAULTS = $.extend({}, $.fn.tooltip.Constructor.DEFAULTS, {
1744 + placement: 'right',
1745 + trigger: 'click',
1746 + content: '',
1747 + template: '<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'
1748 + })
1749 +
1750 +
1751 + // NOTE: POPOVER EXTENDS tooltip.js
1752 + // ================================
1753 +
1754 + Popover.prototype = $.extend({}, $.fn.tooltip.Constructor.prototype)
1755 +
1756 + Popover.prototype.constructor = Popover
1757 +
1758 + Popover.prototype.getDefaults = function () {
1759 + return Popover.DEFAULTS
1760 + }
1761 +
1762 + Popover.prototype.setContent = function () {
1763 + var $tip = this.tip()
1764 + var title = this.getTitle()
1765 + var content = this.getContent()
1766 +
1767 + $tip.find('.popover-title')[this.options.html ? 'html' : 'text'](title)
1768 + $tip.find('.popover-content').children().detach().end()[ // we use append for html objects to maintain js events
1769 + this.options.html ? (typeof content == 'string' ? 'html' : 'append') : 'text'
1770 + ](content)
1771 +
1772 + $tip.removeClass('fade top bottom left right in')
1773 +
1774 + // IE8 doesn't accept hiding via the `:empty` pseudo selector, we have to do
1775 + // this manually by checking the contents.
1776 + if (!$tip.find('.popover-title').html()) $tip.find('.popover-title').hide()
1777 + }
1778 +
1779 + Popover.prototype.hasContent = function () {
1780 + return this.getTitle() || this.getContent()
1781 + }
1782 +
1783 + Popover.prototype.getContent = function () {
1784 + var $e = this.$element
1785 + var o = this.options
1786 +
1787 + return $e.attr('data-content')
1788 + || (typeof o.content == 'function' ?
1789 + o.content.call($e[0]) :
1790 + o.content)
1791 + }
1792 +
1793 + Popover.prototype.arrow = function () {
1794 + return (this.$arrow = this.$arrow || this.tip().find('.arrow'))
1795 + }
1796 +
1797 +
1798 + // POPOVER PLUGIN DEFINITION
1799 + // =========================
1800 +
1801 + function Plugin(option) {
1802 + return this.each(function () {
1803 + var $this = $(this)
1804 + var data = $this.data('bs.popover')
1805 + var options = typeof option == 'object' && option
1806 +
1807 + if (!data && /destroy|hide/.test(option)) return
1808 + if (!data) $this.data('bs.popover', (data = new Popover(this, options)))
1809 + if (typeof option == 'string') data[option]()
1810 + })
1811 + }
1812 +
1813 + var old = $.fn.popover
1814 +
1815 + $.fn.popover = Plugin
1816 + $.fn.popover.Constructor = Popover
1817 +
1818 +
1819 + // POPOVER NO CONFLICT
1820 + // ===================
1821 +
1822 + $.fn.popover.noConflict = function () {
1823 + $.fn.popover = old
1824 + return this
1825 + }
1826 +
1827 +}(jQuery);
1828 +
1829 +/* ========================================================================
1830 + * Bootstrap: scrollspy.js v3.3.4
1831 + * http://getbootstrap.com/javascript/#scrollspy
1832 + * ========================================================================
1833 + * Copyright 2011-2015 Twitter, Inc.
1834 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
1835 + * ======================================================================== */
1836 +
1837 +
1838 ++function ($) {
1839 + 'use strict';
1840 +
1841 + // SCROLLSPY CLASS DEFINITION
1842 + // ==========================
1843 +
1844 + function ScrollSpy(element, options) {
1845 + this.$body = $(document.body)
1846 + this.$scrollElement = $(element).is(document.body) ? $(window) : $(element)
1847 + this.options = $.extend({}, ScrollSpy.DEFAULTS, options)
1848 + this.selector = (this.options.target || '') + ' .nav li > a'
1849 + this.offsets = []
1850 + this.targets = []
1851 + this.activeTarget = null
1852 + this.scrollHeight = 0
1853 +
1854 + this.$scrollElement.on('scroll.bs.scrollspy', $.proxy(this.process, this))
1855 + this.refresh()
1856 + this.process()
1857 + }
1858 +
1859 + ScrollSpy.VERSION = '3.3.4'
1860 +
1861 + ScrollSpy.DEFAULTS = {
1862 + offset: 10
1863 + }
1864 +
1865 + ScrollSpy.prototype.getScrollHeight = function () {
1866 + return this.$scrollElement[0].scrollHeight || Math.max(this.$body[0].scrollHeight, document.documentElement.scrollHeight)
1867 + }
1868 +
1869 + ScrollSpy.prototype.refresh = function () {
1870 + var that = this
1871 + var offsetMethod = 'offset'
1872 + var offsetBase = 0
1873 +
1874 + this.offsets = []
1875 + this.targets = []
1876 + this.scrollHeight = this.getScrollHeight()
1877 +
1878 + if (!$.isWindow(this.$scrollElement[0])) {
1879 + offsetMethod = 'position'
1880 + offsetBase = this.$scrollElement.scrollTop()
1881 + }
1882 +
1883 + this.$body
1884 + .find(this.selector)
1885 + .map(function () {
1886 + var $el = $(this)
1887 + var href = $el.data('target') || $el.attr('href')
1888 + var $href = /^#./.test(href) && $(href)
1889 +
1890 + return ($href
1891 + && $href.length
1892 + && $href.is(':visible')
1893 + && [[$href[offsetMethod]().top + offsetBase, href]]) || null
1894 + })
1895 + .sort(function (a, b) { return a[0] - b[0] })
1896 + .each(function () {
1897 + that.offsets.push(this[0])
1898 + that.targets.push(this[1])
1899 + })
1900 + }
1901 +
1902 + ScrollSpy.prototype.process = function () {
1903 + var scrollTop = this.$scrollElement.scrollTop() + this.options.offset
1904 + var scrollHeight = this.getScrollHeight()
1905 + var maxScroll = this.options.offset + scrollHeight - this.$scrollElement.height()
1906 + var offsets = this.offsets
1907 + var targets = this.targets
1908 + var activeTarget = this.activeTarget
1909 + var i
1910 +
1911 + if (this.scrollHeight != scrollHeight) {
1912 + this.refresh()
1913 + }
1914 +
1915 + if (scrollTop >= maxScroll) {
1916 + return activeTarget != (i = targets[targets.length - 1]) && this.activate(i)
1917 + }
1918 +
1919 + if (activeTarget && scrollTop < offsets[0]) {
1920 + this.activeTarget = null
1921 + return this.clear()
1922 + }
1923 +
1924 + for (i = offsets.length; i--;) {
1925 + activeTarget != targets[i]
1926 + && scrollTop >= offsets[i]
1927 + && (offsets[i + 1] === undefined || scrollTop < offsets[i + 1])
1928 + && this.activate(targets[i])
1929 + }
1930 + }
1931 +
1932 + ScrollSpy.prototype.activate = function (target) {
1933 + this.activeTarget = target
1934 +
1935 + this.clear()
1936 +
1937 + var selector = this.selector +
1938 + '[data-target="' + target + '"],' +
1939 + this.selector + '[href="' + target + '"]'
1940 +
1941 + var active = $(selector)
1942 + .parents('li')
1943 + .addClass('active')
1944 +
1945 + if (active.parent('.dropdown-menu').length) {
1946 + active = active
1947 + .closest('li.dropdown')
1948 + .addClass('active')
1949 + }
1950 +
1951 + active.trigger('activate.bs.scrollspy')
1952 + }
1953 +
1954 + ScrollSpy.prototype.clear = function () {
1955 + $(this.selector)
1956 + .parentsUntil(this.options.target, '.active')
1957 + .removeClass('active')
1958 + }
1959 +
1960 +
1961 + // SCROLLSPY PLUGIN DEFINITION
1962 + // ===========================
1963 +
1964 + function Plugin(option) {
1965 + return this.each(function () {
1966 + var $this = $(this)
1967 + var data = $this.data('bs.scrollspy')
1968 + var options = typeof option == 'object' && option
1969 +
1970 + if (!data) $this.data('bs.scrollspy', (data = new ScrollSpy(this, options)))
1971 + if (typeof option == 'string') data[option]()
1972 + })
1973 + }
1974 +
1975 + var old = $.fn.scrollspy
1976 +
1977 + $.fn.scrollspy = Plugin
1978 + $.fn.scrollspy.Constructor = ScrollSpy
1979 +
1980 +
1981 + // SCROLLSPY NO CONFLICT
1982 + // =====================
1983 +
1984 + $.fn.scrollspy.noConflict = function () {
1985 + $.fn.scrollspy = old
1986 + return this
1987 + }
1988 +
1989 +
1990 + // SCROLLSPY DATA-API
1991 + // ==================
1992 +
1993 + $(window).on('load.bs.scrollspy.data-api', function () {
1994 + $('[data-spy="scroll"]').each(function () {
1995 + var $spy = $(this)
1996 + Plugin.call($spy, $spy.data())
1997 + })
1998 + })
1999 +
2000 +}(jQuery);
2001 +
2002 +/* ========================================================================
2003 + * Bootstrap: tab.js v3.3.4
2004 + * http://getbootstrap.com/javascript/#tabs
2005 + * ========================================================================
2006 + * Copyright 2011-2015 Twitter, Inc.
2007 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
2008 + * ======================================================================== */
2009 +
2010 +
2011 ++function ($) {
2012 + 'use strict';
2013 +
2014 + // TAB CLASS DEFINITION
2015 + // ====================
2016 +
2017 + var Tab = function (element) {
2018 + this.element = $(element)
2019 + }
2020 +
2021 + Tab.VERSION = '3.3.4'
2022 +
2023 + Tab.TRANSITION_DURATION = 150
2024 +
2025 + Tab.prototype.show = function () {
2026 + var $this = this.element
2027 + var $ul = $this.closest('ul:not(.dropdown-menu)')
2028 + var selector = $this.data('target')
2029 +
2030 + if (!selector) {
2031 + selector = $this.attr('href')
2032 + selector = selector && selector.replace(/.*(?=#[^\s]*$)/, '') // strip for ie7
2033 + }
2034 +
2035 + if ($this.parent('li').hasClass('active')) return
2036 +
2037 + var $previous = $ul.find('.active:last a')
2038 + var hideEvent = $.Event('hide.bs.tab', {
2039 + relatedTarget: $this[0]
2040 + })
2041 + var showEvent = $.Event('show.bs.tab', {
2042 + relatedTarget: $previous[0]
2043 + })
2044 +
2045 + $previous.trigger(hideEvent)
2046 + $this.trigger(showEvent)
2047 +
2048 + if (showEvent.isDefaultPrevented() || hideEvent.isDefaultPrevented()) return
2049 +
2050 + var $target = $(selector)
2051 +
2052 + this.activate($this.closest('li'), $ul)
2053 + this.activate($target, $target.parent(), function () {
2054 + $previous.trigger({
2055 + type: 'hidden.bs.tab',
2056 + relatedTarget: $this[0]
2057 + })
2058 + $this.trigger({
2059 + type: 'shown.bs.tab',
2060 + relatedTarget: $previous[0]
2061 + })
2062 + })
2063 + }
2064 +
2065 + Tab.prototype.activate = function (element, container, callback) {
2066 + var $active = container.find('> .active')
2067 + var transition = callback
2068 + && $.support.transition
2069 + && (($active.length && $active.hasClass('fade')) || !!container.find('> .fade').length)
2070 +
2071 + function next() {
2072 + $active
2073 + .removeClass('active')
2074 + .find('> .dropdown-menu > .active')
2075 + .removeClass('active')
2076 + .end()
2077 + .find('[data-toggle="tab"]')
2078 + .attr('aria-expanded', false)
2079 +
2080 + element
2081 + .addClass('active')
2082 + .find('[data-toggle="tab"]')
2083 + .attr('aria-expanded', true)
2084 +
2085 + if (transition) {
2086 + element[0].offsetWidth // reflow for transition
2087 + element.addClass('in')
2088 + } else {
2089 + element.removeClass('fade')
2090 + }
2091 +
2092 + if (element.parent('.dropdown-menu').length) {
2093 + element
2094 + .closest('li.dropdown')
2095 + .addClass('active')
2096 + .end()
2097 + .find('[data-toggle="tab"]')
2098 + .attr('aria-expanded', true)
2099 + }
2100 +
2101 + callback && callback()
2102 + }
2103 +
2104 + $active.length && transition ?
2105 + $active
2106 + .one('bsTransitionEnd', next)
2107 + .emulateTransitionEnd(Tab.TRANSITION_DURATION) :
2108 + next()
2109 +
2110 + $active.removeClass('in')
2111 + }
2112 +
2113 +
2114 + // TAB PLUGIN DEFINITION
2115 + // =====================
2116 +
2117 + function Plugin(option) {
2118 + return this.each(function () {
2119 + var $this = $(this)
2120 + var data = $this.data('bs.tab')
2121 +
2122 + if (!data) $this.data('bs.tab', (data = new Tab(this)))
2123 + if (typeof option == 'string') data[option]()
2124 + })
2125 + }
2126 +
2127 + var old = $.fn.tab
2128 +
2129 + $.fn.tab = Plugin
2130 + $.fn.tab.Constructor = Tab
2131 +
2132 +
2133 + // TAB NO CONFLICT
2134 + // ===============
2135 +
2136 + $.fn.tab.noConflict = function () {
2137 + $.fn.tab = old
2138 + return this
2139 + }
2140 +
2141 +
2142 + // TAB DATA-API
2143 + // ============
2144 +
2145 + var clickHandler = function (e) {
2146 + e.preventDefault()
2147 + Plugin.call($(this), 'show')
2148 + }
2149 +
2150 + $(document)
2151 + .on('click.bs.tab.data-api', '[data-toggle="tab"]', clickHandler)
2152 + .on('click.bs.tab.data-api', '[data-toggle="pill"]', clickHandler)
2153 +
2154 +}(jQuery);
2155 +
2156 +/* ========================================================================
2157 + * Bootstrap: affix.js v3.3.4
2158 + * http://getbootstrap.com/javascript/#affix
2159 + * ========================================================================
2160 + * Copyright 2011-2015 Twitter, Inc.
2161 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
2162 + * ======================================================================== */
2163 +
2164 +
2165 ++function ($) {
2166 + 'use strict';
2167 +
2168 + // AFFIX CLASS DEFINITION
2169 + // ======================
2170 +
2171 + var Affix = function (element, options) {
2172 + this.options = $.extend({}, Affix.DEFAULTS, options)
2173 +
2174 + this.$target = $(this.options.target)
2175 + .on('scroll.bs.affix.data-api', $.proxy(this.checkPosition, this))
2176 + .on('click.bs.affix.data-api', $.proxy(this.checkPositionWithEventLoop, this))
2177 +
2178 + this.$element = $(element)
2179 + this.affixed = null
2180 + this.unpin = null
2181 + this.pinnedOffset = null
2182 +
2183 + this.checkPosition()
2184 + }
2185 +
2186 + Affix.VERSION = '3.3.4'
2187 +
2188 + Affix.RESET = 'affix affix-top affix-bottom'
2189 +
2190 + Affix.DEFAULTS = {
2191 + offset: 0,
2192 + target: window
2193 + }
2194 +
2195 + Affix.prototype.getState = function (scrollHeight, height, offsetTop, offsetBottom) {
2196 + var scrollTop = this.$target.scrollTop()
2197 + var position = this.$element.offset()
2198 + var targetHeight = this.$target.height()
2199 +
2200 + if (offsetTop != null && this.affixed == 'top') return scrollTop < offsetTop ? 'top' : false
2201 +
2202 + if (this.affixed == 'bottom') {
2203 + if (offsetTop != null) return (scrollTop + this.unpin <= position.top) ? false : 'bottom'
2204 + return (scrollTop + targetHeight <= scrollHeight - offsetBottom) ? false : 'bottom'
2205 + }
2206 +
2207 + var initializing = this.affixed == null
2208 + var colliderTop = initializing ? scrollTop : position.top
2209 + var colliderHeight = initializing ? targetHeight : height
2210 +
2211 + if (offsetTop != null && scrollTop <= offsetTop) return 'top'
2212 + if (offsetBottom != null && (colliderTop + colliderHeight >= scrollHeight - offsetBottom)) return 'bottom'
2213 +
2214 + return false
2215 + }
2216 +
2217 + Affix.prototype.getPinnedOffset = function () {
2218 + if (this.pinnedOffset) return this.pinnedOffset
2219 + this.$element.removeClass(Affix.RESET).addClass('affix')
2220 + var scrollTop = this.$target.scrollTop()
2221 + var position = this.$element.offset()
2222 + return (this.pinnedOffset = position.top - scrollTop)
2223 + }
2224 +
2225 + Affix.prototype.checkPositionWithEventLoop = function () {
2226 + setTimeout($.proxy(this.checkPosition, this), 1)
2227 + }
2228 +
2229 + Affix.prototype.checkPosition = function () {
2230 + if (!this.$element.is(':visible')) return
2231 +
2232 + var height = this.$element.height()
2233 + var offset = this.options.offset
2234 + var offsetTop = offset.top
2235 + var offsetBottom = offset.bottom
2236 + var scrollHeight = $(document.body).height()
2237 +
2238 + if (typeof offset != 'object') offsetBottom = offsetTop = offset
2239 + if (typeof offsetTop == 'function') offsetTop = offset.top(this.$element)
2240 + if (typeof offsetBottom == 'function') offsetBottom = offset.bottom(this.$element)
2241 +
2242 + var affix = this.getState(scrollHeight, height, offsetTop, offsetBottom)
2243 +
2244 + if (this.affixed != affix) {
2245 + if (this.unpin != null) this.$element.css('top', '')
2246 +
2247 + var affixType = 'affix' + (affix ? '-' + affix : '')
2248 + var e = $.Event(affixType + '.bs.affix')
2249 +
2250 + this.$element.trigger(e)
2251 +
2252 + if (e.isDefaultPrevented()) return
2253 +
2254 + this.affixed = affix
2255 + this.unpin = affix == 'bottom' ? this.getPinnedOffset() : null
2256 +
2257 + this.$element
2258 + .removeClass(Affix.RESET)
2259 + .addClass(affixType)
2260 + .trigger(affixType.replace('affix', 'affixed') + '.bs.affix')
2261 + }
2262 +
2263 + if (affix == 'bottom') {
2264 + this.$element.offset({
2265 + top: scrollHeight - height - offsetBottom
2266 + })
2267 + }
2268 + }
2269 +
2270 +
2271 + // AFFIX PLUGIN DEFINITION
2272 + // =======================
2273 +
2274 + function Plugin(option) {
2275 + return this.each(function () {
2276 + var $this = $(this)
2277 + var data = $this.data('bs.affix')
2278 + var options = typeof option == 'object' && option
2279 +
2280 + if (!data) $this.data('bs.affix', (data = new Affix(this, options)))
2281 + if (typeof option == 'string') data[option]()
2282 + })
2283 + }
2284 +
2285 + var old = $.fn.affix
2286 +
2287 + $.fn.affix = Plugin
2288 + $.fn.affix.Constructor = Affix
2289 +
2290 +
2291 + // AFFIX NO CONFLICT
2292 + // =================
2293 +
2294 + $.fn.affix.noConflict = function () {
2295 + $.fn.affix = old
2296 + return this
2297 + }
2298 +
2299 +
2300 + // AFFIX DATA-API
2301 + // ==============
2302 +
2303 + $(window).on('load', function () {
2304 + $('[data-spy="affix"]').each(function () {
2305 + var $spy = $(this)
2306 + var data = $spy.data()
2307 +
2308 + data.offset = data.offset || {}
2309 +
2310 + if (data.offsetBottom != null) data.offset.bottom = data.offsetBottom
2311 + if (data.offsetTop != null) data.offset.top = data.offsetTop
2312 +
2313 + Plugin.call($spy, data)
2314 + })
2315 + })
2316 +
2317 +}(jQuery);
1 +/*!
2 + * Bootstrap v3.3.4 (http://getbootstrap.com)
3 + * Copyright 2011-2015 Twitter, Inc.
4 + * Licensed under MIT (https://github.com/twbs/bootstrap/blob/master/LICENSE)
5 + */
6 +if("undefined"==typeof jQuery)throw new Error("Bootstrap's JavaScript requires jQuery");+function(a){"use strict";var b=a.fn.jquery.split(" ")[0].split(".");if(b[0]<2&&b[1]<9||1==b[0]&&9==b[1]&&b[2]<1)throw new Error("Bootstrap's JavaScript requires jQuery version 1.9.1 or higher")}(jQuery),+function(a){"use strict";function b(){var a=document.createElement("bootstrap"),b={WebkitTransition:"webkitTransitionEnd",MozTransition:"transitionend",OTransition:"oTransitionEnd otransitionend",transition:"transitionend"};for(var c in b)if(void 0!==a.style[c])return{end:b[c]};return!1}a.fn.emulateTransitionEnd=function(b){var c=!1,d=this;a(this).one("bsTransitionEnd",function(){c=!0});var e=function(){c||a(d).trigger(a.support.transition.end)};return setTimeout(e,b),this},a(function(){a.support.transition=b(),a.support.transition&&(a.event.special.bsTransitionEnd={bindType:a.support.transition.end,delegateType:a.support.transition.end,handle:function(b){return a(b.target).is(this)?b.handleObj.handler.apply(this,arguments):void 0}})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var c=a(this),e=c.data("bs.alert");e||c.data("bs.alert",e=new d(this)),"string"==typeof b&&e[b].call(c)})}var c='[data-dismiss="alert"]',d=function(b){a(b).on("click",c,this.close)};d.VERSION="3.3.4",d.TRANSITION_DURATION=150,d.prototype.close=function(b){function c(){g.detach().trigger("closed.bs.alert").remove()}var e=a(this),f=e.attr("data-target");f||(f=e.attr("href"),f=f&&f.replace(/.*(?=#[^\s]*$)/,""));var g=a(f);b&&b.preventDefault(),g.length||(g=e.closest(".alert")),g.trigger(b=a.Event("close.bs.alert")),b.isDefaultPrevented()||(g.removeClass("in"),a.support.transition&&g.hasClass("fade")?g.one("bsTransitionEnd",c).emulateTransitionEnd(d.TRANSITION_DURATION):c())};var e=a.fn.alert;a.fn.alert=b,a.fn.alert.Constructor=d,a.fn.alert.noConflict=function(){return a.fn.alert=e,this},a(document).on("click.bs.alert.data-api",c,d.prototype.close)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.button"),f="object"==typeof b&&b;e||d.data("bs.button",e=new c(this,f)),"toggle"==b?e.toggle():b&&e.setState(b)})}var c=function(b,d){this.$element=a(b),this.options=a.extend({},c.DEFAULTS,d),this.isLoading=!1};c.VERSION="3.3.4",c.DEFAULTS={loadingText:"loading..."},c.prototype.setState=function(b){var c="disabled",d=this.$element,e=d.is("input")?"val":"html",f=d.data();b+="Text",null==f.resetText&&d.data("resetText",d[e]()),setTimeout(a.proxy(function(){d[e](null==f[b]?this.options[b]:f[b]),"loadingText"==b?(this.isLoading=!0,d.addClass(c).attr(c,c)):this.isLoading&&(this.isLoading=!1,d.removeClass(c).removeAttr(c))},this),0)},c.prototype.toggle=function(){var a=!0,b=this.$element.closest('[data-toggle="buttons"]');if(b.length){var c=this.$element.find("input");"radio"==c.prop("type")&&(c.prop("checked")&&this.$element.hasClass("active")?a=!1:b.find(".active").removeClass("active")),a&&c.prop("checked",!this.$element.hasClass("active")).trigger("change")}else this.$element.attr("aria-pressed",!this.$element.hasClass("active"));a&&this.$element.toggleClass("active")};var d=a.fn.button;a.fn.button=b,a.fn.button.Constructor=c,a.fn.button.noConflict=function(){return a.fn.button=d,this},a(document).on("click.bs.button.data-api",'[data-toggle^="button"]',function(c){var d=a(c.target);d.hasClass("btn")||(d=d.closest(".btn")),b.call(d,"toggle"),c.preventDefault()}).on("focus.bs.button.data-api blur.bs.button.data-api",'[data-toggle^="button"]',function(b){a(b.target).closest(".btn").toggleClass("focus",/^focus(in)?$/.test(b.type))})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.carousel"),f=a.extend({},c.DEFAULTS,d.data(),"object"==typeof b&&b),g="string"==typeof b?b:f.slide;e||d.data("bs.carousel",e=new c(this,f)),"number"==typeof b?e.to(b):g?e[g]():f.interval&&e.pause().cycle()})}var c=function(b,c){this.$element=a(b),this.$indicators=this.$element.find(".carousel-indicators"),this.options=c,this.paused=null,this.sliding=null,this.interval=null,this.$active=null,this.$items=null,this.options.keyboard&&this.$element.on("keydown.bs.carousel",a.proxy(this.keydown,this)),"hover"==this.options.pause&&!("ontouchstart"in document.documentElement)&&this.$element.on("mouseenter.bs.carousel",a.proxy(this.pause,this)).on("mouseleave.bs.carousel",a.proxy(this.cycle,this))};c.VERSION="3.3.4",c.TRANSITION_DURATION=600,c.DEFAULTS={interval:5e3,pause:"hover",wrap:!0,keyboard:!0},c.prototype.keydown=function(a){if(!/input|textarea/i.test(a.target.tagName)){switch(a.which){case 37:this.prev();break;case 39:this.next();break;default:return}a.preventDefault()}},c.prototype.cycle=function(b){return b||(this.paused=!1),this.interval&&clearInterval(this.interval),this.options.interval&&!this.paused&&(this.interval=setInterval(a.proxy(this.next,this),this.options.interval)),this},c.prototype.getItemIndex=function(a){return this.$items=a.parent().children(".item"),this.$items.index(a||this.$active)},c.prototype.getItemForDirection=function(a,b){var c=this.getItemIndex(b),d="prev"==a&&0===c||"next"==a&&c==this.$items.length-1;if(d&&!this.options.wrap)return b;var e="prev"==a?-1:1,f=(c+e)%this.$items.length;return this.$items.eq(f)},c.prototype.to=function(a){var b=this,c=this.getItemIndex(this.$active=this.$element.find(".item.active"));return a>this.$items.length-1||0>a?void 0:this.sliding?this.$element.one("slid.bs.carousel",function(){b.to(a)}):c==a?this.pause().cycle():this.slide(a>c?"next":"prev",this.$items.eq(a))},c.prototype.pause=function(b){return b||(this.paused=!0),this.$element.find(".next, .prev").length&&a.support.transition&&(this.$element.trigger(a.support.transition.end),this.cycle(!0)),this.interval=clearInterval(this.interval),this},c.prototype.next=function(){return this.sliding?void 0:this.slide("next")},c.prototype.prev=function(){return this.sliding?void 0:this.slide("prev")},c.prototype.slide=function(b,d){var e=this.$element.find(".item.active"),f=d||this.getItemForDirection(b,e),g=this.interval,h="next"==b?"left":"right",i=this;if(f.hasClass("active"))return this.sliding=!1;var j=f[0],k=a.Event("slide.bs.carousel",{relatedTarget:j,direction:h});if(this.$element.trigger(k),!k.isDefaultPrevented()){if(this.sliding=!0,g&&this.pause(),this.$indicators.length){this.$indicators.find(".active").removeClass("active");var l=a(this.$indicators.children()[this.getItemIndex(f)]);l&&l.addClass("active")}var m=a.Event("slid.bs.carousel",{relatedTarget:j,direction:h});return a.support.transition&&this.$element.hasClass("slide")?(f.addClass(b),f[0].offsetWidth,e.addClass(h),f.addClass(h),e.one("bsTransitionEnd",function(){f.removeClass([b,h].join(" ")).addClass("active"),e.removeClass(["active",h].join(" ")),i.sliding=!1,setTimeout(function(){i.$element.trigger(m)},0)}).emulateTransitionEnd(c.TRANSITION_DURATION)):(e.removeClass("active"),f.addClass("active"),this.sliding=!1,this.$element.trigger(m)),g&&this.cycle(),this}};var d=a.fn.carousel;a.fn.carousel=b,a.fn.carousel.Constructor=c,a.fn.carousel.noConflict=function(){return a.fn.carousel=d,this};var e=function(c){var d,e=a(this),f=a(e.attr("data-target")||(d=e.attr("href"))&&d.replace(/.*(?=#[^\s]+$)/,""));if(f.hasClass("carousel")){var g=a.extend({},f.data(),e.data()),h=e.attr("data-slide-to");h&&(g.interval=!1),b.call(f,g),h&&f.data("bs.carousel").to(h),c.preventDefault()}};a(document).on("click.bs.carousel.data-api","[data-slide]",e).on("click.bs.carousel.data-api","[data-slide-to]",e),a(window).on("load",function(){a('[data-ride="carousel"]').each(function(){var c=a(this);b.call(c,c.data())})})}(jQuery),+function(a){"use strict";function b(b){var c,d=b.attr("data-target")||(c=b.attr("href"))&&c.replace(/.*(?=#[^\s]+$)/,"");return a(d)}function c(b){return this.each(function(){var c=a(this),e=c.data("bs.collapse"),f=a.extend({},d.DEFAULTS,c.data(),"object"==typeof b&&b);!e&&f.toggle&&/show|hide/.test(b)&&(f.toggle=!1),e||c.data("bs.collapse",e=new d(this,f)),"string"==typeof b&&e[b]()})}var d=function(b,c){this.$element=a(b),this.options=a.extend({},d.DEFAULTS,c),this.$trigger=a('[data-toggle="collapse"][href="#'+b.id+'"],[data-toggle="collapse"][data-target="#'+b.id+'"]'),this.transitioning=null,this.options.parent?this.$parent=this.getParent():this.addAriaAndCollapsedClass(this.$element,this.$trigger),this.options.toggle&&this.toggle()};d.VERSION="3.3.4",d.TRANSITION_DURATION=350,d.DEFAULTS={toggle:!0},d.prototype.dimension=function(){var a=this.$element.hasClass("width");return a?"width":"height"},d.prototype.show=function(){if(!this.transitioning&&!this.$element.hasClass("in")){var b,e=this.$parent&&this.$parent.children(".panel").children(".in, .collapsing");if(!(e&&e.length&&(b=e.data("bs.collapse"),b&&b.transitioning))){var f=a.Event("show.bs.collapse");if(this.$element.trigger(f),!f.isDefaultPrevented()){e&&e.length&&(c.call(e,"hide"),b||e.data("bs.collapse",null));var g=this.dimension();this.$element.removeClass("collapse").addClass("collapsing")[g](0).attr("aria-expanded",!0),this.$trigger.removeClass("collapsed").attr("aria-expanded",!0),this.transitioning=1;var h=function(){this.$element.removeClass("collapsing").addClass("collapse in")[g](""),this.transitioning=0,this.$element.trigger("shown.bs.collapse")};if(!a.support.transition)return h.call(this);var i=a.camelCase(["scroll",g].join("-"));this.$element.one("bsTransitionEnd",a.proxy(h,this)).emulateTransitionEnd(d.TRANSITION_DURATION)[g](this.$element[0][i])}}}},d.prototype.hide=function(){if(!this.transitioning&&this.$element.hasClass("in")){var b=a.Event("hide.bs.collapse");if(this.$element.trigger(b),!b.isDefaultPrevented()){var c=this.dimension();this.$element[c](this.$element[c]())[0].offsetHeight,this.$element.addClass("collapsing").removeClass("collapse in").attr("aria-expanded",!1),this.$trigger.addClass("collapsed").attr("aria-expanded",!1),this.transitioning=1;var e=function(){this.transitioning=0,this.$element.removeClass("collapsing").addClass("collapse").trigger("hidden.bs.collapse")};return a.support.transition?void this.$element[c](0).one("bsTransitionEnd",a.proxy(e,this)).emulateTransitionEnd(d.TRANSITION_DURATION):e.call(this)}}},d.prototype.toggle=function(){this[this.$element.hasClass("in")?"hide":"show"]()},d.prototype.getParent=function(){return a(this.options.parent).find('[data-toggle="collapse"][data-parent="'+this.options.parent+'"]').each(a.proxy(function(c,d){var e=a(d);this.addAriaAndCollapsedClass(b(e),e)},this)).end()},d.prototype.addAriaAndCollapsedClass=function(a,b){var c=a.hasClass("in");a.attr("aria-expanded",c),b.toggleClass("collapsed",!c).attr("aria-expanded",c)};var e=a.fn.collapse;a.fn.collapse=c,a.fn.collapse.Constructor=d,a.fn.collapse.noConflict=function(){return a.fn.collapse=e,this},a(document).on("click.bs.collapse.data-api",'[data-toggle="collapse"]',function(d){var e=a(this);e.attr("data-target")||d.preventDefault();var f=b(e),g=f.data("bs.collapse"),h=g?"toggle":e.data();c.call(f,h)})}(jQuery),+function(a){"use strict";function b(b){b&&3===b.which||(a(e).remove(),a(f).each(function(){var d=a(this),e=c(d),f={relatedTarget:this};e.hasClass("open")&&(e.trigger(b=a.Event("hide.bs.dropdown",f)),b.isDefaultPrevented()||(d.attr("aria-expanded","false"),e.removeClass("open").trigger("hidden.bs.dropdown",f)))}))}function c(b){var c=b.attr("data-target");c||(c=b.attr("href"),c=c&&/#[A-Za-z]/.test(c)&&c.replace(/.*(?=#[^\s]*$)/,""));var d=c&&a(c);return d&&d.length?d:b.parent()}function d(b){return this.each(function(){var c=a(this),d=c.data("bs.dropdown");d||c.data("bs.dropdown",d=new g(this)),"string"==typeof b&&d[b].call(c)})}var e=".dropdown-backdrop",f='[data-toggle="dropdown"]',g=function(b){a(b).on("click.bs.dropdown",this.toggle)};g.VERSION="3.3.4",g.prototype.toggle=function(d){var e=a(this);if(!e.is(".disabled, :disabled")){var f=c(e),g=f.hasClass("open");if(b(),!g){"ontouchstart"in document.documentElement&&!f.closest(".navbar-nav").length&&a('<div class="dropdown-backdrop"/>').insertAfter(a(this)).on("click",b);var h={relatedTarget:this};if(f.trigger(d=a.Event("show.bs.dropdown",h)),d.isDefaultPrevented())return;e.trigger("focus").attr("aria-expanded","true"),f.toggleClass("open").trigger("shown.bs.dropdown",h)}return!1}},g.prototype.keydown=function(b){if(/(38|40|27|32)/.test(b.which)&&!/input|textarea/i.test(b.target.tagName)){var d=a(this);if(b.preventDefault(),b.stopPropagation(),!d.is(".disabled, :disabled")){var e=c(d),g=e.hasClass("open");if(!g&&27!=b.which||g&&27==b.which)return 27==b.which&&e.find(f).trigger("focus"),d.trigger("click");var h=" li:not(.disabled):visible a",i=e.find('[role="menu"]'+h+', [role="listbox"]'+h);if(i.length){var j=i.index(b.target);38==b.which&&j>0&&j--,40==b.which&&j<i.length-1&&j++,~j||(j=0),i.eq(j).trigger("focus")}}}};var h=a.fn.dropdown;a.fn.dropdown=d,a.fn.dropdown.Constructor=g,a.fn.dropdown.noConflict=function(){return a.fn.dropdown=h,this},a(document).on("click.bs.dropdown.data-api",b).on("click.bs.dropdown.data-api",".dropdown form",function(a){a.stopPropagation()}).on("click.bs.dropdown.data-api",f,g.prototype.toggle).on("keydown.bs.dropdown.data-api",f,g.prototype.keydown).on("keydown.bs.dropdown.data-api",'[role="menu"]',g.prototype.keydown).on("keydown.bs.dropdown.data-api",'[role="listbox"]',g.prototype.keydown)}(jQuery),+function(a){"use strict";function b(b,d){return this.each(function(){var e=a(this),f=e.data("bs.modal"),g=a.extend({},c.DEFAULTS,e.data(),"object"==typeof b&&b);f||e.data("bs.modal",f=new c(this,g)),"string"==typeof b?f[b](d):g.show&&f.show(d)})}var c=function(b,c){this.options=c,this.$body=a(document.body),this.$element=a(b),this.$dialog=this.$element.find(".modal-dialog"),this.$backdrop=null,this.isShown=null,this.originalBodyPad=null,this.scrollbarWidth=0,this.ignoreBackdropClick=!1,this.options.remote&&this.$element.find(".modal-content").load(this.options.remote,a.proxy(function(){this.$element.trigger("loaded.bs.modal")},this))};c.VERSION="3.3.4",c.TRANSITION_DURATION=300,c.BACKDROP_TRANSITION_DURATION=150,c.DEFAULTS={backdrop:!0,keyboard:!0,show:!0},c.prototype.toggle=function(a){return this.isShown?this.hide():this.show(a)},c.prototype.show=function(b){var d=this,e=a.Event("show.bs.modal",{relatedTarget:b});this.$element.trigger(e),this.isShown||e.isDefaultPrevented()||(this.isShown=!0,this.checkScrollbar(),this.setScrollbar(),this.$body.addClass("modal-open"),this.escape(),this.resize(),this.$element.on("click.dismiss.bs.modal",'[data-dismiss="modal"]',a.proxy(this.hide,this)),this.$dialog.on("mousedown.dismiss.bs.modal",function(){d.$element.one("mouseup.dismiss.bs.modal",function(b){a(b.target).is(d.$element)&&(d.ignoreBackdropClick=!0)})}),this.backdrop(function(){var e=a.support.transition&&d.$element.hasClass("fade");d.$element.parent().length||d.$element.appendTo(d.$body),d.$element.show().scrollTop(0),d.adjustDialog(),e&&d.$element[0].offsetWidth,d.$element.addClass("in").attr("aria-hidden",!1),d.enforceFocus();var f=a.Event("shown.bs.modal",{relatedTarget:b});e?d.$dialog.one("bsTransitionEnd",function(){d.$element.trigger("focus").trigger(f)}).emulateTransitionEnd(c.TRANSITION_DURATION):d.$element.trigger("focus").trigger(f)}))},c.prototype.hide=function(b){b&&b.preventDefault(),b=a.Event("hide.bs.modal"),this.$element.trigger(b),this.isShown&&!b.isDefaultPrevented()&&(this.isShown=!1,this.escape(),this.resize(),a(document).off("focusin.bs.modal"),this.$element.removeClass("in").attr("aria-hidden",!0).off("click.dismiss.bs.modal").off("mouseup.dismiss.bs.modal"),this.$dialog.off("mousedown.dismiss.bs.modal"),a.support.transition&&this.$element.hasClass("fade")?this.$element.one("bsTransitionEnd",a.proxy(this.hideModal,this)).emulateTransitionEnd(c.TRANSITION_DURATION):this.hideModal())},c.prototype.enforceFocus=function(){a(document).off("focusin.bs.modal").on("focusin.bs.modal",a.proxy(function(a){this.$element[0]===a.target||this.$element.has(a.target).length||this.$element.trigger("focus")},this))},c.prototype.escape=function(){this.isShown&&this.options.keyboard?this.$element.on("keydown.dismiss.bs.modal",a.proxy(function(a){27==a.which&&this.hide()},this)):this.isShown||this.$element.off("keydown.dismiss.bs.modal")},c.prototype.resize=function(){this.isShown?a(window).on("resize.bs.modal",a.proxy(this.handleUpdate,this)):a(window).off("resize.bs.modal")},c.prototype.hideModal=function(){var a=this;this.$element.hide(),this.backdrop(function(){a.$body.removeClass("modal-open"),a.resetAdjustments(),a.resetScrollbar(),a.$element.trigger("hidden.bs.modal")})},c.prototype.removeBackdrop=function(){this.$backdrop&&this.$backdrop.remove(),this.$backdrop=null},c.prototype.backdrop=function(b){var d=this,e=this.$element.hasClass("fade")?"fade":"";if(this.isShown&&this.options.backdrop){var f=a.support.transition&&e;if(this.$backdrop=a('<div class="modal-backdrop '+e+'" />').appendTo(this.$body),this.$element.on("click.dismiss.bs.modal",a.proxy(function(a){return this.ignoreBackdropClick?void(this.ignoreBackdropClick=!1):void(a.target===a.currentTarget&&("static"==this.options.backdrop?this.$element[0].focus():this.hide()))},this)),f&&this.$backdrop[0].offsetWidth,this.$backdrop.addClass("in"),!b)return;f?this.$backdrop.one("bsTransitionEnd",b).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):b()}else if(!this.isShown&&this.$backdrop){this.$backdrop.removeClass("in");var g=function(){d.removeBackdrop(),b&&b()};a.support.transition&&this.$element.hasClass("fade")?this.$backdrop.one("bsTransitionEnd",g).emulateTransitionEnd(c.BACKDROP_TRANSITION_DURATION):g()}else b&&b()},c.prototype.handleUpdate=function(){this.adjustDialog()},c.prototype.adjustDialog=function(){var a=this.$element[0].scrollHeight>document.documentElement.clientHeight;this.$element.css({paddingLeft:!this.bodyIsOverflowing&&a?this.scrollbarWidth:"",paddingRight:this.bodyIsOverflowing&&!a?this.scrollbarWidth:""})},c.prototype.resetAdjustments=function(){this.$element.css({paddingLeft:"",paddingRight:""})},c.prototype.checkScrollbar=function(){var a=window.innerWidth;if(!a){var b=document.documentElement.getBoundingClientRect();a=b.right-Math.abs(b.left)}this.bodyIsOverflowing=document.body.clientWidth<a,this.scrollbarWidth=this.measureScrollbar()},c.prototype.setScrollbar=function(){var a=parseInt(this.$body.css("padding-right")||0,10);this.originalBodyPad=document.body.style.paddingRight||"",this.bodyIsOverflowing&&this.$body.css("padding-right",a+this.scrollbarWidth)},c.prototype.resetScrollbar=function(){this.$body.css("padding-right",this.originalBodyPad)},c.prototype.measureScrollbar=function(){var a=document.createElement("div");a.className="modal-scrollbar-measure",this.$body.append(a);var b=a.offsetWidth-a.clientWidth;return this.$body[0].removeChild(a),b};var d=a.fn.modal;a.fn.modal=b,a.fn.modal.Constructor=c,a.fn.modal.noConflict=function(){return a.fn.modal=d,this},a(document).on("click.bs.modal.data-api",'[data-toggle="modal"]',function(c){var d=a(this),e=d.attr("href"),f=a(d.attr("data-target")||e&&e.replace(/.*(?=#[^\s]+$)/,"")),g=f.data("bs.modal")?"toggle":a.extend({remote:!/#/.test(e)&&e},f.data(),d.data());d.is("a")&&c.preventDefault(),f.one("show.bs.modal",function(a){a.isDefaultPrevented()||f.one("hidden.bs.modal",function(){d.is(":visible")&&d.trigger("focus")})}),b.call(f,g,this)})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tooltip"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.tooltip",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.type=null,this.options=null,this.enabled=null,this.timeout=null,this.hoverState=null,this.$element=null,this.init("tooltip",a,b)};c.VERSION="3.3.4",c.TRANSITION_DURATION=150,c.DEFAULTS={animation:!0,placement:"top",selector:!1,template:'<div class="tooltip" role="tooltip"><div class="tooltip-arrow"></div><div class="tooltip-inner"></div></div>',trigger:"hover focus",title:"",delay:0,html:!1,container:!1,viewport:{selector:"body",padding:0}},c.prototype.init=function(b,c,d){if(this.enabled=!0,this.type=b,this.$element=a(c),this.options=this.getOptions(d),this.$viewport=this.options.viewport&&a(this.options.viewport.selector||this.options.viewport),this.$element[0]instanceof document.constructor&&!this.options.selector)throw new Error("`selector` option must be specified when initializing "+this.type+" on the window.document object!");for(var e=this.options.trigger.split(" "),f=e.length;f--;){var g=e[f];if("click"==g)this.$element.on("click."+this.type,this.options.selector,a.proxy(this.toggle,this));else if("manual"!=g){var h="hover"==g?"mouseenter":"focusin",i="hover"==g?"mouseleave":"focusout";this.$element.on(h+"."+this.type,this.options.selector,a.proxy(this.enter,this)),this.$element.on(i+"."+this.type,this.options.selector,a.proxy(this.leave,this))}}this.options.selector?this._options=a.extend({},this.options,{trigger:"manual",selector:""}):this.fixTitle()},c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.getOptions=function(b){return b=a.extend({},this.getDefaults(),this.$element.data(),b),b.delay&&"number"==typeof b.delay&&(b.delay={show:b.delay,hide:b.delay}),b},c.prototype.getDelegateOptions=function(){var b={},c=this.getDefaults();return this._options&&a.each(this._options,function(a,d){c[a]!=d&&(b[a]=d)}),b},c.prototype.enter=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c&&c.$tip&&c.$tip.is(":visible")?void(c.hoverState="in"):(c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),clearTimeout(c.timeout),c.hoverState="in",c.options.delay&&c.options.delay.show?void(c.timeout=setTimeout(function(){"in"==c.hoverState&&c.show()},c.options.delay.show)):c.show())},c.prototype.leave=function(b){var c=b instanceof this.constructor?b:a(b.currentTarget).data("bs."+this.type);return c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c)),clearTimeout(c.timeout),c.hoverState="out",c.options.delay&&c.options.delay.hide?void(c.timeout=setTimeout(function(){"out"==c.hoverState&&c.hide()},c.options.delay.hide)):c.hide()},c.prototype.show=function(){var b=a.Event("show.bs."+this.type);if(this.hasContent()&&this.enabled){this.$element.trigger(b);var d=a.contains(this.$element[0].ownerDocument.documentElement,this.$element[0]);if(b.isDefaultPrevented()||!d)return;var e=this,f=this.tip(),g=this.getUID(this.type);this.setContent(),f.attr("id",g),this.$element.attr("aria-describedby",g),this.options.animation&&f.addClass("fade");var h="function"==typeof this.options.placement?this.options.placement.call(this,f[0],this.$element[0]):this.options.placement,i=/\s?auto?\s?/i,j=i.test(h);j&&(h=h.replace(i,"")||"top"),f.detach().css({top:0,left:0,display:"block"}).addClass(h).data("bs."+this.type,this),this.options.container?f.appendTo(this.options.container):f.insertAfter(this.$element);var k=this.getPosition(),l=f[0].offsetWidth,m=f[0].offsetHeight;if(j){var n=h,o=this.options.container?a(this.options.container):this.$element.parent(),p=this.getPosition(o);h="bottom"==h&&k.bottom+m>p.bottom?"top":"top"==h&&k.top-m<p.top?"bottom":"right"==h&&k.right+l>p.width?"left":"left"==h&&k.left-l<p.left?"right":h,f.removeClass(n).addClass(h)}var q=this.getCalculatedOffset(h,k,l,m);this.applyPlacement(q,h);var r=function(){var a=e.hoverState;e.$element.trigger("shown.bs."+e.type),e.hoverState=null,"out"==a&&e.leave(e)};a.support.transition&&this.$tip.hasClass("fade")?f.one("bsTransitionEnd",r).emulateTransitionEnd(c.TRANSITION_DURATION):r()}},c.prototype.applyPlacement=function(b,c){var d=this.tip(),e=d[0].offsetWidth,f=d[0].offsetHeight,g=parseInt(d.css("margin-top"),10),h=parseInt(d.css("margin-left"),10);isNaN(g)&&(g=0),isNaN(h)&&(h=0),b.top=b.top+g,b.left=b.left+h,a.offset.setOffset(d[0],a.extend({using:function(a){d.css({top:Math.round(a.top),left:Math.round(a.left)})}},b),0),d.addClass("in");var i=d[0].offsetWidth,j=d[0].offsetHeight;"top"==c&&j!=f&&(b.top=b.top+f-j);var k=this.getViewportAdjustedDelta(c,b,i,j);k.left?b.left+=k.left:b.top+=k.top;var l=/top|bottom/.test(c),m=l?2*k.left-e+i:2*k.top-f+j,n=l?"offsetWidth":"offsetHeight";d.offset(b),this.replaceArrow(m,d[0][n],l)},c.prototype.replaceArrow=function(a,b,c){this.arrow().css(c?"left":"top",50*(1-a/b)+"%").css(c?"top":"left","")},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle();a.find(".tooltip-inner")[this.options.html?"html":"text"](b),a.removeClass("fade in top bottom left right")},c.prototype.hide=function(b){function d(){"in"!=e.hoverState&&f.detach(),e.$element.removeAttr("aria-describedby").trigger("hidden.bs."+e.type),b&&b()}var e=this,f=a(this.$tip),g=a.Event("hide.bs."+this.type);return this.$element.trigger(g),g.isDefaultPrevented()?void 0:(f.removeClass("in"),a.support.transition&&f.hasClass("fade")?f.one("bsTransitionEnd",d).emulateTransitionEnd(c.TRANSITION_DURATION):d(),this.hoverState=null,this)},c.prototype.fixTitle=function(){var a=this.$element;(a.attr("title")||"string"!=typeof a.attr("data-original-title"))&&a.attr("data-original-title",a.attr("title")||"").attr("title","")},c.prototype.hasContent=function(){return this.getTitle()},c.prototype.getPosition=function(b){b=b||this.$element;var c=b[0],d="BODY"==c.tagName,e=c.getBoundingClientRect();null==e.width&&(e=a.extend({},e,{width:e.right-e.left,height:e.bottom-e.top}));var f=d?{top:0,left:0}:b.offset(),g={scroll:d?document.documentElement.scrollTop||document.body.scrollTop:b.scrollTop()},h=d?{width:a(window).width(),height:a(window).height()}:null;return a.extend({},e,g,h,f)},c.prototype.getCalculatedOffset=function(a,b,c,d){return"bottom"==a?{top:b.top+b.height,left:b.left+b.width/2-c/2}:"top"==a?{top:b.top-d,left:b.left+b.width/2-c/2}:"left"==a?{top:b.top+b.height/2-d/2,left:b.left-c}:{top:b.top+b.height/2-d/2,left:b.left+b.width}},c.prototype.getViewportAdjustedDelta=function(a,b,c,d){var e={top:0,left:0};if(!this.$viewport)return e;var f=this.options.viewport&&this.options.viewport.padding||0,g=this.getPosition(this.$viewport);if(/right|left/.test(a)){var h=b.top-f-g.scroll,i=b.top+f-g.scroll+d;h<g.top?e.top=g.top-h:i>g.top+g.height&&(e.top=g.top+g.height-i)}else{var j=b.left-f,k=b.left+f+c;j<g.left?e.left=g.left-j:k>g.width&&(e.left=g.left+g.width-k)}return e},c.prototype.getTitle=function(){var a,b=this.$element,c=this.options;return a=b.attr("data-original-title")||("function"==typeof c.title?c.title.call(b[0]):c.title)},c.prototype.getUID=function(a){do a+=~~(1e6*Math.random());while(document.getElementById(a));return a},c.prototype.tip=function(){return this.$tip=this.$tip||a(this.options.template)},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".tooltip-arrow")},c.prototype.enable=function(){this.enabled=!0},c.prototype.disable=function(){this.enabled=!1},c.prototype.toggleEnabled=function(){this.enabled=!this.enabled},c.prototype.toggle=function(b){var c=this;b&&(c=a(b.currentTarget).data("bs."+this.type),c||(c=new this.constructor(b.currentTarget,this.getDelegateOptions()),a(b.currentTarget).data("bs."+this.type,c))),c.tip().hasClass("in")?c.leave(c):c.enter(c)},c.prototype.destroy=function(){var a=this;clearTimeout(this.timeout),this.hide(function(){a.$element.off("."+a.type).removeData("bs."+a.type)})};var d=a.fn.tooltip;a.fn.tooltip=b,a.fn.tooltip.Constructor=c,a.fn.tooltip.noConflict=function(){return a.fn.tooltip=d,this}}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.popover"),f="object"==typeof b&&b;(e||!/destroy|hide/.test(b))&&(e||d.data("bs.popover",e=new c(this,f)),"string"==typeof b&&e[b]())})}var c=function(a,b){this.init("popover",a,b)};if(!a.fn.tooltip)throw new Error("Popover requires tooltip.js");c.VERSION="3.3.4",c.DEFAULTS=a.extend({},a.fn.tooltip.Constructor.DEFAULTS,{placement:"right",trigger:"click",content:"",template:'<div class="popover" role="tooltip"><div class="arrow"></div><h3 class="popover-title"></h3><div class="popover-content"></div></div>'}),c.prototype=a.extend({},a.fn.tooltip.Constructor.prototype),c.prototype.constructor=c,c.prototype.getDefaults=function(){return c.DEFAULTS},c.prototype.setContent=function(){var a=this.tip(),b=this.getTitle(),c=this.getContent();a.find(".popover-title")[this.options.html?"html":"text"](b),a.find(".popover-content").children().detach().end()[this.options.html?"string"==typeof c?"html":"append":"text"](c),a.removeClass("fade top bottom left right in"),a.find(".popover-title").html()||a.find(".popover-title").hide()},c.prototype.hasContent=function(){return this.getTitle()||this.getContent()},c.prototype.getContent=function(){var a=this.$element,b=this.options;return a.attr("data-content")||("function"==typeof b.content?b.content.call(a[0]):b.content)},c.prototype.arrow=function(){return this.$arrow=this.$arrow||this.tip().find(".arrow")};var d=a.fn.popover;a.fn.popover=b,a.fn.popover.Constructor=c,a.fn.popover.noConflict=function(){return a.fn.popover=d,this}}(jQuery),+function(a){"use strict";function b(c,d){this.$body=a(document.body),this.$scrollElement=a(a(c).is(document.body)?window:c),this.options=a.extend({},b.DEFAULTS,d),this.selector=(this.options.target||"")+" .nav li > a",this.offsets=[],this.targets=[],this.activeTarget=null,this.scrollHeight=0,this.$scrollElement.on("scroll.bs.scrollspy",a.proxy(this.process,this)),this.refresh(),this.process()}function c(c){return this.each(function(){var d=a(this),e=d.data("bs.scrollspy"),f="object"==typeof c&&c;e||d.data("bs.scrollspy",e=new b(this,f)),"string"==typeof c&&e[c]()})}b.VERSION="3.3.4",b.DEFAULTS={offset:10},b.prototype.getScrollHeight=function(){return this.$scrollElement[0].scrollHeight||Math.max(this.$body[0].scrollHeight,document.documentElement.scrollHeight)},b.prototype.refresh=function(){var b=this,c="offset",d=0;this.offsets=[],this.targets=[],this.scrollHeight=this.getScrollHeight(),a.isWindow(this.$scrollElement[0])||(c="position",d=this.$scrollElement.scrollTop()),this.$body.find(this.selector).map(function(){var b=a(this),e=b.data("target")||b.attr("href"),f=/^#./.test(e)&&a(e);return f&&f.length&&f.is(":visible")&&[[f[c]().top+d,e]]||null}).sort(function(a,b){return a[0]-b[0]}).each(function(){b.offsets.push(this[0]),b.targets.push(this[1])})},b.prototype.process=function(){var a,b=this.$scrollElement.scrollTop()+this.options.offset,c=this.getScrollHeight(),d=this.options.offset+c-this.$scrollElement.height(),e=this.offsets,f=this.targets,g=this.activeTarget;if(this.scrollHeight!=c&&this.refresh(),b>=d)return g!=(a=f[f.length-1])&&this.activate(a);if(g&&b<e[0])return this.activeTarget=null,this.clear();for(a=e.length;a--;)g!=f[a]&&b>=e[a]&&(void 0===e[a+1]||b<e[a+1])&&this.activate(f[a])},b.prototype.activate=function(b){this.activeTarget=b,this.clear();var c=this.selector+'[data-target="'+b+'"],'+this.selector+'[href="'+b+'"]',d=a(c).parents("li").addClass("active");d.parent(".dropdown-menu").length&&(d=d.closest("li.dropdown").addClass("active")),d.trigger("activate.bs.scrollspy")},b.prototype.clear=function(){a(this.selector).parentsUntil(this.options.target,".active").removeClass("active")};var d=a.fn.scrollspy;a.fn.scrollspy=c,a.fn.scrollspy.Constructor=b,a.fn.scrollspy.noConflict=function(){return a.fn.scrollspy=d,this},a(window).on("load.bs.scrollspy.data-api",function(){a('[data-spy="scroll"]').each(function(){var b=a(this);c.call(b,b.data())})})}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.tab");e||d.data("bs.tab",e=new c(this)),"string"==typeof b&&e[b]()})}var c=function(b){this.element=a(b)};c.VERSION="3.3.4",c.TRANSITION_DURATION=150,c.prototype.show=function(){var b=this.element,c=b.closest("ul:not(.dropdown-menu)"),d=b.data("target");if(d||(d=b.attr("href"),d=d&&d.replace(/.*(?=#[^\s]*$)/,"")),!b.parent("li").hasClass("active")){
7 +var e=c.find(".active:last a"),f=a.Event("hide.bs.tab",{relatedTarget:b[0]}),g=a.Event("show.bs.tab",{relatedTarget:e[0]});if(e.trigger(f),b.trigger(g),!g.isDefaultPrevented()&&!f.isDefaultPrevented()){var h=a(d);this.activate(b.closest("li"),c),this.activate(h,h.parent(),function(){e.trigger({type:"hidden.bs.tab",relatedTarget:b[0]}),b.trigger({type:"shown.bs.tab",relatedTarget:e[0]})})}}},c.prototype.activate=function(b,d,e){function f(){g.removeClass("active").find("> .dropdown-menu > .active").removeClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!1),b.addClass("active").find('[data-toggle="tab"]').attr("aria-expanded",!0),h?(b[0].offsetWidth,b.addClass("in")):b.removeClass("fade"),b.parent(".dropdown-menu").length&&b.closest("li.dropdown").addClass("active").end().find('[data-toggle="tab"]').attr("aria-expanded",!0),e&&e()}var g=d.find("> .active"),h=e&&a.support.transition&&(g.length&&g.hasClass("fade")||!!d.find("> .fade").length);g.length&&h?g.one("bsTransitionEnd",f).emulateTransitionEnd(c.TRANSITION_DURATION):f(),g.removeClass("in")};var d=a.fn.tab;a.fn.tab=b,a.fn.tab.Constructor=c,a.fn.tab.noConflict=function(){return a.fn.tab=d,this};var e=function(c){c.preventDefault(),b.call(a(this),"show")};a(document).on("click.bs.tab.data-api",'[data-toggle="tab"]',e).on("click.bs.tab.data-api",'[data-toggle="pill"]',e)}(jQuery),+function(a){"use strict";function b(b){return this.each(function(){var d=a(this),e=d.data("bs.affix"),f="object"==typeof b&&b;e||d.data("bs.affix",e=new c(this,f)),"string"==typeof b&&e[b]()})}var c=function(b,d){this.options=a.extend({},c.DEFAULTS,d),this.$target=a(this.options.target).on("scroll.bs.affix.data-api",a.proxy(this.checkPosition,this)).on("click.bs.affix.data-api",a.proxy(this.checkPositionWithEventLoop,this)),this.$element=a(b),this.affixed=null,this.unpin=null,this.pinnedOffset=null,this.checkPosition()};c.VERSION="3.3.4",c.RESET="affix affix-top affix-bottom",c.DEFAULTS={offset:0,target:window},c.prototype.getState=function(a,b,c,d){var e=this.$target.scrollTop(),f=this.$element.offset(),g=this.$target.height();if(null!=c&&"top"==this.affixed)return c>e?"top":!1;if("bottom"==this.affixed)return null!=c?e+this.unpin<=f.top?!1:"bottom":a-d>=e+g?!1:"bottom";var h=null==this.affixed,i=h?e:f.top,j=h?g:b;return null!=c&&c>=e?"top":null!=d&&i+j>=a-d?"bottom":!1},c.prototype.getPinnedOffset=function(){if(this.pinnedOffset)return this.pinnedOffset;this.$element.removeClass(c.RESET).addClass("affix");var a=this.$target.scrollTop(),b=this.$element.offset();return this.pinnedOffset=b.top-a},c.prototype.checkPositionWithEventLoop=function(){setTimeout(a.proxy(this.checkPosition,this),1)},c.prototype.checkPosition=function(){if(this.$element.is(":visible")){var b=this.$element.height(),d=this.options.offset,e=d.top,f=d.bottom,g=a(document.body).height();"object"!=typeof d&&(f=e=d),"function"==typeof e&&(e=d.top(this.$element)),"function"==typeof f&&(f=d.bottom(this.$element));var h=this.getState(g,b,e,f);if(this.affixed!=h){null!=this.unpin&&this.$element.css("top","");var i="affix"+(h?"-"+h:""),j=a.Event(i+".bs.affix");if(this.$element.trigger(j),j.isDefaultPrevented())return;this.affixed=h,this.unpin="bottom"==h?this.getPinnedOffset():null,this.$element.removeClass(c.RESET).addClass(i).trigger(i.replace("affix","affixed")+".bs.affix")}"bottom"==h&&this.$element.offset({top:g-b-f})}};var d=a.fn.affix;a.fn.affix=b,a.fn.affix.Constructor=c,a.fn.affix.noConflict=function(){return a.fn.affix=d,this},a(window).on("load",function(){a('[data-spy="affix"]').each(function(){var c=a(this),d=c.data();d.offset=d.offset||{},null!=d.offsetBottom&&(d.offset.bottom=d.offsetBottom),null!=d.offsetTop&&(d.offset.top=d.offsetTop),b.call(c,d)})})}(jQuery);
...\ No newline at end of file ...\ No newline at end of file
1 +$(function() {
2 +
3 + $("input,textarea").jqBootstrapValidation({
4 + preventSubmit: true,
5 + submitError: function($form, event, errors) {
6 + // additional error messages or events
7 + },
8 + submitSuccess: function($form, event) {
9 + event.preventDefault(); // prevent default submit behaviour
10 + // get values from FORM
11 + var name = $("input#name").val();
12 + var email = $("input#email").val();
13 + var message = $("textarea#message").val();
14 + var firstName = name; // For Success/Failure Message
15 + // Check for white space in name for Success/Fail message
16 + if (firstName.indexOf(' ') >= 0) {
17 + firstName = name.split(' ').slice(0, -1).join(' ');
18 + }
19 + $.ajax({
20 + url: "././mail/contact_me.php",
21 + type: "POST",
22 + data: {
23 + name: name,
24 + email: email,
25 + message: message
26 + },
27 + cache: false,
28 + success: function() {
29 + // Success message
30 + $('#success').html("<div class='alert alert-success'>");
31 + $('#success > .alert-success').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>&times;")
32 + .append("</button>");
33 + $('#success > .alert-success')
34 + .append("<strong>Your message has been sent. </strong>");
35 + $('#success > .alert-success')
36 + .append('</div>');
37 +
38 + //clear all fields
39 + $('#contactForm').trigger("reset");
40 + },
41 + error: function() {
42 + // Fail message
43 + $('#success').html("<div class='alert alert-danger'>");
44 + $('#success > .alert-danger').html("<button type='button' class='close' data-dismiss='alert' aria-hidden='true'>&times;")
45 + .append("</button>");
46 + $('#success > .alert-danger').append("<strong>Sorry " + firstName + ", it seems that my mail server is not responding. Please try again later!");
47 + $('#success > .alert-danger').append('</div>');
48 + //clear all fields
49 + $('#contactForm').trigger("reset");
50 + },
51 + })
52 + },
53 + filter: function() {
54 + return $(this).is(":visible");
55 + },
56 + });
57 +
58 + $("a[data-toggle=\"tab\"]").click(function(e) {
59 + e.preventDefault();
60 + $(this).tab("show");
61 + });
62 +});
63 +
64 +
65 +/*When clicking on Full hide fail/success boxes */
66 +$('#name').focus(function() {
67 + $('#success').html('');
68 +});
...@@ -3,6 +3,20 @@ ...@@ -3,6 +3,20 @@
3 <head> 3 <head>
4 <title><%= title %></title> 4 <title><%= title %></title>
5 <link rel='stylesheet' href='/stylesheets/style.css' /> 5 <link rel='stylesheet' href='/stylesheets/style.css' />
6 + <<!-- Bootstrap -->
7 + <link rel="stylesheet" type="text/css" href="/stylesheets/bootstrap.css">
8 + <link rel="stylesheet" type="text/css" href="/stylesheets/font-awesome.css">
9 +
10 + <!-- Stylesheet
11 + ================================================== -->
12 + <link rel="stylesheet" type="text/css" href="/stylesheets/style.css">
13 + <link rel="stylesheet" type="text/css" href="/stylesheets/nivo-lightbox/nivo-lightbox.css">
14 + <link rel="stylesheet" type="text/css" href="/stylesheets/nivo-lightbox/default.css">
15 + <link href="https://fonts.googleapis.com/css?family=Raleway:300,400,500,600,700" rel="stylesheet">
16 + <link href="https://fonts.googleapis.com/css?family=Open+Sans:300,400,600,700" rel="stylesheet">
17 + <link href="https://fonts.googleapis.com/css?family=Dancing+Script:400,700" rel="stylesheet">
18 +
19 + <link href="https://fonts.googleapis.com/css?family=Gugi&amp;subset=korean" rel="stylesheet">
6 <script src="http://developers.kakao.com/sdk/js/kakao.min.js"> 20 <script src="http://developers.kakao.com/sdk/js/kakao.min.js">
7 function daum_click() 21 function daum_click()
8 { 22 {
...@@ -13,116 +27,313 @@ ...@@ -13,116 +27,313 @@
13 } 27 }
14 </script> 28 </script>
15 </head> 29 </head>
16 - <h1><%= title %></h1>
17 - <p>웹툰 리스트</p>
18 30
19 - <a href="/auth/login/kakao" class="btn btn-block btn-lg btn-warning btn_login">로그인</a> 31 + <body id="page-top" data-spy="scroll" data-target=".navbar-fixed-top">
32 + <!-- Navigation
33 + ==========================================-->
34 + <nav id="menu" class="navbar navbar-default navbar-fixed-top">
35 + <div class="container">
36 + <!-- Brand and toggle get grouped for better mobile display -->
37 + <div class="navbar-header">
38 + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button>
39 + <a class="navbar-brand page-scroll" href="#page-top">Touché</a> </div>
40 +
41 + <!-- Collect the nav links, forms, and other content for toggling -->
42 + <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
43 + <ul class="nav navbar-nav navbar-right">
44 + <li><a href="#about" class="page-scroll">About</a></li>
45 + <li><a href="#menu" class="page-scroll">Menu</a></li>
46 + <li><a href="#portfolio" class="page-scroll">Gallery</a></li>
47 + <li><a href="/auth/login/kakao" class="page-scroll">Login</a></li>
48 + </ul>
49 + </div>
50 + <!-- /.navbar-collapse -->
51 + </div>
52 + </nav>
53 + <!-- Header -->
54 + <header id="header">
55 + <div class="intro">
56 + <div class="overlay">
57 + <div class="container">
58 + <div class="row">
59 + <div class="intro-text">
60 + <h1>YTMT</h1>
61 + <p>NAVER / DAUM / WEBTOONS</p>
62 + <a href="#about" class="btn btn-custom btn-lg page-scroll">All the Webtoons</a> </div>
63 + </div>
64 + </div>
65 + </div>
66 + </div>
67 + </header>
68 +
69 + <!-- About Section -->
70 + <div id="about">
71 + <div class="container">
72 + <div class="row">
73 + <div class="col-xs-12 col-md-6 ">
74 + <div class="about-img"><img src="img/about.jpg" class="img-responsive" alt=""></div>
75 + </div>
76 + <div class="col-xs-12 col-md-6">
77 + <div class="about-text">
78 + <h2>Our Restaurant</h2>
79 + <hr>
80 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam. Sed commodo nibh ante facilisis bibendum dolor feugiat at. Duis sed dapibus leo nec ornare diam commodo nibh.</p>
81 + <h3>Awarded Chefs</h3>
82 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam. Sed commodo nibh ante facilisis bibendum dolor feugiat at. Duis sed dapibus leo nec ornare.</p>
83 + </div>
84 + </div>
85 + </div>
86 + </div>
87 + </div>
88 + <!-- Portfolio Section -->
89 + <div id="portfolio">
90 + <div class="section-title text-center center">
91 + <div class="overlay">
92 + <h2>Gallery</h2>
93 + <hr>
94 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit duis sed.</p>
95 + </div>
96 + </div>
97 + <div class="container">
98 + <div class="row">
99 + <div class="categories">
100 + <ul class="cat">
101 + <li>
102 + <ol class="type">
103 + <li><a href="#" data-filter="*" class="active">All</a></li>
104 + <li><a href="#" data-filter=".breakfast">Breakfast</a></li>
105 + <li><a href="#" data-filter=".lunch">Lunch</a></li>
106 + <li><a href="#" data-filter=".dinner">Dinner</a></li>
107 + </ol>
108 + </li>
109 + </ul>
110 + <div class="clearfix"></div>
111 + </div>
112 + </div>
113 + <div class="row">
114 + <div class="portfolio-items">
115 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
116 + <div class="portfolio-item">
117 + <div class="hover-bg"> <a href="img/portfolio/01-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
118 + <div class="hover-text">
119 + <h4>Dish Name</h4>
120 + </div>
121 + <img src="img/portfolio/01-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
122 + </div>
123 + </div>
124 + <div class="col-sm-6 col-md-4 col-lg-4 dinner">
125 + <div class="portfolio-item">
126 + <div class="hover-bg"> <a href="img/portfolio/02-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
127 + <div class="hover-text">
128 + <h4>Dish Name</h4>
129 + </div>
130 + <img src="img/portfolio/02-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
131 + </div>
132 + </div>
133 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
134 + <div class="portfolio-item">
135 + <div class="hover-bg"> <a href="img/portfolio/03-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
136 + <div class="hover-text">
137 + <h4>Dish Name</h4>
138 + </div>
139 + <img src="img/portfolio/03-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
140 + </div>
141 + </div>
142 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
143 + <div class="portfolio-item">
144 + <div class="hover-bg"> <a href="img/portfolio/04-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
145 + <div class="hover-text">
146 + <h4>Dish Name</h4>
147 + </div>
148 + <img src="img/portfolio/04-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
149 + </div>
150 + </div>
151 + <div class="col-sm-6 col-md-4 col-lg-4 dinner">
152 + <div class="portfolio-item">
153 + <div class="hover-bg"> <a href="img/portfolio/05-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
154 + <div class="hover-text">
155 + <h4>Dish Name</h4>
156 + </div>
157 + <img src="img/portfolio/05-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
158 + </div>
159 + </div>
160 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
161 + <div class="portfolio-item">
162 + <div class="hover-bg"> <a href="img/portfolio/06-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
163 + <div class="hover-text">
164 + <h4>Dish Name</h4>
165 + </div>
166 + <img src="img/portfolio/06-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
167 + </div>
168 + </div>
169 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
170 + <div class="portfolio-item">
171 + <div class="hover-bg"> <a href="img/portfolio/07-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
172 + <div class="hover-text">
173 + <h4>Dish Name</h4>
174 + </div>
175 + <img src="img/portfolio/07-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
176 + </div>
177 + </div>
178 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
179 + <div class="portfolio-item">
180 + <div class="hover-bg"> <a href="img/portfolio/08-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
181 + <div class="hover-text">
182 + <h4>Dish Name</h4>
183 + </div>
184 + <img src="img/portfolio/08-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
185 + </div>
186 + </div>
187 + <div class="col-sm-6 col-md-4 col-lg-4 dinner">
188 + <div class="portfolio-item">
189 + <div class="hover-bg"> <a href="img/portfolio/09-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
190 + <div class="hover-text">
191 + <h4>Dish Name</h4>
192 + </div>
193 + <img src="img/portfolio/09-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
194 + </div>
195 + </div>
196 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
197 + <div class="portfolio-item">
198 + <div class="hover-bg"> <a href="img/portfolio/10-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
199 + <div class="hover-text">
200 + <h4>Dish Name</h4>
201 + </div>
202 + <img src="img/portfolio/10-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
203 + </div>
204 + </div>
205 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
206 + <div class="portfolio-item">
207 + <div class="hover-bg"> <a href="img/portfolio/11-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
208 + <div class="hover-text">
209 + <h4>Dish Name</h4>
210 + </div>
211 + <img src="img/portfolio/11-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
212 + </div>
213 + </div>
214 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
215 + <div class="portfolio-item">
216 + <div class="hover-bg"> <a href="img/portfolio/12-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
217 + <div class="hover-text">
218 + <h4>Dish Name</h4>
219 + </div>
220 + <img src="img/portfolio/12-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
221 + </div>
222 + </div>
223 + </div>
224 + </div>
225 + </div>
226 + </div>
227 +
228 + <h1><%= title %></h1>
229 + <p>웹툰 리스트</p>
230 +
231 +
20 232
21 - <br> 233 + <br>
22 - <br> 234 + <br>
23 - <br> 235 + <br>
24 - <br> 236 + <br>
25 - <font size = 60> 237 + <font size = 60>
26 다음 웹툰 238 다음 웹툰
27 - </font> 239 + </font>
28 - 240 +
29 - 241 +
30 - <a onclick="Daum_webtoons.style.display=(Daum_webtoons.style.display=='none')?'block':'none';" href="javascript:void(0)"> 242 + <a onclick="Daum_webtoons.style.display=(Daum_webtoons.style.display=='none')?'block':'none';" href="javascript:void(0)">
31 - <img src ='/images/daumicon.png' width="83" height="90" onclick="daum_click" /> 243 + <img src ='/images/daumicon.png' width="83" height="90" onclick="daum_click" />
32 -</a> 244 + </a>
33 -<div style="display:none" id="Daum_webtoons"> 245 + <div style="display:none" id="Daum_webtoons">
34 - <table> 246 + <table>
35 - <% 247 + <%
36 - var current = ""; 248 + var current = "";
37 - for(webtoon in list){ 249 + for(webtoon in list){
38 - 250 +
39 - if(current!=list[webtoon].week && list[webtoon].site == 'daum'){ 251 + if(current!=list[webtoon].week && list[webtoon].site == 'daum'){
40 - if(current!=""){ 252 + if(current!=""){
41 - %>
42 - </tr>
43 - <% } %>
44 - <tr>
45 - <th><%= list[webtoon].week %></th>
46 - <% } %>
47 - <%
48 - if(list[webtoon].site == 'daum')
49 - {
50 - %>
51 - <td>
52 - <a href="<%= list[webtoon].webtoon_link %>">
53 - <img alt="img" width="83" height="90" src="<%= list[webtoon].thum_link %>"/>
54 - </a>
55 - <%= list[webtoon].name %>
56 - </td>
57 - <%
58 - }
59 %> 253 %>
254 + </tr>
255 + <% } %>
256 + <tr>
257 + <th><%= list[webtoon].week %></th>
258 + <% } %>
259 + <%
260 + if(list[webtoon].site == 'daum')
261 + {
262 + %>
263 + <td>
264 + <a href="<%= list[webtoon].webtoon_link %>">
265 + <img alt="img" width="83" height="90" src="<%= list[webtoon].thum_link %>"/>
266 + </a>
267 + <%= list[webtoon].name %>
268 + </td>
269 + <%
270 + }
271 + %>
272 +
273 + <%
274 + if(current!=list[webtoon].week) {
275 + current = list[webtoon].week;
276 + %>
60 277
61 - <% 278 + <%
62 - if(current!=list[webtoon].week) { 279 + }
63 - current = list[webtoon].week; 280 + }
64 - %> 281 + %>
65 - 282 + </tr>
66 - <% 283 + </table>
67 - } 284 + </br>
68 - }
69 - %>
70 - </tr>
71 - </table>
72 - </br>
73 </div> 285 </div>
74 -<br> 286 + <br>
75 287
76 <font size = 60> 288 <font size = 60>
77 - 네이버 웹툰 289 + 네이버 웹툰
78 </font> 290 </font>
79 - <a onclick="Naver_webtoons.style.display=(Naver_webtoons.style.display=='none')?'block':'none';" href="javascript:void(0)"> 291 + <a onclick="Naver_webtoons.style.display=(Naver_webtoons.style.display=='none')?'block':'none';" href="javascript:void(0)">
80 - <img src ='/images/navericon.png' width="83" height="90"/> 292 + <img src ='/images/navericon.png' width="83" height="90"/>
81 </a> 293 </a>
82 <div id="Naver_webtoons" style = "display:none"> 294 <div id="Naver_webtoons" style = "display:none">
83 295
84 <table> 296 <table>
85 - <% 297 + <%
86 - var current = ""; 298 + var current = "";
87 - for(webtoon in list){ 299 + for(webtoon in list){
88 300
89 if(current!=list[webtoon].week && list[webtoon].site == 'naver'){ 301 if(current!=list[webtoon].week && list[webtoon].site == 'naver'){
90 - if(current!=""){ 302 + if(current!=""){
91 %> 303 %>
92 - </tr> 304 + </tr>
93 <% } %> 305 <% } %>
94 <tr> 306 <tr>
95 <th><%= list[webtoon].week %></th> 307 <th><%= list[webtoon].week %></th>
96 - <% } %> 308 + <% } %>
97 - <% 309 + <%
98 - if(list[webtoon].site == 'naver') 310 + if(list[webtoon].site == 'naver')
99 - { 311 + {
100 - %> 312 + %>
101 - <td> 313 + <td>
102 - <a href="<%= list[webtoon].webtoon_link %>"> 314 + <a href="<%= list[webtoon].webtoon_link %>">
103 - <img alt="img" width="83" height="90" src="<%= list[webtoon].thum_link %>"/> 315 + <img alt="img" width="83" height="90" src="<%= list[webtoon].thum_link %>"/>
104 - </a> 316 + </a>
105 - <%= list[webtoon].name %> 317 + <%= list[webtoon].name %>
106 - </td> 318 + </td>
107 <% 319 <%
108 - } 320 + }
109 - %> 321 + %>
110 322
111 - <% 323 + <%
112 - if(current!=list[webtoon].week) { 324 + if(current!=list[webtoon].week) {
113 - current = list[webtoon].week; 325 + current = list[webtoon].week;
114 %> 326 %>
115 327
116 - <% 328 + <%
117 - } 329 + }
118 - } 330 + }
119 - %> 331 + %>
120 </tr> 332 </tr>
121 </table> 333 </table>
122 </br> 334 </br>
123 335
124 - </div> 336 + </div>
125 -
126 </body> 337 </body>
127 338
128 </html> 339 </html>
......
1 +<!DOCTYPE html>
2 +<html lang="en">
3 +<head>
4 +<meta charset="utf-8">
5 +<meta name="viewport" content="width=device-width, initial-scale=1">
6 +<title>Touché</title>
7 +<meta name="description" content="">
8 +<meta name="author" content="">
9 +
10 +<!-- Favicons
11 + ================================================== -->
12 +<link rel="shortcut icon" href="img/favicon.ico" type="image/x-icon">
13 +<link rel="apple-touch-icon" href="img/apple-touch-icon.png">
14 +<link rel="apple-touch-icon" sizes="72x72" href="img/apple-touch-icon-72x72.png">
15 +<link rel="apple-touch-icon" sizes="114x114" href="img/apple-touch-icon-114x114.png">
16 +
17 +<!-- Bootstrap -->
18 +<link rel="stylesheet" type="text/css" href="css/bootstrap.css">
19 +<link rel="stylesheet" type="text/css" href="fonts/font-awesome/css/font-awesome.css">
20 +
21 +<!-- Stylesheet
22 + ================================================== -->
23 +<link rel="stylesheet" type="text/css" href="css/style.css">
24 +<link rel="stylesheet" type="text/css" href="css/nivo-lightbox/nivo-lightbox.css">
25 +<link rel="stylesheet" type="text/css" href="css/nivo-lightbox/default.css">
26 +<link href="https://fonts.googleapis.com/css?family=Raleway:300,400,500,600,700" rel="stylesheet">
27 +<link href="https://fonts.googleapis.com/css?family=Open+Sans:300,400,600,700" rel="stylesheet">
28 +<link href="https://fonts.googleapis.com/css?family=Dancing+Script:400,700" rel="stylesheet">
29 +
30 +<!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
31 +<!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
32 +<!--[if lt IE 9]>
33 + <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
34 + <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
35 + <![endif]-->
36 +</head>
37 +<body id="page-top" data-spy="scroll" data-target=".navbar-fixed-top">
38 +<!-- Navigation
39 + ==========================================-->
40 +<nav id="menu" class="navbar navbar-default navbar-fixed-top">
41 + <div class="container">
42 + <!-- Brand and toggle get grouped for better mobile display -->
43 + <div class="navbar-header">
44 + <button type="button" class="navbar-toggle collapsed" data-toggle="collapse" data-target="#bs-example-navbar-collapse-1"> <span class="sr-only">Toggle navigation</span> <span class="icon-bar"></span> <span class="icon-bar"></span> <span class="icon-bar"></span> </button>
45 + <a class="navbar-brand page-scroll" href="#page-top">Touché</a> </div>
46 +
47 + <!-- Collect the nav links, forms, and other content for toggling -->
48 + <div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
49 + <ul class="nav navbar-nav navbar-right">
50 + <li><a href="#about" class="page-scroll">About</a></li>
51 + <li><a href="#restaurant-menu" class="page-scroll">Menu</a></li>
52 + <li><a href="#portfolio" class="page-scroll">Gallery</a></li>
53 + <li><a href="#team" class="page-scroll">Chefs</a></li>
54 + <li><a href="#call-reservation" class="page-scroll">Contact</a></li>
55 + </ul>
56 + </div>
57 + <!-- /.navbar-collapse -->
58 + </div>
59 +</nav>
60 +<!-- Header -->
61 +<header id="header">
62 + <div class="intro">
63 + <div class="overlay">
64 + <div class="container">
65 + <div class="row">
66 + <div class="intro-text">
67 + <h1>Touché</h1>
68 + <p>Restaurant / Coffee / Pub</p>
69 + <a href="#about" class="btn btn-custom btn-lg page-scroll">Discover Story</a> </div>
70 + </div>
71 + </div>
72 + </div>
73 + </div>
74 +</header>
75 +<!-- About Section -->
76 +<div id="about">
77 + <div class="container">
78 + <div class="row">
79 + <div class="col-xs-12 col-md-6 ">
80 + <div class="about-img"><img src="img/about.jpg" class="img-responsive" alt=""></div>
81 + </div>
82 + <div class="col-xs-12 col-md-6">
83 + <div class="about-text">
84 + <h2>Our Restaurant</h2>
85 + <hr>
86 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam. Sed commodo nibh ante facilisis bibendum dolor feugiat at. Duis sed dapibus leo nec ornare diam commodo nibh.</p>
87 + <h3>Awarded Chefs</h3>
88 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam. Sed commodo nibh ante facilisis bibendum dolor feugiat at. Duis sed dapibus leo nec ornare.</p>
89 + </div>
90 + </div>
91 + </div>
92 + </div>
93 +</div>
94 +<!-- Restaurant Menu Section -->
95 +<div id="restaurant-menu">
96 + <div class="section-title text-center center">
97 + <div class="overlay">
98 + <h2>Menu</h2>
99 + <hr>
100 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit duis sed.</p>
101 + </div>
102 + </div>
103 + <div class="container">
104 + <div class="row">
105 + <div class="col-xs-12 col-sm-6">
106 + <div class="menu-section">
107 + <h2 class="menu-section-title">Breakfast & Starters</h2>
108 + <hr>
109 + <div class="menu-item">
110 + <div class="menu-item-name"> Delicious Dish </div>
111 + <div class="menu-item-price"> $35 </div>
112 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
113 + </div>
114 + <div class="menu-item">
115 + <div class="menu-item-name"> Delicious Dish </div>
116 + <div class="menu-item-price"> $30 </div>
117 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
118 + </div>
119 + <div class="menu-item">
120 + <div class="menu-item-name"> Delicious Dish </div>
121 + <div class="menu-item-price"> $30 </div>
122 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
123 + </div>
124 + <div class="menu-item">
125 + <div class="menu-item-name"> Delicious Dish </div>
126 + <div class="menu-item-price"> $30 </div>
127 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
128 + </div>
129 + </div>
130 + </div>
131 + <div class="col-xs-12 col-sm-6">
132 + <div class="menu-section">
133 + <h2 class="menu-section-title">Main Course</h2>
134 + <hr>
135 + <div class="menu-item">
136 + <div class="menu-item-name"> Delicious Dish </div>
137 + <div class="menu-item-price"> $45 </div>
138 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
139 + </div>
140 + <div class="menu-item">
141 + <div class="menu-item-name"> Delicious Dish </div>
142 + <div class="menu-item-price"> $30 </div>
143 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
144 + </div>
145 + <div class="menu-item">
146 + <div class="menu-item-name"> Delicious Dish </div>
147 + <div class="menu-item-price"> $30 </div>
148 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
149 + </div>
150 + <div class="menu-item">
151 + <div class="menu-item-name"> Delicious Dish </div>
152 + <div class="menu-item-price"> $30 </div>
153 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
154 + </div>
155 + </div>
156 + </div>
157 + </div>
158 + <div class="row">
159 + <div class="col-xs-12 col-sm-6">
160 + <div class="menu-section">
161 + <h2 class="menu-section-title">Dinner</h2>
162 + <hr>
163 + <div class="menu-item">
164 + <div class="menu-item-name"> Delicious Dish </div>
165 + <div class="menu-item-price"> $45 </div>
166 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
167 + </div>
168 + <div class="menu-item">
169 + <div class="menu-item-name"> Delicious Dish </div>
170 + <div class="menu-item-price"> $350 </div>
171 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
172 + </div>
173 + <div class="menu-item">
174 + <div class="menu-item-name"> Delicious Dish </div>
175 + <div class="menu-item-price"> $30 </div>
176 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam.. </div>
177 + </div>
178 + <div class="menu-item">
179 + <div class="menu-item-name"> Delicious Dish </div>
180 + <div class="menu-item-price"> $30 </div>
181 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
182 + </div>
183 + </div>
184 + </div>
185 + <div class="col-xs-12 col-sm-6">
186 + <div class="menu-section">
187 + <h2 class="menu-section-title">Coffee & Drinks</h2>
188 + <hr>
189 + <div class="menu-item">
190 + <div class="menu-item-name"> Delicious Dish </div>
191 + <div class="menu-item-price"> $35 </div>
192 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
193 + </div>
194 + <div class="menu-item">
195 + <div class="menu-item-name"> Delicious Dish </div>
196 + <div class="menu-item-price"> $30 </div>
197 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
198 + </div>
199 + <div class="menu-item">
200 + <div class="menu-item-name"> Delicious Dish </div>
201 + <div class="menu-item-price"> $30 </div>
202 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
203 + </div>
204 + <div class="menu-item">
205 + <div class="menu-item-name"> Delicious Dish </div>
206 + <div class="menu-item-price"> $30 </div>
207 + <div class="menu-item-description"> Lorem ipsum dolor sit amet, consectetur adipiscing elit, duis sed dapibus leo nec ornare diam. </div>
208 + </div>
209 + </div>
210 + </div>
211 + </div>
212 + </div>
213 +</div>
214 +<!-- Portfolio Section -->
215 +<div id="portfolio">
216 + <div class="section-title text-center center">
217 + <div class="overlay">
218 + <h2>Gallery</h2>
219 + <hr>
220 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit duis sed.</p>
221 + </div>
222 + </div>
223 + <div class="container">
224 + <div class="row">
225 + <div class="categories">
226 + <ul class="cat">
227 + <li>
228 + <ol class="type">
229 + <li><a href="#" data-filter="*" class="active">All</a></li>
230 + <li><a href="#" data-filter=".breakfast">Breakfast</a></li>
231 + <li><a href="#" data-filter=".lunch">Lunch</a></li>
232 + <li><a href="#" data-filter=".dinner">Dinner</a></li>
233 + </ol>
234 + </li>
235 + </ul>
236 + <div class="clearfix"></div>
237 + </div>
238 + </div>
239 + <div class="row">
240 + <div class="portfolio-items">
241 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
242 + <div class="portfolio-item">
243 + <div class="hover-bg"> <a href="img/portfolio/01-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
244 + <div class="hover-text">
245 + <h4>Dish Name</h4>
246 + </div>
247 + <img src="img/portfolio/01-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
248 + </div>
249 + </div>
250 + <div class="col-sm-6 col-md-4 col-lg-4 dinner">
251 + <div class="portfolio-item">
252 + <div class="hover-bg"> <a href="img/portfolio/02-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
253 + <div class="hover-text">
254 + <h4>Dish Name</h4>
255 + </div>
256 + <img src="img/portfolio/02-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
257 + </div>
258 + </div>
259 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
260 + <div class="portfolio-item">
261 + <div class="hover-bg"> <a href="img/portfolio/03-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
262 + <div class="hover-text">
263 + <h4>Dish Name</h4>
264 + </div>
265 + <img src="img/portfolio/03-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
266 + </div>
267 + </div>
268 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
269 + <div class="portfolio-item">
270 + <div class="hover-bg"> <a href="img/portfolio/04-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
271 + <div class="hover-text">
272 + <h4>Dish Name</h4>
273 + </div>
274 + <img src="img/portfolio/04-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
275 + </div>
276 + </div>
277 + <div class="col-sm-6 col-md-4 col-lg-4 dinner">
278 + <div class="portfolio-item">
279 + <div class="hover-bg"> <a href="img/portfolio/05-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
280 + <div class="hover-text">
281 + <h4>Dish Name</h4>
282 + </div>
283 + <img src="img/portfolio/05-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
284 + </div>
285 + </div>
286 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
287 + <div class="portfolio-item">
288 + <div class="hover-bg"> <a href="img/portfolio/06-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
289 + <div class="hover-text">
290 + <h4>Dish Name</h4>
291 + </div>
292 + <img src="img/portfolio/06-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
293 + </div>
294 + </div>
295 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
296 + <div class="portfolio-item">
297 + <div class="hover-bg"> <a href="img/portfolio/07-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
298 + <div class="hover-text">
299 + <h4>Dish Name</h4>
300 + </div>
301 + <img src="img/portfolio/07-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
302 + </div>
303 + </div>
304 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
305 + <div class="portfolio-item">
306 + <div class="hover-bg"> <a href="img/portfolio/08-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
307 + <div class="hover-text">
308 + <h4>Dish Name</h4>
309 + </div>
310 + <img src="img/portfolio/08-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
311 + </div>
312 + </div>
313 + <div class="col-sm-6 col-md-4 col-lg-4 dinner">
314 + <div class="portfolio-item">
315 + <div class="hover-bg"> <a href="img/portfolio/09-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
316 + <div class="hover-text">
317 + <h4>Dish Name</h4>
318 + </div>
319 + <img src="img/portfolio/09-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
320 + </div>
321 + </div>
322 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
323 + <div class="portfolio-item">
324 + <div class="hover-bg"> <a href="img/portfolio/10-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
325 + <div class="hover-text">
326 + <h4>Dish Name</h4>
327 + </div>
328 + <img src="img/portfolio/10-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
329 + </div>
330 + </div>
331 + <div class="col-sm-6 col-md-4 col-lg-4 lunch">
332 + <div class="portfolio-item">
333 + <div class="hover-bg"> <a href="img/portfolio/11-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
334 + <div class="hover-text">
335 + <h4>Dish Name</h4>
336 + </div>
337 + <img src="img/portfolio/11-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
338 + </div>
339 + </div>
340 + <div class="col-sm-6 col-md-4 col-lg-4 breakfast">
341 + <div class="portfolio-item">
342 + <div class="hover-bg"> <a href="img/portfolio/12-large.jpg" title="Dish Name" data-lightbox-gallery="gallery1">
343 + <div class="hover-text">
344 + <h4>Dish Name</h4>
345 + </div>
346 + <img src="img/portfolio/12-small.jpg" class="img-responsive" alt="Project Title"> </a> </div>
347 + </div>
348 + </div>
349 + </div>
350 + </div>
351 + </div>
352 +</div>
353 +<!-- Team Section -->
354 +<div id="team" class="text-center">
355 + <div class="overlay">
356 + <div class="container">
357 + <div class="col-md-10 col-md-offset-1 section-title">
358 + <h2>Meet Our Chefs</h2>
359 + <hr>
360 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit duis sed dapibus leonec.</p>
361 + </div>
362 + <div id="row">
363 + <div class="col-md-4 team">
364 + <div class="thumbnail">
365 + <div class="team-img"><img src="img/team/01.jpg" alt="..."></div>
366 + <div class="caption">
367 + <h3>Mike Doe</h3>
368 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam.</p>
369 + </div>
370 + </div>
371 + </div>
372 + <div class="col-md-4 team">
373 + <div class="thumbnail">
374 + <div class="team-img"><img src="img/team/02.jpg" alt="..."></div>
375 + <div class="caption">
376 + <h3>Chris Doe</h3>
377 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam.</p>
378 + </div>
379 + </div>
380 + </div>
381 + <div class="col-md-4 team">
382 + <div class="thumbnail">
383 + <div class="team-img"><img src="img/team/03.jpg" alt="..."></div>
384 + <div class="caption">
385 + <h3>Ethan Doe</h3>
386 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit. Duis sed dapibus leo nec ornare diam.</p>
387 + </div>
388 + </div>
389 + </div>
390 + </div>
391 + </div>
392 + </div>
393 +</div>
394 +<!-- Call Reservation Section -->
395 +<div id="call-reservation" class="text-center">
396 + <div class="container">
397 + <h2>Want to make a reservation? Call <strong>1-887-654-3210</strong></h2>
398 + </div>
399 +</div>
400 +<!-- Contact Section -->
401 +<div id="contact" class="text-center">
402 + <div class="container">
403 + <div class="section-title text-center">
404 + <h2>Contact Form</h2>
405 + <hr>
406 + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit duis sed.</p>
407 + </div>
408 + <div class="col-md-10 col-md-offset-1">
409 + <form name="sentMessage" id="contactForm" novalidate>
410 + <div class="row">
411 + <div class="col-md-6">
412 + <div class="form-group">
413 + <input type="text" id="name" class="form-control" placeholder="Name" required="required">
414 + <p class="help-block text-danger"></p>
415 + </div>
416 + </div>
417 + <div class="col-md-6">
418 + <div class="form-group">
419 + <input type="email" id="email" class="form-control" placeholder="Email" required="required">
420 + <p class="help-block text-danger"></p>
421 + </div>
422 + </div>
423 + </div>
424 + <div class="form-group">
425 + <textarea name="message" id="message" class="form-control" rows="4" placeholder="Message" required></textarea>
426 + <p class="help-block text-danger"></p>
427 + </div>
428 + <div id="success"></div>
429 + <button type="submit" class="btn btn-custom btn-lg">Send Message</button>
430 + </form>
431 + </div>
432 + </div>
433 +</div>
434 +<div id="footer">
435 + <div class="container text-center">
436 + <div class="col-md-4">
437 + <h3>Address</h3>
438 + <div class="contact-item">
439 + <p>4321 California St,</p>
440 + <p>San Francisco, CA 12345</p>
441 + </div>
442 + </div>
443 + <div class="col-md-4">
444 + <h3>Opening Hours</h3>
445 + <div class="contact-item">
446 + <p>Mon-Thurs: 10:00 AM - 11:00 PM</p>
447 + <p>Fri-Sun: 11:00 AM - 02:00 AM</p>
448 + </div>
449 + </div>
450 + <div class="col-md-4">
451 + <h3>Contact Info</h3>
452 + <div class="contact-item">
453 + <p>Phone: +1 123 456 1234</p>
454 + <p>Email: info@company.com</p>
455 + </div>
456 + </div>
457 + </div>
458 + <div class="container-fluid text-center copyrights">
459 + <div class="col-md-8 col-md-offset-2">
460 + <div class="social">
461 + <ul>
462 + <li><a href="#"><i class="fa fa-facebook"></i></a></li>
463 + <li><a href="#"><i class="fa fa-twitter"></i></a></li>
464 + <li><a href="#"><i class="fa fa-google-plus"></i></a></li>
465 + </ul>
466 + </div>
467 + <p>&copy; 2016 Touché. All rights reserved. Designed by <a href="http://www.templatewire.com" rel="nofollow">TemplateWire</a></p>
468 + </div>
469 + </div>
470 +</div>
471 +<script type="text/javascript" src="js/jquery.1.11.1.js"></script>
472 +<script type="text/javascript" src="js/bootstrap.js"></script>
473 +<script type="text/javascript" src="js/SmoothScroll.js"></script>
474 +<script type="text/javascript" src="js/nivo-lightbox.js"></script>
475 +<script type="text/javascript" src="js/jquery.isotope.js"></script>
476 +<script type="text/javascript" src="js/jqBootstrapValidation.js"></script>
477 +<script type="text/javascript" src="js/contact_me.js"></script>
478 +<script type="text/javascript" src="js/main.js"></script>
479 +</body>
480 +</html>
1 +/* jqBootstrapValidation
2 + * A plugin for automating validation on Twitter Bootstrap formatted forms.
3 + *
4 + * v1.3.6
5 + *
6 + * License: MIT <http://opensource.org/licenses/mit-license.php> - see LICENSE file
7 + *
8 + * http://ReactiveRaven.github.com/jqBootstrapValidation/
9 + */
10 +
11 +(function( $ ){
12 +
13 + var createdElements = [];
14 +
15 + var defaults = {
16 + options: {
17 + prependExistingHelpBlock: false,
18 + sniffHtml: true, // sniff for 'required', 'maxlength', etc
19 + preventSubmit: true, // stop the form submit event from firing if validation fails
20 + submitError: false, // function called if there is an error when trying to submit
21 + submitSuccess: false, // function called just before a successful submit event is sent to the server
22 + semanticallyStrict: false, // set to true to tidy up generated HTML output
23 + autoAdd: {
24 + helpBlocks: true
25 + },
26 + filter: function () {
27 + // return $(this).is(":visible"); // only validate elements you can see
28 + return true; // validate everything
29 + }
30 + },
31 + methods: {
32 + init : function( options ) {
33 +
34 + var settings = $.extend(true, {}, defaults);
35 +
36 + settings.options = $.extend(true, settings.options, options);
37 +
38 + var $siblingElements = this;
39 +
40 + var uniqueForms = $.unique(
41 + $siblingElements.map( function () {
42 + return $(this).parents("form")[0];
43 + }).toArray()
44 + );
45 +
46 + $(uniqueForms).bind("submit", function (e) {
47 + var $form = $(this);
48 + var warningsFound = 0;
49 + var $inputs = $form.find("input,textarea,select").not("[type=submit],[type=image]").filter(settings.options.filter);
50 + $inputs.trigger("submit.validation").trigger("validationLostFocus.validation");
51 +
52 + $inputs.each(function (i, el) {
53 + var $this = $(el),
54 + $controlGroup = $this.parents(".form-group").first();
55 + if (
56 + $controlGroup.hasClass("warning")
57 + ) {
58 + $controlGroup.removeClass("warning").addClass("error");
59 + warningsFound++;
60 + }
61 + });
62 +
63 + $inputs.trigger("validationLostFocus.validation");
64 +
65 + if (warningsFound) {
66 + if (settings.options.preventSubmit) {
67 + e.preventDefault();
68 + }
69 + $form.addClass("error");
70 + if ($.isFunction(settings.options.submitError)) {
71 + settings.options.submitError($form, e, $inputs.jqBootstrapValidation("collectErrors", true));
72 + }
73 + } else {
74 + $form.removeClass("error");
75 + if ($.isFunction(settings.options.submitSuccess)) {
76 + settings.options.submitSuccess($form, e);
77 + }
78 + }
79 + });
80 +
81 + return this.each(function(){
82 +
83 + // Get references to everything we're interested in
84 + var $this = $(this),
85 + $controlGroup = $this.parents(".form-group").first(),
86 + $helpBlock = $controlGroup.find(".help-block").first(),
87 + $form = $this.parents("form").first(),
88 + validatorNames = [];
89 +
90 + // create message container if not exists
91 + if (!$helpBlock.length && settings.options.autoAdd && settings.options.autoAdd.helpBlocks) {
92 + $helpBlock = $('<div class="help-block" />');
93 + $controlGroup.find('.controls').append($helpBlock);
94 + createdElements.push($helpBlock[0]);
95 + }
96 +
97 + // =============================================================
98 + // SNIFF HTML FOR VALIDATORS
99 + // =============================================================
100 +
101 + // *snort sniff snuffle*
102 +
103 + if (settings.options.sniffHtml) {
104 + var message = "";
105 + // ---------------------------------------------------------
106 + // PATTERN
107 + // ---------------------------------------------------------
108 + if ($this.attr("pattern") !== undefined) {
109 + message = "Not in the expected format<!-- data-validation-pattern-message to override -->";
110 + if ($this.data("validationPatternMessage")) {
111 + message = $this.data("validationPatternMessage");
112 + }
113 + $this.data("validationPatternMessage", message);
114 + $this.data("validationPatternRegex", $this.attr("pattern"));
115 + }
116 + // ---------------------------------------------------------
117 + // MAX
118 + // ---------------------------------------------------------
119 + if ($this.attr("max") !== undefined || $this.attr("aria-valuemax") !== undefined) {
120 + var max = ($this.attr("max") !== undefined ? $this.attr("max") : $this.attr("aria-valuemax"));
121 + message = "Too high: Maximum of '" + max + "'<!-- data-validation-max-message to override -->";
122 + if ($this.data("validationMaxMessage")) {
123 + message = $this.data("validationMaxMessage");
124 + }
125 + $this.data("validationMaxMessage", message);
126 + $this.data("validationMaxMax", max);
127 + }
128 + // ---------------------------------------------------------
129 + // MIN
130 + // ---------------------------------------------------------
131 + if ($this.attr("min") !== undefined || $this.attr("aria-valuemin") !== undefined) {
132 + var min = ($this.attr("min") !== undefined ? $this.attr("min") : $this.attr("aria-valuemin"));
133 + message = "Too low: Minimum of '" + min + "'<!-- data-validation-min-message to override -->";
134 + if ($this.data("validationMinMessage")) {
135 + message = $this.data("validationMinMessage");
136 + }
137 + $this.data("validationMinMessage", message);
138 + $this.data("validationMinMin", min);
139 + }
140 + // ---------------------------------------------------------
141 + // MAXLENGTH
142 + // ---------------------------------------------------------
143 + if ($this.attr("maxlength") !== undefined) {
144 + message = "Too long: Maximum of '" + $this.attr("maxlength") + "' characters<!-- data-validation-maxlength-message to override -->";
145 + if ($this.data("validationMaxlengthMessage")) {
146 + message = $this.data("validationMaxlengthMessage");
147 + }
148 + $this.data("validationMaxlengthMessage", message);
149 + $this.data("validationMaxlengthMaxlength", $this.attr("maxlength"));
150 + }
151 + // ---------------------------------------------------------
152 + // MINLENGTH
153 + // ---------------------------------------------------------
154 + if ($this.attr("minlength") !== undefined) {
155 + message = "Too short: Minimum of '" + $this.attr("minlength") + "' characters<!-- data-validation-minlength-message to override -->";
156 + if ($this.data("validationMinlengthMessage")) {
157 + message = $this.data("validationMinlengthMessage");
158 + }
159 + $this.data("validationMinlengthMessage", message);
160 + $this.data("validationMinlengthMinlength", $this.attr("minlength"));
161 + }
162 + // ---------------------------------------------------------
163 + // REQUIRED
164 + // ---------------------------------------------------------
165 + if ($this.attr("required") !== undefined || $this.attr("aria-required") !== undefined) {
166 + message = settings.builtInValidators.required.message;
167 + if ($this.data("validationRequiredMessage")) {
168 + message = $this.data("validationRequiredMessage");
169 + }
170 + $this.data("validationRequiredMessage", message);
171 + }
172 + // ---------------------------------------------------------
173 + // NUMBER
174 + // ---------------------------------------------------------
175 + if ($this.attr("type") !== undefined && $this.attr("type").toLowerCase() === "number") {
176 + message = settings.builtInValidators.number.message;
177 + if ($this.data("validationNumberMessage")) {
178 + message = $this.data("validationNumberMessage");
179 + }
180 + $this.data("validationNumberMessage", message);
181 + }
182 + // ---------------------------------------------------------
183 + // EMAIL
184 + // ---------------------------------------------------------
185 + if ($this.attr("type") !== undefined && $this.attr("type").toLowerCase() === "email") {
186 + message = "Not a valid email address<!-- data-validator-validemail-message to override -->";
187 + if ($this.data("validationValidemailMessage")) {
188 + message = $this.data("validationValidemailMessage");
189 + } else if ($this.data("validationEmailMessage")) {
190 + message = $this.data("validationEmailMessage");
191 + }
192 + $this.data("validationValidemailMessage", message);
193 + }
194 + // ---------------------------------------------------------
195 + // MINCHECKED
196 + // ---------------------------------------------------------
197 + if ($this.attr("minchecked") !== undefined) {
198 + message = "Not enough options checked; Minimum of '" + $this.attr("minchecked") + "' required<!-- data-validation-minchecked-message to override -->";
199 + if ($this.data("validationMincheckedMessage")) {
200 + message = $this.data("validationMincheckedMessage");
201 + }
202 + $this.data("validationMincheckedMessage", message);
203 + $this.data("validationMincheckedMinchecked", $this.attr("minchecked"));
204 + }
205 + // ---------------------------------------------------------
206 + // MAXCHECKED
207 + // ---------------------------------------------------------
208 + if ($this.attr("maxchecked") !== undefined) {
209 + message = "Too many options checked; Maximum of '" + $this.attr("maxchecked") + "' required<!-- data-validation-maxchecked-message to override -->";
210 + if ($this.data("validationMaxcheckedMessage")) {
211 + message = $this.data("validationMaxcheckedMessage");
212 + }
213 + $this.data("validationMaxcheckedMessage", message);
214 + $this.data("validationMaxcheckedMaxchecked", $this.attr("maxchecked"));
215 + }
216 + }
217 +
218 + // =============================================================
219 + // COLLECT VALIDATOR NAMES
220 + // =============================================================
221 +
222 + // Get named validators
223 + if ($this.data("validation") !== undefined) {
224 + validatorNames = $this.data("validation").split(",");
225 + }
226 +
227 + // Get extra ones defined on the element's data attributes
228 + $.each($this.data(), function (i, el) {
229 + var parts = i.replace(/([A-Z])/g, ",$1").split(",");
230 + if (parts[0] === "validation" && parts[1]) {
231 + validatorNames.push(parts[1]);
232 + }
233 + });
234 +
235 + // =============================================================
236 + // NORMALISE VALIDATOR NAMES
237 + // =============================================================
238 +
239 + var validatorNamesToInspect = validatorNames;
240 + var newValidatorNamesToInspect = [];
241 +
242 + do // repeatedly expand 'shortcut' validators into their real validators
243 + {
244 + // Uppercase only the first letter of each name
245 + $.each(validatorNames, function (i, el) {
246 + validatorNames[i] = formatValidatorName(el);
247 + });
248 +
249 + // Remove duplicate validator names
250 + validatorNames = $.unique(validatorNames);
251 +
252 + // Pull out the new validator names from each shortcut
253 + newValidatorNamesToInspect = [];
254 + $.each(validatorNamesToInspect, function(i, el) {
255 + if ($this.data("validation" + el + "Shortcut") !== undefined) {
256 + // Are these custom validators?
257 + // Pull them out!
258 + $.each($this.data("validation" + el + "Shortcut").split(","), function(i2, el2) {
259 + newValidatorNamesToInspect.push(el2);
260 + });
261 + } else if (settings.builtInValidators[el.toLowerCase()]) {
262 + // Is this a recognised built-in?
263 + // Pull it out!
264 + var validator = settings.builtInValidators[el.toLowerCase()];
265 + if (validator.type.toLowerCase() === "shortcut") {
266 + $.each(validator.shortcut.split(","), function (i, el) {
267 + el = formatValidatorName(el);
268 + newValidatorNamesToInspect.push(el);
269 + validatorNames.push(el);
270 + });
271 + }
272 + }
273 + });
274 +
275 + validatorNamesToInspect = newValidatorNamesToInspect;
276 +
277 + } while (validatorNamesToInspect.length > 0)
278 +
279 + // =============================================================
280 + // SET UP VALIDATOR ARRAYS
281 + // =============================================================
282 +
283 + var validators = {};
284 +
285 + $.each(validatorNames, function (i, el) {
286 + // Set up the 'override' message
287 + var message = $this.data("validation" + el + "Message");
288 + var hasOverrideMessage = (message !== undefined);
289 + var foundValidator = false;
290 + message =
291 + (
292 + message
293 + ? message
294 + : "'" + el + "' validation failed <!-- Add attribute 'data-validation-" + el.toLowerCase() + "-message' to input to change this message -->"
295 + )
296 + ;
297 +
298 + $.each(
299 + settings.validatorTypes,
300 + function (validatorType, validatorTemplate) {
301 + if (validators[validatorType] === undefined) {
302 + validators[validatorType] = [];
303 + }
304 + if (!foundValidator && $this.data("validation" + el + formatValidatorName(validatorTemplate.name)) !== undefined) {
305 + validators[validatorType].push(
306 + $.extend(
307 + true,
308 + {
309 + name: formatValidatorName(validatorTemplate.name),
310 + message: message
311 + },
312 + validatorTemplate.init($this, el)
313 + )
314 + );
315 + foundValidator = true;
316 + }
317 + }
318 + );
319 +
320 + if (!foundValidator && settings.builtInValidators[el.toLowerCase()]) {
321 +
322 + var validator = $.extend(true, {}, settings.builtInValidators[el.toLowerCase()]);
323 + if (hasOverrideMessage) {
324 + validator.message = message;
325 + }
326 + var validatorType = validator.type.toLowerCase();
327 +
328 + if (validatorType === "shortcut") {
329 + foundValidator = true;
330 + } else {
331 + $.each(
332 + settings.validatorTypes,
333 + function (validatorTemplateType, validatorTemplate) {
334 + if (validators[validatorTemplateType] === undefined) {
335 + validators[validatorTemplateType] = [];
336 + }
337 + if (!foundValidator && validatorType === validatorTemplateType.toLowerCase()) {
338 + $this.data("validation" + el + formatValidatorName(validatorTemplate.name), validator[validatorTemplate.name.toLowerCase()]);
339 + validators[validatorType].push(
340 + $.extend(
341 + validator,
342 + validatorTemplate.init($this, el)
343 + )
344 + );
345 + foundValidator = true;
346 + }
347 + }
348 + );
349 + }
350 + }
351 +
352 + if (! foundValidator) {
353 + $.error("Cannot find validation info for '" + el + "'");
354 + }
355 + });
356 +
357 + // =============================================================
358 + // STORE FALLBACK VALUES
359 + // =============================================================
360 +
361 + $helpBlock.data(
362 + "original-contents",
363 + (
364 + $helpBlock.data("original-contents")
365 + ? $helpBlock.data("original-contents")
366 + : $helpBlock.html()
367 + )
368 + );
369 +
370 + $helpBlock.data(
371 + "original-role",
372 + (
373 + $helpBlock.data("original-role")
374 + ? $helpBlock.data("original-role")
375 + : $helpBlock.attr("role")
376 + )
377 + );
378 +
379 + $controlGroup.data(
380 + "original-classes",
381 + (
382 + $controlGroup.data("original-clases")
383 + ? $controlGroup.data("original-classes")
384 + : $controlGroup.attr("class")
385 + )
386 + );
387 +
388 + $this.data(
389 + "original-aria-invalid",
390 + (
391 + $this.data("original-aria-invalid")
392 + ? $this.data("original-aria-invalid")
393 + : $this.attr("aria-invalid")
394 + )
395 + );
396 +
397 + // =============================================================
398 + // VALIDATION
399 + // =============================================================
400 +
401 + $this.bind(
402 + "validation.validation",
403 + function (event, params) {
404 +
405 + var value = getValue($this);
406 +
407 + // Get a list of the errors to apply
408 + var errorsFound = [];
409 +
410 + $.each(validators, function (validatorType, validatorTypeArray) {
411 + if (value || value.length || (params && params.includeEmpty) || (!!settings.validatorTypes[validatorType].blockSubmit && params && !!params.submitting)) {
412 + $.each(validatorTypeArray, function (i, validator) {
413 + if (settings.validatorTypes[validatorType].validate($this, value, validator)) {
414 + errorsFound.push(validator.message);
415 + }
416 + });
417 + }
418 + });
419 +
420 + return errorsFound;
421 + }
422 + );
423 +
424 + $this.bind(
425 + "getValidators.validation",
426 + function () {
427 + return validators;
428 + }
429 + );
430 +
431 + // =============================================================
432 + // WATCH FOR CHANGES
433 + // =============================================================
434 + $this.bind(
435 + "submit.validation",
436 + function () {
437 + return $this.triggerHandler("change.validation", {submitting: true});
438 + }
439 + );
440 + $this.bind(
441 + [
442 + "keyup",
443 + "focus",
444 + "blur",
445 + "click",
446 + "keydown",
447 + "keypress",
448 + "change"
449 + ].join(".validation ") + ".validation",
450 + function (e, params) {
451 +
452 + var value = getValue($this);
453 +
454 + var errorsFound = [];
455 +
456 + $controlGroup.find("input,textarea,select").each(function (i, el) {
457 + var oldCount = errorsFound.length;
458 + $.each($(el).triggerHandler("validation.validation", params), function (j, message) {
459 + errorsFound.push(message);
460 + });
461 + if (errorsFound.length > oldCount) {
462 + $(el).attr("aria-invalid", "true");
463 + } else {
464 + var original = $this.data("original-aria-invalid");
465 + $(el).attr("aria-invalid", (original !== undefined ? original : false));
466 + }
467 + });
468 +
469 + $form.find("input,select,textarea").not($this).not("[name=\"" + $this.attr("name") + "\"]").trigger("validationLostFocus.validation");
470 +
471 + errorsFound = $.unique(errorsFound.sort());
472 +
473 + // Were there any errors?
474 + if (errorsFound.length) {
475 + // Better flag it up as a warning.
476 + $controlGroup.removeClass("success error").addClass("warning");
477 +
478 + // How many errors did we find?
479 + if (settings.options.semanticallyStrict && errorsFound.length === 1) {
480 + // Only one? Being strict? Just output it.
481 + $helpBlock.html(errorsFound[0] +
482 + ( settings.options.prependExistingHelpBlock ? $helpBlock.data("original-contents") : "" ));
483 + } else {
484 + // Multiple? Being sloppy? Glue them together into an UL.
485 + $helpBlock.html("<ul role=\"alert\"><li>" + errorsFound.join("</li><li>") + "</li></ul>" +
486 + ( settings.options.prependExistingHelpBlock ? $helpBlock.data("original-contents") : "" ));
487 + }
488 + } else {
489 + $controlGroup.removeClass("warning error success");
490 + if (value.length > 0) {
491 + $controlGroup.addClass("success");
492 + }
493 + $helpBlock.html($helpBlock.data("original-contents"));
494 + }
495 +
496 + if (e.type === "blur") {
497 + $controlGroup.removeClass("success");
498 + }
499 + }
500 + );
501 + $this.bind("validationLostFocus.validation", function () {
502 + $controlGroup.removeClass("success");
503 + });
504 + });
505 + },
506 + destroy : function( ) {
507 +
508 + return this.each(
509 + function() {
510 +
511 + var
512 + $this = $(this),
513 + $controlGroup = $this.parents(".form-group").first(),
514 + $helpBlock = $controlGroup.find(".help-block").first();
515 +
516 + // remove our events
517 + $this.unbind('.validation'); // events are namespaced.
518 + // reset help text
519 + $helpBlock.html($helpBlock.data("original-contents"));
520 + // reset classes
521 + $controlGroup.attr("class", $controlGroup.data("original-classes"));
522 + // reset aria
523 + $this.attr("aria-invalid", $this.data("original-aria-invalid"));
524 + // reset role
525 + $helpBlock.attr("role", $this.data("original-role"));
526 + // remove all elements we created
527 + if (createdElements.indexOf($helpBlock[0]) > -1) {
528 + $helpBlock.remove();
529 + }
530 +
531 + }
532 + );
533 +
534 + },
535 + collectErrors : function(includeEmpty) {
536 +
537 + var errorMessages = {};
538 + this.each(function (i, el) {
539 + var $el = $(el);
540 + var name = $el.attr("name");
541 + var errors = $el.triggerHandler("validation.validation", {includeEmpty: true});
542 + errorMessages[name] = $.extend(true, errors, errorMessages[name]);
543 + });
544 +
545 + $.each(errorMessages, function (i, el) {
546 + if (el.length === 0) {
547 + delete errorMessages[i];
548 + }
549 + });
550 +
551 + return errorMessages;
552 +
553 + },
554 + hasErrors: function() {
555 +
556 + var errorMessages = [];
557 +
558 + this.each(function (i, el) {
559 + errorMessages = errorMessages.concat(
560 + $(el).triggerHandler("getValidators.validation") ? $(el).triggerHandler("validation.validation", {submitting: true}) : []
561 + );
562 + });
563 +
564 + return (errorMessages.length > 0);
565 + },
566 + override : function (newDefaults) {
567 + defaults = $.extend(true, defaults, newDefaults);
568 + }
569 + },
570 + validatorTypes: {
571 + callback: {
572 + name: "callback",
573 + init: function ($this, name) {
574 + return {
575 + validatorName: name,
576 + callback: $this.data("validation" + name + "Callback"),
577 + lastValue: $this.val(),
578 + lastValid: true,
579 + lastFinished: true
580 + };
581 + },
582 + validate: function ($this, value, validator) {
583 + if (validator.lastValue === value && validator.lastFinished) {
584 + return !validator.lastValid;
585 + }
586 +
587 + if (validator.lastFinished === true)
588 + {
589 + validator.lastValue = value;
590 + validator.lastValid = true;
591 + validator.lastFinished = false;
592 +
593 + var rrjqbvValidator = validator;
594 + var rrjqbvThis = $this;
595 + executeFunctionByName(
596 + validator.callback,
597 + window,
598 + $this,
599 + value,
600 + function (data) {
601 + if (rrjqbvValidator.lastValue === data.value) {
602 + rrjqbvValidator.lastValid = data.valid;
603 + if (data.message) {
604 + rrjqbvValidator.message = data.message;
605 + }
606 + rrjqbvValidator.lastFinished = true;
607 + rrjqbvThis.data("validation" + rrjqbvValidator.validatorName + "Message", rrjqbvValidator.message);
608 + // Timeout is set to avoid problems with the events being considered 'already fired'
609 + setTimeout(function () {
610 + rrjqbvThis.trigger("change.validation");
611 + }, 1); // doesn't need a long timeout, just long enough for the event bubble to burst
612 + }
613 + }
614 + );
615 + }
616 +
617 + return false;
618 +
619 + }
620 + },
621 + ajax: {
622 + name: "ajax",
623 + init: function ($this, name) {
624 + return {
625 + validatorName: name,
626 + url: $this.data("validation" + name + "Ajax"),
627 + lastValue: $this.val(),
628 + lastValid: true,
629 + lastFinished: true
630 + };
631 + },
632 + validate: function ($this, value, validator) {
633 + if (""+validator.lastValue === ""+value && validator.lastFinished === true) {
634 + return validator.lastValid === false;
635 + }
636 +
637 + if (validator.lastFinished === true)
638 + {
639 + validator.lastValue = value;
640 + validator.lastValid = true;
641 + validator.lastFinished = false;
642 + $.ajax({
643 + url: validator.url,
644 + data: "value=" + value + "&field=" + $this.attr("name"),
645 + dataType: "json",
646 + success: function (data) {
647 + if (""+validator.lastValue === ""+data.value) {
648 + validator.lastValid = !!(data.valid);
649 + if (data.message) {
650 + validator.message = data.message;
651 + }
652 + validator.lastFinished = true;
653 + $this.data("validation" + validator.validatorName + "Message", validator.message);
654 + // Timeout is set to avoid problems with the events being considered 'already fired'
655 + setTimeout(function () {
656 + $this.trigger("change.validation");
657 + }, 1); // doesn't need a long timeout, just long enough for the event bubble to burst
658 + }
659 + },
660 + failure: function () {
661 + validator.lastValid = true;
662 + validator.message = "ajax call failed";
663 + validator.lastFinished = true;
664 + $this.data("validation" + validator.validatorName + "Message", validator.message);
665 + // Timeout is set to avoid problems with the events being considered 'already fired'
666 + setTimeout(function () {
667 + $this.trigger("change.validation");
668 + }, 1); // doesn't need a long timeout, just long enough for the event bubble to burst
669 + }
670 + });
671 + }
672 +
673 + return false;
674 +
675 + }
676 + },
677 + regex: {
678 + name: "regex",
679 + init: function ($this, name) {
680 + return {regex: regexFromString($this.data("validation" + name + "Regex"))};
681 + },
682 + validate: function ($this, value, validator) {
683 + return (!validator.regex.test(value) && ! validator.negative)
684 + || (validator.regex.test(value) && validator.negative);
685 + }
686 + },
687 + required: {
688 + name: "required",
689 + init: function ($this, name) {
690 + return {};
691 + },
692 + validate: function ($this, value, validator) {
693 + return !!(value.length === 0 && ! validator.negative)
694 + || !!(value.length > 0 && validator.negative);
695 + },
696 + blockSubmit: true
697 + },
698 + match: {
699 + name: "match",
700 + init: function ($this, name) {
701 + var element = $this.parents("form").first().find("[name=\"" + $this.data("validation" + name + "Match") + "\"]").first();
702 + element.bind("validation.validation", function () {
703 + $this.trigger("change.validation", {submitting: true});
704 + });
705 + return {"element": element};
706 + },
707 + validate: function ($this, value, validator) {
708 + return (value !== validator.element.val() && ! validator.negative)
709 + || (value === validator.element.val() && validator.negative);
710 + },
711 + blockSubmit: true
712 + },
713 + max: {
714 + name: "max",
715 + init: function ($this, name) {
716 + return {max: $this.data("validation" + name + "Max")};
717 + },
718 + validate: function ($this, value, validator) {
719 + return (parseFloat(value, 10) > parseFloat(validator.max, 10) && ! validator.negative)
720 + || (parseFloat(value, 10) <= parseFloat(validator.max, 10) && validator.negative);
721 + }
722 + },
723 + min: {
724 + name: "min",
725 + init: function ($this, name) {
726 + return {min: $this.data("validation" + name + "Min")};
727 + },
728 + validate: function ($this, value, validator) {
729 + return (parseFloat(value) < parseFloat(validator.min) && ! validator.negative)
730 + || (parseFloat(value) >= parseFloat(validator.min) && validator.negative);
731 + }
732 + },
733 + maxlength: {
734 + name: "maxlength",
735 + init: function ($this, name) {
736 + return {maxlength: $this.data("validation" + name + "Maxlength")};
737 + },
738 + validate: function ($this, value, validator) {
739 + return ((value.length > validator.maxlength) && ! validator.negative)
740 + || ((value.length <= validator.maxlength) && validator.negative);
741 + }
742 + },
743 + minlength: {
744 + name: "minlength",
745 + init: function ($this, name) {
746 + return {minlength: $this.data("validation" + name + "Minlength")};
747 + },
748 + validate: function ($this, value, validator) {
749 + return ((value.length < validator.minlength) && ! validator.negative)
750 + || ((value.length >= validator.minlength) && validator.negative);
751 + }
752 + },
753 + maxchecked: {
754 + name: "maxchecked",
755 + init: function ($this, name) {
756 + var elements = $this.parents("form").first().find("[name=\"" + $this.attr("name") + "\"]");
757 + elements.bind("click.validation", function () {
758 + $this.trigger("change.validation", {includeEmpty: true});
759 + });
760 + return {maxchecked: $this.data("validation" + name + "Maxchecked"), elements: elements};
761 + },
762 + validate: function ($this, value, validator) {
763 + return (validator.elements.filter(":checked").length > validator.maxchecked && ! validator.negative)
764 + || (validator.elements.filter(":checked").length <= validator.maxchecked && validator.negative);
765 + },
766 + blockSubmit: true
767 + },
768 + minchecked: {
769 + name: "minchecked",
770 + init: function ($this, name) {
771 + var elements = $this.parents("form").first().find("[name=\"" + $this.attr("name") + "\"]");
772 + elements.bind("click.validation", function () {
773 + $this.trigger("change.validation", {includeEmpty: true});
774 + });
775 + return {minchecked: $this.data("validation" + name + "Minchecked"), elements: elements};
776 + },
777 + validate: function ($this, value, validator) {
778 + return (validator.elements.filter(":checked").length < validator.minchecked && ! validator.negative)
779 + || (validator.elements.filter(":checked").length >= validator.minchecked && validator.negative);
780 + },
781 + blockSubmit: true
782 + }
783 + },
784 + builtInValidators: {
785 + email: {
786 + name: "Email",
787 + type: "shortcut",
788 + shortcut: "validemail"
789 + },
790 + validemail: {
791 + name: "Validemail",
792 + type: "regex",
793 + regex: "[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\\.[A-Za-z]{2,4}",
794 + message: "Not a valid email address<!-- data-validator-validemail-message to override -->"
795 + },
796 + passwordagain: {
797 + name: "Passwordagain",
798 + type: "match",
799 + match: "password",
800 + message: "Does not match the given password<!-- data-validator-paswordagain-message to override -->"
801 + },
802 + positive: {
803 + name: "Positive",
804 + type: "shortcut",
805 + shortcut: "number,positivenumber"
806 + },
807 + negative: {
808 + name: "Negative",
809 + type: "shortcut",
810 + shortcut: "number,negativenumber"
811 + },
812 + number: {
813 + name: "Number",
814 + type: "regex",
815 + regex: "([+-]?\\\d+(\\\.\\\d*)?([eE][+-]?[0-9]+)?)?",
816 + message: "Must be a number<!-- data-validator-number-message to override -->"
817 + },
818 + integer: {
819 + name: "Integer",
820 + type: "regex",
821 + regex: "[+-]?\\\d+",
822 + message: "No decimal places allowed<!-- data-validator-integer-message to override -->"
823 + },
824 + positivenumber: {
825 + name: "Positivenumber",
826 + type: "min",
827 + min: 0,
828 + message: "Must be a positive number<!-- data-validator-positivenumber-message to override -->"
829 + },
830 + negativenumber: {
831 + name: "Negativenumber",
832 + type: "max",
833 + max: 0,
834 + message: "Must be a negative number<!-- data-validator-negativenumber-message to override -->"
835 + },
836 + required: {
837 + name: "Required",
838 + type: "required",
839 + message: "This is required<!-- data-validator-required-message to override -->"
840 + },
841 + checkone: {
842 + name: "Checkone",
843 + type: "minchecked",
844 + minchecked: 1,
845 + message: "Check at least one option<!-- data-validation-checkone-message to override -->"
846 + }
847 + }
848 + };
849 +
850 + var formatValidatorName = function (name) {
851 + return name
852 + .toLowerCase()
853 + .replace(
854 + /(^|\s)([a-z])/g ,
855 + function(m,p1,p2) {
856 + return p1+p2.toUpperCase();
857 + }
858 + )
859 + ;
860 + };
861 +
862 + var getValue = function ($this) {
863 + // Extract the value we're talking about
864 + var value = $this.val();
865 + var type = $this.attr("type");
866 + if (type === "checkbox") {
867 + value = ($this.is(":checked") ? value : "");
868 + }
869 + if (type === "radio") {
870 + value = ($('input[name="' + $this.attr("name") + '"]:checked').length > 0 ? value : "");
871 + }
872 + return value;
873 + };
874 +
875 + function regexFromString(inputstring) {
876 + return new RegExp("^" + inputstring + "$");
877 + }
878 +
879 + /**
880 + * Thanks to Jason Bunting via StackOverflow.com
881 + *
882 + * http://stackoverflow.com/questions/359788/how-to-execute-a-javascript-function-when-i-have-its-name-as-a-string#answer-359910
883 + * Short link: http://tinyurl.com/executeFunctionByName
884 + **/
885 + function executeFunctionByName(functionName, context /*, args*/) {
886 + var args = Array.prototype.slice.call(arguments).splice(2);
887 + var namespaces = functionName.split(".");
888 + var func = namespaces.pop();
889 + for(var i = 0; i < namespaces.length; i++) {
890 + context = context[namespaces[i]];
891 + }
892 + return context[func].apply(this, args);
893 + }
894 +
895 + $.fn.jqBootstrapValidation = function( method ) {
896 +
897 + if ( defaults.methods[method] ) {
898 + return defaults.methods[method].apply( this, Array.prototype.slice.call( arguments, 1 ));
899 + } else if ( typeof method === 'object' || ! method ) {
900 + return defaults.methods.init.apply( this, arguments );
901 + } else {
902 + $.error( 'Method ' + method + ' does not exist on jQuery.jqBootstrapValidation' );
903 + return null;
904 + }
905 +
906 + };
907 +
908 + $.jqBootstrapValidation = function (options) {
909 + $(":input").not("[type=image],[type=submit]").jqBootstrapValidation.apply(this,arguments);
910 + };
911 +
912 +})( jQuery );
1 +/*! jQuery v1.11.1 | (c) 2005, 2014 jQuery Foundation, Inc. | jquery.org/license */
2 +!function(a,b){"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){var c=[],d=c.slice,e=c.concat,f=c.push,g=c.indexOf,h={},i=h.toString,j=h.hasOwnProperty,k={},l="1.11.1",m=function(a,b){return new m.fn.init(a,b)},n=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,o=/^-ms-/,p=/-([\da-z])/gi,q=function(a,b){return b.toUpperCase()};m.fn=m.prototype={jquery:l,constructor:m,selector:"",length:0,toArray:function(){return d.call(this)},get:function(a){return null!=a?0>a?this[a+this.length]:this[a]:d.call(this)},pushStack:function(a){var b=m.merge(this.constructor(),a);return b.prevObject=this,b.context=this.context,b},each:function(a,b){return m.each(this,a,b)},map:function(a){return this.pushStack(m.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(d.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(0>a?b:0);return this.pushStack(c>=0&&b>c?[this[c]]:[])},end:function(){return this.prevObject||this.constructor(null)},push:f,sort:c.sort,splice:c.splice},m.extend=m.fn.extend=function(){var a,b,c,d,e,f,g=arguments[0]||{},h=1,i=arguments.length,j=!1;for("boolean"==typeof g&&(j=g,g=arguments[h]||{},h++),"object"==typeof g||m.isFunction(g)||(g={}),h===i&&(g=this,h--);i>h;h++)if(null!=(e=arguments[h]))for(d in e)a=g[d],c=e[d],g!==c&&(j&&c&&(m.isPlainObject(c)||(b=m.isArray(c)))?(b?(b=!1,f=a&&m.isArray(a)?a:[]):f=a&&m.isPlainObject(a)?a:{},g[d]=m.extend(j,f,c)):void 0!==c&&(g[d]=c));return g},m.extend({expando:"jQuery"+(l+Math.random()).replace(/\D/g,""),isReady:!0,error:function(a){throw new Error(a)},noop:function(){},isFunction:function(a){return"function"===m.type(a)},isArray:Array.isArray||function(a){return"array"===m.type(a)},isWindow:function(a){return null!=a&&a==a.window},isNumeric:function(a){return!m.isArray(a)&&a-parseFloat(a)>=0},isEmptyObject:function(a){var b;for(b in a)return!1;return!0},isPlainObject:function(a){var b;if(!a||"object"!==m.type(a)||a.nodeType||m.isWindow(a))return!1;try{if(a.constructor&&!j.call(a,"constructor")&&!j.call(a.constructor.prototype,"isPrototypeOf"))return!1}catch(c){return!1}if(k.ownLast)for(b in a)return j.call(a,b);for(b in a);return void 0===b||j.call(a,b)},type:function(a){return null==a?a+"":"object"==typeof a||"function"==typeof a?h[i.call(a)]||"object":typeof a},globalEval:function(b){b&&m.trim(b)&&(a.execScript||function(b){a.eval.call(a,b)})(b)},camelCase:function(a){return a.replace(o,"ms-").replace(p,q)},nodeName:function(a,b){return a.nodeName&&a.nodeName.toLowerCase()===b.toLowerCase()},each:function(a,b,c){var d,e=0,f=a.length,g=r(a);if(c){if(g){for(;f>e;e++)if(d=b.apply(a[e],c),d===!1)break}else for(e in a)if(d=b.apply(a[e],c),d===!1)break}else if(g){for(;f>e;e++)if(d=b.call(a[e],e,a[e]),d===!1)break}else for(e in a)if(d=b.call(a[e],e,a[e]),d===!1)break;return a},trim:function(a){return null==a?"":(a+"").replace(n,"")},makeArray:function(a,b){var c=b||[];return null!=a&&(r(Object(a))?m.merge(c,"string"==typeof a?[a]:a):f.call(c,a)),c},inArray:function(a,b,c){var d;if(b){if(g)return g.call(b,a,c);for(d=b.length,c=c?0>c?Math.max(0,d+c):c:0;d>c;c++)if(c in b&&b[c]===a)return c}return-1},merge:function(a,b){var c=+b.length,d=0,e=a.length;while(c>d)a[e++]=b[d++];if(c!==c)while(void 0!==b[d])a[e++]=b[d++];return a.length=e,a},grep:function(a,b,c){for(var d,e=[],f=0,g=a.length,h=!c;g>f;f++)d=!b(a[f],f),d!==h&&e.push(a[f]);return e},map:function(a,b,c){var d,f=0,g=a.length,h=r(a),i=[];if(h)for(;g>f;f++)d=b(a[f],f,c),null!=d&&i.push(d);else for(f in a)d=b(a[f],f,c),null!=d&&i.push(d);return e.apply([],i)},guid:1,proxy:function(a,b){var c,e,f;return"string"==typeof b&&(f=a[b],b=a,a=f),m.isFunction(a)?(c=d.call(arguments,2),e=function(){return a.apply(b||this,c.concat(d.call(arguments)))},e.guid=a.guid=a.guid||m.guid++,e):void 0},now:function(){return+new Date},support:k}),m.each("Boolean Number String Function Array Date RegExp Object Error".split(" "),function(a,b){h["[object "+b+"]"]=b.toLowerCase()});function r(a){var b=a.length,c=m.type(a);return"function"===c||m.isWindow(a)?!1:1===a.nodeType&&b?!0:"array"===c||0===b||"number"==typeof b&&b>0&&b-1 in a}var s=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+-new Date,v=a.document,w=0,x=0,y=gb(),z=gb(),A=gb(),B=function(a,b){return a===b&&(l=!0),0},C="undefined",D=1<<31,E={}.hasOwnProperty,F=[],G=F.pop,H=F.push,I=F.push,J=F.slice,K=F.indexOf||function(a){for(var b=0,c=this.length;c>b;b++)if(this[b]===a)return b;return-1},L="checked|selected|async|autofocus|autoplay|controls|defer|disabled|hidden|ismap|loop|multiple|open|readonly|required|scoped",M="[\\x20\\t\\r\\n\\f]",N="(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+",O=N.replace("w","w#"),P="\\["+M+"*("+N+")(?:"+M+"*([*^$|!~]?=)"+M+"*(?:'((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\"|("+O+"))|)"+M+"*\\]",Q=":("+N+")(?:\\((('((?:\\\\.|[^\\\\'])*)'|\"((?:\\\\.|[^\\\\\"])*)\")|((?:\\\\.|[^\\\\()[\\]]|"+P+")*)|.*)\\)|)",R=new RegExp("^"+M+"+|((?:^|[^\\\\])(?:\\\\.)*)"+M+"+$","g"),S=new RegExp("^"+M+"*,"+M+"*"),T=new RegExp("^"+M+"*([>+~]|"+M+")"+M+"*"),U=new RegExp("="+M+"*([^\\]'\"]*?)"+M+"*\\]","g"),V=new RegExp(Q),W=new RegExp("^"+O+"$"),X={ID:new RegExp("^#("+N+")"),CLASS:new RegExp("^\\.("+N+")"),TAG:new RegExp("^("+N.replace("w","w*")+")"),ATTR:new RegExp("^"+P),PSEUDO:new RegExp("^"+Q),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+M+"*(even|odd|(([+-]|)(\\d*)n|)"+M+"*(?:([+-]|)"+M+"*(\\d+)|))"+M+"*\\)|)","i"),bool:new RegExp("^(?:"+L+")$","i"),needsContext:new RegExp("^"+M+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+M+"*((?:-\\d)?\\d*)"+M+"*\\)|)(?=[^-]|$)","i")},Y=/^(?:input|select|textarea|button)$/i,Z=/^h\d$/i,$=/^[^{]+\{\s*\[native \w/,_=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,ab=/[+~]/,bb=/'|\\/g,cb=new RegExp("\\\\([\\da-f]{1,6}"+M+"?|("+M+")|.)","ig"),db=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:0>d?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)};try{I.apply(F=J.call(v.childNodes),v.childNodes),F[v.childNodes.length].nodeType}catch(eb){I={apply:F.length?function(a,b){H.apply(a,J.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function fb(a,b,d,e){var f,h,j,k,l,o,r,s,w,x;if((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,d=d||[],!a||"string"!=typeof a)return d;if(1!==(k=b.nodeType)&&9!==k)return[];if(p&&!e){if(f=_.exec(a))if(j=f[1]){if(9===k){if(h=b.getElementById(j),!h||!h.parentNode)return d;if(h.id===j)return d.push(h),d}else if(b.ownerDocument&&(h=b.ownerDocument.getElementById(j))&&t(b,h)&&h.id===j)return d.push(h),d}else{if(f[2])return I.apply(d,b.getElementsByTagName(a)),d;if((j=f[3])&&c.getElementsByClassName&&b.getElementsByClassName)return I.apply(d,b.getElementsByClassName(j)),d}if(c.qsa&&(!q||!q.test(a))){if(s=r=u,w=b,x=9===k&&a,1===k&&"object"!==b.nodeName.toLowerCase()){o=g(a),(r=b.getAttribute("id"))?s=r.replace(bb,"\\$&"):b.setAttribute("id",s),s="[id='"+s+"'] ",l=o.length;while(l--)o[l]=s+qb(o[l]);w=ab.test(a)&&ob(b.parentNode)||b,x=o.join(",")}if(x)try{return I.apply(d,w.querySelectorAll(x)),d}catch(y){}finally{r||b.removeAttribute("id")}}}return i(a.replace(R,"$1"),b,d,e)}function gb(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function hb(a){return a[u]=!0,a}function ib(a){var b=n.createElement("div");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function jb(a,b){var c=a.split("|"),e=a.length;while(e--)d.attrHandle[c[e]]=b}function kb(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&(~b.sourceIndex||D)-(~a.sourceIndex||D);if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function lb(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function mb(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function nb(a){return hb(function(b){return b=+b,hb(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function ob(a){return a&&typeof a.getElementsByTagName!==C&&a}c=fb.support={},f=fb.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return b?"HTML"!==b.nodeName:!1},m=fb.setDocument=function(a){var b,e=a?a.ownerDocument||a:v,g=e.defaultView;return e!==n&&9===e.nodeType&&e.documentElement?(n=e,o=e.documentElement,p=!f(e),g&&g!==g.top&&(g.addEventListener?g.addEventListener("unload",function(){m()},!1):g.attachEvent&&g.attachEvent("onunload",function(){m()})),c.attributes=ib(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ib(function(a){return a.appendChild(e.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=$.test(e.getElementsByClassName)&&ib(function(a){return a.innerHTML="<div class='a'></div><div class='a i'></div>",a.firstChild.className="i",2===a.getElementsByClassName("i").length}),c.getById=ib(function(a){return o.appendChild(a).id=u,!e.getElementsByName||!e.getElementsByName(u).length}),c.getById?(d.find.ID=function(a,b){if(typeof b.getElementById!==C&&p){var c=b.getElementById(a);return c&&c.parentNode?[c]:[]}},d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){return a.getAttribute("id")===b}}):(delete d.find.ID,d.filter.ID=function(a){var b=a.replace(cb,db);return function(a){var c=typeof a.getAttributeNode!==C&&a.getAttributeNode("id");return c&&c.value===b}}),d.find.TAG=c.getElementsByTagName?function(a,b){return typeof b.getElementsByTagName!==C?b.getElementsByTagName(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){return typeof b.getElementsByClassName!==C&&p?b.getElementsByClassName(a):void 0},r=[],q=[],(c.qsa=$.test(e.querySelectorAll))&&(ib(function(a){a.innerHTML="<select msallowclip=''><option selected=''></option></select>",a.querySelectorAll("[msallowclip^='']").length&&q.push("[*^$]="+M+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+M+"*(?:value|"+L+")"),a.querySelectorAll(":checked").length||q.push(":checked")}),ib(function(a){var b=e.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+M+"*[*^$|!~]?="),a.querySelectorAll(":enabled").length||q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=$.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ib(function(a){c.disconnectedMatch=s.call(a,"div"),s.call(a,"[s!='']:x"),r.push("!=",Q)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=$.test(o.compareDocumentPosition),t=b||$.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===e||a.ownerDocument===v&&t(v,a)?-1:b===e||b.ownerDocument===v&&t(v,b)?1:k?K.call(k,a)-K.call(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,f=a.parentNode,g=b.parentNode,h=[a],i=[b];if(!f||!g)return a===e?-1:b===e?1:f?-1:g?1:k?K.call(k,a)-K.call(k,b):0;if(f===g)return kb(a,b);c=a;while(c=c.parentNode)h.unshift(c);c=b;while(c=c.parentNode)i.unshift(c);while(h[d]===i[d])d++;return d?kb(h[d],i[d]):h[d]===v?-1:i[d]===v?1:0},e):n},fb.matches=function(a,b){return fb(a,null,null,b)},fb.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(U,"='$1']"),!(!c.matchesSelector||!p||r&&r.test(b)||q&&q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return fb(b,n,null,[a]).length>0},fb.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},fb.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&E.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},fb.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},fb.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=fb.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=fb.selectors={cacheLength:50,createPseudo:hb,match:X,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(cb,db),a[3]=(a[3]||a[4]||a[5]||"").replace(cb,db),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||fb.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&fb.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return X.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&V.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(cb,db).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+M+")"+a+"("+M+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||typeof a.getAttribute!==C&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=fb.attr(d,a);return null==e?"!="===b:b?(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e+" ").indexOf(c)>-1:"|="===b?e===c||e.slice(0,c.length+1)===c+"-":!1):!0}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h;if(q){if(f){while(p){l=b;while(l=l[p])if(h?l.nodeName.toLowerCase()===r:1===l.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){k=q[u]||(q[u]={}),j=k[a]||[],n=j[0]===w&&j[1],m=j[0]===w&&j[2],l=n&&q.childNodes[n];while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if(1===l.nodeType&&++m&&l===b){k[a]=[w,n,m];break}}else if(s&&(j=(b[u]||(b[u]={}))[a])&&j[0]===w)m=j[1];else while(l=++n&&l&&l[p]||(m=n=0)||o.pop())if((h?l.nodeName.toLowerCase()===r:1===l.nodeType)&&++m&&(s&&((l[u]||(l[u]={}))[a]=[w,m]),l===b))break;return m-=e,m===d||m%d===0&&m/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||fb.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?hb(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=K.call(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:hb(function(a){var b=[],c=[],d=h(a.replace(R,"$1"));return d[u]?hb(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),!c.pop()}}),has:hb(function(a){return function(b){return fb(a,b).length>0}}),contains:hb(function(a){return function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:hb(function(a){return W.test(a||"")||fb.error("unsupported lang: "+a),a=a.replace(cb,db).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:function(a){return a.disabled===!1},disabled:function(a){return a.disabled===!0},checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return Z.test(a.nodeName)},input:function(a){return Y.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:nb(function(){return[0]}),last:nb(function(a,b){return[b-1]}),eq:nb(function(a,b,c){return[0>c?c+b:c]}),even:nb(function(a,b){for(var c=0;b>c;c+=2)a.push(c);return a}),odd:nb(function(a,b){for(var c=1;b>c;c+=2)a.push(c);return a}),lt:nb(function(a,b,c){for(var d=0>c?c+b:c;--d>=0;)a.push(d);return a}),gt:nb(function(a,b,c){for(var d=0>c?c+b:c;++d<b;)a.push(d);return a})}},d.pseudos.nth=d.pseudos.eq;for(b in{radio:!0,checkbox:!0,file:!0,password:!0,image:!0})d.pseudos[b]=lb(b);for(b in{submit:!0,reset:!0})d.pseudos[b]=mb(b);function pb(){}pb.prototype=d.filters=d.pseudos,d.setFilters=new pb,g=fb.tokenize=function(a,b){var c,e,f,g,h,i,j,k=z[a+" "];if(k)return b?0:k.slice(0);h=a,i=[],j=d.preFilter;while(h){(!c||(e=S.exec(h)))&&(e&&(h=h.slice(e[0].length)||h),i.push(f=[])),c=!1,(e=T.exec(h))&&(c=e.shift(),f.push({value:c,type:e[0].replace(R," ")}),h=h.slice(c.length));for(g in d.filter)!(e=X[g].exec(h))||j[g]&&!(e=j[g](e))||(c=e.shift(),f.push({value:c,type:g,matches:e}),h=h.slice(c.length));if(!c)break}return b?h.length:h?fb.error(a):z(a,i).slice(0)};function qb(a){for(var b=0,c=a.length,d="";c>b;b++)d+=a[b].value;return d}function rb(a,b,c){var d=b.dir,e=c&&"parentNode"===d,f=x++;return b.first?function(b,c,f){while(b=b[d])if(1===b.nodeType||e)return a(b,c,f)}:function(b,c,g){var h,i,j=[w,f];if(g){while(b=b[d])if((1===b.nodeType||e)&&a(b,c,g))return!0}else while(b=b[d])if(1===b.nodeType||e){if(i=b[u]||(b[u]={}),(h=i[d])&&h[0]===w&&h[1]===f)return j[2]=h[2];if(i[d]=j,j[2]=a(b,c,g))return!0}}}function sb(a){return a.length>1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function tb(a,b,c){for(var d=0,e=b.length;e>d;d++)fb(a,b[d],c);return c}function ub(a,b,c,d,e){for(var f,g=[],h=0,i=a.length,j=null!=b;i>h;h++)(f=a[h])&&(!c||c(f,d,e))&&(g.push(f),j&&b.push(h));return g}function vb(a,b,c,d,e,f){return d&&!d[u]&&(d=vb(d)),e&&!e[u]&&(e=vb(e,f)),hb(function(f,g,h,i){var j,k,l,m=[],n=[],o=g.length,p=f||tb(b||"*",h.nodeType?[h]:h,[]),q=!a||!f&&b?p:ub(p,m,a,h,i),r=c?e||(f?a:o||d)?[]:g:q;if(c&&c(q,r,h,i),d){j=ub(r,n),d(j,[],h,i),k=j.length;while(k--)(l=j[k])&&(r[n[k]]=!(q[n[k]]=l))}if(f){if(e||a){if(e){j=[],k=r.length;while(k--)(l=r[k])&&j.push(q[k]=l);e(null,r=[],j,i)}k=r.length;while(k--)(l=r[k])&&(j=e?K.call(f,l):m[k])>-1&&(f[j]=!(g[j]=l))}}else r=ub(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):I.apply(g,r)})}function wb(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=rb(function(a){return a===b},h,!0),l=rb(function(a){return K.call(b,a)>-1},h,!0),m=[function(a,c,d){return!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d))}];f>i;i++)if(c=d.relative[a[i].type])m=[rb(sb(m),c)];else{if(c=d.filter[a[i].type].apply(null,a[i].matches),c[u]){for(e=++i;f>e;e++)if(d.relative[a[e].type])break;return vb(i>1&&sb(m),i>1&&qb(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(R,"$1"),c,e>i&&wb(a.slice(i,e)),f>e&&wb(a=a.slice(e)),f>e&&qb(a))}m.push(c)}return sb(m)}function xb(a,b){var c=b.length>0,e=a.length>0,f=function(f,g,h,i,k){var l,m,o,p=0,q="0",r=f&&[],s=[],t=j,u=f||e&&d.find.TAG("*",k),v=w+=null==t?1:Math.random()||.1,x=u.length;for(k&&(j=g!==n&&g);q!==x&&null!=(l=u[q]);q++){if(e&&l){m=0;while(o=a[m++])if(o(l,g,h)){i.push(l);break}k&&(w=v)}c&&((l=!o&&l)&&p--,f&&r.push(l))}if(p+=q,c&&q!==p){m=0;while(o=b[m++])o(r,s,g,h);if(f){if(p>0)while(q--)r[q]||s[q]||(s[q]=G.call(i));s=ub(s)}I.apply(i,s),k&&!f&&s.length>0&&p+b.length>1&&fb.uniqueSort(i)}return k&&(w=v,j=t),r};return c?hb(f):f}return h=fb.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=wb(b[c]),f[u]?d.push(f):e.push(f);f=A(a,xb(e,d)),f.selector=a}return f},i=fb.select=function(a,b,e,f){var i,j,k,l,m,n="function"==typeof a&&a,o=!f&&g(a=n.selector||a);if(e=e||[],1===o.length){if(j=o[0]=o[0].slice(0),j.length>2&&"ID"===(k=j[0]).type&&c.getById&&9===b.nodeType&&p&&d.relative[j[1].type]){if(b=(d.find.ID(k.matches[0].replace(cb,db),b)||[])[0],!b)return e;n&&(b=b.parentNode),a=a.slice(j.shift().value.length)}i=X.needsContext.test(a)?0:j.length;while(i--){if(k=j[i],d.relative[l=k.type])break;if((m=d.find[l])&&(f=m(k.matches[0].replace(cb,db),ab.test(j[0].type)&&ob(b.parentNode)||b))){if(j.splice(i,1),a=f.length&&qb(j),!a)return I.apply(e,f),e;break}}}return(n||h(a,o))(f,b,!p,e,ab.test(a)&&ob(b.parentNode)||b),e},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ib(function(a){return 1&a.compareDocumentPosition(n.createElement("div"))}),ib(function(a){return a.innerHTML="<a href='#'></a>","#"===a.firstChild.getAttribute("href")})||jb("type|href|height|width",function(a,b,c){return c?void 0:a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ib(function(a){return a.innerHTML="<input/>",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||jb("value",function(a,b,c){return c||"input"!==a.nodeName.toLowerCase()?void 0:a.defaultValue}),ib(function(a){return null==a.getAttribute("disabled")})||jb(L,function(a,b,c){var d;return c?void 0:a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),fb}(a);m.find=s,m.expr=s.selectors,m.expr[":"]=m.expr.pseudos,m.unique=s.uniqueSort,m.text=s.getText,m.isXMLDoc=s.isXML,m.contains=s.contains;var t=m.expr.match.needsContext,u=/^<(\w+)\s*\/?>(?:<\/\1>|)$/,v=/^.[^:#\[\.,]*$/;function w(a,b,c){if(m.isFunction(b))return m.grep(a,function(a,d){return!!b.call(a,d,a)!==c});if(b.nodeType)return m.grep(a,function(a){return a===b!==c});if("string"==typeof b){if(v.test(b))return m.filter(b,a,c);b=m.filter(b,a)}return m.grep(a,function(a){return m.inArray(a,b)>=0!==c})}m.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?m.find.matchesSelector(d,a)?[d]:[]:m.find.matches(a,m.grep(b,function(a){return 1===a.nodeType}))},m.fn.extend({find:function(a){var b,c=[],d=this,e=d.length;if("string"!=typeof a)return this.pushStack(m(a).filter(function(){for(b=0;e>b;b++)if(m.contains(d[b],this))return!0}));for(b=0;e>b;b++)m.find(a,d[b],c);return c=this.pushStack(e>1?m.unique(c):c),c.selector=this.selector?this.selector+" "+a:a,c},filter:function(a){return this.pushStack(w(this,a||[],!1))},not:function(a){return this.pushStack(w(this,a||[],!0))},is:function(a){return!!w(this,"string"==typeof a&&t.test(a)?m(a):a||[],!1).length}});var x,y=a.document,z=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]*))$/,A=m.fn.init=function(a,b){var c,d;if(!a)return this;if("string"==typeof a){if(c="<"===a.charAt(0)&&">"===a.charAt(a.length-1)&&a.length>=3?[null,a,null]:z.exec(a),!c||!c[1]&&b)return!b||b.jquery?(b||x).find(a):this.constructor(b).find(a);if(c[1]){if(b=b instanceof m?b[0]:b,m.merge(this,m.parseHTML(c[1],b&&b.nodeType?b.ownerDocument||b:y,!0)),u.test(c[1])&&m.isPlainObject(b))for(c in b)m.isFunction(this[c])?this[c](b[c]):this.attr(c,b[c]);return this}if(d=y.getElementById(c[2]),d&&d.parentNode){if(d.id!==c[2])return x.find(a);this.length=1,this[0]=d}return this.context=y,this.selector=a,this}return a.nodeType?(this.context=this[0]=a,this.length=1,this):m.isFunction(a)?"undefined"!=typeof x.ready?x.ready(a):a(m):(void 0!==a.selector&&(this.selector=a.selector,this.context=a.context),m.makeArray(a,this))};A.prototype=m.fn,x=m(y);var B=/^(?:parents|prev(?:Until|All))/,C={children:!0,contents:!0,next:!0,prev:!0};m.extend({dir:function(a,b,c){var d=[],e=a[b];while(e&&9!==e.nodeType&&(void 0===c||1!==e.nodeType||!m(e).is(c)))1===e.nodeType&&d.push(e),e=e[b];return d},sibling:function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c}}),m.fn.extend({has:function(a){var b,c=m(a,this),d=c.length;return this.filter(function(){for(b=0;d>b;b++)if(m.contains(this,c[b]))return!0})},closest:function(a,b){for(var c,d=0,e=this.length,f=[],g=t.test(a)||"string"!=typeof a?m(a,b||this.context):0;e>d;d++)for(c=this[d];c&&c!==b;c=c.parentNode)if(c.nodeType<11&&(g?g.index(c)>-1:1===c.nodeType&&m.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?m.unique(f):f)},index:function(a){return a?"string"==typeof a?m.inArray(this[0],m(a)):m.inArray(a.jquery?a[0]:a,this):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(m.unique(m.merge(this.get(),m(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function D(a,b){do a=a[b];while(a&&1!==a.nodeType);return a}m.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return m.dir(a,"parentNode")},parentsUntil:function(a,b,c){return m.dir(a,"parentNode",c)},next:function(a){return D(a,"nextSibling")},prev:function(a){return D(a,"previousSibling")},nextAll:function(a){return m.dir(a,"nextSibling")},prevAll:function(a){return m.dir(a,"previousSibling")},nextUntil:function(a,b,c){return m.dir(a,"nextSibling",c)},prevUntil:function(a,b,c){return m.dir(a,"previousSibling",c)},siblings:function(a){return m.sibling((a.parentNode||{}).firstChild,a)},children:function(a){return m.sibling(a.firstChild)},contents:function(a){return m.nodeName(a,"iframe")?a.contentDocument||a.contentWindow.document:m.merge([],a.childNodes)}},function(a,b){m.fn[a]=function(c,d){var e=m.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=m.filter(d,e)),this.length>1&&(C[a]||(e=m.unique(e)),B.test(a)&&(e=e.reverse())),this.pushStack(e)}});var E=/\S+/g,F={};function G(a){var b=F[a]={};return m.each(a.match(E)||[],function(a,c){b[c]=!0}),b}m.Callbacks=function(a){a="string"==typeof a?F[a]||G(a):m.extend({},a);var b,c,d,e,f,g,h=[],i=!a.once&&[],j=function(l){for(c=a.memory&&l,d=!0,f=g||0,g=0,e=h.length,b=!0;h&&e>f;f++)if(h[f].apply(l[0],l[1])===!1&&a.stopOnFalse){c=!1;break}b=!1,h&&(i?i.length&&j(i.shift()):c?h=[]:k.disable())},k={add:function(){if(h){var d=h.length;!function f(b){m.each(b,function(b,c){var d=m.type(c);"function"===d?a.unique&&k.has(c)||h.push(c):c&&c.length&&"string"!==d&&f(c)})}(arguments),b?e=h.length:c&&(g=d,j(c))}return this},remove:function(){return h&&m.each(arguments,function(a,c){var d;while((d=m.inArray(c,h,d))>-1)h.splice(d,1),b&&(e>=d&&e--,f>=d&&f--)}),this},has:function(a){return a?m.inArray(a,h)>-1:!(!h||!h.length)},empty:function(){return h=[],e=0,this},disable:function(){return h=i=c=void 0,this},disabled:function(){return!h},lock:function(){return i=void 0,c||k.disable(),this},locked:function(){return!i},fireWith:function(a,c){return!h||d&&!i||(c=c||[],c=[a,c.slice?c.slice():c],b?i.push(c):j(c)),this},fire:function(){return k.fireWith(this,arguments),this},fired:function(){return!!d}};return k},m.extend({Deferred:function(a){var b=[["resolve","done",m.Callbacks("once memory"),"resolved"],["reject","fail",m.Callbacks("once memory"),"rejected"],["notify","progress",m.Callbacks("memory")]],c="pending",d={state:function(){return c},always:function(){return e.done(arguments).fail(arguments),this},then:function(){var a=arguments;return m.Deferred(function(c){m.each(b,function(b,f){var g=m.isFunction(a[b])&&a[b];e[f[1]](function(){var a=g&&g.apply(this,arguments);a&&m.isFunction(a.promise)?a.promise().done(c.resolve).fail(c.reject).progress(c.notify):c[f[0]+"With"](this===d?c.promise():this,g?[a]:arguments)})}),a=null}).promise()},promise:function(a){return null!=a?m.extend(a,d):d}},e={};return d.pipe=d.then,m.each(b,function(a,f){var g=f[2],h=f[3];d[f[1]]=g.add,h&&g.add(function(){c=h},b[1^a][2].disable,b[2][2].lock),e[f[0]]=function(){return e[f[0]+"With"](this===e?d:this,arguments),this},e[f[0]+"With"]=g.fireWith}),d.promise(e),a&&a.call(e,e),e},when:function(a){var b=0,c=d.call(arguments),e=c.length,f=1!==e||a&&m.isFunction(a.promise)?e:0,g=1===f?a:m.Deferred(),h=function(a,b,c){return function(e){b[a]=this,c[a]=arguments.length>1?d.call(arguments):e,c===i?g.notifyWith(b,c):--f||g.resolveWith(b,c)}},i,j,k;if(e>1)for(i=new Array(e),j=new Array(e),k=new Array(e);e>b;b++)c[b]&&m.isFunction(c[b].promise)?c[b].promise().done(h(b,k,c)).fail(g.reject).progress(h(b,j,i)):--f;return f||g.resolveWith(k,c),g.promise()}});var H;m.fn.ready=function(a){return m.ready.promise().done(a),this},m.extend({isReady:!1,readyWait:1,holdReady:function(a){a?m.readyWait++:m.ready(!0)},ready:function(a){if(a===!0?!--m.readyWait:!m.isReady){if(!y.body)return setTimeout(m.ready);m.isReady=!0,a!==!0&&--m.readyWait>0||(H.resolveWith(y,[m]),m.fn.triggerHandler&&(m(y).triggerHandler("ready"),m(y).off("ready")))}}});function I(){y.addEventListener?(y.removeEventListener("DOMContentLoaded",J,!1),a.removeEventListener("load",J,!1)):(y.detachEvent("onreadystatechange",J),a.detachEvent("onload",J))}function J(){(y.addEventListener||"load"===event.type||"complete"===y.readyState)&&(I(),m.ready())}m.ready.promise=function(b){if(!H)if(H=m.Deferred(),"complete"===y.readyState)setTimeout(m.ready);else if(y.addEventListener)y.addEventListener("DOMContentLoaded",J,!1),a.addEventListener("load",J,!1);else{y.attachEvent("onreadystatechange",J),a.attachEvent("onload",J);var c=!1;try{c=null==a.frameElement&&y.documentElement}catch(d){}c&&c.doScroll&&!function e(){if(!m.isReady){try{c.doScroll("left")}catch(a){return setTimeout(e,50)}I(),m.ready()}}()}return H.promise(b)};var K="undefined",L;for(L in m(k))break;k.ownLast="0"!==L,k.inlineBlockNeedsLayout=!1,m(function(){var a,b,c,d;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="display:inline;margin:0;border:0;padding:1px;width:1px;zoom:1",k.inlineBlockNeedsLayout=a=3===b.offsetWidth,a&&(c.style.zoom=1)),c.removeChild(d))}),function(){var a=y.createElement("div");if(null==k.deleteExpando){k.deleteExpando=!0;try{delete a.test}catch(b){k.deleteExpando=!1}}a=null}(),m.acceptData=function(a){var b=m.noData[(a.nodeName+" ").toLowerCase()],c=+a.nodeType||1;return 1!==c&&9!==c?!1:!b||b!==!0&&a.getAttribute("classid")===b};var M=/^(?:\{[\w\W]*\}|\[[\w\W]*\])$/,N=/([A-Z])/g;function O(a,b,c){if(void 0===c&&1===a.nodeType){var d="data-"+b.replace(N,"-$1").toLowerCase();if(c=a.getAttribute(d),"string"==typeof c){try{c="true"===c?!0:"false"===c?!1:"null"===c?null:+c+""===c?+c:M.test(c)?m.parseJSON(c):c}catch(e){}m.data(a,b,c)}else c=void 0}return c}function P(a){var b;for(b in a)if(("data"!==b||!m.isEmptyObject(a[b]))&&"toJSON"!==b)return!1;return!0}function Q(a,b,d,e){if(m.acceptData(a)){var f,g,h=m.expando,i=a.nodeType,j=i?m.cache:a,k=i?a[h]:a[h]&&h;
3 +if(k&&j[k]&&(e||j[k].data)||void 0!==d||"string"!=typeof b)return k||(k=i?a[h]=c.pop()||m.guid++:h),j[k]||(j[k]=i?{}:{toJSON:m.noop}),("object"==typeof b||"function"==typeof b)&&(e?j[k]=m.extend(j[k],b):j[k].data=m.extend(j[k].data,b)),g=j[k],e||(g.data||(g.data={}),g=g.data),void 0!==d&&(g[m.camelCase(b)]=d),"string"==typeof b?(f=g[b],null==f&&(f=g[m.camelCase(b)])):f=g,f}}function R(a,b,c){if(m.acceptData(a)){var d,e,f=a.nodeType,g=f?m.cache:a,h=f?a[m.expando]:m.expando;if(g[h]){if(b&&(d=c?g[h]:g[h].data)){m.isArray(b)?b=b.concat(m.map(b,m.camelCase)):b in d?b=[b]:(b=m.camelCase(b),b=b in d?[b]:b.split(" ")),e=b.length;while(e--)delete d[b[e]];if(c?!P(d):!m.isEmptyObject(d))return}(c||(delete g[h].data,P(g[h])))&&(f?m.cleanData([a],!0):k.deleteExpando||g!=g.window?delete g[h]:g[h]=null)}}}m.extend({cache:{},noData:{"applet ":!0,"embed ":!0,"object ":"clsid:D27CDB6E-AE6D-11cf-96B8-444553540000"},hasData:function(a){return a=a.nodeType?m.cache[a[m.expando]]:a[m.expando],!!a&&!P(a)},data:function(a,b,c){return Q(a,b,c)},removeData:function(a,b){return R(a,b)},_data:function(a,b,c){return Q(a,b,c,!0)},_removeData:function(a,b){return R(a,b,!0)}}),m.fn.extend({data:function(a,b){var c,d,e,f=this[0],g=f&&f.attributes;if(void 0===a){if(this.length&&(e=m.data(f),1===f.nodeType&&!m._data(f,"parsedAttrs"))){c=g.length;while(c--)g[c]&&(d=g[c].name,0===d.indexOf("data-")&&(d=m.camelCase(d.slice(5)),O(f,d,e[d])));m._data(f,"parsedAttrs",!0)}return e}return"object"==typeof a?this.each(function(){m.data(this,a)}):arguments.length>1?this.each(function(){m.data(this,a,b)}):f?O(f,a,m.data(f,a)):void 0},removeData:function(a){return this.each(function(){m.removeData(this,a)})}}),m.extend({queue:function(a,b,c){var d;return a?(b=(b||"fx")+"queue",d=m._data(a,b),c&&(!d||m.isArray(c)?d=m._data(a,b,m.makeArray(c)):d.push(c)),d||[]):void 0},dequeue:function(a,b){b=b||"fx";var c=m.queue(a,b),d=c.length,e=c.shift(),f=m._queueHooks(a,b),g=function(){m.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return m._data(a,c)||m._data(a,c,{empty:m.Callbacks("once memory").add(function(){m._removeData(a,b+"queue"),m._removeData(a,c)})})}}),m.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length<c?m.queue(this[0],a):void 0===b?this:this.each(function(){var c=m.queue(this,a,b);m._queueHooks(this,a),"fx"===a&&"inprogress"!==c[0]&&m.dequeue(this,a)})},dequeue:function(a){return this.each(function(){m.dequeue(this,a)})},clearQueue:function(a){return this.queue(a||"fx",[])},promise:function(a,b){var c,d=1,e=m.Deferred(),f=this,g=this.length,h=function(){--d||e.resolveWith(f,[f])};"string"!=typeof a&&(b=a,a=void 0),a=a||"fx";while(g--)c=m._data(f[g],a+"queueHooks"),c&&c.empty&&(d++,c.empty.add(h));return h(),e.promise(b)}});var S=/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/.source,T=["Top","Right","Bottom","Left"],U=function(a,b){return a=b||a,"none"===m.css(a,"display")||!m.contains(a.ownerDocument,a)},V=m.access=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===m.type(c)){e=!0;for(h in c)m.access(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,m.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(m(a),c)})),b))for(;i>h;h++)b(a[h],c,g?d:d.call(a[h],h,b(a[h],c)));return e?a:j?b.call(a):i?b(a[0],c):f},W=/^(?:checkbox|radio)$/i;!function(){var a=y.createElement("input"),b=y.createElement("div"),c=y.createDocumentFragment();if(b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",k.leadingWhitespace=3===b.firstChild.nodeType,k.tbody=!b.getElementsByTagName("tbody").length,k.htmlSerialize=!!b.getElementsByTagName("link").length,k.html5Clone="<:nav></:nav>"!==y.createElement("nav").cloneNode(!0).outerHTML,a.type="checkbox",a.checked=!0,c.appendChild(a),k.appendChecked=a.checked,b.innerHTML="<textarea>x</textarea>",k.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue,c.appendChild(b),b.innerHTML="<input type='radio' checked='checked' name='t'/>",k.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,k.noCloneEvent=!0,b.attachEvent&&(b.attachEvent("onclick",function(){k.noCloneEvent=!1}),b.cloneNode(!0).click()),null==k.deleteExpando){k.deleteExpando=!0;try{delete b.test}catch(d){k.deleteExpando=!1}}}(),function(){var b,c,d=y.createElement("div");for(b in{submit:!0,change:!0,focusin:!0})c="on"+b,(k[b+"Bubbles"]=c in a)||(d.setAttribute(c,"t"),k[b+"Bubbles"]=d.attributes[c].expando===!1);d=null}();var X=/^(?:input|select|textarea)$/i,Y=/^key/,Z=/^(?:mouse|pointer|contextmenu)|click/,$=/^(?:focusinfocus|focusoutblur)$/,_=/^([^.]*)(?:\.(.+)|)$/;function ab(){return!0}function bb(){return!1}function cb(){try{return y.activeElement}catch(a){}}m.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m._data(a);if(r){c.handler&&(i=c,c=i.handler,e=i.selector),c.guid||(c.guid=m.guid++),(g=r.events)||(g=r.events={}),(k=r.handle)||(k=r.handle=function(a){return typeof m===K||a&&m.event.triggered===a.type?void 0:m.event.dispatch.apply(k.elem,arguments)},k.elem=a),b=(b||"").match(E)||[""],h=b.length;while(h--)f=_.exec(b[h])||[],o=q=f[1],p=(f[2]||"").split(".").sort(),o&&(j=m.event.special[o]||{},o=(e?j.delegateType:j.bindType)||o,j=m.event.special[o]||{},l=m.extend({type:o,origType:q,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&m.expr.match.needsContext.test(e),namespace:p.join(".")},i),(n=g[o])||(n=g[o]=[],n.delegateCount=0,j.setup&&j.setup.call(a,d,p,k)!==!1||(a.addEventListener?a.addEventListener(o,k,!1):a.attachEvent&&a.attachEvent("on"+o,k))),j.add&&(j.add.call(a,l),l.handler.guid||(l.handler.guid=c.guid)),e?n.splice(n.delegateCount++,0,l):n.push(l),m.event.global[o]=!0);a=null}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,n,o,p,q,r=m.hasData(a)&&m._data(a);if(r&&(k=r.events)){b=(b||"").match(E)||[""],j=b.length;while(j--)if(h=_.exec(b[j])||[],o=q=h[1],p=(h[2]||"").split(".").sort(),o){l=m.event.special[o]||{},o=(d?l.delegateType:l.bindType)||o,n=k[o]||[],h=h[2]&&new RegExp("(^|\\.)"+p.join("\\.(?:.*\\.|)")+"(\\.|$)"),i=f=n.length;while(f--)g=n[f],!e&&q!==g.origType||c&&c.guid!==g.guid||h&&!h.test(g.namespace)||d&&d!==g.selector&&("**"!==d||!g.selector)||(n.splice(f,1),g.selector&&n.delegateCount--,l.remove&&l.remove.call(a,g));i&&!n.length&&(l.teardown&&l.teardown.call(a,p,r.handle)!==!1||m.removeEvent(a,o,r.handle),delete k[o])}else for(o in k)m.event.remove(a,o+b[j],c,d,!0);m.isEmptyObject(k)&&(delete r.handle,m._removeData(a,"events"))}},trigger:function(b,c,d,e){var f,g,h,i,k,l,n,o=[d||y],p=j.call(b,"type")?b.type:b,q=j.call(b,"namespace")?b.namespace.split("."):[];if(h=l=d=d||y,3!==d.nodeType&&8!==d.nodeType&&!$.test(p+m.event.triggered)&&(p.indexOf(".")>=0&&(q=p.split("."),p=q.shift(),q.sort()),g=p.indexOf(":")<0&&"on"+p,b=b[m.expando]?b:new m.Event(p,"object"==typeof b&&b),b.isTrigger=e?2:3,b.namespace=q.join("."),b.namespace_re=b.namespace?new RegExp("(^|\\.)"+q.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=d),c=null==c?[b]:m.makeArray(c,[b]),k=m.event.special[p]||{},e||!k.trigger||k.trigger.apply(d,c)!==!1)){if(!e&&!k.noBubble&&!m.isWindow(d)){for(i=k.delegateType||p,$.test(i+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),l=h;l===(d.ownerDocument||y)&&o.push(l.defaultView||l.parentWindow||a)}n=0;while((h=o[n++])&&!b.isPropagationStopped())b.type=n>1?i:k.bindType||p,f=(m._data(h,"events")||{})[b.type]&&m._data(h,"handle"),f&&f.apply(h,c),f=g&&h[g],f&&f.apply&&m.acceptData(h)&&(b.result=f.apply(h,c),b.result===!1&&b.preventDefault());if(b.type=p,!e&&!b.isDefaultPrevented()&&(!k._default||k._default.apply(o.pop(),c)===!1)&&m.acceptData(d)&&g&&d[p]&&!m.isWindow(d)){l=d[g],l&&(d[g]=null),m.event.triggered=p;try{d[p]()}catch(r){}m.event.triggered=void 0,l&&(d[g]=l)}return b.result}},dispatch:function(a){a=m.event.fix(a);var b,c,e,f,g,h=[],i=d.call(arguments),j=(m._data(this,"events")||{})[a.type]||[],k=m.event.special[a.type]||{};if(i[0]=a,a.delegateTarget=this,!k.preDispatch||k.preDispatch.call(this,a)!==!1){h=m.event.handlers.call(this,a,j),b=0;while((f=h[b++])&&!a.isPropagationStopped()){a.currentTarget=f.elem,g=0;while((e=f.handlers[g++])&&!a.isImmediatePropagationStopped())(!a.namespace_re||a.namespace_re.test(e.namespace))&&(a.handleObj=e,a.data=e.data,c=((m.event.special[e.origType]||{}).handle||e.handler).apply(f.elem,i),void 0!==c&&(a.result=c)===!1&&(a.preventDefault(),a.stopPropagation()))}return k.postDispatch&&k.postDispatch.call(this,a),a.result}},handlers:function(a,b){var c,d,e,f,g=[],h=b.delegateCount,i=a.target;if(h&&i.nodeType&&(!a.button||"click"!==a.type))for(;i!=this;i=i.parentNode||this)if(1===i.nodeType&&(i.disabled!==!0||"click"!==a.type)){for(e=[],f=0;h>f;f++)d=b[f],c=d.selector+" ",void 0===e[c]&&(e[c]=d.needsContext?m(c,this).index(i)>=0:m.find(c,this,null,[i]).length),e[c]&&e.push(d);e.length&&g.push({elem:i,handlers:e})}return h<b.length&&g.push({elem:this,handlers:b.slice(h)}),g},fix:function(a){if(a[m.expando])return a;var b,c,d,e=a.type,f=a,g=this.fixHooks[e];g||(this.fixHooks[e]=g=Z.test(e)?this.mouseHooks:Y.test(e)?this.keyHooks:{}),d=g.props?this.props.concat(g.props):this.props,a=new m.Event(f),b=d.length;while(b--)c=d[b],a[c]=f[c];return a.target||(a.target=f.srcElement||y),3===a.target.nodeType&&(a.target=a.target.parentNode),a.metaKey=!!a.metaKey,g.filter?g.filter(a,f):a},props:"altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "),fixHooks:{},keyHooks:{props:"char charCode key keyCode".split(" "),filter:function(a,b){return null==a.which&&(a.which=null!=b.charCode?b.charCode:b.keyCode),a}},mouseHooks:{props:"button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "),filter:function(a,b){var c,d,e,f=b.button,g=b.fromElement;return null==a.pageX&&null!=b.clientX&&(d=a.target.ownerDocument||y,e=d.documentElement,c=d.body,a.pageX=b.clientX+(e&&e.scrollLeft||c&&c.scrollLeft||0)-(e&&e.clientLeft||c&&c.clientLeft||0),a.pageY=b.clientY+(e&&e.scrollTop||c&&c.scrollTop||0)-(e&&e.clientTop||c&&c.clientTop||0)),!a.relatedTarget&&g&&(a.relatedTarget=g===a.target?b.toElement:g),a.which||void 0===f||(a.which=1&f?1:2&f?3:4&f?2:0),a}},special:{load:{noBubble:!0},focus:{trigger:function(){if(this!==cb()&&this.focus)try{return this.focus(),!1}catch(a){}},delegateType:"focusin"},blur:{trigger:function(){return this===cb()&&this.blur?(this.blur(),!1):void 0},delegateType:"focusout"},click:{trigger:function(){return m.nodeName(this,"input")&&"checkbox"===this.type&&this.click?(this.click(),!1):void 0},_default:function(a){return m.nodeName(a.target,"a")}},beforeunload:{postDispatch:function(a){void 0!==a.result&&a.originalEvent&&(a.originalEvent.returnValue=a.result)}}},simulate:function(a,b,c,d){var e=m.extend(new m.Event,c,{type:a,isSimulated:!0,originalEvent:{}});d?m.event.trigger(e,null,b):m.event.dispatch.call(b,e),e.isDefaultPrevented()&&c.preventDefault()}},m.removeEvent=y.removeEventListener?function(a,b,c){a.removeEventListener&&a.removeEventListener(b,c,!1)}:function(a,b,c){var d="on"+b;a.detachEvent&&(typeof a[d]===K&&(a[d]=null),a.detachEvent(d,c))},m.Event=function(a,b){return this instanceof m.Event?(a&&a.type?(this.originalEvent=a,this.type=a.type,this.isDefaultPrevented=a.defaultPrevented||void 0===a.defaultPrevented&&a.returnValue===!1?ab:bb):this.type=a,b&&m.extend(this,b),this.timeStamp=a&&a.timeStamp||m.now(),void(this[m.expando]=!0)):new m.Event(a,b)},m.Event.prototype={isDefaultPrevented:bb,isPropagationStopped:bb,isImmediatePropagationStopped:bb,preventDefault:function(){var a=this.originalEvent;this.isDefaultPrevented=ab,a&&(a.preventDefault?a.preventDefault():a.returnValue=!1)},stopPropagation:function(){var a=this.originalEvent;this.isPropagationStopped=ab,a&&(a.stopPropagation&&a.stopPropagation(),a.cancelBubble=!0)},stopImmediatePropagation:function(){var a=this.originalEvent;this.isImmediatePropagationStopped=ab,a&&a.stopImmediatePropagation&&a.stopImmediatePropagation(),this.stopPropagation()}},m.each({mouseenter:"mouseover",mouseleave:"mouseout",pointerenter:"pointerover",pointerleave:"pointerout"},function(a,b){m.event.special[a]={delegateType:b,bindType:b,handle:function(a){var c,d=this,e=a.relatedTarget,f=a.handleObj;return(!e||e!==d&&!m.contains(d,e))&&(a.type=f.origType,c=f.handler.apply(this,arguments),a.type=b),c}}}),k.submitBubbles||(m.event.special.submit={setup:function(){return m.nodeName(this,"form")?!1:void m.event.add(this,"click._submit keypress._submit",function(a){var b=a.target,c=m.nodeName(b,"input")||m.nodeName(b,"button")?b.form:void 0;c&&!m._data(c,"submitBubbles")&&(m.event.add(c,"submit._submit",function(a){a._submit_bubble=!0}),m._data(c,"submitBubbles",!0))})},postDispatch:function(a){a._submit_bubble&&(delete a._submit_bubble,this.parentNode&&!a.isTrigger&&m.event.simulate("submit",this.parentNode,a,!0))},teardown:function(){return m.nodeName(this,"form")?!1:void m.event.remove(this,"._submit")}}),k.changeBubbles||(m.event.special.change={setup:function(){return X.test(this.nodeName)?(("checkbox"===this.type||"radio"===this.type)&&(m.event.add(this,"propertychange._change",function(a){"checked"===a.originalEvent.propertyName&&(this._just_changed=!0)}),m.event.add(this,"click._change",function(a){this._just_changed&&!a.isTrigger&&(this._just_changed=!1),m.event.simulate("change",this,a,!0)})),!1):void m.event.add(this,"beforeactivate._change",function(a){var b=a.target;X.test(b.nodeName)&&!m._data(b,"changeBubbles")&&(m.event.add(b,"change._change",function(a){!this.parentNode||a.isSimulated||a.isTrigger||m.event.simulate("change",this.parentNode,a,!0)}),m._data(b,"changeBubbles",!0))})},handle:function(a){var b=a.target;return this!==b||a.isSimulated||a.isTrigger||"radio"!==b.type&&"checkbox"!==b.type?a.handleObj.handler.apply(this,arguments):void 0},teardown:function(){return m.event.remove(this,"._change"),!X.test(this.nodeName)}}),k.focusinBubbles||m.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){m.event.simulate(b,a.target,m.event.fix(a),!0)};m.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=m._data(d,b);e||d.addEventListener(a,c,!0),m._data(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=m._data(d,b)-1;e?m._data(d,b,e):(d.removeEventListener(a,c,!0),m._removeData(d,b))}}}),m.fn.extend({on:function(a,b,c,d,e){var f,g;if("object"==typeof a){"string"!=typeof b&&(c=c||b,b=void 0);for(f in a)this.on(f,b,c,a[f],e);return this}if(null==c&&null==d?(d=b,c=b=void 0):null==d&&("string"==typeof b?(d=c,c=void 0):(d=c,c=b,b=void 0)),d===!1)d=bb;else if(!d)return this;return 1===e&&(g=d,d=function(a){return m().off(a),g.apply(this,arguments)},d.guid=g.guid||(g.guid=m.guid++)),this.each(function(){m.event.add(this,a,d,c,b)})},one:function(a,b,c,d){return this.on(a,b,c,d,1)},off:function(a,b,c){var d,e;if(a&&a.preventDefault&&a.handleObj)return d=a.handleObj,m(a.delegateTarget).off(d.namespace?d.origType+"."+d.namespace:d.origType,d.selector,d.handler),this;if("object"==typeof a){for(e in a)this.off(e,b,a[e]);return this}return(b===!1||"function"==typeof b)&&(c=b,b=void 0),c===!1&&(c=bb),this.each(function(){m.event.remove(this,a,c,b)})},trigger:function(a,b){return this.each(function(){m.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];return c?m.event.trigger(a,b,c,!0):void 0}});function db(a){var b=eb.split("|"),c=a.createDocumentFragment();if(c.createElement)while(b.length)c.createElement(b.pop());return c}var eb="abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|header|hgroup|mark|meter|nav|output|progress|section|summary|time|video",fb=/ jQuery\d+="(?:null|\d+)"/g,gb=new RegExp("<(?:"+eb+")[\\s/>]","i"),hb=/^\s+/,ib=/<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi,jb=/<([\w:]+)/,kb=/<tbody/i,lb=/<|&#?\w+;/,mb=/<(?:script|style|link)/i,nb=/checked\s*(?:[^=]|=\s*.checked.)/i,ob=/^$|\/(?:java|ecma)script/i,pb=/^true\/(.*)/,qb=/^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g,rb={option:[1,"<select multiple='multiple'>","</select>"],legend:[1,"<fieldset>","</fieldset>"],area:[1,"<map>","</map>"],param:[1,"<object>","</object>"],thead:[1,"<table>","</table>"],tr:[2,"<table><tbody>","</tbody></table>"],col:[2,"<table><tbody></tbody><colgroup>","</colgroup></table>"],td:[3,"<table><tbody><tr>","</tr></tbody></table>"],_default:k.htmlSerialize?[0,"",""]:[1,"X<div>","</div>"]},sb=db(y),tb=sb.appendChild(y.createElement("div"));rb.optgroup=rb.option,rb.tbody=rb.tfoot=rb.colgroup=rb.caption=rb.thead,rb.th=rb.td;function ub(a,b){var c,d,e=0,f=typeof a.getElementsByTagName!==K?a.getElementsByTagName(b||"*"):typeof a.querySelectorAll!==K?a.querySelectorAll(b||"*"):void 0;if(!f)for(f=[],c=a.childNodes||a;null!=(d=c[e]);e++)!b||m.nodeName(d,b)?f.push(d):m.merge(f,ub(d,b));return void 0===b||b&&m.nodeName(a,b)?m.merge([a],f):f}function vb(a){W.test(a.type)&&(a.defaultChecked=a.checked)}function wb(a,b){return m.nodeName(a,"table")&&m.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a.appendChild(a.ownerDocument.createElement("tbody")):a}function xb(a){return a.type=(null!==m.find.attr(a,"type"))+"/"+a.type,a}function yb(a){var b=pb.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function zb(a,b){for(var c,d=0;null!=(c=a[d]);d++)m._data(c,"globalEval",!b||m._data(b[d],"globalEval"))}function Ab(a,b){if(1===b.nodeType&&m.hasData(a)){var c,d,e,f=m._data(a),g=m._data(b,f),h=f.events;if(h){delete g.handle,g.events={};for(c in h)for(d=0,e=h[c].length;e>d;d++)m.event.add(b,c,h[c][d])}g.data&&(g.data=m.extend({},g.data))}}function Bb(a,b){var c,d,e;if(1===b.nodeType){if(c=b.nodeName.toLowerCase(),!k.noCloneEvent&&b[m.expando]){e=m._data(b);for(d in e.events)m.removeEvent(b,d,e.handle);b.removeAttribute(m.expando)}"script"===c&&b.text!==a.text?(xb(b).text=a.text,yb(b)):"object"===c?(b.parentNode&&(b.outerHTML=a.outerHTML),k.html5Clone&&a.innerHTML&&!m.trim(b.innerHTML)&&(b.innerHTML=a.innerHTML)):"input"===c&&W.test(a.type)?(b.defaultChecked=b.checked=a.checked,b.value!==a.value&&(b.value=a.value)):"option"===c?b.defaultSelected=b.selected=a.defaultSelected:("input"===c||"textarea"===c)&&(b.defaultValue=a.defaultValue)}}m.extend({clone:function(a,b,c){var d,e,f,g,h,i=m.contains(a.ownerDocument,a);if(k.html5Clone||m.isXMLDoc(a)||!gb.test("<"+a.nodeName+">")?f=a.cloneNode(!0):(tb.innerHTML=a.outerHTML,tb.removeChild(f=tb.firstChild)),!(k.noCloneEvent&&k.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||m.isXMLDoc(a)))for(d=ub(f),h=ub(a),g=0;null!=(e=h[g]);++g)d[g]&&Bb(e,d[g]);if(b)if(c)for(h=h||ub(a),d=d||ub(f),g=0;null!=(e=h[g]);g++)Ab(e,d[g]);else Ab(a,f);return d=ub(f,"script"),d.length>0&&zb(d,!i&&ub(a,"script")),d=h=e=null,f},buildFragment:function(a,b,c,d){for(var e,f,g,h,i,j,l,n=a.length,o=db(b),p=[],q=0;n>q;q++)if(f=a[q],f||0===f)if("object"===m.type(f))m.merge(p,f.nodeType?[f]:f);else if(lb.test(f)){h=h||o.appendChild(b.createElement("div")),i=(jb.exec(f)||["",""])[1].toLowerCase(),l=rb[i]||rb._default,h.innerHTML=l[1]+f.replace(ib,"<$1></$2>")+l[2],e=l[0];while(e--)h=h.lastChild;if(!k.leadingWhitespace&&hb.test(f)&&p.push(b.createTextNode(hb.exec(f)[0])),!k.tbody){f="table"!==i||kb.test(f)?"<table>"!==l[1]||kb.test(f)?0:h:h.firstChild,e=f&&f.childNodes.length;while(e--)m.nodeName(j=f.childNodes[e],"tbody")&&!j.childNodes.length&&f.removeChild(j)}m.merge(p,h.childNodes),h.textContent="";while(h.firstChild)h.removeChild(h.firstChild);h=o.lastChild}else p.push(b.createTextNode(f));h&&o.removeChild(h),k.appendChecked||m.grep(ub(p,"input"),vb),q=0;while(f=p[q++])if((!d||-1===m.inArray(f,d))&&(g=m.contains(f.ownerDocument,f),h=ub(o.appendChild(f),"script"),g&&zb(h),c)){e=0;while(f=h[e++])ob.test(f.type||"")&&c.push(f)}return h=null,o},cleanData:function(a,b){for(var d,e,f,g,h=0,i=m.expando,j=m.cache,l=k.deleteExpando,n=m.event.special;null!=(d=a[h]);h++)if((b||m.acceptData(d))&&(f=d[i],g=f&&j[f])){if(g.events)for(e in g.events)n[e]?m.event.remove(d,e):m.removeEvent(d,e,g.handle);j[f]&&(delete j[f],l?delete d[i]:typeof d.removeAttribute!==K?d.removeAttribute(i):d[i]=null,c.push(f))}}}),m.fn.extend({text:function(a){return V(this,function(a){return void 0===a?m.text(this):this.empty().append((this[0]&&this[0].ownerDocument||y).createTextNode(a))},null,a,arguments.length)},append:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wb(this,a);b.appendChild(a)}})},prepend:function(){return this.domManip(arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=wb(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return this.domManip(arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},remove:function(a,b){for(var c,d=a?m.filter(a,this):this,e=0;null!=(c=d[e]);e++)b||1!==c.nodeType||m.cleanData(ub(c)),c.parentNode&&(b&&m.contains(c.ownerDocument,c)&&zb(ub(c,"script")),c.parentNode.removeChild(c));return this},empty:function(){for(var a,b=0;null!=(a=this[b]);b++){1===a.nodeType&&m.cleanData(ub(a,!1));while(a.firstChild)a.removeChild(a.firstChild);a.options&&m.nodeName(a,"select")&&(a.options.length=0)}return this},clone:function(a,b){return a=null==a?!1:a,b=null==b?a:b,this.map(function(){return m.clone(this,a,b)})},html:function(a){return V(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a)return 1===b.nodeType?b.innerHTML.replace(fb,""):void 0;if(!("string"!=typeof a||mb.test(a)||!k.htmlSerialize&&gb.test(a)||!k.leadingWhitespace&&hb.test(a)||rb[(jb.exec(a)||["",""])[1].toLowerCase()])){a=a.replace(ib,"<$1></$2>");try{for(;d>c;c++)b=this[c]||{},1===b.nodeType&&(m.cleanData(ub(b,!1)),b.innerHTML=a);b=0}catch(e){}}b&&this.empty().append(a)},null,a,arguments.length)},replaceWith:function(){var a=arguments[0];return this.domManip(arguments,function(b){a=this.parentNode,m.cleanData(ub(this)),a&&a.replaceChild(b,this)}),a&&(a.length||a.nodeType)?this:this.remove()},detach:function(a){return this.remove(a,!0)},domManip:function(a,b){a=e.apply([],a);var c,d,f,g,h,i,j=0,l=this.length,n=this,o=l-1,p=a[0],q=m.isFunction(p);if(q||l>1&&"string"==typeof p&&!k.checkClone&&nb.test(p))return this.each(function(c){var d=n.eq(c);q&&(a[0]=p.call(this,c,d.html())),d.domManip(a,b)});if(l&&(i=m.buildFragment(a,this[0].ownerDocument,!1,this),c=i.firstChild,1===i.childNodes.length&&(i=c),c)){for(g=m.map(ub(i,"script"),xb),f=g.length;l>j;j++)d=i,j!==o&&(d=m.clone(d,!0,!0),f&&m.merge(g,ub(d,"script"))),b.call(this[j],d,j);if(f)for(h=g[g.length-1].ownerDocument,m.map(g,yb),j=0;f>j;j++)d=g[j],ob.test(d.type||"")&&!m._data(d,"globalEval")&&m.contains(h,d)&&(d.src?m._evalUrl&&m._evalUrl(d.src):m.globalEval((d.text||d.textContent||d.innerHTML||"").replace(qb,"")));i=c=null}return this}}),m.each({appendTo:"append",prependTo:"prepend",insertBefore:"before",insertAfter:"after",replaceAll:"replaceWith"},function(a,b){m.fn[a]=function(a){for(var c,d=0,e=[],g=m(a),h=g.length-1;h>=d;d++)c=d===h?this:this.clone(!0),m(g[d])[b](c),f.apply(e,c.get());return this.pushStack(e)}});var Cb,Db={};function Eb(b,c){var d,e=m(c.createElement(b)).appendTo(c.body),f=a.getDefaultComputedStyle&&(d=a.getDefaultComputedStyle(e[0]))?d.display:m.css(e[0],"display");return e.detach(),f}function Fb(a){var b=y,c=Db[a];return c||(c=Eb(a,b),"none"!==c&&c||(Cb=(Cb||m("<iframe frameborder='0' width='0' height='0'/>")).appendTo(b.documentElement),b=(Cb[0].contentWindow||Cb[0].contentDocument).document,b.write(),b.close(),c=Eb(a,b),Cb.detach()),Db[a]=c),c}!function(){var a;k.shrinkWrapBlocks=function(){if(null!=a)return a;a=!1;var b,c,d;return c=y.getElementsByTagName("body")[0],c&&c.style?(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),typeof b.style.zoom!==K&&(b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:1px;width:1px;zoom:1",b.appendChild(y.createElement("div")).style.width="5px",a=3!==b.offsetWidth),c.removeChild(d),a):void 0}}();var Gb=/^margin/,Hb=new RegExp("^("+S+")(?!px)[a-z%]+$","i"),Ib,Jb,Kb=/^(top|right|bottom|left)$/;a.getComputedStyle?(Ib=function(a){return a.ownerDocument.defaultView.getComputedStyle(a,null)},Jb=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ib(a),g=c?c.getPropertyValue(b)||c[b]:void 0,c&&(""!==g||m.contains(a.ownerDocument,a)||(g=m.style(a,b)),Hb.test(g)&&Gb.test(b)&&(d=h.width,e=h.minWidth,f=h.maxWidth,h.minWidth=h.maxWidth=h.width=g,g=c.width,h.width=d,h.minWidth=e,h.maxWidth=f)),void 0===g?g:g+""}):y.documentElement.currentStyle&&(Ib=function(a){return a.currentStyle},Jb=function(a,b,c){var d,e,f,g,h=a.style;return c=c||Ib(a),g=c?c[b]:void 0,null==g&&h&&h[b]&&(g=h[b]),Hb.test(g)&&!Kb.test(b)&&(d=h.left,e=a.runtimeStyle,f=e&&e.left,f&&(e.left=a.currentStyle.left),h.left="fontSize"===b?"1em":g,g=h.pixelLeft+"px",h.left=d,f&&(e.left=f)),void 0===g?g:g+""||"auto"});function Lb(a,b){return{get:function(){var c=a();if(null!=c)return c?void delete this.get:(this.get=b).apply(this,arguments)}}}!function(){var b,c,d,e,f,g,h;if(b=y.createElement("div"),b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",d=b.getElementsByTagName("a")[0],c=d&&d.style){c.cssText="float:left;opacity:.5",k.opacity="0.5"===c.opacity,k.cssFloat=!!c.cssFloat,b.style.backgroundClip="content-box",b.cloneNode(!0).style.backgroundClip="",k.clearCloneStyle="content-box"===b.style.backgroundClip,k.boxSizing=""===c.boxSizing||""===c.MozBoxSizing||""===c.WebkitBoxSizing,m.extend(k,{reliableHiddenOffsets:function(){return null==g&&i(),g},boxSizingReliable:function(){return null==f&&i(),f},pixelPosition:function(){return null==e&&i(),e},reliableMarginRight:function(){return null==h&&i(),h}});function i(){var b,c,d,i;c=y.getElementsByTagName("body")[0],c&&c.style&&(b=y.createElement("div"),d=y.createElement("div"),d.style.cssText="position:absolute;border:0;width:0;height:0;top:0;left:-9999px",c.appendChild(d).appendChild(b),b.style.cssText="-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;display:block;margin-top:1%;top:1%;border:1px;padding:1px;width:4px;position:absolute",e=f=!1,h=!0,a.getComputedStyle&&(e="1%"!==(a.getComputedStyle(b,null)||{}).top,f="4px"===(a.getComputedStyle(b,null)||{width:"4px"}).width,i=b.appendChild(y.createElement("div")),i.style.cssText=b.style.cssText="-webkit-box-sizing:content-box;-moz-box-sizing:content-box;box-sizing:content-box;display:block;margin:0;border:0;padding:0",i.style.marginRight=i.style.width="0",b.style.width="1px",h=!parseFloat((a.getComputedStyle(i,null)||{}).marginRight)),b.innerHTML="<table><tr><td></td><td>t</td></tr></table>",i=b.getElementsByTagName("td"),i[0].style.cssText="margin:0;border:0;padding:0;display:none",g=0===i[0].offsetHeight,g&&(i[0].style.display="",i[1].style.display="none",g=0===i[0].offsetHeight),c.removeChild(d))}}}(),m.swap=function(a,b,c,d){var e,f,g={};for(f in b)g[f]=a.style[f],a.style[f]=b[f];e=c.apply(a,d||[]);for(f in b)a.style[f]=g[f];return e};var Mb=/alpha\([^)]*\)/i,Nb=/opacity\s*=\s*([^)]*)/,Ob=/^(none|table(?!-c[ea]).+)/,Pb=new RegExp("^("+S+")(.*)$","i"),Qb=new RegExp("^([+-])=("+S+")","i"),Rb={position:"absolute",visibility:"hidden",display:"block"},Sb={letterSpacing:"0",fontWeight:"400"},Tb=["Webkit","O","Moz","ms"];function Ub(a,b){if(b in a)return b;var c=b.charAt(0).toUpperCase()+b.slice(1),d=b,e=Tb.length;while(e--)if(b=Tb[e]+c,b in a)return b;return d}function Vb(a,b){for(var c,d,e,f=[],g=0,h=a.length;h>g;g++)d=a[g],d.style&&(f[g]=m._data(d,"olddisplay"),c=d.style.display,b?(f[g]||"none"!==c||(d.style.display=""),""===d.style.display&&U(d)&&(f[g]=m._data(d,"olddisplay",Fb(d.nodeName)))):(e=U(d),(c&&"none"!==c||!e)&&m._data(d,"olddisplay",e?c:m.css(d,"display"))));for(g=0;h>g;g++)d=a[g],d.style&&(b&&"none"!==d.style.display&&""!==d.style.display||(d.style.display=b?f[g]||"":"none"));return a}function Wb(a,b,c){var d=Pb.exec(b);return d?Math.max(0,d[1]-(c||0))+(d[2]||"px"):b}function Xb(a,b,c,d,e){for(var f=c===(d?"border":"content")?4:"width"===b?1:0,g=0;4>f;f+=2)"margin"===c&&(g+=m.css(a,c+T[f],!0,e)),d?("content"===c&&(g-=m.css(a,"padding"+T[f],!0,e)),"margin"!==c&&(g-=m.css(a,"border"+T[f]+"Width",!0,e))):(g+=m.css(a,"padding"+T[f],!0,e),"padding"!==c&&(g+=m.css(a,"border"+T[f]+"Width",!0,e)));return g}function Yb(a,b,c){var d=!0,e="width"===b?a.offsetWidth:a.offsetHeight,f=Ib(a),g=k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,f);if(0>=e||null==e){if(e=Jb(a,b,f),(0>e||null==e)&&(e=a.style[b]),Hb.test(e))return e;d=g&&(k.boxSizingReliable()||e===a.style[b]),e=parseFloat(e)||0}return e+Xb(a,b,c||(g?"border":"content"),d,f)+"px"}m.extend({cssHooks:{opacity:{get:function(a,b){if(b){var c=Jb(a,"opacity");return""===c?"1":c}}}},cssNumber:{columnCount:!0,fillOpacity:!0,flexGrow:!0,flexShrink:!0,fontWeight:!0,lineHeight:!0,opacity:!0,order:!0,orphans:!0,widows:!0,zIndex:!0,zoom:!0},cssProps:{"float":k.cssFloat?"cssFloat":"styleFloat"},style:function(a,b,c,d){if(a&&3!==a.nodeType&&8!==a.nodeType&&a.style){var e,f,g,h=m.camelCase(b),i=a.style;if(b=m.cssProps[h]||(m.cssProps[h]=Ub(i,h)),g=m.cssHooks[b]||m.cssHooks[h],void 0===c)return g&&"get"in g&&void 0!==(e=g.get(a,!1,d))?e:i[b];if(f=typeof c,"string"===f&&(e=Qb.exec(c))&&(c=(e[1]+1)*e[2]+parseFloat(m.css(a,b)),f="number"),null!=c&&c===c&&("number"!==f||m.cssNumber[h]||(c+="px"),k.clearCloneStyle||""!==c||0!==b.indexOf("background")||(i[b]="inherit"),!(g&&"set"in g&&void 0===(c=g.set(a,c,d)))))try{i[b]=c}catch(j){}}},css:function(a,b,c,d){var e,f,g,h=m.camelCase(b);return b=m.cssProps[h]||(m.cssProps[h]=Ub(a.style,h)),g=m.cssHooks[b]||m.cssHooks[h],g&&"get"in g&&(f=g.get(a,!0,c)),void 0===f&&(f=Jb(a,b,d)),"normal"===f&&b in Sb&&(f=Sb[b]),""===c||c?(e=parseFloat(f),c===!0||m.isNumeric(e)?e||0:f):f}}),m.each(["height","width"],function(a,b){m.cssHooks[b]={get:function(a,c,d){return c?Ob.test(m.css(a,"display"))&&0===a.offsetWidth?m.swap(a,Rb,function(){return Yb(a,b,d)}):Yb(a,b,d):void 0},set:function(a,c,d){var e=d&&Ib(a);return Wb(a,c,d?Xb(a,b,d,k.boxSizing&&"border-box"===m.css(a,"boxSizing",!1,e),e):0)}}}),k.opacity||(m.cssHooks.opacity={get:function(a,b){return Nb.test((b&&a.currentStyle?a.currentStyle.filter:a.style.filter)||"")?.01*parseFloat(RegExp.$1)+"":b?"1":""},set:function(a,b){var c=a.style,d=a.currentStyle,e=m.isNumeric(b)?"alpha(opacity="+100*b+")":"",f=d&&d.filter||c.filter||"";c.zoom=1,(b>=1||""===b)&&""===m.trim(f.replace(Mb,""))&&c.removeAttribute&&(c.removeAttribute("filter"),""===b||d&&!d.filter)||(c.filter=Mb.test(f)?f.replace(Mb,e):f+" "+e)}}),m.cssHooks.marginRight=Lb(k.reliableMarginRight,function(a,b){return b?m.swap(a,{display:"inline-block"},Jb,[a,"marginRight"]):void 0}),m.each({margin:"",padding:"",border:"Width"},function(a,b){m.cssHooks[a+b]={expand:function(c){for(var d=0,e={},f="string"==typeof c?c.split(" "):[c];4>d;d++)e[a+T[d]+b]=f[d]||f[d-2]||f[0];return e}},Gb.test(a)||(m.cssHooks[a+b].set=Wb)}),m.fn.extend({css:function(a,b){return V(this,function(a,b,c){var d,e,f={},g=0;if(m.isArray(b)){for(d=Ib(a),e=b.length;e>g;g++)f[b[g]]=m.css(a,b[g],!1,d);return f}return void 0!==c?m.style(a,b,c):m.css(a,b)},a,b,arguments.length>1)},show:function(){return Vb(this,!0)},hide:function(){return Vb(this)},toggle:function(a){return"boolean"==typeof a?a?this.show():this.hide():this.each(function(){U(this)?m(this).show():m(this).hide()})}});function Zb(a,b,c,d,e){return new Zb.prototype.init(a,b,c,d,e)}m.Tween=Zb,Zb.prototype={constructor:Zb,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||"swing",this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(m.cssNumber[c]?"":"px")
4 +},cur:function(){var a=Zb.propHooks[this.prop];return a&&a.get?a.get(this):Zb.propHooks._default.get(this)},run:function(a){var b,c=Zb.propHooks[this.prop];return this.pos=b=this.options.duration?m.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Zb.propHooks._default.set(this),this}},Zb.prototype.init.prototype=Zb.prototype,Zb.propHooks={_default:{get:function(a){var b;return null==a.elem[a.prop]||a.elem.style&&null!=a.elem.style[a.prop]?(b=m.css(a.elem,a.prop,""),b&&"auto"!==b?b:0):a.elem[a.prop]},set:function(a){m.fx.step[a.prop]?m.fx.step[a.prop](a):a.elem.style&&(null!=a.elem.style[m.cssProps[a.prop]]||m.cssHooks[a.prop])?m.style(a.elem,a.prop,a.now+a.unit):a.elem[a.prop]=a.now}}},Zb.propHooks.scrollTop=Zb.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},m.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2}},m.fx=Zb.prototype.init,m.fx.step={};var $b,_b,ac=/^(?:toggle|show|hide)$/,bc=new RegExp("^(?:([+-])=|)("+S+")([a-z%]*)$","i"),cc=/queueHooks$/,dc=[ic],ec={"*":[function(a,b){var c=this.createTween(a,b),d=c.cur(),e=bc.exec(b),f=e&&e[3]||(m.cssNumber[a]?"":"px"),g=(m.cssNumber[a]||"px"!==f&&+d)&&bc.exec(m.css(c.elem,a)),h=1,i=20;if(g&&g[3]!==f){f=f||g[3],e=e||[],g=+d||1;do h=h||".5",g/=h,m.style(c.elem,a,g+f);while(h!==(h=c.cur()/d)&&1!==h&&--i)}return e&&(g=c.start=+g||+d||0,c.unit=f,c.end=e[1]?g+(e[1]+1)*e[2]:+e[2]),c}]};function fc(){return setTimeout(function(){$b=void 0}),$b=m.now()}function gc(a,b){var c,d={height:a},e=0;for(b=b?1:0;4>e;e+=2-b)c=T[e],d["margin"+c]=d["padding"+c]=a;return b&&(d.opacity=d.width=a),d}function hc(a,b,c){for(var d,e=(ec[b]||[]).concat(ec["*"]),f=0,g=e.length;g>f;f++)if(d=e[f].call(c,b,a))return d}function ic(a,b,c){var d,e,f,g,h,i,j,l,n=this,o={},p=a.style,q=a.nodeType&&U(a),r=m._data(a,"fxshow");c.queue||(h=m._queueHooks(a,"fx"),null==h.unqueued&&(h.unqueued=0,i=h.empty.fire,h.empty.fire=function(){h.unqueued||i()}),h.unqueued++,n.always(function(){n.always(function(){h.unqueued--,m.queue(a,"fx").length||h.empty.fire()})})),1===a.nodeType&&("height"in b||"width"in b)&&(c.overflow=[p.overflow,p.overflowX,p.overflowY],j=m.css(a,"display"),l="none"===j?m._data(a,"olddisplay")||Fb(a.nodeName):j,"inline"===l&&"none"===m.css(a,"float")&&(k.inlineBlockNeedsLayout&&"inline"!==Fb(a.nodeName)?p.zoom=1:p.display="inline-block")),c.overflow&&(p.overflow="hidden",k.shrinkWrapBlocks()||n.always(function(){p.overflow=c.overflow[0],p.overflowX=c.overflow[1],p.overflowY=c.overflow[2]}));for(d in b)if(e=b[d],ac.exec(e)){if(delete b[d],f=f||"toggle"===e,e===(q?"hide":"show")){if("show"!==e||!r||void 0===r[d])continue;q=!0}o[d]=r&&r[d]||m.style(a,d)}else j=void 0;if(m.isEmptyObject(o))"inline"===("none"===j?Fb(a.nodeName):j)&&(p.display=j);else{r?"hidden"in r&&(q=r.hidden):r=m._data(a,"fxshow",{}),f&&(r.hidden=!q),q?m(a).show():n.done(function(){m(a).hide()}),n.done(function(){var b;m._removeData(a,"fxshow");for(b in o)m.style(a,b,o[b])});for(d in o)g=hc(q?r[d]:0,d,n),d in r||(r[d]=g.start,q&&(g.end=g.start,g.start="width"===d||"height"===d?1:0))}}function jc(a,b){var c,d,e,f,g;for(c in a)if(d=m.camelCase(c),e=b[d],f=a[c],m.isArray(f)&&(e=f[1],f=a[c]=f[0]),c!==d&&(a[d]=f,delete a[c]),g=m.cssHooks[d],g&&"expand"in g){f=g.expand(f),delete a[d];for(c in f)c in a||(a[c]=f[c],b[c]=e)}else b[d]=e}function kc(a,b,c){var d,e,f=0,g=dc.length,h=m.Deferred().always(function(){delete i.elem}),i=function(){if(e)return!1;for(var b=$b||fc(),c=Math.max(0,j.startTime+j.duration-b),d=c/j.duration||0,f=1-d,g=0,i=j.tweens.length;i>g;g++)j.tweens[g].run(f);return h.notifyWith(a,[j,f,c]),1>f&&i?c:(h.resolveWith(a,[j]),!1)},j=h.promise({elem:a,props:m.extend({},b),opts:m.extend(!0,{specialEasing:{}},c),originalProperties:b,originalOptions:c,startTime:$b||fc(),duration:c.duration,tweens:[],createTween:function(b,c){var d=m.Tween(a,j.opts,b,c,j.opts.specialEasing[b]||j.opts.easing);return j.tweens.push(d),d},stop:function(b){var c=0,d=b?j.tweens.length:0;if(e)return this;for(e=!0;d>c;c++)j.tweens[c].run(1);return b?h.resolveWith(a,[j,b]):h.rejectWith(a,[j,b]),this}}),k=j.props;for(jc(k,j.opts.specialEasing);g>f;f++)if(d=dc[f].call(j,a,k,j.opts))return d;return m.map(k,hc,j),m.isFunction(j.opts.start)&&j.opts.start.call(a,j),m.fx.timer(m.extend(i,{elem:a,anim:j,queue:j.opts.queue})),j.progress(j.opts.progress).done(j.opts.done,j.opts.complete).fail(j.opts.fail).always(j.opts.always)}m.Animation=m.extend(kc,{tweener:function(a,b){m.isFunction(a)?(b=a,a=["*"]):a=a.split(" ");for(var c,d=0,e=a.length;e>d;d++)c=a[d],ec[c]=ec[c]||[],ec[c].unshift(b)},prefilter:function(a,b){b?dc.unshift(a):dc.push(a)}}),m.speed=function(a,b,c){var d=a&&"object"==typeof a?m.extend({},a):{complete:c||!c&&b||m.isFunction(a)&&a,duration:a,easing:c&&b||b&&!m.isFunction(b)&&b};return d.duration=m.fx.off?0:"number"==typeof d.duration?d.duration:d.duration in m.fx.speeds?m.fx.speeds[d.duration]:m.fx.speeds._default,(null==d.queue||d.queue===!0)&&(d.queue="fx"),d.old=d.complete,d.complete=function(){m.isFunction(d.old)&&d.old.call(this),d.queue&&m.dequeue(this,d.queue)},d},m.fn.extend({fadeTo:function(a,b,c,d){return this.filter(U).css("opacity",0).show().end().animate({opacity:b},a,c,d)},animate:function(a,b,c,d){var e=m.isEmptyObject(a),f=m.speed(b,c,d),g=function(){var b=kc(this,m.extend({},a),f);(e||m._data(this,"finish"))&&b.stop(!0)};return g.finish=g,e||f.queue===!1?this.each(g):this.queue(f.queue,g)},stop:function(a,b,c){var d=function(a){var b=a.stop;delete a.stop,b(c)};return"string"!=typeof a&&(c=b,b=a,a=void 0),b&&a!==!1&&this.queue(a||"fx",[]),this.each(function(){var b=!0,e=null!=a&&a+"queueHooks",f=m.timers,g=m._data(this);if(e)g[e]&&g[e].stop&&d(g[e]);else for(e in g)g[e]&&g[e].stop&&cc.test(e)&&d(g[e]);for(e=f.length;e--;)f[e].elem!==this||null!=a&&f[e].queue!==a||(f[e].anim.stop(c),b=!1,f.splice(e,1));(b||!c)&&m.dequeue(this,a)})},finish:function(a){return a!==!1&&(a=a||"fx"),this.each(function(){var b,c=m._data(this),d=c[a+"queue"],e=c[a+"queueHooks"],f=m.timers,g=d?d.length:0;for(c.finish=!0,m.queue(this,a,[]),e&&e.stop&&e.stop.call(this,!0),b=f.length;b--;)f[b].elem===this&&f[b].queue===a&&(f[b].anim.stop(!0),f.splice(b,1));for(b=0;g>b;b++)d[b]&&d[b].finish&&d[b].finish.call(this);delete c.finish})}}),m.each(["toggle","show","hide"],function(a,b){var c=m.fn[b];m.fn[b]=function(a,d,e){return null==a||"boolean"==typeof a?c.apply(this,arguments):this.animate(gc(b,!0),a,d,e)}}),m.each({slideDown:gc("show"),slideUp:gc("hide"),slideToggle:gc("toggle"),fadeIn:{opacity:"show"},fadeOut:{opacity:"hide"},fadeToggle:{opacity:"toggle"}},function(a,b){m.fn[a]=function(a,c,d){return this.animate(b,a,c,d)}}),m.timers=[],m.fx.tick=function(){var a,b=m.timers,c=0;for($b=m.now();c<b.length;c++)a=b[c],a()||b[c]!==a||b.splice(c--,1);b.length||m.fx.stop(),$b=void 0},m.fx.timer=function(a){m.timers.push(a),a()?m.fx.start():m.timers.pop()},m.fx.interval=13,m.fx.start=function(){_b||(_b=setInterval(m.fx.tick,m.fx.interval))},m.fx.stop=function(){clearInterval(_b),_b=null},m.fx.speeds={slow:600,fast:200,_default:400},m.fn.delay=function(a,b){return a=m.fx?m.fx.speeds[a]||a:a,b=b||"fx",this.queue(b,function(b,c){var d=setTimeout(b,a);c.stop=function(){clearTimeout(d)}})},function(){var a,b,c,d,e;b=y.createElement("div"),b.setAttribute("className","t"),b.innerHTML=" <link/><table></table><a href='/a'>a</a><input type='checkbox'/>",d=b.getElementsByTagName("a")[0],c=y.createElement("select"),e=c.appendChild(y.createElement("option")),a=b.getElementsByTagName("input")[0],d.style.cssText="top:1px",k.getSetAttribute="t"!==b.className,k.style=/top/.test(d.getAttribute("style")),k.hrefNormalized="/a"===d.getAttribute("href"),k.checkOn=!!a.value,k.optSelected=e.selected,k.enctype=!!y.createElement("form").enctype,c.disabled=!0,k.optDisabled=!e.disabled,a=y.createElement("input"),a.setAttribute("value",""),k.input=""===a.getAttribute("value"),a.value="t",a.setAttribute("type","radio"),k.radioValue="t"===a.value}();var lc=/\r/g;m.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=m.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,m(this).val()):a,null==e?e="":"number"==typeof e?e+="":m.isArray(e)&&(e=m.map(e,function(a){return null==a?"":a+""})),b=m.valHooks[this.type]||m.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=m.valHooks[e.type]||m.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(lc,""):null==c?"":c)}}}),m.extend({valHooks:{option:{get:function(a){var b=m.find.attr(a,"value");return null!=b?b:m.trim(m.text(a))}},select:{get:function(a){for(var b,c,d=a.options,e=a.selectedIndex,f="select-one"===a.type||0>e,g=f?null:[],h=f?e+1:d.length,i=0>e?h:f?e:0;h>i;i++)if(c=d[i],!(!c.selected&&i!==e||(k.optDisabled?c.disabled:null!==c.getAttribute("disabled"))||c.parentNode.disabled&&m.nodeName(c.parentNode,"optgroup"))){if(b=m(c).val(),f)return b;g.push(b)}return g},set:function(a,b){var c,d,e=a.options,f=m.makeArray(b),g=e.length;while(g--)if(d=e[g],m.inArray(m.valHooks.option.get(d),f)>=0)try{d.selected=c=!0}catch(h){d.scrollHeight}else d.selected=!1;return c||(a.selectedIndex=-1),e}}}}),m.each(["radio","checkbox"],function(){m.valHooks[this]={set:function(a,b){return m.isArray(b)?a.checked=m.inArray(m(a).val(),b)>=0:void 0}},k.checkOn||(m.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var mc,nc,oc=m.expr.attrHandle,pc=/^(?:checked|selected)$/i,qc=k.getSetAttribute,rc=k.input;m.fn.extend({attr:function(a,b){return V(this,m.attr,a,b,arguments.length>1)},removeAttr:function(a){return this.each(function(){m.removeAttr(this,a)})}}),m.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(a&&3!==f&&8!==f&&2!==f)return typeof a.getAttribute===K?m.prop(a,b,c):(1===f&&m.isXMLDoc(a)||(b=b.toLowerCase(),d=m.attrHooks[b]||(m.expr.match.bool.test(b)?nc:mc)),void 0===c?d&&"get"in d&&null!==(e=d.get(a,b))?e:(e=m.find.attr(a,b),null==e?void 0:e):null!==c?d&&"set"in d&&void 0!==(e=d.set(a,c,b))?e:(a.setAttribute(b,c+""),c):void m.removeAttr(a,b))},removeAttr:function(a,b){var c,d,e=0,f=b&&b.match(E);if(f&&1===a.nodeType)while(c=f[e++])d=m.propFix[c]||c,m.expr.match.bool.test(c)?rc&&qc||!pc.test(c)?a[d]=!1:a[m.camelCase("default-"+c)]=a[d]=!1:m.attr(a,c,""),a.removeAttribute(qc?c:d)},attrHooks:{type:{set:function(a,b){if(!k.radioValue&&"radio"===b&&m.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}}}),nc={set:function(a,b,c){return b===!1?m.removeAttr(a,c):rc&&qc||!pc.test(c)?a.setAttribute(!qc&&m.propFix[c]||c,c):a[m.camelCase("default-"+c)]=a[c]=!0,c}},m.each(m.expr.match.bool.source.match(/\w+/g),function(a,b){var c=oc[b]||m.find.attr;oc[b]=rc&&qc||!pc.test(b)?function(a,b,d){var e,f;return d||(f=oc[b],oc[b]=e,e=null!=c(a,b,d)?b.toLowerCase():null,oc[b]=f),e}:function(a,b,c){return c?void 0:a[m.camelCase("default-"+b)]?b.toLowerCase():null}}),rc&&qc||(m.attrHooks.value={set:function(a,b,c){return m.nodeName(a,"input")?void(a.defaultValue=b):mc&&mc.set(a,b,c)}}),qc||(mc={set:function(a,b,c){var d=a.getAttributeNode(c);return d||a.setAttributeNode(d=a.ownerDocument.createAttribute(c)),d.value=b+="","value"===c||b===a.getAttribute(c)?b:void 0}},oc.id=oc.name=oc.coords=function(a,b,c){var d;return c?void 0:(d=a.getAttributeNode(b))&&""!==d.value?d.value:null},m.valHooks.button={get:function(a,b){var c=a.getAttributeNode(b);return c&&c.specified?c.value:void 0},set:mc.set},m.attrHooks.contenteditable={set:function(a,b,c){mc.set(a,""===b?!1:b,c)}},m.each(["width","height"],function(a,b){m.attrHooks[b]={set:function(a,c){return""===c?(a.setAttribute(b,"auto"),c):void 0}}})),k.style||(m.attrHooks.style={get:function(a){return a.style.cssText||void 0},set:function(a,b){return a.style.cssText=b+""}});var sc=/^(?:input|select|textarea|button|object)$/i,tc=/^(?:a|area)$/i;m.fn.extend({prop:function(a,b){return V(this,m.prop,a,b,arguments.length>1)},removeProp:function(a){return a=m.propFix[a]||a,this.each(function(){try{this[a]=void 0,delete this[a]}catch(b){}})}}),m.extend({propFix:{"for":"htmlFor","class":"className"},prop:function(a,b,c){var d,e,f,g=a.nodeType;if(a&&3!==g&&8!==g&&2!==g)return f=1!==g||!m.isXMLDoc(a),f&&(b=m.propFix[b]||b,e=m.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=m.find.attr(a,"tabindex");return b?parseInt(b,10):sc.test(a.nodeName)||tc.test(a.nodeName)&&a.href?0:-1}}}}),k.hrefNormalized||m.each(["href","src"],function(a,b){m.propHooks[b]={get:function(a){return a.getAttribute(b,4)}}}),k.optSelected||(m.propHooks.selected={get:function(a){var b=a.parentNode;return b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex),null}}),m.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){m.propFix[this.toLowerCase()]=this}),k.enctype||(m.propFix.enctype="encoding");var uc=/[\t\r\n\f]/g;m.fn.extend({addClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j="string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).addClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(uc," "):" ")){f=0;while(e=b[f++])d.indexOf(" "+e+" ")<0&&(d+=e+" ");g=m.trim(d),c.className!==g&&(c.className=g)}return this},removeClass:function(a){var b,c,d,e,f,g,h=0,i=this.length,j=0===arguments.length||"string"==typeof a&&a;if(m.isFunction(a))return this.each(function(b){m(this).removeClass(a.call(this,b,this.className))});if(j)for(b=(a||"").match(E)||[];i>h;h++)if(c=this[h],d=1===c.nodeType&&(c.className?(" "+c.className+" ").replace(uc," "):"")){f=0;while(e=b[f++])while(d.indexOf(" "+e+" ")>=0)d=d.replace(" "+e+" "," ");g=a?m.trim(d):"",c.className!==g&&(c.className=g)}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):this.each(m.isFunction(a)?function(c){m(this).toggleClass(a.call(this,c,this.className,b),b)}:function(){if("string"===c){var b,d=0,e=m(this),f=a.match(E)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else(c===K||"boolean"===c)&&(this.className&&m._data(this,"__className__",this.className),this.className=this.className||a===!1?"":m._data(this,"__className__")||"")})},hasClass:function(a){for(var b=" "+a+" ",c=0,d=this.length;d>c;c++)if(1===this[c].nodeType&&(" "+this[c].className+" ").replace(uc," ").indexOf(b)>=0)return!0;return!1}}),m.each("blur focus focusin focusout load resize scroll unload click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup error contextmenu".split(" "),function(a,b){m.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),m.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)},bind:function(a,b,c){return this.on(a,null,b,c)},unbind:function(a,b){return this.off(a,null,b)},delegate:function(a,b,c,d){return this.on(b,a,c,d)},undelegate:function(a,b,c){return 1===arguments.length?this.off(a,"**"):this.off(b,a||"**",c)}});var vc=m.now(),wc=/\?/,xc=/(,)|(\[|{)|(}|])|"(?:[^"\\\r\n]|\\["\\\/bfnrt]|\\u[\da-fA-F]{4})*"\s*:?|true|false|null|-?(?!0\d)\d+(?:\.\d+|)(?:[eE][+-]?\d+|)/g;m.parseJSON=function(b){if(a.JSON&&a.JSON.parse)return a.JSON.parse(b+"");var c,d=null,e=m.trim(b+"");return e&&!m.trim(e.replace(xc,function(a,b,e,f){return c&&b&&(d=0),0===d?a:(c=e||b,d+=!f-!e,"")}))?Function("return "+e)():m.error("Invalid JSON: "+b)},m.parseXML=function(b){var c,d;if(!b||"string"!=typeof b)return null;try{a.DOMParser?(d=new DOMParser,c=d.parseFromString(b,"text/xml")):(c=new ActiveXObject("Microsoft.XMLDOM"),c.async="false",c.loadXML(b))}catch(e){c=void 0}return c&&c.documentElement&&!c.getElementsByTagName("parsererror").length||m.error("Invalid XML: "+b),c};var yc,zc,Ac=/#.*$/,Bc=/([?&])_=[^&]*/,Cc=/^(.*?):[ \t]*([^\r\n]*)\r?$/gm,Dc=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Ec=/^(?:GET|HEAD)$/,Fc=/^\/\//,Gc=/^([\w.+-]+:)(?:\/\/(?:[^\/?#]*@|)([^\/?#:]*)(?::(\d+)|)|)/,Hc={},Ic={},Jc="*/".concat("*");try{zc=location.href}catch(Kc){zc=y.createElement("a"),zc.href="",zc=zc.href}yc=Gc.exec(zc.toLowerCase())||[];function Lc(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(E)||[];if(m.isFunction(c))while(d=f[e++])"+"===d.charAt(0)?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Mc(a,b,c,d){var e={},f=a===Ic;function g(h){var i;return e[h]=!0,m.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Nc(a,b){var c,d,e=m.ajaxSettings.flatOptions||{};for(d in b)void 0!==b[d]&&((e[d]?a:c||(c={}))[d]=b[d]);return c&&m.extend(!0,a,c),a}function Oc(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===e&&(e=a.mimeType||b.getResponseHeader("Content-Type"));if(e)for(g in h)if(h[g]&&h[g].test(e)){i.unshift(g);break}if(i[0]in c)f=i[0];else{for(g in c){if(!i[0]||a.converters[g+" "+i[0]]){f=g;break}d||(d=g)}f=f||d}return f?(f!==i[0]&&i.unshift(f),c[f]):void 0}function Pc(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}m.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:zc,type:"GET",isLocal:Dc.test(yc[1]),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Jc,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/xml/,html:/html/,json:/json/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":m.parseJSON,"text xml":m.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Nc(Nc(a,m.ajaxSettings),b):Nc(m.ajaxSettings,a)},ajaxPrefilter:Lc(Hc),ajaxTransport:Lc(Ic),ajax:function(a,b){"object"==typeof a&&(b=a,a=void 0),b=b||{};var c,d,e,f,g,h,i,j,k=m.ajaxSetup({},b),l=k.context||k,n=k.context&&(l.nodeType||l.jquery)?m(l):m.event,o=m.Deferred(),p=m.Callbacks("once memory"),q=k.statusCode||{},r={},s={},t=0,u="canceled",v={readyState:0,getResponseHeader:function(a){var b;if(2===t){if(!j){j={};while(b=Cc.exec(f))j[b[1].toLowerCase()]=b[2]}b=j[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return 2===t?f:null},setRequestHeader:function(a,b){var c=a.toLowerCase();return t||(a=s[c]=s[c]||a,r[a]=b),this},overrideMimeType:function(a){return t||(k.mimeType=a),this},statusCode:function(a){var b;if(a)if(2>t)for(b in a)q[b]=[q[b],a[b]];else v.always(a[v.status]);return this},abort:function(a){var b=a||u;return i&&i.abort(b),x(0,b),this}};if(o.promise(v).complete=p.add,v.success=v.done,v.error=v.fail,k.url=((a||k.url||zc)+"").replace(Ac,"").replace(Fc,yc[1]+"//"),k.type=b.method||b.type||k.method||k.type,k.dataTypes=m.trim(k.dataType||"*").toLowerCase().match(E)||[""],null==k.crossDomain&&(c=Gc.exec(k.url.toLowerCase()),k.crossDomain=!(!c||c[1]===yc[1]&&c[2]===yc[2]&&(c[3]||("http:"===c[1]?"80":"443"))===(yc[3]||("http:"===yc[1]?"80":"443")))),k.data&&k.processData&&"string"!=typeof k.data&&(k.data=m.param(k.data,k.traditional)),Mc(Hc,k,b,v),2===t)return v;h=k.global,h&&0===m.active++&&m.event.trigger("ajaxStart"),k.type=k.type.toUpperCase(),k.hasContent=!Ec.test(k.type),e=k.url,k.hasContent||(k.data&&(e=k.url+=(wc.test(e)?"&":"?")+k.data,delete k.data),k.cache===!1&&(k.url=Bc.test(e)?e.replace(Bc,"$1_="+vc++):e+(wc.test(e)?"&":"?")+"_="+vc++)),k.ifModified&&(m.lastModified[e]&&v.setRequestHeader("If-Modified-Since",m.lastModified[e]),m.etag[e]&&v.setRequestHeader("If-None-Match",m.etag[e])),(k.data&&k.hasContent&&k.contentType!==!1||b.contentType)&&v.setRequestHeader("Content-Type",k.contentType),v.setRequestHeader("Accept",k.dataTypes[0]&&k.accepts[k.dataTypes[0]]?k.accepts[k.dataTypes[0]]+("*"!==k.dataTypes[0]?", "+Jc+"; q=0.01":""):k.accepts["*"]);for(d in k.headers)v.setRequestHeader(d,k.headers[d]);if(k.beforeSend&&(k.beforeSend.call(l,v,k)===!1||2===t))return v.abort();u="abort";for(d in{success:1,error:1,complete:1})v[d](k[d]);if(i=Mc(Ic,k,b,v)){v.readyState=1,h&&n.trigger("ajaxSend",[v,k]),k.async&&k.timeout>0&&(g=setTimeout(function(){v.abort("timeout")},k.timeout));try{t=1,i.send(r,x)}catch(w){if(!(2>t))throw w;x(-1,w)}}else x(-1,"No Transport");function x(a,b,c,d){var j,r,s,u,w,x=b;2!==t&&(t=2,g&&clearTimeout(g),i=void 0,f=d||"",v.readyState=a>0?4:0,j=a>=200&&300>a||304===a,c&&(u=Oc(k,v,c)),u=Pc(k,u,v,j),j?(k.ifModified&&(w=v.getResponseHeader("Last-Modified"),w&&(m.lastModified[e]=w),w=v.getResponseHeader("etag"),w&&(m.etag[e]=w)),204===a||"HEAD"===k.type?x="nocontent":304===a?x="notmodified":(x=u.state,r=u.data,s=u.error,j=!s)):(s=x,(a||!x)&&(x="error",0>a&&(a=0))),v.status=a,v.statusText=(b||x)+"",j?o.resolveWith(l,[r,x,v]):o.rejectWith(l,[v,x,s]),v.statusCode(q),q=void 0,h&&n.trigger(j?"ajaxSuccess":"ajaxError",[v,k,j?r:s]),p.fireWith(l,[v,x]),h&&(n.trigger("ajaxComplete",[v,k]),--m.active||m.event.trigger("ajaxStop")))}return v},getJSON:function(a,b,c){return m.get(a,b,c,"json")},getScript:function(a,b){return m.get(a,void 0,b,"script")}}),m.each(["get","post"],function(a,b){m[b]=function(a,c,d,e){return m.isFunction(c)&&(e=e||d,d=c,c=void 0),m.ajax({url:a,type:b,dataType:e,data:c,success:d})}}),m.each(["ajaxStart","ajaxStop","ajaxComplete","ajaxError","ajaxSuccess","ajaxSend"],function(a,b){m.fn[b]=function(a){return this.on(b,a)}}),m._evalUrl=function(a){return m.ajax({url:a,type:"GET",dataType:"script",async:!1,global:!1,"throws":!0})},m.fn.extend({wrapAll:function(a){if(m.isFunction(a))return this.each(function(b){m(this).wrapAll(a.call(this,b))});if(this[0]){var b=m(a,this[0].ownerDocument).eq(0).clone(!0);this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstChild&&1===a.firstChild.nodeType)a=a.firstChild;return a}).append(this)}return this},wrapInner:function(a){return this.each(m.isFunction(a)?function(b){m(this).wrapInner(a.call(this,b))}:function(){var b=m(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=m.isFunction(a);return this.each(function(c){m(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(){return this.parent().each(function(){m.nodeName(this,"body")||m(this).replaceWith(this.childNodes)}).end()}}),m.expr.filters.hidden=function(a){return a.offsetWidth<=0&&a.offsetHeight<=0||!k.reliableHiddenOffsets()&&"none"===(a.style&&a.style.display||m.css(a,"display"))},m.expr.filters.visible=function(a){return!m.expr.filters.hidden(a)};var Qc=/%20/g,Rc=/\[\]$/,Sc=/\r?\n/g,Tc=/^(?:submit|button|image|reset|file)$/i,Uc=/^(?:input|select|textarea|keygen)/i;function Vc(a,b,c,d){var e;if(m.isArray(b))m.each(b,function(b,e){c||Rc.test(a)?d(a,e):Vc(a+"["+("object"==typeof e?b:"")+"]",e,c,d)});else if(c||"object"!==m.type(b))d(a,b);else for(e in b)Vc(a+"["+e+"]",b[e],c,d)}m.param=function(a,b){var c,d=[],e=function(a,b){b=m.isFunction(b)?b():null==b?"":b,d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(b)};if(void 0===b&&(b=m.ajaxSettings&&m.ajaxSettings.traditional),m.isArray(a)||a.jquery&&!m.isPlainObject(a))m.each(a,function(){e(this.name,this.value)});else for(c in a)Vc(c,a[c],b,e);return d.join("&").replace(Qc,"+")},m.fn.extend({serialize:function(){return m.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=m.prop(this,"elements");return a?m.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!m(this).is(":disabled")&&Uc.test(this.nodeName)&&!Tc.test(a)&&(this.checked||!W.test(a))}).map(function(a,b){var c=m(this).val();return null==c?null:m.isArray(c)?m.map(c,function(a){return{name:b.name,value:a.replace(Sc,"\r\n")}}):{name:b.name,value:c.replace(Sc,"\r\n")}}).get()}}),m.ajaxSettings.xhr=void 0!==a.ActiveXObject?function(){return!this.isLocal&&/^(get|post|head|put|delete|options)$/i.test(this.type)&&Zc()||$c()}:Zc;var Wc=0,Xc={},Yc=m.ajaxSettings.xhr();a.ActiveXObject&&m(a).on("unload",function(){for(var a in Xc)Xc[a](void 0,!0)}),k.cors=!!Yc&&"withCredentials"in Yc,Yc=k.ajax=!!Yc,Yc&&m.ajaxTransport(function(a){if(!a.crossDomain||k.cors){var b;return{send:function(c,d){var e,f=a.xhr(),g=++Wc;if(f.open(a.type,a.url,a.async,a.username,a.password),a.xhrFields)for(e in a.xhrFields)f[e]=a.xhrFields[e];a.mimeType&&f.overrideMimeType&&f.overrideMimeType(a.mimeType),a.crossDomain||c["X-Requested-With"]||(c["X-Requested-With"]="XMLHttpRequest");for(e in c)void 0!==c[e]&&f.setRequestHeader(e,c[e]+"");f.send(a.hasContent&&a.data||null),b=function(c,e){var h,i,j;if(b&&(e||4===f.readyState))if(delete Xc[g],b=void 0,f.onreadystatechange=m.noop,e)4!==f.readyState&&f.abort();else{j={},h=f.status,"string"==typeof f.responseText&&(j.text=f.responseText);try{i=f.statusText}catch(k){i=""}h||!a.isLocal||a.crossDomain?1223===h&&(h=204):h=j.text?200:404}j&&d(h,i,j,f.getAllResponseHeaders())},a.async?4===f.readyState?setTimeout(b):f.onreadystatechange=Xc[g]=b:b()},abort:function(){b&&b(void 0,!0)}}}});function Zc(){try{return new a.XMLHttpRequest}catch(b){}}function $c(){try{return new a.ActiveXObject("Microsoft.XMLHTTP")}catch(b){}}m.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/(?:java|ecma)script/},converters:{"text script":function(a){return m.globalEval(a),a}}}),m.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET",a.global=!1)}),m.ajaxTransport("script",function(a){if(a.crossDomain){var b,c=y.head||m("head")[0]||y.documentElement;return{send:function(d,e){b=y.createElement("script"),b.async=!0,a.scriptCharset&&(b.charset=a.scriptCharset),b.src=a.url,b.onload=b.onreadystatechange=function(a,c){(c||!b.readyState||/loaded|complete/.test(b.readyState))&&(b.onload=b.onreadystatechange=null,b.parentNode&&b.parentNode.removeChild(b),b=null,c||e(200,"success"))},c.insertBefore(b,c.firstChild)},abort:function(){b&&b.onload(void 0,!0)}}}});var _c=[],ad=/(=)\?(?=&|$)|\?\?/;m.ajaxSetup({jsonp:"callback",jsonpCallback:function(){var a=_c.pop()||m.expando+"_"+vc++;return this[a]=!0,a}}),m.ajaxPrefilter("json jsonp",function(b,c,d){var e,f,g,h=b.jsonp!==!1&&(ad.test(b.url)?"url":"string"==typeof b.data&&!(b.contentType||"").indexOf("application/x-www-form-urlencoded")&&ad.test(b.data)&&"data");return h||"jsonp"===b.dataTypes[0]?(e=b.jsonpCallback=m.isFunction(b.jsonpCallback)?b.jsonpCallback():b.jsonpCallback,h?b[h]=b[h].replace(ad,"$1"+e):b.jsonp!==!1&&(b.url+=(wc.test(b.url)?"&":"?")+b.jsonp+"="+e),b.converters["script json"]=function(){return g||m.error(e+" was not called"),g[0]},b.dataTypes[0]="json",f=a[e],a[e]=function(){g=arguments},d.always(function(){a[e]=f,b[e]&&(b.jsonpCallback=c.jsonpCallback,_c.push(e)),g&&m.isFunction(f)&&f(g[0]),g=f=void 0}),"script"):void 0}),m.parseHTML=function(a,b,c){if(!a||"string"!=typeof a)return null;"boolean"==typeof b&&(c=b,b=!1),b=b||y;var d=u.exec(a),e=!c&&[];return d?[b.createElement(d[1])]:(d=m.buildFragment([a],b,e),e&&e.length&&m(e).remove(),m.merge([],d.childNodes))};var bd=m.fn.load;m.fn.load=function(a,b,c){if("string"!=typeof a&&bd)return bd.apply(this,arguments);var d,e,f,g=this,h=a.indexOf(" ");return h>=0&&(d=m.trim(a.slice(h,a.length)),a=a.slice(0,h)),m.isFunction(b)?(c=b,b=void 0):b&&"object"==typeof b&&(f="POST"),g.length>0&&m.ajax({url:a,type:f,dataType:"html",data:b}).done(function(a){e=arguments,g.html(d?m("<div>").append(m.parseHTML(a)).find(d):a)}).complete(c&&function(a,b){g.each(c,e||[a.responseText,b,a])}),this},m.expr.filters.animated=function(a){return m.grep(m.timers,function(b){return a===b.elem}).length};var cd=a.document.documentElement;function dd(a){return m.isWindow(a)?a:9===a.nodeType?a.defaultView||a.parentWindow:!1}m.offset={setOffset:function(a,b,c){var d,e,f,g,h,i,j,k=m.css(a,"position"),l=m(a),n={};"static"===k&&(a.style.position="relative"),h=l.offset(),f=m.css(a,"top"),i=m.css(a,"left"),j=("absolute"===k||"fixed"===k)&&m.inArray("auto",[f,i])>-1,j?(d=l.position(),g=d.top,e=d.left):(g=parseFloat(f)||0,e=parseFloat(i)||0),m.isFunction(b)&&(b=b.call(a,c,h)),null!=b.top&&(n.top=b.top-h.top+g),null!=b.left&&(n.left=b.left-h.left+e),"using"in b?b.using.call(a,n):l.css(n)}},m.fn.extend({offset:function(a){if(arguments.length)return void 0===a?this:this.each(function(b){m.offset.setOffset(this,a,b)});var b,c,d={top:0,left:0},e=this[0],f=e&&e.ownerDocument;if(f)return b=f.documentElement,m.contains(b,e)?(typeof e.getBoundingClientRect!==K&&(d=e.getBoundingClientRect()),c=dd(f),{top:d.top+(c.pageYOffset||b.scrollTop)-(b.clientTop||0),left:d.left+(c.pageXOffset||b.scrollLeft)-(b.clientLeft||0)}):d},position:function(){if(this[0]){var a,b,c={top:0,left:0},d=this[0];return"fixed"===m.css(d,"position")?b=d.getBoundingClientRect():(a=this.offsetParent(),b=this.offset(),m.nodeName(a[0],"html")||(c=a.offset()),c.top+=m.css(a[0],"borderTopWidth",!0),c.left+=m.css(a[0],"borderLeftWidth",!0)),{top:b.top-c.top-m.css(d,"marginTop",!0),left:b.left-c.left-m.css(d,"marginLeft",!0)}}},offsetParent:function(){return this.map(function(){var a=this.offsetParent||cd;while(a&&!m.nodeName(a,"html")&&"static"===m.css(a,"position"))a=a.offsetParent;return a||cd})}}),m.each({scrollLeft:"pageXOffset",scrollTop:"pageYOffset"},function(a,b){var c=/Y/.test(b);m.fn[a]=function(d){return V(this,function(a,d,e){var f=dd(a);return void 0===e?f?b in f?f[b]:f.document.documentElement[d]:a[d]:void(f?f.scrollTo(c?m(f).scrollLeft():e,c?e:m(f).scrollTop()):a[d]=e)},a,d,arguments.length,null)}}),m.each(["top","left"],function(a,b){m.cssHooks[b]=Lb(k.pixelPosition,function(a,c){return c?(c=Jb(a,b),Hb.test(c)?m(a).position()[b]+"px":c):void 0})}),m.each({Height:"height",Width:"width"},function(a,b){m.each({padding:"inner"+a,content:b,"":"outer"+a},function(c,d){m.fn[d]=function(d,e){var f=arguments.length&&(c||"boolean"!=typeof d),g=c||(d===!0||e===!0?"margin":"border");return V(this,function(b,c,d){var e;return m.isWindow(b)?b.document.documentElement["client"+a]:9===b.nodeType?(e=b.documentElement,Math.max(b.body["scroll"+a],e["scroll"+a],b.body["offset"+a],e["offset"+a],e["client"+a])):void 0===d?m.css(b,c,g):m.style(b,c,d,g)},b,f?d:void 0,f,null)}})}),m.fn.size=function(){return this.length},m.fn.andSelf=m.fn.addBack,"function"==typeof define&&define.amd&&define("jquery",[],function(){return m});var ed=a.jQuery,fd=a.$;return m.noConflict=function(b){return a.$===m&&(a.$=fd),b&&a.jQuery===m&&(a.jQuery=ed),m},typeof b===K&&(a.jQuery=a.$=m),m});
...\ No newline at end of file ...\ No newline at end of file
1 +/**
2 + * Isotope v1.5.25
3 + * An exquisite jQuery plugin for magical layouts
4 + * http://isotope.metafizzy.co
5 + *
6 + * Commercial use requires one-time license fee
7 + * http://metafizzy.co/#licenses
8 + *
9 + * Copyright 2012 David DeSandro / Metafizzy
10 + */
11 +
12 +/*jshint asi: true, browser: true, curly: true, eqeqeq: true, forin: false, immed: false, newcap: true, noempty: true, strict: true, undef: true */
13 +/*global jQuery: false */
14 +
15 +(function( window, $, undefined ){
16 +
17 + 'use strict';
18 +
19 + // get global vars
20 + var document = window.document;
21 + var Modernizr = window.Modernizr;
22 +
23 + // helper function
24 + var capitalize = function( str ) {
25 + return str.charAt(0).toUpperCase() + str.slice(1);
26 + };
27 +
28 + // ========================= getStyleProperty by kangax ===============================
29 + // http://perfectionkills.com/feature-testing-css-properties/
30 +
31 + var prefixes = 'Moz Webkit O Ms'.split(' ');
32 +
33 + var getStyleProperty = function( propName ) {
34 + var style = document.documentElement.style,
35 + prefixed;
36 +
37 + // test standard property first
38 + if ( typeof style[propName] === 'string' ) {
39 + return propName;
40 + }
41 +
42 + // capitalize
43 + propName = capitalize( propName );
44 +
45 + // test vendor specific properties
46 + for ( var i=0, len = prefixes.length; i < len; i++ ) {
47 + prefixed = prefixes[i] + propName;
48 + if ( typeof style[ prefixed ] === 'string' ) {
49 + return prefixed;
50 + }
51 + }
52 + };
53 +
54 + var transformProp = getStyleProperty('transform'),
55 + transitionProp = getStyleProperty('transitionProperty');
56 +
57 +
58 + // ========================= miniModernizr ===============================
59 + // <3<3<3 and thanks to Faruk and Paul for doing the heavy lifting
60 +
61 + /*!
62 + * Modernizr v1.6ish: miniModernizr for Isotope
63 + * http://www.modernizr.com
64 + *
65 + * Developed by:
66 + * - Faruk Ates http://farukat.es/
67 + * - Paul Irish http://paulirish.com/
68 + *
69 + * Copyright (c) 2009-2010
70 + * Dual-licensed under the BSD or MIT licenses.
71 + * http://www.modernizr.com/license/
72 + */
73 +
74 + /*
75 + * This version whittles down the script just to check support for
76 + * CSS transitions, transforms, and 3D transforms.
77 + */
78 +
79 + var tests = {
80 + csstransforms: function() {
81 + return !!transformProp;
82 + },
83 +
84 + csstransforms3d: function() {
85 + var test = !!getStyleProperty('perspective');
86 + // double check for Chrome's false positive
87 + if ( test ) {
88 + var vendorCSSPrefixes = ' -o- -moz- -ms- -webkit- -khtml- '.split(' '),
89 + mediaQuery = '@media (' + vendorCSSPrefixes.join('transform-3d),(') + 'modernizr)',
90 + $style = $('<style>' + mediaQuery + '{#modernizr{height:3px}}' + '</style>')
91 + .appendTo('head'),
92 + $div = $('<div id="modernizr" />').appendTo('html');
93 +
94 + test = $div.height() === 3;
95 +
96 + $div.remove();
97 + $style.remove();
98 + }
99 + return test;
100 + },
101 +
102 + csstransitions: function() {
103 + return !!transitionProp;
104 + }
105 + };
106 +
107 + var testName;
108 +
109 + if ( Modernizr ) {
110 + // if there's a previous Modernzir, check if there are necessary tests
111 + for ( testName in tests) {
112 + if ( !Modernizr.hasOwnProperty( testName ) ) {
113 + // if test hasn't been run, use addTest to run it
114 + Modernizr.addTest( testName, tests[ testName ] );
115 + }
116 + }
117 + } else {
118 + // or create new mini Modernizr that just has the 3 tests
119 + Modernizr = window.Modernizr = {
120 + _version : '1.6ish: miniModernizr for Isotope'
121 + };
122 +
123 + var classes = ' ';
124 + var result;
125 +
126 + // Run through tests
127 + for ( testName in tests) {
128 + result = tests[ testName ]();
129 + Modernizr[ testName ] = result;
130 + classes += ' ' + ( result ? '' : 'no-' ) + testName;
131 + }
132 +
133 + // Add the new classes to the <html> element.
134 + $('html').addClass( classes );
135 + }
136 +
137 +
138 + // ========================= isoTransform ===============================
139 +
140 + /**
141 + * provides hooks for .css({ scale: value, translate: [x, y] })
142 + * Progressively enhanced CSS transforms
143 + * Uses hardware accelerated 3D transforms for Safari
144 + * or falls back to 2D transforms.
145 + */
146 +
147 + if ( Modernizr.csstransforms ) {
148 +
149 + // i.e. transformFnNotations.scale(0.5) >> 'scale3d( 0.5, 0.5, 1)'
150 + var transformFnNotations = Modernizr.csstransforms3d ?
151 + { // 3D transform functions
152 + translate : function ( position ) {
153 + return 'translate3d(' + position[0] + 'px, ' + position[1] + 'px, 0) ';
154 + },
155 + scale : function ( scale ) {
156 + return 'scale3d(' + scale + ', ' + scale + ', 1) ';
157 + }
158 + } :
159 + { // 2D transform functions
160 + translate : function ( position ) {
161 + return 'translate(' + position[0] + 'px, ' + position[1] + 'px) ';
162 + },
163 + scale : function ( scale ) {
164 + return 'scale(' + scale + ') ';
165 + }
166 + }
167 + ;
168 +
169 + var setIsoTransform = function ( elem, name, value ) {
170 + // unpack current transform data
171 + var data = $.data( elem, 'isoTransform' ) || {},
172 + newData = {},
173 + fnName,
174 + transformObj = {},
175 + transformValue;
176 +
177 + // i.e. newData.scale = 0.5
178 + newData[ name ] = value;
179 + // extend new value over current data
180 + $.extend( data, newData );
181 +
182 + for ( fnName in data ) {
183 + transformValue = data[ fnName ];
184 + transformObj[ fnName ] = transformFnNotations[ fnName ]( transformValue );
185 + }
186 +
187 + // get proper order
188 + // ideally, we could loop through this give an array, but since we only have
189 + // a couple transforms we're keeping track of, we'll do it like so
190 + var translateFn = transformObj.translate || '',
191 + scaleFn = transformObj.scale || '',
192 + // sorting so translate always comes first
193 + valueFns = translateFn + scaleFn;
194 +
195 + // set data back in elem
196 + $.data( elem, 'isoTransform', data );
197 +
198 + // set name to vendor specific property
199 + elem.style[ transformProp ] = valueFns;
200 + };
201 +
202 + // ==================== scale ===================
203 +
204 + $.cssNumber.scale = true;
205 +
206 + $.cssHooks.scale = {
207 + set: function( elem, value ) {
208 + // uncomment this bit if you want to properly parse strings
209 + // if ( typeof value === 'string' ) {
210 + // value = parseFloat( value );
211 + // }
212 + setIsoTransform( elem, 'scale', value );
213 + },
214 + get: function( elem, computed ) {
215 + var transform = $.data( elem, 'isoTransform' );
216 + return transform && transform.scale ? transform.scale : 1;
217 + }
218 + };
219 +
220 + $.fx.step.scale = function( fx ) {
221 + $.cssHooks.scale.set( fx.elem, fx.now+fx.unit );
222 + };
223 +
224 +
225 + // ==================== translate ===================
226 +
227 + $.cssNumber.translate = true;
228 +
229 + $.cssHooks.translate = {
230 + set: function( elem, value ) {
231 +
232 + // uncomment this bit if you want to properly parse strings
233 + // if ( typeof value === 'string' ) {
234 + // value = value.split(' ');
235 + // }
236 + //
237 + // var i, val;
238 + // for ( i = 0; i < 2; i++ ) {
239 + // val = value[i];
240 + // if ( typeof val === 'string' ) {
241 + // val = parseInt( val );
242 + // }
243 + // }
244 +
245 + setIsoTransform( elem, 'translate', value );
246 + },
247 +
248 + get: function( elem, computed ) {
249 + var transform = $.data( elem, 'isoTransform' );
250 + return transform && transform.translate ? transform.translate : [ 0, 0 ];
251 + }
252 + };
253 +
254 + }
255 +
256 + // ========================= get transition-end event ===============================
257 + var transitionEndEvent, transitionDurProp;
258 +
259 + if ( Modernizr.csstransitions ) {
260 + transitionEndEvent = {
261 + WebkitTransitionProperty: 'webkitTransitionEnd', // webkit
262 + MozTransitionProperty: 'transitionend',
263 + OTransitionProperty: 'oTransitionEnd otransitionend',
264 + transitionProperty: 'transitionend'
265 + }[ transitionProp ];
266 +
267 + transitionDurProp = getStyleProperty('transitionDuration');
268 + }
269 +
270 + // ========================= smartresize ===============================
271 +
272 + /*
273 + * smartresize: debounced resize event for jQuery
274 + *
275 + * latest version and complete README available on Github:
276 + * https://github.com/louisremi/jquery.smartresize.js
277 + *
278 + * Copyright 2011 @louis_remi
279 + * Licensed under the MIT license.
280 + */
281 +
282 + var $event = $.event,
283 + dispatchMethod = $.event.handle ? 'handle' : 'dispatch',
284 + resizeTimeout;
285 +
286 + $event.special.smartresize = {
287 + setup: function() {
288 + $(this).bind( "resize", $event.special.smartresize.handler );
289 + },
290 + teardown: function() {
291 + $(this).unbind( "resize", $event.special.smartresize.handler );
292 + },
293 + handler: function( event, execAsap ) {
294 + // Save the context
295 + var context = this,
296 + args = arguments;
297 +
298 + // set correct event type
299 + event.type = "smartresize";
300 +
301 + if ( resizeTimeout ) { clearTimeout( resizeTimeout ); }
302 + resizeTimeout = setTimeout(function() {
303 + $event[ dispatchMethod ].apply( context, args );
304 + }, execAsap === "execAsap"? 0 : 100 );
305 + }
306 + };
307 +
308 + $.fn.smartresize = function( fn ) {
309 + return fn ? this.bind( "smartresize", fn ) : this.trigger( "smartresize", ["execAsap"] );
310 + };
311 +
312 +
313 +
314 +// ========================= Isotope ===============================
315 +
316 +
317 + // our "Widget" object constructor
318 + $.Isotope = function( options, element, callback ){
319 + this.element = $( element );
320 +
321 + this._create( options );
322 + this._init( callback );
323 + };
324 +
325 + // styles of container element we want to keep track of
326 + var isoContainerStyles = [ 'width', 'height' ];
327 +
328 + var $window = $(window);
329 +
330 + $.Isotope.settings = {
331 + resizable: true,
332 + layoutMode : 'masonry',
333 + containerClass : 'isotope',
334 + itemClass : 'isotope-item',
335 + hiddenClass : 'isotope-hidden',
336 + hiddenStyle: { opacity: 0, scale: 0.001 },
337 + visibleStyle: { opacity: 1, scale: 1 },
338 + containerStyle: {
339 + position: 'relative',
340 + overflow: 'hidden'
341 + },
342 + animationEngine: 'best-available',
343 + animationOptions: {
344 + queue: false,
345 + duration: 800
346 + },
347 + sortBy : 'original-order',
348 + sortAscending : true,
349 + resizesContainer : true,
350 + transformsEnabled: true,
351 + itemPositionDataEnabled: false
352 + };
353 +
354 + $.Isotope.prototype = {
355 +
356 + // sets up widget
357 + _create : function( options ) {
358 +
359 + this.options = $.extend( {}, $.Isotope.settings, options );
360 +
361 + this.styleQueue = [];
362 + this.elemCount = 0;
363 +
364 + // get original styles in case we re-apply them in .destroy()
365 + var elemStyle = this.element[0].style;
366 + this.originalStyle = {};
367 + // keep track of container styles
368 + var containerStyles = isoContainerStyles.slice(0);
369 + for ( var prop in this.options.containerStyle ) {
370 + containerStyles.push( prop );
371 + }
372 + for ( var i=0, len = containerStyles.length; i < len; i++ ) {
373 + prop = containerStyles[i];
374 + this.originalStyle[ prop ] = elemStyle[ prop ] || '';
375 + }
376 + // apply container style from options
377 + this.element.css( this.options.containerStyle );
378 +
379 + this._updateAnimationEngine();
380 + this._updateUsingTransforms();
381 +
382 + // sorting
383 + var originalOrderSorter = {
384 + 'original-order' : function( $elem, instance ) {
385 + instance.elemCount ++;
386 + return instance.elemCount;
387 + },
388 + random : function() {
389 + return Math.random();
390 + }
391 + };
392 +
393 + this.options.getSortData = $.extend( this.options.getSortData, originalOrderSorter );
394 +
395 + // need to get atoms
396 + this.reloadItems();
397 +
398 + // get top left position of where the bricks should be
399 + this.offset = {
400 + left: parseInt( ( this.element.css('padding-left') || 0 ), 10 ),
401 + top: parseInt( ( this.element.css('padding-top') || 0 ), 10 )
402 + };
403 +
404 + // add isotope class first time around
405 + var instance = this;
406 + setTimeout( function() {
407 + instance.element.addClass( instance.options.containerClass );
408 + }, 0 );
409 +
410 + // bind resize method
411 + if ( this.options.resizable ) {
412 + $window.bind( 'smartresize.isotope', function() {
413 + instance.resize();
414 + });
415 + }
416 +
417 + // dismiss all click events from hidden events
418 + this.element.delegate( '.' + this.options.hiddenClass, 'click', function(){
419 + return false;
420 + });
421 +
422 + },
423 +
424 + _getAtoms : function( $elems ) {
425 + var selector = this.options.itemSelector,
426 + // filter & find
427 + $atoms = selector ? $elems.filter( selector ).add( $elems.find( selector ) ) : $elems,
428 + // base style for atoms
429 + atomStyle = { position: 'absolute' };
430 +
431 + // filter out text nodes
432 + $atoms = $atoms.filter( function( i, atom ) {
433 + return atom.nodeType === 1;
434 + });
435 +
436 + if ( this.usingTransforms ) {
437 + atomStyle.left = 0;
438 + atomStyle.top = 0;
439 + }
440 +
441 + $atoms.css( atomStyle ).addClass( this.options.itemClass );
442 +
443 + this.updateSortData( $atoms, true );
444 +
445 + return $atoms;
446 + },
447 +
448 + // _init fires when your instance is first created
449 + // (from the constructor above), and when you
450 + // attempt to initialize the widget again (by the bridge)
451 + // after it has already been initialized.
452 + _init : function( callback ) {
453 +
454 + this.$filteredAtoms = this._filter( this.$allAtoms );
455 + this._sort();
456 + this.reLayout( callback );
457 +
458 + },
459 +
460 + option : function( opts ){
461 + // change options AFTER initialization:
462 + // signature: $('#foo').bar({ cool:false });
463 + if ( $.isPlainObject( opts ) ){
464 + this.options = $.extend( true, this.options, opts );
465 +
466 + // trigger _updateOptionName if it exists
467 + var updateOptionFn;
468 + for ( var optionName in opts ) {
469 + updateOptionFn = '_update' + capitalize( optionName );
470 + if ( this[ updateOptionFn ] ) {
471 + this[ updateOptionFn ]();
472 + }
473 + }
474 + }
475 + },
476 +
477 + // ====================== updaters ====================== //
478 + // kind of like setters
479 +
480 + _updateAnimationEngine : function() {
481 + var animationEngine = this.options.animationEngine.toLowerCase().replace( /[ _\-]/g, '');
482 + var isUsingJQueryAnimation;
483 + // set applyStyleFnName
484 + switch ( animationEngine ) {
485 + case 'css' :
486 + case 'none' :
487 + isUsingJQueryAnimation = false;
488 + break;
489 + case 'jquery' :
490 + isUsingJQueryAnimation = true;
491 + break;
492 + default : // best available
493 + isUsingJQueryAnimation = !Modernizr.csstransitions;
494 + }
495 + this.isUsingJQueryAnimation = isUsingJQueryAnimation;
496 + this._updateUsingTransforms();
497 + },
498 +
499 + _updateTransformsEnabled : function() {
500 + this._updateUsingTransforms();
501 + },
502 +
503 + _updateUsingTransforms : function() {
504 + var usingTransforms = this.usingTransforms = this.options.transformsEnabled &&
505 + Modernizr.csstransforms && Modernizr.csstransitions && !this.isUsingJQueryAnimation;
506 +
507 + // prevent scales when transforms are disabled
508 + if ( !usingTransforms ) {
509 + delete this.options.hiddenStyle.scale;
510 + delete this.options.visibleStyle.scale;
511 + }
512 +
513 + this.getPositionStyles = usingTransforms ? this._translate : this._positionAbs;
514 + },
515 +
516 +
517 + // ====================== Filtering ======================
518 +
519 + _filter : function( $atoms ) {
520 + var filter = this.options.filter === '' ? '*' : this.options.filter;
521 +
522 + if ( !filter ) {
523 + return $atoms;
524 + }
525 +
526 + var hiddenClass = this.options.hiddenClass,
527 + hiddenSelector = '.' + hiddenClass,
528 + $hiddenAtoms = $atoms.filter( hiddenSelector ),
529 + $atomsToShow = $hiddenAtoms;
530 +
531 + if ( filter !== '*' ) {
532 + $atomsToShow = $hiddenAtoms.filter( filter );
533 + var $atomsToHide = $atoms.not( hiddenSelector ).not( filter ).addClass( hiddenClass );
534 + this.styleQueue.push({ $el: $atomsToHide, style: this.options.hiddenStyle });
535 + }
536 +
537 + this.styleQueue.push({ $el: $atomsToShow, style: this.options.visibleStyle });
538 + $atomsToShow.removeClass( hiddenClass );
539 +
540 + return $atoms.filter( filter );
541 + },
542 +
543 + // ====================== Sorting ======================
544 +
545 + updateSortData : function( $atoms, isIncrementingElemCount ) {
546 + var instance = this,
547 + getSortData = this.options.getSortData,
548 + $this, sortData;
549 + $atoms.each(function(){
550 + $this = $(this);
551 + sortData = {};
552 + // get value for sort data based on fn( $elem ) passed in
553 + for ( var key in getSortData ) {
554 + if ( !isIncrementingElemCount && key === 'original-order' ) {
555 + // keep original order original
556 + sortData[ key ] = $.data( this, 'isotope-sort-data' )[ key ];
557 + } else {
558 + sortData[ key ] = getSortData[ key ]( $this, instance );
559 + }
560 + }
561 + // apply sort data to element
562 + $.data( this, 'isotope-sort-data', sortData );
563 + });
564 + },
565 +
566 + // used on all the filtered atoms
567 + _sort : function() {
568 +
569 + var sortBy = this.options.sortBy,
570 + getSorter = this._getSorter,
571 + sortDir = this.options.sortAscending ? 1 : -1,
572 + sortFn = function( alpha, beta ) {
573 + var a = getSorter( alpha, sortBy ),
574 + b = getSorter( beta, sortBy );
575 + // fall back to original order if data matches
576 + if ( a === b && sortBy !== 'original-order') {
577 + a = getSorter( alpha, 'original-order' );
578 + b = getSorter( beta, 'original-order' );
579 + }
580 + return ( ( a > b ) ? 1 : ( a < b ) ? -1 : 0 ) * sortDir;
581 + };
582 +
583 + this.$filteredAtoms.sort( sortFn );
584 + },
585 +
586 + _getSorter : function( elem, sortBy ) {
587 + return $.data( elem, 'isotope-sort-data' )[ sortBy ];
588 + },
589 +
590 + // ====================== Layout Helpers ======================
591 +
592 + _translate : function( x, y ) {
593 + return { translate : [ x, y ] };
594 + },
595 +
596 + _positionAbs : function( x, y ) {
597 + return { left: x, top: y };
598 + },
599 +
600 + _pushPosition : function( $elem, x, y ) {
601 + x = Math.round( x + this.offset.left );
602 + y = Math.round( y + this.offset.top );
603 + var position = this.getPositionStyles( x, y );
604 + this.styleQueue.push({ $el: $elem, style: position });
605 + if ( this.options.itemPositionDataEnabled ) {
606 + $elem.data('isotope-item-position', {x: x, y: y} );
607 + }
608 + },
609 +
610 +
611 + // ====================== General Layout ======================
612 +
613 + // used on collection of atoms (should be filtered, and sorted before )
614 + // accepts atoms-to-be-laid-out to start with
615 + layout : function( $elems, callback ) {
616 +
617 + var layoutMode = this.options.layoutMode;
618 +
619 + // layout logic
620 + this[ '_' + layoutMode + 'Layout' ]( $elems );
621 +
622 + // set the size of the container
623 + if ( this.options.resizesContainer ) {
624 + var containerStyle = this[ '_' + layoutMode + 'GetContainerSize' ]();
625 + this.styleQueue.push({ $el: this.element, style: containerStyle });
626 + }
627 +
628 + this._processStyleQueue( $elems, callback );
629 +
630 + this.isLaidOut = true;
631 + },
632 +
633 + _processStyleQueue : function( $elems, callback ) {
634 + // are we animating the layout arrangement?
635 + // use plugin-ish syntax for css or animate
636 + var styleFn = !this.isLaidOut ? 'css' : (
637 + this.isUsingJQueryAnimation ? 'animate' : 'css'
638 + ),
639 + animOpts = this.options.animationOptions,
640 + onLayout = this.options.onLayout,
641 + objStyleFn, processor,
642 + triggerCallbackNow, callbackFn;
643 +
644 + // default styleQueue processor, may be overwritten down below
645 + processor = function( i, obj ) {
646 + obj.$el[ styleFn ]( obj.style, animOpts );
647 + };
648 +
649 + if ( this._isInserting && this.isUsingJQueryAnimation ) {
650 + // if using styleQueue to insert items
651 + processor = function( i, obj ) {
652 + // only animate if it not being inserted
653 + objStyleFn = obj.$el.hasClass('no-transition') ? 'css' : styleFn;
654 + obj.$el[ objStyleFn ]( obj.style, animOpts );
655 + };
656 +
657 + } else if ( callback || onLayout || animOpts.complete ) {
658 + // has callback
659 + var isCallbackTriggered = false,
660 + // array of possible callbacks to trigger
661 + callbacks = [ callback, onLayout, animOpts.complete ],
662 + instance = this;
663 + triggerCallbackNow = true;
664 + // trigger callback only once
665 + callbackFn = function() {
666 + if ( isCallbackTriggered ) {
667 + return;
668 + }
669 + var hollaback;
670 + for (var i=0, len = callbacks.length; i < len; i++) {
671 + hollaback = callbacks[i];
672 + if ( typeof hollaback === 'function' ) {
673 + hollaback.call( instance.element, $elems, instance );
674 + }
675 + }
676 + isCallbackTriggered = true;
677 + };
678 +
679 + if ( this.isUsingJQueryAnimation && styleFn === 'animate' ) {
680 + // add callback to animation options
681 + animOpts.complete = callbackFn;
682 + triggerCallbackNow = false;
683 +
684 + } else if ( Modernizr.csstransitions ) {
685 + // detect if first item has transition
686 + var i = 0,
687 + firstItem = this.styleQueue[0],
688 + testElem = firstItem && firstItem.$el,
689 + styleObj;
690 + // get first non-empty jQ object
691 + while ( !testElem || !testElem.length ) {
692 + styleObj = this.styleQueue[ i++ ];
693 + // HACK: sometimes styleQueue[i] is undefined
694 + if ( !styleObj ) {
695 + return;
696 + }
697 + testElem = styleObj.$el;
698 + }
699 + // get transition duration of the first element in that object
700 + // yeah, this is inexact
701 + var duration = parseFloat( getComputedStyle( testElem[0] )[ transitionDurProp ] );
702 + if ( duration > 0 ) {
703 + processor = function( i, obj ) {
704 + obj.$el[ styleFn ]( obj.style, animOpts )
705 + // trigger callback at transition end
706 + .one( transitionEndEvent, callbackFn );
707 + };
708 + triggerCallbackNow = false;
709 + }
710 + }
711 + }
712 +
713 + // process styleQueue
714 + $.each( this.styleQueue, processor );
715 +
716 + if ( triggerCallbackNow ) {
717 + callbackFn();
718 + }
719 +
720 + // clear out queue for next time
721 + this.styleQueue = [];
722 + },
723 +
724 +
725 + resize : function() {
726 + if ( this[ '_' + this.options.layoutMode + 'ResizeChanged' ]() ) {
727 + this.reLayout();
728 + }
729 + },
730 +
731 +
732 + reLayout : function( callback ) {
733 +
734 + this[ '_' + this.options.layoutMode + 'Reset' ]();
735 + this.layout( this.$filteredAtoms, callback );
736 +
737 + },
738 +
739 + // ====================== Convenience methods ======================
740 +
741 + // ====================== Adding items ======================
742 +
743 + // adds a jQuery object of items to a isotope container
744 + addItems : function( $content, callback ) {
745 + var $newAtoms = this._getAtoms( $content );
746 + // add new atoms to atoms pools
747 + this.$allAtoms = this.$allAtoms.add( $newAtoms );
748 +
749 + if ( callback ) {
750 + callback( $newAtoms );
751 + }
752 + },
753 +
754 + // convienence method for adding elements properly to any layout
755 + // positions items, hides them, then animates them back in <--- very sezzy
756 + insert : function( $content, callback ) {
757 + // position items
758 + this.element.append( $content );
759 +
760 + var instance = this;
761 + this.addItems( $content, function( $newAtoms ) {
762 + var $newFilteredAtoms = instance._filter( $newAtoms );
763 + instance._addHideAppended( $newFilteredAtoms );
764 + instance._sort();
765 + instance.reLayout();
766 + instance._revealAppended( $newFilteredAtoms, callback );
767 + });
768 +
769 + },
770 +
771 + // convienence method for working with Infinite Scroll
772 + appended : function( $content, callback ) {
773 + var instance = this;
774 + this.addItems( $content, function( $newAtoms ) {
775 + instance._addHideAppended( $newAtoms );
776 + instance.layout( $newAtoms );
777 + instance._revealAppended( $newAtoms, callback );
778 + });
779 + },
780 +
781 + // adds new atoms, then hides them before positioning
782 + _addHideAppended : function( $newAtoms ) {
783 + this.$filteredAtoms = this.$filteredAtoms.add( $newAtoms );
784 + $newAtoms.addClass('no-transition');
785 +
786 + this._isInserting = true;
787 +
788 + // apply hidden styles
789 + this.styleQueue.push({ $el: $newAtoms, style: this.options.hiddenStyle });
790 + },
791 +
792 + // sets visible style on new atoms
793 + _revealAppended : function( $newAtoms, callback ) {
794 + var instance = this;
795 + // apply visible style after a sec
796 + setTimeout( function() {
797 + // enable animation
798 + $newAtoms.removeClass('no-transition');
799 + // reveal newly inserted filtered elements
800 + instance.styleQueue.push({ $el: $newAtoms, style: instance.options.visibleStyle });
801 + instance._isInserting = false;
802 + instance._processStyleQueue( $newAtoms, callback );
803 + }, 10 );
804 + },
805 +
806 + // gathers all atoms
807 + reloadItems : function() {
808 + this.$allAtoms = this._getAtoms( this.element.children() );
809 + },
810 +
811 + // removes elements from Isotope widget
812 + remove: function( $content, callback ) {
813 + // remove elements immediately from Isotope instance
814 + this.$allAtoms = this.$allAtoms.not( $content );
815 + this.$filteredAtoms = this.$filteredAtoms.not( $content );
816 + // remove() as a callback, for after transition / animation
817 + var instance = this;
818 + var removeContent = function() {
819 + $content.remove();
820 + if ( callback ) {
821 + callback.call( instance.element );
822 + }
823 + };
824 +
825 + if ( $content.filter( ':not(.' + this.options.hiddenClass + ')' ).length ) {
826 + // if any non-hidden content needs to be removed
827 + this.styleQueue.push({ $el: $content, style: this.options.hiddenStyle });
828 + this._sort();
829 + this.reLayout( removeContent );
830 + } else {
831 + // remove it now
832 + removeContent();
833 + }
834 +
835 + },
836 +
837 + shuffle : function( callback ) {
838 + this.updateSortData( this.$allAtoms );
839 + this.options.sortBy = 'random';
840 + this._sort();
841 + this.reLayout( callback );
842 + },
843 +
844 + // destroys widget, returns elements and container back (close) to original style
845 + destroy : function() {
846 +
847 + var usingTransforms = this.usingTransforms;
848 + var options = this.options;
849 +
850 + this.$allAtoms
851 + .removeClass( options.hiddenClass + ' ' + options.itemClass )
852 + .each(function(){
853 + var style = this.style;
854 + style.position = '';
855 + style.top = '';
856 + style.left = '';
857 + style.opacity = '';
858 + if ( usingTransforms ) {
859 + style[ transformProp ] = '';
860 + }
861 + });
862 +
863 + // re-apply saved container styles
864 + var elemStyle = this.element[0].style;
865 + for ( var prop in this.originalStyle ) {
866 + elemStyle[ prop ] = this.originalStyle[ prop ];
867 + }
868 +
869 + this.element
870 + .unbind('.isotope')
871 + .undelegate( '.' + options.hiddenClass, 'click' )
872 + .removeClass( options.containerClass )
873 + .removeData('isotope');
874 +
875 + $window.unbind('.isotope');
876 +
877 + },
878 +
879 +
880 + // ====================== LAYOUTS ======================
881 +
882 + // calculates number of rows or columns
883 + // requires columnWidth or rowHeight to be set on namespaced object
884 + // i.e. this.masonry.columnWidth = 200
885 + _getSegments : function( isRows ) {
886 + var namespace = this.options.layoutMode,
887 + measure = isRows ? 'rowHeight' : 'columnWidth',
888 + size = isRows ? 'height' : 'width',
889 + segmentsName = isRows ? 'rows' : 'cols',
890 + containerSize = this.element[ size ](),
891 + segments,
892 + // i.e. options.masonry && options.masonry.columnWidth
893 + segmentSize = this.options[ namespace ] && this.options[ namespace ][ measure ] ||
894 + // or use the size of the first item, i.e. outerWidth
895 + this.$filteredAtoms[ 'outer' + capitalize(size) ](true) ||
896 + // if there's no items, use size of container
897 + containerSize;
898 +
899 + segments = Math.floor( containerSize / segmentSize );
900 + segments = Math.max( segments, 1 );
901 +
902 + // i.e. this.masonry.cols = ....
903 + this[ namespace ][ segmentsName ] = segments;
904 + // i.e. this.masonry.columnWidth = ...
905 + this[ namespace ][ measure ] = segmentSize;
906 +
907 + },
908 +
909 + _checkIfSegmentsChanged : function( isRows ) {
910 + var namespace = this.options.layoutMode,
911 + segmentsName = isRows ? 'rows' : 'cols',
912 + prevSegments = this[ namespace ][ segmentsName ];
913 + // update cols/rows
914 + this._getSegments( isRows );
915 + // return if updated cols/rows is not equal to previous
916 + return ( this[ namespace ][ segmentsName ] !== prevSegments );
917 + },
918 +
919 + // ====================== Masonry ======================
920 +
921 + _masonryReset : function() {
922 + // layout-specific props
923 + this.masonry = {};
924 + // FIXME shouldn't have to call this again
925 + this._getSegments();
926 + var i = this.masonry.cols;
927 + this.masonry.colYs = [];
928 + while (i--) {
929 + this.masonry.colYs.push( 0 );
930 + }
931 + },
932 +
933 + _masonryLayout : function( $elems ) {
934 + var instance = this,
935 + props = instance.masonry;
936 + $elems.each(function(){
937 + var $this = $(this),
938 + //how many columns does this brick span
939 + colSpan = Math.ceil( $this.outerWidth(true) / props.columnWidth );
940 + colSpan = Math.min( colSpan, props.cols );
941 +
942 + if ( colSpan === 1 ) {
943 + // if brick spans only one column, just like singleMode
944 + instance._masonryPlaceBrick( $this, props.colYs );
945 + } else {
946 + // brick spans more than one column
947 + // how many different places could this brick fit horizontally
948 + var groupCount = props.cols + 1 - colSpan,
949 + groupY = [],
950 + groupColY,
951 + i;
952 +
953 + // for each group potential horizontal position
954 + for ( i=0; i < groupCount; i++ ) {
955 + // make an array of colY values for that one group
956 + groupColY = props.colYs.slice( i, i+colSpan );
957 + // and get the max value of the array
958 + groupY[i] = Math.max.apply( Math, groupColY );
959 + }
960 +
961 + instance._masonryPlaceBrick( $this, groupY );
962 + }
963 + });
964 + },
965 +
966 + // worker method that places brick in the columnSet
967 + // with the the minY
968 + _masonryPlaceBrick : function( $brick, setY ) {
969 + // get the minimum Y value from the columns
970 + var minimumY = Math.min.apply( Math, setY ),
971 + shortCol = 0;
972 +
973 + // Find index of short column, the first from the left
974 + for (var i=0, len = setY.length; i < len; i++) {
975 + if ( setY[i] === minimumY ) {
976 + shortCol = i;
977 + break;
978 + }
979 + }
980 +
981 + // position the brick
982 + var x = this.masonry.columnWidth * shortCol,
983 + y = minimumY;
984 + this._pushPosition( $brick, x, y );
985 +
986 + // apply setHeight to necessary columns
987 + var setHeight = minimumY + $brick.outerHeight(true),
988 + setSpan = this.masonry.cols + 1 - len;
989 + for ( i=0; i < setSpan; i++ ) {
990 + this.masonry.colYs[ shortCol + i ] = setHeight;
991 + }
992 +
993 + },
994 +
995 + _masonryGetContainerSize : function() {
996 + var containerHeight = Math.max.apply( Math, this.masonry.colYs );
997 + return { height: containerHeight };
998 + },
999 +
1000 + _masonryResizeChanged : function() {
1001 + return this._checkIfSegmentsChanged();
1002 + },
1003 +
1004 + // ====================== fitRows ======================
1005 +
1006 + _fitRowsReset : function() {
1007 + this.fitRows = {
1008 + x : 0,
1009 + y : 0,
1010 + height : 0
1011 + };
1012 + },
1013 +
1014 + _fitRowsLayout : function( $elems ) {
1015 + var instance = this,
1016 + containerWidth = this.element.width(),
1017 + props = this.fitRows;
1018 +
1019 + $elems.each( function() {
1020 + var $this = $(this),
1021 + atomW = $this.outerWidth(true),
1022 + atomH = $this.outerHeight(true);
1023 +
1024 + if ( props.x !== 0 && atomW + props.x > containerWidth ) {
1025 + // if this element cannot fit in the current row
1026 + props.x = 0;
1027 + props.y = props.height;
1028 + }
1029 +
1030 + // position the atom
1031 + instance._pushPosition( $this, props.x, props.y );
1032 +
1033 + props.height = Math.max( props.y + atomH, props.height );
1034 + props.x += atomW;
1035 +
1036 + });
1037 + },
1038 +
1039 + _fitRowsGetContainerSize : function () {
1040 + return { height : this.fitRows.height };
1041 + },
1042 +
1043 + _fitRowsResizeChanged : function() {
1044 + return true;
1045 + },
1046 +
1047 +
1048 + // ====================== cellsByRow ======================
1049 +
1050 + _cellsByRowReset : function() {
1051 + this.cellsByRow = {
1052 + index : 0
1053 + };
1054 + // get this.cellsByRow.columnWidth
1055 + this._getSegments();
1056 + // get this.cellsByRow.rowHeight
1057 + this._getSegments(true);
1058 + },
1059 +
1060 + _cellsByRowLayout : function( $elems ) {
1061 + var instance = this,
1062 + props = this.cellsByRow;
1063 + $elems.each( function(){
1064 + var $this = $(this),
1065 + col = props.index % props.cols,
1066 + row = Math.floor( props.index / props.cols ),
1067 + x = ( col + 0.5 ) * props.columnWidth - $this.outerWidth(true) / 2,
1068 + y = ( row + 0.5 ) * props.rowHeight - $this.outerHeight(true) / 2;
1069 + instance._pushPosition( $this, x, y );
1070 + props.index ++;
1071 + });
1072 + },
1073 +
1074 + _cellsByRowGetContainerSize : function() {
1075 + return { height : Math.ceil( this.$filteredAtoms.length / this.cellsByRow.cols ) * this.cellsByRow.rowHeight + this.offset.top };
1076 + },
1077 +
1078 + _cellsByRowResizeChanged : function() {
1079 + return this._checkIfSegmentsChanged();
1080 + },
1081 +
1082 +
1083 + // ====================== straightDown ======================
1084 +
1085 + _straightDownReset : function() {
1086 + this.straightDown = {
1087 + y : 0
1088 + };
1089 + },
1090 +
1091 + _straightDownLayout : function( $elems ) {
1092 + var instance = this;
1093 + $elems.each( function( i ){
1094 + var $this = $(this);
1095 + instance._pushPosition( $this, 0, instance.straightDown.y );
1096 + instance.straightDown.y += $this.outerHeight(true);
1097 + });
1098 + },
1099 +
1100 + _straightDownGetContainerSize : function() {
1101 + return { height : this.straightDown.y };
1102 + },
1103 +
1104 + _straightDownResizeChanged : function() {
1105 + return true;
1106 + },
1107 +
1108 +
1109 + // ====================== masonryHorizontal ======================
1110 +
1111 + _masonryHorizontalReset : function() {
1112 + // layout-specific props
1113 + this.masonryHorizontal = {};
1114 + // FIXME shouldn't have to call this again
1115 + this._getSegments( true );
1116 + var i = this.masonryHorizontal.rows;
1117 + this.masonryHorizontal.rowXs = [];
1118 + while (i--) {
1119 + this.masonryHorizontal.rowXs.push( 0 );
1120 + }
1121 + },
1122 +
1123 + _masonryHorizontalLayout : function( $elems ) {
1124 + var instance = this,
1125 + props = instance.masonryHorizontal;
1126 + $elems.each(function(){
1127 + var $this = $(this),
1128 + //how many rows does this brick span
1129 + rowSpan = Math.ceil( $this.outerHeight(true) / props.rowHeight );
1130 + rowSpan = Math.min( rowSpan, props.rows );
1131 +
1132 + if ( rowSpan === 1 ) {
1133 + // if brick spans only one column, just like singleMode
1134 + instance._masonryHorizontalPlaceBrick( $this, props.rowXs );
1135 + } else {
1136 + // brick spans more than one row
1137 + // how many different places could this brick fit horizontally
1138 + var groupCount = props.rows + 1 - rowSpan,
1139 + groupX = [],
1140 + groupRowX, i;
1141 +
1142 + // for each group potential horizontal position
1143 + for ( i=0; i < groupCount; i++ ) {
1144 + // make an array of colY values for that one group
1145 + groupRowX = props.rowXs.slice( i, i+rowSpan );
1146 + // and get the max value of the array
1147 + groupX[i] = Math.max.apply( Math, groupRowX );
1148 + }
1149 +
1150 + instance._masonryHorizontalPlaceBrick( $this, groupX );
1151 + }
1152 + });
1153 + },
1154 +
1155 + _masonryHorizontalPlaceBrick : function( $brick, setX ) {
1156 + // get the minimum Y value from the columns
1157 + var minimumX = Math.min.apply( Math, setX ),
1158 + smallRow = 0;
1159 + // Find index of smallest row, the first from the top
1160 + for (var i=0, len = setX.length; i < len; i++) {
1161 + if ( setX[i] === minimumX ) {
1162 + smallRow = i;
1163 + break;
1164 + }
1165 + }
1166 +
1167 + // position the brick
1168 + var x = minimumX,
1169 + y = this.masonryHorizontal.rowHeight * smallRow;
1170 + this._pushPosition( $brick, x, y );
1171 +
1172 + // apply setHeight to necessary columns
1173 + var setWidth = minimumX + $brick.outerWidth(true),
1174 + setSpan = this.masonryHorizontal.rows + 1 - len;
1175 + for ( i=0; i < setSpan; i++ ) {
1176 + this.masonryHorizontal.rowXs[ smallRow + i ] = setWidth;
1177 + }
1178 + },
1179 +
1180 + _masonryHorizontalGetContainerSize : function() {
1181 + var containerWidth = Math.max.apply( Math, this.masonryHorizontal.rowXs );
1182 + return { width: containerWidth };
1183 + },
1184 +
1185 + _masonryHorizontalResizeChanged : function() {
1186 + return this._checkIfSegmentsChanged(true);
1187 + },
1188 +
1189 +
1190 + // ====================== fitColumns ======================
1191 +
1192 + _fitColumnsReset : function() {
1193 + this.fitColumns = {
1194 + x : 0,
1195 + y : 0,
1196 + width : 0
1197 + };
1198 + },
1199 +
1200 + _fitColumnsLayout : function( $elems ) {
1201 + var instance = this,
1202 + containerHeight = this.element.height(),
1203 + props = this.fitColumns;
1204 + $elems.each( function() {
1205 + var $this = $(this),
1206 + atomW = $this.outerWidth(true),
1207 + atomH = $this.outerHeight(true);
1208 +
1209 + if ( props.y !== 0 && atomH + props.y > containerHeight ) {
1210 + // if this element cannot fit in the current column
1211 + props.x = props.width;
1212 + props.y = 0;
1213 + }
1214 +
1215 + // position the atom
1216 + instance._pushPosition( $this, props.x, props.y );
1217 +
1218 + props.width = Math.max( props.x + atomW, props.width );
1219 + props.y += atomH;
1220 +
1221 + });
1222 + },
1223 +
1224 + _fitColumnsGetContainerSize : function () {
1225 + return { width : this.fitColumns.width };
1226 + },
1227 +
1228 + _fitColumnsResizeChanged : function() {
1229 + return true;
1230 + },
1231 +
1232 +
1233 +
1234 + // ====================== cellsByColumn ======================
1235 +
1236 + _cellsByColumnReset : function() {
1237 + this.cellsByColumn = {
1238 + index : 0
1239 + };
1240 + // get this.cellsByColumn.columnWidth
1241 + this._getSegments();
1242 + // get this.cellsByColumn.rowHeight
1243 + this._getSegments(true);
1244 + },
1245 +
1246 + _cellsByColumnLayout : function( $elems ) {
1247 + var instance = this,
1248 + props = this.cellsByColumn;
1249 + $elems.each( function(){
1250 + var $this = $(this),
1251 + col = Math.floor( props.index / props.rows ),
1252 + row = props.index % props.rows,
1253 + x = ( col + 0.5 ) * props.columnWidth - $this.outerWidth(true) / 2,
1254 + y = ( row + 0.5 ) * props.rowHeight - $this.outerHeight(true) / 2;
1255 + instance._pushPosition( $this, x, y );
1256 + props.index ++;
1257 + });
1258 + },
1259 +
1260 + _cellsByColumnGetContainerSize : function() {
1261 + return { width : Math.ceil( this.$filteredAtoms.length / this.cellsByColumn.rows ) * this.cellsByColumn.columnWidth };
1262 + },
1263 +
1264 + _cellsByColumnResizeChanged : function() {
1265 + return this._checkIfSegmentsChanged(true);
1266 + },
1267 +
1268 + // ====================== straightAcross ======================
1269 +
1270 + _straightAcrossReset : function() {
1271 + this.straightAcross = {
1272 + x : 0
1273 + };
1274 + },
1275 +
1276 + _straightAcrossLayout : function( $elems ) {
1277 + var instance = this;
1278 + $elems.each( function( i ){
1279 + var $this = $(this);
1280 + instance._pushPosition( $this, instance.straightAcross.x, 0 );
1281 + instance.straightAcross.x += $this.outerWidth(true);
1282 + });
1283 + },
1284 +
1285 + _straightAcrossGetContainerSize : function() {
1286 + return { width : this.straightAcross.x };
1287 + },
1288 +
1289 + _straightAcrossResizeChanged : function() {
1290 + return true;
1291 + }
1292 +
1293 + };
1294 +
1295 +
1296 + // ======================= imagesLoaded Plugin ===============================
1297 + /*!
1298 + * jQuery imagesLoaded plugin v1.1.0
1299 + * http://github.com/desandro/imagesloaded
1300 + *
1301 + * MIT License. by Paul Irish et al.
1302 + */
1303 +
1304 +
1305 + // $('#my-container').imagesLoaded(myFunction)
1306 + // or
1307 + // $('img').imagesLoaded(myFunction)
1308 +
1309 + // execute a callback when all images have loaded.
1310 + // needed because .load() doesn't work on cached images
1311 +
1312 + // callback function gets image collection as argument
1313 + // `this` is the container
1314 +
1315 + $.fn.imagesLoaded = function( callback ) {
1316 + var $this = this,
1317 + $images = $this.find('img').add( $this.filter('img') ),
1318 + len = $images.length,
1319 + blank = '',
1320 + loaded = [];
1321 +
1322 + function triggerCallback() {
1323 + callback.call( $this, $images );
1324 + }
1325 +
1326 + function imgLoaded( event ) {
1327 + var img = event.target;
1328 + if ( img.src !== blank && $.inArray( img, loaded ) === -1 ){
1329 + loaded.push( img );
1330 + if ( --len <= 0 ){
1331 + setTimeout( triggerCallback );
1332 + $images.unbind( '.imagesLoaded', imgLoaded );
1333 + }
1334 + }
1335 + }
1336 +
1337 + // if no images, trigger immediately
1338 + if ( !len ) {
1339 + triggerCallback();
1340 + }
1341 +
1342 + $images.bind( 'load.imagesLoaded error.imagesLoaded', imgLoaded ).each( function() {
1343 + // cached images don't fire load sometimes, so we reset src.
1344 + var src = this.src;
1345 + // webkit hack from http://groups.google.com/group/jquery-dev/browse_thread/thread/eee6ab7b2da50e1f
1346 + // data uri bypasses webkit log warning (thx doug jones)
1347 + this.src = blank;
1348 + this.src = src;
1349 + });
1350 +
1351 + return $this;
1352 + };
1353 +
1354 +
1355 + // helper function for logging errors
1356 + // $.error breaks jQuery chaining
1357 + var logError = function( message ) {
1358 + if ( window.console ) {
1359 + window.console.error( message );
1360 + }
1361 + };
1362 +
1363 + // ======================= Plugin bridge ===============================
1364 + // leverages data method to either create or return $.Isotope constructor
1365 + // A bit from jQuery UI
1366 + // https://github.com/jquery/jquery-ui/blob/master/ui/jquery.ui.widget.js
1367 + // A bit from jcarousel
1368 + // https://github.com/jsor/jcarousel/blob/master/lib/jquery.jcarousel.js
1369 +
1370 + $.fn.isotope = function( options, callback ) {
1371 + if ( typeof options === 'string' ) {
1372 + // call method
1373 + var args = Array.prototype.slice.call( arguments, 1 );
1374 +
1375 + this.each(function(){
1376 + var instance = $.data( this, 'isotope' );
1377 + if ( !instance ) {
1378 + logError( "cannot call methods on isotope prior to initialization; " +
1379 + "attempted to call method '" + options + "'" );
1380 + return;
1381 + }
1382 + if ( !$.isFunction( instance[options] ) || options.charAt(0) === "_" ) {
1383 + logError( "no such method '" + options + "' for isotope instance" );
1384 + return;
1385 + }
1386 + // apply method
1387 + instance[ options ].apply( instance, args );
1388 + });
1389 + } else {
1390 + this.each(function() {
1391 + var instance = $.data( this, 'isotope' );
1392 + if ( instance ) {
1393 + // apply options & init
1394 + instance.option( options );
1395 + instance._init( callback );
1396 + } else {
1397 + // initialize new instance
1398 + $.data( this, 'isotope', new $.Isotope( options, this, callback ) );
1399 + }
1400 + });
1401 + }
1402 + // return jQuery object
1403 + // so plugin methods do not have to
1404 + return this;
1405 + };
1406 +
1407 +})( window, jQuery );
...\ No newline at end of file ...\ No newline at end of file
1 +
2 +function main() {
3 +
4 +(function () {
5 + 'use strict';
6 +
7 + $('a.page-scroll').click(function() {
8 + if (location.pathname.replace(/^\//,'') == this.pathname.replace(/^\//,'') && location.hostname == this.hostname) {
9 + var target = $(this.hash);
10 + target = target.length ? target : $('[name=' + this.hash.slice(1) +']');
11 + if (target.length) {
12 + $('html,body').animate({
13 + scrollTop: target.offset().top - 40
14 + }, 900);
15 + return false;
16 + }
17 + }
18 + });
19 +
20 +
21 + // Show Menu on Book
22 + $(window).bind('scroll', function() {
23 + var navHeight = $(window).height() - 500;
24 + if ($(window).scrollTop() > navHeight) {
25 + $('.navbar-default').addClass('on');
26 + } else {
27 + $('.navbar-default').removeClass('on');
28 + }
29 + });
30 +
31 + $('body').scrollspy({
32 + target: '.navbar-default',
33 + offset: 80
34 + });
35 +
36 + // Hide nav on click
37 + $(".navbar-nav li a").click(function (event) {
38 + // check if window is small enough so dropdown is created
39 + var toggle = $(".navbar-toggle").is(":visible");
40 + if (toggle) {
41 + $(".navbar-collapse").collapse('hide');
42 + }
43 + });
44 +
45 + // Portfolio isotope filter
46 + $(window).load(function() {
47 + var $container = $('.portfolio-items');
48 + $container.isotope({
49 + filter: '*',
50 + animationOptions: {
51 + duration: 750,
52 + easing: 'linear',
53 + queue: false
54 + }
55 + });
56 + $('.cat a').click(function() {
57 + $('.cat .active').removeClass('active');
58 + $(this).addClass('active');
59 + var selector = $(this).attr('data-filter');
60 + $container.isotope({
61 + filter: selector,
62 + animationOptions: {
63 + duration: 750,
64 + easing: 'linear',
65 + queue: false
66 + }
67 + });
68 + return false;
69 + });
70 +
71 + });
72 +
73 + // Nivo Lightbox
74 + $('.portfolio-item a').nivoLightbox({
75 + effect: 'slideDown',
76 + keyboardNav: true,
77 + });
78 +
79 +}());
80 +
81 +
82 +}
83 +main();
...\ No newline at end of file ...\ No newline at end of file
...@@ -2,7 +2,39 @@ ...@@ -2,7 +2,39 @@
2 <html> 2 <html>
3 <head> 3 <head>
4 <title>내툰</title> 4 <title>내툰</title>
5 - <link rel='stylesheet' href='/stylesheets/style.css' /> 5 + <link rel='stylesheet' href='/stylesheets/style2.css' />
6 + <meta charset="utf-8">
7 + <meta name="viewport" content="width=device-width, initial-scale=1">
8 + <title>Touché</title>
9 + <meta name="description" content="">
10 + <meta name="author" content="">
11 +
12 + <!-- Favicons
13 + ================================================== -->
14 + <link rel="shortcut icon" href="img/favicon.ico" type="image/x-icon">
15 + <link rel="apple-touch-icon" href="img/apple-touch-icon.png">
16 + <link rel="apple-touch-icon" sizes="72x72" href="img/apple-touch-icon-72x72.png">
17 + <link rel="apple-touch-icon" sizes="114x114" href="img/apple-touch-icon-114x114.png">
18 +
19 + <!-- Bootstrap -->
20 + <link rel="stylesheet" type="text/css" href="css/bootstrap.css">
21 + <link rel="stylesheet" type="text/css" href="fonts/font-awesome/css/font-awesome.css">
22 +
23 + <!-- Stylesheet
24 + ================================================== -->
25 + <link rel="stylesheet" type="text/css" href="css/style.css">
26 + <link rel="stylesheet" type="text/css" href="css/nivo-lightbox/nivo-lightbox.css">
27 + <link rel="stylesheet" type="text/css" href="css/nivo-lightbox/default.css">
28 + <link href="https://fonts.googleapis.com/css?family=Raleway:300,400,500,600,700" rel="stylesheet">
29 + <link href="https://fonts.googleapis.com/css?family=Open+Sans:300,400,600,700" rel="stylesheet">
30 + <link href="https://fonts.googleapis.com/css?family=Dancing+Script:400,700" rel="stylesheet">
31 +
32 + <!-- HTML5 shim and Respond.js for IE8 support of HTML5 elements and media queries -->
33 + <!-- WARNING: Respond.js doesn't work if you view the page via file:// -->
34 + <!--[if lt IE 9]>
35 + <script src="https://oss.maxcdn.com/html5shiv/3.7.2/html5shiv.min.js"></script>
36 + <script src="https://oss.maxcdn.com/respond/1.4.2/respond.min.js"></script>
37 + <![endif]-->
6 <style> 38 <style>
7 .toon_name,.toon_thumbnail{ 39 .toon_name,.toon_thumbnail{
8 width:10%; 40 width:10%;
...@@ -24,6 +56,7 @@ ...@@ -24,6 +56,7 @@
24 border-bottom:2px solid #474747; 56 border-bottom:2px solid #474747;
25 } 57 }
26 </style> 58 </style>
59 +
27 </head> 60 </head>
28 <h1>내툰</h1> 61 <h1>내툰</h1>
29 <p>추가한 리스트</p> 62 <p>추가한 리스트</p>
......
1 +/*
2 + * Nivo Lightbox v1.2.0
3 + * http://dev7studios.com/nivo-lightbox
4 + *
5 + * Copyright 2013, Dev7studios
6 + * Free to use and abuse under the MIT license.
7 + * http://www.opensource.org/licenses/mit-license.php
8 + */
9 +
10 +;(function($, window, document, undefined){
11 +
12 + var pluginName = 'nivoLightbox',
13 + defaults = {
14 + effect: 'fade',
15 + theme: 'default',
16 + keyboardNav: true,
17 + clickOverlayToClose: true,
18 + onInit: function(){},
19 + beforeShowLightbox: function(){},
20 + afterShowLightbox: function(lightbox){},
21 + beforeHideLightbox: function(){},
22 + afterHideLightbox: function(){},
23 + onPrev: function(element){},
24 + onNext: function(element){},
25 + errorMessage: 'The requested content cannot be loaded. Please try again later.'
26 + };
27 +
28 + function NivoLightbox(element, options){
29 + this.el = element;
30 + this.$el = $(this.el);
31 +
32 + this.options = $.extend({}, defaults, options);
33 +
34 + this._defaults = defaults;
35 + this._name = pluginName;
36 +
37 + this.init();
38 + }
39 +
40 + NivoLightbox.prototype = {
41 +
42 + init: function(){
43 + var $this = this;
44 +
45 + // Need this so we don't use CSS transitions in mobile
46 + if(!$('html').hasClass('nivo-lightbox-notouch')) $('html').addClass('nivo-lightbox-notouch');
47 + if('ontouchstart' in document) $('html').removeClass('nivo-lightbox-notouch');
48 +
49 + // Setup the click
50 + this.$el.on('click', function(e){
51 + $this.showLightbox(e);
52 + });
53 +
54 + // keyboardNav
55 + if(this.options.keyboardNav){
56 + $('body').off('keyup').on('keyup', function(e){
57 + var code = (e.keyCode ? e.keyCode : e.which);
58 + // Escape
59 + if(code == 27) $this.destructLightbox();
60 + // Left
61 + if(code == 37) $('.nivo-lightbox-prev').trigger('click');
62 + // Right
63 + if(code == 39) $('.nivo-lightbox-next').trigger('click');
64 + });
65 + }
66 +
67 + this.options.onInit.call(this);
68 +
69 + },
70 +
71 + showLightbox: function(e){
72 + var $this = this,
73 + currentLink = this.$el;
74 +
75 + // Check content
76 + var check = this.checkContent(currentLink);
77 + if(!check) return;
78 +
79 + e.preventDefault();
80 + this.options.beforeShowLightbox.call(this);
81 + var lightbox = this.constructLightbox();
82 + if(!lightbox) return;
83 + var content = lightbox.find('.nivo-lightbox-content');
84 + if(!content) return;
85 +
86 + $('body').addClass('nivo-lightbox-body-effect-'+ this.options.effect);
87 +
88 + this.processContent( content, currentLink );
89 +
90 + // Nav
91 + if(this.$el.attr('data-lightbox-gallery')){
92 + var galleryItems = $('[data-lightbox-gallery="'+ this.$el.attr('data-lightbox-gallery') +'"]');
93 +
94 + $('.nivo-lightbox-nav').show();
95 +
96 + // Prev
97 + $('.nivo-lightbox-prev').off('click').on('click', function(e){
98 + e.preventDefault();
99 + var index = galleryItems.index(currentLink);
100 + currentLink = galleryItems.eq(index - 1);
101 + if(!$(currentLink).length) currentLink = galleryItems.last();
102 + $this.processContent(content, currentLink);
103 + $this.options.onPrev.call(this, [ currentLink ]);
104 + });
105 +
106 + // Next
107 + $('.nivo-lightbox-next').off('click').on('click', function(e){
108 + e.preventDefault();
109 + var index = galleryItems.index(currentLink);
110 + currentLink = galleryItems.eq(index + 1);
111 + if(!$(currentLink).length) currentLink = galleryItems.first();
112 + $this.processContent(content, currentLink);
113 + $this.options.onNext.call(this, [ currentLink ]);
114 + });
115 + }
116 +
117 + setTimeout(function(){
118 + lightbox.addClass('nivo-lightbox-open');
119 + $this.options.afterShowLightbox.call(this, [ lightbox ]);
120 + }, 1); // For CSS transitions
121 + },
122 +
123 + checkContent: function( link ) {
124 + var $this = this,
125 + href = link.attr('href'),
126 + video = href.match(/(youtube|youtu|vimeo)\.(com|be)\/(watch\?v=([\w-]+)|([\w-]+))/);
127 +
128 + if(href.match(/\.(jpeg|jpg|gif|png)$/i) !== null){
129 + return true;
130 + }
131 + // Video (Youtube/Vimeo)
132 + else if(video){
133 + return true;
134 + }
135 + // AJAX
136 + else if(link.attr('data-lightbox-type') == 'ajax'){
137 + return true;
138 + }
139 + // Inline HTML
140 + else if(href.substring(0, 1) == '#' && link.attr('data-lightbox-type') == 'inline'){
141 + return true;
142 + }
143 + // iFrame (default)
144 + else if(link.attr('data-lightbox-type') == 'iframe'){
145 + return true;
146 + }
147 +
148 + return false;
149 + },
150 +
151 + processContent: function(content, link){
152 + var $this = this,
153 + href = link.attr('href'),
154 + video = href.match(/(youtube|youtu|vimeo)\.(com|be)\/(watch\?v=([\w-]+)|([\w-]+))/);
155 +
156 + content.html('').addClass('nivo-lightbox-loading');
157 +
158 + // Is HiDPI?
159 + if(this.isHidpi() && link.attr('data-lightbox-hidpi')){
160 + href = link.attr('data-lightbox-hidpi');
161 + }
162 +
163 + // Image
164 + if(href.match(/\.(jpeg|jpg|gif|png)$/i) !== null){
165 + var img = $('<img>', { src: href });
166 + img.one('load', function() {
167 + var wrap = $('<div class="nivo-lightbox-image" />');
168 + wrap.append(img);
169 + content.html(wrap).removeClass('nivo-lightbox-loading');
170 +
171 + // Vertically center images
172 + wrap.css({
173 + 'line-height': $('.nivo-lightbox-content').height() +'px',
174 + 'height': $('.nivo-lightbox-content').height() +'px' // For Firefox
175 + });
176 + $(window).resize(function() {
177 + wrap.css({
178 + 'line-height': $('.nivo-lightbox-content').height() +'px',
179 + 'height': $('.nivo-lightbox-content').height() +'px' // For Firefox
180 + });
181 + });
182 + }).each(function() {
183 + if(this.complete) $(this).load();
184 + });
185 +
186 + img.error(function() {
187 + var wrap = $('<div class="nivo-lightbox-error"><p>'+ $this.options.errorMessage +'</p></div>');
188 + content.html(wrap).removeClass('nivo-lightbox-loading');
189 + });
190 + }
191 + // Video (Youtube/Vimeo)
192 + else if(video){
193 + var src = '',
194 + classTerm = 'nivo-lightbox-video';
195 +
196 + if(video[1] == 'youtube'){
197 + src = 'http://www.youtube.com/embed/'+ video[4];
198 + classTerm = 'nivo-lightbox-youtube';
199 + }
200 + if(video[1] == 'youtu'){
201 + src = 'http://www.youtube.com/embed/'+ video[3];
202 + classTerm = 'nivo-lightbox-youtube';
203 + }
204 + if(video[1] == 'vimeo'){
205 + src = 'http://player.vimeo.com/video/'+ video[3];
206 + classTerm = 'nivo-lightbox-vimeo';
207 + }
208 +
209 + if(src){
210 + var iframeVideo = $('<iframe>', {
211 + src: src,
212 + 'class': classTerm,
213 + frameborder: 0,
214 + vspace: 0,
215 + hspace: 0,
216 + scrolling: 'auto'
217 + });
218 + content.html(iframeVideo);
219 + iframeVideo.load(function(){ content.removeClass('nivo-lightbox-loading'); });
220 + }
221 + }
222 + // AJAX
223 + else if(link.attr('data-lightbox-type') == 'ajax'){
224 + $.ajax({
225 + url: href,
226 + cache: false,
227 + success: function(data) {
228 + var wrap = $('<div class="nivo-lightbox-ajax" />');
229 + wrap.append(data);
230 + content.html(wrap).removeClass('nivo-lightbox-loading');
231 +
232 + // Vertically center html
233 + if(wrap.outerHeight() < content.height()){
234 + wrap.css({
235 + 'position': 'relative',
236 + 'top': '50%',
237 + 'margin-top': -(wrap.outerHeight()/2) +'px'
238 + });
239 + }
240 + $(window).resize(function() {
241 + if(wrap.outerHeight() < content.height()){
242 + wrap.css({
243 + 'position': 'relative',
244 + 'top': '50%',
245 + 'margin-top': -(wrap.outerHeight()/2) +'px'
246 + });
247 + }
248 + });
249 + },
250 + error: function(){
251 + var wrap = $('<div class="nivo-lightbox-error"><p>'+ $this.options.errorMessage +'</p></div>');
252 + content.html(wrap).removeClass('nivo-lightbox-loading');
253 + }
254 + });
255 + }
256 + // Inline HTML
257 + else if(href.substring(0, 1) == '#' && link.attr('data-lightbox-type') == 'inline'){
258 + if($(href).length){
259 + var wrap = $('<div class="nivo-lightbox-inline" />');
260 + wrap.append($(href).clone().show());
261 + content.html(wrap).removeClass('nivo-lightbox-loading');
262 +
263 + // Vertically center html
264 + if(wrap.outerHeight() < content.height()){
265 + wrap.css({
266 + 'position': 'relative',
267 + 'top': '50%',
268 + 'margin-top': -(wrap.outerHeight()/2) +'px'
269 + });
270 + }
271 + $(window).resize(function() {
272 + if(wrap.outerHeight() < content.height()){
273 + wrap.css({
274 + 'position': 'relative',
275 + 'top': '50%',
276 + 'margin-top': -(wrap.outerHeight()/2) +'px'
277 + });
278 + }
279 + });
280 + } else {
281 + var wrapError = $('<div class="nivo-lightbox-error"><p>'+ $this.options.errorMessage +'</p></div>');
282 + content.html(wrapError).removeClass('nivo-lightbox-loading');
283 + }
284 + }
285 + // iFrame (default)
286 + else if(link.attr('data-lightbox-type') == 'iframe'){
287 + var iframe = $('<iframe>', {
288 + src: href,
289 + 'class': 'nivo-lightbox-item',
290 + frameborder: 0,
291 + vspace: 0,
292 + hspace: 0,
293 + scrolling: 'auto'
294 + });
295 + content.html(iframe);
296 + iframe.load(function(){ content.removeClass('nivo-lightbox-loading'); });
297 + } else {
298 + return false;
299 + }
300 +
301 + // Set the title
302 + if(link.attr('title')){
303 + var titleWrap = $('<span>', { 'class': 'nivo-lightbox-title' });
304 + titleWrap.text(link.attr('title'));
305 + $('.nivo-lightbox-title-wrap').html(titleWrap);
306 + } else {
307 + $('.nivo-lightbox-title-wrap').html('');
308 + }
309 + },
310 +
311 + constructLightbox: function(){
312 + if($('.nivo-lightbox-overlay').length) return $('.nivo-lightbox-overlay');
313 +
314 + var overlay = $('<div>', { 'class': 'nivo-lightbox-overlay nivo-lightbox-theme-'+ this.options.theme +' nivo-lightbox-effect-'+ this.options.effect });
315 + var wrap = $('<div>', { 'class': 'nivo-lightbox-wrap' });
316 + var content = $('<div>', { 'class': 'nivo-lightbox-content' });
317 + var nav = $('<a href="#" class="nivo-lightbox-nav nivo-lightbox-prev">Previous</a><a href="#" class="nivo-lightbox-nav nivo-lightbox-next">Next</a>');
318 + var close = $('<a href="#" class="nivo-lightbox-close" title="Close">Close</a>');
319 + var title = $('<div>', { 'class': 'nivo-lightbox-title-wrap' });
320 +
321 + var isMSIE = /*@cc_on!@*/0;
322 + if(isMSIE) overlay.addClass('nivo-lightbox-ie');
323 +
324 + wrap.append(content);
325 + wrap.append(title);
326 + overlay.append(wrap);
327 + overlay.append(nav);
328 + overlay.append(close);
329 + $('body').append(overlay);
330 +
331 + var $this = this;
332 + if($this.options.clickOverlayToClose){
333 + overlay.on('click', function(e){
334 + if(e.target === this || $(e.target).hasClass('nivo-lightbox-content') || $(e.target).hasClass('nivo-lightbox-image')){
335 + $this.destructLightbox();
336 + }
337 + });
338 + }
339 +
340 + close.on('click', function(e){
341 + e.preventDefault();
342 + $this.destructLightbox();
343 + });
344 +
345 + return overlay;
346 + },
347 +
348 + destructLightbox: function(){
349 + var $this = this;
350 + this.options.beforeHideLightbox.call(this);
351 +
352 + $('.nivo-lightbox-overlay').removeClass('nivo-lightbox-open');
353 + $('.nivo-lightbox-nav').hide();
354 + $('body').removeClass('nivo-lightbox-body-effect-'+ $this.options.effect);
355 +
356 + // For IE
357 + var isMSIE = /*@cc_on!@*/0;
358 + if(isMSIE){
359 + $('.nivo-lightbox-overlay iframe').attr("src", " ");
360 + $('.nivo-lightbox-overlay iframe').remove();
361 + }
362 +
363 + // Remove click handlers
364 + $('.nivo-lightbox-prev').off('click');
365 + $('.nivo-lightbox-next').off('click');
366 +
367 + // Empty content (for videos)
368 + $('.nivo-lightbox-content').empty();
369 +
370 + this.options.afterHideLightbox.call(this);
371 + },
372 +
373 + isHidpi: function(){
374 + var mediaQuery = "(-webkit-min-device-pixel-ratio: 1.5),\
375 + (min--moz-device-pixel-ratio: 1.5),\
376 + (-o-min-device-pixel-ratio: 3/2),\
377 + (min-resolution: 1.5dppx)";
378 + if(window.devicePixelRatio > 1) return true;
379 + if(window.matchMedia && window.matchMedia(mediaQuery).matches) return true;
380 + return false;
381 + }
382 +
383 + };
384 +
385 + $.fn[pluginName] = function(options){
386 + return this.each(function(){
387 + if(!$.data(this, pluginName)){
388 + $.data(this, pluginName, new NivoLightbox(this, options));
389 + }
390 + });
391 + };
392 +
393 +})(jQuery, window, document);
No preview for this file type