-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathapp.ts
More file actions
37 lines (30 loc) · 933 Bytes
/
app.ts
File metadata and controls
37 lines (30 loc) · 933 Bytes
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
import { UsersService } from "./services/users.service";
import { User } from "./interfaces/user";
import { UsersComponent } from "./components/users.component";
import { AddUserComponent } from "./components/add-user.component";
const usersService: UsersService = new UsersService();
const usersComponent = new UsersComponent();
const addUserComponent: AddUserComponent = new AddUserComponent();
// store users
let users: User[] = [];
const usersTarget: HTMLTableElement = document.querySelector("table tbody");
function renderUsers() {
usersComponent.render(users, usersTarget);
}
function renderForm() {
addUserComponent.render(
document.getElementById("addUsers") as HTMLDivElement,
addUserToList
);
}
function addUserToList(user: User) {
users.push(user);
renderUsers();
}
async function init() {
users = await usersService.getUsers();
console.log(users);
renderUsers();
renderForm();
}
init();