brick-engine-js 1.0.2 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (132) hide show
  1. package/dist/app.js +5028 -1
  2. package/dist/app.js.map +1 -1
  3. package/dist/bootstrap.d.ts +24 -0
  4. package/dist/brick-engine.js +4442 -1
  5. package/dist/brick-engine.js.map +1 -1
  6. package/dist/css/{app.743066d8e4172b0e73f9.css → app.bundle.css} +1 -1
  7. package/dist/css/app.bundle.css.map +1 -0
  8. package/dist/docs/GAME_DEVELOPER_GUIDE.html +1 -1
  9. package/dist/docs/brick-engine-guide.html +1 -1
  10. package/dist/docs/getting-started.html +1 -1
  11. package/dist/docs/jsdoc_standard.html +1 -1
  12. package/dist/docs/publishing.html +1 -1
  13. package/dist/docs/reference/interfaces/modules/Session.html +1 -1
  14. package/dist/docs/reference/modules/GameMenu.html +1 -1
  15. package/dist/docs/reference/modules/GameSession.html +1 -1
  16. package/dist/docs/reference/modules/InitialStateSnapshot.html +1 -1
  17. package/dist/docs/reference/modules/SessionModal.html +1 -1
  18. package/dist/docs/testing_best_practices.html +1 -1
  19. package/dist/index.html +15 -1
  20. package/dist/main.d.ts +1 -3
  21. package/dist/menu/GameMenuSingleton.d.ts +23 -0
  22. package/dist/vendor/p5.min.js +1 -1
  23. package/package.json +2 -1
  24. package/public/CNAME +1 -0
  25. package/public/docs/GAME_DEVELOPER_GUIDE.html +727 -0
  26. package/public/docs/brick-engine-guide.html +610 -0
  27. package/public/docs/diagrams/lifecycle.mmd +19 -0
  28. package/public/docs/documentation_style_guide.html +994 -0
  29. package/public/docs/getting-started.html +648 -0
  30. package/public/docs/images/lifecycle.svg +1 -0
  31. package/public/docs/index.html +593 -0
  32. package/public/docs/jsdoc_standard.html +656 -0
  33. package/public/docs/publishing.html +573 -0
  34. package/public/docs/reference/enums/Color.html +533 -0
  35. package/public/docs/reference/enums/ControlEventType.html +505 -0
  36. package/public/docs/reference/enums/ControlKey.html +529 -0
  37. package/public/docs/reference/enums/FontAlignment.html +545 -0
  38. package/public/docs/reference/enums/FontSize.html +517 -0
  39. package/public/docs/reference/enums/Sound.html +558 -0
  40. package/public/docs/reference/enums/StateProperty.html +525 -0
  41. package/public/docs/reference/helpers/CellHelper.html +520 -0
  42. package/public/docs/reference/helpers/ControlInputHandlerHelper.html +569 -0
  43. package/public/docs/reference/helpers/CoordinateHelper.html +703 -0
  44. package/public/docs/reference/helpers/RelativeValuesHelper.html +560 -0
  45. package/public/docs/reference/interfaces/Debuggable.html +501 -0
  46. package/public/docs/reference/interfaces/GameModules.html +544 -0
  47. package/public/docs/reference/interfaces/Initializable.html +495 -0
  48. package/public/docs/reference/interfaces/RendererInitializable.html +517 -0
  49. package/public/docs/reference/interfaces/StateSyncable.html +542 -0
  50. package/public/docs/reference/interfaces/modules/Control.html +648 -0
  51. package/public/docs/reference/interfaces/modules/Grid.html +1256 -0
  52. package/public/docs/reference/interfaces/modules/Renderer.html +522 -0
  53. package/public/docs/reference/interfaces/modules/RendererComposite.html +577 -0
  54. package/public/docs/reference/interfaces/modules/Score.html +669 -0
  55. package/public/docs/reference/interfaces/modules/Session.html +585 -0
  56. package/public/docs/reference/interfaces/modules/State.html +897 -0
  57. package/public/docs/reference/interfaces/modules/Text.html +668 -0
  58. package/public/docs/reference/interfaces/modules/Time.html +684 -0
  59. package/public/docs/reference/modules/Debugger.html +579 -0
  60. package/public/docs/reference/modules/DisplayRenderer.html +557 -0
  61. package/public/docs/reference/modules/Game.html +909 -0
  62. package/public/docs/reference/modules/GameControl.html +716 -0
  63. package/public/docs/reference/modules/GameGrid.html +1910 -0
  64. package/public/docs/reference/modules/GameHudGrid.html +508 -0
  65. package/public/docs/reference/modules/GameMenu.html +538 -0
  66. package/public/docs/reference/modules/GameRenderer.html +589 -0
  67. package/public/docs/reference/modules/GameScore.html +664 -0
  68. package/public/docs/reference/modules/GameSession.html +533 -0
  69. package/public/docs/reference/modules/GameSound.html +636 -0
  70. package/public/docs/reference/modules/GameState.html +922 -0
  71. package/public/docs/reference/modules/GameText.html +701 -0
  72. package/public/docs/reference/modules/GameTime.html +696 -0
  73. package/public/docs/reference/modules/HudRenderer.html +568 -0
  74. package/public/docs/reference/modules/InitialStateSnapshot.html +557 -0
  75. package/public/docs/reference/modules/SessionModal.html +520 -0
  76. package/public/docs/reference/types/Axis.html +505 -0
  77. package/public/docs/reference/types/Cell.html +514 -0
  78. package/public/docs/reference/types/ControlCallback.html +488 -0
  79. package/public/docs/reference/types/Coordinate.html +510 -0
  80. package/public/docs/reference/types/GameEntry.html +514 -0
  81. package/public/docs/reference/types/GameEvent.html +514 -0
  82. package/public/docs/reference/types/Piece.html +506 -0
  83. package/public/docs/reference/types/RendererMetrics.html +514 -0
  84. package/public/docs/reference/types/Vector.html +509 -0
  85. package/public/docs/testing_best_practices.html +770 -0
  86. package/public/favicon.ico +0 -0
  87. package/public/fonts/digital-7.monoitalic.ttf +0 -0
  88. package/public/images/cell.svg +32 -0
  89. package/public/images/close.png +0 -0
  90. package/public/images/games.png +0 -0
  91. package/public/images/github.png +0 -0
  92. package/public/images/letter-a.png +0 -0
  93. package/public/images/letter-d.png +0 -0
  94. package/public/images/letter-j.png +0 -0
  95. package/public/images/letter-s.png +0 -0
  96. package/public/images/letter-w.png +0 -0
  97. package/public/images/meta-image.png +0 -0
  98. package/public/images/number-1.png +0 -0
  99. package/public/images/number-2.png +0 -0
  100. package/public/images/number-3.png +0 -0
  101. package/public/images/number-4.png +0 -0
  102. package/public/images/number-5.png +0 -0
  103. package/public/images/number-6.png +0 -0
  104. package/public/images/splash.gif +0 -0
  105. package/public/index.html +15 -0
  106. package/public/sounds/sound_00.wav +0 -0
  107. package/public/sounds/sound_01.wav +0 -0
  108. package/public/sounds/sound_02.wav +0 -0
  109. package/public/sounds/sound_03.wav +0 -0
  110. package/public/sounds/sound_04.wav +0 -0
  111. package/public/sounds/sound_05.wav +0 -0
  112. package/public/sounds/sound_06.wav +0 -0
  113. package/public/sounds/sound_07.wav +0 -0
  114. package/public/sounds/sound_08.wav +0 -0
  115. package/public/sounds/sound_09.wav +0 -0
  116. package/public/sounds/sound_10.wav +0 -0
  117. package/public/sounds/sound_11.wav +0 -0
  118. package/public/sounds/sound_12.wav +0 -0
  119. package/public/sounds/sound_13.wav +0 -0
  120. package/public/sounds/sound_14.wav +0 -0
  121. package/public/sounds/sound_15.wav +0 -0
  122. package/public/style/body.css +86 -0
  123. package/public/style/buttons.css +233 -0
  124. package/public/style/debugger.css +117 -0
  125. package/public/style/sessionModal.css +155 -0
  126. package/public/style/sourceCodeAndCommands.css +74 -0
  127. package/public/style/splash.css +13 -0
  128. package/public/style/theme.css +137 -0
  129. package/dist/config/env.d.ts +0 -2
  130. package/dist/css/app.743066d8e4172b0e73f9.css.map +0 -1
  131. package/dist/main.test.d.ts +0 -1
  132. /package/dist/{config/env.test.d.ts → bootstrap.test.d.ts} +0 -0
@@ -0,0 +1,155 @@
1
+ #modal-background {
2
+ position: absolute;
3
+ inset: 0;
4
+ background-color: rgba(0, 0, 0, 0.5);
5
+ z-index: 999;
6
+ display: flex;
7
+ justify-content: center;
8
+ align-items: center;
9
+ }
10
+
11
+ #modal-background.hidden {
12
+ display: none;
13
+ }
14
+
15
+ #session-modal {
16
+ width: 80%;
17
+ max-width: 500px;
18
+ height: 44%;
19
+ max-height: 360px;
20
+ min-width: 320px;
21
+ min-height: 280px;
22
+ position: relative;
23
+ overflow: hidden;
24
+
25
+ display: flex;
26
+ flex-direction: column;
27
+ align-items: center;
28
+ box-sizing: border-box;
29
+ padding: 1rem 0;
30
+
31
+ background-color: var(--main-color);
32
+
33
+ border-radius: var(--border-radius);
34
+ border: var(--border);
35
+
36
+ box-shadow:
37
+ calc(var(--width) * -0.03) calc(var(--width) * 0.03) var(--dispersion) black,
38
+ calc(var(--width) * -0.02) calc(var(--width) * 0.02) var(--dispersion) var(--color-shadow-reflexion) inset,
39
+ calc(var(--width) * 0.01) calc(var(--width) * -0.01) var(--dispersion) var(--color-shadow) inset;
40
+ }
41
+
42
+ #session-modal-frame {
43
+ border: var(--border);
44
+ border-radius: var(--border-radius);
45
+
46
+ position: relative;
47
+
48
+ width: 90%;
49
+ flex: 1;
50
+ margin: 1rem 0;
51
+ min-height: 0;
52
+
53
+ display: flex;
54
+ justify-content: center;
55
+ align-items: center;
56
+ }
57
+
58
+ #session-modal-frame > p {
59
+ position: absolute;
60
+ top: 0;
61
+ transform: translateY(-50%);
62
+
63
+ text-align: center;
64
+
65
+ font-family: 'retro-gamming';
66
+ font-weight: bold;
67
+ font-size: clamp(1rem, calc(var(--height) * 0.03), 1.4rem);
68
+
69
+ background-color: var(--main-color);
70
+ padding: 0 calc(var(--width) * 0.02);
71
+
72
+ text-shadow:
73
+ calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--color-shadow),
74
+ calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--color-shadow-reflexion);
75
+ }
76
+
77
+ #session-modal-screen {
78
+ width: 90%;
79
+ height: 80%;
80
+
81
+ border: var(--border);
82
+ box-shadow:
83
+ calc(var(--width) * -0.01) calc(var(--width) * 0.01) var(--dispersion) var(--color-shadow),
84
+ calc(var(--width) * 0.01) calc(var(--width) * -0.01) var(--dispersion) var(--color-shadow-reflexion);
85
+
86
+ background-image: url('../images/cell.svg');
87
+ background-size: 3.7%;
88
+ background-repeat: repeat;
89
+
90
+ display: flex;
91
+ justify-content: center;
92
+ align-items: center;
93
+ }
94
+
95
+ #session-modal-screen > p {
96
+ text-align: center;
97
+
98
+ font-family: 'retro-gamming';
99
+ font-size: 1.5rem;
100
+
101
+ padding: 0 calc(var(--width) * 0.02);
102
+ }
103
+
104
+ #session-modal-screen > p > span {
105
+ font-size: 1.8rem;
106
+ padding: 0 calc(var(--width) * 0.02);
107
+ }
108
+
109
+ #session-modal-buttons {
110
+ width: 100%;
111
+ padding-bottom: 0.5rem;
112
+
113
+ display: flex;
114
+ justify-content: center;
115
+ align-items: center;
116
+
117
+ gap: clamp(1rem, 5vw, 2.5rem);
118
+ }
119
+
120
+ .session-modal-button:active {
121
+ box-shadow:
122
+ calc(var(--width) * -0.005) calc(var(--width) * 0.005) var(--dispersion) var(--color-shadow),
123
+ calc(var(--width) * -0.004) calc(var(--width) * 0.004) var(--dispersion) var(--button-color-reflexion) inset;
124
+ transform: translate(calc(var(--width) * -0.005), calc(var(--width) * 0.005));
125
+ }
126
+
127
+ .session-modal-button {
128
+ width: 35%;
129
+ max-width: 150px;
130
+ padding: 0.8rem 0;
131
+
132
+ border: var(--border);
133
+ border-radius: var(--border-radius);
134
+
135
+ background-color: var(--button-color);
136
+ box-shadow:
137
+ calc(var(--width) * -0.015) calc(var(--width) * 0.015) var(--dispersion) var(--color-shadow),
138
+ calc(var(--width) * -0.0175) calc(var(--width) * 0.0175) var(--dispersion) var(--button-color-reflexion) inset;
139
+
140
+ font-family: 'retro-gamming';
141
+ color: white;
142
+ text-align: center;
143
+
144
+ user-select: none;
145
+
146
+ font-size: 1rem;
147
+
148
+ text-shadow:
149
+ calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--button-color-shadow),
150
+ calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--button-color-reflexion);
151
+
152
+ transition:
153
+ transform var(--button-animation-duration),
154
+ box-shadow var(--button-animation-duration);
155
+ }
@@ -0,0 +1,74 @@
1
+ #source-code {
2
+ position: absolute;
3
+ top: 2%;
4
+ right: 2%;
5
+ }
6
+
7
+ #controls {
8
+ position: absolute;
9
+ top: 2%;
10
+ left: 2%;
11
+ }
12
+
13
+ #source-code,
14
+ #controls {
15
+ background-color: var(--main-color);
16
+ padding: 0.75rem;
17
+ border-radius: 1.5rem;
18
+ cursor: pointer;
19
+ box-sizing: content-box;
20
+ }
21
+
22
+ #source-code > #source-code-button,
23
+ #controls > #controls-button {
24
+ display: flex;
25
+ justify-content: center;
26
+ align-items: center;
27
+ }
28
+
29
+ #source-code > #source-code-button > img,
30
+ #controls > #controls-button > img {
31
+ width: 2.5rem;
32
+ filter: invert();
33
+ }
34
+ #source-code:hover,
35
+ #controls:hover {
36
+ background-color: var(--color-shadow-reflexion);
37
+ }
38
+ #source-code:active,
39
+ #controls:active {
40
+ filter: brightness(1.15);
41
+ }
42
+
43
+ #source-code::after,
44
+ #controls::after {
45
+ font-family: 'retro-gamming';
46
+ padding: 0.5rem;
47
+ width: 6rem;
48
+ background-color: white;
49
+ text-align: center;
50
+ border-radius: 0.25rem;
51
+ border: 1px black solid;
52
+ box-shadow: 0.25rem 0.25rem black;
53
+ opacity: 0;
54
+ transition: 0.25s opacity;
55
+ }
56
+
57
+ #source-code:hover::after,
58
+ #controls:hover::after {
59
+ opacity: 1;
60
+ }
61
+
62
+ #source-code::after {
63
+ content: 'source code';
64
+ position: absolute;
65
+ top: 75px;
66
+ left: -65px;
67
+ }
68
+
69
+ #controls::after {
70
+ content: 'Controls';
71
+ position: absolute;
72
+ top: 75px;
73
+ left: 15px;
74
+ }
@@ -0,0 +1,13 @@
1
+ #splash {
2
+ position: absolute;
3
+ top: 0;
4
+ left: 0;
5
+ right: 0;
6
+ bottom: 0;
7
+ background-color: black;
8
+ opacity: 0.85;
9
+ z-index: 1000;
10
+ display: flex;
11
+ justify-content: center;
12
+ align-items: center;
13
+ }
@@ -0,0 +1,137 @@
1
+ @font-face {
2
+ font-family: retro-gamming;
3
+ src: url(./../fonts/digital-7.monoitalic.ttf);
4
+ }
5
+
6
+ * {
7
+ margin: 0;
8
+ padding: 0;
9
+ box-sizing: content-box;
10
+ user-select: none;
11
+ }
12
+
13
+ body {
14
+ width: 100vw;
15
+ height: 100vh;
16
+
17
+ display: flex;
18
+ justify-content: center;
19
+ align-items: center;
20
+
21
+ background: rgb(0, 158, 247);
22
+ background: linear-gradient(300deg, rgb(48, 179, 255) 0%, rgba(0, 158, 247, 1) 100%);
23
+ }
24
+
25
+ #version {
26
+ font-family: 'retro-gamming';
27
+ font-size: 1rem;
28
+ color: white;
29
+ position: absolute;
30
+ bottom: 1rem;
31
+ right: 1rem;
32
+ }
33
+
34
+ @media only screen and (max-width: 600px) {
35
+ #source-code,
36
+ #controls {
37
+ display: none;
38
+ }
39
+
40
+ body,
41
+ #container {
42
+ width: 100% !important;
43
+ height: 100vh !important;
44
+ /* height: 100dvh !important; */
45
+ border-radius: 0px !important;
46
+ }
47
+
48
+ #frame > canvas {
49
+ width: 85% !important;
50
+ height: auto !important;
51
+ aspect-ratio: 9/10 !important;
52
+ }
53
+
54
+ #frame {
55
+ width: 85% !important;
56
+ padding: 7.5%¨ !important;
57
+ }
58
+
59
+ #small-button-container {
60
+ margin-top: 3.5%;
61
+ }
62
+ #direction-vertical-container,
63
+ #direction-horizontal-container {
64
+ gap: calc(var(--width) * 0.13);
65
+ }
66
+
67
+ #large-button-container {
68
+ flex-shrink: 1.75;
69
+ }
70
+
71
+ .sm-btn {
72
+ width: var(--sm-button-size-mobile) !important;
73
+ height: var(--sm-button-size-mobile) !important;
74
+ }
75
+
76
+ .btn {
77
+ width: var(--button-size-mobile) !important;
78
+ height: var(--button-size-mobile) !important;
79
+ margin: var(--button-size-mobile-spacing) !important;
80
+ font-size: var(--button-size-mobile-font-size) !important;
81
+ }
82
+
83
+ .lg-btn {
84
+ width: var(--lg-button-size-mobile) !important;
85
+ height: var(--lg-button-size-mobile) !important;
86
+ font-size: var(--lg-button-size-mobile-font-size) !important;
87
+ }
88
+
89
+ .sm-btn-p {
90
+ font-size: var(--sm-button-size-mobile-font-size) !important;
91
+ line-height: var(--sm-button-size-mobile-line-height) !important;
92
+ }
93
+ }
94
+
95
+ @media only screen and (max-width: 990px) {
96
+ #wasd {
97
+ width: 10.5rem !important;
98
+ }
99
+
100
+ .key {
101
+ width: 3rem !important;
102
+ }
103
+
104
+ .key-description {
105
+ font-size: 1.5rem !important;
106
+ }
107
+
108
+ .command {
109
+ gap: 0.5rem !important;
110
+ }
111
+ }
112
+
113
+ @media only screen and (max-width: 815px) {
114
+ #controls-tutorial {
115
+ gap: 0rem;
116
+ flex-direction: column !important;
117
+ }
118
+ }
119
+
120
+ @media only screen and (max-width: 750px) {
121
+ .key-description {
122
+ font-size: 1.2rem !important;
123
+ }
124
+ }
125
+
126
+ @media only screen and (max-width: 650px) {
127
+ #wasd {
128
+ width: 9rem !important;
129
+ }
130
+
131
+ .key {
132
+ width: 2.5rem !important;
133
+ }
134
+ .key-description {
135
+ font-size: 1rem !important;
136
+ }
137
+ }
@@ -1,2 +0,0 @@
1
- export declare function isClientMode(): boolean;
2
- export declare function isServerMode(): boolean;
@@ -1 +0,0 @@
1
- {"version":3,"file":"css/app.743066d8e4172b0e73f9.css","mappings":"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","sources":["webpack://BrickEngine/./public/style/body.css","webpack://BrickEngine/./public/style/buttons.css","webpack://BrickEngine/./public/style/debugger.css","webpack://BrickEngine/./public/style/sessionModal.css","webpack://BrickEngine/./public/style/sourceCodeAndCommands.css","webpack://BrickEngine/./public/style/splash.css","webpack://BrickEngine/./public/style/theme.css"],"sourcesContent":["/* MAIN BODY */\n\n#brick-game {\n display: flex;\n justify-content: center;\n align-items: center;\n width: 100%;\n height: 100%;\n}\n\n#container {\n width: var(--width);\n height: var(--height);\n\n background-color: var(--main-color);\n\n border-radius: var(--border-radius);\n border: var(--border);\n\n box-sizing: border-box;\n margin: auto;\n position: relative;\n\n display: flex;\n flex-direction: column;\n\n box-shadow:\n calc(var(--width) * -0.03) calc(var(--width) * 0.03) var(--dispersion) black,\n calc(var(--width) * -0.02) calc(var(--width) * 0.02) var(--dispersion) var(--color-shadow-reflexion) inset,\n calc(var(--width) * 0.01) calc(var(--width) * -0.01) var(--dispersion) var(--color-shadow) inset;\n}\n\n#brick-game-canvas {\n border: var(--border);\n box-shadow:\n calc(var(--width) * -0.01) calc(var(--width) * 0.01) var(--dispersion) var(--color-shadow),\n calc(var(--width) * 0.01) calc(var(--width) * -0.01) var(--dispersion) var(--color-shadow-reflexion);\n}\n\n/* FRAME */\n\n#frame {\n border: var(--border);\n border-radius: var(--border-radius);\n\n position: relative;\n\n width: calc(var(--width) * 0.85);\n height: auto;\n aspect-ratio: 9/10;\n margin: 7.5%;\n margin-bottom: 3.75%;\n\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n#frame div {\n position: absolute;\n top: calc(var(--height) * -0.02);\n left: 27.5%;\n\n width: 45%;\n height: calc(var(--height) * 0.03);\n\n background-color: var(--main-color);\n\n display: flex;\n justify-content: center;\n\n padding-top: calc(var(--height) * 0.005);\n padding-bottom: 0;\n}\n\n#frame p {\n text-align: center;\n\n font-family: 'retro-gamming';\n font-weight: bold;\n font-size: calc(var(--height) * 0.03);\n\n text-shadow:\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--color-shadow),\n calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--color-shadow-reflexion);\n}\n","/* BUTTONS */\n\n.sm-btn,\n.btn,\n.lg-btn {\n z-index: 999;\n}\n\n.sm-btn {\n box-shadow:\n calc(var(--width) * -0.0075) calc(var(--width) * 0.0075) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.01) calc(var(--width) * 0.01) var(--dispersion) var(--button-color-reflexion) inset;\n}\n\n.sm-btn:active {\n box-shadow:\n calc(var(--width) * -0.004) calc(var(--width) * 0.004) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) var(--dispersion) var(--button-color-reflexion) inset;\n transform: translateX(calc(var(--width) * -0.0025)) translateY(calc(var(--width) * 0.0025));\n}\n\n.btn {\n box-shadow:\n calc(var(--width) * -0.015) calc(var(--width) * 0.015) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.0175) calc(var(--width) * 0.0175) var(--dispersion) var(--button-color-reflexion) inset;\n}\n\n.btn:active {\n box-shadow:\n calc(var(--width) * -0.004) calc(var(--width) * 0.004) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) var(--dispersion) var(--button-color-reflexion) inset;\n transform: translateX(calc(var(--width) * -0.005)) translateY(calc(var(--width) * 0.005));\n}\n\n.lg-btn {\n box-shadow:\n calc(var(--width) * -0.02) calc(var(--width) * 0.02) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.0175) calc(var(--width) * 0.0175) var(--dispersion) var(--button-color-reflexion) inset;\n}\n\n.lg-btn:active {\n box-shadow:\n calc(var(--width) * -0.005) calc(var(--width) * 0.005) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.004) calc(var(--width) * 0.004) var(--dispersion) var(--button-color-reflexion) inset;\n transform: translateX(calc(var(--width) * -0.0075)) translateY(calc(var(--width) * 0.0075));\n}\n\n.sm-btn-p,\n.btn-p,\n.lg-btn-p {\n font-family: 'retro-gamming';\n color: white;\n text-align: center;\n\n user-select: none;\n}\n\n.sm-btn-container,\n.btn-container,\n.lg-btn-container {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n.sm-btn,\n.btn,\n.lg-btn {\n outline: none;\n\n border-radius: 50%;\n border: var(--button-border);\n\n transition-property: transform box-shadow;\n transition-duration: var(--button-animation-duration);\n\n background-color: var(--button-color);\n}\n\n.sm-btn-container {\n flex-direction: column;\n}\n\n.sm-btn {\n width: var(--sm-button-size);\n height: var(--sm-button-size);\n}\n\n.sm-btn-p {\n font-family: 'retro-gamming';\n color: white;\n text-align: center;\n\n user-select: none;\n\n font-size: calc(var(--width) * 0.03);\n\n /* width: calc(var(--width) * 0.08); */\n margin-top: calc(var(--width) * 0.01);\n\n line-height: calc(var(--width) * 0.03);\n height: calc(var(--width) * 0.06);\n\n text-shadow:\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--color-shadow),\n calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--color-shadow-reflexion);\n}\n\n.btn-container {\n flex-direction: column-reverse;\n}\n\n.btn {\n width: var(--button-size);\n height: var(--button-size);\n}\n\n.btn-p {\n font-weight: bold;\n font-size: calc(var(--width) * 0.04);\n margin-bottom: calc(var(--width) * 0.015);\n line-height: calc(var(--width) * 0.03);\n}\n\n.lg-btn-container {\n flex-direction: column;\n}\n\n.lg-btn {\n width: var(--lg-button-size);\n height: var(--lg-button-size);\n}\n\n.lg-btn-p {\n font-weight: bold;\n font-size: calc(var(--width) * 0.05);\n margin-bottom: calc(var(--width) * 0.015);\n line-height: calc(var(--width) * 0.03);\n}\n\n.btn,\n.lg-btn {\n font-family: 'retro-gamming';\n font-size: calc(var(--width) * 0.045);\n font-weight: bold;\n color: white;\n text-shadow:\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--button-color-shadow),\n calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--button-color-reflexion);\n}\n\n/* BUTTON CONTAINERS */\n\n#button-container,\n#small-button-container,\n#inner-button-container,\n#medium-button-container,\n#large-button-container {\n width: 100%;\n height: auto;\n}\n\n#button-container {\n display: flex;\n flex-grow: 1;\n flex-direction: column;\n}\n\n#small-button-container {\n display: flex;\n flex-grow: 0.1;\n justify-content: space-evenly;\n\n max-height: 150px;\n\n position: relative;\n}\n\n.sm-btn-container-top {\n position: relative;\n top: -20%;\n}\n\n.sm-btn-container-bottom {\n position: relative;\n bottom: -20%;\n}\n\n#inner-button-container {\n display: flex;\n flex-grow: 1;\n flex-direction: row;\n}\n\n#medium-button-container {\n display: flex;\n flex-shrink: 1;\n\n position: relative;\n}\n\n#large-button-container {\n display: flex;\n justify-content: center;\n align-items: center;\n\n flex-shrink: 1.5;\n}\n\n#direction-vertical-container,\n#direction-horizontal-container {\n width: 100%;\n height: 100%;\n\n display: flex;\n justify-content: center;\n align-items: center;\n gap: calc(var(--width) * 0.115);\n\n position: absolute;\n top: 0;\n bottom: 0;\n left: 0;\n right: 0;\n}\n\n#direction-vertical-container {\n flex-direction: column;\n}\n\n#direction-horizontal-container {\n flex-direction: row;\n}\n","#debugger {\n font-family: 'retro-gamming', monospace;\n background-color: rgba(0, 0, 0, 0.9);\n color: #0f0; /* Green phosphor */\n border: 2px solid #0f0;\n box-shadow: 0 0 10px #0f0;\n padding: 10px;\n position: absolute;\n top: 10px;\n right: 10px;\n width: 300px;\n max-height: calc(100vh - 40px);\n overflow-y: auto;\n user-select: none;\n -webkit-user-select: none;\n z-index: 9999;\n font-size: 14px;\n /* text-shadow: 0 0 2px #0f0; */\n}\n\n/* Custom Scrollbar */\n#debugger::-webkit-scrollbar {\n width: 8px;\n}\n\n#debugger::-webkit-scrollbar-track {\n background: #001100;\n}\n\n#debugger::-webkit-scrollbar-thumb {\n background: #0f0;\n border-radius: 4px;\n}\n\n#debugger::-webkit-scrollbar-thumb:hover {\n background: #0a0;\n}\n\n/* Summary / Header */\n#debugger-summary {\n font-weight: bold;\n font-size: 16px;\n cursor: pointer;\n margin-bottom: 10px;\n /* text-transform: uppercase; */\n border-bottom: 1px dashed #0f0;\n padding-bottom: 5px;\n list-style: none;\n}\n\n/* Module Sections */\n.debugger-module {\n margin-bottom: 10px;\n border-left: 1px solid #004400;\n padding-left: 8px;\n}\n\n.debugger-module-summary {\n cursor: pointer;\n font-weight: bold;\n color: #cfc;\n margin-bottom: 4px;\n}\n\n.debugger-module-summary:hover {\n color: #fff;\n /* text-shadow: 0 0 4px #fff; */\n}\n\n/* Data Rows */\n.debugger-container {\n display: flex;\n justify-content: space-between;\n padding: 2px 0;\n border-bottom: 1px dotted #003300;\n}\n\n/* Closed State */\n#debugger:not([open]) {\n width: auto;\n height: auto;\n max-height: none;\n padding: 5px 10px;\n border: 1px solid #0f0;\n background-color: rgba(0, 0, 0, 0.5);\n box-shadow: none;\n}\n\n#debugger:not([open]) #debugger-summary {\n margin-bottom: 0;\n border-bottom: none;\n padding-bottom: 0;\n}\n\n.debugger-container:hover {\n background-color: rgba(0, 255, 0, 0.05);\n}\n\n.debugger-container.highlight {\n background-color: transparent;\n color: #fff;\n /* text-shadow: 0 0 5px #fff; */\n border-bottom: 1px solid #fff;\n}\n\n.debugger-container.highlight span {\n color: #fff;\n}\n\n.debugger-container p {\n margin: 0;\n opacity: 0.8;\n}\n\n.debugger-container span {\n font-weight: bold;\n}\n","#modal-background {\n position: absolute;\n inset: 0;\n background-color: rgba(0, 0, 0, 0.5);\n z-index: 999;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n#modal-background.hidden {\n display: none;\n}\n\n#session-modal {\n width: 80%;\n max-width: 500px;\n height: 44%;\n max-height: 360px;\n min-width: 320px;\n min-height: 280px;\n position: relative;\n overflow: hidden;\n\n display: flex;\n flex-direction: column;\n align-items: center;\n box-sizing: border-box;\n padding: 1rem 0;\n\n background-color: var(--main-color);\n\n border-radius: var(--border-radius);\n border: var(--border);\n\n box-shadow:\n calc(var(--width) * -0.03) calc(var(--width) * 0.03) var(--dispersion) black,\n calc(var(--width) * -0.02) calc(var(--width) * 0.02) var(--dispersion) var(--color-shadow-reflexion) inset,\n calc(var(--width) * 0.01) calc(var(--width) * -0.01) var(--dispersion) var(--color-shadow) inset;\n}\n\n#session-modal-frame {\n border: var(--border);\n border-radius: var(--border-radius);\n\n position: relative;\n\n width: 90%;\n flex: 1;\n margin: 1rem 0;\n min-height: 0;\n\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n#session-modal-frame > p {\n position: absolute;\n top: 0;\n transform: translateY(-50%);\n\n text-align: center;\n\n font-family: 'retro-gamming';\n font-weight: bold;\n font-size: clamp(1rem, calc(var(--height) * 0.03), 1.4rem);\n\n background-color: var(--main-color);\n padding: 0 calc(var(--width) * 0.02);\n\n text-shadow:\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--color-shadow),\n calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--color-shadow-reflexion);\n}\n\n#session-modal-screen {\n width: 90%;\n height: 80%;\n\n border: var(--border);\n box-shadow:\n calc(var(--width) * -0.01) calc(var(--width) * 0.01) var(--dispersion) var(--color-shadow),\n calc(var(--width) * 0.01) calc(var(--width) * -0.01) var(--dispersion) var(--color-shadow-reflexion);\n\n background-image: url('../images/cell.svg');\n background-size: 3.7%;\n background-repeat: repeat;\n\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n#session-modal-screen > p {\n text-align: center;\n\n font-family: 'retro-gamming';\n font-size: 1.5rem;\n\n padding: 0 calc(var(--width) * 0.02);\n}\n\n#session-modal-screen > p > span {\n font-size: 1.8rem;\n padding: 0 calc(var(--width) * 0.02);\n}\n\n#session-modal-buttons {\n width: 100%;\n padding-bottom: 0.5rem;\n\n display: flex;\n justify-content: center;\n align-items: center;\n\n gap: clamp(1rem, 5vw, 2.5rem);\n}\n\n.session-modal-button:active {\n box-shadow:\n calc(var(--width) * -0.005) calc(var(--width) * 0.005) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.004) calc(var(--width) * 0.004) var(--dispersion) var(--button-color-reflexion) inset;\n transform: translate(calc(var(--width) * -0.005), calc(var(--width) * 0.005));\n}\n\n.session-modal-button {\n width: 35%;\n max-width: 150px;\n padding: 0.8rem 0;\n\n border: var(--border);\n border-radius: var(--border-radius);\n\n background-color: var(--button-color);\n box-shadow:\n calc(var(--width) * -0.015) calc(var(--width) * 0.015) var(--dispersion) var(--color-shadow),\n calc(var(--width) * -0.0175) calc(var(--width) * 0.0175) var(--dispersion) var(--button-color-reflexion) inset;\n\n font-family: 'retro-gamming';\n color: white;\n text-align: center;\n\n user-select: none;\n\n font-size: 1rem;\n\n text-shadow:\n calc(var(--width) * -0.003) calc(var(--width) * 0.003) 0 var(--button-color-shadow),\n calc(var(--width) * 0.002) calc(var(--width) * -0.002) 0 var(--button-color-reflexion);\n\n transition:\n transform var(--button-animation-duration),\n box-shadow var(--button-animation-duration);\n}\n","#source-code {\n position: absolute;\n top: 2%;\n right: 2%;\n}\n\n#controls {\n position: absolute;\n top: 2%;\n left: 2%;\n}\n\n#source-code,\n#controls {\n background-color: var(--main-color);\n padding: 0.75rem;\n border-radius: 1.5rem;\n cursor: pointer;\n box-sizing: content-box;\n}\n\n#source-code > #source-code-button,\n#controls > #controls-button {\n display: flex;\n justify-content: center;\n align-items: center;\n}\n\n#source-code > #source-code-button > img,\n#controls > #controls-button > img {\n width: 2.5rem;\n filter: invert();\n}\n#source-code:hover,\n#controls:hover {\n background-color: var(--color-shadow-reflexion);\n}\n#source-code:active,\n#controls:active {\n filter: brightness(1.15);\n}\n\n#source-code::after,\n#controls::after {\n font-family: 'retro-gamming';\n padding: 0.5rem;\n width: 6rem;\n background-color: white;\n text-align: center;\n border-radius: 0.25rem;\n border: 1px black solid;\n box-shadow: 0.25rem 0.25rem black;\n opacity: 0;\n transition: 0.25s opacity;\n}\n\n#source-code:hover::after,\n#controls:hover::after {\n opacity: 1;\n}\n\n#source-code::after {\n content: 'source code';\n position: absolute;\n top: 75px;\n left: -65px;\n}\n\n#controls::after {\n content: 'Controls';\n position: absolute;\n top: 75px;\n left: 15px;\n}\n","#splash {\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background-color: black;\n opacity: 0.85;\n z-index: 1000;\n display: flex;\n justify-content: center;\n align-items: center;\n}\n","@font-face {\n font-family: retro-gamming;\n src: url(./../fonts/digital-7.monoitalic.ttf);\n}\n\n* {\n margin: 0;\n padding: 0;\n box-sizing: content-box;\n user-select: none;\n}\n\nbody {\n width: 100vw;\n height: 100vh;\n\n display: flex;\n justify-content: center;\n align-items: center;\n\n background: rgb(0, 158, 247);\n background: linear-gradient(300deg, rgb(48, 179, 255) 0%, rgba(0, 158, 247, 1) 100%);\n}\n\n#version {\n font-family: 'retro-gamming';\n font-size: 1rem;\n color: white;\n position: absolute;\n bottom: 1rem;\n right: 1rem;\n}\n\n@media only screen and (max-width: 600px) {\n #source-code,\n #controls {\n display: none;\n }\n\n body,\n #container {\n width: 100% !important;\n height: 100vh !important;\n /* height: 100dvh !important; */\n border-radius: 0px !important;\n }\n\n #frame > canvas {\n width: 85% !important;\n height: auto !important;\n aspect-ratio: 9/10 !important;\n }\n\n #frame {\n width: 85% !important;\n padding: 7.5%¨ !important;\n }\n\n #small-button-container {\n margin-top: 3.5%;\n }\n #direction-vertical-container,\n #direction-horizontal-container {\n gap: calc(var(--width) * 0.13);\n }\n\n #large-button-container {\n flex-shrink: 1.75;\n }\n\n .sm-btn {\n width: var(--sm-button-size-mobile) !important;\n height: var(--sm-button-size-mobile) !important;\n }\n\n .btn {\n width: var(--button-size-mobile) !important;\n height: var(--button-size-mobile) !important;\n margin: var(--button-size-mobile-spacing) !important;\n font-size: var(--button-size-mobile-font-size) !important;\n }\n\n .lg-btn {\n width: var(--lg-button-size-mobile) !important;\n height: var(--lg-button-size-mobile) !important;\n font-size: var(--lg-button-size-mobile-font-size) !important;\n }\n\n .sm-btn-p {\n font-size: var(--sm-button-size-mobile-font-size) !important;\n line-height: var(--sm-button-size-mobile-line-height) !important;\n }\n}\n\n@media only screen and (max-width: 990px) {\n #wasd {\n width: 10.5rem !important;\n }\n\n .key {\n width: 3rem !important;\n }\n\n .key-description {\n font-size: 1.5rem !important;\n }\n\n .command {\n gap: 0.5rem !important;\n }\n}\n\n@media only screen and (max-width: 815px) {\n #controls-tutorial {\n gap: 0rem;\n flex-direction: column !important;\n }\n}\n\n@media only screen and (max-width: 750px) {\n .key-description {\n font-size: 1.2rem !important;\n }\n}\n\n@media only screen and (max-width: 650px) {\n #wasd {\n width: 9rem !important;\n }\n\n .key {\n width: 2.5rem !important;\n }\n .key-description {\n font-size: 1rem !important;\n }\n}\n"],"names":[],"sourceRoot":""}
@@ -1 +0,0 @@
1
- export {};