volleyballsimtypes 0.0.7 → 0.0.9
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.
- package/dist/cjs/src/data/index.d.ts +3 -0
- package/dist/cjs/src/data/index.js +96 -0
- package/dist/cjs/src/data/models/block.js +98 -0
- package/dist/cjs/src/data/models/coach.js +55 -0
- package/dist/cjs/src/data/models/country.js +40 -0
- package/dist/cjs/src/data/models/event.js +54 -0
- package/dist/cjs/src/data/models/index.d.ts +23 -0
- package/dist/cjs/src/data/models/index.js +47 -0
- package/dist/cjs/src/data/models/league.js +42 -0
- package/dist/cjs/src/data/models/libero-replacement.js +66 -0
- package/dist/cjs/src/data/models/match-set-stats.js +129 -0
- package/dist/cjs/src/data/models/match-set.js +71 -0
- package/dist/cjs/src/data/models/match.js +58 -0
- package/dist/cjs/src/data/models/performance-stats.js +88 -0
- package/dist/cjs/src/data/models/player.d.ts +278 -0
- package/dist/cjs/src/data/models/player.js +66 -0
- package/dist/cjs/src/data/models/rally-position.js +52 -0
- package/dist/cjs/src/data/models/rally.js +50 -0
- package/dist/cjs/src/data/models/reception.js +74 -0
- package/dist/cjs/src/data/models/score.js +62 -0
- package/dist/cjs/src/data/models/season-teams.js +44 -0
- package/dist/cjs/src/data/models/season.js +42 -0
- package/dist/cjs/src/data/models/serve.js +74 -0
- package/dist/cjs/src/data/models/set.js +74 -0
- package/dist/cjs/src/data/models/spike.js +74 -0
- package/dist/cjs/src/data/models/substitution.js +62 -0
- package/dist/cjs/src/data/models/team.js +64 -0
- package/dist/cjs/src/data/transformers/block.js +107 -0
- package/dist/cjs/src/data/transformers/coach.js +30 -0
- package/dist/cjs/src/data/transformers/country.js +20 -0
- package/dist/cjs/src/data/transformers/court-position.js +31 -0
- package/dist/cjs/src/data/transformers/court-target.js +41 -0
- package/dist/cjs/src/data/transformers/event-type.js +31 -0
- package/dist/cjs/src/data/transformers/formation.js +12 -0
- package/dist/cjs/src/data/transformers/index.d.ts +27 -0
- package/dist/cjs/src/data/transformers/index.js +98 -0
- package/dist/cjs/src/data/transformers/league.js +23 -0
- package/dist/cjs/src/data/transformers/libero-replacement.js +53 -0
- package/dist/cjs/src/data/transformers/match-set-stats.js +95 -0
- package/dist/cjs/src/data/transformers/match-set.js +52 -0
- package/dist/cjs/src/data/transformers/match.js +40 -0
- package/dist/cjs/src/data/transformers/performance-stats.js +37 -0
- package/dist/cjs/src/data/transformers/player.js +100 -0
- package/dist/cjs/src/data/transformers/rally-position.js +20 -0
- package/dist/cjs/src/data/transformers/rally.d.ts +7 -0
- package/dist/cjs/src/data/transformers/rally.js +101 -0
- package/dist/cjs/src/data/transformers/reception.js +86 -0
- package/dist/cjs/src/data/transformers/role.js +27 -0
- package/dist/cjs/src/data/transformers/score.js +38 -0
- package/dist/cjs/src/data/transformers/season.js +36 -0
- package/dist/cjs/src/data/transformers/serve.js +88 -0
- package/dist/cjs/src/data/transformers/set.js +86 -0
- package/dist/cjs/src/data/transformers/spike.js +90 -0
- package/dist/cjs/src/data/transformers/substitution.js +37 -0
- package/dist/cjs/src/data/transformers/team.js +40 -0
- package/dist/cjs/src/data/transformers/trait.js +32 -0
- package/dist/cjs/src/index.d.ts +4 -0
- package/dist/cjs/src/index.js +149 -0
- package/dist/cjs/src/routing/events.js +2 -0
- package/dist/cjs/src/routing/index.d.ts +6 -0
- package/dist/cjs/src/routing/index.js +5 -0
- package/dist/cjs/src/routing/league.js +2 -0
- package/dist/cjs/src/routing/match.js +2 -0
- package/dist/cjs/src/routing/player.js +12 -0
- package/dist/cjs/src/routing/team.js +2 -0
- package/dist/cjs/src/service/coach/__stubs__/index.js +46 -0
- package/dist/cjs/src/service/coach/coach.js +15 -0
- package/dist/cjs/src/service/coach/coach.test.js +11 -0
- package/dist/cjs/src/service/coach/formation.js +126 -0
- package/dist/cjs/src/service/coach/formation.test.js +10 -0
- package/dist/cjs/src/service/coach/index.d.ts +3 -0
- package/dist/cjs/src/service/coach/index.js +7 -0
- package/dist/cjs/src/service/country/__stubs__/index.js +15 -0
- package/dist/cjs/src/service/country/country.js +13 -0
- package/dist/cjs/src/service/country/country.test.js +11 -0
- package/dist/cjs/src/service/country/index.d.ts +2 -0
- package/dist/cjs/src/service/country/index.js +5 -0
- package/dist/cjs/src/service/event/__stubs__/index.js +27 -0
- package/dist/cjs/src/service/event/block.js +55 -0
- package/dist/cjs/src/service/event/block.test.js +98 -0
- package/dist/cjs/src/service/event/in-play-event.js +26 -0
- package/dist/cjs/src/service/event/libero-replacement.js +17 -0
- package/dist/cjs/src/service/event/libero-replacement.test.js +36 -0
- package/dist/cjs/src/service/event/rally-event.js +23 -0
- package/dist/cjs/src/service/event/reception.js +30 -0
- package/dist/cjs/src/service/event/reception.test.js +49 -0
- package/dist/cjs/src/service/event/score.js +14 -0
- package/dist/cjs/src/service/event/score.test.js +28 -0
- package/dist/cjs/src/service/event/serve.js +31 -0
- package/dist/cjs/src/service/event/serve.test.js +49 -0
- package/dist/cjs/src/service/event/set.js +30 -0
- package/dist/cjs/src/service/event/set.test.js +49 -0
- package/dist/cjs/src/service/event/spike.js +36 -0
- package/dist/cjs/src/service/event/spike.test.js +63 -0
- package/dist/cjs/src/service/event/substitution.js +11 -0
- package/dist/cjs/src/service/index.d.ts +18 -0
- package/dist/cjs/src/service/index.js +70 -0
- package/dist/cjs/src/service/league/index.d.ts +4 -0
- package/dist/cjs/src/service/league/index.js +9 -0
- package/dist/cjs/src/service/league/league.js +87 -0
- package/dist/cjs/src/service/league/season.js +26 -0
- package/dist/cjs/src/service/league/standing.js +80 -0
- package/dist/cjs/src/service/match/__stubs__/index.js +116 -0
- package/dist/cjs/src/service/match/court-position.js +56 -0
- package/dist/cjs/src/service/match/court-position.test.js +69 -0
- package/dist/cjs/src/service/match/court-target.js +42 -0
- package/dist/cjs/src/service/match/court-target.test.js +37 -0
- package/dist/cjs/src/service/match/index.d.ts +7 -0
- package/dist/cjs/src/service/match/index.js +18 -0
- package/dist/cjs/src/service/match/match-set.js +89 -0
- package/dist/cjs/src/service/match/match-set.test.js +152 -0
- package/dist/cjs/src/service/match/match-team.js +20 -0
- package/dist/cjs/src/service/match/match-team.test.js +16 -0
- package/dist/cjs/src/service/match/match.js +42 -0
- package/dist/cjs/src/service/match/match.test.js +72 -0
- package/dist/cjs/src/service/match/rally.js +51 -0
- package/dist/cjs/src/service/match/rally.test.js +88 -0
- package/dist/cjs/src/service/player/__stubs__/index.js +1425 -0
- package/dist/cjs/src/service/player/index.d.ts +6 -0
- package/dist/cjs/src/service/player/index.js +13 -0
- package/dist/cjs/src/service/player/performance-stats.js +23 -0
- package/dist/cjs/src/service/player/performance-stats.test.js +23 -0
- package/dist/cjs/src/service/player/player.js +61 -0
- package/dist/cjs/src/service/player/player.test.js +49 -0
- package/dist/cjs/src/service/player/role.js +34 -0
- package/dist/cjs/src/service/player/role.test.js +30 -0
- package/dist/cjs/src/service/player/stats.js +31 -0
- package/dist/cjs/src/service/player/stats.test.js +24 -0
- package/dist/cjs/src/service/player/trait.js +97 -0
- package/dist/cjs/src/service/player/trait.test.js +11 -0
- package/dist/cjs/src/service/team/__stubs__/index.js +289 -0
- package/dist/cjs/src/service/team/index.d.ts +2 -0
- package/dist/cjs/src/service/team/index.js +5 -0
- package/dist/cjs/src/service/team/team.js +23 -0
- package/dist/cjs/src/service/team/team.test.js +28 -0
- package/dist/cjs/src/service/utils/enum-utils.js +9 -0
- package/dist/cjs/src/service/utils/enum-utils.test.js +13 -0
- package/dist/cjs/src/service/utils/index.d.ts +5 -0
- package/dist/cjs/src/service/utils/index.js +14 -0
- package/dist/cjs/src/service/utils/object-utils.js +4 -0
- package/dist/cjs/src/service/utils/rng-utils.js +41 -0
- package/dist/cjs/src/service/utils/rng-utils.test.js +31 -0
- package/dist/cjs/src/service/utils/string-utils.js +16 -0
- package/dist/cjs/src/service/utils/string-utils.test.js +27 -0
- package/dist/cjs/src/service/utils/testing-utils.js +2 -0
- package/dist/esm/data/event.formula.json +124 -0
- package/dist/esm/data/role.formula.json +98 -0
- package/dist/esm/data/stat.formula.json +66 -0
- package/dist/esm/src/data/index.d.ts +3 -0
- package/dist/esm/src/data/index.js +3 -0
- package/dist/esm/src/data/models/block.d.ts +59 -0
- package/dist/esm/src/data/models/block.js +94 -0
- package/dist/esm/src/data/models/coach.d.ts +40 -0
- package/dist/esm/src/data/models/coach.js +51 -0
- package/dist/esm/src/data/models/country.d.ts +64 -0
- package/dist/esm/src/data/models/country.js +36 -0
- package/dist/esm/src/data/models/event.d.ts +30 -0
- package/dist/esm/src/data/models/event.js +50 -0
- package/dist/esm/src/data/models/index.d.ts +23 -0
- package/dist/esm/src/data/models/index.js +23 -0
- package/dist/esm/src/data/models/league.d.ts +48 -0
- package/dist/esm/src/data/models/league.js +38 -0
- package/dist/esm/src/data/models/libero-replacement.d.ts +38 -0
- package/dist/esm/src/data/models/libero-replacement.js +62 -0
- package/dist/esm/src/data/models/match-set-stats.d.ts +59 -0
- package/dist/esm/src/data/models/match-set-stats.js +125 -0
- package/dist/esm/src/data/models/match-set.d.ts +78 -0
- package/dist/esm/src/data/models/match-set.js +67 -0
- package/dist/esm/src/data/models/match.d.ts +47 -0
- package/dist/esm/src/data/models/match.js +54 -0
- package/dist/esm/src/data/models/performance-stats.d.ts +40 -0
- package/dist/esm/src/data/models/performance-stats.js +84 -0
- package/dist/esm/src/data/models/player.d.ts +278 -0
- package/dist/esm/src/data/models/player.js +62 -0
- package/dist/esm/src/data/models/rally-position.d.ts +28 -0
- package/dist/esm/src/data/models/rally-position.js +48 -0
- package/dist/esm/src/data/models/rally.d.ts +169 -0
- package/dist/esm/src/data/models/rally.js +46 -0
- package/dist/esm/src/data/models/reception.d.ts +40 -0
- package/dist/esm/src/data/models/reception.js +70 -0
- package/dist/esm/src/data/models/score.d.ts +37 -0
- package/dist/esm/src/data/models/score.js +58 -0
- package/dist/esm/src/data/models/season-teams.d.ts +24 -0
- package/dist/esm/src/data/models/season-teams.js +40 -0
- package/dist/esm/src/data/models/season.d.ts +60 -0
- package/dist/esm/src/data/models/season.js +38 -0
- package/dist/esm/src/data/models/serve.d.ts +40 -0
- package/dist/esm/src/data/models/serve.js +70 -0
- package/dist/esm/src/data/models/set.d.ts +40 -0
- package/dist/esm/src/data/models/set.js +70 -0
- package/dist/esm/src/data/models/spike.d.ts +40 -0
- package/dist/esm/src/data/models/spike.js +70 -0
- package/dist/esm/src/data/models/substitution.d.ts +36 -0
- package/dist/esm/src/data/models/substitution.js +58 -0
- package/dist/esm/src/data/models/team.d.ts +122 -0
- package/dist/esm/src/data/models/team.js +60 -0
- package/dist/esm/src/data/transformers/block.d.ts +7 -0
- package/dist/esm/src/data/transformers/block.js +102 -0
- package/dist/esm/src/data/transformers/coach.d.ts +5 -0
- package/dist/esm/src/data/transformers/coach.js +26 -0
- package/dist/esm/src/data/transformers/country.d.ts +5 -0
- package/dist/esm/src/data/transformers/country.js +16 -0
- package/dist/esm/src/data/transformers/court-position.d.ts +5 -0
- package/dist/esm/src/data/transformers/court-position.js +27 -0
- package/dist/esm/src/data/transformers/court-target.d.ts +5 -0
- package/dist/esm/src/data/transformers/court-target.js +37 -0
- package/dist/esm/src/data/transformers/event-type.d.ts +5 -0
- package/dist/esm/src/data/transformers/event-type.js +27 -0
- package/dist/esm/src/data/transformers/formation.d.ts +5 -0
- package/dist/esm/src/data/transformers/formation.js +8 -0
- package/dist/esm/src/data/transformers/index.d.ts +27 -0
- package/dist/esm/src/data/transformers/index.js +27 -0
- package/dist/esm/src/data/transformers/league.d.ts +5 -0
- package/dist/esm/src/data/transformers/league.js +19 -0
- package/dist/esm/src/data/transformers/libero-replacement.d.ts +7 -0
- package/dist/esm/src/data/transformers/libero-replacement.js +48 -0
- package/dist/esm/src/data/transformers/match-set-stats.d.ts +7 -0
- package/dist/esm/src/data/transformers/match-set-stats.js +90 -0
- package/dist/esm/src/data/transformers/match-set.d.ts +7 -0
- package/dist/esm/src/data/transformers/match-set.js +47 -0
- package/dist/esm/src/data/transformers/match.d.ts +8 -0
- package/dist/esm/src/data/transformers/match.js +35 -0
- package/dist/esm/src/data/transformers/performance-stats.d.ts +5 -0
- package/dist/esm/src/data/transformers/performance-stats.js +33 -0
- package/dist/esm/src/data/transformers/player.d.ts +7 -0
- package/dist/esm/src/data/transformers/player.js +95 -0
- package/dist/esm/src/data/transformers/rally-position.d.ts +5 -0
- package/dist/esm/src/data/transformers/rally-position.js +16 -0
- package/dist/esm/src/data/transformers/rally.d.ts +7 -0
- package/dist/esm/src/data/transformers/rally.js +96 -0
- package/dist/esm/src/data/transformers/reception.d.ts +7 -0
- package/dist/esm/src/data/transformers/reception.js +81 -0
- package/dist/esm/src/data/transformers/role.d.ts +5 -0
- package/dist/esm/src/data/transformers/role.js +23 -0
- package/dist/esm/src/data/transformers/score.d.ts +7 -0
- package/dist/esm/src/data/transformers/score.js +33 -0
- package/dist/esm/src/data/transformers/season.d.ts +7 -0
- package/dist/esm/src/data/transformers/season.js +31 -0
- package/dist/esm/src/data/transformers/serve.d.ts +7 -0
- package/dist/esm/src/data/transformers/serve.js +83 -0
- package/dist/esm/src/data/transformers/set.d.ts +7 -0
- package/dist/esm/src/data/transformers/set.js +81 -0
- package/dist/esm/src/data/transformers/spike.d.ts +7 -0
- package/dist/esm/src/data/transformers/spike.js +85 -0
- package/dist/esm/src/data/transformers/substitution.d.ts +7 -0
- package/dist/esm/src/data/transformers/substitution.js +32 -0
- package/dist/esm/src/data/transformers/team.d.ts +7 -0
- package/dist/esm/src/data/transformers/team.js +35 -0
- package/dist/esm/src/data/transformers/trait.d.ts +7 -0
- package/dist/esm/src/data/transformers/trait.js +27 -0
- package/dist/esm/src/index.d.ts +4 -0
- package/dist/esm/src/index.js +4 -0
- package/dist/esm/src/routing/events.d.ts +50 -0
- package/dist/esm/src/routing/events.js +1 -0
- package/dist/esm/src/routing/index.d.ts +6 -0
- package/dist/esm/src/routing/index.js +2 -0
- package/dist/esm/src/routing/league.d.ts +13 -0
- package/dist/esm/src/routing/league.js +1 -0
- package/dist/esm/src/routing/match.d.ts +46 -0
- package/dist/esm/src/routing/match.js +1 -0
- package/dist/esm/src/routing/player.d.ts +22 -0
- package/dist/esm/src/routing/player.js +9 -0
- package/dist/esm/src/routing/team.d.ts +12 -0
- package/dist/esm/src/routing/team.js +1 -0
- package/dist/esm/src/service/coach/__stubs__/index.d.ts +3 -0
- package/dist/esm/src/service/coach/__stubs__/index.js +43 -0
- package/dist/esm/src/service/coach/coach.d.ts +18 -0
- package/dist/esm/src/service/coach/coach.js +11 -0
- package/dist/esm/src/service/coach/coach.test.d.ts +1 -0
- package/dist/esm/src/service/coach/coach.test.js +9 -0
- package/dist/esm/src/service/coach/formation.d.ts +31 -0
- package/dist/esm/src/service/coach/formation.js +122 -0
- package/dist/esm/src/service/coach/formation.test.d.ts +1 -0
- package/dist/esm/src/service/coach/formation.test.js +8 -0
- package/dist/esm/src/service/coach/index.d.ts +3 -0
- package/dist/esm/src/service/coach/index.js +3 -0
- package/dist/esm/src/service/country/__stubs__/index.d.ts +3 -0
- package/dist/esm/src/service/country/__stubs__/index.js +12 -0
- package/dist/esm/src/service/country/country.d.ts +15 -0
- package/dist/esm/src/service/country/country.js +9 -0
- package/dist/esm/src/service/country/country.test.d.ts +1 -0
- package/dist/esm/src/service/country/country.test.js +9 -0
- package/dist/esm/src/service/country/index.d.ts +2 -0
- package/dist/esm/src/service/country/index.js +2 -0
- package/dist/esm/src/service/event/__stubs__/index.d.ts +4 -0
- package/dist/esm/src/service/event/__stubs__/index.js +24 -0
- package/dist/esm/src/service/event/block.d.ts +29 -0
- package/dist/esm/src/service/event/block.js +51 -0
- package/dist/esm/src/service/event/block.test.d.ts +1 -0
- package/dist/esm/src/service/event/block.test.js +96 -0
- package/dist/esm/src/service/event/in-play-event.d.ts +17 -0
- package/dist/esm/src/service/event/in-play-event.js +19 -0
- package/dist/esm/src/service/event/libero-replacement.d.ts +16 -0
- package/dist/esm/src/service/event/libero-replacement.js +13 -0
- package/dist/esm/src/service/event/libero-replacement.test.d.ts +1 -0
- package/dist/esm/src/service/event/libero-replacement.test.js +34 -0
- package/dist/esm/src/service/event/rally-event.d.ts +24 -0
- package/dist/esm/src/service/event/rally-event.js +19 -0
- package/dist/esm/src/service/event/reception.d.ts +26 -0
- package/dist/esm/src/service/event/reception.js +26 -0
- package/dist/esm/src/service/event/reception.test.d.ts +1 -0
- package/dist/esm/src/service/event/reception.test.js +47 -0
- package/dist/esm/src/service/event/score.d.ts +13 -0
- package/dist/esm/src/service/event/score.js +10 -0
- package/dist/esm/src/service/event/score.test.d.ts +1 -0
- package/dist/esm/src/service/event/score.test.js +26 -0
- package/dist/esm/src/service/event/serve.d.ts +27 -0
- package/dist/esm/src/service/event/serve.js +27 -0
- package/dist/esm/src/service/event/serve.test.d.ts +1 -0
- package/dist/esm/src/service/event/serve.test.js +47 -0
- package/dist/esm/src/service/event/set.d.ts +26 -0
- package/dist/esm/src/service/event/set.js +26 -0
- package/dist/esm/src/service/event/set.test.d.ts +1 -0
- package/dist/esm/src/service/event/set.test.js +47 -0
- package/dist/esm/src/service/event/spike.d.ts +28 -0
- package/dist/esm/src/service/event/spike.js +32 -0
- package/dist/esm/src/service/event/spike.test.d.ts +1 -0
- package/dist/esm/src/service/event/spike.test.js +61 -0
- package/dist/esm/src/service/event/substitution.d.ts +9 -0
- package/dist/esm/src/service/event/substitution.js +7 -0
- package/dist/esm/src/service/index.d.ts +18 -0
- package/dist/esm/src/service/index.js +18 -0
- package/dist/esm/src/service/league/index.d.ts +4 -0
- package/dist/esm/src/service/league/index.js +4 -0
- package/dist/esm/src/service/league/league.d.ts +19 -0
- package/dist/esm/src/service/league/league.js +80 -0
- package/dist/esm/src/service/league/season.d.ts +19 -0
- package/dist/esm/src/service/league/season.js +22 -0
- package/dist/esm/src/service/league/standing.d.ts +26 -0
- package/dist/esm/src/service/league/standing.js +76 -0
- package/dist/esm/src/service/match/__stubs__/index.d.ts +11 -0
- package/dist/esm/src/service/match/__stubs__/index.js +113 -0
- package/dist/esm/src/service/match/court-position.d.ts +21 -0
- package/dist/esm/src/service/match/court-position.js +53 -0
- package/dist/esm/src/service/match/court-position.test.d.ts +1 -0
- package/dist/esm/src/service/match/court-position.test.js +67 -0
- package/dist/esm/src/service/match/court-target.d.ts +21 -0
- package/dist/esm/src/service/match/court-target.js +39 -0
- package/dist/esm/src/service/match/court-target.test.d.ts +1 -0
- package/dist/esm/src/service/match/court-target.test.js +35 -0
- package/dist/esm/src/service/match/index.d.ts +7 -0
- package/dist/esm/src/service/match/index.js +7 -0
- package/dist/esm/src/service/match/match-set.d.ts +71 -0
- package/dist/esm/src/service/match/match-set.js +85 -0
- package/dist/esm/src/service/match/match-set.test.d.ts +1 -0
- package/dist/esm/src/service/match/match-set.test.js +150 -0
- package/dist/esm/src/service/match/match-team.d.ts +7 -0
- package/dist/esm/src/service/match/match-team.js +17 -0
- package/dist/esm/src/service/match/match-team.test.d.ts +1 -0
- package/dist/esm/src/service/match/match-team.test.js +14 -0
- package/dist/esm/src/service/match/match.d.ts +24 -0
- package/dist/esm/src/service/match/match.js +38 -0
- package/dist/esm/src/service/match/match.test.d.ts +1 -0
- package/dist/esm/src/service/match/match.test.js +70 -0
- package/dist/esm/src/service/match/rally.d.ts +41 -0
- package/dist/esm/src/service/match/rally.js +47 -0
- package/dist/esm/src/service/match/rally.test.d.ts +1 -0
- package/dist/esm/src/service/match/rally.test.js +86 -0
- package/dist/esm/src/service/player/__stubs__/index.d.ts +28 -0
- package/dist/esm/src/service/player/__stubs__/index.js +1422 -0
- package/dist/esm/src/service/player/index.d.ts +6 -0
- package/dist/esm/src/service/player/index.js +6 -0
- package/dist/esm/src/service/player/performance-stats.d.ts +28 -0
- package/dist/esm/src/service/player/performance-stats.js +19 -0
- package/dist/esm/src/service/player/performance-stats.test.d.ts +1 -0
- package/dist/esm/src/service/player/performance-stats.test.js +21 -0
- package/dist/esm/src/service/player/player.d.ts +38 -0
- package/dist/esm/src/service/player/player.js +57 -0
- package/dist/esm/src/service/player/player.test.d.ts +1 -0
- package/dist/esm/src/service/player/player.test.js +47 -0
- package/dist/esm/src/service/player/role.d.ts +13 -0
- package/dist/esm/src/service/player/role.js +28 -0
- package/dist/esm/src/service/player/role.test.d.ts +1 -0
- package/dist/esm/src/service/player/role.test.js +28 -0
- package/dist/esm/src/service/player/stats.d.ts +11 -0
- package/dist/esm/src/service/player/stats.js +25 -0
- package/dist/esm/src/service/player/stats.test.d.ts +1 -0
- package/dist/esm/src/service/player/stats.test.js +22 -0
- package/dist/esm/src/service/player/trait.d.ts +21 -0
- package/dist/esm/src/service/player/trait.js +93 -0
- package/dist/esm/src/service/player/trait.test.d.ts +1 -0
- package/dist/esm/src/service/player/trait.test.js +9 -0
- package/dist/esm/src/service/team/__stubs__/index.d.ts +6 -0
- package/dist/esm/src/service/team/__stubs__/index.js +286 -0
- package/dist/esm/src/service/team/index.d.ts +2 -0
- package/dist/esm/src/service/team/index.js +2 -0
- package/dist/esm/src/service/team/team.d.ts +25 -0
- package/dist/esm/src/service/team/team.js +19 -0
- package/dist/esm/src/service/team/team.test.d.ts +1 -0
- package/dist/esm/src/service/team/team.test.js +26 -0
- package/dist/esm/src/service/utils/enum-utils.d.ts +1 -0
- package/dist/esm/src/service/utils/enum-utils.js +5 -0
- package/dist/esm/src/service/utils/enum-utils.test.d.ts +1 -0
- package/dist/esm/src/service/utils/enum-utils.test.js +11 -0
- package/dist/esm/src/service/utils/index.d.ts +5 -0
- package/dist/esm/src/service/utils/index.js +5 -0
- package/dist/esm/src/service/utils/object-utils.d.ts +1 -0
- package/dist/esm/src/service/utils/object-utils.js +1 -0
- package/dist/esm/src/service/utils/rng-utils.d.ts +8 -0
- package/dist/esm/src/service/utils/rng-utils.js +35 -0
- package/dist/esm/src/service/utils/rng-utils.test.d.ts +1 -0
- package/dist/esm/src/service/utils/rng-utils.test.js +29 -0
- package/dist/esm/src/service/utils/string-utils.d.ts +2 -0
- package/dist/esm/src/service/utils/string-utils.js +11 -0
- package/dist/esm/src/service/utils/string-utils.test.d.ts +1 -0
- package/dist/esm/src/service/utils/string-utils.test.js +25 -0
- package/dist/esm/src/service/utils/testing-utils.d.ts +1 -0
- package/dist/esm/src/service/utils/testing-utils.js +1 -0
- package/package.json +40 -42
- package/dist/src/data/index.d.ts +0 -2
- package/dist/src/data/index.js +0 -19
- package/dist/src/data/index.js.map +0 -1
- package/dist/src/data/models/block.js +0 -99
- package/dist/src/data/models/block.js.map +0 -1
- package/dist/src/data/models/coach.js +0 -56
- package/dist/src/data/models/coach.js.map +0 -1
- package/dist/src/data/models/country.js +0 -41
- package/dist/src/data/models/country.js.map +0 -1
- package/dist/src/data/models/event.js +0 -55
- package/dist/src/data/models/event.js.map +0 -1
- package/dist/src/data/models/index.d.ts +0 -22
- package/dist/src/data/models/index.js +0 -39
- package/dist/src/data/models/index.js.map +0 -1
- package/dist/src/data/models/league.js +0 -43
- package/dist/src/data/models/league.js.map +0 -1
- package/dist/src/data/models/libero-replacement.js +0 -67
- package/dist/src/data/models/libero-replacement.js.map +0 -1
- package/dist/src/data/models/match-set-stats.js +0 -130
- package/dist/src/data/models/match-set-stats.js.map +0 -1
- package/dist/src/data/models/match-set.js +0 -72
- package/dist/src/data/models/match-set.js.map +0 -1
- package/dist/src/data/models/match.js +0 -59
- package/dist/src/data/models/match.js.map +0 -1
- package/dist/src/data/models/performance-stats.js +0 -89
- package/dist/src/data/models/performance-stats.js.map +0 -1
- package/dist/src/data/models/player.d.ts +0 -278
- package/dist/src/data/models/player.js +0 -67
- package/dist/src/data/models/player.js.map +0 -1
- package/dist/src/data/models/rally-position.js +0 -53
- package/dist/src/data/models/rally-position.js.map +0 -1
- package/dist/src/data/models/rally.js +0 -51
- package/dist/src/data/models/rally.js.map +0 -1
- package/dist/src/data/models/reception.js +0 -75
- package/dist/src/data/models/reception.js.map +0 -1
- package/dist/src/data/models/score.js +0 -63
- package/dist/src/data/models/score.js.map +0 -1
- package/dist/src/data/models/season-teams.js +0 -45
- package/dist/src/data/models/season-teams.js.map +0 -1
- package/dist/src/data/models/season.js +0 -43
- package/dist/src/data/models/season.js.map +0 -1
- package/dist/src/data/models/serve.js +0 -75
- package/dist/src/data/models/serve.js.map +0 -1
- package/dist/src/data/models/set.js +0 -75
- package/dist/src/data/models/set.js.map +0 -1
- package/dist/src/data/models/spike.js +0 -75
- package/dist/src/data/models/spike.js.map +0 -1
- package/dist/src/data/models/substitution.js +0 -63
- package/dist/src/data/models/substitution.js.map +0 -1
- package/dist/src/data/models/team.js +0 -65
- package/dist/src/data/models/team.js.map +0 -1
- package/dist/src/data/transformers/block.js +0 -109
- package/dist/src/data/transformers/block.js.map +0 -1
- package/dist/src/data/transformers/coach.js +0 -31
- package/dist/src/data/transformers/coach.js.map +0 -1
- package/dist/src/data/transformers/country.js +0 -21
- package/dist/src/data/transformers/country.js.map +0 -1
- package/dist/src/data/transformers/court-position.js +0 -32
- package/dist/src/data/transformers/court-position.js.map +0 -1
- package/dist/src/data/transformers/court-target.js +0 -42
- package/dist/src/data/transformers/court-target.js.map +0 -1
- package/dist/src/data/transformers/event-type.js +0 -32
- package/dist/src/data/transformers/event-type.js.map +0 -1
- package/dist/src/data/transformers/formation.js +0 -13
- package/dist/src/data/transformers/formation.js.map +0 -1
- package/dist/src/data/transformers/index.d.ts +0 -26
- package/dist/src/data/transformers/index.js +0 -43
- package/dist/src/data/transformers/index.js.map +0 -1
- package/dist/src/data/transformers/league.js +0 -24
- package/dist/src/data/transformers/league.js.map +0 -1
- package/dist/src/data/transformers/libero-replacement.js +0 -54
- package/dist/src/data/transformers/libero-replacement.js.map +0 -1
- package/dist/src/data/transformers/match-set-stats.js +0 -96
- package/dist/src/data/transformers/match-set-stats.js.map +0 -1
- package/dist/src/data/transformers/match-set.js +0 -54
- package/dist/src/data/transformers/match-set.js.map +0 -1
- package/dist/src/data/transformers/match.js +0 -41
- package/dist/src/data/transformers/match.js.map +0 -1
- package/dist/src/data/transformers/performance-stats.js +0 -38
- package/dist/src/data/transformers/performance-stats.js.map +0 -1
- package/dist/src/data/transformers/player.js +0 -101
- package/dist/src/data/transformers/player.js.map +0 -1
- package/dist/src/data/transformers/rally-position.js +0 -21
- package/dist/src/data/transformers/rally-position.js.map +0 -1
- package/dist/src/data/transformers/rally.d.ts +0 -7
- package/dist/src/data/transformers/rally.js +0 -102
- package/dist/src/data/transformers/rally.js.map +0 -1
- package/dist/src/data/transformers/reception.js +0 -87
- package/dist/src/data/transformers/reception.js.map +0 -1
- package/dist/src/data/transformers/role.js +0 -28
- package/dist/src/data/transformers/role.js.map +0 -1
- package/dist/src/data/transformers/score.js +0 -39
- package/dist/src/data/transformers/score.js.map +0 -1
- package/dist/src/data/transformers/season.js +0 -37
- package/dist/src/data/transformers/season.js.map +0 -1
- package/dist/src/data/transformers/serve.js +0 -89
- package/dist/src/data/transformers/serve.js.map +0 -1
- package/dist/src/data/transformers/set.js +0 -87
- package/dist/src/data/transformers/set.js.map +0 -1
- package/dist/src/data/transformers/spike.js +0 -91
- package/dist/src/data/transformers/spike.js.map +0 -1
- package/dist/src/data/transformers/substitution.js +0 -38
- package/dist/src/data/transformers/substitution.js.map +0 -1
- package/dist/src/data/transformers/team.js +0 -41
- package/dist/src/data/transformers/team.js.map +0 -1
- package/dist/src/data/transformers/trait.js +0 -33
- package/dist/src/data/transformers/trait.js.map +0 -1
- package/dist/src/index.d.ts +0 -3
- package/dist/src/index.js +0 -22
- package/dist/src/index.js.map +0 -1
- package/dist/src/routing/events.js +0 -3
- package/dist/src/routing/events.js.map +0 -1
- package/dist/src/routing/index.d.ts +0 -5
- package/dist/src/routing/index.js +0 -22
- package/dist/src/routing/index.js.map +0 -1
- package/dist/src/routing/league.js +0 -3
- package/dist/src/routing/league.js.map +0 -1
- package/dist/src/routing/match.js +0 -3
- package/dist/src/routing/match.js.map +0 -1
- package/dist/src/routing/player.js +0 -13
- package/dist/src/routing/player.js.map +0 -1
- package/dist/src/routing/team.js +0 -3
- package/dist/src/routing/team.js.map +0 -1
- package/dist/src/service/coach/__stubs__/index.js +0 -47
- package/dist/src/service/coach/__stubs__/index.js.map +0 -1
- package/dist/src/service/coach/coach.js +0 -16
- package/dist/src/service/coach/coach.js.map +0 -1
- package/dist/src/service/coach/coach.test.js +0 -12
- package/dist/src/service/coach/coach.test.js.map +0 -1
- package/dist/src/service/coach/formation.js +0 -127
- package/dist/src/service/coach/formation.js.map +0 -1
- package/dist/src/service/coach/formation.test.js +0 -11
- package/dist/src/service/coach/formation.test.js.map +0 -1
- package/dist/src/service/coach/index.d.ts +0 -2
- package/dist/src/service/coach/index.js +0 -19
- package/dist/src/service/coach/index.js.map +0 -1
- package/dist/src/service/country/__stubs__/index.js +0 -16
- package/dist/src/service/country/__stubs__/index.js.map +0 -1
- package/dist/src/service/country/country.js +0 -14
- package/dist/src/service/country/country.js.map +0 -1
- package/dist/src/service/country/country.test.js +0 -12
- package/dist/src/service/country/country.test.js.map +0 -1
- package/dist/src/service/country/index.d.ts +0 -1
- package/dist/src/service/country/index.js +0 -18
- package/dist/src/service/country/index.js.map +0 -1
- package/dist/src/service/event/__stubs__/index.js +0 -28
- package/dist/src/service/event/__stubs__/index.js.map +0 -1
- package/dist/src/service/event/block.js +0 -56
- package/dist/src/service/event/block.js.map +0 -1
- package/dist/src/service/event/block.test.js +0 -99
- package/dist/src/service/event/block.test.js.map +0 -1
- package/dist/src/service/event/in-play-event.js +0 -28
- package/dist/src/service/event/in-play-event.js.map +0 -1
- package/dist/src/service/event/libero-replacement.js +0 -18
- package/dist/src/service/event/libero-replacement.js.map +0 -1
- package/dist/src/service/event/libero-replacement.test.js +0 -37
- package/dist/src/service/event/libero-replacement.test.js.map +0 -1
- package/dist/src/service/event/rally-event.js +0 -24
- package/dist/src/service/event/rally-event.js.map +0 -1
- package/dist/src/service/event/reception.js +0 -31
- package/dist/src/service/event/reception.js.map +0 -1
- package/dist/src/service/event/reception.test.js +0 -50
- package/dist/src/service/event/reception.test.js.map +0 -1
- package/dist/src/service/event/score.js +0 -15
- package/dist/src/service/event/score.js.map +0 -1
- package/dist/src/service/event/score.test.js +0 -29
- package/dist/src/service/event/score.test.js.map +0 -1
- package/dist/src/service/event/serve.js +0 -32
- package/dist/src/service/event/serve.js.map +0 -1
- package/dist/src/service/event/serve.test.js +0 -50
- package/dist/src/service/event/serve.test.js.map +0 -1
- package/dist/src/service/event/set.js +0 -31
- package/dist/src/service/event/set.js.map +0 -1
- package/dist/src/service/event/set.test.js +0 -50
- package/dist/src/service/event/set.test.js.map +0 -1
- package/dist/src/service/event/spike.js +0 -37
- package/dist/src/service/event/spike.js.map +0 -1
- package/dist/src/service/event/spike.test.js +0 -64
- package/dist/src/service/event/spike.test.js.map +0 -1
- package/dist/src/service/event/substitution.js +0 -12
- package/dist/src/service/event/substitution.js.map +0 -1
- package/dist/src/service/index.d.ts +0 -17
- package/dist/src/service/index.js +0 -34
- package/dist/src/service/index.js.map +0 -1
- package/dist/src/service/league/index.d.ts +0 -3
- package/dist/src/service/league/index.js +0 -20
- package/dist/src/service/league/index.js.map +0 -1
- package/dist/src/service/league/league.js +0 -88
- package/dist/src/service/league/league.js.map +0 -1
- package/dist/src/service/league/season.js +0 -27
- package/dist/src/service/league/season.js.map +0 -1
- package/dist/src/service/league/standing.js +0 -81
- package/dist/src/service/league/standing.js.map +0 -1
- package/dist/src/service/main.d.ts +0 -1
- package/dist/src/service/main.js +0 -56
- package/dist/src/service/main.js.map +0 -1
- package/dist/src/service/match/__stubs__/index.js +0 -117
- package/dist/src/service/match/__stubs__/index.js.map +0 -1
- package/dist/src/service/match/court-position.js +0 -57
- package/dist/src/service/match/court-position.js.map +0 -1
- package/dist/src/service/match/court-position.test.js +0 -70
- package/dist/src/service/match/court-position.test.js.map +0 -1
- package/dist/src/service/match/court-target.js +0 -43
- package/dist/src/service/match/court-target.js.map +0 -1
- package/dist/src/service/match/court-target.test.js +0 -38
- package/dist/src/service/match/court-target.test.js.map +0 -1
- package/dist/src/service/match/index.d.ts +0 -6
- package/dist/src/service/match/index.js +0 -23
- package/dist/src/service/match/index.js.map +0 -1
- package/dist/src/service/match/match-set.js +0 -90
- package/dist/src/service/match/match-set.js.map +0 -1
- package/dist/src/service/match/match-set.test.js +0 -153
- package/dist/src/service/match/match-set.test.js.map +0 -1
- package/dist/src/service/match/match-team.js +0 -21
- package/dist/src/service/match/match-team.js.map +0 -1
- package/dist/src/service/match/match-team.test.js +0 -17
- package/dist/src/service/match/match-team.test.js.map +0 -1
- package/dist/src/service/match/match.js +0 -43
- package/dist/src/service/match/match.js.map +0 -1
- package/dist/src/service/match/match.test.js +0 -73
- package/dist/src/service/match/match.test.js.map +0 -1
- package/dist/src/service/match/rally.js +0 -52
- package/dist/src/service/match/rally.js.map +0 -1
- package/dist/src/service/match/rally.test.js +0 -91
- package/dist/src/service/match/rally.test.js.map +0 -1
- package/dist/src/service/player/__stubs__/index.js +0 -1426
- package/dist/src/service/player/__stubs__/index.js.map +0 -1
- package/dist/src/service/player/index.d.ts +0 -5
- package/dist/src/service/player/index.js +0 -22
- package/dist/src/service/player/index.js.map +0 -1
- package/dist/src/service/player/performance-stats.js +0 -24
- package/dist/src/service/player/performance-stats.js.map +0 -1
- package/dist/src/service/player/performance-stats.test.js +0 -24
- package/dist/src/service/player/performance-stats.test.js.map +0 -1
- package/dist/src/service/player/player.js +0 -62
- package/dist/src/service/player/player.js.map +0 -1
- package/dist/src/service/player/player.test.js +0 -50
- package/dist/src/service/player/player.test.js.map +0 -1
- package/dist/src/service/player/role.js +0 -35
- package/dist/src/service/player/role.js.map +0 -1
- package/dist/src/service/player/role.test.js +0 -31
- package/dist/src/service/player/role.test.js.map +0 -1
- package/dist/src/service/player/stats.js +0 -32
- package/dist/src/service/player/stats.js.map +0 -1
- package/dist/src/service/player/stats.test.js +0 -25
- package/dist/src/service/player/stats.test.js.map +0 -1
- package/dist/src/service/player/trait.js +0 -98
- package/dist/src/service/player/trait.js.map +0 -1
- package/dist/src/service/player/trait.test.js +0 -12
- package/dist/src/service/player/trait.test.js.map +0 -1
- package/dist/src/service/team/__stubs__/index.js +0 -290
- package/dist/src/service/team/__stubs__/index.js.map +0 -1
- package/dist/src/service/team/index.d.ts +0 -1
- package/dist/src/service/team/index.js +0 -18
- package/dist/src/service/team/index.js.map +0 -1
- package/dist/src/service/team/team.js +0 -25
- package/dist/src/service/team/team.js.map +0 -1
- package/dist/src/service/team/team.test.js +0 -29
- package/dist/src/service/team/team.test.js.map +0 -1
- package/dist/src/service/utils/enum-utils.js +0 -10
- package/dist/src/service/utils/enum-utils.js.map +0 -1
- package/dist/src/service/utils/enum-utils.test.js +0 -14
- package/dist/src/service/utils/enum-utils.test.js.map +0 -1
- package/dist/src/service/utils/index.d.ts +0 -4
- package/dist/src/service/utils/index.js +0 -21
- package/dist/src/service/utils/index.js.map +0 -1
- package/dist/src/service/utils/object-utils.js +0 -5
- package/dist/src/service/utils/object-utils.js.map +0 -1
- package/dist/src/service/utils/rng-utils.js +0 -42
- package/dist/src/service/utils/rng-utils.js.map +0 -1
- package/dist/src/service/utils/rng-utils.test.js +0 -32
- package/dist/src/service/utils/rng-utils.test.js.map +0 -1
- package/dist/src/service/utils/string-utils.js +0 -17
- package/dist/src/service/utils/string-utils.js.map +0 -1
- package/dist/src/service/utils/string-utils.test.js +0 -28
- package/dist/src/service/utils/string-utils.test.js.map +0 -1
- package/dist/src/service/utils/testing-utils.js +0 -3
- package/dist/src/service/utils/testing-utils.js.map +0 -1
- package/src/data/index.ts +0 -2
- package/src/data/models/block.ts +0 -159
- package/src/data/models/coach.ts +0 -94
- package/src/data/models/country.ts +0 -105
- package/src/data/models/event.ts +0 -83
- package/src/data/models/index.ts +0 -22
- package/src/data/models/league.ts +0 -90
- package/src/data/models/libero-replacement.ts +0 -104
- package/src/data/models/match-set-stats.ts +0 -204
- package/src/data/models/match-set.ts +0 -152
- package/src/data/models/match.ts +0 -106
- package/src/data/models/performance-stats.ts +0 -136
- package/src/data/models/player.ts +0 -370
- package/src/data/models/rally-position.ts +0 -79
- package/src/data/models/rally.ts +0 -229
- package/src/data/models/reception.ts +0 -113
- package/src/data/models/score.ts +0 -99
- package/src/data/models/season-teams.ts +0 -67
- package/src/data/models/season.ts +0 -103
- package/src/data/models/serve.ts +0 -113
- package/src/data/models/set.ts +0 -113
- package/src/data/models/spike.ts +0 -113
- package/src/data/models/substitution.ts +0 -98
- package/src/data/models/team.ts +0 -193
- package/src/data/transformers/block.ts +0 -117
- package/src/data/transformers/coach.ts +0 -33
- package/src/data/transformers/country.ts +0 -23
- package/src/data/transformers/court-position.ts +0 -43
- package/src/data/transformers/court-target.ts +0 -58
- package/src/data/transformers/event-type.ts +0 -35
- package/src/data/transformers/formation.ts +0 -16
- package/src/data/transformers/index.ts +0 -27
- package/src/data/transformers/league.ts +0 -26
- package/src/data/transformers/libero-replacement.ts +0 -62
- package/src/data/transformers/match-set-stats.ts +0 -101
- package/src/data/transformers/match-set.ts +0 -59
- package/src/data/transformers/match.ts +0 -48
- package/src/data/transformers/performance-stats.ts +0 -40
- package/src/data/transformers/player.ts +0 -109
- package/src/data/transformers/rally-position.ts +0 -24
- package/src/data/transformers/rally.ts +0 -139
- package/src/data/transformers/reception.ts +0 -98
- package/src/data/transformers/role.ts +0 -31
- package/src/data/transformers/score.ts +0 -43
- package/src/data/transformers/season.ts +0 -42
- package/src/data/transformers/serve.ts +0 -100
- package/src/data/transformers/set.ts +0 -98
- package/src/data/transformers/spike.ts +0 -102
- package/src/data/transformers/substitution.ts +0 -42
- package/src/data/transformers/team.ts +0 -45
- package/src/data/transformers/trait.ts +0 -37
- package/src/index.ts +0 -7
- package/src/routing/events.ts +0 -60
- package/src/routing/index.ts +0 -5
- package/src/routing/league.ts +0 -15
- package/src/routing/match.ts +0 -52
- package/src/routing/player.ts +0 -24
- package/src/routing/team.ts +0 -14
- package/src/service/coach/__stubs__/index.ts +0 -46
- package/src/service/coach/coach.test.ts +0 -10
- package/src/service/coach/coach.ts +0 -30
- package/src/service/coach/formation.test.ts +0 -10
- package/src/service/coach/formation.ts +0 -160
- package/src/service/coach/index.ts +0 -2
- package/src/service/country/__stubs__/index.ts +0 -13
- package/src/service/country/country.test.ts +0 -10
- package/src/service/country/country.ts +0 -23
- package/src/service/country/index.ts +0 -1
- package/src/service/event/__stubs__/index.ts +0 -25
- package/src/service/event/block.test.ts +0 -100
- package/src/service/event/block.ts +0 -69
- package/src/service/event/in-play-event.ts +0 -37
- package/src/service/event/libero-replacement.test.ts +0 -37
- package/src/service/event/libero-replacement.ts +0 -25
- package/src/service/event/rally-event.ts +0 -33
- package/src/service/event/reception.test.ts +0 -50
- package/src/service/event/reception.ts +0 -38
- package/src/service/event/score.test.ts +0 -29
- package/src/service/event/score.ts +0 -22
- package/src/service/event/serve.test.ts +0 -50
- package/src/service/event/serve.ts +0 -39
- package/src/service/event/set.test.ts +0 -50
- package/src/service/event/set.ts +0 -38
- package/src/service/event/spike.test.ts +0 -64
- package/src/service/event/spike.ts +0 -46
- package/src/service/event/substitution.ts +0 -16
- package/src/service/index.ts +0 -17
- package/src/service/league/index.ts +0 -3
- package/src/service/league/league.ts +0 -112
- package/src/service/league/season.ts +0 -41
- package/src/service/league/standing.ts +0 -82
- package/src/service/main.ts +0 -52
- package/src/service/match/__stubs__/index.ts +0 -119
- package/src/service/match/court-position.test.ts +0 -73
- package/src/service/match/court-position.ts +0 -46
- package/src/service/match/court-target.test.ts +0 -39
- package/src/service/match/court-target.ts +0 -30
- package/src/service/match/index.ts +0 -6
- package/src/service/match/match-set.test.ts +0 -174
- package/src/service/match/match-set.ts +0 -140
- package/src/service/match/match-team.test.ts +0 -16
- package/src/service/match/match-team.ts +0 -13
- package/src/service/match/match.test.ts +0 -80
- package/src/service/match/match.ts +0 -63
- package/src/service/match/rally.test.ts +0 -94
- package/src/service/match/rally.ts +0 -79
- package/src/service/player/__stubs__/index.ts +0 -1433
- package/src/service/player/index.ts +0 -5
- package/src/service/player/performance-stats.test.ts +0 -24
- package/src/service/player/performance-stats.ts +0 -47
- package/src/service/player/player.test.ts +0 -51
- package/src/service/player/player.ts +0 -101
- package/src/service/player/role.test.ts +0 -29
- package/src/service/player/role.ts +0 -33
- package/src/service/player/stats.test.ts +0 -23
- package/src/service/player/stats.ts +0 -29
- package/src/service/player/trait.test.ts +0 -10
- package/src/service/player/trait.ts +0 -124
- package/src/service/team/__stubs__/index.ts +0 -290
- package/src/service/team/index.ts +0 -1
- package/src/service/team/team.test.ts +0 -30
- package/src/service/team/team.ts +0 -45
- package/src/service/utils/enum-utils.test.ts +0 -10
- package/src/service/utils/enum-utils.ts +0 -6
- package/src/service/utils/index.ts +0 -4
- package/src/service/utils/object-utils.ts +0 -1
- package/src/service/utils/rng-utils.test.ts +0 -32
- package/src/service/utils/rng-utils.ts +0 -41
- package/src/service/utils/string-utils.test.ts +0 -28
- package/src/service/utils/string-utils.ts +0 -13
- package/src/service/utils/testing-utils.ts +0 -2
- /package/dist/{data/formula → cjs/data}/event.formula.json +0 -0
- /package/dist/{data/formula → cjs/data}/role.formula.json +0 -0
- /package/dist/{data/formula → cjs/data}/stat.formula.json +0 -0
- /package/dist/{src → cjs/src}/data/models/block.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/coach.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/country.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/event.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/league.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/libero-replacement.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/match-set-stats.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/match-set.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/match.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/performance-stats.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/rally-position.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/rally.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/reception.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/score.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/season-teams.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/season.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/serve.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/set.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/spike.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/substitution.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/models/team.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/block.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/coach.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/country.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/court-position.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/court-target.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/event-type.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/formation.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/league.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/libero-replacement.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/match-set-stats.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/match-set.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/match.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/performance-stats.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/player.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/rally-position.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/reception.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/role.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/score.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/season.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/serve.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/set.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/spike.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/substitution.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/team.d.ts +0 -0
- /package/dist/{src → cjs/src}/data/transformers/trait.d.ts +0 -0
- /package/dist/{src → cjs/src}/routing/events.d.ts +0 -0
- /package/dist/{src → cjs/src}/routing/league.d.ts +0 -0
- /package/dist/{src → cjs/src}/routing/match.d.ts +0 -0
- /package/dist/{src → cjs/src}/routing/player.d.ts +0 -0
- /package/dist/{src → cjs/src}/routing/team.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/coach/__stubs__/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/coach/coach.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/coach/coach.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/coach/formation.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/coach/formation.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/country/__stubs__/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/country/country.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/country/country.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/__stubs__/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/block.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/block.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/in-play-event.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/libero-replacement.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/libero-replacement.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/rally-event.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/reception.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/reception.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/score.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/score.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/serve.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/serve.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/set.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/set.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/spike.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/spike.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/event/substitution.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/league/league.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/league/season.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/league/standing.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/__stubs__/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/court-position.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/court-position.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/court-target.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/court-target.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/match-set.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/match-set.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/match-team.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/match-team.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/match.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/match.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/rally.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/match/rally.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/__stubs__/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/performance-stats.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/performance-stats.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/player.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/player.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/role.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/role.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/stats.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/stats.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/trait.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/player/trait.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/team/__stubs__/index.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/team/team.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/team/team.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/enum-utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/enum-utils.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/object-utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/rng-utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/rng-utils.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/string-utils.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/string-utils.test.d.ts +0 -0
- /package/dist/{src → cjs/src}/service/utils/testing-utils.d.ts +0 -0
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import { Name, Player, PlayerOpts, Stat } from './player';
|
|
2
|
+
import { PerformanceStats, PerformanceStatsOpts } from './performance-stats';
|
|
3
|
+
import { Role } from './role';
|
|
4
|
+
import { Trait } from './trait';
|
|
5
|
+
import { GeneralStat } from './stats';
|
|
6
|
+
export { PerformanceStatsOpts, PlayerOpts, Player, PerformanceStats, GeneralStat, Name, Stat, Role, Trait, };
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Trait = exports.Role = exports.GeneralStat = exports.PerformanceStats = exports.Player = void 0;
|
|
4
|
+
const player_1 = require("./player");
|
|
5
|
+
Object.defineProperty(exports, "Player", { enumerable: true, get: function () { return player_1.Player; } });
|
|
6
|
+
const performance_stats_1 = require("./performance-stats");
|
|
7
|
+
Object.defineProperty(exports, "PerformanceStats", { enumerable: true, get: function () { return performance_stats_1.PerformanceStats; } });
|
|
8
|
+
const role_1 = require("./role");
|
|
9
|
+
Object.defineProperty(exports, "Role", { enumerable: true, get: function () { return role_1.Role; } });
|
|
10
|
+
const trait_1 = require("./trait");
|
|
11
|
+
Object.defineProperty(exports, "Trait", { enumerable: true, get: function () { return trait_1.Trait; } });
|
|
12
|
+
const stats_1 = require("./stats");
|
|
13
|
+
Object.defineProperty(exports, "GeneralStat", { enumerable: true, get: function () { return stats_1.GeneralStat; } });
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.PerformanceStats = void 0;
|
|
4
|
+
const utils_1 = require("../utils");
|
|
5
|
+
class PerformanceStats {
|
|
6
|
+
constructor(opts) {
|
|
7
|
+
this.serve = opts.serve;
|
|
8
|
+
this.pass = opts.pass;
|
|
9
|
+
this.setting = opts.setting;
|
|
10
|
+
this.reception = opts.reception;
|
|
11
|
+
this.spike = opts.spike;
|
|
12
|
+
this.backAttack = opts.backAttack;
|
|
13
|
+
this.jump = opts.jump;
|
|
14
|
+
this.block = opts.block;
|
|
15
|
+
this.awareness = opts.awareness;
|
|
16
|
+
this.defense = opts.defense;
|
|
17
|
+
this.stamina = opts.stamina;
|
|
18
|
+
}
|
|
19
|
+
toString() {
|
|
20
|
+
return (0, utils_1.getKeys)(this).map(key => `${key}: ${this[key]}`).join(', ');
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
exports.PerformanceStats = PerformanceStats;
|
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const globals_1 = require("@jest/globals");
|
|
4
|
+
const __stubs__1 = require("./__stubs__");
|
|
5
|
+
(0, globals_1.describe)('PerformanceStats Test Module', () => {
|
|
6
|
+
(0, globals_1.test)('Should instantiate object properly', () => {
|
|
7
|
+
(0, globals_1.expect)(__stubs__1.performance.serve).toBe(6);
|
|
8
|
+
(0, globals_1.expect)(__stubs__1.performance.setting).toBe(1);
|
|
9
|
+
(0, globals_1.expect)(__stubs__1.performance.pass).toBe(11);
|
|
10
|
+
(0, globals_1.expect)(__stubs__1.performance.reception).toBe(2);
|
|
11
|
+
(0, globals_1.expect)(__stubs__1.performance.spike).toBe(7);
|
|
12
|
+
(0, globals_1.expect)(__stubs__1.performance.backAttack).toBe(3);
|
|
13
|
+
(0, globals_1.expect)(__stubs__1.performance.jump).toBe(10);
|
|
14
|
+
(0, globals_1.expect)(__stubs__1.performance.block).toBe(4);
|
|
15
|
+
(0, globals_1.expect)(__stubs__1.performance.awareness).toBe(5);
|
|
16
|
+
(0, globals_1.expect)(__stubs__1.performance.defense).toBe(8);
|
|
17
|
+
(0, globals_1.expect)(__stubs__1.performance.stamina).toBe(11);
|
|
18
|
+
});
|
|
19
|
+
(0, globals_1.test)('Should print all stats properly', () => {
|
|
20
|
+
const expected = 'serve: 6, pass: 11, setting: 1, reception: 2, spike: 7, backAttack: 3, jump: 10, block: 4, awareness: 5, defense: 8, stamina: 11';
|
|
21
|
+
(0, globals_1.expect)(__stubs__1.performance.toString()).toBe(expected);
|
|
22
|
+
});
|
|
23
|
+
});
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Player = void 0;
|
|
4
|
+
const role_1 = require("./role");
|
|
5
|
+
const utils_1 = require("../utils");
|
|
6
|
+
const stats_1 = require("./stats");
|
|
7
|
+
class Player {
|
|
8
|
+
constructor({ id, name, country, stats, roles, traits, jerseyNumber, team }) {
|
|
9
|
+
(0, utils_1.validateUUID)(id);
|
|
10
|
+
this.id = id;
|
|
11
|
+
this.name = name;
|
|
12
|
+
this.country = country;
|
|
13
|
+
this.stats = stats;
|
|
14
|
+
this.roles = roles;
|
|
15
|
+
this.traits = traits;
|
|
16
|
+
this.jerseyNumber = jerseyNumber;
|
|
17
|
+
this.team = team;
|
|
18
|
+
this.generalStats = stats_1.GeneralStat.getStats()
|
|
19
|
+
.map(stat => ({
|
|
20
|
+
name: stat,
|
|
21
|
+
value: stats_1.GeneralStat.calculateScore(stats, stat)
|
|
22
|
+
}));
|
|
23
|
+
}
|
|
24
|
+
// Used as a base sorting function for players
|
|
25
|
+
static sortPlayers(roles) {
|
|
26
|
+
return (p1, p2) => roles.reduce((x, role) => {
|
|
27
|
+
const p2Score = role_1.Role.calculateScore(p2.stats, role);
|
|
28
|
+
const p1Score = role_1.Role.calculateScore(p1.stats, role);
|
|
29
|
+
return x + p2Score - p1Score;
|
|
30
|
+
}, 0);
|
|
31
|
+
}
|
|
32
|
+
canPlayLibero() {
|
|
33
|
+
return this.roles.includes(role_1.Role.LIBERO);
|
|
34
|
+
}
|
|
35
|
+
static compareStats(p1, p2) {
|
|
36
|
+
const compareFn = (acc, current) => {
|
|
37
|
+
let x = current.value;
|
|
38
|
+
switch (current.name) {
|
|
39
|
+
case stats_1.GeneralStat.ATTACK:
|
|
40
|
+
x *= 0.35;
|
|
41
|
+
break;
|
|
42
|
+
case stats_1.GeneralStat.DEFENSE:
|
|
43
|
+
x *= 0.35;
|
|
44
|
+
break;
|
|
45
|
+
case stats_1.GeneralStat.SERVE:
|
|
46
|
+
x *= 0.2;
|
|
47
|
+
break;
|
|
48
|
+
case stats_1.GeneralStat.PHYSICAL:
|
|
49
|
+
x *= 0.1;
|
|
50
|
+
break;
|
|
51
|
+
default:
|
|
52
|
+
x *= 0;
|
|
53
|
+
}
|
|
54
|
+
return acc + x;
|
|
55
|
+
};
|
|
56
|
+
const s1 = p1.generalStats.reduce(compareFn, 0);
|
|
57
|
+
const s2 = p2.generalStats.reduce(compareFn, 0);
|
|
58
|
+
return s2 - s1;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
exports.Player = Player;
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const globals_1 = require("@jest/globals");
|
|
4
|
+
const player_1 = require("./player");
|
|
5
|
+
const role_1 = require("./role");
|
|
6
|
+
const __stubs__1 = require("./__stubs__");
|
|
7
|
+
(0, globals_1.describe)('Player Test Module', () => {
|
|
8
|
+
(0, globals_1.test)('Should instantiate object properly', () => {
|
|
9
|
+
(0, globals_1.expect)(__stubs__1.player.id).toBe('622c36dc-f2d2-44b3-a744-667ea53218b7');
|
|
10
|
+
(0, globals_1.expect)(__stubs__1.player.roles).toEqual([role_1.Role.SETTER, role_1.Role.OPPOSITE_HITTER]);
|
|
11
|
+
(0, globals_1.expect)(__stubs__1.player.name.first).toEqual('Francisco');
|
|
12
|
+
(0, globals_1.expect)(__stubs__1.player.name.last).toEqual('Farias');
|
|
13
|
+
(0, globals_1.expect)(__stubs__1.player.stats).toEqual({
|
|
14
|
+
serve: 6,
|
|
15
|
+
setting: 1,
|
|
16
|
+
reception: 2,
|
|
17
|
+
spike: 7,
|
|
18
|
+
backAttack: 3,
|
|
19
|
+
jump: 10,
|
|
20
|
+
block: 4,
|
|
21
|
+
awareness: 5,
|
|
22
|
+
defense: 8,
|
|
23
|
+
stamina: 11,
|
|
24
|
+
pass: 11
|
|
25
|
+
});
|
|
26
|
+
});
|
|
27
|
+
(0, globals_1.test)('Should sort players according to Role Score', () => {
|
|
28
|
+
const sortedArrays = {
|
|
29
|
+
single: [...__stubs__1.players].sort(player_1.Player.sortPlayers([role_1.Role.LIBERO])),
|
|
30
|
+
multiple: [...__stubs__1.players].sort(player_1.Player.sortPlayers([role_1.Role.MIDDLE_BLOCKER, role_1.Role.SETTER])),
|
|
31
|
+
all: [...__stubs__1.players].sort(player_1.Player.sortPlayers(role_1.Role.getRoles()))
|
|
32
|
+
};
|
|
33
|
+
const expected = {
|
|
34
|
+
single: [__stubs__1.players[2], __stubs__1.players[0], __stubs__1.players[1]],
|
|
35
|
+
multiple: [__stubs__1.players[1], __stubs__1.players[2], __stubs__1.players[0]],
|
|
36
|
+
all: [__stubs__1.players[2], __stubs__1.players[1], __stubs__1.players[0]]
|
|
37
|
+
};
|
|
38
|
+
(0, globals_1.expect)(sortedArrays.single).toStrictEqual(expected.single);
|
|
39
|
+
(0, globals_1.expect)(sortedArrays.multiple).toStrictEqual(expected.multiple);
|
|
40
|
+
(0, globals_1.expect)(sortedArrays.all).toStrictEqual(expected.all);
|
|
41
|
+
});
|
|
42
|
+
// canPlayLibero Tests
|
|
43
|
+
(0, globals_1.test)('Should return false when player does not have the Libero role', () => {
|
|
44
|
+
(0, globals_1.expect)(__stubs__1.player.canPlayLibero()).toBe(false);
|
|
45
|
+
});
|
|
46
|
+
(0, globals_1.test)('Should return true when player has the Libero role', () => {
|
|
47
|
+
(0, globals_1.expect)(__stubs__1.libero.canPlayLibero()).toBe(true);
|
|
48
|
+
});
|
|
49
|
+
});
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.Role = void 0;
|
|
7
|
+
const role_formula_json_1 = __importDefault(require("../../../data/role.formula.json"));
|
|
8
|
+
var Role;
|
|
9
|
+
(function (Role) {
|
|
10
|
+
Role["SETTER"] = "Setter";
|
|
11
|
+
Role["LIBERO"] = "Libero";
|
|
12
|
+
Role["OUTSIDE_HITTER"] = "Outside Hitter";
|
|
13
|
+
Role["OPPOSITE_HITTER"] = "Opposite Hitter";
|
|
14
|
+
Role["MIDDLE_BLOCKER"] = "Middle Blocker";
|
|
15
|
+
Role["DEFENSIVE_SPECIALIST"] = "Defensive Specialist";
|
|
16
|
+
})(Role = exports.Role || (exports.Role = {}));
|
|
17
|
+
// eslint-disable-next-line @typescript-eslint/no-namespace
|
|
18
|
+
(function (Role) {
|
|
19
|
+
const ROLES = [Role.LIBERO, Role.SETTER, Role.OPPOSITE_HITTER, Role.OUTSIDE_HITTER, Role.MIDDLE_BLOCKER,
|
|
20
|
+
Role.DEFENSIVE_SPECIALIST];
|
|
21
|
+
function getRoles() {
|
|
22
|
+
return [...ROLES];
|
|
23
|
+
}
|
|
24
|
+
Role.getRoles = getRoles;
|
|
25
|
+
function calculateScore(stats, role) {
|
|
26
|
+
const weights = role_formula_json_1.default.find(r => r.role === role);
|
|
27
|
+
if (weights == null)
|
|
28
|
+
throw new Error('COULD_NOT_FIND_ROLE_WEIGHT');
|
|
29
|
+
const score = Object.entries(weights.weight)
|
|
30
|
+
.reduce((score, [key, value]) => score + (stats[key] * weights.weight[key]), 0);
|
|
31
|
+
return Math.round(score);
|
|
32
|
+
}
|
|
33
|
+
Role.calculateScore = calculateScore;
|
|
34
|
+
})(Role = exports.Role || (exports.Role = {}));
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const globals_1 = require("@jest/globals");
|
|
4
|
+
const role_1 = require("./role");
|
|
5
|
+
const __stubs__1 = require("./__stubs__");
|
|
6
|
+
(0, globals_1.describe)('Role Test Module', () => {
|
|
7
|
+
// getRoles Test
|
|
8
|
+
(0, globals_1.test)('Should return an array with all the Roles', () => {
|
|
9
|
+
(0, globals_1.expect)(role_1.Role.getRoles().sort()).toEqual(__stubs__1.roles.sort());
|
|
10
|
+
});
|
|
11
|
+
// calculateScore Tests
|
|
12
|
+
(0, globals_1.test)('Should calculate Score for SETTER Role', () => {
|
|
13
|
+
(0, globals_1.expect)(role_1.Role.calculateScore(__stubs__1.performanceStats, role_1.Role.SETTER)).toBe(39);
|
|
14
|
+
});
|
|
15
|
+
(0, globals_1.test)('Should calculate Score for OPPOSITE_HITTER Role', () => {
|
|
16
|
+
(0, globals_1.expect)(role_1.Role.calculateScore(__stubs__1.performanceStats, role_1.Role.OPPOSITE_HITTER)).toBe(50);
|
|
17
|
+
});
|
|
18
|
+
(0, globals_1.test)('Should calculate Score for OUTSIDE_HITTER Role', () => {
|
|
19
|
+
(0, globals_1.expect)(role_1.Role.calculateScore(__stubs__1.performanceStats, role_1.Role.OUTSIDE_HITTER)).toBe(51);
|
|
20
|
+
});
|
|
21
|
+
(0, globals_1.test)('Should calculate Score for MIDDLE_BLOCKER Role', () => {
|
|
22
|
+
(0, globals_1.expect)(role_1.Role.calculateScore(__stubs__1.performanceStats, role_1.Role.MIDDLE_BLOCKER)).toBe(53);
|
|
23
|
+
});
|
|
24
|
+
(0, globals_1.test)('Should calculate Score for LIBERO Role', () => {
|
|
25
|
+
(0, globals_1.expect)(role_1.Role.calculateScore(__stubs__1.performanceStats, role_1.Role.LIBERO)).toBe(52);
|
|
26
|
+
});
|
|
27
|
+
(0, globals_1.test)('Should calculate Score for DEFENSIVE_SPECIALIST Role', () => {
|
|
28
|
+
(0, globals_1.expect)(role_1.Role.calculateScore(__stubs__1.performanceStats, role_1.Role.DEFENSIVE_SPECIALIST)).toBe(53);
|
|
29
|
+
});
|
|
30
|
+
});
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
exports.GeneralStat = void 0;
|
|
7
|
+
const stat_formula_json_1 = __importDefault(require("../../../data/stat.formula.json"));
|
|
8
|
+
var GeneralStat;
|
|
9
|
+
(function (GeneralStat) {
|
|
10
|
+
GeneralStat["ATTACK"] = "Attack";
|
|
11
|
+
GeneralStat["DEFENSE"] = "Defense";
|
|
12
|
+
GeneralStat["SERVE"] = "Serve";
|
|
13
|
+
GeneralStat["PHYSICAL"] = "Physical";
|
|
14
|
+
})(GeneralStat = exports.GeneralStat || (exports.GeneralStat = {}));
|
|
15
|
+
// eslint-disable-next-line @typescript-eslint/no-namespace
|
|
16
|
+
(function (GeneralStat) {
|
|
17
|
+
const STATS = [GeneralStat.ATTACK, GeneralStat.DEFENSE, GeneralStat.SERVE, GeneralStat.PHYSICAL];
|
|
18
|
+
function getStats() {
|
|
19
|
+
return [...STATS];
|
|
20
|
+
}
|
|
21
|
+
GeneralStat.getStats = getStats;
|
|
22
|
+
function calculateScore(performanceStats, statName) {
|
|
23
|
+
const weights = stat_formula_json_1.default.find(s => s.statName === statName);
|
|
24
|
+
if (weights == null)
|
|
25
|
+
throw new Error('COULD_NOT_FIND_ROLE_WEIGHT');
|
|
26
|
+
const score = Object.entries(weights.weight)
|
|
27
|
+
.reduce((score, [key, value]) => score + (performanceStats[key] * value), 0);
|
|
28
|
+
return Math.round(score);
|
|
29
|
+
}
|
|
30
|
+
GeneralStat.calculateScore = calculateScore;
|
|
31
|
+
})(GeneralStat = exports.GeneralStat || (exports.GeneralStat = {}));
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const globals_1 = require("@jest/globals");
|
|
4
|
+
const stats_1 = require("./stats");
|
|
5
|
+
const __stubs__1 = require("./__stubs__");
|
|
6
|
+
(0, globals_1.describe)('Stat Test Module', () => {
|
|
7
|
+
// getStats Test
|
|
8
|
+
(0, globals_1.test)('Should return an array with all the Stats', () => {
|
|
9
|
+
(0, globals_1.expect)(stats_1.GeneralStat.getStats().sort()).toEqual(__stubs__1.stats.sort());
|
|
10
|
+
});
|
|
11
|
+
// calculateScore Tests
|
|
12
|
+
(0, globals_1.test)('Should calculate Score for ATTACK Stat', () => {
|
|
13
|
+
(0, globals_1.expect)(stats_1.GeneralStat.calculateScore(__stubs__1.performanceStats, stats_1.GeneralStat.ATTACK)).toBe(49);
|
|
14
|
+
});
|
|
15
|
+
(0, globals_1.test)('Should calculate Score for DEFENSE Stat', () => {
|
|
16
|
+
(0, globals_1.expect)(stats_1.GeneralStat.calculateScore(__stubs__1.performanceStats, stats_1.GeneralStat.DEFENSE)).toBe(60);
|
|
17
|
+
});
|
|
18
|
+
(0, globals_1.test)('Should calculate Score for SERVE Stat', () => {
|
|
19
|
+
(0, globals_1.expect)(stats_1.GeneralStat.calculateScore(__stubs__1.performanceStats, stats_1.GeneralStat.SERVE)).toBe(20);
|
|
20
|
+
});
|
|
21
|
+
(0, globals_1.test)('Should calculate Score for PHYSICAL Stat', () => {
|
|
22
|
+
(0, globals_1.expect)(stats_1.GeneralStat.calculateScore(__stubs__1.performanceStats, stats_1.GeneralStat.PHYSICAL)).toBe(58);
|
|
23
|
+
});
|
|
24
|
+
});
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.Trait = void 0;
|
|
4
|
+
const role_1 = require("./role");
|
|
5
|
+
const stats_1 = require("./stats");
|
|
6
|
+
class Trait {
|
|
7
|
+
constructor({ name, roles, modifier, chance, statThreshold, stat, weight }) {
|
|
8
|
+
this.name = name;
|
|
9
|
+
this.roles = roles;
|
|
10
|
+
this.modifier = modifier;
|
|
11
|
+
this.chance = chance;
|
|
12
|
+
this.statThreshold = statThreshold;
|
|
13
|
+
this.stat = stat;
|
|
14
|
+
this.weight = weight;
|
|
15
|
+
}
|
|
16
|
+
static getTraits() {
|
|
17
|
+
return [Trait.GUARDIAN, Trait.MARKSMAN, Trait.METEOR_SERVE, Trait.VIGOROUS, Trait.MOVING_WALL, Trait.MASTER_MIND];
|
|
18
|
+
}
|
|
19
|
+
static assignTraitsToPlayer(roles, performanceStats) {
|
|
20
|
+
const qualifiedTraits = this.getTraits().filter(trait => {
|
|
21
|
+
return (trait.roles.length < 1 || trait.roles.some(role => roles.includes(role))) &&
|
|
22
|
+
stats_1.GeneralStat.calculateScore(performanceStats, trait.stat) >= trait.statThreshold;
|
|
23
|
+
});
|
|
24
|
+
const random = Math.random();
|
|
25
|
+
let traitCount;
|
|
26
|
+
switch (true) {
|
|
27
|
+
case random > 0.9:
|
|
28
|
+
traitCount = 3;
|
|
29
|
+
break;
|
|
30
|
+
case random > 0.75:
|
|
31
|
+
traitCount = 2;
|
|
32
|
+
break;
|
|
33
|
+
case random > 0.4:
|
|
34
|
+
traitCount = 1;
|
|
35
|
+
break;
|
|
36
|
+
default:
|
|
37
|
+
traitCount = 0;
|
|
38
|
+
}
|
|
39
|
+
return qualifiedTraits.sort((t1, t2) => t2.weight - t1.weight)
|
|
40
|
+
.slice(0, traitCount);
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
exports.Trait = Trait;
|
|
44
|
+
Trait.MASTER_MIND = new Trait({
|
|
45
|
+
name: 'Master Mind',
|
|
46
|
+
roles: [role_1.Role.SETTER],
|
|
47
|
+
modifier: 1.25,
|
|
48
|
+
chance: 0.15,
|
|
49
|
+
statThreshold: 80,
|
|
50
|
+
stat: stats_1.GeneralStat.ATTACK,
|
|
51
|
+
weight: 10
|
|
52
|
+
});
|
|
53
|
+
Trait.MOVING_WALL = new Trait({
|
|
54
|
+
name: 'Moving Wall',
|
|
55
|
+
roles: [role_1.Role.MIDDLE_BLOCKER, role_1.Role.DEFENSIVE_SPECIALIST],
|
|
56
|
+
modifier: 1,
|
|
57
|
+
chance: 1,
|
|
58
|
+
statThreshold: 75,
|
|
59
|
+
stat: stats_1.GeneralStat.DEFENSE,
|
|
60
|
+
weight: 5
|
|
61
|
+
});
|
|
62
|
+
Trait.MARKSMAN = new Trait({
|
|
63
|
+
name: 'Marksman',
|
|
64
|
+
roles: [role_1.Role.OUTSIDE_HITTER, role_1.Role.OPPOSITE_HITTER, role_1.Role.SETTER],
|
|
65
|
+
modifier: 1,
|
|
66
|
+
chance: 0.33,
|
|
67
|
+
statThreshold: 75,
|
|
68
|
+
stat: stats_1.GeneralStat.ATTACK,
|
|
69
|
+
weight: 5
|
|
70
|
+
});
|
|
71
|
+
Trait.METEOR_SERVE = new Trait({
|
|
72
|
+
name: 'Meteor Serve',
|
|
73
|
+
roles: [role_1.Role.OUTSIDE_HITTER, role_1.Role.OPPOSITE_HITTER, role_1.Role.SETTER, role_1.Role.DEFENSIVE_SPECIALIST, role_1.Role.MIDDLE_BLOCKER],
|
|
74
|
+
modifier: 1.33,
|
|
75
|
+
chance: 0.25,
|
|
76
|
+
statThreshold: 75,
|
|
77
|
+
stat: stats_1.GeneralStat.SERVE,
|
|
78
|
+
weight: 10
|
|
79
|
+
});
|
|
80
|
+
Trait.VIGOROUS = new Trait({
|
|
81
|
+
name: 'Vigorous',
|
|
82
|
+
roles: [],
|
|
83
|
+
modifier: 1,
|
|
84
|
+
statThreshold: 60,
|
|
85
|
+
chance: 0.5,
|
|
86
|
+
stat: stats_1.GeneralStat.PHYSICAL,
|
|
87
|
+
weight: 1
|
|
88
|
+
});
|
|
89
|
+
Trait.GUARDIAN = new Trait({
|
|
90
|
+
name: 'Guardian',
|
|
91
|
+
roles: [role_1.Role.DEFENSIVE_SPECIALIST, role_1.Role.LIBERO],
|
|
92
|
+
chance: 0.33,
|
|
93
|
+
statThreshold: 75,
|
|
94
|
+
modifier: 1.2,
|
|
95
|
+
stat: stats_1.GeneralStat.DEFENSE,
|
|
96
|
+
weight: 10
|
|
97
|
+
});
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const globals_1 = require("@jest/globals");
|
|
4
|
+
const trait_1 = require("./trait");
|
|
5
|
+
// TODO
|
|
6
|
+
(0, globals_1.describe)('Trait Test Module', () => {
|
|
7
|
+
// getTraits Test
|
|
8
|
+
(0, globals_1.test)('Should return an array with all the Traits', () => {
|
|
9
|
+
(0, globals_1.expect)(trait_1.Trait.VIGOROUS.name).toEqual('Vigorous');
|
|
10
|
+
});
|
|
11
|
+
});
|