From a31676b2b1a4e01410894d02c32b4adf4a7eee31 Mon Sep 17 00:00:00 2001 From: ruben Date: Mon, 30 Jan 2023 16:25:06 +0100 Subject: [PATCH] sus --- docker-compose.yml | 11 + web/.eslintignore | 13 + web/.eslintrc.cjs | 20 + web/.gitignore | 10 + web/.npmrc | 1 + web/.prettierignore | 13 + web/.prettierrc | 20 + web/Dockerfile | 24 + web/README.md | 38 + web/package.json | 35 + web/src/app.d.ts | 12 + web/src/app.html | 12 + web/src/lib/operators.ts | 134 +++ web/src/routes/+page.svelte | 2 + web/static/favicon.png | Bin 0 -> 1571 bytes web/svelte.config.js | 15 + web/tsconfig.json | 17 + web/vite.config.ts | 8 + web/yarn.lock | 1626 +++++++++++++++++++++++++++++++++++ 19 files changed, 2011 insertions(+) create mode 100644 docker-compose.yml create mode 100644 web/.eslintignore create mode 100644 web/.eslintrc.cjs create mode 100644 web/.gitignore create mode 100644 web/.npmrc create mode 100644 web/.prettierignore create mode 100644 web/.prettierrc create mode 100644 web/Dockerfile create mode 100644 web/README.md create mode 100644 web/package.json create mode 100644 web/src/app.d.ts create mode 100644 web/src/app.html create mode 100644 web/src/lib/operators.ts create mode 100644 web/src/routes/+page.svelte create mode 100644 web/static/favicon.png create mode 100644 web/svelte.config.js create mode 100644 web/tsconfig.json create mode 100644 web/vite.config.ts create mode 100644 web/yarn.lock diff --git a/docker-compose.yml b/docker-compose.yml new file mode 100644 index 0000000..cc4beb6 --- /dev/null +++ b/docker-compose.yml @@ -0,0 +1,11 @@ +version: '4' + +services: + web: + build: + context: ./web + environment: + ORIGIN: http://localhost:3300 + ports: + - '3300:3000' + restart: always diff --git a/web/.eslintignore b/web/.eslintignore new file mode 100644 index 0000000..3897265 --- /dev/null +++ b/web/.eslintignore @@ -0,0 +1,13 @@ +.DS_Store +node_modules +/build +/.svelte-kit +/package +.env +.env.* +!.env.example + +# Ignore files for PNPM, NPM and YARN +pnpm-lock.yaml +package-lock.json +yarn.lock diff --git a/web/.eslintrc.cjs b/web/.eslintrc.cjs new file mode 100644 index 0000000..3ccf435 --- /dev/null +++ b/web/.eslintrc.cjs @@ -0,0 +1,20 @@ +module.exports = { + root: true, + parser: '@typescript-eslint/parser', + extends: ['eslint:recommended', 'plugin:@typescript-eslint/recommended', 'prettier'], + plugins: ['svelte3', '@typescript-eslint'], + ignorePatterns: ['*.cjs'], + overrides: [{ files: ['*.svelte'], processor: 'svelte3/svelte3' }], + settings: { + 'svelte3/typescript': () => require('typescript') + }, + parserOptions: { + sourceType: 'module', + ecmaVersion: 2020 + }, + env: { + browser: true, + es2017: true, + node: true + } +}; diff --git a/web/.gitignore b/web/.gitignore new file mode 100644 index 0000000..6635cf5 --- /dev/null +++ b/web/.gitignore @@ -0,0 +1,10 @@ +.DS_Store +node_modules +/build +/.svelte-kit +/package +.env +.env.* +!.env.example +vite.config.js.timestamp-* +vite.config.ts.timestamp-* diff --git a/web/.npmrc b/web/.npmrc new file mode 100644 index 0000000..b6f27f1 --- /dev/null +++ b/web/.npmrc @@ -0,0 +1 @@ +engine-strict=true diff --git a/web/.prettierignore b/web/.prettierignore new file mode 100644 index 0000000..3897265 --- /dev/null +++ b/web/.prettierignore @@ -0,0 +1,13 @@ +.DS_Store +node_modules +/build +/.svelte-kit +/package +.env +.env.* +!.env.example + +# Ignore files for PNPM, NPM and YARN +pnpm-lock.yaml +package-lock.json +yarn.lock diff --git a/web/.prettierrc b/web/.prettierrc new file mode 100644 index 0000000..266e662 --- /dev/null +++ b/web/.prettierrc @@ -0,0 +1,20 @@ +{ + "useTabs": true, + "singleQuote": true, + "trailingComma": "none", + "printWidth": 150, + "plugins": [ + "prettier-plugin-svelte" + ], + "pluginSearchDirs": [ + "." + ], + "overrides": [ + { + "files": "*.svelte", + "options": { + "parser": "svelte" + } + } + ] +} \ No newline at end of file diff --git a/web/Dockerfile b/web/Dockerfile new file mode 100644 index 0000000..53ed434 --- /dev/null +++ b/web/Dockerfile @@ -0,0 +1,24 @@ +FROM node:18-alpine AS build + +# install dependencies +WORKDIR /app +COPY package.json yarn.lock ./ +RUN yarn install + +# Copy all local files into the image. +COPY . . + +RUN yarn build + +### +# Only copy over the Node pieces we need +# ~> Saves 35MB +### +FROM node:18-alpine AS deploy + +WORKDIR /app +COPY --from=0 /app . +COPY . . + +EXPOSE 3000 +CMD ["node", "./build"] \ No newline at end of file diff --git a/web/README.md b/web/README.md new file mode 100644 index 0000000..5c91169 --- /dev/null +++ b/web/README.md @@ -0,0 +1,38 @@ +# create-svelte + +Everything you need to build a Svelte project, powered by [`create-svelte`](https://github.com/sveltejs/kit/tree/master/packages/create-svelte). + +## Creating a project + +If you're seeing this, you've probably already done this step. Congrats! + +```bash +# create a new project in the current directory +npm create svelte@latest + +# create a new project in my-app +npm create svelte@latest my-app +``` + +## Developing + +Once you've created a project and installed dependencies with `npm install` (or `pnpm install` or `yarn`), start a development server: + +```bash +npm run dev + +# or start the server and open the app in a new browser tab +npm run dev -- --open +``` + +## Building + +To create a production version of your app: + +```bash +npm run build +``` + +You can preview the production build with `npm run preview`. + +> To deploy your app, you may need to install an [adapter](https://kit.svelte.dev/docs/adapters) for your target environment. diff --git a/web/package.json b/web/package.json new file mode 100644 index 0000000..a8d1d79 --- /dev/null +++ b/web/package.json @@ -0,0 +1,35 @@ +{ + "name": "web", + "version": "0.0.1", + "private": true, + "scripts": { + "dev": "vite dev", + "build": "vite build", + "preview": "vite preview", + "check": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json", + "check:watch": "svelte-kit sync && svelte-check --tsconfig ./tsconfig.json --watch", + "lint": "prettier --plugin-search-dir . --check . && eslint .", + "format": "prettier --plugin-search-dir . --write ." + }, + "devDependencies": { + "@sveltejs/adapter-auto": "^1.0.0", + "@sveltejs/adapter-node": "^1.1.4", + "@sveltejs/kit": "^1.0.0", + "@typescript-eslint/eslint-plugin": "^5.45.0", + "@typescript-eslint/parser": "^5.45.0", + "eslint": "^8.28.0", + "eslint-config-prettier": "^8.5.0", + "eslint-plugin-svelte3": "^4.0.0", + "prettier": "^2.8.0", + "prettier-plugin-svelte": "^2.8.1", + "svelte": "^3.54.0", + "svelte-check": "^3.0.1", + "tslib": "^2.4.1", + "typescript": "^4.9.3", + "vite": "^4.0.0" + }, + "type": "module", + "dependencies": { + "dotenv": "^16.0.3" + } +} diff --git a/web/src/app.d.ts b/web/src/app.d.ts new file mode 100644 index 0000000..f59b884 --- /dev/null +++ b/web/src/app.d.ts @@ -0,0 +1,12 @@ +// See https://kit.svelte.dev/docs/types#app +// for information about these interfaces +declare global { + namespace App { + // interface Error {} + // interface Locals {} + // interface PageData {} + // interface Platform {} + } +} + +export {}; diff --git a/web/src/app.html b/web/src/app.html new file mode 100644 index 0000000..effe0d0 --- /dev/null +++ b/web/src/app.html @@ -0,0 +1,12 @@ + + + + + + + %sveltekit.head% + + +
%sveltekit.body%
+ + diff --git a/web/src/lib/operators.ts b/web/src/lib/operators.ts new file mode 100644 index 0000000..0ccbe09 --- /dev/null +++ b/web/src/lib/operators.ts @@ -0,0 +1,134 @@ +class Operator { + name: string; + gender: Gender; + side: Side; + roles: Array; + speed: number; + squad: Squad; + + constructor(name: string, gender: Gender, side: Side, roles: Array, speed: number, squad: Squad) { + this.name = name; + this.gender = gender; + this.side = side; + this.roles = roles; + this.speed = speed; + this.squad = squad; + } +} + +enum Gender { + male, + female, + divers +} + +enum Side { + attacker, + defender +} + +enum Squad { + Rainbow, + Nighthaven, + Wolfguard, + Ghosteyes +} + +enum Role { + Intel_Gatherer, + Area_Denial, + Covering_Fire, + Crowd_Control, + Anchor, + Secure, + Anti_Roam, + Roam, + Buff, + Soft_Breach, + Disable, + Back_Line, + Intel_Denier, + Front_Line, + Hard_Breach, + Flank, + Trap, + Anti_Hard_Breach, + Shield +} + +const operators: Array = [ + new Operator('Solid', Gender.female, Side.defender, [Role.Intel_Gatherer], 2, Squad.Ghosteyes), + new Operator('Grim', Gender.male, Side.attacker, [Role.Intel_Gatherer, Role.Area_Denial], 3, Squad.Nighthaven), + new Operator('Sens', Gender.divers, Side.attacker, [Role.Covering_Fire, Role.Area_Denial, Role.Crowd_Control], 3, Squad.Wolfguard), + new Operator('Azami', Gender.female, Side.defender, [Role.Area_Denial], 2, Squad.Rainbow), + new Operator('Thorn', Gender.female, Side.defender, [Role.Anchor, Role.Secure], 2, Squad.Rainbow), + new Operator('Osa', Gender.divers, Side.attacker, [Role.Intel_Gatherer, Role.Area_Denial, Role.Anti_Roam], 1, Squad.Nighthaven), + new Operator('Thunderbird', Gender.female, Side.defender, [Role.Secure, Role.Roam, Role.Buff], 2, Squad.Wolfguard), + new Operator('Flores', Gender.male, Side.attacker, [Role.Disable, Role.Soft_Breach, Role.Area_Denial, Role.Back_Line], 2, Squad.Ghosteyes), + new Operator('Aruni', Gender.female, Side.defender, [Role.Intel_Gatherer, Role.Secure, Role.Anchor], 1, Squad.Nighthaven), + new Operator('Zero', Gender.male, Side.attacker, [Role.Intel_Denier, Role.Intel_Gatherer], 3, Squad.Ghosteyes), + new Operator('Ace', Gender.male, Side.attacker, [Role.Front_Line, Role.Hard_Breach], 2, Squad.Nighthaven), + new Operator('Melusi', Gender.female, Side.defender, [Role.Intel_Gatherer, Role.Secure, Role.Crowd_Control], 1, Squad.Wolfguard), + new Operator('Oryx', Gender.male, Side.defender, [Role.Roam, Role.Soft_Breach], 2, Squad.Rainbow), + new Operator('Iana', Gender.female, Side.attacker, [Role.Intel_Denier, Role.Intel_Gatherer], 2, Squad.Ghosteyes), + new Operator('Wamai', Gender.male, Side.defender, [Role.Anchor, Role.Secure], 2, Squad.Nighthaven), + new Operator('Kali', Gender.female, Side.attacker, [Role.Back_Line, Role.Covering_Fire, Role.Disable], 2, Squad.Nighthaven), + new Operator('Amaru', Gender.female, Side.attacker, [Role.Front_Line, Role.Flank], 2, Squad.Rainbow), + new Operator('Goyo', Gender.male, Side.defender, [Role.Area_Denial, Role.Secure], 2, Squad.Rainbow), + new Operator('Nøkk', Gender.female, Side.attacker, [Role.Intel_Denier, Role.Flank], 2, Squad.Ghosteyes), + new Operator('Warden', Gender.male, Side.defender, [Role.Anchor, Role.Intel_Denier], 2, Squad.Ghosteyes), + new Operator('Mozzie', Gender.male, Side.defender, [Role.Intel_Gatherer, Role.Intel_Denier, Role.Secure], 2, Squad.Ghosteyes), + new Operator('Gridlock', Gender.female, Side.attacker, [Role.Anti_Roam, Role.Area_Denial, Role.Crowd_Control], 1, Squad.Rainbow), + new Operator('Nomad', Gender.female, Side.attacker, [Role.Anti_Roam, Role.Trap, Role.Crowd_Control], 2, Squad.Wolfguard), + new Operator('Kaid', Gender.male, Side.defender, [Role.Anti_Hard_Breach, Role.Secure, Role.Anchor], 1, Squad.Rainbow), + new Operator('Clash', Gender.female, Side.defender, [Role.Crowd_Control, Role.Intel_Gatherer, Role.Secure, Role.Shield], 1, Squad.Wolfguard), + new Operator('Maverick', Gender.male, Side.attacker, [Role.Hard_Breach, Role.Back_Line, Role.Disable, Role.Flank], 3, Squad.Ghosteyes), + new Operator('Maestro', Gender.male, Side.defender, [Role.Secure, Role.Anchor, Role.Area_Denial, Role.Intel_Gatherer], 1, Squad.Rainbow), + new Operator('Alibi', Gender.female, Side.defender, [Role.Intel_Denier, Role.Intel_Gatherer, Role.Roam, Role.Trap], 3, Squad.Rainbow), + new Operator('Lion', Gender.male, Side.attacker, [Role.Intel_Gatherer, Role.Back_Line, Role.Anti_Roam, Role.Crowd_Control], 2, Squad.Wolfguard), + new Operator('Finka', Gender.female, Side.attacker, [Role.Back_Line, Role.Buff], 2, Squad.Nighthaven), + new Operator('Vigil', Gender.male, Side.defender, [Role.Intel_Denier, Role.Roam], 3, Squad.Ghosteyes), + new Operator('Dokkaebi', Gender.female, Side.attacker, [Role.Intel_Gatherer, Role.Intel_Denier, Role.Anti_Roam, Role.Flank], 3, Squad.Rainbow), + new Operator( + 'Zofia', + Gender.female, + Side.attacker, + [Role.Anti_Roam, Role.Crowd_Control, Role.Disable, Role.Flank, Role.Soft_Breach], + 1, + Squad.Ghosteyes + ), + new Operator('Ela', Gender.female, Side.defender, [Role.Crowd_Control, Role.Trap, Role.Roam], 2, Squad.Nighthaven), + new Operator('Ying', Gender.female, Side.attacker, [Role.Crowd_Control, Role.Front_Line], 2, Squad.Wolfguard), + new Operator( + 'Lesion', + Gender.male, + Side.defender, + [Role.Crowd_Control, Role.Trap, Role.Roam, Role.Anchor, Role.Intel_Gatherer], + 2, + Squad.Ghosteyes + ), + new Operator('Mira', Gender.female, Side.defender, [Role.Secure, Role.Anchor, Role.Intel_Gatherer], 1, Squad.Rainbow), + new Operator('Jackal', Gender.male, Side.attacker, [Role.Anti_Roam, Role.Intel_Gatherer], 2, Squad.Rainbow), + new Operator('Hibana', Gender.female, Side.attacker, [Role.Hard_Breach, Role.Back_Line, Role.Front_Line], 3, Squad.Rainbow), + new Operator('Echo', Gender.male, Side.defender, [Role.Anchor, Role.Crowd_Control, Role.Intel_Gatherer, Role.Secure], 2, Squad.Rainbow), + new Operator('Caveira', Gender.female, Side.defender, [Role.Intel_Denier, Role.Intel_Gatherer, Role.Roam], 3, Squad.Ghosteyes), + new Operator('Capitão', Gender.male, Side.attacker, [Role.Area_Denial, Role.Flank, Role.Front_Line], 3, Squad.Rainbow), + new Operator('Blackbeard', Gender.male, Side.attacker, [Role.Back_Line, Role.Covering_Fire, Role.Shield], 2, Squad.Rainbow), + new Operator('Valkyrie', Gender.female, Side.defender, [Role.Intel_Gatherer, Role.Roam], 2, Squad.Ghosteyes), + new Operator('Buck', Gender.male, Side.attacker, [Role.Flank, Role.Soft_Breach], 2, Squad.Rainbow), + new Operator('Frost', Gender.female, Side.defender, [Role.Crowd_Control, Role.Trap], 2, Squad.Wolfguard), + new Operator('Mute', Gender.male, Side.defender, [Role.Anti_Hard_Breach, Role.Secure, Role.Intel_Denier], 1, Squad.Rainbow), + new Operator('Sledge', Gender.male, Side.attacker, [Role.Flank, Role.Soft_Breach], 1, Squad.Rainbow), + new Operator('Smoke', Gender.male, Side.defender, [Role.Anchor, Role.Secure, Role.Area_Denial], 2, Squad.Nighthaven), + new Operator('Thatcher', Gender.male, Side.attacker, [Role.Back_Line, Role.Disable], 1, Squad.Rainbow), + new Operator('Ash', Gender.female, Side.attacker, [Role.Flank, Role.Front_Line, Role.Disable, Role.Soft_Breach], 3, Squad.Rainbow), + new Operator('Castle', Gender.male, Side.defender, [Role.Anchor, Role.Secure], 2, Squad.Wolfguard), + new Operator('Pulse', Gender.male, Side.defender, [Role.Intel_Gatherer, Role.Roam], 3, Squad.Nighthaven), + new Operator('Thermite', Gender.male, Side.attacker, [Role.Hard_Breach, Role.Back_Line], 2, Squad.Rainbow), + new Operator('Montagne', Gender.male, Side.attacker, [Role.Shield], 1, Squad.Wolfguard), + new Operator('Twitch', Gender.female, Side.attacker, [Role.Back_Line, Role.Disable, Role.Front_Line, Role.Intel_Gatherer], 2, Squad.Wolfguard), + new Operator('Doc', Gender.male, Side.defender, [Role.Anchor, Role.Buff], 1, Squad.Wolfguard), + new Operator('Rook', Gender.male, Side.defender, [Role.Anchor, Role.Buff], 1, Squad.Rainbow) +]; + +export { operators }; diff --git a/web/src/routes/+page.svelte b/web/src/routes/+page.svelte new file mode 100644 index 0000000..5982b0a --- /dev/null +++ b/web/src/routes/+page.svelte @@ -0,0 +1,2 @@ +

Welcome to SvelteKit

+

Visit kit.svelte.dev to read the documentation

diff --git a/web/static/favicon.png b/web/static/favicon.png new file mode 100644 index 0000000000000000000000000000000000000000..825b9e65af7c104cfb07089bb28659393b4f2097 GIT binary patch literal 1571 zcmV+;2Hg3HP)Px)-AP12RCwC$UE6KzI1p6{F2N z1VK2vi|pOpn{~#djwYcWXTI_im_u^TJgMZ4JMOsSj!0ma>B?-(Hr@X&W@|R-$}W@Z zgj#$x=!~7LGqHW?IO8+*oE1MyDp!G=L0#^lUx?;!fXv@l^6SvTnf^ac{5OurzC#ZMYc20lI%HhX816AYVs1T3heS1*WaWH z%;x>)-J}YB5#CLzU@GBR6sXYrD>Vw(Fmt#|JP;+}<#6b63Ike{Fuo!?M{yEffez;| zp!PfsuaC)>h>-AdbnwN13g*1LowNjT5?+lFVd#9$!8Z9HA|$*6dQ8EHLu}U|obW6f z2%uGv?vr=KNq7YYa2Roj;|zooo<)lf=&2yxM@e`kM$CmCR#x>gI>I|*Ubr({5Y^rb zghxQU22N}F51}^yfDSt786oMTc!W&V;d?76)9KXX1 z+6Okem(d}YXmmOiZq$!IPk5t8nnS{%?+vDFz3BevmFNgpIod~R{>@#@5x9zJKEHLHv!gHeK~n)Ld!M8DB|Kfe%~123&Hz1Z(86nU7*G5chmyDe ziV7$pB7pJ=96hpxHv9rCR29%bLOXlKU<_13_M8x)6;P8E1Kz6G<&P?$P^%c!M5`2` zfY2zg;VK5~^>TJGQzc+33-n~gKt{{of8GzUkWmU110IgI0DLxRIM>0US|TsM=L|@F z0Bun8U!cRB7-2apz=y-7*UxOxz@Z0)@QM)9wSGki1AZ38ceG7Q72z5`i;i=J`ILzL z@iUO?SBBG-0cQuo+an4TsLy-g-x;8P4UVwk|D8{W@U1Zi z!M)+jqy@nQ$p?5tsHp-6J304Q={v-B>66$P0IDx&YT(`IcZ~bZfmn11#rXd7<5s}y zBi9eim&zQc0Dk|2>$bs0PnLmDfMP5lcXRY&cvJ=zKxI^f0%-d$tD!`LBf9^jMSYUA zI8U?CWdY@}cRq6{5~y+)#h1!*-HcGW@+gZ4B};0OnC~`xQOyH19z*TA!!BJ%9s0V3F?CAJ{hTd#*tf+ur-W9MOURF-@B77_-OshsY}6 zOXRY=5%C^*26z?l)1=$bz30!so5tfABdSYzO+H=CpV~aaUefmjvfZ3Ttu9W&W3Iu6 zROlh0MFA5h;my}8lB0tAV-Rvc2Zs_CCSJnx@d`**$idgy-iMob4dJWWw|21b4NB=LfsYp0Aeh{Ov)yztQi;eL4y5 zMi>8^SzKqk8~k?UiQK^^-5d8c%bV?$F8%X~czyiaKCI2=UH