Compare commits
	
		
			8 Commits
		
	
	
		
			2caa910613
			...
			0a5f23f1af
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 0a5f23f1af | |||
| 23a3dbbc5e | |||
| 8975665407 | |||
| 90de90684c | |||
| d1ecfe9603 | |||
| f7f25e9428 | |||
| 6ae7ab5c5a | |||
| 315c90cacc | 
| @@ -38,6 +38,8 @@ type Server implements TableWithHistoryQuery { | |||||||
|     config: ServerConfig |     config: ServerConfig | ||||||
|     hasFeatureFlag(flag: String): FeatureFlag |     hasFeatureFlag(flag: String): FeatureFlag | ||||||
|  |  | ||||||
|  |     statistic(date: String): ServerStatistic | ||||||
|  |  | ||||||
|     createdAt: String |     createdAt: String | ||||||
|     modifiedAt: String |     modifiedAt: String | ||||||
|  |  | ||||||
|   | |||||||
							
								
								
									
										17
									
								
								bot/src/bot_graphql/graphql/serverStatistic.gql
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										17
									
								
								bot/src/bot_graphql/graphql/serverStatistic.gql
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,17 @@ | |||||||
|  | type ServerStatistic { | ||||||
|  |     achievementsAchieved: Int | ||||||
|  |     messageCount: Int | ||||||
|  |  | ||||||
|  |     userCount: Int | ||||||
|  |     activeUserCount: Int | ||||||
|  |  | ||||||
|  |     userJoinedVoiceChannelCount: Int | ||||||
|  |     userJoinedVoiceChannelOntime: Int | ||||||
|  |  | ||||||
|  |     userJoinedGameServerCount: Int | ||||||
|  |     userJoinedGameServerOntime: Int | ||||||
|  |  | ||||||
|  |     userWarningCount: Int | ||||||
|  |  | ||||||
|  |     activityScore: Int | ||||||
|  | } | ||||||
| @@ -57,6 +57,7 @@ from bot_graphql.queries.level_query import LevelQuery | |||||||
| from bot_graphql.queries.server_config_query import ServerConfigQuery | from bot_graphql.queries.server_config_query import ServerConfigQuery | ||||||
| from bot_graphql.queries.server_history_query import ServerHistoryQuery | from bot_graphql.queries.server_history_query import ServerHistoryQuery | ||||||
| from bot_graphql.queries.server_query import ServerQuery | from bot_graphql.queries.server_query import ServerQuery | ||||||
|  | from bot_graphql.queries.server_statistic_query import ServerStatisticQuery | ||||||
| from bot_graphql.queries.short_role_name_history_query import ShortRoleNameHistoryQuery | from bot_graphql.queries.short_role_name_history_query import ShortRoleNameHistoryQuery | ||||||
| from bot_graphql.queries.short_role_name_query import ShortRoleNameQuery | from bot_graphql.queries.short_role_name_query import ShortRoleNameQuery | ||||||
| from bot_graphql.queries.technician_config_history_query import ( | from bot_graphql.queries.technician_config_history_query import ( | ||||||
| @@ -138,6 +139,7 @@ class GraphQLModule(ModuleABC): | |||||||
|         services.add_transient(QueryABC, ShortRoleNameQuery) |         services.add_transient(QueryABC, ShortRoleNameQuery) | ||||||
|         services.add_transient(QueryABC, UserWarningHistoryQuery) |         services.add_transient(QueryABC, UserWarningHistoryQuery) | ||||||
|         services.add_transient(QueryABC, UserWarningQuery) |         services.add_transient(QueryABC, UserWarningQuery) | ||||||
|  |         services.add_transient(QueryABC, ServerStatisticQuery) | ||||||
|  |  | ||||||
|         services.add_transient(QueryABC, DiscordQuery) |         services.add_transient(QueryABC, DiscordQuery) | ||||||
|         services.add_transient(QueryABC, GuildQuery) |         services.add_transient(QueryABC, GuildQuery) | ||||||
|   | |||||||
							
								
								
									
										7
									
								
								bot/src/bot_graphql/model/server_statistics.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										7
									
								
								bot/src/bot_graphql/model/server_statistics.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,7 @@ | |||||||
|  | from bot_data.model.server import Server | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class ServerStatistics: | ||||||
|  |     def __init__(self, server: Server, kwargs: dict): | ||||||
|  |         self.server = server | ||||||
|  |         self.kwargs = kwargs | ||||||
| @@ -26,6 +26,7 @@ from bot_graphql.filter.client_filter import ClientFilter | |||||||
| from bot_graphql.filter.level_filter import LevelFilter | from bot_graphql.filter.level_filter import LevelFilter | ||||||
| from bot_graphql.filter.short_role_name_filter import ShortRoleNameFilter | from bot_graphql.filter.short_role_name_filter import ShortRoleNameFilter | ||||||
| from bot_graphql.filter.user_filter import UserFilter | from bot_graphql.filter.user_filter import UserFilter | ||||||
|  | from bot_graphql.model.server_statistics import ServerStatistics | ||||||
|  |  | ||||||
|  |  | ||||||
| class ServerQuery(DataQueryWithHistoryABC): | class ServerQuery(DataQueryWithHistoryABC): | ||||||
| @@ -107,6 +108,7 @@ class ServerQuery(DataQueryWithHistoryABC): | |||||||
|             "hasFeatureFlag", |             "hasFeatureFlag", | ||||||
|             lambda server, *_, **kwargs: self._resolve_has_feature_flag(server, *_, **kwargs), |             lambda server, *_, **kwargs: self._resolve_has_feature_flag(server, *_, **kwargs), | ||||||
|         ) |         ) | ||||||
|  |         self.set_field("statistic", lambda server, *_, **kwargs: ServerStatistics(server, kwargs)) | ||||||
|  |  | ||||||
|     @staticmethod |     @staticmethod | ||||||
|     def resolve_id(server: Server, *_): |     def resolve_id(server: Server, *_): | ||||||
|   | |||||||
							
								
								
									
										157
									
								
								bot/src/bot_graphql/queries/server_statistic_query.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										157
									
								
								bot/src/bot_graphql/queries/server_statistic_query.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,157 @@ | |||||||
|  | import datetime | ||||||
|  |  | ||||||
|  | from cpl_core.configuration import ConfigurationABC | ||||||
|  |  | ||||||
|  | from bot_data.abc.achievement_repository_abc import AchievementRepositoryABC | ||||||
|  | from bot_data.abc.user_joined_game_server_repository_abc import UserJoinedGameServerRepositoryABC | ||||||
|  | from bot_data.abc.user_joined_voice_channel_repository_abc import UserJoinedVoiceChannelRepositoryABC | ||||||
|  | from bot_data.abc.user_message_count_per_hour_repository_abc import UserMessageCountPerHourRepositoryABC | ||||||
|  | from bot_data.abc.user_repository_abc import UserRepositoryABC | ||||||
|  | from bot_data.abc.user_warnings_repository_abc import UserWarningsRepositoryABC | ||||||
|  | from bot_data.model.server_config import ServerConfig | ||||||
|  | from bot_graphql.abc.query_abc import QueryABC | ||||||
|  |  | ||||||
|  |  | ||||||
|  | class ServerStatisticQuery(QueryABC): | ||||||
|  |     def __init__( | ||||||
|  |         self, | ||||||
|  |         config: ConfigurationABC, | ||||||
|  |         users: UserRepositoryABC, | ||||||
|  |         user_joined_voice_channels: UserJoinedVoiceChannelRepositoryABC, | ||||||
|  |         user_joined_game_servers: UserJoinedGameServerRepositoryABC, | ||||||
|  |         user_messages: UserMessageCountPerHourRepositoryABC, | ||||||
|  |         user_warnings: UserWarningsRepositoryABC, | ||||||
|  |         achievements: AchievementRepositoryABC, | ||||||
|  |     ): | ||||||
|  |         QueryABC.__init__(self, "ServerStatistic") | ||||||
|  |  | ||||||
|  |         self._config = config | ||||||
|  |         self._users = users | ||||||
|  |         self._user_joined_voice_channels = user_joined_voice_channels | ||||||
|  |         self._user_joined_game_servers = user_joined_game_servers | ||||||
|  |         self._user_messages = user_messages | ||||||
|  |         self._user_warnings = user_warnings | ||||||
|  |         self._achievements = achievements | ||||||
|  |  | ||||||
|  |         self.set_field( | ||||||
|  |             "achievementsAchieved", | ||||||
|  |             self._resolve_achievements, | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         self.set_field( | ||||||
|  |             "messageCount", | ||||||
|  |             self._resolve_message_count, | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |         self.set_field("userCount", lambda server, *_: self._users.get_users_by_server_id(server.server.id).count()) | ||||||
|  |         self.set_field("activeUserCount", self._resolve_active_count) | ||||||
|  |  | ||||||
|  |         self.set_field("userJoinedVoiceChannelCount", self._resolve_voice_channel_count) | ||||||
|  |         self.set_field("userJoinedVoiceChannelOntime", self._resolve_voice_channel_ontime) | ||||||
|  |  | ||||||
|  |         self.set_field("userJoinedGameServerCount", self._resolve_game_server_count) | ||||||
|  |         self.set_field("userJoinedGameServerOntime", self._resolve_game_server_ontime) | ||||||
|  |  | ||||||
|  |         self.set_field("userWarningCount", self._resolve_user_warning_count) | ||||||
|  |  | ||||||
|  |         self.set_field("activityScore", self._resolve_activity_score) | ||||||
|  |  | ||||||
|  |     def _resolve_activity_score(self, server, *_): | ||||||
|  |         days = (datetime.date.today() - self._get_date(**server.kwargs)).days | ||||||
|  |         return int( | ||||||
|  |             ( | ||||||
|  |                 ( | ||||||
|  |                     self._resolve_achievements(server, *_) | ||||||
|  |                     + self._resolve_message_count(server, *_) | ||||||
|  |                     + self._resolve_voice_channel_count(server, *_) | ||||||
|  |                     + self._resolve_voice_channel_ontime(server, *_) | ||||||
|  |                     + self._resolve_game_server_count(server, *_) | ||||||
|  |                     + self._resolve_game_server_ontime(server, *_) | ||||||
|  |                     - self._resolve_user_warning_count(server, *_) | ||||||
|  |                 ) | ||||||
|  |                 / self._resolve_active_count(server, *_) | ||||||
|  |             ) | ||||||
|  |             / days | ||||||
|  |             * 1000 | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_message_count(self, server, *_): | ||||||
|  |         settings: ServerConfig = self._config.get_configuration(f"ServerConfig_{server.server.discord_id}") | ||||||
|  |         return ( | ||||||
|  |             self._user_messages.get_user_message_count_per_hours() | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .sum(lambda x: x.xp_count / settings.xp_per_message) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_active_count(self, server, *_): | ||||||
|  |         return self._users.get_users_by_server_id(server.server.id).where(lambda x: not x.left_server).count() | ||||||
|  |  | ||||||
|  |     def _resolve_voice_channel_count(self, server, *_): | ||||||
|  |         return ( | ||||||
|  |             self._user_joined_voice_channels.get_user_joined_voice_channels() | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .count() | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_voice_channel_ontime(self, server, *_): | ||||||
|  |         return ( | ||||||
|  |             self._user_joined_voice_channels.get_user_joined_voice_channels() | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .sum(lambda x: x.time) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_game_server_count(self, server, *_): | ||||||
|  |         return ( | ||||||
|  |             self._user_joined_game_servers.get_user_joined_game_servers() | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .count() | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_game_server_ontime(self, server, *_): | ||||||
|  |         return ( | ||||||
|  |             self._user_joined_game_servers.get_user_joined_game_servers() | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .sum(lambda x: x.time) | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_user_warning_count(self, server, *_): | ||||||
|  |         return ( | ||||||
|  |             self._user_warnings.get_user_warnings() | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .count() | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _resolve_achievements(self, server, *_): | ||||||
|  |         return ( | ||||||
|  |             self._achievements.get_achievements_by_server_id(server.server.id) | ||||||
|  |             .select_many(lambda x: self._achievements.get_user_got_achievements_by_achievement_id(x.id)) | ||||||
|  |             .where( | ||||||
|  |                 lambda x: x.user.server.id == server.server.id | ||||||
|  |                 and x.created_at.date() >= self._get_date(**server.kwargs) | ||||||
|  |             ) | ||||||
|  |             .count() | ||||||
|  |         ) | ||||||
|  |  | ||||||
|  |     def _get_date(self, **kwargs) -> datetime.date: | ||||||
|  |         if "date" not in kwargs: | ||||||
|  |             return datetime.date.today() - datetime.timedelta(days=7) | ||||||
|  |  | ||||||
|  |         return datetime.datetime.strptime(kwargs["date"], "%d.%m.%Y").date() | ||||||
| @@ -186,7 +186,7 @@ class SteamOfferWatcher(TaskABC): | |||||||
|         self._logger.trace(__name__, "Finished watching") |         self._logger.trace(__name__, "Finished watching") | ||||||
|         return offers_for_notifications |         return offers_for_notifications | ||||||
|  |  | ||||||
|     @tasks.loop(hours=1) |     @tasks.loop(hours=4) | ||||||
|     async def watch(self): |     async def watch(self): | ||||||
|         self._logger.info(__name__, "Watching steam special offers") |         self._logger.info(__name__, "Watching steam special offers") | ||||||
|         try: |         try: | ||||||
|   | |||||||
| @@ -20,6 +20,7 @@ export interface Server extends Data { | |||||||
|   autoRoles?: AutoRole[]; |   autoRoles?: AutoRole[]; | ||||||
|   clientCount?: number; |   clientCount?: number; | ||||||
|   clients?: Client[]; |   clients?: Client[]; | ||||||
|  |   statistic?: ServerStatistic; | ||||||
|   levelCount?: number; |   levelCount?: number; | ||||||
|   levels?: Level[]; |   levels?: Level[]; | ||||||
|   userCount?: number; |   userCount?: number; | ||||||
| @@ -35,3 +36,16 @@ export interface ServerFilter { | |||||||
|   discordId?: String; |   discordId?: String; | ||||||
|   name?: String; |   name?: String; | ||||||
| } | } | ||||||
|  |  | ||||||
|  | export interface ServerStatistic { | ||||||
|  |   achievementsAchieved?: Number | ||||||
|  |   messageCount?: Number | ||||||
|  |   userCount?: Number | ||||||
|  |   activeUserCount?: Number | ||||||
|  |   userJoinedVoiceChannelCount?: Number | ||||||
|  |   userJoinedVoiceChannelOntime?: Number | ||||||
|  |   userJoinedGameServerCount?: Number | ||||||
|  |   userJoinedGameServerOntime?: Number | ||||||
|  |   userWarningCount?: Number | ||||||
|  |   activityScore?: Number | ||||||
|  | } | ||||||
|   | |||||||
| @@ -79,6 +79,18 @@ export class Queries { | |||||||
|           receivedCommandCount |           receivedCommandCount | ||||||
|           movedUsersCount |           movedUsersCount | ||||||
|         } |         } | ||||||
|  |         statistic { | ||||||
|  |           achievementsAchieved | ||||||
|  |           messageCount | ||||||
|  |           userCount | ||||||
|  |           activeUserCount | ||||||
|  |           userJoinedVoiceChannelCount | ||||||
|  |           userJoinedVoiceChannelOntime | ||||||
|  |           userJoinedGameServerCount | ||||||
|  |           userJoinedGameServerOntime | ||||||
|  |           userWarningCount | ||||||
|  |           activityScore | ||||||
|  |         } | ||||||
|       } |       } | ||||||
|     } |     } | ||||||
|   `; |   `; | ||||||
|   | |||||||
| @@ -0,0 +1,35 @@ | |||||||
|  | <div class="client"> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.activity_score' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.activityScore}}</label> | ||||||
|  |   </div> | ||||||
|  |  | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.achievements_achieved' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.achievementsAchieved}}</label> | ||||||
|  |   </div> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.message_count' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.messageCount}}</label> | ||||||
|  |   </div> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.user_joined_voice_channel_count' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.userJoinedVoiceChannelCount}}</label> | ||||||
|  |   </div> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.user_joined_voice_channel_ontime' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.userJoinedVoiceChannelOntime}}</label> | ||||||
|  |   </div> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.user_joined_game_server_count' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.userJoinedGameServerCount}}</label> | ||||||
|  |   </div> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.user_joined_game_server_ontime' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.userJoinedGameServerOntime}}</label> | ||||||
|  |   </div> | ||||||
|  |   <div class="client-info client-info-small"> | ||||||
|  |     <label class="client-info-header">{{'view.server.dashboard.user_warning_count' | translate}}</label> | ||||||
|  |     <label class="client-info-value">{{stats?.userWarningCount}}</label> | ||||||
|  |   </div> | ||||||
|  | </div> | ||||||
| @@ -0,0 +1,23 @@ | |||||||
|  | import { ComponentFixture, TestBed } from '@angular/core/testing'; | ||||||
|  |  | ||||||
|  | import { ServerStatisticComponent } from './server-statistic.component'; | ||||||
|  |  | ||||||
|  | describe('ServerStatisticComponent', () => { | ||||||
|  |   let component: ServerStatisticComponent; | ||||||
|  |   let fixture: ComponentFixture<ServerStatisticComponent>; | ||||||
|  |  | ||||||
|  |   beforeEach(async () => { | ||||||
|  |     await TestBed.configureTestingModule({ | ||||||
|  |       declarations: [ ServerStatisticComponent ] | ||||||
|  |     }) | ||||||
|  |     .compileComponents(); | ||||||
|  |  | ||||||
|  |     fixture = TestBed.createComponent(ServerStatisticComponent); | ||||||
|  |     component = fixture.componentInstance; | ||||||
|  |     fixture.detectChanges(); | ||||||
|  |   }); | ||||||
|  |  | ||||||
|  |   it('should create', () => { | ||||||
|  |     expect(component).toBeTruthy(); | ||||||
|  |   }); | ||||||
|  | }); | ||||||
| @@ -0,0 +1,22 @@ | |||||||
|  | import { Component, Input } from "@angular/core"; | ||||||
|  | import { ServerStatistic } from "../../../../../../models/data/server.model"; | ||||||
|  |  | ||||||
|  | @Component({ | ||||||
|  |   selector: 'app-server-statistic', | ||||||
|  |   templateUrl: './server-statistic.component.html', | ||||||
|  |   styleUrls: ['./server-statistic.component.scss'] | ||||||
|  | }) | ||||||
|  | export class ServerStatisticComponent { | ||||||
|  |   @Input() stats?: ServerStatistic = { | ||||||
|  |     achievementsAchieved: 0, | ||||||
|  |     messageCount: 0, | ||||||
|  |     userCount: 0, | ||||||
|  |     activeUserCount: 0, | ||||||
|  |     userJoinedVoiceChannelCount: 0, | ||||||
|  |     userJoinedVoiceChannelOntime: 0, | ||||||
|  |     userJoinedGameServerCount: 0, | ||||||
|  |     userJoinedGameServerOntime: 0, | ||||||
|  |     userWarningCount: 0, | ||||||
|  |     activityScore: 0, | ||||||
|  |   }; | ||||||
|  | } | ||||||
| @@ -28,6 +28,13 @@ | |||||||
|               {{'view.dashboard.server.active_members' | translate}} {{server ? server.activeUserCount : ''}} |               {{'view.dashboard.server.active_members' | translate}} {{server ? server.activeUserCount : ''}} | ||||||
|             </div> |             </div> | ||||||
|  |  | ||||||
|  |  | ||||||
|  |             <div class="content-divider"></div> | ||||||
|  |             <div class="client-data"> | ||||||
|  |               <app-server-statistic class="client-component" [stats]="server.statistic"></app-server-statistic> | ||||||
|  |             </div> | ||||||
|  |  | ||||||
|  |             <div class="content-divider"></div> | ||||||
|             <div class="client-data" |             <div class="client-data" | ||||||
|                  *ngFor="let client of server?.clients"> |                  *ngFor="let client of server?.clients"> | ||||||
|               <app-client class="client-component" [client]="client"></app-client> |               <app-client class="client-component" [client]="client"></app-client> | ||||||
|   | |||||||
| @@ -6,6 +6,7 @@ import { SharedModule } from "../../shared/shared.module"; | |||||||
| import { ProfileComponent } from "./profile/profile.component"; | import { ProfileComponent } from "./profile/profile.component"; | ||||||
| import { MembersComponent } from "./members/members.component"; | import { MembersComponent } from "./members/members.component"; | ||||||
| import { ClientComponent } from "./server-dashboard/components/client/client.component"; | import { ClientComponent } from "./server-dashboard/components/client/client.component"; | ||||||
|  | import { ServerStatisticComponent } from './server-dashboard/components/server-statistic/server-statistic.component'; | ||||||
|  |  | ||||||
|  |  | ||||||
| @NgModule({ | @NgModule({ | ||||||
| @@ -14,6 +15,7 @@ import { ClientComponent } from "./server-dashboard/components/client/client.com | |||||||
|     ProfileComponent, |     ProfileComponent, | ||||||
|     MembersComponent, |     MembersComponent, | ||||||
|     ClientComponent, |     ClientComponent, | ||||||
|  |     ServerStatisticComponent, | ||||||
|   ], |   ], | ||||||
|   imports: [ |   imports: [ | ||||||
|     CommonModule, |     CommonModule, | ||||||
|   | |||||||
| @@ -454,13 +454,21 @@ | |||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|       "dashboard": { |       "dashboard": { | ||||||
|  |         "achievements_achieved": "Errungenschaften vergeben", | ||||||
|  |         "activity_score": "Aktivitätsbewertung", | ||||||
|         "deleted_message_count": "Gelöschte Nachrichten", |         "deleted_message_count": "Gelöschte Nachrichten", | ||||||
|         "header": "Server dashboard", |         "header": "Server dashboard", | ||||||
|  |         "message_count": "Anzahl Nachrichten", | ||||||
|         "moved_users_count": "Verschobene Benutzer", |         "moved_users_count": "Verschobene Benutzer", | ||||||
|         "name": "Name", |         "name": "Name", | ||||||
|         "received_command_count": "Empfangene Befehle", |         "received_command_count": "Empfangene Befehle", | ||||||
|         "received_message_count": "Empfangene Nachrichten", |         "received_message_count": "Empfangene Nachrichten", | ||||||
|         "sent_message_count": "Gesendete Nachrichten" |         "sent_message_count": "Gesendete Nachrichten", | ||||||
|  |         "user_joined_game_server_count": "Anzahl Gameserver beitritte", | ||||||
|  |         "user_joined_game_server_ontime": "Gameserver Ontime", | ||||||
|  |         "user_joined_voice_channel_count": "Anzahl Sprachkanal beitritte", | ||||||
|  |         "user_joined_voice_channel_ontime": "Sprachkanal Ontime", | ||||||
|  |         "user_warning_count": "Anzahl Verwarnungen" | ||||||
|       }, |       }, | ||||||
|       "header": "Server", |       "header": "Server", | ||||||
|       "levels": { |       "levels": { | ||||||
|   | |||||||
| @@ -454,13 +454,21 @@ | |||||||
|         } |         } | ||||||
|       }, |       }, | ||||||
|       "dashboard": { |       "dashboard": { | ||||||
|  |         "achievements_achieved": "Achievements achieved", | ||||||
|  |         "activity_score": "Activity score", | ||||||
|         "deleted_message_count": "Deleted messages", |         "deleted_message_count": "Deleted messages", | ||||||
|         "header": "Server dashboard", |         "header": "Server dashboard", | ||||||
|  |         "message_count": "Message count", | ||||||
|         "moved_users_count": "Moved users", |         "moved_users_count": "Moved users", | ||||||
|         "name": "Name", |         "name": "Name", | ||||||
|         "received_command_count": "Received commands", |         "received_command_count": "Received commands", | ||||||
|         "received_message_count": "Received messages", |         "received_message_count": "Received messages", | ||||||
|         "sent_message_count": "Sent messages" |         "sent_message_count": "Sent messages", | ||||||
|  |         "user_joined_game_server_count": "Joined Gameserver count", | ||||||
|  |         "user_joined_game_server_ontime": "Gameserver ontime", | ||||||
|  |         "user_joined_voice_channel_count": "Joined voice channel count", | ||||||
|  |         "user_joined_voice_channel_ontime": "Joined voice channel ontime", | ||||||
|  |         "user_warning_count": "User warning count" | ||||||
|       }, |       }, | ||||||
|       "header": "Server", |       "header": "Server", | ||||||
|       "levels": { |       "levels": { | ||||||
|   | |||||||
| @@ -163,6 +163,14 @@ header { | |||||||
|             } |             } | ||||||
|           } |           } | ||||||
|  |  | ||||||
|  |           td, | ||||||
|  |           th { | ||||||
|  |             p-dropdown, | ||||||
|  |             .p-dropdown { | ||||||
|  |               width: 100%; | ||||||
|  |             } | ||||||
|  |           } | ||||||
|  |  | ||||||
|           .content-row { |           .content-row { | ||||||
|             display: flex; |             display: flex; | ||||||
|             flex-direction: row; |             flex-direction: row; | ||||||
| @@ -811,8 +819,4 @@ p-inputNumber { | |||||||
|       gap: 5px; |       gap: 5px; | ||||||
|     } |     } | ||||||
|   } |   } | ||||||
|  |  | ||||||
|   p-dropdown { |  | ||||||
|     width: 100%; |  | ||||||
|   } |  | ||||||
| } | } | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user