cyberweb 0.4.174 → 0.5.225
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of cyberweb might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/README.md +1782 -405
- data/bin/cyberweb_sanitize +10 -0
- data/bin/download_webpage +7 -0
- data/bin/html_to_cyberweb_converter +7 -0
- data/cyberweb.gemspec +25 -25
- data/doc/README.gen +1745 -383
- data/doc/USAGE.md +16 -16
- data/doc/{AUTHORS.md → authors.md} +0 -0
- data/doc/configuration/configuration.md +3 -1
- data/doc/deprecations.md +13 -7
- data/doc/{DOCUMENTATION_FOR_CYBERSPRAWL.md → documentation_for_cybersprawl.md} +7 -4
- data/doc/future_design_goals.md +33 -0
- data/doc/html_characters.md +7 -7
- data/doc/{JQUERY.md → jquery/jquery.md} +20 -12
- data/doc/{MOUSE.md → mouse.md} +1 -9
- data/doc/{RENDER_WEB_BASE.md → render_web_base.md} +11 -4
- data/doc/todo/todo_for_the_cyberweb_project.md +791 -0
- data/examples/advanced/animated_css_example/animated_css_example.html +47 -0
- data/examples/advanced/animated_submarine/animated_submarine.html +511 -0
- data/examples/advanced/animated_windmill/animated_windmill.html +468 -0
- data/examples/advanced/delayed_update_of_the_body_via_javascript.cgi +8 -5
- data/examples/advanced/draw_circle/draw_circle.cgi +36 -0
- data/examples/advanced/drop_shadow_examples.cgi +37 -0
- data/examples/advanced/games/snake/food.png +0 -0
- data/examples/advanced/games/snake/ground.png +0 -0
- data/examples/advanced/games/snake/snake.cgi +28 -0
- data/examples/advanced/games/tetris/tetris.cgi +7 -0
- data/examples/advanced/games/tetris/tetris.rb +17 -0
- data/examples/advanced/games/tetris/tetris.sinatra +58 -0
- data/examples/advanced/games/tic-tac-toe/tic-tac-toe.cgi +123 -0
- data/examples/advanced/get_some_coffee/get_some_coffee.html +293 -0
- data/examples/advanced/glow_on_hover_example/glow_on_hover_example.cgi +27 -0
- data/examples/advanced/hybrid_experiment.cgi +34 -12
- data/examples/advanced/images/global_css_rules_for_the_images.cgi +32 -0
- data/examples/advanced/larger_image_on_mouse_over_example.cgi +2 -2
- data/examples/advanced/no_right_click.cgi +4 -3
- data/examples/advanced/{objectified_html_tags.cgi → objectified_html_tags/objectified_html_tags.cgi} +12 -3
- data/examples/advanced/objectified_html_tags/testing_objectified_html_tags_with_the_webobject.cgi +28 -0
- data/examples/advanced/random_glow_effects.cgi +34 -0
- data/examples/advanced/select_everything_example/select_everything_example.cgi +25 -0
- data/examples/advanced/simple_calculator.cgi +13 -21
- data/examples/advanced/simple_form_example.cgi +11 -11
- data/examples/advanced/traffic_light/traffic_light.html +163 -0
- data/examples/advanced/weather_animation/weather_animation.html +560 -0
- data/examples/css/animated_3D_cube_example/animated_3D_cube_example.html +265 -0
- data/examples/css/animated_bird_example/animated_bird_example.html +207 -0
- data/examples/css/animated_desk_example/animated_desk_example.html +120 -0
- data/examples/css/animated_dog_example/animated_dog_example.html +432 -0
- data/examples/css/animated_submit_button.html +190 -0
- data/examples/css/animated_text_colour_change/animated_text_colour_change.html +41 -0
- data/examples/css/blue_border.html +3 -1
- data/examples/css/border_image_example/border_image_example.html +40 -0
- data/examples/css/box_shadow/box_shadow_example.html +18 -0
- data/examples/css/christmas_snow_globe_animation.html +596 -0
- data/examples/css/css_border_spacing_example.html +5 -5
- data/examples/css/css_bubbles.html +3 -1
- data/examples/css/css_checkboxes_example/css_checkboxes_example.html +110 -0
- data/examples/css/css_drag_and_drop.html +1 -5
- data/examples/css/css_grid_feline_style/css_grid_feline_style.html +161 -0
- data/examples/css/css_neon_glow_effects.html +1 -1
- data/examples/css/css_rotate_these_words.html +83 -0
- data/examples/css/css_text_decoration_example.html +7 -7
- data/examples/css/css_thermometer/css_thermometer.html +91 -0
- data/examples/css/{css_tooltip.html → css_tooltip/css_tooltip.html} +8 -6
- data/examples/css/css_typewriter_example/css_typewriter_example.html +226 -0
- data/examples/css/cyberweb_animated_logo/cyberweb_animated_logo.html +179 -0
- data/examples/css/daily_coffee/daily_coffee.html +1110 -0
- data/examples/css/different_colour_on_selected_text/different_colour_on_selected_text.html +31 -0
- data/examples/css/differentially_glowing_text_example/differentially_glowing_text_example.html +82 -0
- data/examples/css/fade_in_and_fade_out_effect.html +2 -2
- data/examples/css/flying_birds_example/flying_birds_example.html +171 -0
- data/examples/css/folding_cards_example/folding_cards_example.html +624 -0
- data/examples/css/font_size_examples.html +7 -5
- data/examples/css/glowing_on_hover_animation/glowing_on_hover_animation.html +90 -0
- data/examples/css/grow_example.html +31 -0
- data/examples/css/happy_toaster_example/happy_toaster_example.html +830 -0
- data/examples/css/landing_on_mars_animation/landing_on_mars_animation.html +374 -0
- data/examples/css/letter_spacing_example.cgi +18 -14
- data/examples/css/lighthouse_example/lighthouse_example.html +1161 -0
- data/examples/css/{meter_example.html → meter_example/meter_example.html} +0 -0
- data/examples/css/motorcycle_on_the_go/motorcycle_on_the_go.html +227 -0
- data/examples/css/on_hover_glow_effect/on_hover_glow_effect.html +50 -0
- data/examples/css/on_mouse_button_pressed.html +6 -4
- data/examples/css/our_solar_system/our_solar_system.html +441 -0
- data/examples/css/outline/outline_versus_border_example.html +57 -0
- data/examples/css/polaroid_card_effect_example/polaroid_card_effect_example.html +130 -0
- data/examples/css/responsive_image_gallery/responsive_image_gallery.html +97 -0
- data/examples/css/rotating_DNA/rotating_DNA.html +626 -0
- data/examples/css/rotating_sphere_example/rotating_sphere_example.html +112 -0
- data/examples/css/scale_example.html +4 -5
- data/examples/css/shadow_example_in_CSS/shadow_example_in_CSS.cgi +62 -0
- data/examples/css/shaking_shapes_example.html +133 -0
- data/examples/css/simple_stars_example/simple_stars_example.html +27 -0
- data/examples/css/slide_checkbox_example/slide_checkbox_example.html +564 -0
- data/examples/css/speak_bubble_quote_example/speak_bubble_quote_example.html +109 -0
- data/examples/css/speedy_truck_example/speedy_truck_example.html +168 -0
- data/examples/css/{sticky_div_example.html → sticky_div_example/sticky_div_example.html} +0 -0
- data/examples/css/stitched_div.html +9 -0
- data/examples/css/sun_and_clouds_animation/sun_and_clouds_animation.html +292 -0
- data/examples/css/talking_candles_example/talking_candles_example.html +550 -0
- data/examples/css/text_decoration_underline_example/text_decoration_underline_example.html +62 -0
- data/examples/css/this_is_a_cat/this_is_a_cat.html +219 -0
- data/examples/css/three_dots_indicating_page_loading.html +65 -0
- data/examples/css/user_select_example/user_select_example.html +24 -0
- data/examples/css/walking_cat/walking_cat.html +128 -0
- data/examples/css/water_wave_text_animation_effect/water_wave_text_animation_effect.html +86 -0
- data/examples/csv/README.md +2 -1
- data/examples/flip_card_example/flip_card_example.html +10 -3
- data/examples/games/README.md +3 -0
- data/examples/games/snake/images/food.png +0 -0
- data/examples/games/snake/images/ground.png +0 -0
- data/examples/games/snake/snake.html +16 -0
- data/examples/games/snake/snake.js +117 -0
- data/examples/games/tetris/smaller_tetris_game.html +518 -0
- data/examples/games/tetris/tetris.html +461 -0
- data/examples/games/tic-tac-toe/index.js +125 -0
- data/examples/games/tic-tac-toe/style.css +79 -0
- data/examples/games/tic-tac-toe/tic-tac-toe.html +39 -0
- data/examples/html/MathML/001_show_a_simple_quadratic_equation.html +22 -0
- data/examples/html/MathML/002_simple_equation.html +7 -0
- data/examples/html/MathML/003_function_of_example.html +17 -0
- data/examples/html/MathML/README.md +2 -0
- data/examples/html/abbr_example.html +2 -5
- data/examples/html/accordion/README.md +1 -0
- data/examples/html/accordion/accordion.html +56 -0
- data/examples/html/base64_image_example.html +8 -5
- data/examples/html/buttons_example.html +133 -0
- data/examples/html/canvas_drawing_example.html +54 -0
- data/examples/html/colour_wheel.html +441 -442
- data/examples/html/column_width_example.html +2 -2
- data/examples/html/custom_cursor.html +8 -5
- data/examples/html/cyberweb_logo/README.md +2 -0
- data/examples/html/cyberweb_logo/cyberweb_logo.html +11 -0
- data/examples/html/draggable_paragraph.html +1 -2
- data/examples/html/email_popup_example/email_popup_example.html +175 -0
- data/examples/html/fieldset_example.html +3 -1
- data/examples/html/font_examples/README.md +1 -0
- data/examples/html/font_examples/chancery_text.html +19 -0
- data/examples/html/font_examples/fantasy_text.html +19 -0
- data/examples/html/font_examples/georgia_text.html +19 -0
- data/examples/html/font_size_example/font_size_example.html +85 -0
- data/examples/html/glyph_example.html +0 -1
- data/examples/html/grayscale_filter_example/grayscale_filter_example.html +15 -0
- data/examples/html/html_links_example.html +61 -0
- data/examples/html/html_slider/html_slider.html +39 -0
- data/examples/html/input_autofocus_example.html +11 -7
- data/examples/html/input_placeholder_example.html +15 -0
- data/examples/html/larger_image_on_mouse_over_example.html +1 -1
- data/examples/html/ordered_and_unordered_bulletsin.html +4 -2
- data/examples/html/play_video_example.html +3 -2
- data/examples/html/remote_image_example.html +8 -2
- data/examples/html/select_everything_on_mouse_click_event.html +38 -0
- data/examples/html/selected_text_appears_in_another_colour_example.html +34 -0
- data/examples/html/send_email_hyperlink/send_email_hyperlink.html +8 -0
- data/examples/html/simple_unordered_list.html +3 -0
- data/examples/html/spinner_example/spinner.html +79 -0
- data/examples/html/table_with_header_example.html +26 -13
- data/examples/html/test_mkv_codec/test_mkv_codec.html +11 -0
- data/examples/html/two_columns_flex_example.html +4 -1
- data/examples/{javascript → javascript_and_jquery}/README.md +0 -0
- data/examples/{javascript → javascript_and_jquery}/arrays/arrays_example_in_javascript.html +0 -0
- data/examples/javascript_and_jquery/autocomplete_on_an_input_field/autocomplete_on_an_input_field.html +295 -0
- data/examples/javascript_and_jquery/change_the_background_colour_dynamically/change_the_background_colour_dynamically.html +41 -0
- data/examples/{javascript → javascript_and_jquery}/delay_example/delay_example.html +0 -0
- data/examples/{javascript → javascript_and_jquery}/drag_support/drag_support.html +0 -0
- data/examples/javascript_and_jquery/jquery_bubbling_header/bubbling_header.html +109 -0
- data/examples/{javascript → javascript_and_jquery}/jquery_drag_and_drop/drag_and_drop_image_example.html +0 -0
- data/examples/javascript_and_jquery/jquery_showcase/README.md +6 -0
- data/examples/javascript_and_jquery/jquery_showcase/jquery_001.cgi +23 -0
- data/examples/javascript_and_jquery/jquery_showcase/jquery_002.cgi +34 -0
- data/examples/javascript_and_jquery/jquery_showcase/jquery_003.cgi +24 -0
- data/examples/javascript_and_jquery/jquery_showcase/jquery_004.cgi +34 -0
- data/examples/javascript_and_jquery/on_change_event/on_change_event.html +29 -0
- data/examples/javascript_and_jquery/on_click_colour_change/on_click_colour_change.html +31 -0
- data/examples/javascript_and_jquery/on_click_display_random_number/on_click_display_random_number.html +43 -0
- data/examples/{javascript → javascript_and_jquery}/on_click_event_hello_world/on_click_event_hello_world.html +0 -0
- data/examples/javascript_and_jquery/on_mouse_wheel_event/on_mouse_wheel_event.html +37 -0
- data/examples/javascript_and_jquery/read_the_content_of_a_local_file/read_the_content_of_a_local_file.html +35 -0
- data/examples/{javascript → javascript_and_jquery}/rgb_to_hex/rgb_to_hex.html +0 -0
- data/examples/{javascript → javascript_and_jquery}/screen_resolution/screen_resolution.html +2 -1
- data/examples/{javascript → javascript_and_jquery}/select_everything/select_everything.html +1 -1
- data/examples/javascript_and_jquery/vue/README.md +1 -0
- data/examples/javascript_and_jquery/vue/showcasing_vue.html +80 -0
- data/examples/{javascript → javascript_and_jquery}/write_into_a_file/write_into_a_file.html +0 -0
- data/examples/rack/example_with_html_template.rb +5 -4
- data/examples/rack/example_with_rack_and_cyberweb_showing_how_to_use_images.rb +3 -2
- data/examples/rack/hello_world_example_with_rack.rb +3 -2
- data/examples/rack/lobster.rb +7 -5
- data/examples/rack/rack_env.rb +3 -3
- data/examples/{show_greek_letters.rb → show_greek_letters/show_greek_letters.rb} +0 -0
- data/examples/simple/input_example_with_coloured_focus.cgi +32 -0
- data/examples/simple/input_type_examples.cgi +51 -0
- data/examples/simple/on_click_event_hello_world.cgi +5 -5
- data/examples/simple/rotate_these_words.cgi +90 -0
- data/examples/{example1.rb → simple/show_how_to_set_a_title.rb} +0 -0
- data/examples/simple/simple_gradient.cgi +57 -0
- data/images/cyberweb_favicon.png +0 -0
- data/images/cyberweb_logo.png +0 -0
- data/images/cyberweb_theme.png +0 -0
- data/lib/cyberweb/REST/README.md +7 -0
- data/lib/cyberweb/REST/base/accept_entry.rb +94 -0
- data/lib/cyberweb/REST/base/application.rb +37 -0
- data/lib/cyberweb/REST/base/bad_request.rb +10 -0
- data/lib/cyberweb/REST/base/base.rb +1131 -0
- data/lib/cyberweb/REST/base/common_logger.rb +35 -0
- data/lib/cyberweb/REST/base/delegator.rb +75 -0
- data/lib/cyberweb/REST/base/error.rb +8 -0
- data/lib/cyberweb/REST/base/extended_rack.rb +66 -0
- data/lib/cyberweb/REST/base/helpers/helpers.rb +473 -0
- data/lib/cyberweb/REST/base/helpers/stream.rb +75 -0
- data/lib/cyberweb/REST/base/mime_type_entry.rb +67 -0
- data/lib/cyberweb/{constants/file_constants.rb → REST/base/not_found.rb} +10 -5
- data/lib/cyberweb/REST/base/request.rb +145 -0
- data/lib/cyberweb/REST/base/response.rb +94 -0
- data/lib/cyberweb/REST/base/templates/templates.rb +208 -0
- data/lib/cyberweb/REST/base/wrapper.rb +28 -0
- data/lib/cyberweb/{constants/nl.rb → REST/constants.rb} +8 -9
- data/lib/cyberweb/REST/main.rb +109 -0
- data/lib/cyberweb/REST/show_exceptions.rb +396 -0
- data/lib/cyberweb/and_sinatra_base.rb +0 -0
- data/lib/cyberweb/autoinclude.rb +0 -0
- data/lib/cyberweb/autoinclude_webobject.rb +0 -0
- data/lib/cyberweb/base/base.rb +9 -2
- data/lib/cyberweb/base/colours.rb +8 -6
- data/lib/cyberweb/base/constants.rb +8 -0
- data/lib/cyberweb/base/misc.rb +140 -53
- data/lib/cyberweb/base/save_file.rb +3 -0
- data/lib/cyberweb/base_module/base_module.rb +79 -0
- data/lib/cyberweb/cascading_style_sheets/admonition.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/balloon.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/border.css +107 -41
- data/lib/cyberweb/cascading_style_sheets/code.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/colours.css +46 -23
- data/lib/cyberweb/cascading_style_sheets/css_reset.css +59 -0
- data/lib/cyberweb/cascading_style_sheets/cursors.css +14 -0
- data/lib/cyberweb/cascading_style_sheets/custom/animated_bike.css +199 -0
- data/lib/cyberweb/cascading_style_sheets/default.css +171 -136
- data/lib/cyberweb/cascading_style_sheets/div.css +18 -4
- data/lib/cyberweb/cascading_style_sheets/drop_shadow.css +154 -0
- data/lib/cyberweb/cascading_style_sheets/error_404_css_class.css +26 -0
- data/lib/cyberweb/cascading_style_sheets/fonts.css +60 -39
- data/lib/cyberweb/cascading_style_sheets/glow_effects.css +69 -0
- data/lib/cyberweb/cascading_style_sheets/gradient_effects.css +5 -0
- data/lib/cyberweb/cascading_style_sheets/hover.css +4212 -0
- data/lib/cyberweb/cascading_style_sheets/links.css +8 -8
- data/lib/cyberweb/cascading_style_sheets/margin.css +195 -178
- data/lib/cyberweb/cascading_style_sheets/menu.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/message_boxes.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/misc.css +51 -11
- data/lib/cyberweb/cascading_style_sheets/popup.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/rpg.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/ruby_regexes.css +12 -0
- data/lib/cyberweb/cascading_style_sheets/shapes.css +59 -0
- data/lib/cyberweb/cascading_style_sheets/template2.css +0 -0
- data/lib/cyberweb/cascading_style_sheets/text_shadow.css +21 -0
- data/lib/cyberweb/cascading_style_sheets/tooltip.css +0 -0
- data/lib/cyberweb/cgi/constants.rb +1 -2
- data/lib/cyberweb/cgi/exceptions.rb +1 -1
- data/lib/cyberweb/coloured_tags/coloured_tags.rb +1 -1
- data/lib/cyberweb/colours/colour_chart.rb +10 -56
- data/lib/cyberweb/colours/colours.rb +149 -4
- data/lib/cyberweb/commandline/commandline_interface.rb +13 -8
- data/lib/cyberweb/configuration/load_the_configuration_file.rb +1 -1
- data/lib/cyberweb/constants/constants.rb +592 -2
- data/lib/cyberweb/controller/{webobject_controller.rb → controller.rb} +1 -1
- data/lib/cyberweb/css_manager/css_manager.rb +237 -0
- data/lib/cyberweb/databases/sqlite.rb +56 -0
- data/lib/cyberweb/debug/debug.rb +1 -1
- data/lib/cyberweb/encoding/encoding.rb +11 -0
- data/lib/cyberweb/erb/test.rhtml +0 -0
- data/lib/cyberweb/erb/test_template.erb +0 -0
- data/lib/cyberweb/evaluate_from_the_same_named_file_then_serve.rb +1 -1
- data/lib/cyberweb/favicon/favicon.rb +8 -7
- data/lib/cyberweb/forum/README.md +4 -0
- data/lib/cyberweb/foto_gallery/foto_gallery.rb +158 -0
- data/lib/cyberweb/generator/README.md +2 -2
- data/lib/cyberweb/generator/cgi.rb +22 -9
- data/lib/cyberweb/generator/static_webpage.rb +22 -12
- data/lib/cyberweb/html_tags/README.md +3 -3
- data/lib/cyberweb/html_tags/button.rb +10 -2
- data/lib/cyberweb/html_tags/h2.rb +6 -4
- data/lib/cyberweb/html_tags/html_tags.rb +17 -1
- data/lib/cyberweb/html_tags/input.rb +10 -5
- data/lib/cyberweb/html_tags/legend.rb +1 -1
- data/lib/cyberweb/html_tags/span.rb +10 -2
- data/lib/cyberweb/html_tags/table.rb +30 -19
- data/lib/cyberweb/html_template/html_template.rb +248 -85
- data/lib/cyberweb/images/embed_this_image.rb +3 -1
- data/lib/cyberweb/images/images.rb +2 -2
- data/lib/cyberweb/images/is_image.rb +2 -1
- data/lib/cyberweb/images/path_to_images.rb +2 -1
- data/lib/cyberweb/images/remove_this_substring_from_all_images.rb +1 -1
- data/lib/cyberweb/images/standalone_drag_and_drop_this_image.rb +3 -3
- data/lib/cyberweb/images/string_image.rb +6 -3
- data/lib/cyberweb/images_base64_encoded/404_ERROR.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/AUSRUFUNGSZEICHEN.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/BLUEARROW.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/BUBBLE.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/CAT.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/CAUTION.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/CHEERING_PERSON.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/CURSOR.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/DOT_01.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/DUCKY.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/ELEPHANT.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/HALLOWEEN.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/HANGING_MONKEY.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/LENS.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/README.md +0 -0
- data/lib/cyberweb/images_base64_encoded/SIX_SIDED_DICE.png.md +1 -0
- data/lib/cyberweb/images_base64_encoded/TU_WIEN_LOGO.png.md +0 -0
- data/lib/cyberweb/images_base64_encoded/VOGEL.png.md +0 -0
- data/lib/cyberweb/javascript/drag_and_drop.rb +17 -14
- data/lib/cyberweb/javascript/javascript.rb +79 -34
- data/lib/cyberweb/javascript/javascript_clock.rb +50 -14
- data/lib/cyberweb/javascript/javascript_helper/javascript_helper.rb +59 -0
- data/lib/cyberweb/javascript/jquery.rb +9 -5
- data/lib/cyberweb/javascript/on_click_change_opacity.rb +5 -1
- data/lib/cyberweb/javascript/on_click_hide.rb +2 -0
- data/lib/cyberweb/javascript/popup.rb +5 -2
- data/lib/cyberweb/javascript/resize.rb +4 -1
- data/lib/cyberweb/javascript_code/README.md +1 -1
- data/lib/cyberweb/javascript_code/custom_functions.js +51 -25
- data/lib/cyberweb/javascript_code/disable_right_click.js +5 -0
- data/lib/cyberweb/javascript_code/games/snake.js +113 -0
- data/lib/cyberweb/javascript_code/games/tetris.js +491 -0
- data/lib/cyberweb/javascript_code/games/tic-tac-toe.js +125 -0
- data/lib/cyberweb/javascript_code/html_colours.js +161 -0
- data/lib/cyberweb/javascript_code/jquery/jquery-3.6.1.js +10909 -0
- data/lib/cyberweb/javascript_code/select_everything_on_mouse_click_event.js +23 -0
- data/lib/cyberweb/javascript_code/simple_calculator.js +3 -3
- data/lib/cyberweb/javascript_code/simulate_a_dice.js +20 -0
- data/lib/cyberweb/javascript_code/sleep.js +3 -0
- data/lib/cyberweb/mouse/mouse.rb +4 -1
- data/lib/cyberweb/objectified/html_tags/README.md +13 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/a.rb +17 -35
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/abbr.rb +18 -9
- data/lib/cyberweb/objectified/html_tags/base.rb +960 -0
- data/lib/cyberweb/objectified/html_tags/blockquote.rb +106 -0
- data/lib/cyberweb/{objectified_html_tags/span.rb → objectified/html_tags/body.rb} +25 -20
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/button.rb +26 -34
- data/lib/cyberweb/objectified/html_tags/canvas.rb +202 -0
- data/lib/cyberweb/objectified/html_tags/cite.rb +103 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/combobox.rb +26 -34
- data/lib/cyberweb/objectified/html_tags/div.rb +155 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/embed.rb +18 -33
- data/lib/cyberweb/objectified/html_tags/fieldset.rb +107 -0
- data/lib/cyberweb/objectified/html_tags/figure.rb +152 -0
- data/lib/cyberweb/objectified/html_tags/form.rb +155 -0
- data/lib/cyberweb/objectified/html_tags/h1.rb +176 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h2.rb +32 -40
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h3.rb +30 -42
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h4.rb +30 -42
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h5.rb +31 -40
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/h6.rb +31 -41
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/hbox.rb +12 -10
- data/lib/cyberweb/objectified/html_tags/head.rb +126 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/img.rb +47 -32
- data/lib/cyberweb/objectified/html_tags/include_objectified_html_tags.rb +49 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/input.rb +50 -51
- data/lib/cyberweb/objectified/html_tags/map.rb +107 -0
- data/lib/cyberweb/{objectified_html_tags/div.rb → objectified/html_tags/meta.rb} +36 -47
- data/lib/cyberweb/{objectified_html_tags/h1.rb → objectified/html_tags/object.rb} +34 -42
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/p.rb +17 -32
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/pre.rb +28 -34
- data/lib/cyberweb/{objectified_html_tags/table.rb → objectified/html_tags/progress.rb} +99 -94
- data/lib/cyberweb/objectified/html_tags/span.rb +103 -0
- data/lib/cyberweb/objectified/html_tags/table.rb +257 -0
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/textarea.rb +25 -36
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/title.rb +11 -17
- data/lib/cyberweb/{objectified_html_tags/form.rb → objectified/html_tags/ul.rb} +45 -42
- data/lib/cyberweb/{objectified_html_tags → objectified/html_tags}/window.rb +15 -10
- data/lib/cyberweb/objectified/mask/README.md +8 -0
- data/lib/cyberweb/objectified/mask/compatibility_to_html_tags.rb +40 -0
- data/lib/cyberweb/objectified/mask/mask.rb +490 -0
- data/lib/cyberweb/objectified/web_object/README.md +4 -0
- data/lib/cyberweb/objectified/web_object/web_object.rb +119 -0
- data/lib/cyberweb/predefined_and_freeform_methods/frage.rb +4 -2
- data/lib/cyberweb/predefined_and_freeform_methods/freeform_methods.rb +30 -19
- data/lib/cyberweb/predefined_and_freeform_methods/hash_registered_extra_tags.rb +6 -0
- data/lib/cyberweb/predefined_and_freeform_methods/header.rb +2 -0
- data/lib/cyberweb/predefined_and_freeform_methods/predefined_methods.rb +10 -175
- data/lib/cyberweb/project/project.rb +9 -4
- data/lib/cyberweb/rack/request.rb +11 -11
- data/lib/cyberweb/raw_images/404.png +0 -0
- data/lib/cyberweb/raw_images/500.png +0 -0
- data/lib/cyberweb/raw_images/README.md +2 -0
- data/lib/cyberweb/raw_images/a_dice.png +0 -0
- data/lib/cyberweb/raw_images/food.png +0 -0
- data/lib/cyberweb/raw_images/ground.png +0 -0
- data/lib/cyberweb/requires/require_generators.rb +1 -1
- data/lib/cyberweb/requires/require_html_tags_files.rb +1 -1
- data/lib/cyberweb/requires/require_javascript_files.rb +1 -1
- data/lib/cyberweb/requires/require_objectified_html_tags_files.rb +29 -3
- data/lib/cyberweb/requires/require_the_constants.rb +3 -1
- data/lib/cyberweb/requires/require_the_cyberweb_project.rb +12 -31
- data/lib/cyberweb/requires/require_the_toplevel_methods_files.rb +1 -1
- data/lib/cyberweb/requires/require_web_object_files.rb +1 -1
- data/lib/cyberweb/requires/require_yaml.rb +3 -3
- data/lib/cyberweb/rest +1 -0
- data/lib/cyberweb/route_handler/class_based_test.rb +43 -0
- data/lib/cyberweb/route_handler/module/misc.rb +108 -0
- data/lib/cyberweb/route_handler/module/route_handler_module.rb +215 -0
- data/lib/cyberweb/route_handler/module/verbs.rb +53 -0
- data/lib/cyberweb/route_handler/route_handler.rb +56 -0
- data/lib/cyberweb/route_handler/test.rb +43 -0
- data/lib/cyberweb/{constants/array_predefined_constants.rb → sinatra/base/set_use_this_port.rb} +16 -9
- data/lib/cyberweb/sinatra/base/use_this_port.rb +40 -0
- data/lib/cyberweb/sinatra/base.rb +51 -36
- data/lib/cyberweb/sinatra/custom_extensions.rb +39 -14
- data/lib/cyberweb/standalone_classes/all_css_classes.rb +1 -1
- data/lib/cyberweb/standalone_classes/calculator.rb +7 -1
- data/lib/cyberweb/standalone_classes/correct_image_entries_in_html_file.rb +12 -7
- data/lib/cyberweb/standalone_classes/turn_html_into_cyberweb.rb +13 -11
- data/lib/cyberweb/svg/standalone/README.md +2 -0
- data/lib/cyberweb/svg/standalone/amusement_park.svg +738 -0
- data/lib/cyberweb/svg/svg.cgi +2 -3
- data/lib/cyberweb/toplevel_methods/a.rb +2 -1
- data/lib/cyberweb/toplevel_methods/anmerkung.rb +3 -0
- data/lib/cyberweb/toplevel_methods/audio.rb +1 -1
- data/lib/cyberweb/toplevel_methods/bold.rb +9 -3
- data/lib/cyberweb/toplevel_methods/charsets.rb +17 -13
- data/lib/cyberweb/toplevel_methods/consider_serving_the_web_object.rb +3 -3
- data/lib/cyberweb/toplevel_methods/css.rb +719 -25
- data/lib/cyberweb/{csv → toplevel_methods}/csv.rb +5 -3
- data/lib/cyberweb/{constants/roebe.rb → toplevel_methods/custom_error_page.rb} +10 -10
- data/lib/cyberweb/toplevel_methods/{date.rb → date_and_time.rb} +23 -10
- data/lib/cyberweb/toplevel_methods/disable.rb +7 -3
- data/lib/cyberweb/toplevel_methods/dot.rb +2 -2
- data/lib/cyberweb/toplevel_methods/download_webpage.rb +41 -3
- data/lib/cyberweb/toplevel_methods/edit_configuration_file.rb +1 -1
- data/lib/cyberweb/toplevel_methods/fields.rb +2 -0
- data/lib/cyberweb/toplevel_methods/filename.rb +3 -1
- data/lib/cyberweb/toplevel_methods/frames.rb +0 -2
- data/lib/cyberweb/toplevel_methods/google.rb +52 -0
- data/lib/cyberweb/{html_codes → toplevel_methods}/greek_letters.rb +22 -1
- data/lib/cyberweb/toplevel_methods/hardware_information.rb +2 -1
- data/lib/cyberweb/{help → toplevel_methods}/help.rb +3 -2
- data/lib/cyberweb/toplevel_methods/html_comment.rb +2 -2
- data/lib/cyberweb/toplevel_methods/html_tables.rb +401 -266
- data/lib/cyberweb/toplevel_methods/internal_hash.rb +173 -0
- data/lib/cyberweb/{io → toplevel_methods}/io.rb +1 -1
- data/lib/cyberweb/toplevel_methods/javascript.rb +42 -0
- data/lib/cyberweb/toplevel_methods/jquery.rb +8 -0
- data/lib/cyberweb/toplevel_methods/last_modified.rb +4 -0
- data/lib/cyberweb/toplevel_methods/links.rb +23 -7
- data/lib/cyberweb/toplevel_methods/listing.rb +2 -1
- data/lib/cyberweb/toplevel_methods/localhost.rb +3 -0
- data/lib/cyberweb/toplevel_methods/markdown.rb +3 -2
- data/lib/cyberweb/toplevel_methods/mathml.rb +5 -3
- data/lib/cyberweb/toplevel_methods/message_boxes.rb +6 -2
- data/lib/cyberweb/toplevel_methods/misc.rb +531 -79
- data/lib/cyberweb/toplevel_methods/padlem_and_marlem.rb +3 -0
- data/lib/cyberweb/toplevel_methods/path.rb +6 -1
- data/lib/cyberweb/toplevel_methods/pdf.rb +1 -1
- data/lib/cyberweb/toplevel_methods/process_content.rb +4 -7
- data/lib/cyberweb/toplevel_methods/progress.rb +6 -2
- data/lib/cyberweb/toplevel_methods/quote.rb +7 -1
- data/lib/cyberweb/toplevel_methods/random.rb +4 -1
- data/lib/cyberweb/toplevel_methods/rds.rb +14 -6
- data/lib/cyberweb/toplevel_methods/read_and_display.rb +3 -2
- data/lib/cyberweb/toplevel_methods/return_head_start.rb +1 -1
- data/lib/cyberweb/toplevel_methods/return_html_fin.rb +6 -3
- data/lib/cyberweb/toplevel_methods/return_html_header.rb +8 -3
- data/lib/cyberweb/toplevel_methods/return_html_start.rb +7 -2
- data/lib/cyberweb/toplevel_methods/return_meta_collection.rb +15 -4
- data/lib/cyberweb/toplevel_methods/return_pwd.rb +4 -0
- data/lib/cyberweb/toplevel_methods/return_strict_doctype.rb +8 -7
- data/lib/cyberweb/toplevel_methods/roebe.rb +6 -0
- data/lib/cyberweb/toplevel_methods/s2.rb +3 -1
- data/lib/cyberweb/toplevel_methods/sanitize_url.rb +7 -5
- data/lib/cyberweb/toplevel_methods/sbr.rb +7 -7
- data/lib/cyberweb/toplevel_methods/server_base_directory.rb +7 -3
- data/lib/cyberweb/toplevel_methods/show_and_display.rb +15 -15
- data/lib/cyberweb/toplevel_methods/show_configuration.rb +2 -2
- data/lib/cyberweb/toplevel_methods/spacer.rb +5 -2
- data/lib/cyberweb/toplevel_methods/svg.rb +62 -4
- data/lib/cyberweb/toplevel_methods/tag.rb +8 -2
- data/lib/cyberweb/toplevel_methods/temp_directory.rb +2 -2
- data/lib/cyberweb/toplevel_methods/textile.rb +2 -2
- data/lib/cyberweb/toplevel_methods/title.rb +14 -2
- data/lib/cyberweb/toplevel_methods/video.rb +3 -4
- data/lib/cyberweb/toplevel_methods/write_what_into.rb +2 -0
- data/lib/cyberweb/utility_scripts/README.md +3 -4
- data/lib/cyberweb/utility_scripts/autogenerate_drop_shadow_rules/autogenerate_drop_shadow_rules.rb +71 -0
- data/lib/cyberweb/utility_scripts/create_standalone_html_page.rb +223 -0
- data/lib/cyberweb/utility_scripts/download_all_images_from_this_website.rb +143 -0
- data/lib/cyberweb/utility_scripts/download_balloon_css.rb +1 -1
- data/lib/cyberweb/utility_scripts/fix_incorrect_links_to_locally_existing_images_in_this_file.rb +142 -0
- data/lib/cyberweb/utility_scripts/html_to_cyberweb_converter.rb +235 -0
- data/lib/cyberweb/utility_scripts/images_to_html/images_to_html.rb +878 -0
- data/lib/cyberweb/utility_scripts/images_to_html/misc.rb +62 -0
- data/lib/cyberweb/utility_scripts/new_tags.rb +105 -0
- data/lib/cyberweb/utility_scripts/simple_index/README.md +9 -0
- data/lib/cyberweb/utility_scripts/simple_index/simple_index.rb +149 -0
- data/lib/cyberweb/version/version.rb +2 -2
- data/lib/cyberweb/vue/README.md +2 -0
- data/lib/cyberweb/vue/vue.rb +91 -0
- data/lib/cyberweb/web_images/array_listing_all_project_images.rb +1 -1
- data/lib/cyberweb/web_images/map_symbol_to_image_location.rb +60 -4
- data/lib/cyberweb/web_images/web_images.rb +37 -20
- data/lib/cyberweb/{constants/array_images.rb → web_object/display_output_and_report.rb} +11 -10
- data/lib/cyberweb/web_object/english.rb +55 -0
- data/lib/cyberweb/web_object/favicon.rb +103 -22
- data/lib/cyberweb/web_object/html_tags.rb +1433 -0
- data/lib/cyberweb/web_object/images.rb +428 -398
- data/lib/cyberweb/web_object/{javascript.rb → javascript_and_jquery.rb} +174 -276
- data/lib/cyberweb/web_object/{links.rb → link.rb} +185 -83
- data/lib/cyberweb/web_object/misc.rb +3934 -3928
- data/lib/cyberweb/web_object/reset.rb +153 -67
- data/lib/cyberweb/web_object/run.rb +1 -1
- data/lib/cyberweb/web_object/web_object.rb +3690 -49
- data/lib/cyberweb/web_scraper/scrape_this_url.rb +4 -2
- data/lib/cyberweb/webmin/biology_server.cgi +14 -15
- data/lib/cyberweb/webmin/calculator.cgi +2 -2
- data/lib/cyberweb/webmin/colour_chart.cgi +4 -5
- data/lib/cyberweb/webmin/comments.cgi +8 -7
- data/lib/cyberweb/webmin/comments_data +0 -0
- data/lib/cyberweb/webmin/constants.rb +1 -2
- data/lib/cyberweb/webmin/dictionary.cgi +3 -4
- data/lib/cyberweb/webmin/sys_info.cgi +1 -2
- data/lib/cyberweb/webmin/webforum.cgi +1 -2
- data/lib/cyberweb/webmin/webmin.cgi +2 -3
- data/lib/cyberweb/yaml/autogenerated_system_settings.yml +10 -10
- data/lib/cyberweb/yaml/custom_tags.yml +1 -1
- data/lib/cyberweb/yaml/html5_global_attributes.yml +5 -1
- data/lib/cyberweb/yaml/html_tag_legend.yml +2 -0
- data/lib/cyberweb/yaml/http_status_codes.yml +4 -1
- data/lib/cyberweb/yaml/load_these_yaml_files_by_default.yml +29 -0
- data/lib/cyberweb/yaml/project_configuration.yml +42 -31
- data/lib/cyberweb/yaml/video_attributes.yml +2 -0
- data/lib/cyberweb/yaml/web_images.yml +1 -1
- data/test/REST/simple.rb +7 -0
- data/test/complex_tests/simple_sinatra_example_using_cyberweb/simple.rb +1 -1
- data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.cgi +1 -1
- data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.rb +4 -4
- data/test/complex_tests/sinatra_or_cyberweb/sinatra_or_cyberweb.sinatra +1 -2
- data/test/complex_tests/testing_frames.cgi +3 -5
- data/test/complex_tests/testing_objectified_html_tags/testing_objectified_html_tags.html +28 -0
- data/test/complex_tests/testing_objectified_html_tags/testing_objectified_html_tags.rb +175 -0
- data/test/complex_tests/testing_style_variants/show_coloured_boxes.cgi +11 -7
- data/test/complex_tests/testing_tables.cgi +3 -3
- data/test/complex_tests/testing_the_cyberweb_shell.rb +2 -0
- data/test/complex_tests/testing_web_object.rb +5 -2
- data/test/css/README.md +4 -3
- data/test/css/return_the_content_of_these_css_classes.rb +5 -1
- data/test/css/test_hover_css/test_hover_css.cgi +59 -0
- data/test/css/test_ordered_list/test_ordered_list.cgi +31 -0
- data/test/css/testing_css_effects.cgi +3 -4
- data/test/css/testing_css_masking.cgi +3 -4
- data/test/hello_world/hello_world.cgi +6 -4
- data/test/html_template/html_template.rb +15 -0
- data/test/javascript/testing_custom_functions.js +24 -0
- data/test/javascript/testing_drag_and_drop_support.cgi +1 -1
- data/test/javascript/testing_on_click_change_opacity.cgi +4 -5
- data/test/javascript/testing_snowflakes.cgi +2 -2
- data/test/simple_tests/ad-hoc-test.cgi +5 -2
- data/test/simple_tests/cgi/hello_world_with_cyberweb.cgi +14 -0
- data/test/simple_tests/commandline_tests.rb +21 -15
- data/test/simple_tests/display_this_file.cgi +2 -2
- data/test/simple_tests/simple_html_example.cgi +2 -1
- data/test/simple_tests/simple_html_test_page/simple_html_test_page.html +20 -0
- data/test/simple_tests/simple_status_page.cgi +2 -2
- data/test/simple_tests/string_s2_test.rb +5 -0
- data/test/simple_tests/test_simple_string_as_input.rb +3 -1
- data/test/simple_tests/testing_base64_images.cgi +3 -4
- data/test/simple_tests/testing_checkboxes.cgi +22 -0
- data/test/simple_tests/testing_dragging_an_image.cgi +5 -6
- data/test/simple_tests/testing_editable_text.cgi +2 -3
- data/test/simple_tests/testing_email.cgi +6 -7
- data/test/simple_tests/testing_embedding_a_pdf_file.cgi +5 -5
- data/test/simple_tests/testing_google_charts.cgi +3 -3
- data/test/simple_tests/testing_html_forms.cgi +3 -3
- data/test/simple_tests/testing_html_template.rb +2 -0
- data/test/simple_tests/testing_popup_div.cgi +2 -3
- data/test/simple_tests/testing_return_dataset_without_any_comments.rb +3 -1
- data/test/simple_tests/testing_the_cap_box.cgi +3 -4
- data/test/simple_tests/testing_the_div_tag.cgi +3 -4
- data/test/simple_tests/testing_the_headers_tag.cgi +3 -4
- data/test/simple_tests/testing_the_html_colours.cgi +2 -3
- data/test/simple_tests/testing_the_info_box.cgi +2 -3
- data/test/simple_tests/testing_the_li_tag.cgi +2 -1
- data/test/simple_tests/testing_the_s2_method.rb +6 -1
- data/test/simple_tests/testing_the_select_tag.cgi +16 -8
- data/test/simple_tests/testing_the_span_tag.cgi +2 -3
- data/test/simple_tests/testing_web_images.rb +4 -2
- data/test/testing_html_tags/button_example.cgi +6 -7
- metadata +345 -151
- data/doc/CONVENTIONS.md +0 -7
- data/doc/CYBERWEB_TUTORIAL.cgi +0 -43
- data/doc/FUTURE_DESIGN_GOAL_CONSIDERATIONS.md +0 -13
- data/doc/todo/TODO_FOR_THE_CYBERWEB_PROJECT.md +0 -1089
- data/examples/css/shadow_example_in_CSS.cgi +0 -30
- data/lib/cyberweb/charts/README.md +0 -2
- data/lib/cyberweb/charts/google_charts.rb +0 -51
- data/lib/cyberweb/colours/random_colour.rb +0 -28
- data/lib/cyberweb/colours/sanitize_for_colours.rb +0 -95
- data/lib/cyberweb/constants/array_local_css_files.rb +0 -35
- data/lib/cyberweb/constants/configuration_file.rb +0 -33
- data/lib/cyberweb/constants/http_status_codes.rb +0 -42
- data/lib/cyberweb/constants/project_constants.rb +0 -99
- data/lib/cyberweb/constants/standalone_constants.rb +0 -309
- data/lib/cyberweb/csv/README.md +0 -2
- data/lib/cyberweb/generator/webpage_for_images.rb +0 -553
- data/lib/cyberweb/html_codes/README.md +0 -15
- data/lib/cyberweb/images/real/README.md +0 -6
- data/lib/cyberweb/io/README.md +0 -1
- data/lib/cyberweb/javascript/scroll.rb +0 -17
- data/lib/cyberweb/objectified_html_tags/README.md +0 -8
- data/lib/cyberweb/objectified_html_tags/base.rb +0 -376
- data/lib/cyberweb/predefined_and_freeform_methods/hash_css_class_to_use.rb +0 -55
- data/lib/cyberweb/requires/require_charts.rb +0 -20
- data/lib/cyberweb/web_object/css.rb +0 -627
- data/lib/cyberweb/web_object/evaluate.rb +0 -126
- data/lib/cyberweb/web_object/html_related_tags.rb +0 -320
- data/lib/cyberweb/web_object/initialize.rb +0 -51
- data/lib/cyberweb/web_object/input_related_functionality.rb +0 -414
- data/lib/cyberweb/web_object/languages.rb +0 -172
- data/lib/cyberweb/web_object/params.rb +0 -289
- data/lib/cyberweb/web_object/sinatra_related_functionality.rb +0 -30
- data/lib/cyberweb/web_object/sitemap.rb +0 -176
- data/lib/cyberweb/web_object/table.rb +0 -378
- data/test/complex_tests/testing_objectified_html_tags.rb +0 -82
- data/test/javascript/testing_cheerleader_javascript.cgi +0 -0
@@ -0,0 +1,461 @@
|
|
1
|
+
<!DOCTYPE html>
|
2
|
+
<html>
|
3
|
+
<head>
|
4
|
+
<title>Tetris</title>
|
5
|
+
<style>
|
6
|
+
body { font-family: Helvetica, sans-serif; }
|
7
|
+
#tetris { margin: 1em auto; padding: 1em; border: 4px solid black; border-radius: 10px; background-color: #F8F8F8; }
|
8
|
+
#stats { display: inline-block; vertical-align: top; }
|
9
|
+
#canvas {
|
10
|
+
display: inline-block;
|
11
|
+
vertical-align: top;
|
12
|
+
background: url(https://raw.githubusercontent.com/jakesgordon/javascript-tetris/master/texture.jpg);
|
13
|
+
box-shadow: 10px 10px 10px #999;
|
14
|
+
border: 2px solid #333;
|
15
|
+
}
|
16
|
+
#menu { display: inline-block; vertical-align: top; position: relative; }
|
17
|
+
#menu p { margin: 0.5em 0; text-align: center; }
|
18
|
+
#menu p a { text-decoration: none; color: black; }
|
19
|
+
#upcoming { display: block; margin: 0 auto; background-color: #E0E0E0; }
|
20
|
+
#score { color: red; font-weight: bold; vertical-align: middle; }
|
21
|
+
#rows { color: blue; font-weight: bold; vertical-align: middle; }
|
22
|
+
#stats { position: absolute; bottom: 0em; right: 1em; }
|
23
|
+
@media screen and (min-width: 0px) and (min-height: 0px) { #tetris { font-size: 0.75em; width: 250px; } #menu { width: 100px; height: 200px; } #upcoming { width: 50px; height: 50px; } #canvas { width: 100px; height: 200px; } } /* 10px chunks */
|
24
|
+
@media screen and (min-width: 400px) and (min-height: 400px) { #tetris { font-size: 1.00em; width: 350px; } #menu { width: 150px; height: 300px; } #upcoming { width: 75px; height: 75px; } #canvas { width: 150px; height: 300px; } } /* 15px chunks */
|
25
|
+
@media screen and (min-width: 500px) and (min-height: 500px) { #tetris { font-size: 1.25em; width: 450px; } #menu { width: 200px; height: 400px; } #upcoming { width: 100px; height: 100px; } #canvas { width: 200px; height: 400px; } } /* 20px chunks */
|
26
|
+
@media screen and (min-width: 600px) and (min-height: 600px) { #tetris { font-size: 1.50em; width: 550px; } #menu { width: 250px; height: 500px; } #upcoming { width: 125px; height: 125px; } #canvas { width: 250px; height: 500px; } } /* 25px chunks */
|
27
|
+
@media screen and (min-width: 700px) and (min-height: 700px) { #tetris { font-size: 1.75em; width: 650px; } #menu { width: 300px; height: 600px; } #upcoming { width: 150px; height: 150px; } #canvas { width: 300px; height: 600px; } } /* 30px chunks */
|
28
|
+
@media screen and (min-width: 800px) and (min-height: 800px) { #tetris { font-size: 2.00em; width: 750px; } #menu { width: 350px; height: 700px; } #upcoming { width: 175px; height: 175px; } #canvas { width: 350px; height: 700px; } } /* 35px chunks */
|
29
|
+
@media screen and (min-width: 900px) and (min-height: 900px) { #tetris { font-size: 2.25em; width: 850px; } #menu { width: 400px; height: 800px; } #upcoming { width: 200px; height: 200px; } #canvas { width: 400px; height: 800px; } } /* 40px chunks */
|
30
|
+
</style>
|
31
|
+
</head>
|
32
|
+
|
33
|
+
<body>
|
34
|
+
|
35
|
+
<div id="tetris">
|
36
|
+
<div id="menu">
|
37
|
+
<p id="start"><a href="javascript:play();">Press Space to Play.</a></p>
|
38
|
+
<p><canvas id="upcoming"></canvas></p>
|
39
|
+
<p>score <span id="score">00000</span></p>
|
40
|
+
<p>rows <span id="rows">0</span></p>
|
41
|
+
</div>
|
42
|
+
<canvas id="canvas">
|
43
|
+
Sorry, this example cannot be run because your browser does not support the <canvas> element
|
44
|
+
</canvas>
|
45
|
+
</div>
|
46
|
+
|
47
|
+
<script>
|
48
|
+
// stats.js r6 - https://github.com/mrdoob/stats.js
|
49
|
+
var Stats=function(){function s(a,g,d){var f,c,e;for(c=0;c<30;c++)for(f=0;f<73;f++)e=(f+c*74)*4,a[e]=a[e+4],a[e+1]=a[e+5],a[e+2]=a[e+6];for(c=0;c<30;c++)e=(73+c*74)*4,c<g?(a[e]=b[d].bg.r,a[e+1]=b[d].bg.g,a[e+2]=b[d].bg.b):(a[e]=b[d].fg.r,a[e+1]=b[d].fg.g,a[e+2]=b[d].fg.b)}var r=0,t=2,g,u=0,j=(new Date).getTime(),F=j,v=j,l=0,w=1E3,x=0,k,d,a,m,y,n=0,z=1E3,A=0,f,c,o,B,p=0,C=1E3,D=0,h,i,q,E,b={fps:{bg:{r:16,g:16,b:48},fg:{r:0,g:255,b:255}},ms:{bg:{r:16,g:48,b:16},fg:{r:0,g:255,b:0}},mb:{bg:{r:48,g:16,
|
50
|
+
b:26},fg:{r:255,g:0,b:128}}};g=document.createElement("div");g.style.cursor="pointer";g.style.width="80px";g.style.opacity="0.9";g.style.zIndex="10001";g.addEventListener("click",function(){r++;r==t&&(r=0);k.style.display="none";f.style.display="none";h.style.display="none";switch(r){case 0:k.style.display="block";break;case 1:f.style.display="block";break;case 2:h.style.display="block"}},!1);k=document.createElement("div");k.style.backgroundColor="rgb("+Math.floor(b.fps.bg.r/2)+","+Math.floor(b.fps.bg.g/
|
51
|
+
2)+","+Math.floor(b.fps.bg.b/2)+")";k.style.padding="2px 0px 3px 0px";g.appendChild(k);d=document.createElement("div");d.style.fontFamily="Helvetica, Arial, sans-serif";d.style.textAlign="left";d.style.fontSize="9px";d.style.color="rgb("+b.fps.fg.r+","+b.fps.fg.g+","+b.fps.fg.b+")";d.style.margin="0px 0px 1px 3px";d.innerHTML='<span style="font-weight:bold">FPS</span>';k.appendChild(d);a=document.createElement("canvas");a.width=74;a.height=30;a.style.display="block";a.style.marginLeft="3px";k.appendChild(a);
|
52
|
+
m=a.getContext("2d");m.fillStyle="rgb("+b.fps.bg.r+","+b.fps.bg.g+","+b.fps.bg.b+")";m.fillRect(0,0,a.width,a.height);y=m.getImageData(0,0,a.width,a.height);f=document.createElement("div");f.style.backgroundColor="rgb("+Math.floor(b.ms.bg.r/2)+","+Math.floor(b.ms.bg.g/2)+","+Math.floor(b.ms.bg.b/2)+")";f.style.padding="2px 0px 3px 0px";f.style.display="none";g.appendChild(f);c=document.createElement("div");c.style.fontFamily="Helvetica, Arial, sans-serif";c.style.textAlign="left";c.style.fontSize=
|
53
|
+
"9px";c.style.color="rgb("+b.ms.fg.r+","+b.ms.fg.g+","+b.ms.fg.b+")";c.style.margin="0px 0px 1px 3px";c.innerHTML='<span style="font-weight:bold">MS</span>';f.appendChild(c);a=document.createElement("canvas");a.width=74;a.height=30;a.style.display="block";a.style.marginLeft="3px";f.appendChild(a);o=a.getContext("2d");o.fillStyle="rgb("+b.ms.bg.r+","+b.ms.bg.g+","+b.ms.bg.b+")";o.fillRect(0,0,a.width,a.height);B=o.getImageData(0,0,a.width,a.height);try{performance&&performance.memory&&performance.memory.totalJSHeapSize&&
|
54
|
+
(t=3)}catch(G){}h=document.createElement("div");h.style.backgroundColor="rgb("+Math.floor(b.mb.bg.r/2)+","+Math.floor(b.mb.bg.g/2)+","+Math.floor(b.mb.bg.b/2)+")";h.style.padding="2px 0px 3px 0px";h.style.display="none";g.appendChild(h);i=document.createElement("div");i.style.fontFamily="Helvetica, Arial, sans-serif";i.style.textAlign="left";i.style.fontSize="9px";i.style.color="rgb("+b.mb.fg.r+","+b.mb.fg.g+","+b.mb.fg.b+")";i.style.margin="0px 0px 1px 3px";i.innerHTML='<span style="font-weight:bold">MB</span>';
|
55
|
+
h.appendChild(i);a=document.createElement("canvas");a.width=74;a.height=30;a.style.display="block";a.style.marginLeft="3px";h.appendChild(a);q=a.getContext("2d");q.fillStyle="#301010";q.fillRect(0,0,a.width,a.height);E=q.getImageData(0,0,a.width,a.height);return{domElement:g,update:function(){u++;j=(new Date).getTime();n=j-F;z=Math.min(z,n);A=Math.max(A,n);s(B.data,Math.min(30,30-n/200*30),"ms");c.innerHTML='<span style="font-weight:bold">'+n+" MS</span> ("+z+"-"+A+")";o.putImageData(B,0,0);F=j;if(j>
|
56
|
+
v+1E3){l=Math.round(u*1E3/(j-v));w=Math.min(w,l);x=Math.max(x,l);s(y.data,Math.min(30,30-l/100*30),"fps");d.innerHTML='<span style="font-weight:bold">'+l+" FPS</span> ("+w+"-"+x+")";m.putImageData(y,0,0);if(t==3)p=performance.memory.usedJSHeapSize*9.54E-7,C=Math.min(C,p),D=Math.max(D,p),s(E.data,Math.min(30,30-p/2),"mb"),i.innerHTML='<span style="font-weight:bold">'+Math.round(p)+" MB</span> ("+Math.round(C)+"-"+Math.round(D)+")",q.putImageData(E,0,0);v=j;u=0}}}};
|
57
|
+
|
58
|
+
// ----------------------------------------------------------------------------
|
59
|
+
// base helper methods
|
60
|
+
// ----------------------------------------------------------------------------
|
61
|
+
|
62
|
+
function get(id) { return document.getElementById(id); }
|
63
|
+
function hide(id) { get(id).style.visibility = 'hidden'; }
|
64
|
+
function show(id) { get(id).style.visibility = null; }
|
65
|
+
function html(id, html) { get(id).innerHTML = html; }
|
66
|
+
|
67
|
+
function timestamp() { return new Date().getTime(); }
|
68
|
+
function random(min, max) { return (min + (Math.random() * (max - min))); }
|
69
|
+
function randomChoice(choices) { return choices[Math.round(random(0, choices.length-1))]; }
|
70
|
+
|
71
|
+
if (!window.requestAnimationFrame) { // http://paulirish.com/2011/requestanimationframe-for-smart-animating/
|
72
|
+
window.requestAnimationFrame = window.webkitRequestAnimationFrame ||
|
73
|
+
window.mozRequestAnimationFrame ||
|
74
|
+
window.oRequestAnimationFrame ||
|
75
|
+
window.msRequestAnimationFrame ||
|
76
|
+
function(callback, element) {
|
77
|
+
window.setTimeout(callback, 1000 / 60);
|
78
|
+
}
|
79
|
+
}
|
80
|
+
|
81
|
+
// ----------------------------------------------------------------------------
|
82
|
+
// game constants
|
83
|
+
// ----------------------------------------------------------------------------
|
84
|
+
|
85
|
+
var KEY = { ESC: 27, SPACE: 32, LEFT: 37, UP: 38, RIGHT: 39, DOWN: 40 },
|
86
|
+
DIR = { UP: 0, RIGHT: 1, DOWN: 2, LEFT: 3, MIN: 0, MAX: 3 },
|
87
|
+
stats = new Stats(),
|
88
|
+
canvas = get('canvas'),
|
89
|
+
ctx = canvas.getContext('2d'),
|
90
|
+
ucanvas = get('upcoming'),
|
91
|
+
uctx = ucanvas.getContext('2d'),
|
92
|
+
speed = { start: 0.6, decrement: 0.005, min: 0.1 }, // how long before piece drops by 1 row (seconds)
|
93
|
+
nx = 10, // width of tetris court (in blocks)
|
94
|
+
ny = 20, // height of tetris court (in blocks)
|
95
|
+
nu = 5; // width/height of upcoming preview (in blocks)
|
96
|
+
|
97
|
+
// ----------------------------------------------------------------------------
|
98
|
+
// game variables (initialized during reset)
|
99
|
+
// ----------------------------------------------------------------------------
|
100
|
+
|
101
|
+
var dx, dy, // pixel size of a single tetris block
|
102
|
+
blocks, // 2 dimensional array (nx*ny) representing tetris court - either empty block or occupied by a 'piece'
|
103
|
+
actions, // queue of user actions (inputs)
|
104
|
+
playing, // true|false - game is in progress
|
105
|
+
dt, // time since starting this game
|
106
|
+
current, // the current piece
|
107
|
+
next, // the next piece
|
108
|
+
score, // the current score
|
109
|
+
vscore, // the currently displayed score (it catches up to score in small chunks - like a spinning slot machine)
|
110
|
+
rows, // number of completed rows in the current game
|
111
|
+
step; // how long before current piece drops by 1 row
|
112
|
+
|
113
|
+
// ----------------------------------------------------------------------------
|
114
|
+
// tetris pieces
|
115
|
+
//
|
116
|
+
// blocks: each element represents a rotation of the piece (0, 90, 180, 270)
|
117
|
+
// each element is a 16 bit integer where the 16 bits represent
|
118
|
+
// a 4x4 set of blocks, e.g. j.blocks[0] = 0x44C0
|
119
|
+
//
|
120
|
+
// 0100 = 0x4 << 3 = 0x4000
|
121
|
+
// 0100 = 0x4 << 2 = 0x0400
|
122
|
+
// 1100 = 0xC << 1 = 0x00C0
|
123
|
+
// 0000 = 0x0 << 0 = 0x0000
|
124
|
+
// ------
|
125
|
+
// 0x44C0
|
126
|
+
//
|
127
|
+
// ----------------------------------------------------------------------------
|
128
|
+
|
129
|
+
var i = { size: 4, blocks: [0x0F00, 0x2222, 0x00F0, 0x4444], color: 'cyan' };
|
130
|
+
var j = { size: 3, blocks: [0x44C0, 0x8E00, 0x6440, 0x0E20], color: 'blue' };
|
131
|
+
var l = { size: 3, blocks: [0x4460, 0x0E80, 0xC440, 0x2E00], color: 'orange' };
|
132
|
+
var o = { size: 2, blocks: [0xCC00, 0xCC00, 0xCC00, 0xCC00], color: 'yellow' };
|
133
|
+
var s = { size: 3, blocks: [0x06C0, 0x8C40, 0x6C00, 0x4620], color: 'green' };
|
134
|
+
var t = { size: 3, blocks: [0x0E40, 0x4C40, 0x4E00, 0x4640], color: 'purple' };
|
135
|
+
var z = { size: 3, blocks: [0x0C60, 0x4C80, 0xC600, 0x2640], color: 'red' };
|
136
|
+
|
137
|
+
//------------------------------------------------
|
138
|
+
// do the bit manipulation and iterate through each
|
139
|
+
// occupied block (x,y) for a given piece
|
140
|
+
//------------------------------------------------
|
141
|
+
function eachblock(type, x, y, dir, fn) {
|
142
|
+
var bit, result, row = 0, col = 0, blocks = type.blocks[dir];
|
143
|
+
for(bit = 0x8000 ; bit > 0 ; bit = bit >> 1) {
|
144
|
+
if (blocks & bit) {
|
145
|
+
fn(x + col, y + row);
|
146
|
+
}
|
147
|
+
if (++col === 4) {
|
148
|
+
col = 0;
|
149
|
+
++row;
|
150
|
+
}
|
151
|
+
}
|
152
|
+
}
|
153
|
+
|
154
|
+
//-----------------------------------------------------
|
155
|
+
// check if a piece can fit into a position in the grid
|
156
|
+
//-----------------------------------------------------
|
157
|
+
function occupied(type, x, y, dir) {
|
158
|
+
var result = false
|
159
|
+
eachblock(type, x, y, dir, function(x, y) {
|
160
|
+
if ((x < 0) || (x >= nx) || (y < 0) || (y >= ny) || getBlock(x,y))
|
161
|
+
result = true;
|
162
|
+
});
|
163
|
+
return result;
|
164
|
+
}
|
165
|
+
|
166
|
+
function unoccupied(type, x, y, dir) {
|
167
|
+
return !occupied(type, x, y, dir);
|
168
|
+
}
|
169
|
+
|
170
|
+
//-----------------------------------------
|
171
|
+
// start with 4 instances of each piece and
|
172
|
+
// pick randomly until the 'bag is empty'
|
173
|
+
//-----------------------------------------
|
174
|
+
var pieces = [];
|
175
|
+
function randomPiece() {
|
176
|
+
if (pieces.length == 0)
|
177
|
+
pieces = [i,i,i,i,j,j,j,j,l,l,l,l,o,o,o,o,s,s,s,s,t,t,t,t,z,z,z,z];
|
178
|
+
var type = pieces.splice(random(0, pieces.length-1), 1)[0];
|
179
|
+
return { type: type, dir: DIR.UP, x: Math.round(random(0, nx - type.size)), y: 0 };
|
180
|
+
}
|
181
|
+
|
182
|
+
// ----------------------------------------------------------------------------
|
183
|
+
// GAME LOOP
|
184
|
+
// ----------------------------------------------------------------------------
|
185
|
+
function run() {
|
186
|
+
|
187
|
+
showStats(); // initialize FPS counter
|
188
|
+
addEvents(); // attach keydown and resize events
|
189
|
+
|
190
|
+
var last = now = timestamp();
|
191
|
+
function frame() {
|
192
|
+
now = timestamp();
|
193
|
+
update(Math.min(1, (now - last) / 1000.0)); // using requestAnimationFrame have to be able to handle large delta's caused when it 'hibernates' in a background or non-visible tab
|
194
|
+
draw();
|
195
|
+
stats.update();
|
196
|
+
last = now;
|
197
|
+
requestAnimationFrame(frame, canvas);
|
198
|
+
}
|
199
|
+
|
200
|
+
resize(); // setup all our sizing information
|
201
|
+
reset(); // reset the per-game variables
|
202
|
+
frame(); // start the first frame
|
203
|
+
}
|
204
|
+
|
205
|
+
function showStats() {
|
206
|
+
stats.domElement.id = 'stats';
|
207
|
+
get('menu').appendChild(stats.domElement);
|
208
|
+
}
|
209
|
+
|
210
|
+
function addEvents() {
|
211
|
+
document.addEventListener('keydown', keydown, false);
|
212
|
+
window.addEventListener('resize', resize, false);
|
213
|
+
}
|
214
|
+
|
215
|
+
function resize(event) {
|
216
|
+
canvas.width = canvas.clientWidth; // set canvas logical size equal to its physical size
|
217
|
+
canvas.height = canvas.clientHeight; // (ditto)
|
218
|
+
ucanvas.width = ucanvas.clientWidth;
|
219
|
+
ucanvas.height = ucanvas.clientHeight;
|
220
|
+
dx = canvas.width / nx; // pixel size of a single tetris block
|
221
|
+
dy = canvas.height / ny; // (ditto)
|
222
|
+
invalidate();
|
223
|
+
invalidateNext();
|
224
|
+
}
|
225
|
+
|
226
|
+
function keydown(ev) {
|
227
|
+
var handled = false;
|
228
|
+
if (playing) {
|
229
|
+
switch(ev.keyCode) {
|
230
|
+
case KEY.LEFT: actions.push(DIR.LEFT); handled = true; break;
|
231
|
+
case KEY.RIGHT: actions.push(DIR.RIGHT); handled = true; break;
|
232
|
+
case KEY.UP: actions.push(DIR.UP); handled = true; break;
|
233
|
+
case KEY.DOWN: actions.push(DIR.DOWN); handled = true; break;
|
234
|
+
case KEY.ESC: lose(); handled = true; break;
|
235
|
+
}
|
236
|
+
}
|
237
|
+
else if (ev.keyCode == KEY.SPACE) {
|
238
|
+
play();
|
239
|
+
handled = true;
|
240
|
+
}
|
241
|
+
if (handled)
|
242
|
+
ev.preventDefault(); // prevent arrow keys from scrolling the page (supported in IE9+ and all other browsers)
|
243
|
+
}
|
244
|
+
|
245
|
+
// ----------------------------------------------------------------------------
|
246
|
+
// GAME LOGIC
|
247
|
+
// ----------------------------------------------------------------------------
|
248
|
+
function play() { hide('start'); reset(); playing = true; }
|
249
|
+
function lose() { show('start'); setVisualScore(); playing = false; }
|
250
|
+
|
251
|
+
function setVisualScore(n) { vscore = n || score; invalidateScore(); }
|
252
|
+
function setScore(n) { score = n; setVisualScore(n); }
|
253
|
+
function addScore(n) { score = score + n; }
|
254
|
+
function clearScore() { setScore(0); }
|
255
|
+
function clearRows() { setRows(0); }
|
256
|
+
function setRows(n) { rows = n; step = Math.max(speed.min, speed.start - (speed.decrement*rows)); invalidateRows(); }
|
257
|
+
function addRows(n) { setRows(rows + n); }
|
258
|
+
function getBlock(x,y) { return (blocks && blocks[x] ? blocks[x][y] : null); }
|
259
|
+
function setBlock(x,y,type) { blocks[x] = blocks[x] || []; blocks[x][y] = type; invalidate(); }
|
260
|
+
function clearBlocks() { blocks = []; invalidate(); }
|
261
|
+
function clearActions() { actions = []; }
|
262
|
+
function setCurrentPiece(piece) { current = piece || randomPiece(); invalidate(); }
|
263
|
+
function setNextPiece(piece) { next = piece || randomPiece(); invalidateNext(); }
|
264
|
+
|
265
|
+
function reset() {
|
266
|
+
dt = 0;
|
267
|
+
clearActions();
|
268
|
+
clearBlocks();
|
269
|
+
clearRows();
|
270
|
+
clearScore();
|
271
|
+
setCurrentPiece(next);
|
272
|
+
setNextPiece();
|
273
|
+
}
|
274
|
+
|
275
|
+
function update(idt) {
|
276
|
+
if (playing) {
|
277
|
+
if (vscore < score)
|
278
|
+
setVisualScore(vscore + 1);
|
279
|
+
handle(actions.shift());
|
280
|
+
dt = dt + idt;
|
281
|
+
if (dt > step) {
|
282
|
+
dt = dt - step;
|
283
|
+
drop();
|
284
|
+
}
|
285
|
+
}
|
286
|
+
}
|
287
|
+
|
288
|
+
function handle(action) {
|
289
|
+
switch(action) {
|
290
|
+
case DIR.LEFT: move(DIR.LEFT); break;
|
291
|
+
case DIR.RIGHT: move(DIR.RIGHT); break;
|
292
|
+
case DIR.UP: rotate(); break;
|
293
|
+
case DIR.DOWN: drop(); break;
|
294
|
+
}
|
295
|
+
}
|
296
|
+
|
297
|
+
function move(dir) {
|
298
|
+
var x = current.x, y = current.y;
|
299
|
+
switch(dir) {
|
300
|
+
case DIR.RIGHT: x = x + 1; break;
|
301
|
+
case DIR.LEFT: x = x - 1; break;
|
302
|
+
case DIR.DOWN: y = y + 1; break;
|
303
|
+
}
|
304
|
+
if (unoccupied(current.type, x, y, current.dir)) {
|
305
|
+
current.x = x;
|
306
|
+
current.y = y;
|
307
|
+
invalidate();
|
308
|
+
return true;
|
309
|
+
}
|
310
|
+
else {
|
311
|
+
return false;
|
312
|
+
}
|
313
|
+
}
|
314
|
+
|
315
|
+
function rotate() {
|
316
|
+
var newdir = (current.dir == DIR.MAX ? DIR.MIN : current.dir + 1);
|
317
|
+
if (unoccupied(current.type, current.x, current.y, newdir)) {
|
318
|
+
current.dir = newdir;
|
319
|
+
invalidate();
|
320
|
+
}
|
321
|
+
}
|
322
|
+
|
323
|
+
function drop() {
|
324
|
+
if (!move(DIR.DOWN)) {
|
325
|
+
addScore(10);
|
326
|
+
dropPiece();
|
327
|
+
removeLines();
|
328
|
+
setCurrentPiece(next);
|
329
|
+
setNextPiece(randomPiece());
|
330
|
+
clearActions();
|
331
|
+
if (occupied(current.type, current.x, current.y, current.dir)) {
|
332
|
+
lose();
|
333
|
+
}
|
334
|
+
}
|
335
|
+
}
|
336
|
+
|
337
|
+
function dropPiece() {
|
338
|
+
eachblock(current.type, current.x, current.y, current.dir, function(x, y) {
|
339
|
+
setBlock(x, y, current.type);
|
340
|
+
});
|
341
|
+
}
|
342
|
+
|
343
|
+
function removeLines() {
|
344
|
+
var x, y, complete, n = 0;
|
345
|
+
for(y = ny ; y > 0 ; --y) {
|
346
|
+
complete = true;
|
347
|
+
for(x = 0 ; x < nx ; ++x) {
|
348
|
+
if (!getBlock(x, y))
|
349
|
+
complete = false;
|
350
|
+
}
|
351
|
+
if (complete) {
|
352
|
+
removeLine(y);
|
353
|
+
y = y + 1; // recheck same line
|
354
|
+
n++;
|
355
|
+
}
|
356
|
+
}
|
357
|
+
if (n > 0) {
|
358
|
+
addRows(n);
|
359
|
+
addScore(100*Math.pow(2,n-1)); // 1: 100, 2: 200, 3: 400, 4: 800
|
360
|
+
}
|
361
|
+
}
|
362
|
+
|
363
|
+
function removeLine(n) {
|
364
|
+
var x, y;
|
365
|
+
for(y = n; y >= 0; --y) {
|
366
|
+
for(x = 0; x < nx; ++x)
|
367
|
+
setBlock(x, y, (y == 0) ? null : getBlock(x, y-1));
|
368
|
+
}
|
369
|
+
}
|
370
|
+
|
371
|
+
// ----------------------------------------------------------------------------
|
372
|
+
// RENDERING
|
373
|
+
// ----------------------------------------------------------------------------
|
374
|
+
|
375
|
+
var invalid = {};
|
376
|
+
|
377
|
+
function invalidate() { invalid.court = true; }
|
378
|
+
function invalidateNext() { invalid.next = true; }
|
379
|
+
function invalidateScore() { invalid.score = true; }
|
380
|
+
function invalidateRows() { invalid.rows = true; }
|
381
|
+
|
382
|
+
function draw() {
|
383
|
+
ctx.save();
|
384
|
+
ctx.lineWidth = 1;
|
385
|
+
ctx.translate(0.5, 0.5); // for crisp 1px black lines
|
386
|
+
drawCourt();
|
387
|
+
drawNext();
|
388
|
+
drawScore();
|
389
|
+
drawRows();
|
390
|
+
ctx.restore();
|
391
|
+
}
|
392
|
+
|
393
|
+
function drawCourt() {
|
394
|
+
if (invalid.court) {
|
395
|
+
ctx.clearRect(0, 0, canvas.width, canvas.height);
|
396
|
+
if (playing)
|
397
|
+
drawPiece(ctx, current.type, current.x, current.y, current.dir);
|
398
|
+
var x,
|
399
|
+
y,
|
400
|
+
block;
|
401
|
+
for (y = 0; y < ny; y++) {
|
402
|
+
for (x = 0; x < nx; x++) {
|
403
|
+
if (block = getBlock(x,y))
|
404
|
+
drawBlock(ctx, x, y, block.color);
|
405
|
+
}
|
406
|
+
}
|
407
|
+
ctx.strokeRect(0, 0, nx*dx - 1, ny*dy - 1); // court boundary
|
408
|
+
invalid.court = false;
|
409
|
+
}
|
410
|
+
}
|
411
|
+
|
412
|
+
function drawNext() {
|
413
|
+
if (invalid.next) {
|
414
|
+
var padding = (nu - next.type.size) / 2; // half-arsed attempt at centering next piece display
|
415
|
+
uctx.save();
|
416
|
+
uctx.translate(0.5, 0.5);
|
417
|
+
uctx.clearRect(0, 0, nu*dx, nu*dy);
|
418
|
+
drawPiece(uctx, next.type, padding, padding, next.dir);
|
419
|
+
uctx.strokeStyle = 'black';
|
420
|
+
uctx.strokeRect(0, 0, nu*dx - 1, nu*dy - 1);
|
421
|
+
uctx.restore();
|
422
|
+
invalid.next = false;
|
423
|
+
}
|
424
|
+
}
|
425
|
+
|
426
|
+
function drawScore() {
|
427
|
+
if (invalid.score) {
|
428
|
+
html('score', ("00000" + Math.floor(vscore)).slice(-5));
|
429
|
+
invalid.score = false;
|
430
|
+
}
|
431
|
+
}
|
432
|
+
|
433
|
+
function drawRows() {
|
434
|
+
if (invalid.rows) {
|
435
|
+
html('rows', rows);
|
436
|
+
invalid.rows = false;
|
437
|
+
}
|
438
|
+
}
|
439
|
+
|
440
|
+
function drawPiece(ctx, type, x, y, dir) {
|
441
|
+
eachblock(type, x, y, dir, function(x, y) {
|
442
|
+
drawBlock(ctx, x, y, type.color);
|
443
|
+
});
|
444
|
+
}
|
445
|
+
|
446
|
+
function drawBlock(ctx, x, y, color) {
|
447
|
+
ctx.fillStyle = color;
|
448
|
+
ctx.fillRect(x*dx, y*dy, dx, dy);
|
449
|
+
ctx.strokeRect(x*dx, y*dy, dx, dy)
|
450
|
+
}
|
451
|
+
|
452
|
+
// ----------------------------------------------------------------------------
|
453
|
+
// FINALLY, lets run the game
|
454
|
+
// ----------------------------------------------------------------------------
|
455
|
+
|
456
|
+
run();
|
457
|
+
|
458
|
+
</script>
|
459
|
+
|
460
|
+
</body>
|
461
|
+
</html>
|
@@ -0,0 +1,125 @@
|
|
1
|
+
window.addEventListener('DOMContentLoaded', () => {
|
2
|
+
const tiles = Array.from(document.querySelectorAll('.tile'));
|
3
|
+
const playerDisplay = document.querySelector('.display-player');
|
4
|
+
const resetButton = document.querySelector('#reset');
|
5
|
+
const announcer = document.querySelector('.announcer');
|
6
|
+
|
7
|
+
let board = ['', '', '', '', '', '', '', '', ''];
|
8
|
+
let currentPlayer = 'X';
|
9
|
+
let isGameActive = true;
|
10
|
+
|
11
|
+
const PLAYERX_WON = 'PLAYERX_WON';
|
12
|
+
const PLAYERO_WON = 'PLAYERO_WON';
|
13
|
+
const TIE = 'TIE';
|
14
|
+
|
15
|
+
/*
|
16
|
+
Indexes within the board
|
17
|
+
[0] [1] [2]
|
18
|
+
[3] [4] [5]
|
19
|
+
[6] [7] [8]
|
20
|
+
*/
|
21
|
+
|
22
|
+
const winningConditions = [
|
23
|
+
[0, 1, 2],
|
24
|
+
[3, 4, 5],
|
25
|
+
[6, 7, 8],
|
26
|
+
[0, 3, 6],
|
27
|
+
[1, 4, 7],
|
28
|
+
[2, 5, 8],
|
29
|
+
[0, 4, 8],
|
30
|
+
[2, 4, 6]
|
31
|
+
];
|
32
|
+
|
33
|
+
function handleResultValidation() {
|
34
|
+
let roundWon = false;
|
35
|
+
for (let i = 0; i <= 7; i++) {
|
36
|
+
const winCondition = winningConditions[i];
|
37
|
+
const a = board[winCondition[0]];
|
38
|
+
const b = board[winCondition[1]];
|
39
|
+
const c = board[winCondition[2]];
|
40
|
+
if (a === '' || b === '' || c === '') {
|
41
|
+
continue;
|
42
|
+
}
|
43
|
+
if (a === b && b === c) {
|
44
|
+
roundWon = true;
|
45
|
+
break;
|
46
|
+
}
|
47
|
+
}
|
48
|
+
|
49
|
+
if (roundWon) {
|
50
|
+
announce(currentPlayer === 'X' ? PLAYERX_WON : PLAYERO_WON);
|
51
|
+
isGameActive = false;
|
52
|
+
return;
|
53
|
+
}
|
54
|
+
|
55
|
+
if (!board.includes(''))
|
56
|
+
announce(TIE);
|
57
|
+
}
|
58
|
+
|
59
|
+
const announce = (type) => {
|
60
|
+
switch(type){
|
61
|
+
case PLAYERO_WON:
|
62
|
+
announcer.innerHTML = 'Player <span class="playerO">O</span> Won';
|
63
|
+
break;
|
64
|
+
case PLAYERX_WON:
|
65
|
+
announcer.innerHTML = 'Player <span class="playerX">X</span> Won';
|
66
|
+
break;
|
67
|
+
case TIE:
|
68
|
+
announcer.innerText = 'Tie';
|
69
|
+
}
|
70
|
+
announcer.classList.remove('hide_tic_tac_toe');
|
71
|
+
};
|
72
|
+
|
73
|
+
const isValidAction = (tile) => {
|
74
|
+
if (tile.innerText === 'X' || tile.innerText === 'O'){
|
75
|
+
return false;
|
76
|
+
}
|
77
|
+
|
78
|
+
return true;
|
79
|
+
};
|
80
|
+
|
81
|
+
const updateBoard = (index) => {
|
82
|
+
board[index] = currentPlayer;
|
83
|
+
}
|
84
|
+
|
85
|
+
const changePlayer = () => {
|
86
|
+
playerDisplay.classList.remove(`player${currentPlayer}`);
|
87
|
+
currentPlayer = currentPlayer === 'X' ? 'O' : 'X';
|
88
|
+
playerDisplay.innerText = currentPlayer;
|
89
|
+
playerDisplay.classList.add(`player${currentPlayer}`);
|
90
|
+
}
|
91
|
+
|
92
|
+
const userAction = (tile, index) => {
|
93
|
+
if(isValidAction(tile) && isGameActive) {
|
94
|
+
tile.innerText = currentPlayer;
|
95
|
+
tile.classList.add(`player${currentPlayer}`);
|
96
|
+
updateBoard(index);
|
97
|
+
handleResultValidation();
|
98
|
+
changePlayer();
|
99
|
+
}
|
100
|
+
}
|
101
|
+
/*
|
102
|
+
* reset the game-board here
|
103
|
+
*/
|
104
|
+
const resetBoard = () => {
|
105
|
+
board = ['', '', '', '', '', '', '', '', ''];
|
106
|
+
isGameActive = true;
|
107
|
+
announcer.classList.add('hide_tic_tac_toe');
|
108
|
+
|
109
|
+
if (currentPlayer === 'O') {
|
110
|
+
changePlayer();
|
111
|
+
}
|
112
|
+
|
113
|
+
tiles.forEach(tile => {
|
114
|
+
tile.innerText = '';
|
115
|
+
tile.classList.remove('playerX');
|
116
|
+
tile.classList.remove('playerO');
|
117
|
+
});
|
118
|
+
}
|
119
|
+
|
120
|
+
tiles.forEach( (tile, index) => {
|
121
|
+
tile.addEventListener('click', () => userAction(tile, index));
|
122
|
+
});
|
123
|
+
|
124
|
+
resetButton.addEventListener('click', resetBoard);
|
125
|
+
});
|
@@ -0,0 +1,79 @@
|
|
1
|
+
* {
|
2
|
+
padding: 0;
|
3
|
+
margin: 0;
|
4
|
+
font-family: 'Itim', cursive;
|
5
|
+
}
|
6
|
+
|
7
|
+
.background {
|
8
|
+
background-color: #12181B;
|
9
|
+
height: 100vh;
|
10
|
+
padding-top: 1px;
|
11
|
+
}
|
12
|
+
|
13
|
+
.title {
|
14
|
+
color: white;
|
15
|
+
text-align: center;
|
16
|
+
font-size: 40px;
|
17
|
+
margin-top: 10%;
|
18
|
+
}
|
19
|
+
|
20
|
+
.display_for_tic_tac_toe {
|
21
|
+
color: white;
|
22
|
+
font-size: 25px;
|
23
|
+
text-align: center;
|
24
|
+
margin-top: 1em;
|
25
|
+
margin-bottom: 1em;
|
26
|
+
}
|
27
|
+
|
28
|
+
.hide_tic_tac_toe {
|
29
|
+
display: none;
|
30
|
+
}
|
31
|
+
|
32
|
+
.container_for_tic_tac_toe {
|
33
|
+
margin: 0 auto;
|
34
|
+
display: grid;
|
35
|
+
grid-template-columns: 33% 33% 33%;
|
36
|
+
grid-template-rows: 33% 33% 33%;
|
37
|
+
max-width: 300px;
|
38
|
+
}
|
39
|
+
|
40
|
+
.tile {
|
41
|
+
border: 1px solid white;
|
42
|
+
min-width: 100px;
|
43
|
+
min-height: 100px;
|
44
|
+
display: flex;
|
45
|
+
justify-content: center;
|
46
|
+
align-items: center;
|
47
|
+
font-size: 50px;
|
48
|
+
cursor: pointer;
|
49
|
+
}
|
50
|
+
|
51
|
+
.playerX {
|
52
|
+
color: #09C372;
|
53
|
+
}
|
54
|
+
|
55
|
+
.playerO {
|
56
|
+
color: #498AFB;
|
57
|
+
}
|
58
|
+
|
59
|
+
.controls_for_tic_tac_toe {
|
60
|
+
display: flex;
|
61
|
+
flex-direction: row;
|
62
|
+
justify-content: center;
|
63
|
+
align-items: center;
|
64
|
+
margin-top: 1em;
|
65
|
+
}
|
66
|
+
|
67
|
+
.controls_for_tic_tac_toe button {
|
68
|
+
color: white;
|
69
|
+
padding: 8px;
|
70
|
+
border-radius: 8px;
|
71
|
+
border: none;
|
72
|
+
font-size: 20px;
|
73
|
+
margin-left: 1em;
|
74
|
+
cursor: pointer;
|
75
|
+
}
|
76
|
+
|
77
|
+
#reset_for_tic_tac_toe {
|
78
|
+
background-color: #FF3860;
|
79
|
+
}
|