@benev/tact 0.1.0-3 → 0.1.0-5

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 (410) hide show
  1. package/README.md +113 -104
  2. package/package.json +7 -7
  3. package/s/core/bindings/action.ts +14 -4
  4. package/s/core/bindings/parts/defaults.ts +4 -1
  5. package/s/core/bindings/parts/lens-algo.ts +21 -13
  6. package/s/core/bindings/parts/lookup-proxies.ts +17 -0
  7. package/s/core/bindings/resolver.ts +12 -12
  8. package/s/core/bindings/sample-map.ts +25 -0
  9. package/s/core/bindings/types.ts +4 -1
  10. package/s/core/core.test.ts +46 -34
  11. package/s/core/devices/auto-gamepads.ts +8 -0
  12. package/s/core/devices/device.ts +12 -0
  13. package/s/core/devices/infra/group.ts +24 -0
  14. package/s/core/devices/infra/sampler.ts +22 -0
  15. package/s/core/devices/standard/gamepad.ts +83 -0
  16. package/s/core/{controllers → devices}/standard/index.ts +2 -1
  17. package/s/core/devices/standard/keyboard.ts +31 -0
  18. package/s/core/{controllers → devices}/standard/pointer.ts +19 -11
  19. package/s/core/devices/standard/primary.ts +20 -0
  20. package/s/core/devices/standard/stick.ts +27 -0
  21. package/s/core/{controllers/standard/virtual-gamepad.ts → devices/standard/vpad.ts} +9 -9
  22. package/s/core/{controllers → devices}/types.ts +0 -1
  23. package/s/core/hub/hub.ts +78 -62
  24. package/s/core/hub/meta-bindings.ts +23 -0
  25. package/s/core/hub/parts/connected.ts +15 -0
  26. package/s/core/hub/port.ts +26 -0
  27. package/s/core/hub/types.ts +5 -6
  28. package/s/core/index.ts +12 -14
  29. package/s/core/testing/testing.ts +19 -14
  30. package/s/deck/components/components.ts +22 -0
  31. package/s/deck/components/deck-bindings/component.ts +99 -0
  32. package/s/deck/components/deck-bindings/style.css.ts +6 -0
  33. package/s/deck/components/deck-overlay/component.ts +51 -0
  34. package/s/deck/components/deck-overlay/style.css.ts +110 -0
  35. package/s/deck/components/framework.ts +17 -0
  36. package/s/deck/deck.ts +82 -0
  37. package/s/deck/index.ts +14 -0
  38. package/s/deck/parts/catalog.ts +58 -0
  39. package/s/deck/parts/db.ts +66 -0
  40. package/s/deck/parts/device-skins/device-icons.ts +38 -0
  41. package/s/deck/parts/device-skins/device-skin.ts +29 -0
  42. package/s/deck/parts/local-storage-kv.ts +8 -0
  43. package/s/deck/parts/merge-bindings.ts +21 -0
  44. package/s/deck/parts/overlay-visibility.ts +49 -0
  45. package/s/demo/game/game.ts +85 -0
  46. package/s/demo/game/parts/agent.ts +10 -0
  47. package/s/demo/game/parts/game-bindings.ts +20 -0
  48. package/s/demo/game/parts/logic.ts +24 -0
  49. package/s/demo/game/parts/player.ts +32 -0
  50. package/s/demo/game/parts/renderer.ts +113 -0
  51. package/s/demo/game/parts/state.ts +24 -0
  52. package/s/demo/game/parts/virtual-device.ts +13 -0
  53. package/s/demo/main.bundle.ts +9 -10
  54. package/s/demo/main.css +30 -2
  55. package/s/demo/ui/theater/styles.css.ts +58 -0
  56. package/s/demo/ui/theater/view.ts +60 -0
  57. package/s/demo/ui/theater/virtual/style.css.ts +43 -0
  58. package/s/demo/ui/theater/virtual/view.ts +31 -0
  59. package/s/demo/ui/utils/loader.ts +5 -0
  60. package/s/index.html.ts +17 -7
  61. package/s/index.ts +3 -1
  62. package/s/nubs/components.ts +14 -0
  63. package/s/nubs/index.ts +6 -0
  64. package/s/nubs/lookpad/component.ts +45 -0
  65. package/s/nubs/stick/component.ts +115 -0
  66. package/s/nubs/stick/style.css.ts +70 -0
  67. package/s/nubs/{virtual-gamepad/view.ts → vpad/component.ts} +21 -11
  68. package/s/nubs/{virtual-gamepad → vpad}/styles.css.ts +5 -4
  69. package/s/utils/circular-clamp.ts +15 -0
  70. package/s/utils/dispensers.ts +20 -0
  71. package/s/utils/split-axis.ts +10 -2
  72. package/s/utils/types.ts +19 -0
  73. package/x/core/bindings/action.d.ts +3 -1
  74. package/x/core/bindings/action.js +12 -4
  75. package/x/core/bindings/action.js.map +1 -1
  76. package/x/core/bindings/parts/defaults.js +4 -1
  77. package/x/core/bindings/parts/defaults.js.map +1 -1
  78. package/x/core/bindings/parts/lens-algo.js +18 -7
  79. package/x/core/bindings/parts/lens-algo.js.map +1 -1
  80. package/x/core/bindings/parts/lookup-proxies.d.ts +1 -0
  81. package/x/core/bindings/parts/lookup-proxies.js +19 -0
  82. package/x/core/bindings/parts/lookup-proxies.js.map +1 -0
  83. package/x/core/bindings/resolver.d.ts +5 -4
  84. package/x/core/bindings/resolver.js +12 -10
  85. package/x/core/bindings/resolver.js.map +1 -1
  86. package/x/core/bindings/sample-map.d.ts +7 -0
  87. package/x/core/bindings/sample-map.js +22 -0
  88. package/x/core/bindings/sample-map.js.map +1 -0
  89. package/x/core/bindings/types.d.ts +4 -1
  90. package/x/core/core.test.d.ts +5 -4
  91. package/x/core/core.test.js +45 -34
  92. package/x/core/core.test.js.map +1 -1
  93. package/x/core/devices/auto-gamepads.d.ts +2 -0
  94. package/x/core/devices/auto-gamepads.js +6 -0
  95. package/x/core/devices/auto-gamepads.js.map +1 -0
  96. package/x/core/devices/device.d.ts +5 -0
  97. package/x/core/devices/device.js +7 -0
  98. package/x/core/devices/device.js.map +1 -0
  99. package/x/core/devices/infra/group.d.ts +8 -0
  100. package/x/core/devices/infra/group.js +21 -0
  101. package/x/core/devices/infra/group.js.map +1 -0
  102. package/x/core/devices/infra/sampler.d.ts +9 -0
  103. package/x/core/devices/infra/sampler.js +18 -0
  104. package/x/core/devices/infra/sampler.js.map +1 -0
  105. package/x/core/devices/standard/gamepad.d.ts +11 -0
  106. package/x/core/devices/standard/gamepad.js +65 -0
  107. package/x/core/devices/standard/gamepad.js.map +1 -0
  108. package/x/core/{controllers → devices}/standard/index.d.ts +2 -1
  109. package/x/core/{controllers → devices}/standard/index.js +2 -1
  110. package/x/core/devices/standard/index.js.map +1 -0
  111. package/x/core/devices/standard/keyboard.d.ts +9 -0
  112. package/x/core/devices/standard/keyboard.js +28 -0
  113. package/x/core/devices/standard/keyboard.js.map +1 -0
  114. package/x/core/devices/standard/pointer.d.ts +15 -0
  115. package/x/core/{controllers → devices}/standard/pointer.js +18 -11
  116. package/x/core/devices/standard/pointer.js.map +1 -0
  117. package/x/core/devices/standard/primary.d.ts +10 -0
  118. package/x/core/devices/standard/primary.js +17 -0
  119. package/x/core/devices/standard/primary.js.map +1 -0
  120. package/x/core/devices/standard/stick.d.ts +15 -0
  121. package/x/core/devices/standard/stick.js +24 -0
  122. package/x/core/devices/standard/stick.js.map +1 -0
  123. package/x/core/devices/standard/vpad.d.ts +7 -0
  124. package/x/core/{controllers/standard/virtual-gamepad.js → devices/standard/vpad.js} +10 -10
  125. package/x/core/devices/standard/vpad.js.map +1 -0
  126. package/x/core/{controllers → devices}/types.d.ts +0 -1
  127. package/x/core/{controllers → devices}/types.js.map +1 -1
  128. package/x/core/hub/hub.d.ts +27 -23
  129. package/x/core/hub/hub.js +71 -61
  130. package/x/core/hub/hub.js.map +1 -1
  131. package/x/core/hub/meta-bindings.d.ts +2 -0
  132. package/x/core/hub/meta-bindings.js +21 -0
  133. package/x/core/hub/meta-bindings.js.map +1 -0
  134. package/x/core/hub/parts/connected.d.ts +14 -0
  135. package/x/core/hub/parts/connected.js +12 -0
  136. package/x/core/hub/parts/connected.js.map +1 -0
  137. package/x/core/hub/port.d.ts +10 -0
  138. package/x/core/hub/port.js +19 -0
  139. package/x/core/hub/port.js.map +1 -0
  140. package/x/core/hub/types.d.ts +5 -5
  141. package/x/core/hub/types.js +1 -1
  142. package/x/core/hub/types.js.map +1 -1
  143. package/x/core/index.d.ts +12 -12
  144. package/x/core/index.js +12 -12
  145. package/x/core/index.js.map +1 -1
  146. package/x/core/testing/testing.d.ts +13 -11
  147. package/x/core/testing/testing.js +14 -13
  148. package/x/core/testing/testing.js.map +1 -1
  149. package/x/deck/components/components.d.ts +14 -0
  150. package/x/deck/components/components.js +9 -0
  151. package/x/deck/components/components.js.map +1 -0
  152. package/x/deck/components/deck-bindings/component.d.ts +6 -0
  153. package/x/deck/components/deck-bindings/component.js +83 -0
  154. package/x/deck/components/deck-bindings/component.js.map +1 -0
  155. package/x/deck/components/deck-bindings/style.css.js +5 -0
  156. package/x/deck/components/deck-bindings/style.css.js.map +1 -0
  157. package/x/deck/components/deck-overlay/component.d.ts +6 -0
  158. package/x/deck/components/deck-overlay/component.js +44 -0
  159. package/x/deck/components/deck-overlay/component.js.map +1 -0
  160. package/x/deck/components/deck-overlay/style.css.d.ts +2 -0
  161. package/x/deck/components/deck-overlay/style.css.js +109 -0
  162. package/x/deck/components/deck-overlay/style.css.js.map +1 -0
  163. package/x/deck/components/framework.d.ts +7 -0
  164. package/x/deck/components/framework.js +13 -0
  165. package/x/deck/components/framework.js.map +1 -0
  166. package/x/deck/deck.d.ts +37 -0
  167. package/x/deck/deck.js +55 -0
  168. package/x/deck/deck.js.map +1 -0
  169. package/x/deck/index.d.ts +10 -0
  170. package/x/deck/index.js +11 -0
  171. package/x/deck/index.js.map +1 -0
  172. package/x/deck/parts/catalog.d.ts +23 -0
  173. package/x/deck/parts/catalog.js +35 -0
  174. package/x/deck/parts/catalog.js.map +1 -0
  175. package/x/deck/parts/db.d.ts +20 -0
  176. package/x/deck/parts/db.js +52 -0
  177. package/x/deck/parts/db.js.map +1 -0
  178. package/x/deck/parts/device-skins/device-icons.d.ts +12 -0
  179. package/x/deck/parts/device-skins/device-icons.js +27 -0
  180. package/x/deck/parts/device-skins/device-icons.js.map +1 -0
  181. package/x/deck/parts/device-skins/device-skin.d.ts +14 -0
  182. package/x/deck/parts/device-skins/device-skin.js +22 -0
  183. package/x/deck/parts/device-skins/device-skin.js.map +1 -0
  184. package/x/deck/parts/local-storage-kv.js +6 -0
  185. package/x/deck/parts/local-storage-kv.js.map +1 -0
  186. package/x/deck/parts/merge-bindings.d.ts +2 -0
  187. package/x/deck/parts/merge-bindings.js +15 -0
  188. package/x/deck/parts/merge-bindings.js.map +1 -0
  189. package/x/deck/parts/overlay-visibility.d.ts +21 -0
  190. package/x/deck/parts/overlay-visibility.js +35 -0
  191. package/x/deck/parts/overlay-visibility.js.map +1 -0
  192. package/x/demo/game/game.d.ts +20 -0
  193. package/x/demo/game/game.js +63 -0
  194. package/x/demo/game/game.js.map +1 -0
  195. package/x/demo/game/parts/agent.d.ts +7 -0
  196. package/x/demo/game/parts/agent.js +8 -0
  197. package/x/demo/game/parts/agent.js.map +1 -0
  198. package/x/demo/game/parts/game-bindings.d.ts +15 -0
  199. package/x/demo/game/parts/game-bindings.js +10 -0
  200. package/x/demo/game/parts/game-bindings.js.map +1 -0
  201. package/x/demo/game/parts/logic.d.ts +8 -0
  202. package/x/demo/game/parts/logic.js +21 -0
  203. package/x/demo/game/parts/logic.js.map +1 -0
  204. package/x/demo/game/parts/player.d.ts +14 -0
  205. package/x/demo/game/parts/player.js +26 -0
  206. package/x/demo/game/parts/player.js.map +1 -0
  207. package/x/demo/game/parts/renderer.d.ts +13 -0
  208. package/x/demo/game/parts/renderer.js +91 -0
  209. package/x/demo/game/parts/renderer.js.map +1 -0
  210. package/x/demo/game/parts/state.d.ts +8 -0
  211. package/x/demo/game/parts/state.js +20 -0
  212. package/x/demo/game/parts/state.js.map +1 -0
  213. package/x/demo/game/parts/virtual-device.d.ts +8 -0
  214. package/x/demo/game/parts/virtual-device.js +11 -0
  215. package/x/demo/game/parts/virtual-device.js.map +1 -0
  216. package/x/demo/main.bundle.js +9 -9
  217. package/x/demo/main.bundle.js.map +1 -1
  218. package/x/demo/main.bundle.min.js +361 -55
  219. package/x/demo/main.bundle.min.js.map +4 -4
  220. package/x/demo/main.css +30 -2
  221. package/x/demo/ui/theater/styles.css.js +57 -0
  222. package/x/demo/ui/theater/styles.css.js.map +1 -0
  223. package/x/demo/ui/theater/view.d.ts +368 -0
  224. package/x/demo/ui/theater/view.js +50 -0
  225. package/x/demo/ui/theater/view.js.map +1 -0
  226. package/x/demo/ui/theater/virtual/style.css.d.ts +2 -0
  227. package/x/demo/ui/theater/virtual/style.css.js +42 -0
  228. package/x/demo/ui/theater/virtual/style.css.js.map +1 -0
  229. package/x/demo/ui/theater/virtual/view.d.ts +4 -0
  230. package/x/demo/ui/theater/virtual/view.js +19 -0
  231. package/x/demo/ui/theater/virtual/view.js.map +1 -0
  232. package/x/demo/ui/utils/loader.d.ts +2 -0
  233. package/x/demo/ui/utils/loader.js +3 -0
  234. package/x/demo/ui/utils/loader.js.map +1 -0
  235. package/x/index.d.ts +3 -1
  236. package/x/index.html +48 -9
  237. package/x/index.html.js +17 -7
  238. package/x/index.html.js.map +1 -1
  239. package/x/index.js +3 -1
  240. package/x/index.js.map +1 -1
  241. package/x/nubs/components.d.ts +9 -0
  242. package/x/nubs/components.js +11 -0
  243. package/x/nubs/components.js.map +1 -0
  244. package/x/nubs/index.d.ts +4 -0
  245. package/x/nubs/index.js +5 -0
  246. package/x/nubs/index.js.map +1 -0
  247. package/x/nubs/lookpad/component.d.ts +4 -0
  248. package/x/nubs/lookpad/component.js +36 -0
  249. package/x/nubs/lookpad/component.js.map +1 -0
  250. package/x/nubs/stick/component.d.ts +368 -0
  251. package/x/nubs/stick/component.js +101 -0
  252. package/x/nubs/stick/component.js.map +1 -0
  253. package/x/nubs/stick/style.css.d.ts +2 -0
  254. package/x/nubs/stick/style.css.js +69 -0
  255. package/x/nubs/stick/style.css.js.map +1 -0
  256. package/x/nubs/vpad/component.d.ts +368 -0
  257. package/x/nubs/{virtual-gamepad/view.js → vpad/component.js} +20 -11
  258. package/x/nubs/vpad/component.js.map +1 -0
  259. package/x/nubs/vpad/styles.css.d.ts +2 -0
  260. package/x/nubs/{virtual-gamepad → vpad}/styles.css.js +4 -4
  261. package/x/nubs/vpad/styles.css.js.map +1 -0
  262. package/x/nubs/vpad/utils/gamepad-inputs.js.map +1 -0
  263. package/x/nubs/vpad/utils/prevent-default-touch-shenanigans.js.map +1 -0
  264. package/x/nubs/vpad/utils/touch-tracking.js.map +1 -0
  265. package/x/utils/circular-clamp.d.ts +2 -0
  266. package/x/utils/circular-clamp.js +8 -0
  267. package/x/utils/circular-clamp.js.map +1 -0
  268. package/x/utils/dispensers.d.ts +7 -0
  269. package/x/utils/dispensers.js +16 -0
  270. package/x/utils/dispensers.js.map +1 -0
  271. package/x/utils/split-axis.d.ts +7 -0
  272. package/x/utils/split-axis.js +7 -2
  273. package/x/utils/split-axis.js.map +1 -1
  274. package/x/utils/types.d.ts +3 -0
  275. package/x/utils/types.js +3 -0
  276. package/x/utils/types.js.map +1 -0
  277. package/s/core/controllers/controller.ts +0 -7
  278. package/s/core/controllers/infra/group.ts +0 -17
  279. package/s/core/controllers/infra/sampler.ts +0 -22
  280. package/s/core/controllers/standard/gamepad.ts +0 -77
  281. package/s/core/controllers/standard/keyboard.ts +0 -50
  282. package/s/core/controllers/standard/stick.ts +0 -30
  283. package/s/core/deck/deck.ts +0 -40
  284. package/s/core/deck/parts/bindings-depot.ts +0 -24
  285. package/s/core/deck/parts/local-storage-kv.ts +0 -7
  286. package/s/core/hub/auto-gamepads.ts +0 -8
  287. package/s/core/hub/bindings.ts +0 -18
  288. package/s/core/port/port.ts +0 -34
  289. package/s/core/port/utils/aggregate_samples_into_map.ts +0 -20
  290. package/s/core/port/utils/wipe_samples_map.ts +0 -8
  291. package/s/nubs/lookpad/utils/listeners.ts +0 -53
  292. package/s/nubs/lookpad/view.ts +0 -32
  293. package/s/nubs/stick/styles.ts +0 -22
  294. package/s/nubs/stick/utils/calculate_new_vector_from_pointer_position.ts +0 -27
  295. package/s/nubs/stick/utils/find_closest_point_on_circle.ts +0 -15
  296. package/s/nubs/stick/utils/make_pointer_listeners.ts +0 -50
  297. package/s/nubs/stick/utils/within_radius.ts +0 -6
  298. package/s/nubs/stick/view.ts +0 -50
  299. package/s/nubs/stick-graphic/styles.ts +0 -38
  300. package/s/nubs/stick-graphic/types/basis.ts +0 -5
  301. package/s/nubs/stick-graphic/utils/calculate_basis.ts +0 -19
  302. package/s/nubs/stick-graphic/utils/stick_vector_to_pixels.ts +0 -13
  303. package/s/nubs/stick-graphic/utils/transform.ts +0 -10
  304. package/s/nubs/stick-graphic/view.ts +0 -43
  305. package/x/core/controllers/controller.d.ts +0 -4
  306. package/x/core/controllers/controller.js +0 -3
  307. package/x/core/controllers/controller.js.map +0 -1
  308. package/x/core/controllers/infra/group.d.ts +0 -7
  309. package/x/core/controllers/infra/group.js +0 -13
  310. package/x/core/controllers/infra/group.js.map +0 -1
  311. package/x/core/controllers/infra/sampler.d.ts +0 -8
  312. package/x/core/controllers/infra/sampler.js +0 -17
  313. package/x/core/controllers/infra/sampler.js.map +0 -1
  314. package/x/core/controllers/standard/gamepad.d.ts +0 -9
  315. package/x/core/controllers/standard/gamepad.js +0 -66
  316. package/x/core/controllers/standard/gamepad.js.map +0 -1
  317. package/x/core/controllers/standard/index.js.map +0 -1
  318. package/x/core/controllers/standard/keyboard.d.ts +0 -9
  319. package/x/core/controllers/standard/keyboard.js +0 -39
  320. package/x/core/controllers/standard/keyboard.js.map +0 -1
  321. package/x/core/controllers/standard/pointer.d.ts +0 -11
  322. package/x/core/controllers/standard/pointer.js.map +0 -1
  323. package/x/core/controllers/standard/stick.d.ts +0 -15
  324. package/x/core/controllers/standard/stick.js +0 -27
  325. package/x/core/controllers/standard/stick.js.map +0 -1
  326. package/x/core/controllers/standard/virtual-gamepad.d.ts +0 -7
  327. package/x/core/controllers/standard/virtual-gamepad.js.map +0 -1
  328. package/x/core/deck/deck.d.ts +0 -16
  329. package/x/core/deck/deck.js +0 -31
  330. package/x/core/deck/deck.js.map +0 -1
  331. package/x/core/deck/parts/bindings-depot.d.ts +0 -9
  332. package/x/core/deck/parts/bindings-depot.js +0 -19
  333. package/x/core/deck/parts/bindings-depot.js.map +0 -1
  334. package/x/core/deck/parts/local-storage-kv.js +0 -5
  335. package/x/core/deck/parts/local-storage-kv.js.map +0 -1
  336. package/x/core/hub/auto-gamepads.d.ts +0 -2
  337. package/x/core/hub/auto-gamepads.js +0 -6
  338. package/x/core/hub/auto-gamepads.js.map +0 -1
  339. package/x/core/hub/bindings.d.ts +0 -2
  340. package/x/core/hub/bindings.js +0 -16
  341. package/x/core/hub/bindings.js.map +0 -1
  342. package/x/core/port/port.d.ts +0 -12
  343. package/x/core/port/port.js +0 -25
  344. package/x/core/port/port.js.map +0 -1
  345. package/x/core/port/utils/aggregate_samples_into_map.d.ts +0 -3
  346. package/x/core/port/utils/aggregate_samples_into_map.js +0 -11
  347. package/x/core/port/utils/aggregate_samples_into_map.js.map +0 -1
  348. package/x/core/port/utils/wipe_samples_map.d.ts +0 -2
  349. package/x/core/port/utils/wipe_samples_map.js +0 -5
  350. package/x/core/port/utils/wipe_samples_map.js.map +0 -1
  351. package/x/nubs/lookpad/utils/listeners.d.ts +0 -19
  352. package/x/nubs/lookpad/utils/listeners.js +0 -37
  353. package/x/nubs/lookpad/utils/listeners.js.map +0 -1
  354. package/x/nubs/lookpad/view.d.ts +0 -1
  355. package/x/nubs/lookpad/view.js +0 -24
  356. package/x/nubs/lookpad/view.js.map +0 -1
  357. package/x/nubs/stick/styles.d.ts +0 -1
  358. package/x/nubs/stick/styles.js +0 -22
  359. package/x/nubs/stick/styles.js.map +0 -1
  360. package/x/nubs/stick/utils/calculate_new_vector_from_pointer_position.d.ts +0 -3
  361. package/x/nubs/stick/utils/calculate_new_vector_from_pointer_position.js +0 -16
  362. package/x/nubs/stick/utils/calculate_new_vector_from_pointer_position.js.map +0 -1
  363. package/x/nubs/stick/utils/find_closest_point_on_circle.d.ts +0 -2
  364. package/x/nubs/stick/utils/find_closest_point_on_circle.js +0 -6
  365. package/x/nubs/stick/utils/find_closest_point_on_circle.js.map +0 -1
  366. package/x/nubs/stick/utils/make_pointer_listeners.d.ts +0 -16
  367. package/x/nubs/stick/utils/make_pointer_listeners.js +0 -34
  368. package/x/nubs/stick/utils/make_pointer_listeners.js.map +0 -1
  369. package/x/nubs/stick/utils/within_radius.d.ts +0 -2
  370. package/x/nubs/stick/utils/within_radius.js +0 -4
  371. package/x/nubs/stick/utils/within_radius.js.map +0 -1
  372. package/x/nubs/stick/view.d.ts +0 -2
  373. package/x/nubs/stick/view.js +0 -38
  374. package/x/nubs/stick/view.js.map +0 -1
  375. package/x/nubs/stick-graphic/styles.js +0 -38
  376. package/x/nubs/stick-graphic/styles.js.map +0 -1
  377. package/x/nubs/stick-graphic/types/basis.d.ts +0 -4
  378. package/x/nubs/stick-graphic/types/basis.js +0 -2
  379. package/x/nubs/stick-graphic/types/basis.js.map +0 -1
  380. package/x/nubs/stick-graphic/utils/calculate_basis.d.ts +0 -2
  381. package/x/nubs/stick-graphic/utils/calculate_basis.js +0 -10
  382. package/x/nubs/stick-graphic/utils/calculate_basis.js.map +0 -1
  383. package/x/nubs/stick-graphic/utils/stick_vector_to_pixels.d.ts +0 -2
  384. package/x/nubs/stick-graphic/utils/stick_vector_to_pixels.js +0 -7
  385. package/x/nubs/stick-graphic/utils/stick_vector_to_pixels.js.map +0 -1
  386. package/x/nubs/stick-graphic/utils/transform.d.ts +0 -2
  387. package/x/nubs/stick-graphic/utils/transform.js +0 -7
  388. package/x/nubs/stick-graphic/utils/transform.js.map +0 -1
  389. package/x/nubs/stick-graphic/view.d.ts +0 -3
  390. package/x/nubs/stick-graphic/view.js +0 -30
  391. package/x/nubs/stick-graphic/view.js.map +0 -1
  392. package/x/nubs/virtual-gamepad/styles.css.js.map +0 -1
  393. package/x/nubs/virtual-gamepad/utils/gamepad-inputs.js.map +0 -1
  394. package/x/nubs/virtual-gamepad/utils/prevent-default-touch-shenanigans.js.map +0 -1
  395. package/x/nubs/virtual-gamepad/utils/touch-tracking.js.map +0 -1
  396. package/x/nubs/virtual-gamepad/view.d.ts +0 -2
  397. package/x/nubs/virtual-gamepad/view.js.map +0 -1
  398. /package/s/nubs/{virtual-gamepad → vpad}/utils/gamepad-inputs.ts +0 -0
  399. /package/s/nubs/{virtual-gamepad → vpad}/utils/prevent-default-touch-shenanigans.ts +0 -0
  400. /package/s/nubs/{virtual-gamepad → vpad}/utils/touch-tracking.ts +0 -0
  401. /package/x/core/{controllers → devices}/types.js +0 -0
  402. /package/x/{nubs/virtual-gamepad/styles.css.d.ts → deck/components/deck-bindings/style.css.d.ts} +0 -0
  403. /package/x/{core/deck → deck}/parts/local-storage-kv.d.ts +0 -0
  404. /package/x/{nubs/stick-graphic/styles.d.ts → demo/ui/theater/styles.css.d.ts} +0 -0
  405. /package/x/nubs/{virtual-gamepad → vpad}/utils/gamepad-inputs.d.ts +0 -0
  406. /package/x/nubs/{virtual-gamepad → vpad}/utils/gamepad-inputs.js +0 -0
  407. /package/x/nubs/{virtual-gamepad → vpad}/utils/prevent-default-touch-shenanigans.d.ts +0 -0
  408. /package/x/nubs/{virtual-gamepad → vpad}/utils/prevent-default-touch-shenanigans.js +0 -0
  409. /package/x/nubs/{virtual-gamepad → vpad}/utils/touch-tracking.d.ts +0 -0
  410. /package/x/nubs/{virtual-gamepad → vpad}/utils/touch-tracking.js +0 -0
package/x/demo/main.css CHANGED
@@ -5,8 +5,9 @@
5
5
  :root {
6
6
  color-scheme: dark;
7
7
  --link: cyan;
8
+ --prime: #ccc;
8
9
  --bg: #181818;
9
- --prime: #aaa;
10
+ --bg2: #111111;
10
11
  }
11
12
  }
12
13
 
@@ -46,12 +47,39 @@
46
47
  body { min-height: 100%; }
47
48
 
48
49
  html, body {
49
- font-size: 21px;
50
+ font-family: sans-serif;
51
+ font-size: 12px;
50
52
  color: var(--prime);
51
53
  background: var(--bg);
52
54
  }
53
55
  }
54
56
 
55
57
  @layer page {
58
+ body {
59
+ display: flex;
60
+ flex-direction: column;
61
+ align-items: center;
62
+
63
+ gap: 1em;
64
+ padding: 2em;
65
+
66
+ > * {
67
+ width: 100%;
68
+ max-width: 42em;
69
+ }
70
+
71
+ > header {
72
+ padding: 0 2em;
73
+ h1 small { font-size: 0.6em; font-weight: normal; }
74
+ * + * { margin-top: 0.5em; }
75
+ }
76
+
77
+ > section {
78
+ padding: 0 2em;
79
+ ul {
80
+ padding-left: 1em;
81
+ }
82
+ }
83
+ }
56
84
  }
57
85
 
@@ -0,0 +1,57 @@
1
+ import { css } from "lit";
2
+ export const styles = css `
3
+
4
+ :host {
5
+ display: flex;
6
+ flex-direction: column;
7
+ align-items: center;
8
+
9
+ gap: 1em;
10
+ }
11
+
12
+ .surface {
13
+ position: relative;
14
+ width: 100%;
15
+ height: auto;
16
+ aspect-ratio: 2 / 1;
17
+ overflow: hidden;
18
+
19
+ background: #000;
20
+ border: 0.5em solid #fff4;
21
+ border-radius: 2em;
22
+
23
+ canvas {
24
+ display: block;
25
+ position: absolute;
26
+ inset: 0;
27
+
28
+ width: 100%;
29
+ height: 100%;
30
+
31
+ image-rendering: pixelated;
32
+ outline: 1px solid red;
33
+ }
34
+
35
+ [deck="overlay"] {
36
+ position: absolute;
37
+ top: 10%;
38
+ left: 0;
39
+ right: 0;
40
+
41
+ display: flex;
42
+ flex-direction: column;
43
+ justify-content: center;
44
+ align-items: center;
45
+ }
46
+ }
47
+
48
+ .dlist {
49
+ display: flex;
50
+ flex-wrap: wrap;
51
+ justify-content: center;
52
+ align-items: center;
53
+ gap: 0.5em;
54
+ }
55
+
56
+ `;
57
+ //# sourceMappingURL=styles.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"styles.css.js","sourceRoot":"","sources":["../../../../s/demo/ui/theater/styles.css.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAA;AACvB,MAAM,CAAC,MAAM,MAAM,GAAG,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAsDxB,CAAA"}
@@ -0,0 +1,368 @@
1
+ import { Game } from "../../game/game.js";
2
+ declare const DemoTheater_base: import("@e280/sly").ComponentClass<{
3
+ new (): {
4
+ game: Game;
5
+ #private: any;
6
+ readonly shadow: ShadowRoot;
7
+ createShadow(): ShadowRoot;
8
+ render(_use: import("@e280/sly").Use): import("@e280/sly").Content;
9
+ updateNow: () => void;
10
+ update: import("@e280/stz").DebounceReturn<() => void>;
11
+ connectedCallback(): void;
12
+ disconnectedCallback(): void;
13
+ accessKey: string;
14
+ readonly accessKeyLabel: string;
15
+ autocapitalize: string;
16
+ autocorrect: boolean;
17
+ dir: string;
18
+ draggable: boolean;
19
+ hidden: boolean;
20
+ inert: boolean;
21
+ innerText: string;
22
+ lang: string;
23
+ readonly offsetHeight: number;
24
+ readonly offsetLeft: number;
25
+ readonly offsetParent: Element | null;
26
+ readonly offsetTop: number;
27
+ readonly offsetWidth: number;
28
+ outerText: string;
29
+ popover: string | null;
30
+ spellcheck: boolean;
31
+ title: string;
32
+ translate: boolean;
33
+ writingSuggestions: string;
34
+ attachInternals(): ElementInternals;
35
+ click(): void;
36
+ hidePopover(): void;
37
+ showPopover(): void;
38
+ togglePopover(options?: boolean): boolean;
39
+ addEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | AddEventListenerOptions): void;
40
+ addEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | AddEventListenerOptions): void;
41
+ removeEventListener<K extends keyof HTMLElementEventMap>(type: K, listener: (this: HTMLElement, ev: HTMLElementEventMap[K]) => any, options?: boolean | EventListenerOptions): void;
42
+ removeEventListener(type: string, listener: EventListenerOrEventListenerObject, options?: boolean | EventListenerOptions): void;
43
+ readonly attributes: NamedNodeMap;
44
+ get classList(): DOMTokenList;
45
+ set classList(value: string);
46
+ className: string;
47
+ readonly clientHeight: number;
48
+ readonly clientLeft: number;
49
+ readonly clientTop: number;
50
+ readonly clientWidth: number;
51
+ readonly currentCSSZoom: number;
52
+ id: string;
53
+ innerHTML: string;
54
+ readonly localName: string;
55
+ readonly namespaceURI: string | null;
56
+ onfullscreenchange: ((this: Element, ev: Event) => any) | null;
57
+ onfullscreenerror: ((this: Element, ev: Event) => any) | null;
58
+ outerHTML: string;
59
+ readonly ownerDocument: Document;
60
+ get part(): DOMTokenList;
61
+ set part(value: string);
62
+ readonly prefix: string | null;
63
+ readonly scrollHeight: number;
64
+ scrollLeft: number;
65
+ scrollTop: number;
66
+ readonly scrollWidth: number;
67
+ readonly shadowRoot: ShadowRoot | null;
68
+ slot: string;
69
+ readonly tagName: string;
70
+ attachShadow(init: ShadowRootInit): ShadowRoot;
71
+ checkVisibility(options?: CheckVisibilityOptions): boolean;
72
+ closest<K extends keyof HTMLElementTagNameMap>(selector: K): HTMLElementTagNameMap[K] | null;
73
+ closest<K extends keyof SVGElementTagNameMap>(selector: K): SVGElementTagNameMap[K] | null;
74
+ closest<K extends keyof MathMLElementTagNameMap>(selector: K): MathMLElementTagNameMap[K] | null;
75
+ closest<E extends Element = Element>(selectors: string): E | null;
76
+ computedStyleMap(): StylePropertyMapReadOnly;
77
+ getAttribute(qualifiedName: string): string | null;
78
+ getAttributeNS(namespace: string | null, localName: string): string | null;
79
+ getAttributeNames(): string[];
80
+ getAttributeNode(qualifiedName: string): Attr | null;
81
+ getAttributeNodeNS(namespace: string | null, localName: string): Attr | null;
82
+ getBoundingClientRect(): DOMRect;
83
+ getClientRects(): DOMRectList;
84
+ getElementsByClassName(classNames: string): HTMLCollectionOf<Element>;
85
+ getElementsByTagName<K extends keyof HTMLElementTagNameMap>(qualifiedName: K): HTMLCollectionOf<HTMLElementTagNameMap[K]>;
86
+ getElementsByTagName<K extends keyof SVGElementTagNameMap>(qualifiedName: K): HTMLCollectionOf<SVGElementTagNameMap[K]>;
87
+ getElementsByTagName<K extends keyof MathMLElementTagNameMap>(qualifiedName: K): HTMLCollectionOf<MathMLElementTagNameMap[K]>;
88
+ getElementsByTagName<K extends keyof HTMLElementDeprecatedTagNameMap>(qualifiedName: K): HTMLCollectionOf<HTMLElementDeprecatedTagNameMap[K]>;
89
+ getElementsByTagName(qualifiedName: string): HTMLCollectionOf<Element>;
90
+ getElementsByTagNameNS(namespaceURI: "http://www.w3.org/1999/xhtml", localName: string): HTMLCollectionOf<HTMLElement>;
91
+ getElementsByTagNameNS(namespaceURI: "http://www.w3.org/2000/svg", localName: string): HTMLCollectionOf<SVGElement>;
92
+ getElementsByTagNameNS(namespaceURI: "http://www.w3.org/1998/Math/MathML", localName: string): HTMLCollectionOf<MathMLElement>;
93
+ getElementsByTagNameNS(namespace: string | null, localName: string): HTMLCollectionOf<Element>;
94
+ getHTML(options?: GetHTMLOptions): string;
95
+ hasAttribute(qualifiedName: string): boolean;
96
+ hasAttributeNS(namespace: string | null, localName: string): boolean;
97
+ hasAttributes(): boolean;
98
+ hasPointerCapture(pointerId: number): boolean;
99
+ insertAdjacentElement(where: InsertPosition, element: Element): Element | null;
100
+ insertAdjacentHTML(position: InsertPosition, string: string): void;
101
+ insertAdjacentText(where: InsertPosition, data: string): void;
102
+ matches(selectors: string): boolean;
103
+ releasePointerCapture(pointerId: number): void;
104
+ removeAttribute(qualifiedName: string): void;
105
+ removeAttributeNS(namespace: string | null, localName: string): void;
106
+ removeAttributeNode(attr: Attr): Attr;
107
+ requestFullscreen(options?: FullscreenOptions): Promise<void>;
108
+ requestPointerLock(options?: PointerLockOptions): Promise<void>;
109
+ scroll(options?: ScrollToOptions): void;
110
+ scroll(x: number, y: number): void;
111
+ scrollBy(options?: ScrollToOptions): void;
112
+ scrollBy(x: number, y: number): void;
113
+ scrollIntoView(arg?: boolean | ScrollIntoViewOptions): void;
114
+ scrollTo(options?: ScrollToOptions): void;
115
+ scrollTo(x: number, y: number): void;
116
+ setAttribute(qualifiedName: string, value: string): void;
117
+ setAttributeNS(namespace: string | null, qualifiedName: string, value: string): void;
118
+ setAttributeNode(attr: Attr): Attr | null;
119
+ setAttributeNodeNS(attr: Attr): Attr | null;
120
+ setHTMLUnsafe(html: string): void;
121
+ setPointerCapture(pointerId: number): void;
122
+ toggleAttribute(qualifiedName: string, force?: boolean): boolean;
123
+ webkitMatchesSelector(selectors: string): boolean;
124
+ get textContent(): string;
125
+ set textContent(value: string | null);
126
+ readonly baseURI: string;
127
+ readonly childNodes: NodeListOf<ChildNode>;
128
+ readonly firstChild: ChildNode | null;
129
+ readonly isConnected: boolean;
130
+ readonly lastChild: ChildNode | null;
131
+ readonly nextSibling: ChildNode | null;
132
+ readonly nodeName: string;
133
+ readonly nodeType: number;
134
+ nodeValue: string | null;
135
+ readonly parentElement: HTMLElement | null;
136
+ readonly parentNode: ParentNode | null;
137
+ readonly previousSibling: ChildNode | null;
138
+ appendChild<T extends Node>(node: T): T;
139
+ cloneNode(subtree?: boolean): Node;
140
+ compareDocumentPosition(other: Node): number;
141
+ contains(other: Node | null): boolean;
142
+ getRootNode(options?: GetRootNodeOptions): Node;
143
+ hasChildNodes(): boolean;
144
+ insertBefore<T extends Node>(node: T, child: Node | null): T;
145
+ isDefaultNamespace(namespace: string | null): boolean;
146
+ isEqualNode(otherNode: Node | null): boolean;
147
+ isSameNode(otherNode: Node | null): boolean;
148
+ lookupNamespaceURI(prefix: string | null): string | null;
149
+ lookupPrefix(namespace: string | null): string | null;
150
+ normalize(): void;
151
+ removeChild<T extends Node>(child: T): T;
152
+ replaceChild<T extends Node>(node: Node, child: T): T;
153
+ readonly ELEMENT_NODE: 1;
154
+ readonly ATTRIBUTE_NODE: 2;
155
+ readonly TEXT_NODE: 3;
156
+ readonly CDATA_SECTION_NODE: 4;
157
+ readonly ENTITY_REFERENCE_NODE: 5;
158
+ readonly ENTITY_NODE: 6;
159
+ readonly PROCESSING_INSTRUCTION_NODE: 7;
160
+ readonly COMMENT_NODE: 8;
161
+ readonly DOCUMENT_NODE: 9;
162
+ readonly DOCUMENT_TYPE_NODE: 10;
163
+ readonly DOCUMENT_FRAGMENT_NODE: 11;
164
+ readonly NOTATION_NODE: 12;
165
+ readonly DOCUMENT_POSITION_DISCONNECTED: 1;
166
+ readonly DOCUMENT_POSITION_PRECEDING: 2;
167
+ readonly DOCUMENT_POSITION_FOLLOWING: 4;
168
+ readonly DOCUMENT_POSITION_CONTAINS: 8;
169
+ readonly DOCUMENT_POSITION_CONTAINED_BY: 16;
170
+ readonly DOCUMENT_POSITION_IMPLEMENTATION_SPECIFIC: 32;
171
+ dispatchEvent(event: Event): boolean;
172
+ ariaActiveDescendantElement: Element | null;
173
+ ariaAtomic: string | null;
174
+ ariaAutoComplete: string | null;
175
+ ariaBrailleLabel: string | null;
176
+ ariaBrailleRoleDescription: string | null;
177
+ ariaBusy: string | null;
178
+ ariaChecked: string | null;
179
+ ariaColCount: string | null;
180
+ ariaColIndex: string | null;
181
+ ariaColIndexText: string | null;
182
+ ariaColSpan: string | null;
183
+ ariaControlsElements: ReadonlyArray<Element> | null;
184
+ ariaCurrent: string | null;
185
+ ariaDescribedByElements: ReadonlyArray<Element> | null;
186
+ ariaDescription: string | null;
187
+ ariaDetailsElements: ReadonlyArray<Element> | null;
188
+ ariaDisabled: string | null;
189
+ ariaErrorMessageElements: ReadonlyArray<Element> | null;
190
+ ariaExpanded: string | null;
191
+ ariaFlowToElements: ReadonlyArray<Element> | null;
192
+ ariaHasPopup: string | null;
193
+ ariaHidden: string | null;
194
+ ariaInvalid: string | null;
195
+ ariaKeyShortcuts: string | null;
196
+ ariaLabel: string | null;
197
+ ariaLabelledByElements: ReadonlyArray<Element> | null;
198
+ ariaLevel: string | null;
199
+ ariaLive: string | null;
200
+ ariaModal: string | null;
201
+ ariaMultiLine: string | null;
202
+ ariaMultiSelectable: string | null;
203
+ ariaOrientation: string | null;
204
+ ariaOwnsElements: ReadonlyArray<Element> | null;
205
+ ariaPlaceholder: string | null;
206
+ ariaPosInSet: string | null;
207
+ ariaPressed: string | null;
208
+ ariaReadOnly: string | null;
209
+ ariaRelevant: string | null;
210
+ ariaRequired: string | null;
211
+ ariaRoleDescription: string | null;
212
+ ariaRowCount: string | null;
213
+ ariaRowIndex: string | null;
214
+ ariaRowIndexText: string | null;
215
+ ariaRowSpan: string | null;
216
+ ariaSelected: string | null;
217
+ ariaSetSize: string | null;
218
+ ariaSort: string | null;
219
+ ariaValueMax: string | null;
220
+ ariaValueMin: string | null;
221
+ ariaValueNow: string | null;
222
+ ariaValueText: string | null;
223
+ role: string | null;
224
+ animate(keyframes: Keyframe[] | PropertyIndexedKeyframes | null, options?: number | KeyframeAnimationOptions): Animation;
225
+ getAnimations(options?: GetAnimationsOptions): Animation[];
226
+ after(...nodes: (Node | string)[]): void;
227
+ before(...nodes: (Node | string)[]): void;
228
+ remove(): void;
229
+ replaceWith(...nodes: (Node | string)[]): void;
230
+ readonly nextElementSibling: Element | null;
231
+ readonly previousElementSibling: Element | null;
232
+ readonly childElementCount: number;
233
+ readonly children: HTMLCollection;
234
+ readonly firstElementChild: Element | null;
235
+ readonly lastElementChild: Element | null;
236
+ append(...nodes: (Node | string)[]): void;
237
+ prepend(...nodes: (Node | string)[]): void;
238
+ querySelector<K extends keyof HTMLElementTagNameMap>(selectors: K): HTMLElementTagNameMap[K] | null;
239
+ querySelector<K extends keyof SVGElementTagNameMap>(selectors: K): SVGElementTagNameMap[K] | null;
240
+ querySelector<K extends keyof MathMLElementTagNameMap>(selectors: K): MathMLElementTagNameMap[K] | null;
241
+ querySelector<K extends keyof HTMLElementDeprecatedTagNameMap>(selectors: K): HTMLElementDeprecatedTagNameMap[K] | null;
242
+ querySelector<E extends Element = Element>(selectors: string): E | null;
243
+ querySelectorAll<K extends keyof HTMLElementTagNameMap>(selectors: K): NodeListOf<HTMLElementTagNameMap[K]>;
244
+ querySelectorAll<K extends keyof SVGElementTagNameMap>(selectors: K): NodeListOf<SVGElementTagNameMap[K]>;
245
+ querySelectorAll<K extends keyof MathMLElementTagNameMap>(selectors: K): NodeListOf<MathMLElementTagNameMap[K]>;
246
+ querySelectorAll<K extends keyof HTMLElementDeprecatedTagNameMap>(selectors: K): NodeListOf<HTMLElementDeprecatedTagNameMap[K]>;
247
+ querySelectorAll<E extends Element = Element>(selectors: string): NodeListOf<E>;
248
+ replaceChildren(...nodes: (Node | string)[]): void;
249
+ readonly assignedSlot: HTMLSlotElement | null;
250
+ readonly attributeStyleMap: StylePropertyMap;
251
+ get style(): CSSStyleDeclaration;
252
+ set style(cssText: string);
253
+ contentEditable: string;
254
+ enterKeyHint: string;
255
+ inputMode: string;
256
+ readonly isContentEditable: boolean;
257
+ onabort: ((this: GlobalEventHandlers, ev: UIEvent) => any) | null;
258
+ onanimationcancel: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
259
+ onanimationend: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
260
+ onanimationiteration: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
261
+ onanimationstart: ((this: GlobalEventHandlers, ev: AnimationEvent) => any) | null;
262
+ onauxclick: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
263
+ onbeforeinput: ((this: GlobalEventHandlers, ev: InputEvent) => any) | null;
264
+ onbeforematch: ((this: GlobalEventHandlers, ev: Event) => any) | null;
265
+ onbeforetoggle: ((this: GlobalEventHandlers, ev: ToggleEvent) => any) | null;
266
+ onblur: ((this: GlobalEventHandlers, ev: FocusEvent) => any) | null;
267
+ oncancel: ((this: GlobalEventHandlers, ev: Event) => any) | null;
268
+ oncanplay: ((this: GlobalEventHandlers, ev: Event) => any) | null;
269
+ oncanplaythrough: ((this: GlobalEventHandlers, ev: Event) => any) | null;
270
+ onchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
271
+ onclick: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
272
+ onclose: ((this: GlobalEventHandlers, ev: Event) => any) | null;
273
+ oncontextlost: ((this: GlobalEventHandlers, ev: Event) => any) | null;
274
+ oncontextmenu: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
275
+ oncontextrestored: ((this: GlobalEventHandlers, ev: Event) => any) | null;
276
+ oncopy: ((this: GlobalEventHandlers, ev: ClipboardEvent) => any) | null;
277
+ oncuechange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
278
+ oncut: ((this: GlobalEventHandlers, ev: ClipboardEvent) => any) | null;
279
+ ondblclick: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
280
+ ondrag: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
281
+ ondragend: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
282
+ ondragenter: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
283
+ ondragleave: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
284
+ ondragover: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
285
+ ondragstart: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
286
+ ondrop: ((this: GlobalEventHandlers, ev: DragEvent) => any) | null;
287
+ ondurationchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
288
+ onemptied: ((this: GlobalEventHandlers, ev: Event) => any) | null;
289
+ onended: ((this: GlobalEventHandlers, ev: Event) => any) | null;
290
+ onerror: OnErrorEventHandler;
291
+ onfocus: ((this: GlobalEventHandlers, ev: FocusEvent) => any) | null;
292
+ onformdata: ((this: GlobalEventHandlers, ev: FormDataEvent) => any) | null;
293
+ ongotpointercapture: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
294
+ oninput: ((this: GlobalEventHandlers, ev: Event) => any) | null;
295
+ oninvalid: ((this: GlobalEventHandlers, ev: Event) => any) | null;
296
+ onkeydown: ((this: GlobalEventHandlers, ev: KeyboardEvent) => any) | null;
297
+ onkeypress: ((this: GlobalEventHandlers, ev: KeyboardEvent) => any) | null;
298
+ onkeyup: ((this: GlobalEventHandlers, ev: KeyboardEvent) => any) | null;
299
+ onload: ((this: GlobalEventHandlers, ev: Event) => any) | null;
300
+ onloadeddata: ((this: GlobalEventHandlers, ev: Event) => any) | null;
301
+ onloadedmetadata: ((this: GlobalEventHandlers, ev: Event) => any) | null;
302
+ onloadstart: ((this: GlobalEventHandlers, ev: Event) => any) | null;
303
+ onlostpointercapture: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
304
+ onmousedown: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
305
+ onmouseenter: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
306
+ onmouseleave: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
307
+ onmousemove: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
308
+ onmouseout: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
309
+ onmouseover: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
310
+ onmouseup: ((this: GlobalEventHandlers, ev: MouseEvent) => any) | null;
311
+ onpaste: ((this: GlobalEventHandlers, ev: ClipboardEvent) => any) | null;
312
+ onpause: ((this: GlobalEventHandlers, ev: Event) => any) | null;
313
+ onplay: ((this: GlobalEventHandlers, ev: Event) => any) | null;
314
+ onplaying: ((this: GlobalEventHandlers, ev: Event) => any) | null;
315
+ onpointercancel: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
316
+ onpointerdown: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
317
+ onpointerenter: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
318
+ onpointerleave: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
319
+ onpointermove: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
320
+ onpointerout: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
321
+ onpointerover: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
322
+ onpointerrawupdate: ((this: GlobalEventHandlers, ev: Event) => any) | null;
323
+ onpointerup: ((this: GlobalEventHandlers, ev: PointerEvent) => any) | null;
324
+ onprogress: ((this: GlobalEventHandlers, ev: ProgressEvent) => any) | null;
325
+ onratechange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
326
+ onreset: ((this: GlobalEventHandlers, ev: Event) => any) | null;
327
+ onresize: ((this: GlobalEventHandlers, ev: UIEvent) => any) | null;
328
+ onscroll: ((this: GlobalEventHandlers, ev: Event) => any) | null;
329
+ onscrollend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
330
+ onsecuritypolicyviolation: ((this: GlobalEventHandlers, ev: SecurityPolicyViolationEvent) => any) | null;
331
+ onseeked: ((this: GlobalEventHandlers, ev: Event) => any) | null;
332
+ onseeking: ((this: GlobalEventHandlers, ev: Event) => any) | null;
333
+ onselect: ((this: GlobalEventHandlers, ev: Event) => any) | null;
334
+ onselectionchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
335
+ onselectstart: ((this: GlobalEventHandlers, ev: Event) => any) | null;
336
+ onslotchange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
337
+ onstalled: ((this: GlobalEventHandlers, ev: Event) => any) | null;
338
+ onsubmit: ((this: GlobalEventHandlers, ev: SubmitEvent) => any) | null;
339
+ onsuspend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
340
+ ontimeupdate: ((this: GlobalEventHandlers, ev: Event) => any) | null;
341
+ ontoggle: ((this: GlobalEventHandlers, ev: ToggleEvent) => any) | null;
342
+ ontouchcancel?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
343
+ ontouchend?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
344
+ ontouchmove?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
345
+ ontouchstart?: ((this: GlobalEventHandlers, ev: TouchEvent) => any) | null | undefined;
346
+ ontransitioncancel: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
347
+ ontransitionend: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
348
+ ontransitionrun: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
349
+ ontransitionstart: ((this: GlobalEventHandlers, ev: TransitionEvent) => any) | null;
350
+ onvolumechange: ((this: GlobalEventHandlers, ev: Event) => any) | null;
351
+ onwaiting: ((this: GlobalEventHandlers, ev: Event) => any) | null;
352
+ onwebkitanimationend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
353
+ onwebkitanimationiteration: ((this: GlobalEventHandlers, ev: Event) => any) | null;
354
+ onwebkitanimationstart: ((this: GlobalEventHandlers, ev: Event) => any) | null;
355
+ onwebkittransitionend: ((this: GlobalEventHandlers, ev: Event) => any) | null;
356
+ onwheel: ((this: GlobalEventHandlers, ev: WheelEvent) => any) | null;
357
+ autofocus: boolean;
358
+ readonly dataset: DOMStringMap;
359
+ nonce?: string;
360
+ tabIndex: number;
361
+ blur(): void;
362
+ focus(options?: FocusOptions): void;
363
+ };
364
+ styles: import("lit").CSSResultGroup | undefined;
365
+ }, [game: Game]>;
366
+ export declare class DemoTheater extends DemoTheater_base {
367
+ }
368
+ export {};
@@ -0,0 +1,50 @@
1
+ import { html } from "lit";
2
+ import { repeat } from "lit/directives/repeat.js";
3
+ import { BaseElement, cssReset, view } from "@e280/sly";
4
+ import { styles } from "./styles.css.js";
5
+ import { VirtualDeviceView } from "./virtual/view.js";
6
+ import { VirtualDevice } from "../../game/parts/virtual-device.js";
7
+ import { DeckBindings } from "../../../deck/components/deck-bindings/component.js";
8
+ export class DemoTheater extends (view(use => (game) => {
9
+ use.css(cssReset, styles);
10
+ use.mount(() => game.loop(60));
11
+ use.mount(() => game.deck.hub.on(use.render));
12
+ const addVirtual = () => game.plug(new VirtualDevice(game.deck.hub));
13
+ const revealOverlay = () => game.deck.overlayVisibility.bump();
14
+ const virtualDevices = game.deck.hub.ports
15
+ .flatMap(port => port.devices.array())
16
+ .filter(device => device instanceof VirtualDevice)
17
+ .map(device => ({ device, skin: game.deck.deviceSkins.get(device) }))
18
+ .sort((a, b) => a.skin.label < b.skin.label ? -1 : 1);
19
+ return html `
20
+ <div class=surface>
21
+ ${game.renderer.canvas}
22
+ ${game.deck.views.DeckOverlay()}
23
+ </div>
24
+
25
+ <div class=dlist>
26
+ ${repeat(virtualDevices, d => d.skin.label, ({ device, skin }) => {
27
+ return VirtualDeviceView
28
+ .props(game.deck.hub, device, skin)
29
+ .attr("style", `--color: ${skin.color};`)
30
+ .render();
31
+ })}
32
+
33
+ <button @click="${addVirtual}">
34
+
35
+ </button>
36
+
37
+ <button @click="${revealOverlay}">
38
+ 👁️
39
+ </button>
40
+ </div>
41
+
42
+ ${DeckBindings.view(game.deck)}
43
+ `;
44
+ })
45
+ .component(class extends BaseElement {
46
+ game;
47
+ })
48
+ .props(el => [el.game])) {
49
+ }
50
+ //# sourceMappingURL=view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"view.js","sourceRoot":"","sources":["../../../../s/demo/ui/theater/view.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,IAAI,EAAC,MAAM,KAAK,CAAA;AACxB,OAAO,EAAC,MAAM,EAAC,MAAM,0BAA0B,CAAA;AAC/C,OAAO,EAAC,WAAW,EAAE,QAAQ,EAAE,IAAI,EAAC,MAAM,WAAW,CAAA;AAErD,OAAO,EAAC,MAAM,EAAC,MAAM,iBAAiB,CAAA;AAEtC,OAAO,EAAC,iBAAiB,EAAC,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAC,aAAa,EAAC,MAAM,oCAAoC,CAAA;AAChE,OAAO,EAAC,YAAY,EAAC,MAAM,qDAAqD,CAAA;AAEhF,MAAM,OAAO,WAAY,SAAQ,CAChC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,IAAU,EAAE,EAAE;IAC1B,GAAG,CAAC,GAAG,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAA;IACzB,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAA;IAC9B,GAAG,CAAC,KAAK,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAA;IAE7C,MAAM,UAAU,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAA;IACpE,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,EAAE,CAAA;IAE9D,MAAM,cAAc,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK;SACxC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,CAAC;SACrC,MAAM,CAAC,MAAM,CAAC,EAAE,CAAC,MAAM,YAAY,aAAa,CAAC;SACjD,GAAG,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC,EAAC,MAAM,EAAE,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,MAAM,CAAC,EAAC,CAAC,CAAC;SAClE,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IAEtD,OAAO,IAAI,CAAA;;MAEP,IAAI,CAAC,QAAQ,CAAC,MAAM;MACpB,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE;;;;MAI7B,MAAM,CACP,cAAc,EACd,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EACjB,CAAC,EAAC,MAAM,EAAE,IAAI,EAAC,EAAE,EAAE;QAClB,OAAO,iBAAiB;aACtB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC;aAClC,IAAI,CAAC,OAAO,EAAE,YAAY,IAAI,CAAC,KAAK,GAAG,CAAC;aACxC,MAAM,EAAE,CAAA;IACX,CAAC,CACD;;sBAEiB,UAAU;;;;sBAIV,aAAa;;;;;KAK9B,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;GAC9B,CAAA;AACF,CAAC,CAAC;KACD,SAAS,CAAC,KAAM,SAAQ,WAAW;IAAG,IAAI,CAAO;CAAE,CAAC;KACpD,KAAK,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CACvB;CAAG"}
@@ -0,0 +1,2 @@
1
+ declare const _default: import("lit").CSSResult;
2
+ export default _default;
@@ -0,0 +1,42 @@
1
+ import { css } from "lit";
2
+ export default css `
3
+
4
+ :host {
5
+ --color: #aaa;
6
+ }
7
+
8
+ .box {
9
+ display: flex;
10
+ align-items: center;
11
+ justify-content: center;
12
+
13
+ gap: 0.2em;
14
+ padding: 0.2em;
15
+ padding-right: 0.5em;
16
+
17
+ border-radius: 2em;
18
+ background: color-mix(in srgb, #fff4, var(--color));
19
+ }
20
+
21
+ [view="nub-stick"] {
22
+ width: 2em;
23
+ }
24
+
25
+ .label {
26
+ font-size: 1.2em;
27
+ font-weight: bold;
28
+
29
+ padding: 0 0.5em;
30
+ text-align: center;
31
+
32
+ color: white;
33
+ text-shadow: 0.1em 0.1em 0.1em #0004;
34
+ }
35
+
36
+ button {
37
+ font-size: 0.8em;
38
+ padding: 0.2em;
39
+ }
40
+
41
+ `;
42
+ //# sourceMappingURL=style.css.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"style.css.js","sourceRoot":"","sources":["../../../../../s/demo/ui/theater/virtual/style.css.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,GAAG,EAAC,MAAM,KAAK,CAAA;AACvB,eAAe,GAAG,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAuCjB,CAAA"}
@@ -0,0 +1,4 @@
1
+ import { Hub } from "../../../../core/hub/hub.js";
2
+ import { VirtualDevice } from "../../../game/parts/virtual-device.js";
3
+ import { DeviceSkin } from "../../../../deck/parts/device-skins/device-skin.js";
4
+ export declare const VirtualDeviceView: import("@e280/sly").View<[hub: Hub<any, any>, device: VirtualDevice, _deviceSkin: DeviceSkin]>;
@@ -0,0 +1,19 @@
1
+ import { html } from "lit";
2
+ import { cssReset, view } from "@e280/sly";
3
+ import styleCss from "./style.css.js";
4
+ import { NubStick } from "../../../../nubs/stick/component.js";
5
+ export const VirtualDeviceView = view(use => (hub, device, _deviceSkin) => {
6
+ use.styles(cssReset, styleCss);
7
+ use.attrs.strings.device = "virtual";
8
+ const unplug = () => hub.unplug(device);
9
+ return html `
10
+ <div class=box>
11
+ ${NubStick.view(device)}
12
+
13
+ <button @click="${device.shimmyPrevious}">👈</button>
14
+ <button @click="${unplug}">💀</button>
15
+ <button @click="${device.shimmyNext}">👉</button>
16
+ </div>
17
+ `;
18
+ });
19
+ //# sourceMappingURL=view.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"view.js","sourceRoot":"","sources":["../../../../../s/demo/ui/theater/virtual/view.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,IAAI,EAAC,MAAM,KAAK,CAAA;AACxB,OAAO,EAAC,QAAQ,EAAE,IAAI,EAAC,MAAM,WAAW,CAAA;AACxC,OAAO,QAAQ,MAAM,gBAAgB,CAAA;AAErC,OAAO,EAAC,QAAQ,EAAC,MAAM,qCAAqC,CAAA;AAI5D,MAAM,CAAC,MAAM,iBAAiB,GAAG,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,CAC3C,GAAa,EACb,MAAqB,EACrB,WAAuB,EACtB,EAAE;IAEJ,GAAG,CAAC,MAAM,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;IAC9B,GAAG,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,SAAS,CAAA;IAEpC,MAAM,MAAM,GAAG,GAAG,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;IAEvC,OAAO,IAAI,CAAA;;KAEP,QAAQ,CAAC,IAAI,CAAC,MAAM,CAAC;;qBAEL,MAAM,CAAC,cAAc;qBACrB,MAAM;qBACN,MAAM,CAAC,UAAU;;EAEpC,CAAA;AACF,CAAC,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ import { loaders } from "@e280/sly";
2
+ export declare const loader: loaders.Loader;
@@ -0,0 +1,3 @@
1
+ import { loaders } from "@e280/sly";
2
+ export const loader = loaders.make();
3
+ //# sourceMappingURL=loader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../../../s/demo/ui/utils/loader.ts"],"names":[],"mappings":"AACA,OAAO,EAAC,OAAO,EAAC,MAAM,WAAW,CAAA;AAEjC,MAAM,CAAC,MAAM,MAAM,GAAG,OAAO,CAAC,IAAI,EAAE,CAAA"}
package/x/index.d.ts CHANGED
@@ -1,3 +1,5 @@
1
1
  export * from "./core/index.js";
2
+ export * from "./deck/index.js";
3
+ export * from "./nubs/index.js";
4
+ export * as nubs from "./nubs/index.js";
2
5
  export * from "./utils/gamepads.js";
3
- export * from "./utils/split-axis.js";