cyberweb 0.4.174 → 0.5.225

Sign up to get free protection for your applications and to get access to all the features.

Potentially problematic release.


This version of cyberweb might be problematic. Click here for more details.

Files changed (625) hide show
  1. checksums.yaml +4 -4
  2. data/README.md +1782 -405
  3. data/bin/cyberweb_sanitize +10 -0
  4. data/bin/download_webpage +7 -0
  5. data/bin/html_to_cyberweb_converter +7 -0
  6. data/cyberweb.gemspec +25 -25
  7. data/doc/README.gen +1745 -383
  8. data/doc/USAGE.md +16 -16
  9. data/doc/{AUTHORS.md → authors.md} +0 -0
  10. data/doc/configuration/configuration.md +3 -1
  11. data/doc/deprecations.md +13 -7
  12. data/doc/{DOCUMENTATION_FOR_CYBERSPRAWL.md → documentation_for_cybersprawl.md} +7 -4
  13. data/doc/future_design_goals.md +33 -0
  14. data/doc/html_characters.md +7 -7
  15. data/doc/{JQUERY.md → jquery/jquery.md} +20 -12
  16. data/doc/{MOUSE.md → mouse.md} +1 -9
  17. data/doc/{RENDER_WEB_BASE.md → render_web_base.md} +11 -4
  18. data/doc/todo/todo_for_the_cyberweb_project.md +791 -0
  19. data/examples/advanced/animated_css_example/animated_css_example.html +47 -0
  20. data/examples/advanced/animated_submarine/animated_submarine.html +511 -0
  21. data/examples/advanced/animated_windmill/animated_windmill.html +468 -0
  22. data/examples/advanced/delayed_update_of_the_body_via_javascript.cgi +8 -5
  23. data/examples/advanced/draw_circle/draw_circle.cgi +36 -0
  24. data/examples/advanced/drop_shadow_examples.cgi +37 -0
  25. data/examples/advanced/games/snake/food.png +0 -0
  26. data/examples/advanced/games/snake/ground.png +0 -0
  27. data/examples/advanced/games/snake/snake.cgi +28 -0
  28. data/examples/advanced/games/tetris/tetris.cgi +7 -0
  29. data/examples/advanced/games/tetris/tetris.rb +17 -0
  30. data/examples/advanced/games/tetris/tetris.sinatra +58 -0
  31. data/examples/advanced/games/tic-tac-toe/tic-tac-toe.cgi +123 -0
  32. data/examples/advanced/get_some_coffee/get_some_coffee.html +293 -0
  33. data/examples/advanced/glow_on_hover_example/glow_on_hover_example.cgi +27 -0
  34. data/examples/advanced/hybrid_experiment.cgi +34 -12
  35. data/examples/advanced/images/global_css_rules_for_the_images.cgi +32 -0
  36. data/examples/advanced/larger_image_on_mouse_over_example.cgi +2 -2
  37. data/examples/advanced/no_right_click.cgi +4 -3
  38. data/examples/advanced/{objectified_html_tags.cgi → objectified_html_tags/objectified_html_tags.cgi} +12 -3
  39. data/examples/advanced/objectified_html_tags/testing_objectified_html_tags_with_the_webobject.cgi +28 -0
  40. data/examples/advanced/random_glow_effects.cgi +34 -0
  41. data/examples/advanced/select_everything_example/select_everything_example.cgi +25 -0
  42. data/examples/advanced/simple_calculator.cgi +13 -21
  43. data/examples/advanced/simple_form_example.cgi +11 -11
  44. data/examples/advanced/traffic_light/traffic_light.html +163 -0
  45. data/examples/advanced/weather_animation/weather_animation.html +560 -0
  46. data/examples/css/animated_3D_cube_example/animated_3D_cube_example.html +265 -0
  47. data/examples/css/animated_bird_example/animated_bird_example.html +207 -0
  48. data/examples/css/animated_desk_example/animated_desk_example.html +120 -0
  49. data/examples/css/animated_dog_example/animated_dog_example.html +432 -0
  50. data/examples/css/animated_submit_button.html +190 -0
  51. data/examples/css/animated_text_colour_change/animated_text_colour_change.html +41 -0
  52. data/examples/css/blue_border.html +3 -1
  53. data/examples/css/border_image_example/border_image_example.html +40 -0
  54. data/examples/css/box_shadow/box_shadow_example.html +18 -0
  55. data/examples/css/christmas_snow_globe_animation.html +596 -0
  56. data/examples/css/css_border_spacing_example.html +5 -5
  57. data/examples/css/css_bubbles.html +3 -1
  58. data/examples/css/css_checkboxes_example/css_checkboxes_example.html +110 -0
  59. data/examples/css/css_drag_and_drop.html +1 -5
  60. data/examples/css/css_grid_feline_style/css_grid_feline_style.html +161 -0
  61. data/examples/css/css_neon_glow_effects.html +1 -1
  62. data/examples/css/css_rotate_these_words.html +83 -0
  63. data/examples/css/css_text_decoration_example.html +7 -7
  64. data/examples/css/css_thermometer/css_thermometer.html +91 -0
  65. data/examples/css/{css_tooltip.html → css_tooltip/css_tooltip.html} +8 -6
  66. data/examples/css/css_typewriter_example/css_typewriter_example.html +226 -0
  67. data/examples/css/cyberweb_animated_logo/cyberweb_animated_logo.html +179 -0
  68. data/examples/css/daily_coffee/daily_coffee.html +1110 -0
  69. data/examples/css/different_colour_on_selected_text/different_colour_on_selected_text.html +31 -0
  70. data/examples/css/differentially_glowing_text_example/differentially_glowing_text_example.html +82 -0
  71. data/examples/css/fade_in_and_fade_out_effect.html +2 -2
  72. data/examples/css/flying_birds_example/flying_birds_example.html +171 -0
  73. data/examples/css/folding_cards_example/folding_cards_example.html +624 -0
  74. data/examples/css/font_size_examples.html +7 -5
  75. data/examples/css/glowing_on_hover_animation/glowing_on_hover_animation.html +90 -0
  76. data/examples/css/grow_example.html +31 -0
  77. data/examples/css/happy_toaster_example/happy_toaster_example.html +830 -0
  78. data/examples/css/landing_on_mars_animation/landing_on_mars_animation.html +374 -0
  79. data/examples/css/letter_spacing_example.cgi +18 -14
  80. data/examples/css/lighthouse_example/lighthouse_example.html +1161 -0
  81. data/examples/css/{meter_example.html → meter_example/meter_example.html} +0 -0
  82. data/examples/css/motorcycle_on_the_go/motorcycle_on_the_go.html +227 -0
  83. data/examples/css/on_hover_glow_effect/on_hover_glow_effect.html +50 -0
  84. data/examples/css/on_mouse_button_pressed.html +6 -4
  85. data/examples/css/our_solar_system/our_solar_system.html +441 -0
  86. data/examples/css/outline/outline_versus_border_example.html +57 -0
  87. data/examples/css/polaroid_card_effect_example/polaroid_card_effect_example.html +130 -0
  88. data/examples/css/responsive_image_gallery/responsive_image_gallery.html +97 -0
  89. data/examples/css/rotating_DNA/rotating_DNA.html +626 -0
  90. data/examples/css/rotating_sphere_example/rotating_sphere_example.html +112 -0
  91. data/examples/css/scale_example.html +4 -5
  92. data/examples/css/shadow_example_in_CSS/shadow_example_in_CSS.cgi +62 -0
  93. data/examples/css/shaking_shapes_example.html +133 -0
  94. data/examples/css/simple_stars_example/simple_stars_example.html +27 -0
  95. data/examples/css/slide_checkbox_example/slide_checkbox_example.html +564 -0
  96. data/examples/css/speak_bubble_quote_example/speak_bubble_quote_example.html +109 -0
  97. data/examples/css/speedy_truck_example/speedy_truck_example.html +168 -0
  98. data/examples/css/{sticky_div_example.html → sticky_div_example/sticky_div_example.html} +0 -0
  99. data/examples/css/stitched_div.html +9 -0
  100. data/examples/css/sun_and_clouds_animation/sun_and_clouds_animation.html +292 -0
  101. data/examples/css/talking_candles_example/talking_candles_example.html +550 -0
  102. data/examples/css/text_decoration_underline_example/text_decoration_underline_example.html +62 -0
  103. data/examples/css/this_is_a_cat/this_is_a_cat.html +219 -0
  104. data/examples/css/three_dots_indicating_page_loading.html +65 -0
  105. data/examples/css/user_select_example/user_select_example.html +24 -0
  106. data/examples/css/walking_cat/walking_cat.html +128 -0
  107. data/examples/css/water_wave_text_animation_effect/water_wave_text_animation_effect.html +86 -0
  108. data/examples/csv/README.md +2 -1
  109. data/examples/flip_card_example/flip_card_example.html +10 -3
  110. data/examples/games/README.md +3 -0
  111. data/examples/games/snake/images/food.png +0 -0
  112. data/examples/games/snake/images/ground.png +0 -0
  113. data/examples/games/snake/snake.html +16 -0
  114. data/examples/games/snake/snake.js +117 -0
  115. data/examples/games/tetris/smaller_tetris_game.html +518 -0
  116. data/examples/games/tetris/tetris.html +461 -0
  117. data/examples/games/tic-tac-toe/index.js +125 -0
  118. data/examples/games/tic-tac-toe/style.css +79 -0
  119. data/examples/games/tic-tac-toe/tic-tac-toe.html +39 -0
  120. data/examples/html/MathML/001_show_a_simple_quadratic_equation.html +22 -0
  121. data/examples/html/MathML/002_simple_equation.html +7 -0
  122. data/examples/html/MathML/003_function_of_example.html +17 -0
  123. data/examples/html/MathML/README.md +2 -0
  124. data/examples/html/abbr_example.html +2 -5
  125. data/examples/html/accordion/README.md +1 -0
  126. data/examples/html/accordion/accordion.html +56 -0
  127. data/examples/html/base64_image_example.html +8 -5
  128. data/examples/html/buttons_example.html +133 -0
  129. data/examples/html/canvas_drawing_example.html +54 -0
  130. data/examples/html/colour_wheel.html +441 -442
  131. data/examples/html/column_width_example.html +2 -2
  132. data/examples/html/custom_cursor.html +8 -5
  133. data/examples/html/cyberweb_logo/README.md +2 -0
  134. data/examples/html/cyberweb_logo/cyberweb_logo.html +11 -0
  135. data/examples/html/draggable_paragraph.html +1 -2
  136. data/examples/html/email_popup_example/email_popup_example.html +175 -0
  137. data/examples/html/fieldset_example.html +3 -1
  138. data/examples/html/font_examples/README.md +1 -0
  139. data/examples/html/font_examples/chancery_text.html +19 -0
  140. data/examples/html/font_examples/fantasy_text.html +19 -0
  141. data/examples/html/font_examples/georgia_text.html +19 -0
  142. data/examples/html/font_size_example/font_size_example.html +85 -0
  143. data/examples/html/glyph_example.html +0 -1
  144. data/examples/html/grayscale_filter_example/grayscale_filter_example.html +15 -0
  145. data/examples/html/html_links_example.html +61 -0
  146. data/examples/html/html_slider/html_slider.html +39 -0
  147. data/examples/html/input_autofocus_example.html +11 -7
  148. data/examples/html/input_placeholder_example.html +15 -0
  149. data/examples/html/larger_image_on_mouse_over_example.html +1 -1
  150. data/examples/html/ordered_and_unordered_bulletsin.html +4 -2
  151. data/examples/html/play_video_example.html +3 -2
  152. data/examples/html/remote_image_example.html +8 -2
  153. data/examples/html/select_everything_on_mouse_click_event.html +38 -0
  154. data/examples/html/selected_text_appears_in_another_colour_example.html +34 -0
  155. data/examples/html/send_email_hyperlink/send_email_hyperlink.html +8 -0
  156. data/examples/html/simple_unordered_list.html +3 -0
  157. data/examples/html/spinner_example/spinner.html +79 -0
  158. data/examples/html/table_with_header_example.html +26 -13
  159. data/examples/html/test_mkv_codec/test_mkv_codec.html +11 -0
  160. data/examples/html/two_columns_flex_example.html +4 -1
  161. data/examples/{javascript → javascript_and_jquery}/README.md +0 -0
  162. data/examples/{javascript → javascript_and_jquery}/arrays/arrays_example_in_javascript.html +0 -0
  163. data/examples/javascript_and_jquery/autocomplete_on_an_input_field/autocomplete_on_an_input_field.html +295 -0
  164. data/examples/javascript_and_jquery/change_the_background_colour_dynamically/change_the_background_colour_dynamically.html +41 -0
  165. data/examples/{javascript → javascript_and_jquery}/delay_example/delay_example.html +0 -0
  166. data/examples/{javascript → javascript_and_jquery}/drag_support/drag_support.html +0 -0
  167. data/examples/javascript_and_jquery/jquery_bubbling_header/bubbling_header.html +109 -0
  168. data/examples/{javascript → javascript_and_jquery}/jquery_drag_and_drop/drag_and_drop_image_example.html +0 -0
  169. data/examples/javascript_and_jquery/jquery_showcase/README.md +6 -0
  170. data/examples/javascript_and_jquery/jquery_showcase/jquery_001.cgi +23 -0
  171. data/examples/javascript_and_jquery/jquery_showcase/jquery_002.cgi +34 -0
  172. data/examples/javascript_and_jquery/jquery_showcase/jquery_003.cgi +24 -0
  173. data/examples/javascript_and_jquery/jquery_showcase/jquery_004.cgi +34 -0
  174. data/examples/javascript_and_jquery/on_change_event/on_change_event.html +29 -0
  175. data/examples/javascript_and_jquery/on_click_colour_change/on_click_colour_change.html +31 -0
  176. data/examples/javascript_and_jquery/on_click_display_random_number/on_click_display_random_number.html +43 -0
  177. data/examples/{javascript → javascript_and_jquery}/on_click_event_hello_world/on_click_event_hello_world.html +0 -0
  178. data/examples/javascript_and_jquery/on_mouse_wheel_event/on_mouse_wheel_event.html +37 -0
  179. data/examples/javascript_and_jquery/read_the_content_of_a_local_file/read_the_content_of_a_local_file.html +35 -0
  180. data/examples/{javascript → javascript_and_jquery}/rgb_to_hex/rgb_to_hex.html +0 -0
  181. data/examples/{javascript → javascript_and_jquery}/screen_resolution/screen_resolution.html +2 -1
  182. data/examples/{javascript → javascript_and_jquery}/select_everything/select_everything.html +1 -1
  183. data/examples/javascript_and_jquery/vue/README.md +1 -0
  184. data/examples/javascript_and_jquery/vue/showcasing_vue.html +80 -0
  185. data/examples/{javascript → javascript_and_jquery}/write_into_a_file/write_into_a_file.html +0 -0
  186. data/examples/rack/example_with_html_template.rb +5 -4
  187. data/examples/rack/example_with_rack_and_cyberweb_showing_how_to_use_images.rb +3 -2
  188. data/examples/rack/hello_world_example_with_rack.rb +3 -2
  189. data/examples/rack/lobster.rb +7 -5
  190. data/examples/rack/rack_env.rb +3 -3
  191. data/examples/{show_greek_letters.rb → show_greek_letters/show_greek_letters.rb} +0 -0
  192. data/examples/simple/input_example_with_coloured_focus.cgi +32 -0
  193. data/examples/simple/input_type_examples.cgi +51 -0
  194. data/examples/simple/on_click_event_hello_world.cgi +5 -5
  195. data/examples/simple/rotate_these_words.cgi +90 -0
  196. data/examples/{example1.rb → simple/show_how_to_set_a_title.rb} +0 -0
  197. data/examples/simple/simple_gradient.cgi +57 -0
  198. data/images/cyberweb_favicon.png +0 -0
  199. data/images/cyberweb_logo.png +0 -0
  200. data/images/cyberweb_theme.png +0 -0
  201. data/lib/cyberweb/REST/README.md +7 -0
  202. data/lib/cyberweb/REST/base/accept_entry.rb +94 -0
  203. data/lib/cyberweb/REST/base/application.rb +37 -0
  204. data/lib/cyberweb/REST/base/bad_request.rb +10 -0
  205. data/lib/cyberweb/REST/base/base.rb +1131 -0
  206. data/lib/cyberweb/REST/base/common_logger.rb +35 -0
  207. data/lib/cyberweb/REST/base/delegator.rb +75 -0
  208. data/lib/cyberweb/REST/base/error.rb +8 -0
  209. data/lib/cyberweb/REST/base/extended_rack.rb +66 -0
  210. data/lib/cyberweb/REST/base/helpers/helpers.rb +473 -0
  211. data/lib/cyberweb/REST/base/helpers/stream.rb +75 -0
  212. data/lib/cyberweb/REST/base/mime_type_entry.rb +67 -0
  213. data/lib/cyberweb/{constants/file_constants.rb → REST/base/not_found.rb} +10 -5
  214. data/lib/cyberweb/REST/base/request.rb +145 -0
  215. data/lib/cyberweb/REST/base/response.rb +94 -0
  216. data/lib/cyberweb/REST/base/templates/templates.rb +208 -0
  217. data/lib/cyberweb/REST/base/wrapper.rb +28 -0
  218. data/lib/cyberweb/{constants/nl.rb → REST/constants.rb} +8 -9
  219. data/lib/cyberweb/REST/main.rb +109 -0
  220. data/lib/cyberweb/REST/show_exceptions.rb +396 -0
  221. data/lib/cyberweb/and_sinatra_base.rb +0 -0
  222. data/lib/cyberweb/autoinclude.rb +0 -0
  223. data/lib/cyberweb/autoinclude_webobject.rb +0 -0
  224. data/lib/cyberweb/base/base.rb +9 -2
  225. data/lib/cyberweb/base/colours.rb +8 -6
  226. data/lib/cyberweb/base/constants.rb +8 -0
  227. data/lib/cyberweb/base/misc.rb +140 -53
  228. data/lib/cyberweb/base/save_file.rb +3 -0
  229. data/lib/cyberweb/base_module/base_module.rb +79 -0
  230. data/lib/cyberweb/cascading_style_sheets/admonition.css +0 -0
  231. data/lib/cyberweb/cascading_style_sheets/balloon.css +0 -0
  232. data/lib/cyberweb/cascading_style_sheets/border.css +107 -41
  233. data/lib/cyberweb/cascading_style_sheets/code.css +0 -0
  234. data/lib/cyberweb/cascading_style_sheets/colours.css +46 -23
  235. data/lib/cyberweb/cascading_style_sheets/css_reset.css +59 -0
  236. data/lib/cyberweb/cascading_style_sheets/cursors.css +14 -0
  237. data/lib/cyberweb/cascading_style_sheets/custom/animated_bike.css +199 -0
  238. data/lib/cyberweb/cascading_style_sheets/default.css +171 -136
  239. data/lib/cyberweb/cascading_style_sheets/div.css +18 -4
  240. data/lib/cyberweb/cascading_style_sheets/drop_shadow.css +154 -0
  241. data/lib/cyberweb/cascading_style_sheets/error_404_css_class.css +26 -0
  242. data/lib/cyberweb/cascading_style_sheets/fonts.css +60 -39
  243. data/lib/cyberweb/cascading_style_sheets/glow_effects.css +69 -0
  244. data/lib/cyberweb/cascading_style_sheets/gradient_effects.css +5 -0
  245. data/lib/cyberweb/cascading_style_sheets/hover.css +4212 -0
  246. data/lib/cyberweb/cascading_style_sheets/links.css +8 -8
  247. data/lib/cyberweb/cascading_style_sheets/margin.css +195 -178
  248. data/lib/cyberweb/cascading_style_sheets/menu.css +0 -0
  249. data/lib/cyberweb/cascading_style_sheets/message_boxes.css +0 -0
  250. data/lib/cyberweb/cascading_style_sheets/misc.css +51 -11
  251. data/lib/cyberweb/cascading_style_sheets/popup.css +0 -0
  252. data/lib/cyberweb/cascading_style_sheets/rpg.css +0 -0
  253. data/lib/cyberweb/cascading_style_sheets/ruby_regexes.css +12 -0
  254. data/lib/cyberweb/cascading_style_sheets/shapes.css +59 -0
  255. data/lib/cyberweb/cascading_style_sheets/template2.css +0 -0
  256. data/lib/cyberweb/cascading_style_sheets/text_shadow.css +21 -0
  257. data/lib/cyberweb/cascading_style_sheets/tooltip.css +0 -0
  258. data/lib/cyberweb/cgi/constants.rb +1 -2
  259. data/lib/cyberweb/cgi/exceptions.rb +1 -1
  260. data/lib/cyberweb/coloured_tags/coloured_tags.rb +1 -1
  261. data/lib/cyberweb/colours/colour_chart.rb +10 -56
  262. data/lib/cyberweb/colours/colours.rb +149 -4
  263. data/lib/cyberweb/commandline/commandline_interface.rb +13 -8
  264. data/lib/cyberweb/configuration/load_the_configuration_file.rb +1 -1
  265. data/lib/cyberweb/constants/constants.rb +592 -2
  266. data/lib/cyberweb/controller/{webobject_controller.rb → controller.rb} +1 -1
  267. data/lib/cyberweb/css_manager/css_manager.rb +237 -0
  268. data/lib/cyberweb/databases/sqlite.rb +56 -0
  269. data/lib/cyberweb/debug/debug.rb +1 -1
  270. data/lib/cyberweb/encoding/encoding.rb +11 -0
  271. data/lib/cyberweb/erb/test.rhtml +0 -0
  272. data/lib/cyberweb/erb/test_template.erb +0 -0
  273. data/lib/cyberweb/evaluate_from_the_same_named_file_then_serve.rb +1 -1
  274. data/lib/cyberweb/favicon/favicon.rb +8 -7
  275. data/lib/cyberweb/forum/README.md +4 -0
  276. data/lib/cyberweb/foto_gallery/foto_gallery.rb +158 -0
  277. data/lib/cyberweb/generator/README.md +2 -2
  278. data/lib/cyberweb/generator/cgi.rb +22 -9
  279. data/lib/cyberweb/generator/static_webpage.rb +22 -12
  280. data/lib/cyberweb/html_tags/README.md +3 -3
  281. data/lib/cyberweb/html_tags/button.rb +10 -2
  282. data/lib/cyberweb/html_tags/h2.rb +6 -4
  283. data/lib/cyberweb/html_tags/html_tags.rb +17 -1
  284. data/lib/cyberweb/html_tags/input.rb +10 -5
  285. data/lib/cyberweb/html_tags/legend.rb +1 -1
  286. data/lib/cyberweb/html_tags/span.rb +10 -2
  287. data/lib/cyberweb/html_tags/table.rb +30 -19
  288. data/lib/cyberweb/html_template/html_template.rb +248 -85
  289. data/lib/cyberweb/images/embed_this_image.rb +3 -1
  290. data/lib/cyberweb/images/images.rb +2 -2
  291. data/lib/cyberweb/images/is_image.rb +2 -1
  292. data/lib/cyberweb/images/path_to_images.rb +2 -1
  293. data/lib/cyberweb/images/remove_this_substring_from_all_images.rb +1 -1
  294. data/lib/cyberweb/images/standalone_drag_and_drop_this_image.rb +3 -3
  295. data/lib/cyberweb/images/string_image.rb +6 -3
  296. data/lib/cyberweb/images_base64_encoded/404_ERROR.png.md +1 -0
  297. data/lib/cyberweb/images_base64_encoded/AUSRUFUNGSZEICHEN.png.md +0 -0
  298. data/lib/cyberweb/images_base64_encoded/BLUEARROW.png.md +0 -0
  299. data/lib/cyberweb/images_base64_encoded/BUBBLE.png.md +0 -0
  300. data/lib/cyberweb/images_base64_encoded/CAT.png.md +0 -0
  301. data/lib/cyberweb/images_base64_encoded/CAUTION.png.md +0 -0
  302. data/lib/cyberweb/images_base64_encoded/CHEERING_PERSON.png.md +0 -0
  303. data/lib/cyberweb/images_base64_encoded/CURSOR.png.md +0 -0
  304. data/lib/cyberweb/images_base64_encoded/DOT_01.png.md +0 -0
  305. data/lib/cyberweb/images_base64_encoded/DUCKY.png.md +0 -0
  306. data/lib/cyberweb/images_base64_encoded/ELEPHANT.png.md +0 -0
  307. data/lib/cyberweb/images_base64_encoded/HALLOWEEN.png.md +0 -0
  308. data/lib/cyberweb/images_base64_encoded/HANGING_MONKEY.png.md +0 -0
  309. data/lib/cyberweb/images_base64_encoded/LENS.png.md +0 -0
  310. data/lib/cyberweb/images_base64_encoded/README.md +0 -0
  311. data/lib/cyberweb/images_base64_encoded/SIX_SIDED_DICE.png.md +1 -0
  312. data/lib/cyberweb/images_base64_encoded/TU_WIEN_LOGO.png.md +0 -0
  313. data/lib/cyberweb/images_base64_encoded/VOGEL.png.md +0 -0
  314. data/lib/cyberweb/javascript/drag_and_drop.rb +17 -14
  315. data/lib/cyberweb/javascript/javascript.rb +79 -34
  316. data/lib/cyberweb/javascript/javascript_clock.rb +50 -14
  317. data/lib/cyberweb/javascript/javascript_helper/javascript_helper.rb +59 -0
  318. data/lib/cyberweb/javascript/jquery.rb +9 -5
  319. data/lib/cyberweb/javascript/on_click_change_opacity.rb +5 -1
  320. data/lib/cyberweb/javascript/on_click_hide.rb +2 -0
  321. data/lib/cyberweb/javascript/popup.rb +5 -2
  322. data/lib/cyberweb/javascript/resize.rb +4 -1
  323. data/lib/cyberweb/javascript_code/README.md +1 -1
  324. data/lib/cyberweb/javascript_code/custom_functions.js +51 -25
  325. data/lib/cyberweb/javascript_code/disable_right_click.js +5 -0
  326. data/lib/cyberweb/javascript_code/games/snake.js +113 -0
  327. data/lib/cyberweb/javascript_code/games/tetris.js +491 -0
  328. data/lib/cyberweb/javascript_code/games/tic-tac-toe.js +125 -0
  329. data/lib/cyberweb/javascript_code/html_colours.js +161 -0
  330. data/lib/cyberweb/javascript_code/jquery/jquery-3.6.1.js +10909 -0
  331. data/lib/cyberweb/javascript_code/select_everything_on_mouse_click_event.js +23 -0
  332. data/lib/cyberweb/javascript_code/simple_calculator.js +3 -3
  333. data/lib/cyberweb/javascript_code/simulate_a_dice.js +20 -0
  334. data/lib/cyberweb/javascript_code/sleep.js +3 -0
  335. data/lib/cyberweb/mouse/mouse.rb +4 -1
  336. data/lib/cyberweb/objectified/html_tags/README.md +13 -0
  337. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/a.rb +17 -35
  338. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/abbr.rb +18 -9
  339. data/lib/cyberweb/objectified/html_tags/base.rb +960 -0
  340. data/lib/cyberweb/objectified/html_tags/blockquote.rb +106 -0
  341. data/lib/cyberweb/{objectified_html_tags/span.rb → objectified/html_tags/body.rb} +25 -20
  342. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/button.rb +26 -34
  343. data/lib/cyberweb/objectified/html_tags/canvas.rb +202 -0
  344. data/lib/cyberweb/objectified/html_tags/cite.rb +103 -0
  345. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/combobox.rb +26 -34
  346. data/lib/cyberweb/objectified/html_tags/div.rb +155 -0
  347. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/embed.rb +18 -33
  348. data/lib/cyberweb/objectified/html_tags/fieldset.rb +107 -0
  349. data/lib/cyberweb/objectified/html_tags/figure.rb +152 -0
  350. data/lib/cyberweb/objectified/html_tags/form.rb +155 -0
  351. data/lib/cyberweb/objectified/html_tags/h1.rb +176 -0
  352. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h2.rb +32 -40
  353. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h3.rb +30 -42
  354. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h4.rb +30 -42
  355. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h5.rb +31 -40
  356. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h6.rb +31 -41
  357. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/hbox.rb +12 -10
  358. data/lib/cyberweb/objectified/html_tags/head.rb +126 -0
  359. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/img.rb +47 -32
  360. data/lib/cyberweb/objectified/html_tags/include_objectified_html_tags.rb +49 -0
  361. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/input.rb +50 -51
  362. data/lib/cyberweb/objectified/html_tags/map.rb +107 -0
  363. data/lib/cyberweb/{objectified_html_tags/div.rb → objectified/html_tags/meta.rb} +36 -47
  364. data/lib/cyberweb/{objectified_html_tags/h1.rb → objectified/html_tags/object.rb} +34 -42
  365. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/p.rb +17 -32
  366. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/pre.rb +28 -34
  367. data/lib/cyberweb/{objectified_html_tags/table.rb → objectified/html_tags/progress.rb} +99 -94
  368. data/lib/cyberweb/objectified/html_tags/span.rb +103 -0
  369. data/lib/cyberweb/objectified/html_tags/table.rb +257 -0
  370. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/textarea.rb +25 -36
  371. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/title.rb +11 -17
  372. data/lib/cyberweb/{objectified_html_tags/form.rb → objectified/html_tags/ul.rb} +45 -42
  373. data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/window.rb +15 -10
  374. data/lib/cyberweb/objectified/mask/README.md +8 -0
  375. data/lib/cyberweb/objectified/mask/compatibility_to_html_tags.rb +40 -0
  376. data/lib/cyberweb/objectified/mask/mask.rb +490 -0
  377. data/lib/cyberweb/objectified/web_object/README.md +4 -0
  378. data/lib/cyberweb/objectified/web_object/web_object.rb +119 -0
  379. data/lib/cyberweb/predefined_and_freeform_methods/frage.rb +4 -2
  380. data/lib/cyberweb/predefined_and_freeform_methods/freeform_methods.rb +30 -19
  381. data/lib/cyberweb/predefined_and_freeform_methods/hash_registered_extra_tags.rb +6 -0
  382. data/lib/cyberweb/predefined_and_freeform_methods/header.rb +2 -0
  383. data/lib/cyberweb/predefined_and_freeform_methods/predefined_methods.rb +10 -175
  384. data/lib/cyberweb/project/project.rb +9 -4
  385. data/lib/cyberweb/rack/request.rb +11 -11
  386. data/lib/cyberweb/raw_images/404.png +0 -0
  387. data/lib/cyberweb/raw_images/500.png +0 -0
  388. data/lib/cyberweb/raw_images/README.md +2 -0
  389. data/lib/cyberweb/raw_images/a_dice.png +0 -0
  390. data/lib/cyberweb/raw_images/food.png +0 -0
  391. data/lib/cyberweb/raw_images/ground.png +0 -0
  392. data/lib/cyberweb/requires/require_generators.rb +1 -1
  393. data/lib/cyberweb/requires/require_html_tags_files.rb +1 -1
  394. data/lib/cyberweb/requires/require_javascript_files.rb +1 -1
  395. data/lib/cyberweb/requires/require_objectified_html_tags_files.rb +29 -3
  396. data/lib/cyberweb/requires/require_the_constants.rb +3 -1
  397. data/lib/cyberweb/requires/require_the_cyberweb_project.rb +12 -31
  398. data/lib/cyberweb/requires/require_the_toplevel_methods_files.rb +1 -1
  399. data/lib/cyberweb/requires/require_web_object_files.rb +1 -1
  400. data/lib/cyberweb/requires/require_yaml.rb +3 -3
  401. data/lib/cyberweb/rest +1 -0
  402. data/lib/cyberweb/route_handler/class_based_test.rb +43 -0
  403. data/lib/cyberweb/route_handler/module/misc.rb +108 -0
  404. data/lib/cyberweb/route_handler/module/route_handler_module.rb +215 -0
  405. data/lib/cyberweb/route_handler/module/verbs.rb +53 -0
  406. data/lib/cyberweb/route_handler/route_handler.rb +56 -0
  407. data/lib/cyberweb/route_handler/test.rb +43 -0
  408. data/lib/cyberweb/{constants/array_predefined_constants.rb → sinatra/base/set_use_this_port.rb} +16 -9
  409. data/lib/cyberweb/sinatra/base/use_this_port.rb +40 -0
  410. data/lib/cyberweb/sinatra/base.rb +51 -36
  411. data/lib/cyberweb/sinatra/custom_extensions.rb +39 -14
  412. data/lib/cyberweb/standalone_classes/all_css_classes.rb +1 -1
  413. data/lib/cyberweb/standalone_classes/calculator.rb +7 -1
  414. data/lib/cyberweb/standalone_classes/correct_image_entries_in_html_file.rb +12 -7
  415. data/lib/cyberweb/standalone_classes/turn_html_into_cyberweb.rb +13 -11
  416. data/lib/cyberweb/svg/standalone/README.md +2 -0
  417. data/lib/cyberweb/svg/standalone/amusement_park.svg +738 -0
  418. data/lib/cyberweb/svg/svg.cgi +2 -3
  419. data/lib/cyberweb/toplevel_methods/a.rb +2 -1
  420. data/lib/cyberweb/toplevel_methods/anmerkung.rb +3 -0
  421. data/lib/cyberweb/toplevel_methods/audio.rb +1 -1
  422. data/lib/cyberweb/toplevel_methods/bold.rb +9 -3
  423. data/lib/cyberweb/toplevel_methods/charsets.rb +17 -13
  424. data/lib/cyberweb/toplevel_methods/consider_serving_the_web_object.rb +3 -3
  425. data/lib/cyberweb/toplevel_methods/css.rb +719 -25
  426. data/lib/cyberweb/{csv → toplevel_methods}/csv.rb +5 -3
  427. data/lib/cyberweb/{constants/roebe.rb → toplevel_methods/custom_error_page.rb} +10 -10
  428. data/lib/cyberweb/toplevel_methods/{date.rb → date_and_time.rb} +23 -10
  429. data/lib/cyberweb/toplevel_methods/disable.rb +7 -3
  430. data/lib/cyberweb/toplevel_methods/dot.rb +2 -2
  431. data/lib/cyberweb/toplevel_methods/download_webpage.rb +41 -3
  432. data/lib/cyberweb/toplevel_methods/edit_configuration_file.rb +1 -1
  433. data/lib/cyberweb/toplevel_methods/fields.rb +2 -0
  434. data/lib/cyberweb/toplevel_methods/filename.rb +3 -1
  435. data/lib/cyberweb/toplevel_methods/frames.rb +0 -2
  436. data/lib/cyberweb/toplevel_methods/google.rb +52 -0
  437. data/lib/cyberweb/{html_codes → toplevel_methods}/greek_letters.rb +22 -1
  438. data/lib/cyberweb/toplevel_methods/hardware_information.rb +2 -1
  439. data/lib/cyberweb/{help → toplevel_methods}/help.rb +3 -2
  440. data/lib/cyberweb/toplevel_methods/html_comment.rb +2 -2
  441. data/lib/cyberweb/toplevel_methods/html_tables.rb +401 -266
  442. data/lib/cyberweb/toplevel_methods/internal_hash.rb +173 -0
  443. data/lib/cyberweb/{io → toplevel_methods}/io.rb +1 -1
  444. data/lib/cyberweb/toplevel_methods/javascript.rb +42 -0
  445. data/lib/cyberweb/toplevel_methods/jquery.rb +8 -0
  446. data/lib/cyberweb/toplevel_methods/last_modified.rb +4 -0
  447. data/lib/cyberweb/toplevel_methods/links.rb +23 -7
  448. data/lib/cyberweb/toplevel_methods/listing.rb +2 -1
  449. data/lib/cyberweb/toplevel_methods/localhost.rb +3 -0
  450. data/lib/cyberweb/toplevel_methods/markdown.rb +3 -2
  451. data/lib/cyberweb/toplevel_methods/mathml.rb +5 -3
  452. data/lib/cyberweb/toplevel_methods/message_boxes.rb +6 -2
  453. data/lib/cyberweb/toplevel_methods/misc.rb +531 -79
  454. data/lib/cyberweb/toplevel_methods/padlem_and_marlem.rb +3 -0
  455. data/lib/cyberweb/toplevel_methods/path.rb +6 -1
  456. data/lib/cyberweb/toplevel_methods/pdf.rb +1 -1
  457. data/lib/cyberweb/toplevel_methods/process_content.rb +4 -7
  458. data/lib/cyberweb/toplevel_methods/progress.rb +6 -2
  459. data/lib/cyberweb/toplevel_methods/quote.rb +7 -1
  460. data/lib/cyberweb/toplevel_methods/random.rb +4 -1
  461. data/lib/cyberweb/toplevel_methods/rds.rb +14 -6
  462. data/lib/cyberweb/toplevel_methods/read_and_display.rb +3 -2
  463. data/lib/cyberweb/toplevel_methods/return_head_start.rb +1 -1
  464. data/lib/cyberweb/toplevel_methods/return_html_fin.rb +6 -3
  465. data/lib/cyberweb/toplevel_methods/return_html_header.rb +8 -3
  466. data/lib/cyberweb/toplevel_methods/return_html_start.rb +7 -2
  467. data/lib/cyberweb/toplevel_methods/return_meta_collection.rb +15 -4
  468. data/lib/cyberweb/toplevel_methods/return_pwd.rb +4 -0
  469. data/lib/cyberweb/toplevel_methods/return_strict_doctype.rb +8 -7
  470. data/lib/cyberweb/toplevel_methods/roebe.rb +6 -0
  471. data/lib/cyberweb/toplevel_methods/s2.rb +3 -1
  472. data/lib/cyberweb/toplevel_methods/sanitize_url.rb +7 -5
  473. data/lib/cyberweb/toplevel_methods/sbr.rb +7 -7
  474. data/lib/cyberweb/toplevel_methods/server_base_directory.rb +7 -3
  475. data/lib/cyberweb/toplevel_methods/show_and_display.rb +15 -15
  476. data/lib/cyberweb/toplevel_methods/show_configuration.rb +2 -2
  477. data/lib/cyberweb/toplevel_methods/spacer.rb +5 -2
  478. data/lib/cyberweb/toplevel_methods/svg.rb +62 -4
  479. data/lib/cyberweb/toplevel_methods/tag.rb +8 -2
  480. data/lib/cyberweb/toplevel_methods/temp_directory.rb +2 -2
  481. data/lib/cyberweb/toplevel_methods/textile.rb +2 -2
  482. data/lib/cyberweb/toplevel_methods/title.rb +14 -2
  483. data/lib/cyberweb/toplevel_methods/video.rb +3 -4
  484. data/lib/cyberweb/toplevel_methods/write_what_into.rb +2 -0
  485. data/lib/cyberweb/utility_scripts/README.md +3 -4
  486. data/lib/cyberweb/utility_scripts/autogenerate_drop_shadow_rules/autogenerate_drop_shadow_rules.rb +71 -0
  487. data/lib/cyberweb/utility_scripts/create_standalone_html_page.rb +223 -0
  488. data/lib/cyberweb/utility_scripts/download_all_images_from_this_website.rb +143 -0
  489. data/lib/cyberweb/utility_scripts/download_balloon_css.rb +1 -1
  490. data/lib/cyberweb/utility_scripts/fix_incorrect_links_to_locally_existing_images_in_this_file.rb +142 -0
  491. data/lib/cyberweb/utility_scripts/html_to_cyberweb_converter.rb +235 -0
  492. data/lib/cyberweb/utility_scripts/images_to_html/images_to_html.rb +878 -0
  493. data/lib/cyberweb/utility_scripts/images_to_html/misc.rb +62 -0
  494. data/lib/cyberweb/utility_scripts/new_tags.rb +105 -0
  495. data/lib/cyberweb/utility_scripts/simple_index/README.md +9 -0
  496. data/lib/cyberweb/utility_scripts/simple_index/simple_index.rb +149 -0
  497. data/lib/cyberweb/version/version.rb +2 -2
  498. data/lib/cyberweb/vue/README.md +2 -0
  499. data/lib/cyberweb/vue/vue.rb +91 -0
  500. data/lib/cyberweb/web_images/array_listing_all_project_images.rb +1 -1
  501. data/lib/cyberweb/web_images/map_symbol_to_image_location.rb +60 -4
  502. data/lib/cyberweb/web_images/web_images.rb +37 -20
  503. data/lib/cyberweb/{constants/array_images.rb → web_object/display_output_and_report.rb} +11 -10
  504. data/lib/cyberweb/web_object/english.rb +55 -0
  505. data/lib/cyberweb/web_object/favicon.rb +103 -22
  506. data/lib/cyberweb/web_object/html_tags.rb +1433 -0
  507. data/lib/cyberweb/web_object/images.rb +428 -398
  508. data/lib/cyberweb/web_object/{javascript.rb → javascript_and_jquery.rb} +174 -276
  509. data/lib/cyberweb/web_object/{links.rb → link.rb} +185 -83
  510. data/lib/cyberweb/web_object/misc.rb +3934 -3928
  511. data/lib/cyberweb/web_object/reset.rb +153 -67
  512. data/lib/cyberweb/web_object/run.rb +1 -1
  513. data/lib/cyberweb/web_object/web_object.rb +3690 -49
  514. data/lib/cyberweb/web_scraper/scrape_this_url.rb +4 -2
  515. data/lib/cyberweb/webmin/biology_server.cgi +14 -15
  516. data/lib/cyberweb/webmin/calculator.cgi +2 -2
  517. data/lib/cyberweb/webmin/colour_chart.cgi +4 -5
  518. data/lib/cyberweb/webmin/comments.cgi +8 -7
  519. data/lib/cyberweb/webmin/comments_data +0 -0
  520. data/lib/cyberweb/webmin/constants.rb +1 -2
  521. data/lib/cyberweb/webmin/dictionary.cgi +3 -4
  522. data/lib/cyberweb/webmin/sys_info.cgi +1 -2
  523. data/lib/cyberweb/webmin/webforum.cgi +1 -2
  524. data/lib/cyberweb/webmin/webmin.cgi +2 -3
  525. data/lib/cyberweb/yaml/autogenerated_system_settings.yml +10 -10
  526. data/lib/cyberweb/yaml/custom_tags.yml +1 -1
  527. data/lib/cyberweb/yaml/html5_global_attributes.yml +5 -1
  528. data/lib/cyberweb/yaml/html_tag_legend.yml +2 -0
  529. data/lib/cyberweb/yaml/http_status_codes.yml +4 -1
  530. data/lib/cyberweb/yaml/load_these_yaml_files_by_default.yml +29 -0
  531. data/lib/cyberweb/yaml/project_configuration.yml +42 -31
  532. data/lib/cyberweb/yaml/video_attributes.yml +2 -0
  533. data/lib/cyberweb/yaml/web_images.yml +1 -1
  534. data/test/REST/simple.rb +7 -0
  535. data/test/complex_tests/simple_sinatra_example_using_cyberweb/simple.rb +1 -1
  536. data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.cgi +1 -1
  537. data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.rb +4 -4
  538. data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.sinatra +1 -2
  539. data/test/complex_tests/testing_frames.cgi +3 -5
  540. data/test/complex_tests/testing_objectified_html_tags/testing_objectified_html_tags.html +28 -0
  541. data/test/complex_tests/testing_objectified_html_tags/testing_objectified_html_tags.rb +175 -0
  542. data/test/complex_tests/testing_style_variants/show_coloured_boxes.cgi +11 -7
  543. data/test/complex_tests/testing_tables.cgi +3 -3
  544. data/test/complex_tests/testing_the_cyberweb_shell.rb +2 -0
  545. data/test/complex_tests/testing_web_object.rb +5 -2
  546. data/test/css/README.md +4 -3
  547. data/test/css/return_the_content_of_these_css_classes.rb +5 -1
  548. data/test/css/test_hover_css/test_hover_css.cgi +59 -0
  549. data/test/css/test_ordered_list/test_ordered_list.cgi +31 -0
  550. data/test/css/testing_css_effects.cgi +3 -4
  551. data/test/css/testing_css_masking.cgi +3 -4
  552. data/test/hello_world/hello_world.cgi +6 -4
  553. data/test/html_template/html_template.rb +15 -0
  554. data/test/javascript/testing_custom_functions.js +24 -0
  555. data/test/javascript/testing_drag_and_drop_support.cgi +1 -1
  556. data/test/javascript/testing_on_click_change_opacity.cgi +4 -5
  557. data/test/javascript/testing_snowflakes.cgi +2 -2
  558. data/test/simple_tests/ad-hoc-test.cgi +5 -2
  559. data/test/simple_tests/cgi/hello_world_with_cyberweb.cgi +14 -0
  560. data/test/simple_tests/commandline_tests.rb +21 -15
  561. data/test/simple_tests/display_this_file.cgi +2 -2
  562. data/test/simple_tests/simple_html_example.cgi +2 -1
  563. data/test/simple_tests/simple_html_test_page/simple_html_test_page.html +20 -0
  564. data/test/simple_tests/simple_status_page.cgi +2 -2
  565. data/test/simple_tests/string_s2_test.rb +5 -0
  566. data/test/simple_tests/test_simple_string_as_input.rb +3 -1
  567. data/test/simple_tests/testing_base64_images.cgi +3 -4
  568. data/test/simple_tests/testing_checkboxes.cgi +22 -0
  569. data/test/simple_tests/testing_dragging_an_image.cgi +5 -6
  570. data/test/simple_tests/testing_editable_text.cgi +2 -3
  571. data/test/simple_tests/testing_email.cgi +6 -7
  572. data/test/simple_tests/testing_embedding_a_pdf_file.cgi +5 -5
  573. data/test/simple_tests/testing_google_charts.cgi +3 -3
  574. data/test/simple_tests/testing_html_forms.cgi +3 -3
  575. data/test/simple_tests/testing_html_template.rb +2 -0
  576. data/test/simple_tests/testing_popup_div.cgi +2 -3
  577. data/test/simple_tests/testing_return_dataset_without_any_comments.rb +3 -1
  578. data/test/simple_tests/testing_the_cap_box.cgi +3 -4
  579. data/test/simple_tests/testing_the_div_tag.cgi +3 -4
  580. data/test/simple_tests/testing_the_headers_tag.cgi +3 -4
  581. data/test/simple_tests/testing_the_html_colours.cgi +2 -3
  582. data/test/simple_tests/testing_the_info_box.cgi +2 -3
  583. data/test/simple_tests/testing_the_li_tag.cgi +2 -1
  584. data/test/simple_tests/testing_the_s2_method.rb +6 -1
  585. data/test/simple_tests/testing_the_select_tag.cgi +16 -8
  586. data/test/simple_tests/testing_the_span_tag.cgi +2 -3
  587. data/test/simple_tests/testing_web_images.rb +4 -2
  588. data/test/testing_html_tags/button_example.cgi +6 -7
  589. metadata +345 -151
  590. data/doc/CONVENTIONS.md +0 -7
  591. data/doc/CYBERWEB_TUTORIAL.cgi +0 -43
  592. data/doc/FUTURE_DESIGN_GOAL_CONSIDERATIONS.md +0 -13
  593. data/doc/todo/TODO_FOR_THE_CYBERWEB_PROJECT.md +0 -1089
  594. data/examples/css/shadow_example_in_CSS.cgi +0 -30
  595. data/lib/cyberweb/charts/README.md +0 -2
  596. data/lib/cyberweb/charts/google_charts.rb +0 -51
  597. data/lib/cyberweb/colours/random_colour.rb +0 -28
  598. data/lib/cyberweb/colours/sanitize_for_colours.rb +0 -95
  599. data/lib/cyberweb/constants/array_local_css_files.rb +0 -35
  600. data/lib/cyberweb/constants/configuration_file.rb +0 -33
  601. data/lib/cyberweb/constants/http_status_codes.rb +0 -42
  602. data/lib/cyberweb/constants/project_constants.rb +0 -99
  603. data/lib/cyberweb/constants/standalone_constants.rb +0 -309
  604. data/lib/cyberweb/csv/README.md +0 -2
  605. data/lib/cyberweb/generator/webpage_for_images.rb +0 -553
  606. data/lib/cyberweb/html_codes/README.md +0 -15
  607. data/lib/cyberweb/images/real/README.md +0 -6
  608. data/lib/cyberweb/io/README.md +0 -1
  609. data/lib/cyberweb/javascript/scroll.rb +0 -17
  610. data/lib/cyberweb/objectified_html_tags/README.md +0 -8
  611. data/lib/cyberweb/objectified_html_tags/base.rb +0 -376
  612. data/lib/cyberweb/predefined_and_freeform_methods/hash_css_class_to_use.rb +0 -55
  613. data/lib/cyberweb/requires/require_charts.rb +0 -20
  614. data/lib/cyberweb/web_object/css.rb +0 -627
  615. data/lib/cyberweb/web_object/evaluate.rb +0 -126
  616. data/lib/cyberweb/web_object/html_related_tags.rb +0 -320
  617. data/lib/cyberweb/web_object/initialize.rb +0 -51
  618. data/lib/cyberweb/web_object/input_related_functionality.rb +0 -414
  619. data/lib/cyberweb/web_object/languages.rb +0 -172
  620. data/lib/cyberweb/web_object/params.rb +0 -289
  621. data/lib/cyberweb/web_object/sinatra_related_functionality.rb +0 -30
  622. data/lib/cyberweb/web_object/sitemap.rb +0 -176
  623. data/lib/cyberweb/web_object/table.rb +0 -378
  624. data/test/complex_tests/testing_objectified_html_tags.rb +0 -82
  625. data/test/javascript/testing_cheerleader_javascript.cgi +0 -0
@@ -0,0 +1,1161 @@
1
+ <html>
2
+ <head>
3
+ <title>Lighthouse Example</title>
4
+ <style>
5
+ html, body {
6
+ height: 100%;
7
+ width: 100%;
8
+ padding: 0;
9
+ margin: 0;
10
+ overflow: hidden;
11
+ }
12
+ html {
13
+ box-sizing: border-box;
14
+ }
15
+ *, *:before, *:after {
16
+ box-sizing: inherit;
17
+ }
18
+ * {
19
+ position: absolute;
20
+ }
21
+ *:before, *:after {
22
+ content: "";
23
+ position: absolute;
24
+ }
25
+ .scene {
26
+ width: 100vw;
27
+ height: 100vh;
28
+ }
29
+ .background {
30
+ width: 100%;
31
+ height: 100%;
32
+ overflow: hidden;
33
+ z-index: 1;
34
+ background-color: #29284c;
35
+ background-image: linear-gradient(#29284c 0%, #4c4b82 10%, #717ae1 60%, #75e2fa 90%);
36
+ }
37
+ .mountains {
38
+ width: 100%;
39
+ height: 250px;
40
+ bottom: 65px;
41
+ z-index: 3;
42
+ }
43
+ .mountains .mountain {
44
+ width: 250px;
45
+ height: 250px;
46
+ right: 50px;
47
+ bottom: -40px;
48
+ background-color: #717ae1;
49
+ transform: rotate(45deg);
50
+ border-radius: 3px;
51
+ }
52
+ .mountains .mountain:after {
53
+ width: 100%;
54
+ height: 100%;
55
+ opacity: 0.7;
56
+ background-image: linear-gradient(135deg, #4c4b82 0%, #717ae1 20%, #75e2fa 40%);
57
+ }
58
+ .mountains .mountain:nth-child(2) {
59
+ width: 240px;
60
+ height: 240px;
61
+ right: 220px;
62
+ z-index: 2;
63
+ }
64
+ .mountains .mountain:nth-child(3) {
65
+ width: 260px;
66
+ height: 260px;
67
+ right: 350px;
68
+ }
69
+ .mountains .mountain:nth-child(4) {
70
+ width: 200px;
71
+ height: 200px;
72
+ right: 130px;
73
+ bottom: -70px;
74
+ z-index: 3;
75
+ }
76
+ .mountains .mountain:nth-child(4):after {
77
+ background-image: linear-gradient(135deg, #4c4b82 0%, #717ae1 6%, #75e2fa 20%);
78
+ }
79
+ .sea {
80
+ width: 100%;
81
+ height: 170px;
82
+ bottom: 0;
83
+ left: 0;
84
+ background: #29284c;
85
+ background-image: linear-gradient(to top, #29284c 0%, #4c4b82 30%, #717ae1 60%, #75e2fa 90%);
86
+ z-index: 4;
87
+ }
88
+ .sea .wave {
89
+ height: 3px;
90
+ background-color: #d6d9f6;
91
+ border-radius: 100%;
92
+ opacity: 0.2;
93
+ animation: wave 5s linear infinite;
94
+ }
95
+ .sea .wave:nth-of-type(1) {
96
+ width: 86px;
97
+ bottom: 55px;
98
+ left: 38vw;
99
+ opacity: 0.5;
100
+ animation-delay: 3s;
101
+ }
102
+ .sea .wave:nth-of-type(2) {
103
+ width: 53px;
104
+ bottom: 150px;
105
+ left: 55vw;
106
+ opacity: 0.4;
107
+ animation-delay: 2s;
108
+ }
109
+ .sea .wave:nth-of-type(3) {
110
+ width: 142px;
111
+ bottom: 53px;
112
+ left: 66vw;
113
+ opacity: 0.3;
114
+ animation-delay: 2s;
115
+ }
116
+ .sea .wave:nth-of-type(4) {
117
+ width: 109px;
118
+ bottom: 123px;
119
+ left: 35vw;
120
+ opacity: 0.5;
121
+ animation-delay: 2s;
122
+ }
123
+ .sea .wave:nth-of-type(5) {
124
+ width: 92px;
125
+ bottom: 89px;
126
+ left: 12vw;
127
+ opacity: 0.5;
128
+ animation-delay: 3s;
129
+ }
130
+ .sea .wave:nth-of-type(6) {
131
+ width: 108px;
132
+ bottom: 48px;
133
+ left: 63vw;
134
+ opacity: 0.2;
135
+ animation-delay: 3s;
136
+ }
137
+ .sea .wave:nth-of-type(7) {
138
+ width: 71px;
139
+ bottom: 153px;
140
+ left: 75vw;
141
+ opacity: 0.3;
142
+ animation-delay: 3s;
143
+ }
144
+ .sea .wave:nth-of-type(8) {
145
+ width: 55px;
146
+ bottom: 139px;
147
+ left: 6vw;
148
+ opacity: 0.3;
149
+ animation-delay: 3s;
150
+ }
151
+ .sea .wave:nth-of-type(9) {
152
+ width: 93px;
153
+ bottom: 163px;
154
+ left: 55vw;
155
+ opacity: 0.1;
156
+ animation-delay: 1s;
157
+ }
158
+ .sea .wave:nth-of-type(10) {
159
+ width: 134px;
160
+ bottom: 58px;
161
+ left: 95vw;
162
+ opacity: 0.1;
163
+ animation-delay: 3s;
164
+ }
165
+ .sea .wave:nth-of-type(11) {
166
+ width: 102px;
167
+ bottom: 156px;
168
+ left: 23vw;
169
+ opacity: 0.2;
170
+ animation-delay: 1s;
171
+ }
172
+ .sea .wave:nth-of-type(12) {
173
+ width: 146px;
174
+ bottom: 38px;
175
+ left: 94vw;
176
+ opacity: 0.4;
177
+ animation-delay: 2s;
178
+ }
179
+ .sea .wave:nth-of-type(13) {
180
+ width: 128px;
181
+ bottom: 11px;
182
+ left: 14vw;
183
+ opacity: 0.4;
184
+ animation-delay: 3s;
185
+ }
186
+ .sea .wave:nth-of-type(14) {
187
+ width: 146px;
188
+ bottom: 43px;
189
+ left: 38vw;
190
+ opacity: 0.4;
191
+ animation-delay: 2s;
192
+ }
193
+ .sea .wave:nth-of-type(15) {
194
+ width: 123px;
195
+ bottom: 31px;
196
+ left: 40vw;
197
+ opacity: 0.1;
198
+ animation-delay: 2s;
199
+ }
200
+ .sea .wave:nth-of-type(16) {
201
+ width: 125px;
202
+ bottom: 54px;
203
+ left: 68vw;
204
+ opacity: 0.3;
205
+ animation-delay: 1s;
206
+ }
207
+ .sea .wave:nth-of-type(17) {
208
+ width: 103px;
209
+ bottom: 150px;
210
+ left: 16vw;
211
+ opacity: 0.2;
212
+ animation-delay: 2s;
213
+ }
214
+ .sea .wave:nth-of-type(18) {
215
+ width: 59px;
216
+ bottom: 49px;
217
+ left: 15vw;
218
+ opacity: 0.5;
219
+ animation-delay: 1s;
220
+ }
221
+ .sea .wave:nth-of-type(19) {
222
+ width: 89px;
223
+ bottom: 52px;
224
+ left: 94vw;
225
+ opacity: 0.5;
226
+ animation-delay: 3s;
227
+ }
228
+ .sea .wave:nth-of-type(20) {
229
+ width: 142px;
230
+ bottom: 143px;
231
+ left: 56vw;
232
+ opacity: 0.1;
233
+ animation-delay: 3s;
234
+ }
235
+ .sea .wave:nth-of-type(21) {
236
+ width: 111px;
237
+ bottom: 169px;
238
+ left: 56vw;
239
+ opacity: 0.1;
240
+ animation-delay: 2s;
241
+ }
242
+ .sea .wave:nth-of-type(22) {
243
+ width: 136px;
244
+ bottom: 163px;
245
+ left: 25vw;
246
+ opacity: 0.3;
247
+ animation-delay: 2s;
248
+ }
249
+ .sea .wave:nth-of-type(23) {
250
+ width: 139px;
251
+ bottom: 103px;
252
+ left: 31vw;
253
+ opacity: 0.2;
254
+ animation-delay: 3s;
255
+ }
256
+ .sea .wave:nth-of-type(24) {
257
+ width: 101px;
258
+ bottom: 147px;
259
+ left: 92vw;
260
+ opacity: 0.5;
261
+ animation-delay: 1s;
262
+ }
263
+ .sea .wave:nth-of-type(25) {
264
+ width: 133px;
265
+ bottom: 154px;
266
+ left: 97vw;
267
+ opacity: 0.2;
268
+ animation-delay: 3s;
269
+ }
270
+ .sea .wave:nth-of-type(26) {
271
+ width: 134px;
272
+ bottom: 107px;
273
+ left: 58vw;
274
+ opacity: 0.3;
275
+ animation-delay: 3s;
276
+ }
277
+ .sea .wave:nth-of-type(27) {
278
+ width: 144px;
279
+ bottom: 162px;
280
+ left: 29vw;
281
+ opacity: 0.1;
282
+ animation-delay: 1s;
283
+ }
284
+ .sea .wave:nth-of-type(28) {
285
+ width: 147px;
286
+ bottom: 81px;
287
+ left: 29vw;
288
+ opacity: 0.2;
289
+ animation-delay: 1s;
290
+ }
291
+ .sea .wave:nth-of-type(29) {
292
+ width: 141px;
293
+ bottom: 144px;
294
+ left: 64vw;
295
+ opacity: 0.1;
296
+ animation-delay: 1s;
297
+ }
298
+ .sea .wave:nth-of-type(30) {
299
+ width: 95px;
300
+ bottom: 13px;
301
+ left: 5vw;
302
+ opacity: 0.1;
303
+ animation-delay: 2s;
304
+ }
305
+ .boat {
306
+ width: 90px;
307
+ height: 90px;
308
+ bottom: 90px;
309
+ animation: boat 100s linear infinite;
310
+ }
311
+ .boat:after {
312
+ background-image: linear-gradient(90deg, rgba(214, 217, 246, 0.7) 30%, rgba(255, 255, 255, 0) 100%);
313
+ width: 200px;
314
+ height: 8px;
315
+ top: 105px;
316
+ left: 20px;
317
+ border-radius: 40%;
318
+ z-index: -1;
319
+ }
320
+ .boat:before {
321
+ width: 92px;
322
+ height: 50px;
323
+ left: 25px;
324
+ bottom: -70px;
325
+ background-image: linear-gradient(to bottom, rgba(41, 40, 76, 0.8) 30%, rgba(41, 40, 76, 0) 100%);
326
+ z-index: -1;
327
+ animation: boatShadow 100s linear infinite;
328
+ }
329
+ .boat .base {
330
+ width: 110px;
331
+ height: 25px;
332
+ bottom: -20px;
333
+ clip-path: polygon(0 0, 100% 0, 100% 100%, 20% 100%);
334
+ background-color: #4c4b82;
335
+ }
336
+ .boat .sail:nth-child(1) {
337
+ width: 90px;
338
+ height: 80px;
339
+ left: 5px;
340
+ clip-path: polygon(50% 0%, 0% 100%, 50% 100%);
341
+ background: linear-gradient(#b9befa 0%, #4c4b82 60%);
342
+ }
343
+ .boat .sail:nth-child(2) {
344
+ width: 80px;
345
+ height: 70px;
346
+ left: 15px;
347
+ bottom: 10px;
348
+ transform: scaleX(-1);
349
+ clip-path: polygon(50% 0%, 0% 100%, 50% 100%);
350
+ background: linear-gradient(#b9befa 0%, #4c4b82 60%);
351
+ }
352
+ .moon {
353
+ width: 80px;
354
+ height: 80px;
355
+ top: 25%;
356
+ right: 10%;
357
+ border-radius: 50%;
358
+ z-index: 2;
359
+ background-color: #d6d9f6;
360
+ box-shadow: 0 0 10px #d6d9f6, 0 0 20px #d6d9f6, 0 0 30px #d6d9f6, 0 0 40px #d6d9f6, 0 0 50px #75e2fa, 0 0 100px #d6d9f6;
361
+ }
362
+ .stars {
363
+ top: 0;
364
+ left: 0;
365
+ right: 0;
366
+ bottom: 0;
367
+ z-index: 1;
368
+ }
369
+ .stars .star {
370
+ border-radius: 50%;
371
+ background-color: #b9befa;
372
+ animation: twinkle 5s linear infinite;
373
+ }
374
+ .stars .star:nth-of-type(1) {
375
+ width: 4px;
376
+ height: 4px;
377
+ top: 66vh;
378
+ left: 86vw;
379
+ animation-delay: 4s;
380
+ }
381
+ .stars .star:nth-of-type(2) {
382
+ width: 3px;
383
+ height: 3px;
384
+ top: 41vh;
385
+ left: 47vw;
386
+ animation-delay: 1s;
387
+ }
388
+ .stars .star:nth-of-type(3) {
389
+ width: 1px;
390
+ height: 1px;
391
+ top: 58vh;
392
+ left: 66vw;
393
+ animation-delay: 5s;
394
+ }
395
+ .stars .star:nth-of-type(4) {
396
+ width: 4px;
397
+ height: 4px;
398
+ top: 78vh;
399
+ left: 3vw;
400
+ animation-delay: 3s;
401
+ }
402
+ .stars .star:nth-of-type(5) {
403
+ width: 1px;
404
+ height: 1px;
405
+ top: 54vh;
406
+ left: 3vw;
407
+ animation-delay: 5s;
408
+ }
409
+ .stars .star:nth-of-type(6) {
410
+ width: 1px;
411
+ height: 1px;
412
+ top: 100vh;
413
+ left: 38vw;
414
+ animation-delay: 4s;
415
+ }
416
+ .stars .star:nth-of-type(7) {
417
+ width: 4px;
418
+ height: 4px;
419
+ top: 48vh;
420
+ left: 43vw;
421
+ animation-delay: 5s;
422
+ }
423
+ .stars .star:nth-of-type(8) {
424
+ width: 1px;
425
+ height: 1px;
426
+ top: 66vh;
427
+ left: 45vw;
428
+ animation-delay: 3s;
429
+ }
430
+ .stars .star:nth-of-type(9) {
431
+ width: 1px;
432
+ height: 1px;
433
+ top: 79vh;
434
+ left: 89vw;
435
+ animation-delay: 4s;
436
+ }
437
+ .stars .star:nth-of-type(10) {
438
+ width: 2px;
439
+ height: 2px;
440
+ top: 77vh;
441
+ left: 87vw;
442
+ animation-delay: 4s;
443
+ }
444
+ .stars .star:nth-of-type(11) {
445
+ width: 1px;
446
+ height: 1px;
447
+ top: 63vh;
448
+ left: 92vw;
449
+ animation-delay: 1s;
450
+ }
451
+ .stars .star:nth-of-type(12) {
452
+ width: 2px;
453
+ height: 2px;
454
+ top: 26vh;
455
+ left: 92vw;
456
+ animation-delay: 1s;
457
+ }
458
+ .stars .star:nth-of-type(13) {
459
+ width: 3px;
460
+ height: 3px;
461
+ top: 22vh;
462
+ left: 40vw;
463
+ animation-delay: 3s;
464
+ }
465
+ .stars .star:nth-of-type(14) {
466
+ width: 4px;
467
+ height: 4px;
468
+ top: 80vh;
469
+ left: 95vw;
470
+ animation-delay: 3s;
471
+ }
472
+ .stars .star:nth-of-type(15) {
473
+ width: 2px;
474
+ height: 2px;
475
+ top: 60vh;
476
+ left: 35vw;
477
+ animation-delay: 4s;
478
+ }
479
+ .stars .star:nth-of-type(16) {
480
+ width: 4px;
481
+ height: 4px;
482
+ top: 17vh;
483
+ left: 12vw;
484
+ animation-delay: 2s;
485
+ }
486
+ .stars .star:nth-of-type(17) {
487
+ width: 3px;
488
+ height: 3px;
489
+ top: 54vh;
490
+ left: 18vw;
491
+ animation-delay: 5s;
492
+ }
493
+ .stars .star:nth-of-type(18) {
494
+ width: 1px;
495
+ height: 1px;
496
+ top: 96vh;
497
+ left: 18vw;
498
+ animation-delay: 4s;
499
+ }
500
+ .stars .star:nth-of-type(19) {
501
+ width: 3px;
502
+ height: 3px;
503
+ top: 65vh;
504
+ left: 75vw;
505
+ animation-delay: 4s;
506
+ }
507
+ .stars .star:nth-of-type(20) {
508
+ width: 2px;
509
+ height: 2px;
510
+ top: 29vh;
511
+ left: 76vw;
512
+ animation-delay: 1s;
513
+ }
514
+ .stars .star:nth-of-type(21) {
515
+ width: 4px;
516
+ height: 4px;
517
+ top: 87vh;
518
+ left: 30vw;
519
+ animation-delay: 3s;
520
+ }
521
+ .stars .star:nth-of-type(22) {
522
+ width: 3px;
523
+ height: 3px;
524
+ top: 5vh;
525
+ left: 8vw;
526
+ animation-delay: 3s;
527
+ }
528
+ .stars .star:nth-of-type(23) {
529
+ width: 3px;
530
+ height: 3px;
531
+ top: 49vh;
532
+ left: 3vw;
533
+ animation-delay: 2s;
534
+ }
535
+ .stars .star:nth-of-type(24) {
536
+ width: 4px;
537
+ height: 4px;
538
+ top: 62vh;
539
+ left: 77vw;
540
+ animation-delay: 1s;
541
+ }
542
+ .stars .star:nth-of-type(25) {
543
+ width: 1px;
544
+ height: 1px;
545
+ top: 69vh;
546
+ left: 28vw;
547
+ animation-delay: 1s;
548
+ }
549
+ .stars .star:nth-of-type(26) {
550
+ width: 1px;
551
+ height: 1px;
552
+ top: 8vh;
553
+ left: 68vw;
554
+ animation-delay: 1s;
555
+ }
556
+ .stars .star:nth-of-type(27) {
557
+ width: 4px;
558
+ height: 4px;
559
+ top: 13vh;
560
+ left: 26vw;
561
+ animation-delay: 2s;
562
+ }
563
+ .stars .star:nth-of-type(28) {
564
+ width: 2px;
565
+ height: 2px;
566
+ top: 75vh;
567
+ left: 54vw;
568
+ animation-delay: 4s;
569
+ }
570
+ .stars .star:nth-of-type(29) {
571
+ width: 4px;
572
+ height: 4px;
573
+ top: 41vh;
574
+ left: 69vw;
575
+ animation-delay: 4s;
576
+ }
577
+ .stars .star:nth-of-type(30) {
578
+ width: 3px;
579
+ height: 3px;
580
+ top: 29vh;
581
+ left: 76vw;
582
+ animation-delay: 4s;
583
+ }
584
+ .stars .star:nth-of-type(31) {
585
+ width: 4px;
586
+ height: 4px;
587
+ top: 27vh;
588
+ left: 37vw;
589
+ animation-delay: 1s;
590
+ }
591
+ .stars .star:nth-of-type(32) {
592
+ width: 2px;
593
+ height: 2px;
594
+ top: 86vh;
595
+ left: 92vw;
596
+ animation-delay: 5s;
597
+ }
598
+ .stars .star:nth-of-type(33) {
599
+ width: 2px;
600
+ height: 2px;
601
+ top: 6vh;
602
+ left: 16vw;
603
+ animation-delay: 5s;
604
+ }
605
+ .stars .star:nth-of-type(34) {
606
+ width: 1px;
607
+ height: 1px;
608
+ top: 45vh;
609
+ left: 47vw;
610
+ animation-delay: 2s;
611
+ }
612
+ .stars .star:nth-of-type(35) {
613
+ width: 4px;
614
+ height: 4px;
615
+ top: 94vh;
616
+ left: 97vw;
617
+ animation-delay: 3s;
618
+ }
619
+ .stars .star:nth-of-type(36) {
620
+ width: 4px;
621
+ height: 4px;
622
+ top: 56vh;
623
+ left: 75vw;
624
+ animation-delay: 1s;
625
+ }
626
+ .stars .star:nth-of-type(37) {
627
+ width: 2px;
628
+ height: 2px;
629
+ top: 35vh;
630
+ left: 32vw;
631
+ animation-delay: 3s;
632
+ }
633
+ .stars .star:nth-of-type(38) {
634
+ width: 4px;
635
+ height: 4px;
636
+ top: 25vh;
637
+ left: 27vw;
638
+ animation-delay: 3s;
639
+ }
640
+ .stars .star:nth-of-type(39) {
641
+ width: 3px;
642
+ height: 3px;
643
+ top: 69vh;
644
+ left: 10vw;
645
+ animation-delay: 1s;
646
+ }
647
+ .stars .star:nth-of-type(40) {
648
+ width: 2px;
649
+ height: 2px;
650
+ top: 42vh;
651
+ left: 16vw;
652
+ animation-delay: 3s;
653
+ }
654
+ .stars .star:nth-of-type(41) {
655
+ width: 2px;
656
+ height: 2px;
657
+ top: 30vh;
658
+ left: 22vw;
659
+ animation-delay: 5s;
660
+ }
661
+ .stars .star:nth-of-type(42) {
662
+ width: 4px;
663
+ height: 4px;
664
+ top: 44vh;
665
+ left: 93vw;
666
+ animation-delay: 5s;
667
+ }
668
+ .stars .star:nth-of-type(43) {
669
+ width: 1px;
670
+ height: 1px;
671
+ top: 32vh;
672
+ left: 15vw;
673
+ animation-delay: 3s;
674
+ }
675
+ .stars .star:nth-of-type(44) {
676
+ width: 4px;
677
+ height: 4px;
678
+ top: 4vh;
679
+ left: 15vw;
680
+ animation-delay: 4s;
681
+ }
682
+ .stars .star:nth-of-type(45) {
683
+ width: 2px;
684
+ height: 2px;
685
+ top: 42vh;
686
+ left: 24vw;
687
+ animation-delay: 3s;
688
+ }
689
+ .stars .star:nth-of-type(46) {
690
+ width: 1px;
691
+ height: 1px;
692
+ top: 38vh;
693
+ left: 30vw;
694
+ animation-delay: 4s;
695
+ }
696
+ .stars .star:nth-of-type(47) {
697
+ width: 2px;
698
+ height: 2px;
699
+ top: 33vh;
700
+ left: 87vw;
701
+ animation-delay: 2s;
702
+ }
703
+ .stars .star:nth-of-type(48) {
704
+ width: 3px;
705
+ height: 3px;
706
+ top: 52vh;
707
+ left: 43vw;
708
+ animation-delay: 2s;
709
+ }
710
+ .stars .star:nth-of-type(49) {
711
+ width: 4px;
712
+ height: 4px;
713
+ top: 55vh;
714
+ left: 1vw;
715
+ animation-delay: 4s;
716
+ }
717
+ .stars .star:nth-of-type(50) {
718
+ width: 4px;
719
+ height: 4px;
720
+ top: 8vh;
721
+ left: 49vw;
722
+ animation-delay: 1s;
723
+ }
724
+ .stars .star:nth-of-type(51) {
725
+ width: 3px;
726
+ height: 3px;
727
+ top: 34vh;
728
+ left: 81vw;
729
+ animation-delay: 4s;
730
+ }
731
+ .stars .star:nth-of-type(52) {
732
+ width: 4px;
733
+ height: 4px;
734
+ top: 3vh;
735
+ left: 37vw;
736
+ animation-delay: 2s;
737
+ }
738
+ .stars .star:nth-of-type(53) {
739
+ width: 4px;
740
+ height: 4px;
741
+ top: 84vh;
742
+ left: 99vw;
743
+ animation-delay: 1s;
744
+ }
745
+ .stars .star:nth-of-type(54) {
746
+ width: 1px;
747
+ height: 1px;
748
+ top: 63vh;
749
+ left: 52vw;
750
+ animation-delay: 2s;
751
+ }
752
+ .stars .star:nth-of-type(55) {
753
+ width: 3px;
754
+ height: 3px;
755
+ top: 92vh;
756
+ left: 26vw;
757
+ animation-delay: 3s;
758
+ }
759
+ .stars .star:nth-of-type(56) {
760
+ width: 3px;
761
+ height: 3px;
762
+ top: 83vh;
763
+ left: 42vw;
764
+ animation-delay: 3s;
765
+ }
766
+ .stars .star:nth-of-type(57) {
767
+ width: 4px;
768
+ height: 4px;
769
+ top: 49vh;
770
+ left: 7vw;
771
+ animation-delay: 5s;
772
+ }
773
+ .stars .star:nth-of-type(58) {
774
+ width: 1px;
775
+ height: 1px;
776
+ top: 29vh;
777
+ left: 52vw;
778
+ animation-delay: 3s;
779
+ }
780
+ .stars .star:nth-of-type(59) {
781
+ width: 1px;
782
+ height: 1px;
783
+ top: 59vh;
784
+ left: 9vw;
785
+ animation-delay: 5s;
786
+ }
787
+ .stars .star:nth-of-type(60) {
788
+ width: 1px;
789
+ height: 1px;
790
+ top: 72vh;
791
+ left: 64vw;
792
+ animation-delay: 2s;
793
+ }
794
+ .lighthouse-group {
795
+ width: 50%;
796
+ height: 100%;
797
+ bottom: 0;
798
+ left: 0;
799
+ z-index: 2;
800
+ }
801
+ .land {
802
+ width: 400px;
803
+ height: 60px;
804
+ left: -30px;
805
+ bottom: 0;
806
+ background-image: linear-gradient(to top, #29284c 80%, #717ae1 100%);
807
+ transform: skewX(35deg);
808
+ border-radius: 10px;
809
+ }
810
+ .lighthouse-holder {
811
+ width: 100px;
812
+ height: 480px;
813
+ bottom: 80px;
814
+ left: 180px;
815
+ }
816
+ .lighthouse-holder .shadow {
817
+ width: 117px;
818
+ height: 50px;
819
+ left: -32px;
820
+ bottom: -70px;
821
+ background: #29284c;
822
+ transform: skewX(-45deg);
823
+ }
824
+ .lighthouse-holder .lighthouse {
825
+ width: 100%;
826
+ height: 100%;
827
+ transform-style: preserve-3d;
828
+ transform: perspective(600px) rotateX(20deg);
829
+ background-color: #d6d9f6;
830
+ background-image: repeating-linear-gradient(-40deg, transparent, transparent 60px, #4c4b82 60px, #4c4b82 120px);
831
+ }
832
+ .lighthouse-holder .lighthouse:after {
833
+ width: 100%;
834
+ height: 100%;
835
+ background-image: linear-gradient(90deg, rgba(214, 217, 246, 0.6) 0%, #29284c 8%, transparent 70%, rgba(214, 217, 246, 0.4) 100%);
836
+ }
837
+ .lighthouse-holder .top {
838
+ width: 94px;
839
+ height: 60px;
840
+ left: 3px;
841
+ top: -15px;
842
+ }
843
+ .lighthouse-holder .top .light-container {
844
+ height: 40px;
845
+ min-width: 300px;
846
+ width: 35vw;
847
+ bottom: 4px;
848
+ left: 40px;
849
+ transform-style: preserve-3d;
850
+ transform-origin: left bottom;
851
+ transform: perspective(500px) rotateY(0);
852
+ animation: lightRotate 20s linear infinite;
853
+ }
854
+ .lighthouse-holder .top .light-container .light {
855
+ width: 100%;
856
+ height: 100%;
857
+ transform-style: preserve-3d;
858
+ transform-origin: left center;
859
+ transform: perspective(500px) rotateY(-35deg);
860
+ background: linear-gradient(90deg, #f7f2b4 40%, rgba(255, 255, 255, 0) 100%);
861
+ }
862
+ .lighthouse-holder .top .rail {
863
+ width: 100%;
864
+ height: 17px;
865
+ bottom: 1px;
866
+ border: 3px solid #29284c;
867
+ border-radius: 1px;
868
+ transform: perspective(1000px) rotateX(-35deg);
869
+ background-image: repeating-linear-gradient(90deg, #29284c, #29284c 3px, #9e9ebe 3px, #f7f2b4 10px);
870
+ background-position: -2px 0;
871
+ }
872
+ .lighthouse-holder .top .middle {
873
+ width: 88px;
874
+ height: 35px;
875
+ left: 3px;
876
+ bottom: 14px;
877
+ border: 2px solid #29284c;
878
+ border-radius: 3px;
879
+ background-image: repeating-linear-gradient(90deg, #29284c, #29284c 4px, #9e9ebe 4px, rgba(255, 255, 255, 0) 21px);
880
+ background-position: -2px 0;
881
+ }
882
+ .lighthouse-holder .top .middle:before {
883
+ width: 100%;
884
+ height: 100%;
885
+ z-index: -1;
886
+ background-color: #f7f2b4;
887
+ box-shadow: 0 0 10px #d6d9f6, 0 0 20px #f7f2b4, 0 0 30px #f7f2b4, 0 0 40px #f7f2b4, 0 0 70px #f7f2b4;
888
+ }
889
+ .lighthouse-holder .top .roof {
890
+ width: 0;
891
+ height: 0;
892
+ bottom: 45px;
893
+ left: -3px;
894
+ border-left: 50px solid rgba(255, 255, 255, 0);
895
+ border-right: 50px solid rgba(255, 255, 255, 0);
896
+ border-bottom: 40px solid #29284c;
897
+ }
898
+ .lighthouse-holder .top .roof:before {
899
+ width: 14px;
900
+ height: 14px;
901
+ bottom: -7px;
902
+ left: -7px;
903
+ background-color: #29284c;
904
+ border-radius: 50%;
905
+ }
906
+ .lighthouse-holder .top .roof:after {
907
+ width: 4px;
908
+ height: 14px;
909
+ left: -2px;
910
+ bottom: 5px;
911
+ background-color: #29284c;
912
+ border-radius: 3px;
913
+ }
914
+ .lighthouse-holder .top .roof .roof-light {
915
+ width: 100px;
916
+ height: 40px;
917
+ left: -50px;
918
+ clip-path: polygon(50% 0, 0% 100%, 100% 100%);
919
+ background-image: linear-gradient(135deg, #29284c 40%, rgba(247, 242, 180, 0.5) 100%);
920
+ }
921
+ .lighthouse-holder .top .glow {
922
+ width: 100px;
923
+ height: 60px;
924
+ top: 0;
925
+ left: 0;
926
+ opacity: 0;
927
+ border-radius: 50%;
928
+ background-color: #f7f2b4;
929
+ box-shadow: 0 0 10px #f7f2b4, 0 0 20px #f7f2b4, 0 0 30px #f7f2b4, 0 0 40px #f7f2b4, 0 0 50px #f7f2b4, 0 0 60px #f7f2b4, 0 0 70px #f7f2b4, 0 0 80px #f7f2b4;
930
+ animation: lightGlow 20s linear infinite;
931
+ }
932
+ .lighthouse-holder .windows {
933
+ height: 100%;
934
+ width: 100%;
935
+ }
936
+ .lighthouse-holder .windows .window {
937
+ width: 15px;
938
+ height: 25px;
939
+ left: 43px;
940
+ background-color: #29284c;
941
+ border-bottom: 2px solid rgba(185, 190, 250, 0.7);
942
+ border-radius: 25px 25px 0 0;
943
+ }
944
+ .lighthouse-holder .windows .window:nth-of-type(1) {
945
+ bottom: 90px;
946
+ }
947
+ .lighthouse-holder .windows .window:nth-of-type(2) {
948
+ bottom: 180px;
949
+ }
950
+ .lighthouse-holder .windows .window:nth-of-type(3) {
951
+ bottom: 270px;
952
+ }
953
+ .lighthouse-holder .windows .window:nth-of-type(4) {
954
+ bottom: 360px;
955
+ }
956
+ .lighthouse-holder .door {
957
+ width: 25px;
958
+ height: 40px;
959
+ background-color: #29284c;
960
+ left: 38px;
961
+ bottom: -2px;
962
+ border-radius: 2px 2px 0 0;
963
+ }
964
+ .lighthouse-holder .door .stairs {
965
+ width: 27px;
966
+ height: 28px;
967
+ top: 34px;
968
+ left: -1px;
969
+ background-color: #29284c;
970
+ transform: perspective(100px) rotateX(45deg);
971
+ background-image: repeating-linear-gradient(to bottom, #29284c, #29284c 4px, #b9befa 4px, rgba(255, 255, 255, 0.1) 5px);
972
+ }
973
+ @keyframes twinkle {
974
+ 50% {
975
+ opacity: 0.3;
976
+ }
977
+ }
978
+ @keyframes wave {
979
+ 50% {
980
+ transform: translateX(-10px);
981
+ }
982
+ }
983
+ @keyframes lightRotate {
984
+ 25% {
985
+ transform: perspective(500px) rotateY(35deg);
986
+ }
987
+ 75% {
988
+ transform: perspective(500px) rotateY(-35deg);
989
+ }
990
+ }
991
+ @keyframes lightGlow {
992
+ 50% {
993
+ opacity: 0;
994
+ }
995
+ 75% {
996
+ opacity: 1;
997
+ }
998
+ }
999
+ @keyframes boat {
1000
+ 0% {
1001
+ transform: translateX(120vw) scale(0.8);
1002
+ }
1003
+ 80%, 100% {
1004
+ transform: translateX(-25vw) scale(0.8);
1005
+ }
1006
+ }
1007
+ @keyframes boatShadow {
1008
+ 0% {
1009
+ transform: skewX(35deg) translateX(15px);
1010
+ }
1011
+ 50%, 100% {
1012
+ transform: skewX(-55deg) translateX(-40px);
1013
+ }
1014
+ }
1015
+
1016
+ </style>
1017
+ </head>
1018
+ <body>
1019
+
1020
+ <div class="scene">
1021
+ <div class="background">
1022
+ <div class="stars">
1023
+ <div class="star"></div>
1024
+ <div class="star"></div>
1025
+ <div class="star"></div>
1026
+ <div class="star"></div>
1027
+ <div class="star"></div>
1028
+ <div class="star"></div>
1029
+ <div class="star"></div>
1030
+ <div class="star"></div>
1031
+ <div class="star"></div>
1032
+ <div class="star"></div>
1033
+ <div class="star"></div>
1034
+ <div class="star"></div>
1035
+ <div class="star"></div>
1036
+ <div class="star"></div>
1037
+ <div class="star"></div>
1038
+ <div class="star"></div>
1039
+ <div class="star"></div>
1040
+ <div class="star"></div>
1041
+ <div class="star"></div>
1042
+ <div class="star"></div>
1043
+ <div class="star"></div>
1044
+ <div class="star"></div>
1045
+ <div class="star"></div>
1046
+ <div class="star"></div>
1047
+ <div class="star"></div>
1048
+ <div class="star"></div>
1049
+ <div class="star"></div>
1050
+ <div class="star"></div>
1051
+ <div class="star"></div>
1052
+ <div class="star"></div>
1053
+ <div class="star"></div>
1054
+ <div class="star"></div>
1055
+ <div class="star"></div>
1056
+ <div class="star"></div>
1057
+ <div class="star"></div>
1058
+ <div class="star"></div>
1059
+ <div class="star"></div>
1060
+ <div class="star"></div>
1061
+ <div class="star"></div>
1062
+ <div class="star"></div>
1063
+ <div class="star"></div>
1064
+ <div class="star"></div>
1065
+ <div class="star"></div>
1066
+ <div class="star"></div>
1067
+ <div class="star"></div>
1068
+ <div class="star"></div>
1069
+ <div class="star"></div>
1070
+ <div class="star"></div>
1071
+ <div class="star"></div>
1072
+ <div class="star"></div>
1073
+ <div class="star"></div>
1074
+ <div class="star"></div>
1075
+ <div class="star"></div>
1076
+ <div class="star"></div>
1077
+ <div class="star"></div>
1078
+ <div class="star"></div>
1079
+ <div class="star"></div>
1080
+ <div class="star"></div>
1081
+ <div class="star"></div>
1082
+ <div class="star"></div>
1083
+ </div>
1084
+ <div class="moon"></div>
1085
+ <div class="mountains">
1086
+ <div class="mountain"></div>
1087
+ <div class="mountain"></div>
1088
+ <div class="mountain"></div>
1089
+ <div class="mountain"></div>
1090
+ </div>
1091
+ <div class="sea">
1092
+ <div class="wave"></div>
1093
+ <div class="wave"></div>
1094
+ <div class="wave"></div>
1095
+ <div class="wave"></div>
1096
+ <div class="wave"></div>
1097
+ <div class="wave"></div>
1098
+ <div class="wave"></div>
1099
+ <div class="wave"></div>
1100
+ <div class="wave"></div>
1101
+ <div class="wave"></div>
1102
+ <div class="wave"></div>
1103
+ <div class="wave"></div>
1104
+ <div class="wave"></div>
1105
+ <div class="wave"></div>
1106
+ <div class="wave"></div>
1107
+ <div class="wave"></div>
1108
+ <div class="wave"></div>
1109
+ <div class="wave"></div>
1110
+ <div class="wave"></div>
1111
+ <div class="wave"></div>
1112
+ <div class="wave"></div>
1113
+ <div class="wave"></div>
1114
+ <div class="wave"></div>
1115
+ <div class="wave"></div>
1116
+ <div class="wave"></div>
1117
+ <div class="wave"></div>
1118
+ <div class="wave"></div>
1119
+ <div class="wave"></div>
1120
+ <div class="wave"></div>
1121
+ <div class="wave"></div>
1122
+ <div class="boat">
1123
+ <div class="sail"></div>
1124
+ <div class="sail"></div>
1125
+ <div class="base"></div>
1126
+ </div>
1127
+ </div>
1128
+ </div>
1129
+ <div class="lighthouse-group">
1130
+ <div class="land"></div>
1131
+ <div class="lighthouse-holder">
1132
+ <div class="shadow"></div>
1133
+ <div class="lighthouse"></div>
1134
+ <div class="top">
1135
+ <div class="light-container">
1136
+ <div class="light"></div>
1137
+ </div>
1138
+ <div class="rail"></div>
1139
+ <div class="middle"></div>
1140
+ <div class="roof">
1141
+ <div class="roof-light"></div>
1142
+ </div>
1143
+ <div class="glow"></div>
1144
+ </div>
1145
+ <div class="windows">
1146
+ <div style="margin-left: 7em; width: 700px; font-weight:bold;">
1147
+ CSS on the spotlight. \o/ (Remove this if you'd like to.)
1148
+ </div>
1149
+ <div class="window"></div>
1150
+ <div class="window"></div>
1151
+ <div class="window"></div>
1152
+ <div class="window"></div>
1153
+ </div>
1154
+ <div class="door">
1155
+ <div class="stairs"></div>
1156
+ </div>
1157
+ </div>
1158
+ </div>
1159
+ </div>
1160
+ </body>
1161
+ </html>