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
@@ -3,13 +3,13 @@
3
3
  <style>
4
4
  .newspaper
5
5
  {
6
- column-width: 300px;
6
+ column-width: 250px;
7
7
  }
8
8
  </style>
9
9
  </head>
10
10
  <body>
11
11
 
12
- <h5>Testing Column Width</h5>
12
+ <h5>Testing Column Width of 250px</h5>
13
13
  <div class="newspaper">
14
14
  Lorem ipsum dolor sit amet, consectetuer adipiscing elit,
15
15
  sed diam nonummy nibh euismod tincidunt ut laoreet dolore
@@ -1,14 +1,17 @@
1
1
  <html>
2
2
  <title>Custom Cursor Example</title>
3
+
4
+ <link href="../../lib/cyberweb/cascading_style_sheets/cursors.css" rel="stylesheet" type="text/css" />
5
+
3
6
  <style>
4
7
  body {
5
8
  margin: 0;
6
- padding: 1em;
9
+ padding: 0.75em;
7
10
  height: 100vh;
8
11
  cursor: cell;
9
12
  }
10
13
  div {
11
- padding: 2em;
14
+ padding: 0.75em;
12
15
  }
13
16
 
14
17
  .custom_cursor {
@@ -94,10 +97,10 @@ div {
94
97
  <div class="sw-resize">sw-resize</div>
95
98
  <div class="nesw-resize">nesw-resize</div>
96
99
  <div class="nwse-resize">nwse-resize</div>
97
- </div>
98
-
99
-
100
100
 
101
+ <div class="cursor_happy">happy</div>
102
+ <div class="cursor_sad">sad</div>
103
+ </div>
101
104
 
102
105
  </body>
103
106
  </html>
@@ -0,0 +1,2 @@
1
+ The html file in this directory will show the logo of the
2
+ cyberweb project.
@@ -0,0 +1,11 @@
1
+ <html>
2
+ <head>
3
+ <title>Cyberweb Logo</title>
4
+ </head>
5
+ <body>
6
+ <h2>Next showing the cyberweb logo</h2>
7
+
8
+ <img src="data:image/png;base64,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">
9
+
10
+ </body>
11
+ </html>
@@ -1,6 +1,5 @@
1
1
  <html>
2
-
3
- <title>Draggable paragraph</title>
2
+ <title>Showcase a draggable paragraph</title>
4
3
 
5
4
  <body>
6
5
 
@@ -0,0 +1,175 @@
1
+ <html>
2
+
3
+ <head>
4
+
5
+ <style>
6
+ body {
7
+ background: #323641;
8
+ }
9
+ .email_letter_image {
10
+ position: absolute;
11
+ top: 50%;
12
+ left: 50%;
13
+ width: 200px;
14
+ height: 200px;
15
+ transform: translate(-50%, -50%);
16
+ cursor: pointer;
17
+ }
18
+ .email_animated_mail {
19
+ position: absolute;
20
+ height: 150px;
21
+ width: 200px;
22
+ transition: 0.4s;
23
+ }
24
+ .email_animated_mail .email_body {
25
+ position: absolute;
26
+ bottom: 0;
27
+ width: 0;
28
+ height: 0;
29
+ border-style: solid;
30
+ border-width: 0 0 100px 200px;
31
+ border-color: transparent transparent #e95f55 transparent;
32
+ z-index: 2;
33
+ }
34
+ .email_animated_mail .email_top_fold {
35
+ position: absolute;
36
+ top: 50px;
37
+ width: 0;
38
+ height: 0;
39
+ border-style: solid;
40
+ border-width: 50px 100px 0 100px;
41
+ -webkit-transform-origin: 50% 0%;
42
+ -webkit-transition: transform 0.4s 0.4s, z-index 0.2s 0.4s;
43
+ -moz-transform-origin: 50% 0%;
44
+ -moz-transition: transform 0.4s 0.4s, z-index 0.2s 0.4s;
45
+ transform-origin: 50% 0%;
46
+ transition: transform 0.4s 0.4s, z-index 0.2s 0.4s;
47
+ border-color: #cf4a43 transparent transparent transparent;
48
+ z-index: 2;
49
+ }
50
+ .email_animated_mail .email_back_fold {
51
+ position: absolute;
52
+ bottom: 0;
53
+ width: 200px;
54
+ height: 100px;
55
+ background: #cf4a43;
56
+ z-index: 0;
57
+ }
58
+ .email_animated_mail .left-fold {
59
+ position: absolute;
60
+ bottom: 0;
61
+ width: 0;
62
+ height: 0;
63
+ border-style: solid;
64
+ border-width: 50px 0 50px 100px;
65
+ border-color: transparent transparent transparent #e15349;
66
+ z-index: 2;
67
+ }
68
+ .email_animated_mail .letter {
69
+ left: 20px;
70
+ bottom: 0px;
71
+ position: absolute;
72
+ width: 160px;
73
+ height: 60px;
74
+ background: white;
75
+ z-index: 1;
76
+ overflow: hidden;
77
+ transition: 0.4s 0.2s;
78
+ }
79
+ .email_animated_mail .letter .email_letter_border {
80
+ height: 10px;
81
+ width: 100%;
82
+ background: repeating-linear-gradient(-45deg, #cb5a5e, #cb5a5e 8px, transparent 8px, transparent 18px);
83
+ }
84
+ .email_animated_mail .letter .email_letter_title {
85
+ margin-top: 10px;
86
+ margin-left: 5px;
87
+ height: 10px;
88
+ width: 40%;
89
+ background: #cb5a5e;
90
+ }
91
+ .email_animated_mail .letter .letter-context {
92
+ margin-top: 10px;
93
+ margin-left: 5px;
94
+ height: 10px;
95
+ width: 20%;
96
+ background: #cb5a5e;
97
+ }
98
+ .email_animated_mail .letter .letter-stamp {
99
+ margin-top: 30px;
100
+ margin-left: 120px;
101
+ border-radius: 100%;
102
+ height: 30px;
103
+ width: 30px;
104
+ background: #cb5a5e;
105
+ opacity: 0.3;
106
+ }
107
+
108
+ .email_shadow {
109
+ position: absolute;
110
+ top: 200px;
111
+ left: 50%;
112
+ width: 400px;
113
+ height: 30px;
114
+ transition: 0.4s;
115
+ transform: translateX(-50%);
116
+ -webkit-transition: 0.4s;
117
+ -webkit-transform: translateX(-50%);
118
+ -moz-transition: 0.4s;
119
+ -moz-transform: translateX(-50%);
120
+ border-radius: 100%;
121
+ background: radial-gradient(rgba(0, 0, 0, 0.5), rgba(0, 0, 0, 0.0), rgba(0, 0, 0, 0.0));
122
+ }
123
+ .email_letter_image:hover .email_animated_mail {
124
+ transform: translateY(50px);
125
+ -webkit-transform: translateY(50px);
126
+ -moz-transform: translateY(50px);
127
+ }
128
+ .email_letter_image:hover .email_animated_mail .email_top_fold {
129
+ transition: transform 0.4s, z-index 0.2s;
130
+ transform: rotateX(180deg);
131
+ -webkit-transition: transform 0.4s, z-index 0.2s;
132
+ -webkit-transform: rotateX(180deg);
133
+ -moz-transition: transform 0.4s, z-index 0.2s;
134
+ -moz-transform: rotateX(180deg);
135
+ z-index: 0;
136
+ }
137
+
138
+ /*
139
+ * This indicates how much the email shall move
140
+ * upwards.
141
+ */
142
+ .email_letter_image:hover .email_animated_mail .letter {
143
+ height: 170px;
144
+ }
145
+
146
+ /*
147
+ * The next CSS rule will expand the bottom-shadow of the email.
148
+ */
149
+ .email_letter_image:hover .email_shadow {
150
+ width: 600px;
151
+ }
152
+
153
+ </style>
154
+ </head>
155
+ <body>
156
+
157
+ <div class="email_letter_image">
158
+ <div class="email_animated_mail">
159
+ <div class="email_back_fold"></div>
160
+ <div class="letter">
161
+ <div class="email_letter_border"></div>
162
+ <div class="email_letter_title"></div>
163
+ <div class="letter-context"></div>
164
+ <div class="letter-stamp">
165
+ <div class="letter-stamp-inner"></div>
166
+ </div>
167
+ </div>
168
+ <div class="email_top_fold"></div>
169
+ <div class="email_body"></div>
170
+ <div class="left-fold"></div>
171
+ </div>
172
+ <div class="email_shadow"></div>
173
+ </div>
174
+ </body>
175
+ </html>
@@ -7,7 +7,9 @@
7
7
 
8
8
  <form action="/foo.html" method="get">
9
9
  <fieldset>
10
- <legend style="font-size: larger; font-weight: bold">Personalia:</legend>
10
+ <legend style="font-size: larger; font-weight: bold">
11
+ Personalia - this is within the fieldset:
12
+ </legend>
11
13
  <label for="fname">First name:</label>
12
14
  <input type="text" id="fname" name="fname"><br><br>
13
15
  <label for="lname">Last name:</label>
@@ -0,0 +1 @@
1
+ This directory may contain some font-specific tests.
@@ -0,0 +1,19 @@
1
+ <html>
2
+ <head>
3
+ </head>
4
+
5
+ <style>
6
+
7
+ body {
8
+ font-family: URW Chancery L, cursive;
9
+ font-size: 25px;
10
+ }
11
+ </style>
12
+ <body>
13
+
14
+ <h1>
15
+ Hello world!
16
+ </h1>
17
+
18
+ </body>
19
+ </html>
@@ -0,0 +1,19 @@
1
+ <html>
2
+ <head>
3
+ </head>
4
+
5
+ <style>
6
+
7
+ body {
8
+ font-family: fantasy;
9
+ font-size: 25px;
10
+ }
11
+ </style>
12
+ <body>
13
+
14
+ <h1>
15
+ Hello world!
16
+ </h1>
17
+
18
+ </body>
19
+ </html>
@@ -0,0 +1,19 @@
1
+ <html>
2
+ <head>
3
+ </head>
4
+
5
+ <style>
6
+
7
+ body {
8
+ font-family: “Times New Roman”, Georgia, Serif;;
9
+ font-size: 25px;
10
+ }
11
+ </style>
12
+ <body>
13
+
14
+ <h1>
15
+ Hello world!
16
+ </h1>
17
+
18
+ </body>
19
+ </html>
@@ -0,0 +1,85 @@
1
+ <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
2
+ <html lang="en">
3
+ <head>
4
+ <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
5
+ <title>Font Size Example</title>
6
+
7
+ <style>
8
+
9
+ .fs10 {
10
+ font-family: arial, helvetica, sans-serif; font-size: 10px;
11
+ }
12
+
13
+ .fs11 {
14
+ font-family: arial, helvetica, sans-serif; font-size: 11px;
15
+ }
16
+
17
+ .fs12 {
18
+ font-family: arial, helvetica, sans-serif; font-size: 12px;
19
+ }
20
+
21
+ .fs13 {
22
+ font-family: arial, helvetica, sans-serif; font-size: 13px;
23
+ }
24
+
25
+ .fs14 {
26
+ font-family: arial, helvetica, sans-serif; font-size: 14px;
27
+ }
28
+
29
+ .fs15 {
30
+ font-family: arial, helvetica, sans-serif; font-size: 15px;
31
+ }
32
+
33
+ .fs16 {
34
+ font-family: arial, helvetica, sans-serif; font-size: 16px;
35
+ }
36
+
37
+ .fs17 {
38
+ font-family: arial, helvetica, sans-serif; font-size: 17px;
39
+ }
40
+
41
+ .fs18 {
42
+ font-family: arial, helvetica, sans-serif; font-size: 18px;
43
+ }
44
+
45
+ .fs19 {
46
+ font-family: arial, helvetica, sans-serif; font-size: 19px;
47
+ }
48
+
49
+ .fs20 {
50
+ font-family: arial, helvetica, sans-serif; font-size: 20px;
51
+ }
52
+
53
+ .raw_fs30 {
54
+ font-size: 30px;
55
+ }
56
+
57
+ .raw_fs40 {
58
+ font-size: 40px;
59
+ }
60
+
61
+ .raw_fs50 {
62
+ font-size: 50px;
63
+ }
64
+ </style>
65
+ </head>
66
+ <body style="margin: 2em; text-align: center">
67
+
68
+ <span class="fs10">font-size: 10px</span><br>
69
+ <span class="fs11">font-size: 11px</span><br>
70
+ <span class="fs12">font-size: 12px</span><br>
71
+ <span class="fs13">font-size: 13px</span><br>
72
+ <span class="fs14">font-size: 14px</span><br>
73
+ <span class="fs15">font-size: 15px</span><br>
74
+ <span class="fs16">font-size: 16px</span><br>
75
+ <span class="fs17">font-size: 17px</span><br>
76
+ <span class="fs18">font-size: 18px</span><br>
77
+ <span class="fs19">font-size: 19px</span><br>
78
+ <span class="fs20">font-size: 20px</span><br>
79
+ <span class="raw_fs30">font-size: 30px</span><br>
80
+ <span class="raw_fs40">font-size: 40px</span><br>
81
+ <span class="raw_fs50">font-size: 50px</span><br>
82
+
83
+ </body>
84
+
85
+ </html>
@@ -33,7 +33,6 @@
33
33
  </head>
34
34
  <body>
35
35
 
36
-
37
36
  <div id="chart">
38
37
  <div id="chart-shape">⬠</div>
39
38
  <div id="chart-value"></div>
@@ -0,0 +1,15 @@
1
+ <html>
2
+
3
+ <head>
4
+ <style>
5
+ .grayscale {
6
+ -webkit-filter: grayscale(1);
7
+ filter: grayscale(1);
8
+ }
9
+ </style>
10
+
11
+ </head>
12
+ <body>
13
+ <img src="../../../images/cyberweb_theme.png" class="grayscale">
14
+ </body>
15
+ </html>
@@ -0,0 +1,61 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <head>
4
+ <title>HTML Links Example</title>
5
+
6
+ <style>
7
+ p {
8
+ font-size: 1.5em;
9
+ }
10
+
11
+ a {
12
+ outline: none;
13
+ text-decoration: none;
14
+ padding: 2px 1px 0;
15
+ }
16
+
17
+ a:link {
18
+ color: #265301;
19
+ }
20
+
21
+ a:visited {
22
+ color: #437A16;
23
+ }
24
+
25
+ a:focus {
26
+ border-bottom: 1px solid;
27
+ background: #BAE498;
28
+ }
29
+
30
+ a:hover {
31
+ border-bottom: 1px solid;
32
+ background: #CDFEAA;
33
+ }
34
+
35
+ a:active {
36
+ background: #265301;
37
+ color: #CDFEAA;
38
+ }
39
+
40
+ </style>
41
+
42
+ </head>
43
+ <body>
44
+
45
+ <h1>HTML Links</h1>
46
+
47
+ <p>
48
+ <a href="https://www.w3schools.com/">Visit W3Schools.com!</a>
49
+ </p>
50
+
51
+
52
+ <h2>Absolute URLs</h2>
53
+ <p><a href="https://www.w3.org/">W3C</a></p>
54
+ <p><a href="https://www.google.com/">Google</a></p>
55
+
56
+ <h2>Relative URLs</h2>
57
+ <p><a href="html_images.asp">HTML Images</a></p>
58
+ <p><a href="/css/default.asp">CSS Tutorial</a></p>
59
+
60
+ </body>
61
+ </html>
@@ -0,0 +1,39 @@
1
+ <html>
2
+ <head>
3
+ <title>html_slider.html</title>
4
+ <style>
5
+ body {
6
+ padding: 50px 20px;
7
+ }
8
+
9
+ label {
10
+ display: block;
11
+ }
12
+
13
+ input[type=range] {
14
+ background: red;
15
+ width: 200px;
16
+ margin-bottom: 20px;
17
+ }
18
+
19
+ </style>
20
+ </head>
21
+ <body>
22
+ <script>
23
+
24
+ const volume = document.getElementById('volume');
25
+ const result = document.getElementById('result');
26
+ result.value = volume.value;
27
+
28
+ volume.addEventListener('change', () => {
29
+ result.value = volume.value;
30
+ });
31
+
32
+ </script>
33
+ <label for="volume">Volume: </label>
34
+ <input type="range" id="volume" name="volume" min="0" max="20">
35
+
36
+ <label for="result">Your choice: </label>
37
+ <input type="number" id="result" name="result">
38
+ </body>
39
+ </html>
@@ -4,13 +4,17 @@
4
4
  </head>
5
5
  <body>
6
6
 
7
- <form action="/action_page.php">
8
- <label for="fname">First name:</label>
9
- <input type="text" id="fname" name="fname"><br>
10
- <label for="lname">Last name:</label>
11
- <input type="text" id="lname" name="lname" autofocus><br><br>
12
- <input type="submit">
13
- </form>
7
+ <p>
8
+ The second input-field makes use of <b>autofocus</b>.
9
+ </p>
10
+
11
+ <form action="/action_page.php">
12
+ <label for="fname">First name:</label>
13
+ <input type="text" id="fname" name="fname"><br>
14
+ <label for="lname">Last name:</label>
15
+ <input type="text" id="lname" name="lname" autofocus><br><br>
16
+ <input type="submit">
17
+ </form>
14
18
 
15
19
  </body>
16
20
  </html>
@@ -0,0 +1,15 @@
1
+ <!DOCTYPE html>
2
+ <html>
3
+ <body>
4
+
5
+ <h1>The input placeholder attribute</h1>
6
+
7
+ <form action="/foobar.php">
8
+ <label for="phone">Enter your phone number:</label><br><br>
9
+ <input type="tel" id="phone" name="phone" placeholder="123-45-678" pattern="[0-9]{3}-[0-9]{2}-[0-9]{3}"><br><br>
10
+ <small>Format: 123-45-678-912456</small><br><br>
11
+ <input type="submit">
12
+ </form>
13
+
14
+ </body>
15
+ </html>
@@ -23,7 +23,7 @@
23
23
  <body>
24
24
 
25
25
  <div class="enlarged">
26
- <img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTS6XX_aJCzSJfuHZUes1xOsozH8KQjAB9VrA&usqp=CAU" style="border: 1px solid black"/>
26
+ <img src="https://encrypted-tbn0.gstatic.com/images?q=tbn:ANd9GcTS6XX_aJCzSJfuHZUes1xOsozH8KQjAB9VrA&usqp=CAU" style="border: 1px solid black" alt="This shows a cat."/>
27
27
  </div>
28
28
 
29
29
  </body>
@@ -1,28 +1,30 @@
1
1
  <html>
2
2
  <head>
3
3
  <title>Ordered Bulletins</title>
4
-
5
4
  <style>
6
5
  li.wide {
7
6
  padding: 1px;
8
- margin-bottom: 5px;
7
+ margin-bottom: 8px;
9
8
  }
10
9
  </style>
11
10
  </head>
12
11
  <body>
13
12
 
13
+ <h4>An unordered list:</h4>
14
14
  <ul>
15
15
  <li>Coffee 1</li>
16
16
  <li>Tea 1</li>
17
17
  <li>Milk 1</li>
18
18
  </ul>
19
19
 
20
+ <h4>An unordered list with more spacing, thanks to margin-bottom: 8px:</h4>
20
21
  <ul>
21
22
  <li class="wide">Coffee 2</li>
22
23
  <li class="wide">Tea 2</li>
23
24
  <li class="wide">Milk 2</li>
24
25
  </ul>
25
26
 
27
+ <h4>And now an ordered list:</h4>
26
28
  <ol>
27
29
  <li>Coffee 3</li>
28
30
  <li>Tea 3</li>