scriptorium 0.0.3 → 0.6.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (292) hide show
  1. checksums.yaml +4 -4
  2. data/README.lt3 +324 -0
  3. data/README.md +3155 -1
  4. data/assets/.DS_Store +0 -0
  5. data/assets/README.md +44 -0
  6. data/assets/back-icon.png +0 -0
  7. data/assets/icons/facebook.svg +1 -0
  8. data/assets/icons/github.svg +1 -0
  9. data/assets/icons/instagram.svg +1 -0
  10. data/assets/icons/reddit.svg +1 -0
  11. data/assets/icons/ui/.DS_Store +0 -0
  12. data/assets/icons/ui/back.png +0 -0
  13. data/assets/icons/ui/copy.png +0 -0
  14. data/assets/icons/ui/down.png +0 -0
  15. data/assets/icons/ui/end.png +0 -0
  16. data/assets/icons/ui/exit.png +0 -0
  17. data/assets/icons/ui/foo +10 -0
  18. data/assets/icons/ui/home.png +0 -0
  19. data/assets/icons/ui/left.png +0 -0
  20. data/assets/icons/ui/next.png +0 -0
  21. data/assets/icons/ui/right.png +0 -0
  22. data/assets/icons/ui/start.png +0 -0
  23. data/assets/icons/ui/up.png +0 -0
  24. data/assets/icons/x.svg +1 -0
  25. data/assets/icons/youtube.svg +1 -0
  26. data/assets/samples/placeholder.svg +9 -0
  27. data/assets/themes/standard/favicon.svg +6 -0
  28. data/bin/scriptorium +1511 -0
  29. data/doc/README.txt +6 -0
  30. data/doc/anti-amnesia/20250727-054000-scriptorium-overview.md +95 -0
  31. data/doc/anti-amnesia/20250727-060000-api-design-tui-planning.md +34 -0
  32. data/doc/anti-amnesia/20250727-061000-runeblog-tui-analysis.md +50 -0
  33. data/doc/anti-amnesia/20250727-123000-anti-amnesia-conventions.md +31 -0
  34. data/doc/anti-amnesia/20250727-154000-livetext-plugin-file-stats.md +73 -0
  35. data/doc/anti-amnesia/20250727-172600-cursor-rbenv-ruby-version-mystery.md +64 -0
  36. data/doc/anti-amnesia/20250727-172600-unified-minitest-framework.md +70 -0
  37. data/doc/anti-amnesia/20250727-172900-ai-cognitive-assessment-capabilities.md +40 -0
  38. data/doc/anti-amnesia/20250727-173000-widget-testing-achievement.md +110 -0
  39. data/doc/anti-amnesia/20250727-180000-post-id-num-refactoring.md +73 -0
  40. data/doc/anti-amnesia/20250728-124243-aaa-syntax-clarification.md +46 -0
  41. data/doc/anti-amnesia/20250728-124421-conversation-summary-concise.md +124 -0
  42. data/doc/anti-amnesia/20250729-190000-scriptorium-tui-testing-complete.md +46 -0
  43. data/doc/anti-amnesia/20250729-200000-scriptorium-tui-testing-edit-file-workflow.md +97 -0
  44. data/doc/anti-amnesia/20250729-210000-reddit-autopost-integration-complete.md +158 -0
  45. data/doc/anti-amnesia/20250729-211500-dependency-management-system.md +211 -0
  46. data/doc/anti-amnesia/20250729-213000-python-virtual-environment-setup.md +141 -0
  47. data/doc/anti-amnesia/20250729-214500-theme-management-commands.md +211 -0
  48. data/doc/anti-amnesia/20250729-215000-version-update-to-0.6.0.md +134 -0
  49. data/doc/anti-amnesia/20250729-220000-user-guide-complete.md +41 -0
  50. data/doc/anti-amnesia/20250804-190500-cognitive-loop-bug.md +45 -0
  51. data/doc/anti-amnesia/20250804-190700-anti-amnesia-timestamping-fix.md +30 -0
  52. data/doc/anti-amnesia/20250804-213700-publishing-test-fix.md +49 -0
  53. data/doc/anti-amnesia/20250804-214400-additional-test-fixes.md +46 -0
  54. data/doc/anti-amnesia/20250804-220000-asset-function-logic-clarification.md +41 -0
  55. data/doc/anti-amnesia/20250806-202032-asset-function-logic-clarification.md +41 -0
  56. data/doc/anti-amnesia/20250807-213025.md +116 -0
  57. data/doc/anti-amnesia/20250813-082428-syntax-highlighting-and-navigation-improvements.md +256 -0
  58. data/doc/banner_svg_config.md +114 -0
  59. data/doc/contrib.lt3 +8 -0
  60. data/doc/dependencies.md +281 -0
  61. data/doc/hacker.lt3 +5 -0
  62. data/doc/reddit_credentials_template.json +8 -0
  63. data/doc/reddit_integration.md +207 -0
  64. data/doc/user.lt3 +38 -0
  65. data/doc/user_guide_section_1.md +137 -0
  66. data/doc/user_guide_section_10.md +515 -0
  67. data/doc/user_guide_section_11.md +708 -0
  68. data/doc/user_guide_section_2.md +233 -0
  69. data/doc/user_guide_section_3.md +5 -0
  70. data/doc/user_guide_section_4.md +221 -0
  71. data/doc/user_guide_section_5.md +243 -0
  72. data/doc/user_guide_section_6.md +147 -0
  73. data/doc/user_guide_section_7.md +311 -0
  74. data/doc/user_guide_section_8.md +224 -0
  75. data/doc/user_guide_section_9.md +375 -0
  76. data/doc/userdoc-toc.txt +88 -0
  77. data/lib/rouge/lexers/livetext.rb +74 -0
  78. data/lib/scriptorium/api.rb +640 -0
  79. data/lib/scriptorium/banner_svg.rb +742 -0
  80. data/lib/scriptorium/contract.rb +33 -0
  81. data/lib/scriptorium/exceptions.rb +170 -1
  82. data/lib/scriptorium/helpers.rb +475 -0
  83. data/lib/scriptorium/post.rb +195 -0
  84. data/lib/scriptorium/reddit.rb +83 -0
  85. data/lib/scriptorium/repo.rb +624 -0
  86. data/lib/scriptorium/standard_files.rb +515 -0
  87. data/lib/scriptorium/syntax_highlighter.rb +234 -0
  88. data/lib/scriptorium/theme.rb +179 -0
  89. data/lib/scriptorium/version.rb +2 -2
  90. data/lib/scriptorium/view.rb +976 -0
  91. data/lib/scriptorium/widgets/featured_posts.rb +149 -0
  92. data/lib/scriptorium/widgets/links.rb +112 -0
  93. data/lib/scriptorium/widgets/pages.rb +133 -0
  94. data/lib/scriptorium/widgets/widget.rb +133 -0
  95. data/lib/scriptorium.rb +21 -40
  96. data/lib/skeleton.rb +8 -2
  97. data/scriptorium.gemspec +15 -4
  98. data/test/README.md +69 -0
  99. data/test/all +43 -0
  100. data/test/api_demo.rb +99 -0
  101. data/test/assets/imagenotfound.jpg +0 -0
  102. data/test/assets/images/.DS_Store +0 -0
  103. data/test/assets/images/README.md +27 -0
  104. data/test/assets/images/odd_aspect.png +0 -0
  105. data/test/assets/images/perfect.png +0 -0
  106. data/test/assets/images/small.png +0 -0
  107. data/test/assets/images/tall.png +0 -0
  108. data/test/assets/images/very_tall.png +0 -0
  109. data/test/assets/images/very_wide.png +0 -0
  110. data/test/assets/images/wide.png +0 -0
  111. data/test/assets/testbanner.jpg +0 -0
  112. data/test/banner_svg/simple_helpers.rb +13 -0
  113. data/test/banner_svg/unit.rb +768 -0
  114. data/test/ed_test.rb +204 -0
  115. data/test/integration/cursor_banner_combinations.rb +193 -0
  116. data/test/integration/cursor_banner_features.rb +374 -0
  117. data/test/integration/integration_test.rb +326 -0
  118. data/test/livetext_plugin_test.rb +229 -0
  119. data/test/manual/asset_mgmt.rb +67 -0
  120. data/test/manual/banner-tests/config.txt +3 -0
  121. data/test/manual/banner-tests/index.html +45 -0
  122. data/test/manual/banner-tests/test01.html +58 -0
  123. data/test/manual/banner-tests/test02.html +58 -0
  124. data/test/manual/banner-tests/test03.html +58 -0
  125. data/test/manual/banner-tests/test04.html +65 -0
  126. data/test/manual/banner-tests/test05.html +65 -0
  127. data/test/manual/banner-tests/test06.html +65 -0
  128. data/test/manual/banner-tests/test07.html +65 -0
  129. data/test/manual/banner-tests/test08.html +59 -0
  130. data/test/manual/banner-tests/test09.html +59 -0
  131. data/test/manual/banner-tests/test10.html +59 -0
  132. data/test/manual/banner-tests/test11.html +59 -0
  133. data/test/manual/banner-tests/test12.html +59 -0
  134. data/test/manual/banner-tests/test13.html +59 -0
  135. data/test/manual/banner-tests/test14.html +59 -0
  136. data/test/manual/banner-tests/test15.html +58 -0
  137. data/test/manual/banner-tests/test16.html +58 -0
  138. data/test/manual/banner-tests/test17.html +58 -0
  139. data/test/manual/banner-tests/test18.html +68 -0
  140. data/test/manual/banner-tests/test19.html +68 -0
  141. data/test/manual/banner-tests/test20.html +68 -0
  142. data/test/manual/banner-tests/test21.html +68 -0
  143. data/test/manual/banner-tests/test22.html +68 -0
  144. data/test/manual/banner-tests/test23.html +68 -0
  145. data/test/manual/banner-tests/test24.html +68 -0
  146. data/test/manual/banner-tests/test25.html +67 -0
  147. data/test/manual/banner_environment.rb +192 -0
  148. data/test/manual/deploy_symlink_demo.rb +142 -0
  149. data/test/manual/environment.rb +67 -0
  150. data/test/manual/make_banner.rb +153 -0
  151. data/test/manual/sample_banner_config.txt +12 -0
  152. data/test/manual/symlink_demo.rb +117 -0
  153. data/test/manual/test1.rb +47 -0
  154. data/test/manual/test2.rb +12 -0
  155. data/test/manual/test3.rb +38 -0
  156. data/test/manual/test4.rb +40 -0
  157. data/test/manual/test5.rb +24 -0
  158. data/test/manual/test6.rb +73 -0
  159. data/test/manual/test_banner_combinations.rb +120 -0
  160. data/test/manual/test_banner_features.rb +306 -0
  161. data/test/manual/test_banner_from_file.rb +150 -0
  162. data/test/manual/test_banner_in_header.rb +35 -0
  163. data/test/manual/test_code_highlighting.rb +68 -0
  164. data/test/manual/test_complex_header.rb +74 -0
  165. data/test/manual/test_empty_header.rb +32 -0
  166. data/test/manual/test_radial_custom.rb +58 -0
  167. data/test/manual/test_radial_large_radius.rb +52 -0
  168. data/test/manual/test_svg_debug.rb +47 -0
  169. data/test/manual/test_syntax_highlighting.rb +147 -0
  170. data/test/pages-demo/config/currentview.txt +1 -0
  171. data/test/pages-demo/views/demo/config/bootstrap_css.txt +5 -0
  172. data/test/pages-demo/views/demo/config/bootstrap_js.txt +4 -0
  173. data/test/pages-demo/views/demo/config/common.js +57 -0
  174. data/test/pages-demo/views/demo/config/footer.txt +1 -0
  175. data/test/pages-demo/views/demo/config/global-head.txt +8 -0
  176. data/test/pages-demo/views/demo/config/header.txt +1 -0
  177. data/test/pages-demo/views/demo/config/layout.txt +1 -0
  178. data/test/pages-demo/views/demo/config/left.txt +1 -0
  179. data/test/pages-demo/views/demo/config/main.txt +1 -0
  180. data/test/pages-demo/views/demo/config/right.txt +1 -0
  181. data/test/pages-demo/views/demo/config.txt +3 -0
  182. data/test/pages-demo/views/demo/output/panes/footer.html +1 -0
  183. data/test/pages-demo/views/demo/output/panes/header.html +1 -0
  184. data/test/pages-demo/views/demo/output/panes/left.html +1 -0
  185. data/test/pages-demo/views/demo/output/panes/main.html +1 -0
  186. data/test/pages-demo/views/demo/output/panes/right.html +1 -0
  187. data/test/rubytext/rubytext_comprehensive_test.rb +307 -0
  188. data/test/rubytext/rubytext_demo_test.rb +42 -0
  189. data/test/rubytext/rubytext_testing_guide.md +277 -0
  190. data/test/run_automated_tests.rb +45 -0
  191. data/test/scriptorium-TEST-1754622690-146/config/bootstrap_css.txt +5 -0
  192. data/test/scriptorium-TEST-1754622690-146/config/bootstrap_js.txt +4 -0
  193. data/test/scriptorium-TEST-1754622690-146/config/common.js +57 -0
  194. data/test/scriptorium-TEST-1754622690-146/config/currentview.txt +1 -0
  195. data/test/scriptorium-TEST-1754622690-146/config/global-head.txt +9 -0
  196. data/test/scriptorium-TEST-1754622690-146/config/last_post_num.txt +1 -0
  197. data/test/scriptorium-TEST-1754622690-146/config/os_helpers.rb +4 -0
  198. data/test/scriptorium-TEST-1754622690-146/config/widgets.txt +3 -0
  199. data/test/scriptorium-TEST-1754622690-146/posts/0001/meta.txt +8 -0
  200. data/test/scriptorium-TEST-1754622690-146/posts/0001/source.lt3 +6 -0
  201. data/test/scriptorium-TEST-1754622690-146/themes/standard/README.txt +1 -0
  202. data/test/scriptorium-TEST-1754622690-146/themes/standard/config.txt +1 -0
  203. data/test/scriptorium-TEST-1754622690-146/themes/standard/initial/post.lt3 +12 -0
  204. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/config/footer.txt +2 -0
  205. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/config/header.txt +4 -0
  206. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/config/left.txt +3 -0
  207. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/config/main.txt +5 -0
  208. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/config/right.txt +3 -0
  209. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/gen/text.css +1 -0
  210. data/test/scriptorium-TEST-1754622690-146/themes/standard/layout/layout.txt +5 -0
  211. data/test/scriptorium-TEST-1754622690-146/themes/standard/templates/index.lt3 +1 -0
  212. data/test/scriptorium-TEST-1754622690-146/themes/standard/templates/index_entry.lt3 +14 -0
  213. data/test/scriptorium-TEST-1754622690-146/themes/standard/templates/post.lt3 +13 -0
  214. data/test/scriptorium-TEST-1754622690-146/themes/standard/templates/widget.lt3 +1 -0
  215. data/test/scriptorium-TEST-1754622690-146/views/sample/config/bootstrap_css.txt +5 -0
  216. data/test/scriptorium-TEST-1754622690-146/views/sample/config/bootstrap_js.txt +4 -0
  217. data/test/scriptorium-TEST-1754622690-146/views/sample/config/common.js +57 -0
  218. data/test/scriptorium-TEST-1754622690-146/views/sample/config/deploy.txt +5 -0
  219. data/test/scriptorium-TEST-1754622690-146/views/sample/config/footer.txt +2 -0
  220. data/test/scriptorium-TEST-1754622690-146/views/sample/config/global-head.txt +9 -0
  221. data/test/scriptorium-TEST-1754622690-146/views/sample/config/header.txt +4 -0
  222. data/test/scriptorium-TEST-1754622690-146/views/sample/config/layout.txt +5 -0
  223. data/test/scriptorium-TEST-1754622690-146/views/sample/config/left.txt +3 -0
  224. data/test/scriptorium-TEST-1754622690-146/views/sample/config/main.txt +5 -0
  225. data/test/scriptorium-TEST-1754622690-146/views/sample/config/reddit.txt +10 -0
  226. data/test/scriptorium-TEST-1754622690-146/views/sample/config/right.txt +3 -0
  227. data/test/scriptorium-TEST-1754622690-146/views/sample/config/social.txt +7 -0
  228. data/test/scriptorium-TEST-1754622690-146/views/sample/config/status.txt +7 -0
  229. data/test/scriptorium-TEST-1754622690-146/views/sample/config.txt +3 -0
  230. data/test/scriptorium-TEST-1754622690-146/views/sample/layout/footer.html +3 -0
  231. data/test/scriptorium-TEST-1754622690-146/views/sample/layout/header.html +3 -0
  232. data/test/scriptorium-TEST-1754622690-146/views/sample/layout/left.html +3 -0
  233. data/test/scriptorium-TEST-1754622690-146/views/sample/layout/main.html +3 -0
  234. data/test/scriptorium-TEST-1754622690-146/views/sample/layout/right.html +3 -0
  235. data/test/scriptorium-TEST-1754622690-146/views/sample/output/panes/footer.html +1 -0
  236. data/test/scriptorium-TEST-1754622690-146/views/sample/output/panes/header.html +1 -0
  237. data/test/scriptorium-TEST-1754622690-146/views/sample/output/panes/left.html +1 -0
  238. data/test/scriptorium-TEST-1754622690-146/views/sample/output/panes/main.html +1 -0
  239. data/test/scriptorium-TEST-1754622690-146/views/sample/output/panes/right.html +1 -0
  240. data/test/staging/.DS_Store +0 -0
  241. data/test/syntax_highlighting_test.lt3 +124 -0
  242. data/test/test_helpers.rb +230 -0
  243. data/test/tui_editor_integration_test.rb +296 -0
  244. data/test/tui_integration_test.rb +637 -0
  245. data/test/unit/api.rb +1056 -0
  246. data/test/unit/asset_management.rb +245 -0
  247. data/test/unit/clipboard_test.rb +60 -0
  248. data/test/unit/contract_test.rb +91 -0
  249. data/test/unit/core.rb +857 -0
  250. data/test/unit/deploy_test.rb +187 -0
  251. data/test/unit/gem_asset_management.rb +189 -0
  252. data/test/unit/livetext_basic.rb +69 -0
  253. data/test/unit/livetext_compatibility.rb +89 -0
  254. data/test/unit/post.rb +244 -0
  255. data/test/unit/read_commented_file_test.rb +276 -0
  256. data/test/unit/reddit_test.rb +235 -0
  257. data/test/unit/repo.rb +548 -0
  258. data/test/unit/social_test.rb +369 -0
  259. data/test/unit/symlink_test.rb +213 -0
  260. data/test/unit/view.rb +431 -0
  261. data/test/unit/widgets.rb +669 -0
  262. data/test/wizard_test.rb +123 -0
  263. data/ui/README.md +67 -0
  264. data/ui/common/lib/ui_common.rb +8 -0
  265. data/ui/rubytext/README.md +191 -0
  266. data/ui/rubytext/bin/scriptorium-rubytext +402 -0
  267. data/ui/rubytext/lib/rubytext_ui.rb +300 -0
  268. data/ui/tui/bin/scriptorium +1420 -0
  269. data/ui/tui/test/tui_test.rb +23 -0
  270. data/ui/web/app/app.rb +1378 -0
  271. data/ui/web/app/error_helpers.rb +150 -0
  272. data/ui/web/app/views/advanced_config.erb +190 -0
  273. data/ui/web/app/views/asset_management.erb +589 -0
  274. data/ui/web/app/views/banner_config.erb +200 -0
  275. data/ui/web/app/views/configure_view.erb +401 -0
  276. data/ui/web/app/views/dashboard.erb +162 -0
  277. data/ui/web/app/views/deploy_config.erb +146 -0
  278. data/ui/web/app/views/edit_pages.erb +195 -0
  279. data/ui/web/app/views/edit_post.erb +54 -0
  280. data/ui/web/app/views/error_page.erb +29 -0
  281. data/ui/web/app/views/header_config.erb +155 -0
  282. data/ui/web/app/views/layout_config.erb +147 -0
  283. data/ui/web/app/views/navbar_config.erb +411 -0
  284. data/ui/web/app/views/view_dashboard.erb +138 -0
  285. data/ui/web/bin/scriptorium-web +153 -0
  286. data/ui/web/test/web_basic_test.rb +38 -0
  287. data/ui/web/test_navbar.txt +7 -0
  288. data/ui/web/tmp/web_server.log +5 -0
  289. data/ui/web/tmp/web_server.pid +1 -0
  290. metadata +359 -7
  291. data/lib/scriptorium/engine.rb +0 -22
  292. data/test/engine/unit.rb +0 -44
@@ -0,0 +1,58 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Right Position</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <rect x='0' y='0' width='100%' height='100%' fill='#fff' />
36
+ <text x='95%'
37
+ y='52%'
38
+ text-anchor='end'
39
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
40
+ fill='#374151'>Right Position</text>
41
+
42
+ <text x='95%'
43
+ y='82%'
44
+ text-anchor='end'
45
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
46
+ fill='#374151'>Position test</text>
47
+
48
+ </svg>
49
+
50
+ </div>
51
+ <div class="content">
52
+ <div class="description">Right Positioned Text</div>
53
+ <div class="config">text.align right</div>
54
+
55
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test16.html">Previous</a> <a href="test18.html">Next</a></div>
56
+ </div>
57
+ </body>
58
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Perfect Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="perfect.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Perfect Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (8:1 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Perfect match: 8:1 aspect ratio image fits banner exactly - no cropping or scaling needed</div>
60
+ <div class="config">back.image ../../assets/images/perfect.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='perfect.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test17.html">Previous</a> <a href="test19.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Wide Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="wide.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Wide Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (16:1 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Wide image (16:1) cropped to fit 8:1 banner - left/right edges removed, center preserved</div>
60
+ <div class="config">back.image ../../assets/images/wide.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='wide.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test18.html">Previous</a> <a href="test20.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Tall Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="tall.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Tall Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (1:1 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Square image (1:1) cropped to fit 8:1 banner - top/bottom removed, center strip visible</div>
60
+ <div class="config">back.image ../../assets/images/tall.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='tall.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test19.html">Previous</a> <a href="test21.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Very Tall Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="very_tall.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Very Tall Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (1:4 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Very tall image (1:4) heavily cropped - only narrow center strip visible, most content lost</div>
60
+ <div class="config">back.image ../../assets/images/very_tall.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='very_tall.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test20.html">Previous</a> <a href="test22.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Very Wide Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="very_wide.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Very Wide Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (16:1 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Very wide image (16:1) heavily cropped - only narrow center strip visible, sides removed</div>
60
+ <div class="config">back.image ../../assets/images/very_wide.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='very_wide.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test21.html">Previous</a> <a href="test23.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Small Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="small.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Small Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (low res, 8:1 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Small low-res image scaled up to fill banner - may appear pixelated but maintains aspect</div>
60
+ <div class="config">back.image ../../assets/images/small.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='small.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test22.html">Previous</a> <a href="test24.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,68 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Odd Aspect Image Background</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <pattern id="bg-pattern" x="0" y="0" width="100%" height="100%" patternUnits="objectBoundingBox">
37
+ <image href="odd_aspect.png" x="0" y="0" width="100%" height="100%"
38
+ preserveAspectRatio="xMidYMid slice" />
39
+ </pattern>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#bg-pattern)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#374151'>Odd Aspect Image Background</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#374151'>Image test (~4:1 aspect)</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Non-standard aspect ratio (~4:1) cropped to fit 8:1 banner - moderate cropping applied</div>
60
+ <div class="config">back.image ../../assets/images/odd_aspect.png</div>
61
+ <div class='original-image'>
62
+ <h3>Original Image (for comparison):</h3>
63
+ <img src='odd_aspect.png' alt='Original image'>
64
+ </div>
65
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test23.html">Previous</a> <a href="test25.html">Next</a></div>
66
+ </div>
67
+ </body>
68
+ </html>
@@ -0,0 +1,67 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>Another gradient test</title>
5
+ <style>
6
+ body { font-family: Arial, sans-serif; margin: 0; padding: 0; background: #f5f5f5; }
7
+ .banner { width: 100%; margin: 0; padding: 0; border: 3px solid #007cba; border-radius: 8px; }
8
+ .content { padding: 20px; padding-bottom: 80px; }
9
+ .description { margin: 10px 0; font-weight: bold; }
10
+ .config { background: #f0f0f0; padding: 10px; margin: 10px 0; font-family: monospace; font-size: 12px; }
11
+ .navigation {
12
+ position: fixed;
13
+ bottom: 0;
14
+ left: 0;
15
+ right: 0;
16
+ background: #e0e0e0;
17
+ padding: 15px;
18
+ text-align: center;
19
+ border-top: 2px solid #007cba;
20
+ z-index: 1000;
21
+ }
22
+ .navigation a { margin: 0 10px; padding: 8px 15px; background: #007cba; color: white; text-decoration: none; border-radius: 3px; }
23
+ .navigation a:hover { background: #005a87; }
24
+ .original-image { margin: 20px 0; padding: 20px; background: white; border-radius: 8px; box-shadow: 0 2px 4px rgba(0,0,0,0.1); }
25
+ .original-image h3 { margin: 0 0 10px 0; color: #333; }
26
+ .original-image img { max-width: 100%; height: auto; border: 1px solid #ddd; }
27
+ </style>
28
+ </head>
29
+ <body>
30
+ <div class="banner">
31
+ <svg xmlns='http://www.w3.org/2000/svg'
32
+ width='100%' height='100'
33
+ viewBox='0 0 800 100'
34
+ preserveAspectRatio='xMidYMid meet'>
35
+ <defs>
36
+ <linearGradient id="grad1" x1="0%" y1="0%" x2="100%" y2="0%">
37
+ <stop offset="0%" style="stop-color:#0000ff;stop-opacity:1" />
38
+ <stop offset="100%" style="stop-color:#000033;stop-opacity:1" />
39
+ </linearGradient>
40
+ </defs>
41
+ <rect x='0' y='0' width='100%' height='100%' fill='url(#grad1)' />
42
+
43
+ <text x='5%'
44
+ y='52%'
45
+ text-anchor='start'
46
+ style='font-family: Verdana; font-size: 48px; font-weight: normal; font-style: normal'
47
+ fill='#fff'>Another gradient test</text>
48
+
49
+ <text x='5%'
50
+ y='82%'
51
+ text-anchor='start'
52
+ style='font-family: Verdana; font-size: 24px; font-weight: normal; font-style: normal'
53
+ fill='#fff'>Just one more, I swear</text>
54
+
55
+ </svg>
56
+
57
+ </div>
58
+ <div class="content">
59
+ <div class="description">Linear Gradient (Left to Right)</div>
60
+ <div class="config">back.linear #0000ff #000033 lr
61
+ title.color #fff
62
+ subtitle.color #fff</div>
63
+
64
+ <div class="navigation"><a href="index.html">Back to Index</a> <a href="test24.html">Previous</a></div>
65
+ </div>
66
+ </body>
67
+ </html>