Simple Managment webapp [LLM]
This commit is contained in:
@@ -6,7 +6,9 @@ import { NzIconModule } from 'ng-zorro-antd/icon';
|
||||
import { NzEmptyModule } from 'ng-zorro-antd/empty';
|
||||
import { NzCardModule } from 'ng-zorro-antd/card';
|
||||
import { NzToolTipModule } from 'ng-zorro-antd/tooltip';
|
||||
import { NzTabsModule } from 'ng-zorro-antd/tabs';
|
||||
import { ApiService } from '../../../core/services/api.service';
|
||||
import { AuthService } from '../../../core/services/auth.service';
|
||||
import { SenderNameStatistics } from '../../../core/models';
|
||||
import { RelativeTimePipe } from '../../../shared/pipes/relative-time.pipe';
|
||||
|
||||
@@ -21,6 +23,7 @@ import { RelativeTimePipe } from '../../../shared/pipes/relative-time.pipe';
|
||||
NzEmptyModule,
|
||||
NzCardModule,
|
||||
NzToolTipModule,
|
||||
NzTabsModule,
|
||||
RelativeTimePipe,
|
||||
],
|
||||
templateUrl: './sender-list.component.html',
|
||||
@@ -28,24 +31,61 @@ import { RelativeTimePipe } from '../../../shared/pipes/relative-time.pipe';
|
||||
})
|
||||
export class SenderListComponent implements OnInit {
|
||||
private apiService = inject(ApiService);
|
||||
private authService = inject(AuthService);
|
||||
|
||||
senders = signal<SenderNameStatistics[]>([]);
|
||||
loading = signal(false);
|
||||
mySenders = signal<SenderNameStatistics[]>([]);
|
||||
allSenders = signal<SenderNameStatistics[]>([]);
|
||||
loadingMy = signal(false);
|
||||
loadingAll = signal(false);
|
||||
activeTab = signal(0);
|
||||
|
||||
ngOnInit(): void {
|
||||
this.loadSenders();
|
||||
this.loadMySenders();
|
||||
}
|
||||
|
||||
loadSenders(): void {
|
||||
this.loading.set(true);
|
||||
this.apiService.getSenderNames().subscribe({
|
||||
onTabChange(index: number): void {
|
||||
this.activeTab.set(index);
|
||||
if (index === 0 && this.mySenders().length === 0) {
|
||||
this.loadMySenders();
|
||||
} else if (index === 1 && this.allSenders().length === 0) {
|
||||
this.loadAllSenders();
|
||||
}
|
||||
}
|
||||
|
||||
loadMySenders(): void {
|
||||
const userId = this.authService.getUserId();
|
||||
if (!userId) return;
|
||||
|
||||
this.loadingMy.set(true);
|
||||
this.apiService.getUserSenderNames(userId).subscribe({
|
||||
next: (response) => {
|
||||
this.senders.set(response.senders);
|
||||
this.loading.set(false);
|
||||
this.mySenders.set(response.sender_names);
|
||||
this.loadingMy.set(false);
|
||||
},
|
||||
error: () => {
|
||||
this.loading.set(false);
|
||||
this.loadingMy.set(false);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
loadAllSenders(): void {
|
||||
this.loadingAll.set(true);
|
||||
this.apiService.getSenderNames().subscribe({
|
||||
next: (response) => {
|
||||
this.allSenders.set(response.sender_names);
|
||||
this.loadingAll.set(false);
|
||||
},
|
||||
error: () => {
|
||||
this.loadingAll.set(false);
|
||||
}
|
||||
});
|
||||
}
|
||||
|
||||
refresh(): void {
|
||||
if (this.activeTab() === 0) {
|
||||
this.loadMySenders();
|
||||
} else {
|
||||
this.loadAllSenders();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user