ngx-histaff-alpha 2.9.4 → 2.9.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -54,6 +54,32 @@ export class SocketService {
54
54
  case EnumSignalRType.LOG_IN:
55
55
  if (isDevMode())
56
56
  this.alertService.info(activity.message, alertOptions);
57
+ if ('Notification' in window) {
58
+ const options = {
59
+ body: activity.message,
60
+ icon: 'assets/icons/icon-72x72.png',
61
+ };
62
+ // Check if notification permissions are granted
63
+ if (Notification.permission === 'granted') {
64
+ // Create and display the notification
65
+ new Notification("Information", options);
66
+ }
67
+ else if (Notification.permission !== 'denied') {
68
+ // Request permission from the user
69
+ Notification.requestPermission().then(permission => {
70
+ if (permission === 'granted') {
71
+ // Create and display the notification
72
+ new Notification("Information", options);
73
+ }
74
+ });
75
+ }
76
+ else {
77
+ console.warn('Notification permissions not granted or denied.');
78
+ }
79
+ }
80
+ else {
81
+ console.warn('Notifications are not supported in this browser.');
82
+ }
57
83
  break;
58
84
  case EnumSignalRType.ENTITY_CHANGED:
59
85
  if (isDevMode())
@@ -144,4 +170,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
144
170
  providedIn: 'root'
145
171
  }]
146
172
  }], ctorParameters: () => [{ type: i1.AuthService }, { type: i2.UserActivityService }, { type: i3.HubConnectionService }, { type: i4.AppConfigService }, { type: i5.AlertService }, { type: i6.Router }, { type: i7.LongTaskService }] });
147
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"socket.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/services/socket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\r\nimport { AuthService } from './auth.service';\r\nimport { HubConnectionService } from './hub-connection.service';\r\nimport { HubConnection, HubConnectionBuilder, LogLevel } from '@microsoft/signalr';\r\nimport { IUserActivityData, UserActivityService } from './user-activity.service';\r\nimport { AppConfigService } from './app-config.service';\r\nimport { IHubConnectionActivity } from '../interfaces/IHubConnectionActivity';\r\nimport { AlertService } from '../libraries/alert/alert.service';\r\nimport { LongTaskService } from '../libraries/services/long-task.service';\r\nimport { alertOptions } from '../constants/alertOptions';\r\nimport { EnumSignalRType } from '../enum/EnumSignalRType';\r\nimport { Router } from '@angular/router';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class SocketService {\r\n\r\n  constructor(\r\n    private authService: AuthService,\r\n    private userActivityService: UserActivityService,\r\n    private hubConnectionService: HubConnectionService,\r\n    private appConfigService: AppConfigService,\r\n    private alertService: AlertService,\r\n    private router: Router,\r\n    private longTaskService: LongTaskService\r\n  ) { }\r\n\r\n  createHubConnection() {\r\n    const token = this.authService.data$.value?.token;\r\n    if (!!!token) {\r\n      console.warn(\"No user logged in\");\r\n      return;\r\n    }\r\n\r\n    const connection: HubConnection = new HubConnectionBuilder()\r\n      .withUrl(this.appConfigService.BASE_URL + '/hubs/signal', {\r\n        // .withUrl('https://tanleica.com/hubs/signal', {\r\n        headers: {\r\n          \"Access-Control-Allow-Credentials\": true,\r\n          \"Access-Control-Allow-Origin\": true,\r\n        } as any,\r\n        withCredentials: false,\r\n        accessTokenFactory: () => token,\r\n      })\r\n      .configureLogging(LogLevel.None)\r\n      .build()\r\n\r\n    connection.on(\"ReceiveSystemMessage\", message => {\r\n      console.log(\"System message: \", message)\r\n    })\r\n\r\n    connection.on(\"ReceiveMessage\", (activity: IHubConnectionActivity) => {\r\n\r\n      console.log(\"MONITORING: \", activity);\r\n      if (this.appConfigService.DEBUG_ENABLED) debugger\r\n\r\n      switch (activity.signalType) {\r\n        case EnumSignalRType.TASK_PROGRESS:\r\n          this.longTaskService.message$.next(activity.message)\r\n          this.longTaskService.data$.next((activity as any).data)\r\n          this.longTaskService.error$.next((activity as any).error)\r\n          break;\r\n        case EnumSignalRType.LOG_IN:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ENTITY_CHANGED:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ACTIVITY:\r\n          const { loginTime } = activity;\r\n          const { sid, username, pathname, avatar, hubConnectionId, accessTime, userActivity } = activity.data;\r\n\r\n          const currentSid = this.authService.data$.value?.fullName;\r\n\r\n          console.group(\"ACTIVITY\")\r\n          console.log(\"isDevMode()\", isDevMode());\r\n          console.log(\"Incoming loginTime\", loginTime);\r\n          console.log(\"Your loginTime\", this.authService.data$.value?.loginTime!);\r\n          console.log(\"Incoming sid\", sid);\r\n          console.log(\"Your sid\", currentSid);\r\n\r\n          console.groupEnd();\r\n\r\n          if (loginTime < this.authService.data$.value?.loginTime! && sid === currentSid /*&& isDevMode()*/) {\r\n\r\n            if (isDevMode()) {\r\n\r\n              this.alertService.error(\r\n                `Trong môi trường Dev, tài khoản (${sid}) đã được dùng trước rồi nhé. Xin đăng nhập bằng tài khoản khác`,\r\n                { ...alertOptions, autoClose: false }\r\n              )\r\n\r\n              setTimeout(() => {\r\n                this.authService.userLogout().subscribe(x => {\r\n                  if (x.ok && x.status === 200) {\r\n                    this.authService.postLogout();\r\n                  }\r\n                });\r\n              }, 3000)\r\n\r\n            }\r\n          }\r\n\r\n          const merged = this.userActivityService.mergeActivities(userActivity)\r\n          const found = merged.filter(item => item.sid === sid)\r\n          if (found.length) {\r\n            const newState: IUserActivityData = { sid, username, pathname, avatar, hubConnectionId, accessTime }\r\n            merged.filter(item => item.sid !== sid).push(newState)\r\n          } else {\r\n            merged.push({ sid, username, pathname, avatar, hubConnectionId, accessTime })\r\n          }\r\n\r\n          this.userActivityService.userActivity$.next(merged);\r\n\r\n          break;\r\n        case EnumSignalRType.ACTIVITY_HISTORY_RESET:\r\n          this.userActivityService.userActivity$.next([]);\r\n          break;\r\n\r\n        default:\r\n          break;\r\n      }\r\n\r\n\r\n    })\r\n\r\n    const start = async () => {\r\n      let id\r\n      try {\r\n        this.hubConnectionService.message = \"HubConnection creating requested.\"\r\n        await connection.start();\r\n        console.log(\"🟢🟢🟢 SignalR Connected.\");\r\n        this.hubConnectionService.message = \"HubConnection created.\";\r\n        this.hubConnectionService.hubConnection$.next(connection);\r\n\r\n        if (id) clearTimeout(id)\r\n\r\n      } catch (err: any) {\r\n        console.group(`🔴🔴🔴 HUB CONNECTION PROBLEM ====================`)\r\n        this.hubConnectionService.message = err;\r\n        console.warn(\"hubConnection start() error: \", err)\r\n\r\n        if (typeof err === 'string') {\r\n          if (err.indexOf(`Status code '401'`) >= 0) {\r\n            console.warn(\"The token expired\")\r\n          } else {\r\n            id = setTimeout(start, 5000)\r\n          }\r\n        } else {\r\n          id = setTimeout(start, 5000)\r\n        }\r\n        console.groupEnd()\r\n      }\r\n    }\r\n\r\n    connection.onclose(async () => {\r\n      await start();\r\n    })\r\n\r\n    // Start the connection.\r\n    start();\r\n  }\r\n\r\n}\r\n"]}
173
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"socket.service.js","sourceRoot":"","sources":["../../../../../../projects/ngx-histaff-alpha/src/lib/app/services/socket.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, isDevMode } from '@angular/core';\r\nimport { AuthService } from './auth.service';\r\nimport { HubConnectionService } from './hub-connection.service';\r\nimport { HubConnection, HubConnectionBuilder, LogLevel } from '@microsoft/signalr';\r\nimport { IUserActivityData, UserActivityService } from './user-activity.service';\r\nimport { AppConfigService } from './app-config.service';\r\nimport { IHubConnectionActivity } from '../interfaces/IHubConnectionActivity';\r\nimport { AlertService } from '../libraries/alert/alert.service';\r\nimport { LongTaskService } from '../libraries/services/long-task.service';\r\nimport { alertOptions } from '../constants/alertOptions';\r\nimport { EnumSignalRType } from '../enum/EnumSignalRType';\r\nimport { Router } from '@angular/router';\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class SocketService {\r\n\r\n  constructor(\r\n    private authService: AuthService,\r\n    private userActivityService: UserActivityService,\r\n    private hubConnectionService: HubConnectionService,\r\n    private appConfigService: AppConfigService,\r\n    private alertService: AlertService,\r\n    private router: Router,\r\n    private longTaskService: LongTaskService\r\n  ) { }\r\n\r\n  createHubConnection() {\r\n    const token = this.authService.data$.value?.token;\r\n    if (!!!token) {\r\n      console.warn(\"No user logged in\");\r\n      return;\r\n    }\r\n\r\n    const connection: HubConnection = new HubConnectionBuilder()\r\n      .withUrl(this.appConfigService.BASE_URL + '/hubs/signal', {\r\n        // .withUrl('https://tanleica.com/hubs/signal', {\r\n        headers: {\r\n          \"Access-Control-Allow-Credentials\": true,\r\n          \"Access-Control-Allow-Origin\": true,\r\n        } as any,\r\n        withCredentials: false,\r\n        accessTokenFactory: () => token,\r\n      })\r\n      .configureLogging(LogLevel.None)\r\n      .build()\r\n\r\n    connection.on(\"ReceiveSystemMessage\", message => {\r\n      console.log(\"System message: \", message)\r\n    })\r\n\r\n    connection.on(\"ReceiveMessage\", (activity: IHubConnectionActivity) => {\r\n\r\n      console.log(\"MONITORING: \", activity);\r\n      if (this.appConfigService.DEBUG_ENABLED) debugger\r\n\r\n      switch (activity.signalType) {\r\n        case EnumSignalRType.TASK_PROGRESS:\r\n          this.longTaskService.message$.next(activity.message)\r\n          this.longTaskService.data$.next((activity as any).data)\r\n          this.longTaskService.error$.next((activity as any).error)\r\n          break;\r\n        case EnumSignalRType.LOG_IN:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n\r\n            if ('Notification' in window) {\r\n\r\n              const options = {\r\n                body: activity.message,\r\n                icon: 'assets/icons/icon-72x72.png',\r\n              };\r\n\r\n              // Check if notification permissions are granted\r\n              if (Notification.permission === 'granted') {\r\n                // Create and display the notification\r\n                new Notification(\"Information\", options);\r\n              } else if (Notification.permission !== 'denied') {\r\n                // Request permission from the user\r\n                Notification.requestPermission().then(permission => {\r\n                  if (permission === 'granted') {\r\n                    // Create and display the notification\r\n                    new Notification(\"Information\", options);\r\n                  }\r\n                });\r\n              } else {\r\n                console.warn('Notification permissions not granted or denied.');\r\n              }\r\n            } else {\r\n              console.warn('Notifications are not supported in this browser.');\r\n            }\r\n\r\n          break;\r\n        case EnumSignalRType.ENTITY_CHANGED:\r\n          if (isDevMode()) this.alertService.info(activity.message, alertOptions)\r\n          break;\r\n        case EnumSignalRType.ACTIVITY:\r\n          const { loginTime } = activity;\r\n          const { sid, username, pathname, avatar, hubConnectionId, accessTime, userActivity } = activity.data;\r\n\r\n          const currentSid = this.authService.data$.value?.fullName;\r\n\r\n          console.group(\"ACTIVITY\")\r\n          console.log(\"isDevMode()\", isDevMode());\r\n          console.log(\"Incoming loginTime\", loginTime);\r\n          console.log(\"Your loginTime\", this.authService.data$.value?.loginTime!);\r\n          console.log(\"Incoming sid\", sid);\r\n          console.log(\"Your sid\", currentSid);\r\n\r\n          console.groupEnd();\r\n\r\n          if (loginTime < this.authService.data$.value?.loginTime! && sid === currentSid /*&& isDevMode()*/) {\r\n\r\n            if (isDevMode()) {\r\n\r\n              this.alertService.error(\r\n                `Trong môi trường Dev, tài khoản (${sid}) đã được dùng trước rồi nhé. Xin đăng nhập bằng tài khoản khác`,\r\n                { ...alertOptions, autoClose: false }\r\n              )\r\n\r\n              setTimeout(() => {\r\n                this.authService.userLogout().subscribe(x => {\r\n                  if (x.ok && x.status === 200) {\r\n                    this.authService.postLogout();\r\n                  }\r\n                });\r\n              }, 3000)\r\n\r\n            }\r\n          }\r\n\r\n          const merged = this.userActivityService.mergeActivities(userActivity)\r\n          const found = merged.filter(item => item.sid === sid)\r\n          if (found.length) {\r\n            const newState: IUserActivityData = { sid, username, pathname, avatar, hubConnectionId, accessTime }\r\n            merged.filter(item => item.sid !== sid).push(newState)\r\n          } else {\r\n            merged.push({ sid, username, pathname, avatar, hubConnectionId, accessTime })\r\n          }\r\n\r\n          this.userActivityService.userActivity$.next(merged);\r\n\r\n          break;\r\n        case EnumSignalRType.ACTIVITY_HISTORY_RESET:\r\n          this.userActivityService.userActivity$.next([]);\r\n          break;\r\n\r\n        default:\r\n          break;\r\n      }\r\n\r\n\r\n    })\r\n\r\n    const start = async () => {\r\n      let id\r\n      try {\r\n        this.hubConnectionService.message = \"HubConnection creating requested.\"\r\n        await connection.start();\r\n        console.log(\"🟢🟢🟢 SignalR Connected.\");\r\n        this.hubConnectionService.message = \"HubConnection created.\";\r\n        this.hubConnectionService.hubConnection$.next(connection);\r\n\r\n        if (id) clearTimeout(id)\r\n\r\n      } catch (err: any) {\r\n        console.group(`🔴🔴🔴 HUB CONNECTION PROBLEM ====================`)\r\n        this.hubConnectionService.message = err;\r\n        console.warn(\"hubConnection start() error: \", err)\r\n\r\n        if (typeof err === 'string') {\r\n          if (err.indexOf(`Status code '401'`) >= 0) {\r\n            console.warn(\"The token expired\")\r\n          } else {\r\n            id = setTimeout(start, 5000)\r\n          }\r\n        } else {\r\n          id = setTimeout(start, 5000)\r\n        }\r\n        console.groupEnd()\r\n      }\r\n    }\r\n\r\n    connection.onclose(async () => {\r\n      await start();\r\n    })\r\n\r\n    // Start the connection.\r\n    start();\r\n  }\r\n\r\n}\r\n"]}
@@ -4343,6 +4343,32 @@ class SocketService {
4343
4343
  case EnumSignalRType.LOG_IN:
4344
4344
  if (isDevMode())
4345
4345
  this.alertService.info(activity.message, alertOptions);
4346
+ if ('Notification' in window) {
4347
+ const options = {
4348
+ body: activity.message,
4349
+ icon: 'assets/icons/icon-72x72.png',
4350
+ };
4351
+ // Check if notification permissions are granted
4352
+ if (Notification.permission === 'granted') {
4353
+ // Create and display the notification
4354
+ new Notification("Information", options);
4355
+ }
4356
+ else if (Notification.permission !== 'denied') {
4357
+ // Request permission from the user
4358
+ Notification.requestPermission().then(permission => {
4359
+ if (permission === 'granted') {
4360
+ // Create and display the notification
4361
+ new Notification("Information", options);
4362
+ }
4363
+ });
4364
+ }
4365
+ else {
4366
+ console.warn('Notification permissions not granted or denied.');
4367
+ }
4368
+ }
4369
+ else {
4370
+ console.warn('Notifications are not supported in this browser.');
4371
+ }
4346
4372
  break;
4347
4373
  case EnumSignalRType.ENTITY_CHANGED:
4348
4374
  if (isDevMode())