@oddsmith/ui 0.0.0 → 1.0.1

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 (478) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +4 -115
  3. package/dist/components/os-leaderboard-casino/assets/fallback/catalog.json +9 -0
  4. package/dist/components/os-leaderboard-casino/assets/fallback/catalog.json.js +13 -0
  5. package/dist/components/os-leaderboard-casino/assets/fallback/catalog.json.js.map +1 -0
  6. package/dist/components/os-leaderboard-casino/assets/fallback/config.json +8 -0
  7. package/dist/components/os-leaderboard-casino/assets/fallback/defaults/glam-sections.json +564 -0
  8. package/dist/components/os-leaderboard-casino/assets/fallback/fonts.json +3 -0
  9. package/dist/components/os-leaderboard-casino/assets/fallback/labels.json +5 -0
  10. package/dist/components/os-leaderboard-casino/assets/fallback/labels.json.js +12 -0
  11. package/dist/components/os-leaderboard-casino/assets/fallback/labels.json.js.map +1 -0
  12. package/dist/components/os-leaderboard-casino/assets/fallback/manifest.json +6 -0
  13. package/dist/components/os-leaderboard-casino/assets/fallback/presets.json +38 -0
  14. package/dist/components/os-leaderboard-casino/assets/fallback/presets.json.js +10 -0
  15. package/dist/components/os-leaderboard-casino/assets/fallback/presets.json.js.map +1 -0
  16. package/dist/components/os-leaderboard-casino/assets/fallback/resolved-presets.json +601 -0
  17. package/dist/components/os-leaderboard-casino/assets/fallback/resolved-presets.json.js +8 -0
  18. package/dist/components/os-leaderboard-casino/assets/fallback/resolved-presets.json.js.map +1 -0
  19. package/dist/components/os-leaderboard-casino/assets/fallback/themes.json +69 -0
  20. package/dist/components/os-leaderboard-casino/assets/fallback/themes.json.js +73 -0
  21. package/dist/components/os-leaderboard-casino/assets/fallback/themes.json.js.map +1 -0
  22. package/dist/components/os-leaderboard-casino/assets/icons/prize.casino-credits.svg +7 -0
  23. package/dist/components/os-leaderboard-casino/assets/icons/prize.casino-credits.svg.js +12 -0
  24. package/dist/components/os-leaderboard-casino/assets/icons/prize.casino-credits.svg.js.map +1 -0
  25. package/dist/components/os-leaderboard-casino/assets/icons/prize.default.svg +7 -0
  26. package/dist/components/os-leaderboard-casino/assets/icons/prize.default.svg.js +12 -0
  27. package/dist/components/os-leaderboard-casino/assets/icons/prize.default.svg.js.map +1 -0
  28. package/dist/components/os-leaderboard-casino/assets/icons/prize.elite-bonus.svg +5 -0
  29. package/dist/components/os-leaderboard-casino/assets/icons/prize.elite-bonus.svg.js +10 -0
  30. package/dist/components/os-leaderboard-casino/assets/icons/prize.elite-bonus.svg.js.map +1 -0
  31. package/dist/components/os-leaderboard-casino/assets/icons/prize.free-spins.svg +10 -0
  32. package/dist/components/os-leaderboard-casino/assets/icons/prize.free-spins.svg.js +15 -0
  33. package/dist/components/os-leaderboard-casino/assets/icons/prize.free-spins.svg.js.map +1 -0
  34. package/dist/components/os-leaderboard-casino/assets/icons/prize.grand-jackpot.svg +5 -0
  35. package/dist/components/os-leaderboard-casino/assets/icons/prize.grand-jackpot.svg.js +10 -0
  36. package/dist/components/os-leaderboard-casino/assets/icons/prize.grand-jackpot.svg.js.map +1 -0
  37. package/dist/components/os-leaderboard-casino/assets/icons/prize.high-roller.svg +5 -0
  38. package/dist/components/os-leaderboard-casino/assets/icons/prize.high-roller.svg.js +10 -0
  39. package/dist/components/os-leaderboard-casino/assets/icons/prize.high-roller.svg.js.map +1 -0
  40. package/dist/components/os-leaderboard-casino/assets/icons/prize.mystery-bonus.svg +8 -0
  41. package/dist/components/os-leaderboard-casino/assets/icons/prize.mystery-bonus.svg.js +13 -0
  42. package/dist/components/os-leaderboard-casino/assets/icons/prize.mystery-bonus.svg.js.map +1 -0
  43. package/dist/components/os-leaderboard-casino/assets/icons/stat.clock.svg +4 -0
  44. package/dist/components/os-leaderboard-casino/assets/icons/stat.clock.svg.js +9 -0
  45. package/dist/components/os-leaderboard-casino/assets/icons/stat.clock.svg.js.map +1 -0
  46. package/dist/components/os-leaderboard-casino/assets/icons/stat.gift.svg +5 -0
  47. package/dist/components/os-leaderboard-casino/assets/icons/stat.gift.svg.js +10 -0
  48. package/dist/components/os-leaderboard-casino/assets/icons/stat.gift.svg.js.map +1 -0
  49. package/dist/components/os-leaderboard-casino/assets/icons/stat.users.svg +5 -0
  50. package/dist/components/os-leaderboard-casino/assets/icons/stat.users.svg.js +10 -0
  51. package/dist/components/os-leaderboard-casino/assets/icons/stat.users.svg.js.map +1 -0
  52. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-down.svg +4 -0
  53. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-down.svg.js +9 -0
  54. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-down.svg.js.map +1 -0
  55. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-neutral.svg +4 -0
  56. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-neutral.svg.js +9 -0
  57. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-neutral.svg.js.map +1 -0
  58. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-up.svg +4 -0
  59. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-up.svg.js +9 -0
  60. package/dist/components/os-leaderboard-casino/assets/icons/table.rank-up.svg.js.map +1 -0
  61. package/dist/components/os-leaderboard-casino/assets/icons/vip.crown.svg +7 -0
  62. package/dist/components/os-leaderboard-casino/assets/icons/vip.crown.svg.js +12 -0
  63. package/dist/components/os-leaderboard-casino/assets/icons/vip.crown.svg.js.map +1 -0
  64. package/dist/components/os-leaderboard-casino/assets/icons/win.bag.svg +5 -0
  65. package/dist/components/os-leaderboard-casino/assets/icons/win.bag.svg.js +10 -0
  66. package/dist/components/os-leaderboard-casino/assets/icons/win.bag.svg.js.map +1 -0
  67. package/dist/components/os-leaderboard-casino/assets/icons/win.bolt.svg +4 -0
  68. package/dist/components/os-leaderboard-casino/assets/icons/win.bolt.svg.js +9 -0
  69. package/dist/components/os-leaderboard-casino/assets/icons/win.bolt.svg.js.map +1 -0
  70. package/dist/components/os-leaderboard-casino/assets/icons/win.coin.svg +5 -0
  71. package/dist/components/os-leaderboard-casino/assets/icons/win.coin.svg.js +10 -0
  72. package/dist/components/os-leaderboard-casino/assets/icons/win.coin.svg.js.map +1 -0
  73. package/dist/components/os-leaderboard-casino/assets/icons/win.fire.svg +4 -0
  74. package/dist/components/os-leaderboard-casino/assets/icons/win.fire.svg.js +9 -0
  75. package/dist/components/os-leaderboard-casino/assets/icons/win.fire.svg.js.map +1 -0
  76. package/dist/components/os-leaderboard-casino/assets/icons/win.gem.svg +5 -0
  77. package/dist/components/os-leaderboard-casino/assets/icons/win.gem.svg.js +10 -0
  78. package/dist/components/os-leaderboard-casino/assets/icons/win.gem.svg.js.map +1 -0
  79. package/dist/components/os-leaderboard-casino/assets/icons/win.trophy.svg +5 -0
  80. package/dist/components/os-leaderboard-casino/assets/icons/win.trophy.svg.js +10 -0
  81. package/dist/components/os-leaderboard-casino/assets/icons/win.trophy.svg.js.map +1 -0
  82. package/dist/components/os-leaderboard-casino/assets/images/games/cards.png +0 -0
  83. package/dist/components/os-leaderboard-casino/assets/images/games/cards.png.js +5 -0
  84. package/dist/components/os-leaderboard-casino/assets/images/games/cards.png.js.map +1 -0
  85. package/dist/components/os-leaderboard-casino/assets/images/games/chips.png +0 -0
  86. package/dist/components/os-leaderboard-casino/assets/images/games/chips.png.js +5 -0
  87. package/dist/components/os-leaderboard-casino/assets/images/games/chips.png.js.map +1 -0
  88. package/dist/components/os-leaderboard-casino/assets/images/games/dice.png +0 -0
  89. package/dist/components/os-leaderboard-casino/assets/images/games/dice.png.js +5 -0
  90. package/dist/components/os-leaderboard-casino/assets/images/games/dice.png.js.map +1 -0
  91. package/dist/components/os-leaderboard-casino/assets/images/games/gates-of-olympus.png +0 -0
  92. package/dist/components/os-leaderboard-casino/assets/images/games/gates-of-olympus.png.js +5 -0
  93. package/dist/components/os-leaderboard-casino/assets/images/games/gates-of-olympus.png.js.map +1 -0
  94. package/dist/components/os-leaderboard-casino/assets/images/games/roulette.png +0 -0
  95. package/dist/components/os-leaderboard-casino/assets/images/games/roulette.png.js +5 -0
  96. package/dist/components/os-leaderboard-casino/assets/images/games/roulette.png.js.map +1 -0
  97. package/dist/components/os-leaderboard-casino/assets/images/games/slot-machine.png +0 -0
  98. package/dist/components/os-leaderboard-casino/assets/images/games/slot-machine.png.js +5 -0
  99. package/dist/components/os-leaderboard-casino/assets/images/games/slot-machine.png.js.map +1 -0
  100. package/dist/components/os-leaderboard-casino/assets/images/logo.png +0 -0
  101. package/dist/components/os-leaderboard-casino/constants/defaults.d.ts +8 -0
  102. package/dist/components/os-leaderboard-casino/constants/defaults.js +9 -0
  103. package/dist/components/os-leaderboard-casino/constants/defaults.js.map +1 -0
  104. package/dist/components/os-leaderboard-casino/constants/index.d.ts +2 -0
  105. package/dist/components/os-leaderboard-casino/constants/tags.d.ts +22 -0
  106. package/dist/components/os-leaderboard-casino/constants/tags.js +17 -0
  107. package/dist/components/os-leaderboard-casino/constants/tags.js.map +1 -0
  108. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.d.ts +35 -0
  109. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.host.d.ts +13 -0
  110. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.html.js +20 -0
  111. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.html.js.map +1 -0
  112. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.js +152 -0
  113. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.js.map +1 -0
  114. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.scss.js +5 -0
  115. package/dist/components/os-leaderboard-casino/container/os-leaderboard-casino.scss.js.map +1 -0
  116. package/dist/components/os-leaderboard-casino/index.d.ts +36 -0
  117. package/dist/components/os-leaderboard-casino/index.js +39 -0
  118. package/dist/components/os-leaderboard-casino/index.js.map +1 -0
  119. package/dist/components/os-leaderboard-casino/integration/assemble-assets.d.ts +21 -0
  120. package/dist/components/os-leaderboard-casino/integration/assemble-assets.js +48 -0
  121. package/dist/components/os-leaderboard-casino/integration/assemble-assets.js.map +1 -0
  122. package/dist/components/os-leaderboard-casino/integration/assets-context.d.ts +26 -0
  123. package/dist/components/os-leaderboard-casino/integration/assets-context.js +64 -0
  124. package/dist/components/os-leaderboard-casino/integration/assets-context.js.map +1 -0
  125. package/dist/components/os-leaderboard-casino/integration/defaults-glam.d.ts +14 -0
  126. package/dist/components/os-leaderboard-casino/integration/defaults-new-money.d.ts +3 -0
  127. package/dist/components/os-leaderboard-casino/integration/index.d.ts +5 -0
  128. package/dist/components/os-leaderboard-casino/integration/labels.d.ts +1 -0
  129. package/dist/components/os-leaderboard-casino/integration/load-assets.d.ts +9 -0
  130. package/dist/components/os-leaderboard-casino/integration/load-assets.js +22 -0
  131. package/dist/components/os-leaderboard-casino/integration/load-assets.js.map +1 -0
  132. package/dist/components/os-leaderboard-casino/integration/presets.d.ts +1 -0
  133. package/dist/components/os-leaderboard-casino/integration/resolve-input.d.ts +20 -0
  134. package/dist/components/os-leaderboard-casino/integration/resolve-input.js +99 -0
  135. package/dist/components/os-leaderboard-casino/integration/resolve-input.js.map +1 -0
  136. package/dist/components/os-leaderboard-casino/integration/themes.d.ts +1 -0
  137. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.d.ts +19 -0
  138. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.host.d.ts +15 -0
  139. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.html.js +46 -0
  140. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.html.js.map +1 -0
  141. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.js +74 -0
  142. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.js.map +1 -0
  143. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.scss.js +5 -0
  144. package/dist/components/os-leaderboard-casino/sections/climb-section/climb-section.scss.js.map +1 -0
  145. package/dist/components/os-leaderboard-casino/sections/events-banner/components/event-icons.d.ts +5 -0
  146. package/dist/components/os-leaderboard-casino/sections/events-banner/components/event-icons.js +116 -0
  147. package/dist/components/os-leaderboard-casino/sections/events-banner/components/event-icons.js.map +1 -0
  148. package/dist/components/os-leaderboard-casino/sections/events-banner/events-banner.d.ts +16 -0
  149. package/dist/components/os-leaderboard-casino/sections/events-banner/events-banner.host.d.ts +8 -0
  150. package/dist/components/os-leaderboard-casino/sections/events-banner/events-banner.js +90 -0
  151. package/dist/components/os-leaderboard-casino/sections/events-banner/events-banner.js.map +1 -0
  152. package/dist/components/os-leaderboard-casino/sections/events-banner/events-banner.scss.js +5 -0
  153. package/dist/components/os-leaderboard-casino/sections/events-banner/events-banner.scss.js.map +1 -0
  154. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.d.ts +10 -0
  155. package/{src/components/sf-leaderboard/sections/footer-section/footer-section.host.ts → dist/components/os-leaderboard-casino/sections/footer-section/footer-section.host.d.ts} +1 -1
  156. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.html.js +18 -0
  157. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.html.js.map +1 -0
  158. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.js +39 -0
  159. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.js.map +1 -0
  160. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.scss.js +5 -0
  161. package/dist/components/os-leaderboard-casino/sections/footer-section/footer-section.scss.js.map +1 -0
  162. package/dist/components/os-leaderboard-casino/sections/games-section/components/game-images.d.ts +1 -0
  163. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.d.ts +20 -0
  164. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.host.d.ts +7 -0
  165. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.html.js +15 -0
  166. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.html.js.map +1 -0
  167. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.js +86 -0
  168. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.js.map +1 -0
  169. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.scss.js +5 -0
  170. package/dist/components/os-leaderboard-casino/sections/games-section/games-section.scss.js.map +1 -0
  171. package/dist/components/os-leaderboard-casino/sections/header-section/header-section.d.ts +12 -0
  172. package/dist/components/os-leaderboard-casino/sections/header-section/header-section.host.d.ts +8 -0
  173. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.d.ts +37 -0
  174. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.host.d.ts +20 -0
  175. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.html.js +34 -0
  176. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.html.js.map +1 -0
  177. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.js +160 -0
  178. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.js.map +1 -0
  179. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.scss.js +5 -0
  180. package/dist/components/os-leaderboard-casino/sections/hero-section/hero-section.scss.js.map +1 -0
  181. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.d.ts +18 -0
  182. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.host.d.ts +8 -0
  183. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.html.js +33 -0
  184. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.html.js.map +1 -0
  185. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.js +74 -0
  186. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.js.map +1 -0
  187. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.scss.js +5 -0
  188. package/dist/components/os-leaderboard-casino/sections/legals-section/legals-section.scss.js.map +1 -0
  189. package/dist/components/os-leaderboard-casino/sections/live-feed-section/live-feed-section.d.ts +13 -0
  190. package/dist/components/os-leaderboard-casino/sections/live-feed-section/live-feed-section.host.d.ts +8 -0
  191. package/dist/components/os-leaderboard-casino/sections/marquee-section/components/win-icons.d.ts +3 -0
  192. package/dist/components/os-leaderboard-casino/sections/marquee-section/components/win-icons.js +8 -0
  193. package/dist/components/os-leaderboard-casino/sections/marquee-section/components/win-icons.js.map +1 -0
  194. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-item.d.ts +14 -0
  195. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-item.js +57 -0
  196. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-item.js.map +1 -0
  197. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.d.ts +42 -0
  198. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.host.d.ts +8 -0
  199. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.html.js +17 -0
  200. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.html.js.map +1 -0
  201. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.js +287 -0
  202. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.js.map +1 -0
  203. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.scss.js +5 -0
  204. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-section.scss.js.map +1 -0
  205. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-variants.d.ts +6 -0
  206. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-variants.js +16 -0
  207. package/dist/components/os-leaderboard-casino/sections/marquee-section/marquee-variants.js.map +1 -0
  208. package/dist/components/os-leaderboard-casino/sections/prize-section/components/medal-coin/medal-coin.d.ts +16 -0
  209. package/dist/components/os-leaderboard-casino/sections/prize-section/components/medal-coin/medal-coin.js +71 -0
  210. package/dist/components/os-leaderboard-casino/sections/prize-section/components/medal-coin/medal-coin.js.map +1 -0
  211. package/dist/components/os-leaderboard-casino/sections/prize-section/components/medal-coin/medal-coin.scss.js +5 -0
  212. package/dist/components/os-leaderboard-casino/sections/prize-section/components/medal-coin/medal-coin.scss.js.map +1 -0
  213. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.d.ts +23 -0
  214. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.host.d.ts +11 -0
  215. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.html.js +18 -0
  216. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.html.js.map +1 -0
  217. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.js +135 -0
  218. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.js.map +1 -0
  219. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.scss.js +5 -0
  220. package/dist/components/os-leaderboard-casino/sections/prize-section/prize-section.scss.js.map +1 -0
  221. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-band/stat-band.d.ts +17 -0
  222. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-card/stat-card.d.ts +15 -0
  223. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-chip/stat-chip.d.ts +17 -0
  224. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-gauge/stat-gauge.d.ts +14 -0
  225. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-icons.d.ts +5 -0
  226. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-icons.js +11 -0
  227. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-icons.js.map +1 -0
  228. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-meter/stat-meter.d.ts +17 -0
  229. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-rail/stat-rail.d.ts +17 -0
  230. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-rail/stat-rail.js +61 -0
  231. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-rail/stat-rail.js.map +1 -0
  232. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-rail/stat-rail.scss.js +5 -0
  233. package/dist/components/os-leaderboard-casino/sections/stats-section/components/stat-rail/stat-rail.scss.js.map +1 -0
  234. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.d.ts +16 -0
  235. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.host.d.ts +13 -0
  236. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.html.js +34 -0
  237. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.html.js.map +1 -0
  238. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.js +69 -0
  239. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.js.map +1 -0
  240. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.scss.js +5 -0
  241. package/dist/components/os-leaderboard-casino/sections/stats-section/stats-section.scss.js.map +1 -0
  242. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.d.ts +31 -0
  243. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.host.d.ts +15 -0
  244. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.html.js +38 -0
  245. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.html.js.map +1 -0
  246. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.js +183 -0
  247. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.js.map +1 -0
  248. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.scss.js +5 -0
  249. package/dist/components/os-leaderboard-casino/sections/table-section/table-section.scss.js.map +1 -0
  250. package/dist/components/os-leaderboard-casino/services/adapter.service.d.ts +11 -0
  251. package/dist/components/os-leaderboard-casino/services/adapter.service.js +49 -0
  252. package/dist/components/os-leaderboard-casino/services/adapter.service.js.map +1 -0
  253. package/dist/components/os-leaderboard-casino/services/icon.service.d.ts +28 -0
  254. package/dist/components/os-leaderboard-casino/services/icon.service.js +192 -0
  255. package/dist/components/os-leaderboard-casino/services/icon.service.js.map +1 -0
  256. package/dist/components/os-leaderboard-casino/services/index.d.ts +2 -0
  257. package/dist/components/os-leaderboard-casino/theme/index.d.ts +3 -0
  258. package/dist/components/os-leaderboard-casino/theme/prize-icons.d.ts +1 -0
  259. package/dist/components/os-leaderboard-casino/theme/prize-resolve.d.ts +5 -0
  260. package/dist/components/os-leaderboard-casino/theme/prize-resolve.js +11 -0
  261. package/dist/components/os-leaderboard-casino/theme/prize-resolve.js.map +1 -0
  262. package/dist/components/os-leaderboard-casino/theme/styles.d.ts +9 -0
  263. package/dist/components/os-leaderboard-casino/theme/styles.js +179 -0
  264. package/dist/components/os-leaderboard-casino/theme/styles.js.map +1 -0
  265. package/dist/components/os-leaderboard-casino/theme/vip-icons.d.ts +2 -0
  266. package/dist/components/os-leaderboard-casino/theme/vip-icons.js +6 -0
  267. package/dist/components/os-leaderboard-casino/theme/vip-icons.js.map +1 -0
  268. package/dist/components/os-leaderboard-casino/theme/vip-mark.d.ts +7 -0
  269. package/dist/components/os-leaderboard-casino/theme/vip-mark.js +20 -0
  270. package/dist/components/os-leaderboard-casino/theme/vip-mark.js.map +1 -0
  271. package/dist/components/os-leaderboard-casino/types/assets.d.ts +40 -0
  272. package/dist/components/os-leaderboard-casino/types/data.d.ts +106 -0
  273. package/dist/components/os-leaderboard-casino/types/data.js +7 -0
  274. package/dist/components/os-leaderboard-casino/types/data.js.map +1 -0
  275. package/dist/components/os-leaderboard-casino/types/events.d.ts +18 -0
  276. package/dist/components/os-leaderboard-casino/types/events.js +8 -0
  277. package/dist/components/os-leaderboard-casino/types/events.js.map +1 -0
  278. package/dist/components/os-leaderboard-casino/types/icons.d.ts +18 -0
  279. package/dist/components/os-leaderboard-casino/types/input.d.ts +73 -0
  280. package/dist/components/os-leaderboard-casino/types/ledger.d.ts +67 -0
  281. package/dist/components/os-leaderboard-casino/types/sections.d.ts +200 -0
  282. package/dist/components/os-leaderboard-casino/types/state.d.ts +69 -0
  283. package/dist/components/os-leaderboard-casino/types/state.js +12 -0
  284. package/dist/components/os-leaderboard-casino/types/state.js.map +1 -0
  285. package/dist/shared/lib/lit/component.d.ts +5 -0
  286. package/dist/shared/lib/lit/component.js +8 -0
  287. package/dist/shared/lib/lit/component.js.map +1 -0
  288. package/dist/shared/lib/lit/safe-custom-element.d.ts +5 -0
  289. package/dist/shared/lib/lit/safe-custom-element.js +7 -0
  290. package/dist/shared/lib/lit/safe-custom-element.js.map +1 -0
  291. package/dist/shared/lib/lit/scss.d.ts +3 -0
  292. package/dist/shared/lib/lit/scss.js +8 -0
  293. package/dist/shared/lib/lit/scss.js.map +1 -0
  294. package/dist/shared/lib/lit/template.d.ts +3 -0
  295. package/dist/shared/vendor/keen-slider-keen-slider.es.js +538 -0
  296. package/dist/shared/vendor/keen-slider-keen-slider.es.js.map +1 -0
  297. package/package.json +37 -39
  298. package/.eleventy.cjs +0 -14
  299. package/custom-elements.json +0 -1539
  300. package/docs/_README/index.html +0 -4
  301. package/docs/api/index.html +0 -2100
  302. package/docs/components.bundle.js +0 -1669
  303. package/docs/components.bundle.js.map +0 -1
  304. package/docs/docs.css +0 -162
  305. package/docs/examples/index.html +0 -56
  306. package/docs/index.html +0 -53
  307. package/docs/install/index.html +0 -45
  308. package/docs/prism-okaidia.css +0 -123
  309. package/docs-src/.nojekyll +0 -0
  310. package/docs-src/_README.md +0 -7
  311. package/docs-src/_data/api.11tydata.js +0 -8
  312. package/docs-src/_includes/example.11ty.js +0 -35
  313. package/docs-src/_includes/footer.11ty.js +0 -6
  314. package/docs-src/_includes/header.11ty.js +0 -7
  315. package/docs-src/_includes/nav.11ty.js +0 -11
  316. package/docs-src/_includes/page.11ty.js +0 -32
  317. package/docs-src/_includes/relative-path.cjs +0 -9
  318. package/docs-src/api.11ty.js +0 -85
  319. package/docs-src/bundle.ts +0 -9
  320. package/docs-src/docs.css +0 -162
  321. package/docs-src/examples/index.md +0 -15
  322. package/docs-src/index.md +0 -39
  323. package/docs-src/install.md +0 -28
  324. package/docs-src/package.json +0 -3
  325. package/index.html +0 -19
  326. package/karma.conf.cjs +0 -24
  327. package/main.css +0 -210
  328. package/main.ts +0 -124
  329. package/previews/casino.ts +0 -12
  330. package/previews/catalog.ts +0 -94
  331. package/previews/leaderboard-v1.ts +0 -12
  332. package/previews/leaderboard-v2.ts +0 -17
  333. package/previews/sample-data.ts +0 -101
  334. package/previews/sf-leaderboard.ts +0 -100
  335. package/previews/sf-live-feed.ts +0 -15
  336. package/previews/streaks.ts +0 -40
  337. package/previews/types.ts +0 -18
  338. package/src/components/README.md +0 -16
  339. package/src/components/casino-leaderboard/casino-leaderboard.html +0 -80
  340. package/src/components/casino-leaderboard/casino-leaderboard.scss +0 -585
  341. package/src/components/casino-leaderboard/casino-leaderboard.ts +0 -136
  342. package/src/components/casino-leaderboard/data.ts +0 -111
  343. package/src/components/casino-leaderboard/index.ts +0 -5
  344. package/src/components/casino-leaderboard/todo.txt +0 -2
  345. package/src/components/casino-leaderboard/types.ts +0 -19
  346. package/src/components/leaderboard/components/leaderboard.ts +0 -373
  347. package/src/components/leaderboard/components/player-card.ts +0 -342
  348. package/src/components/leaderboard/components/ui.ts +0 -452
  349. package/src/components/leaderboard/data.ts +0 -152
  350. package/src/components/leaderboard/index.ts +0 -2
  351. package/src/components/leaderboard/main.ts +0 -42
  352. package/src/components/leaderboard/styles.ts +0 -67
  353. package/src/components/leaderboard/types.ts +0 -28
  354. package/src/components/leaderboard-v2/components/sf-leaderboard-player.ts +0 -451
  355. package/src/components/leaderboard-v2/components/sf-leaderboard-ui.ts +0 -512
  356. package/src/components/leaderboard-v2/components/sf-leaderboard.ts +0 -205
  357. package/src/components/leaderboard-v2/constants.ts +0 -16
  358. package/src/components/leaderboard-v2/demo/sample-data.ts +0 -152
  359. package/src/components/leaderboard-v2/events.ts +0 -13
  360. package/src/components/leaderboard-v2/icons.ts +0 -22
  361. package/src/components/leaderboard-v2/index.ts +0 -23
  362. package/src/components/leaderboard-v2/sf-leaderboard.html +0 -1
  363. package/src/components/leaderboard-v2/sf-leaderboard.scss +0 -382
  364. package/src/components/leaderboard-v2/tokens.ts +0 -35
  365. package/src/components/leaderboard-v2/types.ts +0 -30
  366. package/src/components/sf-leaderboard/index.ts +0 -77
  367. package/src/components/sf-leaderboard/sections/footer-section/footer-section.html +0 -3
  368. package/src/components/sf-leaderboard/sections/footer-section/footer-section.scss +0 -18
  369. package/src/components/sf-leaderboard/sections/footer-section/footer-section.ts +0 -22
  370. package/src/components/sf-leaderboard/sections/header-section/header-section.host.ts +0 -14
  371. package/src/components/sf-leaderboard/sections/header-section/header-section.html +0 -27
  372. package/src/components/sf-leaderboard/sections/header-section/header-section.scss +0 -189
  373. package/src/components/sf-leaderboard/sections/header-section/header-section.ts +0 -70
  374. package/src/components/sf-leaderboard/sections/ranking-section/ranking-section.host.ts +0 -22
  375. package/src/components/sf-leaderboard/sections/ranking-section/ranking-section.html +0 -38
  376. package/src/components/sf-leaderboard/sections/ranking-section/ranking-section.scss +0 -99
  377. package/src/components/sf-leaderboard/sections/ranking-section/ranking-section.ts +0 -121
  378. package/src/components/sf-leaderboard/sections/stats-section/stats-section.host.ts +0 -8
  379. package/src/components/sf-leaderboard/sections/stats-section/stats-section.html +0 -6
  380. package/src/components/sf-leaderboard/sections/stats-section/stats-section.scss +0 -44
  381. package/src/components/sf-leaderboard/sections/stats-section/stats-section.ts +0 -41
  382. package/src/components/sf-leaderboard/sections/table-section/table-section.host.ts +0 -17
  383. package/src/components/sf-leaderboard/sections/table-section/table-section.html +0 -19
  384. package/src/components/sf-leaderboard/sections/table-section/table-section.scss +0 -37
  385. package/src/components/sf-leaderboard/sections/table-section/table-section.ts +0 -108
  386. package/src/components/sf-leaderboard/services/index.ts +0 -22
  387. package/src/components/sf-leaderboard/services/sf-leaderboard-data.service.ts +0 -54
  388. package/src/components/sf-leaderboard/services/sf-leaderboard.state.ts +0 -160
  389. package/src/components/sf-leaderboard/shared/components/activity-feed/activity-feed.host.ts +0 -7
  390. package/src/components/sf-leaderboard/shared/components/activity-feed/activity-feed.html +0 -10
  391. package/src/components/sf-leaderboard/shared/components/activity-feed/activity-feed.scss +0 -180
  392. package/src/components/sf-leaderboard/shared/components/activity-feed/activity-feed.ts +0 -88
  393. package/src/components/sf-leaderboard/shared/components/filters/filters.host.ts +0 -12
  394. package/src/components/sf-leaderboard/shared/components/filters/filters.html +0 -22
  395. package/src/components/sf-leaderboard/shared/components/filters/filters.scss +0 -122
  396. package/src/components/sf-leaderboard/shared/components/filters/filters.ts +0 -75
  397. package/src/components/sf-leaderboard/shared/components/player-avatar/player-avatar.host.ts +0 -9
  398. package/src/components/sf-leaderboard/shared/components/player-avatar/player-avatar.html +0 -5
  399. package/src/components/sf-leaderboard/shared/components/player-avatar/player-avatar.scss +0 -81
  400. package/src/components/sf-leaderboard/shared/components/player-avatar/player-avatar.ts +0 -34
  401. package/src/components/sf-leaderboard/shared/components/podium/map-players.ts +0 -24
  402. package/src/components/sf-leaderboard/shared/components/podium/podium.host.ts +0 -10
  403. package/src/components/sf-leaderboard/shared/components/podium/podium.html +0 -53
  404. package/src/components/sf-leaderboard/shared/components/podium/podium.scss +0 -580
  405. package/src/components/sf-leaderboard/shared/components/podium/podium.ts +0 -49
  406. package/src/components/sf-leaderboard/shared/components/podium/podium.types.ts +0 -9
  407. package/src/components/sf-leaderboard/shared/components/rank-badge/rank-badge.host.ts +0 -11
  408. package/src/components/sf-leaderboard/shared/components/rank-badge/rank-badge.html +0 -9
  409. package/src/components/sf-leaderboard/shared/components/rank-badge/rank-badge.scss +0 -98
  410. package/src/components/sf-leaderboard/shared/components/rank-badge/rank-badge.ts +0 -63
  411. package/src/components/sf-leaderboard/shared/components/stat-card/stat-card.host.ts +0 -9
  412. package/src/components/sf-leaderboard/shared/components/stat-card/stat-card.html +0 -15
  413. package/src/components/sf-leaderboard/shared/components/stat-card/stat-card.scss +0 -210
  414. package/src/components/sf-leaderboard/shared/components/stat-card/stat-card.ts +0 -36
  415. package/src/components/sf-leaderboard/shared/components/table/table.host.ts +0 -5
  416. package/src/components/sf-leaderboard/shared/components/table/table.html +0 -11
  417. package/src/components/sf-leaderboard/shared/components/table/table.scss +0 -212
  418. package/src/components/sf-leaderboard/shared/components/table/table.ts +0 -111
  419. package/src/components/sf-leaderboard/shared/constants/defaults.ts +0 -7
  420. package/src/components/sf-leaderboard/shared/constants/filters.ts +0 -16
  421. package/src/components/sf-leaderboard/shared/constants/index.ts +0 -5
  422. package/src/components/sf-leaderboard/shared/constants/player-stats.ts +0 -3
  423. package/src/components/sf-leaderboard/shared/constants/stats-overview.ts +0 -38
  424. package/src/components/sf-leaderboard/shared/constants/tags.ts +0 -16
  425. package/src/components/sf-leaderboard/shared/styles/_section.scss +0 -35
  426. package/src/components/sf-leaderboard/shared/types/data.ts +0 -29
  427. package/src/components/sf-leaderboard/shared/types/events.ts +0 -30
  428. package/src/components/sf-leaderboard/shared/types/player-stats.ts +0 -3
  429. package/src/components/sf-leaderboard/shared/types/sections.ts +0 -100
  430. package/src/components/sf-leaderboard/shared/utils/utils.ts +0 -17
  431. package/src/components/sf-leaderboard/theme/THEMING.md +0 -54
  432. package/src/components/sf-leaderboard/theme/context.ts +0 -16
  433. package/src/components/sf-leaderboard/theme/default-theme.ts +0 -4
  434. package/src/components/sf-leaderboard/theme/hex-to-rgb.ts +0 -25
  435. package/src/components/sf-leaderboard/theme/index.ts +0 -18
  436. package/src/components/sf-leaderboard/theme/inject-theme.ts +0 -39
  437. package/src/components/sf-leaderboard/theme/load-theme.ts +0 -26
  438. package/src/components/sf-leaderboard/theme/merge-theme.ts +0 -59
  439. package/src/components/sf-leaderboard/theme/scss/_colors.scss +0 -101
  440. package/src/components/sf-leaderboard/theme/scss/shared.scss +0 -123
  441. package/src/components/sf-leaderboard/theme/styles.ts +0 -6
  442. package/src/components/sf-leaderboard/theme/theme-to-css-vars.ts +0 -99
  443. package/src/components/sf-leaderboard/theme/themes/fallback.json +0 -62
  444. package/src/components/sf-leaderboard/theme/themes/red.json +0 -62
  445. package/src/components/sf-leaderboard/theme/types.ts +0 -71
  446. package/src/components/sf-live-feed/components/avatar/avatar.host.ts +0 -5
  447. package/src/components/sf-live-feed/components/avatar/avatar.html +0 -3
  448. package/src/components/sf-live-feed/components/avatar/avatar.scss +0 -24
  449. package/src/components/sf-live-feed/components/avatar/avatar.ts +0 -27
  450. package/src/components/sf-live-feed/components/sf-live-feed/sf-live-feed.host.ts +0 -8
  451. package/src/components/sf-live-feed/components/sf-live-feed/sf-live-feed.html +0 -10
  452. package/src/components/sf-live-feed/components/sf-live-feed/sf-live-feed.scss +0 -177
  453. package/src/components/sf-live-feed/components/sf-live-feed/sf-live-feed.ts +0 -65
  454. package/src/components/sf-live-feed/constants.ts +0 -4
  455. package/src/components/sf-live-feed/demo/sample-data.ts +0 -34
  456. package/src/components/sf-live-feed/index.ts +0 -19
  457. package/src/components/sf-live-feed/styles/theme.scss +0 -19
  458. package/src/components/sf-live-feed/styles/theme.ts +0 -5
  459. package/src/components/sf-live-feed/types.ts +0 -19
  460. package/src/components/sf-live-feed/utils.ts +0 -17
  461. package/src/components/streaks/constants.ts +0 -17
  462. package/src/components/streaks/demo/sample-steps.ts +0 -10
  463. package/src/components/streaks/events.ts +0 -8
  464. package/src/components/streaks/index.ts +0 -16
  465. package/src/components/streaks/sf-streaks.html +0 -26
  466. package/src/components/streaks/sf-streaks.scss +0 -351
  467. package/src/components/streaks/sf-streaks.ts +0 -235
  468. package/src/components/streaks/types.ts +0 -7
  469. package/src/lib/lit/component.ts +0 -10
  470. package/src/lib/lit/safe-custom-element.ts +0 -12
  471. package/src/lib/lit/scss.ts +0 -6
  472. package/src/vite-env.d.ts +0 -18
  473. package/styles/global.css +0 -125
  474. package/todo.txt +0 -54
  475. package/tsconfig.json +0 -31
  476. package/vite.config.ts +0 -56
  477. package/vite.docs.config.ts +0 -33
  478. package/vite.lit-html-plugin.ts +0 -43
@@ -1,121 +0,0 @@
1
- import { LitElement, nothing } from 'lit';
2
- import { property } from 'lit/decorators.js';
3
- import { Component } from '../../../../lib/lit/component.js';
4
- import { scss } from '../../../../lib/lit/scss.js';
5
- import { SF_LEADERBOARD_RANKING_SECTION } from '../../shared/constants/tags.js';
6
- import { sfLeaderboardTheme } from '../../theme/styles.js';
7
- import type { Player } from '../../shared/types/data.js';
8
- import type { SfLeaderboardRankingSection as RankingSectionData } from '../../shared/types/sections.js';
9
- import { formatCurrency } from '../../shared/utils/utils.js';
10
- import '../../shared/components/podium/podium.js';
11
- import '../../shared/components/player-stats-card/player-stats-card.js';
12
- import type { RankingSectionHost } from './ranking-section.host.js';
13
- import renderTemplate from './ranking-section.html?lit-html';
14
- import styles from './ranking-section.scss?inline';
15
-
16
- @Component({ selector: SF_LEADERBOARD_RANKING_SECTION })
17
- export class SfLeaderboardRankingBlock
18
- extends LitElement
19
- implements RankingSectionHost
20
- {
21
- static styles = [sfLeaderboardTheme, scss(styles)];
22
-
23
- @property({ attribute: false })
24
- ranking!: RankingSectionData;
25
-
26
- @property({ attribute: false })
27
- lookupPlayers: Player[] = [];
28
-
29
- get hasPair(): boolean {
30
- return this.ranking?.podium != null && this.ranking?.playerStats != null;
31
- }
32
-
33
- get hasPodium(): boolean {
34
- return this.ranking?.podium != null;
35
- }
36
-
37
- get hasPlayerStats(): boolean {
38
- return this.ranking?.playerStats != null;
39
- }
40
-
41
- get podiumTitle(): string {
42
- return this.ranking?.podium?.title ?? 'Top Champions';
43
- }
44
-
45
- get podiumBadge(): string {
46
- return this.ranking?.podium?.badge ?? '';
47
- }
48
-
49
- get showPodiumBadge(): boolean {
50
- return Boolean(this.ranking?.podium?.badge);
51
- }
52
-
53
- get podiumPlayers(): Player[] {
54
- return this.ranking?.podium?.players ?? [];
55
- }
56
-
57
- get playerStatsTitle(): string {
58
- return this.ranking?.playerStats?.title ?? 'Your Position';
59
- }
60
-
61
- private get resolvedPlayerStats() {
62
- const block = this.ranking?.playerStats;
63
- const players = this.lookupPlayers ?? [];
64
- const player = block
65
- ? players.find((p) => p.rank === block.rank)
66
- : undefined;
67
- const percentileMatch = block?.message?.match(/(\d+)\s*%/);
68
-
69
- return {
70
- block,
71
- player,
72
- percentile:
73
- block?.percentile ?? (percentileMatch ? Number(percentileMatch[1]) : 5),
74
- };
75
- }
76
-
77
- get playerStatsRank(): number {
78
- return this.resolvedPlayerStats.block?.rank ?? 0;
79
- }
80
-
81
- get playerStatsPercentile(): number {
82
- return this.resolvedPlayerStats.percentile;
83
- }
84
-
85
- get playerStatsUsername(): string {
86
- const { block, player } = this.resolvedPlayerStats;
87
- return block?.username ?? player?.username ?? 'You';
88
- }
89
-
90
- get playerStatsEarnings(): string {
91
- const { block, player } = this.resolvedPlayerStats;
92
- return (
93
- block?.earnings ?? (player ? formatCurrency(player.totalWinnings) : '$0')
94
- );
95
- }
96
-
97
- get playerStatsWinRate(): number {
98
- const { block, player } = this.resolvedPlayerStats;
99
- return block?.winRate ?? player?.winRate ?? 0;
100
- }
101
-
102
- get playerStatsGamesPlayed(): number {
103
- const { block, player } = this.resolvedPlayerStats;
104
- return block?.gamesPlayed ?? player?.gamesPlayed ?? 0;
105
- }
106
-
107
- get playerStatsWinStreak(): number {
108
- const { block, player } = this.resolvedPlayerStats;
109
- return block?.winStreak ?? player?.streak ?? 0;
110
- }
111
-
112
- get playerStatsLevel(): number {
113
- const { block, player } = this.resolvedPlayerStats;
114
- return block?.level ?? player?.level ?? 0;
115
- }
116
-
117
- render() {
118
- if (!this.ranking?.podium && !this.ranking?.playerStats) return nothing;
119
- return renderTemplate(this);
120
- }
121
- }
@@ -1,8 +0,0 @@
1
- import type { TemplateResult } from 'lit';
2
- import type { SfLeaderboardStatsSection } from '../../shared/types/sections.js';
3
-
4
- export interface StatsSectionHost {
5
- section: SfLeaderboardStatsSection;
6
- hasTitle: boolean;
7
- renderStatCards(): TemplateResult;
8
- }
@@ -1,6 +0,0 @@
1
- <section class="section stats-section">
2
- <div class="section-header" ?hidden="${!host.hasTitle}">
3
- <h2 class="section-title">${host.section.title}</h2>
4
- </div>
5
- <div class="stats-grid">${host.renderStatCards()}</div>
6
- </section>
@@ -1,44 +0,0 @@
1
- @use '../../shared/styles/section';
2
-
3
- :host {
4
- display: block;
5
- width: 100%;
6
- }
7
-
8
- .stats-section .stats-grid {
9
- display: grid;
10
- grid-template-columns: repeat(2, minmax(0, 1fr));
11
- gap: clamp(0.625rem, 2vw, 1rem);
12
- width: 100%;
13
- min-width: 0;
14
- align-items: stretch;
15
- }
16
-
17
- @media (min-width: 640px) and (max-width: 1079px) {
18
- .stats-section .stats-grid {
19
- gap: 0.875rem;
20
- grid-auto-rows: 1fr;
21
- }
22
- }
23
-
24
- @media (min-width: 1080px) {
25
- .stats-section .stats-grid {
26
- grid-template-columns: repeat(4, minmax(0, 1fr));
27
- grid-auto-rows: auto;
28
- gap: 1rem;
29
- }
30
- }
31
-
32
- @media (max-width: 639px) {
33
- .stats-section .stats-grid {
34
- gap: clamp(0.35rem, 2.5vw, 0.5rem);
35
- grid-auto-rows: 1fr;
36
- grid-template-columns: repeat(2, minmax(0, 1fr));
37
- }
38
- }
39
-
40
- @media (max-width: 576px) {
41
- .stats-section .stats-grid {
42
- gap: clamp(0.5rem, 2.8vw, 0.75rem);
43
- }
44
- }
@@ -1,41 +0,0 @@
1
- import { LitElement, nothing } from 'lit';
2
- import { property } from 'lit/decorators.js';
3
- import { Component } from '../../../../../lib/lit/component.js';
4
- import { scss } from '../../../../../lib/lit/scss.js';
5
- import { SF_LEADERBOARD_STATS_SECTION } from '../../shared/constants/tags.js';
6
- import { sfLeaderboardTheme } from '../../theme/styles.js';
7
- import type { SfLeaderboardStatsSection as StatsSectionData } from '../../shared/types/sections.js';
8
- import { SF_LEADERBOARD_STAT_CARD } from '../../shared/constants/tags.js';
9
- import '../../shared/components/stat-card/stat-card.js';
10
- import type { StatsSectionHost } from './stats-section.host.js';
11
- import renderTemplate from './stats-section.html?lit-html';
12
- import styles from './stats-section.scss?inline';
13
-
14
- @Component({ selector: SF_LEADERBOARD_STATS_SECTION })
15
- export class SfLeaderboardStatsBlock extends LitElement implements StatsSectionHost {
16
- static styles = [sfLeaderboardTheme, scss(styles)];
17
-
18
- @property({ attribute: false })
19
- section!: StatsSectionData;
20
-
21
- get hasTitle(): boolean {
22
- return Boolean(this.section?.title);
23
- }
24
-
25
- renderStatCards() {
26
- return this.section.items.map((stat) => {
27
- const card = document.createElement(SF_LEADERBOARD_STAT_CARD);
28
- card.label = stat.label;
29
- card.value = stat.value;
30
- card.icon = stat.icon;
31
- if (stat.trendValue !== undefined) card.trendValue = stat.trendValue;
32
- card.trendPositive = stat.trendPositive ?? true;
33
- return card;
34
- });
35
- }
36
-
37
- render() {
38
- if (!this.section?.items?.length) return nothing;
39
- return renderTemplate(this);
40
- }
41
- }
@@ -1,17 +0,0 @@
1
- import type { Category, TimeFrame } from '../../shared/types/data.js';
2
- import type { SfLeaderboardTableSection } from '../../shared/types/sections.js';
3
-
4
- export interface TableSectionHost {
5
- section: SfLeaderboardTableSection;
6
- hasHeader: boolean;
7
- hasTitle: boolean;
8
- hasSubtitle: boolean;
9
- hasFilters: boolean;
10
- timeframe: TimeFrame;
11
- category: Category;
12
- searchQuery: string;
13
- onTimeframeChange(e: CustomEvent<TimeFrame>): void;
14
- onCategoryChange(e: CustomEvent<Category>): void;
15
- onSearchChange(e: CustomEvent<string>): void;
16
- onPlayerSelect(e: CustomEvent<import('../../shared/types/data.js').Player>): void;
17
- }
@@ -1,19 +0,0 @@
1
- <section class="section table-section">
2
- <div class="table-section-header" ?hidden="${!host.hasHeader}">
3
- <h2 class="section-title" ?hidden="${!host.hasTitle}">${host.section.title}</h2>
4
- <span class="table-subtitle" ?hidden="${!host.hasSubtitle}">${host.section.subtitle}</span>
5
- </div>
6
- <sf-leaderboard-filters
7
- ?hidden="${!host.hasFilters}"
8
- activeTimeframe="${host.timeframe}"
9
- activeCategory="${host.category}"
10
- searchQuery="${host.searchQuery}"
11
- @timeframe-change="${host.onTimeframeChange}"
12
- @category-change="${host.onCategoryChange}"
13
- @search-change="${host.onSearchChange}"
14
- ></sf-leaderboard-filters>
15
- <sf-leaderboard-table
16
- .players="${host.section.players}"
17
- @player-select="${host.onPlayerSelect}"
18
- ></sf-leaderboard-table>
19
- </section>
@@ -1,37 +0,0 @@
1
- @use '../../shared/styles/section';
2
-
3
- :host {
4
- display: block;
5
- width: 100%;
6
- }
7
-
8
- .table-section {
9
- display: flex;
10
- flex-direction: column;
11
- gap: 1rem;
12
- min-width: 0;
13
- }
14
-
15
- .table-section-header {
16
- display: flex;
17
- flex-wrap: wrap;
18
- align-items: baseline;
19
- justify-content: space-between;
20
- gap: 0.5rem;
21
- }
22
-
23
- .table-subtitle {
24
- font-size: 0.875rem;
25
- color: var(--muted-foreground);
26
- }
27
-
28
- .table-section sf-leaderboard-table {
29
- width: 100%;
30
- }
31
-
32
- @media (max-width: 639px) {
33
- .table-section-header {
34
- flex-direction: column;
35
- align-items: flex-start;
36
- }
37
- }
@@ -1,108 +0,0 @@
1
- import { LitElement, nothing } from 'lit';
2
- import { property } from 'lit/decorators.js';
3
- import { Component } from '../../../../../lib/lit/component.js';
4
- import { scss } from '../../../../../lib/lit/scss.js';
5
- import {
6
- DEFAULT_CATEGORY,
7
- DEFAULT_TIMEFRAME,
8
- SF_LEADERBOARD_TABLE_SECTION,
9
- } from '../../shared/constants/index.js';
10
- import { sfLeaderboardTheme } from '../../theme/styles.js';
11
- import type { Category, Player, TimeFrame } from '../../shared/types/data.js';
12
- import {
13
- SF_LEADERBOARD_CATEGORY_CHANGE,
14
- SF_LEADERBOARD_PLAYER_SELECT,
15
- SF_LEADERBOARD_SEARCH_CHANGE,
16
- SF_LEADERBOARD_TIMEFRAME_CHANGE,
17
- } from '../../shared/types/events.js';
18
- import type { SfLeaderboardTableSection as TableSectionData } from '../../shared/types/sections.js';
19
- import '../../shared/components/filters/filters.js';
20
- import '../../shared/components/table/table.js';
21
- import type { TableSectionHost } from './table-section.host.js';
22
- import renderTemplate from './table-section.html?lit-html';
23
- import styles from './table-section.scss?inline';
24
-
25
- @Component({ selector: SF_LEADERBOARD_TABLE_SECTION })
26
- export class SfLeaderboardTableBlock extends LitElement implements TableSectionHost {
27
- static styles = [sfLeaderboardTheme, scss(styles)];
28
-
29
- @property({ attribute: false })
30
- section!: TableSectionData;
31
-
32
- get hasHeader(): boolean {
33
- return Boolean(this.section?.title || this.section?.subtitle);
34
- }
35
-
36
- get hasTitle(): boolean {
37
- return Boolean(this.section?.title);
38
- }
39
-
40
- get hasSubtitle(): boolean {
41
- return Boolean(this.section?.subtitle);
42
- }
43
-
44
- get hasFilters(): boolean {
45
- return Boolean(this.section?.filters);
46
- }
47
-
48
- get timeframe(): TimeFrame {
49
- return this.section.filters?.timeframe ?? DEFAULT_TIMEFRAME;
50
- }
51
-
52
- get category(): Category {
53
- return this.section.filters?.category ?? DEFAULT_CATEGORY;
54
- }
55
-
56
- get searchQuery(): string {
57
- return this.section.filters?.searchQuery ?? '';
58
- }
59
-
60
- onTimeframeChange(e: CustomEvent<TimeFrame>) {
61
- e.stopPropagation();
62
- this.dispatchEvent(
63
- new CustomEvent(SF_LEADERBOARD_TIMEFRAME_CHANGE, {
64
- detail: e.detail,
65
- bubbles: true,
66
- composed: true,
67
- }),
68
- );
69
- }
70
-
71
- onCategoryChange(e: CustomEvent<Category>) {
72
- e.stopPropagation();
73
- this.dispatchEvent(
74
- new CustomEvent(SF_LEADERBOARD_CATEGORY_CHANGE, {
75
- detail: e.detail,
76
- bubbles: true,
77
- composed: true,
78
- }),
79
- );
80
- }
81
-
82
- onSearchChange(e: CustomEvent<string>) {
83
- e.stopPropagation();
84
- this.dispatchEvent(
85
- new CustomEvent(SF_LEADERBOARD_SEARCH_CHANGE, {
86
- detail: e.detail,
87
- bubbles: true,
88
- composed: true,
89
- }),
90
- );
91
- }
92
-
93
- onPlayerSelect(e: CustomEvent<Player>) {
94
- e.stopPropagation();
95
- this.dispatchEvent(
96
- new CustomEvent(SF_LEADERBOARD_PLAYER_SELECT, {
97
- detail: e.detail,
98
- bubbles: true,
99
- composed: true,
100
- }),
101
- );
102
- }
103
-
104
- render() {
105
- if (!this.section) return nothing;
106
- return renderTemplate(this);
107
- }
108
- }
@@ -1,22 +0,0 @@
1
- export { sfLeaderboardDataService } from './sf-leaderboard-data.service.js';
2
- export type {
3
- SfLeaderboardState,
4
- SfLeaderboardConfig,
5
- SfLeaderboardLabels,
6
- SfLeaderboardSectionData,
7
- SfLeaderboardSectionId,
8
- SfLeaderboardSectionEntry,
9
- SfLeaderboardSectionPayloadMap,
10
- SfLeaderboardSectionPatch,
11
- SfLeaderboardData,
12
- } from './sf-leaderboard.state.js';
13
- export {
14
- EMPTY_SF_LEADERBOARD_STATE,
15
- applySectionPatch,
16
- getSectionData,
17
- getSectionId,
18
- hasSection,
19
- patchSectionData,
20
- sectionEntry,
21
- updateSections,
22
- } from './sf-leaderboard.state.js';
@@ -1,54 +0,0 @@
1
- import { BehaviorSubject, type Observable } from 'rxjs';
2
- import {
3
- applySectionPatch,
4
- EMPTY_SF_LEADERBOARD_STATE,
5
- type SfLeaderboardSectionPatch,
6
- type SfLeaderboardState,
7
- updateSections,
8
- } from './sf-leaderboard.state.js';
9
-
10
- /** Holds the leaderboard model as one observable object. */
11
- class SfLeaderboardDataService {
12
- private readonly stateSubject = new BehaviorSubject<SfLeaderboardState>(
13
- EMPTY_SF_LEADERBOARD_STATE,
14
- );
15
-
16
- readonly state$: Observable<SfLeaderboardState> =
17
- this.stateSubject.asObservable();
18
-
19
- /** @deprecated Prefer `state$` */
20
- readonly data$ = this.state$;
21
-
22
- get snapshot(): SfLeaderboardState {
23
- return this.stateSubject.getValue();
24
- }
25
-
26
- setState(state: SfLeaderboardState): void {
27
- this.stateSubject.next(state);
28
- }
29
-
30
- /** Flat partial patch — `{ table: { filters: { searchQuery: 'x' } } }` */
31
- patchState(patch: SfLeaderboardSectionPatch): void {
32
- this.setState(applySectionPatch(this.snapshot, patch));
33
- }
34
-
35
- updateState(
36
- updater: (current: SfLeaderboardState) => SfLeaderboardState,
37
- ): void {
38
- this.setState(updater(this.snapshot));
39
- }
40
-
41
- /** Immer recipe for config/sections when patch objects are not enough. */
42
- updateSections(
43
- recipe: Parameters<typeof updateSections>[1],
44
- ): void {
45
- this.setState(updateSections(this.snapshot, recipe));
46
- }
47
-
48
- /** @deprecated Use `setState` */
49
- setData(state: SfLeaderboardState): void {
50
- this.setState(state);
51
- }
52
- }
53
-
54
- export const sfLeaderboardDataService = new SfLeaderboardDataService();
@@ -1,160 +0,0 @@
1
- import { produce, type Draft } from 'immer';
2
- import type { SfLeaderboardTheme } from '../theme/index.js';
3
- import type {
4
- SfLeaderboardFooterSection,
5
- SfLeaderboardHeaderSection,
6
- SfLeaderboardRankingSection,
7
- SfLeaderboardStatsSection,
8
- SfLeaderboardTableSection,
9
- } from '../shared/types/sections.js';
10
-
11
- export type SfLeaderboardSectionId =
12
- | 'header'
13
- | 'stats'
14
- | 'ranking'
15
- | 'table'
16
- | 'footer';
17
-
18
- export type SfLeaderboardSectionPayloadMap = {
19
- header: SfLeaderboardHeaderSection;
20
- stats: SfLeaderboardStatsSection;
21
- ranking: SfLeaderboardRankingSection;
22
- table: SfLeaderboardTableSection;
23
- footer: SfLeaderboardFooterSection;
24
- };
25
-
26
- /** One layout slot: section id + its render payload. Order in `config.sections` = render order. */
27
- export type SfLeaderboardSectionEntry = {
28
- [K in SfLeaderboardSectionId]: {
29
- [P in K]: { data: SfLeaderboardSectionPayloadMap[K] };
30
- };
31
- }[SfLeaderboardSectionId];
32
-
33
- /** Shared copy not owned by a single section payload. */
34
- export interface SfLeaderboardLabels {
35
- back?: string;
36
- live?: string;
37
- }
38
-
39
- /** Layout, theme, labels, and all section payloads in one place. */
40
- export interface SfLeaderboardConfig {
41
- sections: readonly SfLeaderboardSectionEntry[];
42
- labels?: SfLeaderboardLabels;
43
- theme?: SfLeaderboardTheme;
44
- }
45
-
46
- export interface SfLeaderboardState {
47
- config: SfLeaderboardConfig;
48
- }
49
-
50
- export const EMPTY_SF_LEADERBOARD_STATE: SfLeaderboardState = {
51
- config: { sections: [] },
52
- };
53
-
54
- /** @deprecated Use `SfLeaderboardState` */
55
- export type SfLeaderboardData = SfLeaderboardState;
56
-
57
- /** Flat partial map — patch by section id, same ergonomics as the old `data` object. */
58
- export type SfLeaderboardSectionPatch = {
59
- [K in SfLeaderboardSectionId]?: Partial<SfLeaderboardSectionPayloadMap[K]>;
60
- };
61
-
62
- /** @deprecated Use `SfLeaderboardSectionPatch` */
63
- export type SfLeaderboardSectionData = {
64
- [K in SfLeaderboardSectionId]?: SfLeaderboardSectionPayloadMap[K];
65
- };
66
-
67
- export function getSectionId(
68
- entry: SfLeaderboardSectionEntry,
69
- ): SfLeaderboardSectionId {
70
- if ('header' in entry) return 'header';
71
- if ('stats' in entry) return 'stats';
72
- if ('ranking' in entry) return 'ranking';
73
- if ('table' in entry) return 'table';
74
- return 'footer';
75
- }
76
-
77
- export function hasSection(
78
- state: SfLeaderboardState,
79
- id: SfLeaderboardSectionId,
80
- ): boolean {
81
- return state.config.sections.some((entry) => id in entry);
82
- }
83
-
84
- export function getSectionData<T extends SfLeaderboardSectionId>(
85
- state: SfLeaderboardState,
86
- id: T,
87
- ): SfLeaderboardSectionPayloadMap[T] | undefined {
88
- const entry = state.config.sections.find((section) => id in section);
89
- if (!entry) return undefined;
90
- return (entry as Record<T, { data: SfLeaderboardSectionPayloadMap[T] }>)[id]
91
- .data;
92
- }
93
-
94
- export function sectionEntry<T extends SfLeaderboardSectionId>(
95
- id: T,
96
- data: SfLeaderboardSectionPayloadMap[T],
97
- ): SfLeaderboardSectionEntry {
98
- return { [id]: { data } } as unknown as SfLeaderboardSectionEntry;
99
- }
100
-
101
- function isPlainObject(value: unknown): value is Record<string, unknown> {
102
- return typeof value === 'object' && value !== null && !Array.isArray(value);
103
- }
104
-
105
- /** Deep-merge a partial patch into a draft target (immer-safe — mutates draft). */
106
- function mergePartial(target: Record<string, unknown>, patch: object): void {
107
- for (const [key, value] of Object.entries(patch)) {
108
- if (value === undefined) continue;
109
-
110
- const current = target[key];
111
- if (isPlainObject(value) && isPlainObject(current)) {
112
- mergePartial(current, value);
113
- continue;
114
- }
115
-
116
- target[key] = value;
117
- }
118
- }
119
-
120
- /**
121
- * Apply a flat section patch onto live state (immer).
122
- *
123
- * @example
124
- * applySectionPatch(state, { table: { filters: { searchQuery: 'neo' } } })
125
- * applySectionPatch(state, { header: { isRefreshing: true } })
126
- */
127
- export function applySectionPatch(
128
- state: SfLeaderboardState,
129
- patch: SfLeaderboardSectionPatch,
130
- ): SfLeaderboardState {
131
- return produce(state, (draft) => {
132
- for (const entry of draft.config.sections) {
133
- const id = getSectionId(entry as SfLeaderboardSectionEntry);
134
- const sectionPatch = patch[id];
135
- if (!sectionPatch) continue;
136
-
137
- const slot = entry as Record<
138
- SfLeaderboardSectionId,
139
- { data: SfLeaderboardSectionPayloadMap[SfLeaderboardSectionId] }
140
- >;
141
- mergePartial(
142
- slot[id].data as unknown as Record<string, unknown>,
143
- sectionPatch as object,
144
- );
145
- }
146
- });
147
- }
148
-
149
- /** Immer recipe when a patch object is not enough. */
150
- export function updateSections(
151
- state: SfLeaderboardState,
152
- recipe: (draft: Draft<SfLeaderboardConfig>) => void,
153
- ): SfLeaderboardState {
154
- return produce(state, (draft) => {
155
- recipe(draft.config);
156
- });
157
- }
158
-
159
- /** @deprecated Use `applySectionPatch` */
160
- export const patchSectionData = applySectionPatch;
@@ -1,7 +0,0 @@
1
- import type { TemplateResult } from 'lit';
2
- import type { Activity } from '../../types/data.js';
3
-
4
- export interface ActivityFeedHost {
5
- activities: Activity[];
6
- renderActivities(): TemplateResult;
7
- }
@@ -1,10 +0,0 @@
1
- <div class="feed-container">
2
- <div class="feed-header">
3
- <div class="header-left">
4
- <div class="live-dot"></div>
5
- <span class="header-title">Live Activity</span>
6
- </div>
7
- <span class="event-count">${host.activities.length} events</span>
8
- </div>
9
- <div class="feed-body">${host.renderActivities()}</div>
10
- </div>