Squashed commit of the following:
commit6596d30bd6Author: eneller <erikneller@gmx.de> Date: Mon Jan 6 18:32:41 2025 +0100 center nTeamsSelector commit497b64fe3fAuthor: eneller <erikneller@gmx.de> Date: Mon Jan 6 15:25:24 2025 +0100 remove angular material completely commit4d58880493Author: eneller <erikneller@gmx.de> Date: Mon Jan 6 15:23:05 2025 +0100 replace angular material components with bootstrap commitdcf25ea969Author: eneller <erikneller@gmx.de> Date: Mon Jan 6 13:13:05 2025 +0100 add ng-bootstrap commit48bbdab308Author: eneller <erikneller@gmx.de> Date: Thu Nov 28 11:07:07 2024 +0100 implement nTeams commitf7f8482bc9Author: eneller <erikneller@gmx.de> Date: Thu Nov 28 09:12:38 2024 +0100 update icons commite0a319b32aAuthor: eneller <erikneller@gmx.de> Date: Thu Nov 28 08:48:14 2024 +0100 make pwa for offline usage commit4be3649d43Author: eneller <erikneller@gmx.de> Date: Thu Nov 28 00:53:27 2024 +0100 add padding to nTeamsToggle commit2a596b15c8Author: eneller <erikneller@gmx.de> Date: Thu Nov 28 00:32:41 2024 +0100 fully functional using angular commitd2090f30d4Author: eneller <erikneller@gmx.de> Date: Wed Nov 27 23:40:34 2024 +0100 basic ui alignment, add nTeams commit97f01f924aAuthor: eneller <erikneller@gmx.de> Date: Wed Nov 27 22:37:29 2024 +0100 add basic ui elements commit102f589869Author: eneller <erikneller@gmx.de> Date: Wed Nov 27 22:01:32 2024 +0100 add angular material commit7f5978b226Author: eneller <erikneller@gmx.de> Date: Wed Nov 27 20:15:11 2024 +0100 Initial Angular Commit
This commit is contained in:
59
src/app/app.component.ts
Normal file
59
src/app/app.component.ts
Normal file
@@ -0,0 +1,59 @@
|
||||
import { Component } from '@angular/core';
|
||||
import { FormsModule } from '@angular/forms';
|
||||
import { RouterOutlet } from '@angular/router';
|
||||
import { NgbModule } from '@ng-bootstrap/ng-bootstrap';
|
||||
|
||||
import { CommonModule } from '@angular/common';
|
||||
|
||||
@Component({
|
||||
selector: 'app-root',
|
||||
imports: [NgbModule, RouterOutlet, CommonModule, FormsModule],
|
||||
templateUrl: './app.component.html',
|
||||
styleUrl: './app.component.less'
|
||||
})
|
||||
export class AppComponent {
|
||||
title = 'vb';
|
||||
numTeamsSelectorValue = "2";
|
||||
numTeamsSelected = 2;
|
||||
nTeamsValue = "4";
|
||||
teamsArray: string[][] = [];
|
||||
displayedColumns = ["teamCount", "teamNames"];
|
||||
|
||||
onButtonGenerate(textinput: string): void{
|
||||
if(this.numTeamsSelectorValue === 'n'){
|
||||
this.numTeamsSelected = Number(this.nTeamsValue);
|
||||
}
|
||||
else{
|
||||
this.numTeamsSelected = Number(this.numTeamsSelectorValue);
|
||||
}
|
||||
let names = textinput
|
||||
.split('\n')
|
||||
.map(function(str){return str.trim();})
|
||||
.filter(function(str){return str}); // boolean interpretation is same as non-empty
|
||||
// remove duplicates by using a Set
|
||||
names = [...new Set(names)];
|
||||
|
||||
var teams = Array.from({ length: this.numTeamsSelected }, () => []);
|
||||
var playersPerTeam = Math.floor(names.length / this.numTeamsSelected);
|
||||
|
||||
let nameslen = names.length;
|
||||
function* iter(list: any){
|
||||
let index = 0;
|
||||
while(true){
|
||||
yield list[index % list.length];
|
||||
index++;
|
||||
}
|
||||
}
|
||||
var iterator = iter(teams);
|
||||
for(let i =0; i < nameslen; i++){
|
||||
var index = Math.floor(Math.random()* names.length);
|
||||
var n = names[index];
|
||||
names.splice(index,1);
|
||||
var team = iterator.next().value;
|
||||
team.push(n);
|
||||
|
||||
}
|
||||
this.teamsArray = teams;
|
||||
}
|
||||
|
||||
}
|
||||
Reference in New Issue
Block a user