@tuki-io/tuki-widgets 0.0.157 → 0.0.158

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.
@@ -30,7 +30,7 @@ export class DeviceManageWidgetComponent {
30
30
  return this.userService.userDevice?.form;
31
31
  }
32
32
  get isWebex() {
33
- return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID')?.length;
33
+ return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID') !== 'null';
34
34
  }
35
35
  constructor(userService, deviceService, apiService, lineService, siteSettingsService, validationService, dialog) {
36
36
  this.userService = userService;
@@ -165,4 +165,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
165
165
  type: ViewChild,
166
166
  args: ['tagInput']
167
167
  }] } });
168
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"device-manage-widget.component.js","sourceRoot":"","sources":["../../../../../../projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.ts","../../../../../../projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { FormControl, FormControlName, FormGroup, Validators } from '@angular/forms';\r\nimport { SimplifiedUser } from './classes/simplified-user';\r\nimport { LineAssociation } from './classes/line-association';\r\nimport { LineAssociationInterface } from './classes/line-association-interface';\r\nimport { Device, DeviceViewType } from './classes/device';\r\nimport { finalize, forkJoin, Subject, takeUntil } from 'rxjs';\r\nimport { MatTabGroup } from '@angular/material/tabs';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { InfoDialogComponent } from './confirm-dialog/info-dialog.component';\r\nimport { UserService } from './services/user.service';\r\nimport { DeviceService } from './services/device.service';\r\nimport { APIService } from './services/api.service';\r\nimport { LineService } from './services/line.service';\r\nimport { SiteSettingsService } from './services/site-settings.service';\r\nimport { ValidationService } from './services/validation.service';\r\nimport { TOGGLE_TYPES } from './app.constants';\r\n\r\n@Component({\r\n  selector: 'app-device-manage-widget',\r\n  templateUrl: './device-manage-widget.component.html',\r\n  styleUrls: ['./device-manage-widget.component.scss'],\r\n})\r\nexport class DeviceManageWidgetComponent implements OnDestroy {\r\n  @Output() onSave = new EventEmitter<string>();\r\n  @Output() onChange = new EventEmitter<string>();\r\n  @Output() discardChanges = new EventEmitter();\r\n  @Output() goBack = new EventEmitter();\r\n  @Input() token!: string;\r\n  @Input() host!: string;\r\n  @Input() siteId!: number;\r\n  @Input() userId!: string;\r\n  @Input() isLdap!: boolean;\r\n  @Input() deviceName!: string;\r\n\r\n   @ViewChild('tagInput') tagInput!: ElementRef<HTMLInputElement>;\r\n\r\n  dataPending!: boolean;\r\n  private readonly destroy$ = new Subject<void>();\r\n  public device: any = null;\r\n  public tokenObj: any = null;\r\n\r\n  public readonly HOTELING_TIME_HOURS = Array.from({ length: 120 }, (_, index) => index);\r\n\r\n  // public readonly hotelingLimitTime = new FormControl(24);\r\n  public logMissedCall = new FormControl(true);\r\n\r\n  tags: string[] = [];\r\n  isAdding = false;\r\n  newTag = '';\r\n\r\n  get firstName(): string {\r\n    return this.userService.userName;\r\n  }\r\n\r\n  get lastName(): string {\r\n    return this.userService.userLastName;\r\n  }\r\n\r\n  get form(): FormGroup | undefined {\r\n    return this.userService.userDevice?.form;\r\n  }\r\n\r\n  get isWebex() {\r\n    return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID')?.length;\r\n  }\r\n\r\n  constructor(\r\n    public userService: UserService,\r\n    public deviceService: DeviceService,\r\n    private apiService: APIService,\r\n    public lineService: LineService,\r\n    public siteSettingsService: SiteSettingsService,\r\n    private validationService: ValidationService,\r\n    private dialog: MatDialog\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.apiService.token = this.token;\r\n    this.apiService.apiUrl = this.host;\r\n    console.log('this.apiService.apiUrl = ', this.apiService.apiUrl);\r\n    this.getData();\r\n  }\r\n\r\n  showInput() {\r\n    this.isAdding = true;\r\n\r\n    // wait until input appears in DOM\r\n    setTimeout(() => {\r\n      this.tagInput?.nativeElement.focus();\r\n    });\r\n  }\r\n\r\n  onBlur() {\r\n    const value = this.newTag.trim();\r\n\r\n    if (value) {\r\n      this.tags.push(value);\r\n    }\r\n\r\n    this.newTag = '';\r\n    this.isAdding = false;\r\n  }\r\n\r\n  removeTag(index: number) {\r\n    this.tags.splice(index, 1);\r\n  }\r\n\r\n  get hotelingEnabled(): FormControl {\r\n    return this.form?.get('hoteling')?.get('enabled') as FormControl;\r\n  }\r\n\r\n  get guestHoursLimit(): FormControl {\r\n    return this.form?.get('hoteling')?.get('guestHoursLimit') as FormControl;\r\n  }\r\n\r\n  private getData() {\r\n    this.dataPending = true;\r\n    let request;\r\n    const deviceType = localStorage.getItem('deviceType');\r\n    if(localStorage.getItem('isWebex') === 'true') {\r\n      // request\r\n      const customerId = localStorage.getItem('customerId');\r\n      const webexId = localStorage.getItem('webexUUID');\r\n      request = this.userService.fetchWebexUserDevice(customerId!, webexId!, deviceType!);\r\n    } else {\r\n      request = this.userService.fetchDIUserDevice(this.siteId, this.userId, deviceType!);\r\n    }\r\n    request\r\n    .pipe(takeUntil(this.destroy$))\r\n    .pipe(finalize(() => this.dataPending = false))\r\n    .subscribe((data: any) => {\r\n      this.device = data;\r\n    });\r\n  }\r\n\r\n  public onNumberChange(event: Event, index: number) {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n    this.device.lines[index].number = value;\r\n    this.onChange.emit();\r\n  }\r\n\r\n  public onExtensionChange(event: Event, index: number) {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n    this.device.lines[index].extension = value;\r\n    this.onChange.emit();\r\n  }\r\n\r\n  saveChanges(): void {\r\n    if (!this.userService.hasUnsavedChanges() || this.form?.invalid) {\r\n      return;\r\n    }\r\n\r\n    const updatedLines = this.device.lines.filter((line: any, index: any) => this.userService.lineUpdated(line, index));\r\n    updatedLines.forEach((line: any) => {\r\n      this.userService.editTranslationPattern(\r\n        this.userService.cucmId,\r\n        this.userService.getOriginalNumber(line),\r\n        line.number,\r\n        line.extension,\r\n        line.routePartitionName,\r\n        line.description || '',\r\n      ).subscribe(() => {\r\n          this.dataPending = false;\r\n          this.onSave.next(\"device's line has been saved successfully..\");\r\n          // subscription.unsubscribe();\r\n        }, () => this.dataPending = false);\r\n    })\r\n\r\n    this.dataPending = true;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  onGoBack(): void {\r\n    this.goBack.emit();\r\n  }\r\n}\r\n","\r\n\r\n<app-loader *ngIf=\"dataPending\"></app-loader>\r\n<div *ngIf=\"!dataPending\">\r\n  <!-- <div class=\"go-back-box\" (click)=\"onGoBack()\"> -->\r\n  <div class=\"go-back-box\">\r\n    <div class=\"go-back-box-container\">\r\n      <span class=\"app-icon icon-webex-left-arrow\"></span>\r\n      <span class=\"go-back-title\">Devices</span>\r\n    </div>\r\n  </div>\r\n\r\n  <app-device-info \r\n    [device]=\"device\" \r\n    [firstName]=\"firstName\" \r\n    [lastName]=\"lastName\"\r\n    (onclickBack)=\"onGoBack()\"\r\n    >\r\n    \r\n  </app-device-info>\r\n  <div class=\"device-info\">\r\n\r\n    <div class=\"device-info-part\">\r\n\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Details</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">{{ form?.get('maxLineCount')?.value || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">Lines</span>\r\n                    </div>\r\n                    <div class=\"side right-part\">\r\n                        <span class=\"main-value\">{{ (form?.get('macAddress')?.value | macAddress) || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">MAC address</span>\r\n                    </div>\r\n                </div>\r\n                <mat-divider></mat-divider>\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">{{ form?.get('ipAddress')?.value || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">Host IP address</span>\r\n                    </div>\r\n                    <div class=\"side right-part\">\r\n                        <span class=\"main-value\">{{ form?.get('remoteIpAddress')?.value || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">Remote IP address</span>\r\n                    </div>\r\n                </div>\r\n                <mat-divider></mat-divider>\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">Cisco</span>\r\n                        <span class=\"extra-info\">Managed By</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Software</span>\r\n                <div class=\"icon-bordered-wrapper\">\r\n                    <i class=\"icon configure-icon rem1\"></i>\r\n                </div>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">{{ form?.get('softwareVersion')?.value || 'N/A'}}</span>\r\n                        <span class=\"extra-info\">Software Channel</span>\r\n                    </div>\r\n                    <div class=\"side right-part\">\r\n                        <span class=\"main-value\">{{ form?.get('softwareChannel')?.value || 'N/A'}}</span>\r\n                        <span class=\"extra-info\">Software version</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Tags</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\" style=\"flex-direction: column; gap: 1rem;\">\r\n                    <div class=\"tags-list-container\">\r\n                        <div *ngFor=\"let tag of tags; let i = index\" class=\"tag-label\">\r\n                            <span class=\"tag-desccription\">{{ tag }}</span>\r\n                            <i class=\"icon close-icon\" (click)=\"removeTag(i)\" style=\"width: 0.75rem; height: 0.75rem; flex: 0 0 auto;\"></i>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"tags-list-container\">\r\n                        <button class=\"tag-label add-tag\" (click)=\"showInput()\">\r\n                            <span class=\"icon plus-icon\" style=\"width: 0.75rem; height: 0.75rem;\"></span>\r\n                            <span>Add tag</span>\r\n                        </button>\r\n                        <input \r\n                            #tagInput\r\n                            id=\"enter-tag-input\" \r\n                            *ngIf=\"isAdding\"\r\n                            [(ngModel)]=\"newTag\"\r\n                            (blur)=\"onBlur()\"\r\n                            type=\"text\"\r\n                            class=\"add-tag-input\" \r\n                            placeholder=\"Enter tag...\"\r\n                        >\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n    </div>\r\n\r\n    <div class=\"device-info-part\">\r\n        <section class=\"card\">\r\n             <div class=\"header\">\r\n                <span class=\"title\">Issues & Information</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\">\r\n                    <div class=\"description\">\r\n                        <i class=\"icon check-icon rem1\" style=\"filter: invert(26%) sepia(27%) saturate(1093%) hue-rotate(114deg) brightness(93%) contrast(90%);\"></i>\r\n                        <span class=\"text-description\">No reported issues at this time</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n             <div class=\"header\">\r\n                <span class=\"title\">Hoteling</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row flex-column gap-0_75\">\r\n                    <span class=\"text-description\">Allow this device to be used as a Hoteling Host by visiting guests.</span>\r\n                    <div class=\"toggle-wrapper\">\r\n                        <mat-slide-toggle class=\"custom-toggle\" name=\"logMissedCalls\" [formControl]=\"hotelingEnabled\"></mat-slide-toggle>\r\n                        <i class=\"icon info-icon rem1\" \r\n                            style=\"filter: invert(20%) sepia(99%) saturate(2065%) hue-rotate(197deg) brightness(92%) contrast(101%);\"\r\n                            [matTooltip]=\"'Enabling this device for Hoteling means that a guest (end user) can log into this host (workspace phone) and use this phone as if it were their own. This is useful when traveling to a remote office but still needing to place/receive calls with their telephone number and to access features normally available to them on their own office phone.'\"\r\n                        ></i>\r\n                    </div>\r\n                    <span class=\"text-description\">Limit the time a guest can use this phone to</span>\r\n                    <mat-select [formControl]=\"guestHoursLimit\">\r\n                        <mat-option *ngFor=\"let type of HOTELING_TIME_HOURS\" [value]=\"type\">\r\n                            {{type}}\r\n                        </mat-option>\r\n                    </mat-select>\r\n                </div>\r\n            </div>\r\n        </section>\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Device Management</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row flex-column gap-0_75\">\r\n                    <p class=\"text-description\">The users and workspaces that appear on this device are displayed below in the order of appearance.</p>\r\n                    <div class=\"flex-column\">\r\n                        <span class=\"text-description\">To add and remove users and workspaces, select <b>Configure Lines.</b></span>\r\n                        <span class=\"text-description\">To customize the programmable Line Keys, select <b>Configure Layout.</b></span>\r\n                        <span class=\"text-description\">To set up the display settings and dialing options, select <b>Device Settings</b>.</span>\r\n                    </div>\r\n                    <table style=\"border-collapse:collapse;\">\r\n                        <thead>\r\n                        <tr style=\"background:#ededed;\">\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Index #</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Name</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Number/Extension</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Appearances</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Registered</th>\r\n                        </tr>\r\n                        </thead>\r\n                        <tbody>\r\n                        <ng-container *ngIf=\"device?.lines && device?.lines.length\">\r\n                            <tr style=\"background:#fff; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='#fff'\"\r\n                            \r\n                            *ngFor=\"let line of device.lines; let i = index\">\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span style=\"display:inline-block; color:#000000f2; padding:4px 14px; font-size:.875rem; font-weight:400;\"></span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span style=\"display:inline-block; color:#000000f2; padding:4px 14px; font-size:.875rem; font-weight:400;\">{{line?.name}}</span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span\r\n                                        [attr.contenteditable]=\"!isWebex\"\r\n                                        (blur)=\"onNumberChange($event, i)\">\r\n                                        {{ line?.number || 'NA' }}\r\n                                    </span> /\r\n                                    <span\r\n                                        [attr.contenteditable]=\"!isWebex\"\r\n                                        (blur)=\"onExtensionChange($event, i)\">\r\n                                        {{ line?.extension }}\r\n                                    </span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span style=\"display:inline-block; color:#000000f2; padding:4px 14px; font-size:.875rem; font-weight:400;\">1</span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <i class=\"icon warning-icon rem1\" [matTooltip]=\"'Unregistered'\"></i>\r\n                                </td>\r\n                        </tr>\r\n                        </ng-container>\r\n                        \r\n                        </tbody>\r\n                    </table>\r\n                    <div class=\"totals\">\r\n                       <span class=\"text-description\">15 of 16 total lines available</span>\r\n                    </div>\r\n                    <div class=\"configure-lines\">\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <i class=\"icon configure-icon rem1-25\"></i>\r\n                                <span class=\"text-description\">Configure Lines</span>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                        <mat-divider></mat-divider>\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <i class=\"icon configure-icon rem1-25\"></i>\r\n                                <span class=\"text-description\">Configure Layout</span>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                        <mat-divider></mat-divider>\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <i class=\"icon configure-icon rem1-25\"></i>\r\n                                <span class=\"text-description\">Device Settings</span>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n             <div class=\"header\">\r\n                <span class=\"title\">Support</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row flex-column gap-0_75\">\r\n                    <div class=\"configure-lines\">\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <span class=\"text-description\">Meetings & Calls</span>\r\n                                <span class=\"label new\">New</span>\r\n                                <i class=\"icon info-icon rem1\"\r\n                                    [matTooltip]=\"'Troubleshooting provides details about the device related to status, network activity, and call information.'\"\r\n                                ></i>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Go to troubleshooting</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                        <mat-divider></mat-divider>\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <span class=\"text-description\">Device Logs</span>\r\n                                <i class=\"icon info-icon rem1\" [matTooltip]=\"'Generate device logs and download them to your computer.'\"></i>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n    </div>\r\n\r\n  </div>\r\n  \r\n</div>"]}
168
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"device-manage-widget.component.js","sourceRoot":"","sources":["../../../../../../projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.ts","../../../../../../projects/tuki/widgets/user-device-manage/src/device-manage-widget.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild } from '@angular/core';\r\nimport { FormControl, FormControlName, FormGroup, Validators } from '@angular/forms';\r\nimport { SimplifiedUser } from './classes/simplified-user';\r\nimport { LineAssociation } from './classes/line-association';\r\nimport { LineAssociationInterface } from './classes/line-association-interface';\r\nimport { Device, DeviceViewType } from './classes/device';\r\nimport { finalize, forkJoin, Subject, takeUntil } from 'rxjs';\r\nimport { MatTabGroup } from '@angular/material/tabs';\r\nimport { MatDialog } from '@angular/material/dialog';\r\nimport { InfoDialogComponent } from './confirm-dialog/info-dialog.component';\r\nimport { UserService } from './services/user.service';\r\nimport { DeviceService } from './services/device.service';\r\nimport { APIService } from './services/api.service';\r\nimport { LineService } from './services/line.service';\r\nimport { SiteSettingsService } from './services/site-settings.service';\r\nimport { ValidationService } from './services/validation.service';\r\nimport { TOGGLE_TYPES } from './app.constants';\r\n\r\n@Component({\r\n  selector: 'app-device-manage-widget',\r\n  templateUrl: './device-manage-widget.component.html',\r\n  styleUrls: ['./device-manage-widget.component.scss'],\r\n})\r\nexport class DeviceManageWidgetComponent implements OnDestroy {\r\n  @Output() onSave = new EventEmitter<string>();\r\n  @Output() onChange = new EventEmitter<string>();\r\n  @Output() discardChanges = new EventEmitter();\r\n  @Output() goBack = new EventEmitter();\r\n  @Input() token!: string;\r\n  @Input() host!: string;\r\n  @Input() siteId!: number;\r\n  @Input() userId!: string;\r\n  @Input() isLdap!: boolean;\r\n  @Input() deviceName!: string;\r\n\r\n   @ViewChild('tagInput') tagInput!: ElementRef<HTMLInputElement>;\r\n\r\n  dataPending!: boolean;\r\n  private readonly destroy$ = new Subject<void>();\r\n  public device: any = null;\r\n  public tokenObj: any = null;\r\n\r\n  public readonly HOTELING_TIME_HOURS = Array.from({ length: 120 }, (_, index) => index);\r\n\r\n  // public readonly hotelingLimitTime = new FormControl(24);\r\n  public logMissedCall = new FormControl(true);\r\n\r\n  tags: string[] = [];\r\n  isAdding = false;\r\n  newTag = '';\r\n\r\n  get firstName(): string {\r\n    return this.userService.userName;\r\n  }\r\n\r\n  get lastName(): string {\r\n    return this.userService.userLastName;\r\n  }\r\n\r\n  get form(): FormGroup | undefined {\r\n    return this.userService.userDevice?.form;\r\n  }\r\n\r\n  get isWebex() {\r\n    return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID') !== 'null';\r\n  }\r\n\r\n  constructor(\r\n    public userService: UserService,\r\n    public deviceService: DeviceService,\r\n    private apiService: APIService,\r\n    public lineService: LineService,\r\n    public siteSettingsService: SiteSettingsService,\r\n    private validationService: ValidationService,\r\n    private dialog: MatDialog\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.apiService.token = this.token;\r\n    this.apiService.apiUrl = this.host;\r\n    console.log('this.apiService.apiUrl = ', this.apiService.apiUrl);\r\n    this.getData();\r\n  }\r\n\r\n  showInput() {\r\n    this.isAdding = true;\r\n\r\n    // wait until input appears in DOM\r\n    setTimeout(() => {\r\n      this.tagInput?.nativeElement.focus();\r\n    });\r\n  }\r\n\r\n  onBlur() {\r\n    const value = this.newTag.trim();\r\n\r\n    if (value) {\r\n      this.tags.push(value);\r\n    }\r\n\r\n    this.newTag = '';\r\n    this.isAdding = false;\r\n  }\r\n\r\n  removeTag(index: number) {\r\n    this.tags.splice(index, 1);\r\n  }\r\n\r\n  get hotelingEnabled(): FormControl {\r\n    return this.form?.get('hoteling')?.get('enabled') as FormControl;\r\n  }\r\n\r\n  get guestHoursLimit(): FormControl {\r\n    return this.form?.get('hoteling')?.get('guestHoursLimit') as FormControl;\r\n  }\r\n\r\n  private getData() {\r\n    this.dataPending = true;\r\n    let request;\r\n    const deviceType = localStorage.getItem('deviceType');\r\n    if(localStorage.getItem('isWebex') === 'true') {\r\n      // request\r\n      const customerId = localStorage.getItem('customerId');\r\n      const webexId = localStorage.getItem('webexUUID');\r\n      request = this.userService.fetchWebexUserDevice(customerId!, webexId!, deviceType!);\r\n    } else {\r\n      request = this.userService.fetchDIUserDevice(this.siteId, this.userId, deviceType!);\r\n    }\r\n    request\r\n    .pipe(takeUntil(this.destroy$))\r\n    .pipe(finalize(() => this.dataPending = false))\r\n    .subscribe((data: any) => {\r\n      this.device = data;\r\n    });\r\n  }\r\n\r\n  public onNumberChange(event: Event, index: number) {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n    this.device.lines[index].number = value;\r\n    this.onChange.emit();\r\n  }\r\n\r\n  public onExtensionChange(event: Event, index: number) {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n    this.device.lines[index].extension = value;\r\n    this.onChange.emit();\r\n  }\r\n\r\n  saveChanges(): void {\r\n    if (!this.userService.hasUnsavedChanges() || this.form?.invalid) {\r\n      return;\r\n    }\r\n\r\n    const updatedLines = this.device.lines.filter((line: any, index: any) => this.userService.lineUpdated(line, index));\r\n    updatedLines.forEach((line: any) => {\r\n      this.userService.editTranslationPattern(\r\n        this.userService.cucmId,\r\n        this.userService.getOriginalNumber(line),\r\n        line.number,\r\n        line.extension,\r\n        line.routePartitionName,\r\n        line.description || '',\r\n      ).subscribe(() => {\r\n          this.dataPending = false;\r\n          this.onSave.next(\"device's line has been saved successfully..\");\r\n          // subscription.unsubscribe();\r\n        }, () => this.dataPending = false);\r\n    })\r\n\r\n    this.dataPending = true;\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroy$.next();\r\n    this.destroy$.complete();\r\n  }\r\n\r\n  onGoBack(): void {\r\n    this.goBack.emit();\r\n  }\r\n}\r\n","\r\n\r\n<app-loader *ngIf=\"dataPending\"></app-loader>\r\n<div *ngIf=\"!dataPending\">\r\n  <!-- <div class=\"go-back-box\" (click)=\"onGoBack()\"> -->\r\n  <div class=\"go-back-box\">\r\n    <div class=\"go-back-box-container\">\r\n      <span class=\"app-icon icon-webex-left-arrow\"></span>\r\n      <span class=\"go-back-title\">Devices</span>\r\n    </div>\r\n  </div>\r\n\r\n  <app-device-info \r\n    [device]=\"device\" \r\n    [firstName]=\"firstName\" \r\n    [lastName]=\"lastName\"\r\n    (onclickBack)=\"onGoBack()\"\r\n    >\r\n    \r\n  </app-device-info>\r\n  <div class=\"device-info\">\r\n\r\n    <div class=\"device-info-part\">\r\n\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Details</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">{{ form?.get('maxLineCount')?.value || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">Lines</span>\r\n                    </div>\r\n                    <div class=\"side right-part\">\r\n                        <span class=\"main-value\">{{ (form?.get('macAddress')?.value | macAddress) || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">MAC address</span>\r\n                    </div>\r\n                </div>\r\n                <mat-divider></mat-divider>\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">{{ form?.get('ipAddress')?.value || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">Host IP address</span>\r\n                    </div>\r\n                    <div class=\"side right-part\">\r\n                        <span class=\"main-value\">{{ form?.get('remoteIpAddress')?.value || 'N/A' }}</span>\r\n                        <span class=\"extra-info\">Remote IP address</span>\r\n                    </div>\r\n                </div>\r\n                <mat-divider></mat-divider>\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">Cisco</span>\r\n                        <span class=\"extra-info\">Managed By</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Software</span>\r\n                <div class=\"icon-bordered-wrapper\">\r\n                    <i class=\"icon configure-icon rem1\"></i>\r\n                </div>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\">\r\n                    <div class=\"side left-part\">\r\n                        <span class=\"main-value\">{{ form?.get('softwareVersion')?.value || 'N/A'}}</span>\r\n                        <span class=\"extra-info\">Software Channel</span>\r\n                    </div>\r\n                    <div class=\"side right-part\">\r\n                        <span class=\"main-value\">{{ form?.get('softwareChannel')?.value || 'N/A'}}</span>\r\n                        <span class=\"extra-info\">Software version</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Tags</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\" style=\"flex-direction: column; gap: 1rem;\">\r\n                    <div class=\"tags-list-container\">\r\n                        <div *ngFor=\"let tag of tags; let i = index\" class=\"tag-label\">\r\n                            <span class=\"tag-desccription\">{{ tag }}</span>\r\n                            <i class=\"icon close-icon\" (click)=\"removeTag(i)\" style=\"width: 0.75rem; height: 0.75rem; flex: 0 0 auto;\"></i>\r\n                        </div>\r\n                    </div>\r\n                    <div class=\"tags-list-container\">\r\n                        <button class=\"tag-label add-tag\" (click)=\"showInput()\">\r\n                            <span class=\"icon plus-icon\" style=\"width: 0.75rem; height: 0.75rem;\"></span>\r\n                            <span>Add tag</span>\r\n                        </button>\r\n                        <input \r\n                            #tagInput\r\n                            id=\"enter-tag-input\" \r\n                            *ngIf=\"isAdding\"\r\n                            [(ngModel)]=\"newTag\"\r\n                            (blur)=\"onBlur()\"\r\n                            type=\"text\"\r\n                            class=\"add-tag-input\" \r\n                            placeholder=\"Enter tag...\"\r\n                        >\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n    </div>\r\n\r\n    <div class=\"device-info-part\">\r\n        <section class=\"card\">\r\n             <div class=\"header\">\r\n                <span class=\"title\">Issues & Information</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row\">\r\n                    <div class=\"description\">\r\n                        <i class=\"icon check-icon rem1\" style=\"filter: invert(26%) sepia(27%) saturate(1093%) hue-rotate(114deg) brightness(93%) contrast(90%);\"></i>\r\n                        <span class=\"text-description\">No reported issues at this time</span>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n             <div class=\"header\">\r\n                <span class=\"title\">Hoteling</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row flex-column gap-0_75\">\r\n                    <span class=\"text-description\">Allow this device to be used as a Hoteling Host by visiting guests.</span>\r\n                    <div class=\"toggle-wrapper\">\r\n                        <mat-slide-toggle class=\"custom-toggle\" name=\"logMissedCalls\" [formControl]=\"hotelingEnabled\"></mat-slide-toggle>\r\n                        <i class=\"icon info-icon rem1\" \r\n                            style=\"filter: invert(20%) sepia(99%) saturate(2065%) hue-rotate(197deg) brightness(92%) contrast(101%);\"\r\n                            [matTooltip]=\"'Enabling this device for Hoteling means that a guest (end user) can log into this host (workspace phone) and use this phone as if it were their own. This is useful when traveling to a remote office but still needing to place/receive calls with their telephone number and to access features normally available to them on their own office phone.'\"\r\n                        ></i>\r\n                    </div>\r\n                    <span class=\"text-description\">Limit the time a guest can use this phone to</span>\r\n                    <mat-select [formControl]=\"guestHoursLimit\">\r\n                        <mat-option *ngFor=\"let type of HOTELING_TIME_HOURS\" [value]=\"type\">\r\n                            {{type}}\r\n                        </mat-option>\r\n                    </mat-select>\r\n                </div>\r\n            </div>\r\n        </section>\r\n        <section class=\"card\">\r\n            <div class=\"header\">\r\n                <span class=\"title\">Device Management</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row flex-column gap-0_75\">\r\n                    <p class=\"text-description\">The users and workspaces that appear on this device are displayed below in the order of appearance.</p>\r\n                    <div class=\"flex-column\">\r\n                        <span class=\"text-description\">To add and remove users and workspaces, select <b>Configure Lines.</b></span>\r\n                        <span class=\"text-description\">To customize the programmable Line Keys, select <b>Configure Layout.</b></span>\r\n                        <span class=\"text-description\">To set up the display settings and dialing options, select <b>Device Settings</b>.</span>\r\n                    </div>\r\n                    <table style=\"border-collapse:collapse;\">\r\n                        <thead>\r\n                        <tr style=\"background:#ededed;\">\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Index #</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Name</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Number/Extension</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Appearances</th>\r\n                            <th style=\"padding:10px 16px; font-size:.75rem; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Registered</th>\r\n                        </tr>\r\n                        </thead>\r\n                        <tbody>\r\n                        <ng-container *ngIf=\"device?.lines && device?.lines.length\">\r\n                            <tr style=\"background:#fff; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='#fff'\"\r\n                            \r\n                            *ngFor=\"let line of device.lines; let i = index\">\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span style=\"display:inline-block; color:#000000f2; padding:4px 14px; font-size:.875rem; font-weight:400;\"></span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span style=\"display:inline-block; color:#000000f2; padding:4px 14px; font-size:.875rem; font-weight:400;\">{{line?.name}}</span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span\r\n                                        [attr.contenteditable]=\"!isWebex\"\r\n                                        (blur)=\"onNumberChange($event, i)\">\r\n                                        {{ line?.number || 'NA' }}\r\n                                    </span> /\r\n                                    <span\r\n                                        [attr.contenteditable]=\"!isWebex\"\r\n                                        (blur)=\"onExtensionChange($event, i)\">\r\n                                        {{ line?.extension }}\r\n                                    </span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <span style=\"display:inline-block; color:#000000f2; padding:4px 14px; font-size:.875rem; font-weight:400;\">1</span>\r\n                                </td>\r\n                                <td style=\"padding: .25rem 1.25rem .25rem .75rem;; border-bottom:1px solid #e8e8e8;\">\r\n                                    <i class=\"icon warning-icon rem1\" [matTooltip]=\"'Unregistered'\"></i>\r\n                                </td>\r\n                        </tr>\r\n                        </ng-container>\r\n                        \r\n                        </tbody>\r\n                    </table>\r\n                    <div class=\"totals\">\r\n                       <span class=\"text-description\">15 of 16 total lines available</span>\r\n                    </div>\r\n                    <div class=\"configure-lines\">\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <i class=\"icon configure-icon rem1-25\"></i>\r\n                                <span class=\"text-description\">Configure Lines</span>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                        <mat-divider></mat-divider>\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <i class=\"icon configure-icon rem1-25\"></i>\r\n                                <span class=\"text-description\">Configure Layout</span>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                        <mat-divider></mat-divider>\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <i class=\"icon configure-icon rem1-25\"></i>\r\n                                <span class=\"text-description\">Device Settings</span>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n\r\n        <section class=\"card\">\r\n             <div class=\"header\">\r\n                <span class=\"title\">Support</span>\r\n            </div>\r\n            <div class=\"main-content\">\r\n                <div class=\"detail-row flex-column gap-0_75\">\r\n                    <div class=\"configure-lines\">\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <span class=\"text-description\">Meetings & Calls</span>\r\n                                <span class=\"label new\">New</span>\r\n                                <i class=\"icon info-icon rem1\"\r\n                                    [matTooltip]=\"'Troubleshooting provides details about the device related to status, network activity, and call information.'\"\r\n                                ></i>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Go to troubleshooting</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                        <mat-divider></mat-divider>\r\n                        <div class=\"line\">\r\n                            <div>\r\n                                <span class=\"text-description\">Device Logs</span>\r\n                                <i class=\"icon info-icon rem1\" [matTooltip]=\"'Generate device logs and download them to your computer.'\"></i>\r\n                            </div>\r\n                            <div style=\"cursor: pointer\">\r\n                                <span class=\"text-description\" style=\"font-weight: 500;\">Manage</span>\r\n                                <i class=\"icon arrow-right-icon rem1-25\"></i>\r\n                            </div>\r\n                        </div>\r\n                    </div>\r\n                </div>\r\n            </div>\r\n        </section>\r\n    </div>\r\n\r\n  </div>\r\n  \r\n</div>"]}
@@ -7,7 +7,7 @@ export class UserCallingComponent {
7
7
  return this.userService?.user?.devices[0] && this.userService?.user?.devices[0].lineAssociations[0].form;
8
8
  }
9
9
  get isWebex() {
10
- return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID')?.length;
10
+ return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID') !== 'null';
11
11
  }
12
12
  get formControl() {
13
13
  const control = this.form?.get('directoryNumber');
@@ -86,4 +86,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
86
86
  }], onExtensionChange: [{
87
87
  type: Output
88
88
  }] } });
89
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-calling.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.ts","../../../../../../../projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { SimplifiedUser } from '../classes/simplified-user';\r\nimport { LineAssociation } from '../classes/line-association';\r\nimport { LineAssociationInterface } from '../classes/line-association-interface';\r\nimport { UserService } from '../services/user.service';\r\nimport { DnsService } from '../services/dns.service';\r\n\r\n@Component({\r\n  selector: 'app-user-calling',\r\n  templateUrl: './user-calling.component.html',\r\n  styleUrls: ['./user-calling.component.scss'],\r\n})\r\nexport class UserCallingComponent implements OnInit {\r\n  @Input() siteId!: number;\r\n  @Input() userId!: string;\r\n  @Output() onExtensionChange = new EventEmitter<any>();\r\n  public dataPending!: boolean;\r\n\r\n  get form(): FormGroup {\r\n    return this.userService?.user?.devices[0] && this.userService?.user?.devices[0].lineAssociations[0].form;\r\n  }\r\n\r\n  get isWebex() {\r\n    return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID')?.length;\r\n  }\r\n\r\n  get formControl(): FormControl {\r\n    const control = this.form?.get('directoryNumber') as FormControl;\r\n    return control;\r\n  }\r\n\r\n  get phoneNumberValue(): string {\r\n    // const control = this.form?.get('directoryNumber') as FormControl;\r\n    // return control;\r\n    return this.userService?.user?.devices[0] && this.userService?.user?.devices[0]?.lineAssociations[0]?.mappedDids[0];\r\n  }\r\n\r\n  get lineAssociation(): LineAssociation | LineAssociationInterface {\r\n    return this.userService?.user?.devices[0].lineAssociations[0];\r\n  }\r\n\r\n  get user(): SimplifiedUser {\r\n    return this.userService.user;\r\n  }\r\n\r\n\r\n  constructor(\r\n    public userService: UserService,\r\n    private dnsService: DnsService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // this.getData();\r\n  }\r\n\r\n  onExtensionLineChange(event: Event): void {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n    (this.userService?.user && this.userService?.user?.lines && this.userService?.user?.lines[0]?.mappedDids[0]) ? this.userService.user.lines[0].mappedDids[0] = value : void 0;\r\n    this.onExtensionChange.next(true);\r\n  }\r\n\r\n  onDirectoryNumberChange(event: Event): void {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n\r\n    if (this.lineAssociation && this.lineAssociation.directoryNumber) {\r\n      // @ts-ignore\r\n      this.userService.user.devices[0].lineAssociations[0].directoryNumber.directoryNumber = value;\r\n      this.onExtensionChange.next(true);\r\n    }\r\n  }\r\n\r\n  public onChangeField(token: string): void {\r\n    if (!token) {\r\n      return;\r\n    }\r\n    (this.userService.user as any)[token] = this.form?.get(token)?.value;\r\n\r\n  }\r\n\r\n  public toggleEditMode() {\r\n    this.userService.user.toggleEditMode();\r\n  }\r\n\r\n  public isSavingDisabled(): boolean {\r\n    return !this.userService.hasUnsavedChanges() || this.userService.hasExistedUserId;\r\n  }\r\n\r\n  public onChangeExtension(value: string): void {\r\n    if (this.lineAssociation && this.lineAssociation.directoryNumber) {\r\n      // @ts-ignore\r\n      this.userService.user.devices[0].lineAssociations[0].directoryNumber.directoryNumber = value;\r\n    }\r\n  }\r\n\r\n  private getData() {\r\n    this.dataPending = true;\r\n    this.dnsService.getNumberRange(String(this.siteId), this.userId)\r\n      .subscribe({\r\n        complete: (v: any) => {\r\n          this.dataPending = false;\r\n        },\r\n        error: (e: any) => this.dataPending = false,\r\n      });\r\n  }\r\n}\r\n","<!--    NUMBERS BOX -->\r\n<div style=\"display: flex; flex-direction: column; padding: 24px 0; gap: 24px;\">\r\n  <div class=\"user-info-box user-details-box\" style=\"display: flex;\">\r\n    <h3 class=\"user-box-title\" style=\"width: 180px;\">Numbers</h3>\r\n    <div style=\"flex:1; display:flex; flex-direction:column;\">\r\n      <!-- Directory numbers section -->\r\n      <div style=\"display:flex; align-items:flex-start; padding:16px 0;\">\r\n        <div style=\"min-width:170px; font-weight:400; font-size:14px; color:#121212; display:flex; align-items:center;\">\r\n          <span>Directory numbers</span>\r\n          <img style=\"margin-left: .5rem;\" src=\"assets/icons/info-circle-regular.svg\" width=\"16\" alt=\"\">\r\n        </div>\r\n        <div style=\"flex:1; display:flex; flex-direction:column; align-items:flex-start;\">\r\n          <!-- Table -->\r\n          <table style=\"width:100%; border-collapse:collapse; margin-bottom:16px;\">\r\n            <thead>\r\n              <tr style=\"background:#ededed;\">\r\n                <th style=\"padding:10px 16px; font-size:13px; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Type</th>\r\n                <th style=\"padding:10px 16px; font-size:13px; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Phone number</th>\r\n                <th style=\"padding:10px 16px; font-size:13px; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Extension</th>\r\n                <th style=\"padding:10px 8px; border-bottom:1px solid #e8e8e8; width:30px;\"></th>\r\n              </tr>\r\n            </thead>\r\n            <tbody>\r\n              <tr style=\"background:#fff; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='#fff'\">\r\n                <td style=\"padding:12px 16px; border-bottom:1px solid #e8e8e8;\">\r\n                  <span style=\"display:inline-block; background:#e8f4fc; color:#1170a8; padding:4px 14px; border-radius:14px; font-size:13px; font-weight:400; border:1px solid #b8d9ed;\">Primary</span>\r\n                </td>\r\n                <td style=\"padding:12px 16px; color:#333; font-size:14px; border-bottom:1px solid #e8e8e8;\">\r\n                  <span\r\n                    [attr.contenteditable]=\"!isWebex\"\r\n                    (blur)=\"onExtensionLineChange($event)\">\r\n                    {{ phoneNumberValue }}\r\n                  </span>\r\n                </td>\r\n                <td style=\"padding:12px 16px; color:#333; font-size:14px; border-bottom:1px solid #e8e8e8;\">\r\n                  <div>\r\n                    <span\r\n                      [attr.contenteditable]=\"!isWebex\"\r\n                      (blur)=\"onDirectoryNumberChange($event)\">\r\n                      {{ formControl.value }}\r\n                    </span>\r\n                    <img style=\"margin-left: .5rem;\" src=\"assets/icons/copy-regular.svg\" width=\"16\" alt=\"\">\r\n                  </div>\r\n                </td>\r\n                <td style=\"padding:19px 8px; text-align:center; border-bottom:1px solid #e8e8e8; display:flex; align-items:center; justify-content:center; line-height:0;\">\r\n                  <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style=\"width:16px; height:16px; color:#222222; transform:rotate(-90deg); transform-origin:center; display:block; margin:0;\" aria-hidden=\"true\">\r\n                    <path fill=\"currentColor\" d=\"M28.708 9.293a1 1 0 0 0-1.415 0L16 20.586 4.707 9.293a1 1 0 0 0-1.414 1.414l12 12a1 1 0 0 0 1.414 0l12-12a1 1 0 0 0 0-1.414\"/>\r\n                  </svg>\r\n                </td>\r\n              </tr>\r\n            </tbody>\r\n          </table>\r\n          <!-- Add secondary number button -->\r\n          <button style=\"background:#fff; border:1px solid #c4c4c4; padding:8px 20px; border-radius:18px; font-size:14px; font-weight:400; cursor:pointer; color:#333;\" onmouseover=\"this.style.background='#ededed'\" onmouseout=\"this.style.background='#fff'\">Add secondary number</button>\r\n        </div>\r\n      </div>\r\n\r\n      <div style=\"height:1px; background:#e8e8e8; margin:8px 0;\"></div>\r\n\r\n      <!-- Caller ID section -->\r\n      <div style=\"display:flex; align-items:center; padding:16px 0; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='transparent'\">\r\n        <div style=\"min-width:170px; font-weight:400; font-size:14px; color:#121212; display:flex; align-items:center;\">\r\n          <span>Caller ID</span>\r\n          <img style=\"margin-left: .5rem;\" src=\"assets/icons/info-circle-regular.svg\" width=\"16\" alt=\"\">\r\n        </div>\r\n        <div style=\"flex:1;\"></div>\r\n        <div style=\"padding-right:8px; display:flex; align-items:center;\">\r\n          <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style=\"width:16px; height:16px; color:#222222; transform:rotate(-90deg); transform-origin:center; display:block; margin:0;\" aria-hidden=\"true\">\r\n            <path fill=\"currentColor\" d=\"M28.708 9.293a1 1 0 0 0-1.415 0L16 20.586 4.707 9.293a1 1 0 0 0-1.414 1.414l12 12a1 1 0 0 0 1.414 0l12-12a1 1 0 0 0 0-1.414\"/>\r\n          </svg>\r\n        </div>\r\n      </div>\r\n      <div style=\"height:1px; background:#e8e8e8; margin:8px 0;\"></div>\r\n\r\n      <!-- Emergency callback number section -->\r\n      <div style=\"display:flex; align-items:flex-start; padding:16px 0; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='transparent'\">\r\n        <div style=\"min-width:170px; font-weight:400; font-size:14px; color:#121212; display:flex; align-items:flex-start;\">\r\n          <div>\r\n            <div style=\"display:flex; align-items:center;\">\r\n              <span>Emergency callback</span>\r\n            </div>\r\n            <div style=\"display:flex; align-items:center;\">\r\n              <span>number</span>\r\n              <img style=\"margin-left: .5rem;\" src=\"assets/icons/info-circle-regular.svg\" width=\"16\" alt=\"\">\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div style=\"flex:1; display:flex; align-items:flex-start; padding-top:2px;\">\r\n          <i class=\"fa fa-times-circle\" style=\"color:#c62828; margin-right:8px; margin-top: 2px; font-size:14px;\"></i>\r\n          <span style=\"color:#c62828; font-size:13px; line-height:1.4;\">All calls will be blocked if there's no ECBN, assign a phone number to this user or set the location default ECBN.</span>\r\n        </div>\r\n        <div style=\"padding-right:8px; display:flex; align-items:center;\">\r\n          <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style=\"width:16px; height:16px; color:#222222; transform:rotate(-90deg); transform-origin:center; display:block; margin:0;\" aria-hidden=\"true\">\r\n            <path fill=\"currentColor\" d=\"M28.708 9.293a1 1 0 0 0-1.415 0L16 20.586 4.707 9.293a1 1 0 0 0-1.414 1.414l12 12a1 1 0 0 0 1.414 0l12-12a1 1 0 0 0 0-1.414\"/>\r\n          </svg>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- user-calling-extension\r\n    *ngIf=\"formControl\"\r\n    [siteId]=\"this.siteId\"\r\n              [control]=\"formControl\"\r\n              [routePartition]=\"this.lineAssociation.directoryNumber.routePartitionName\"\r\n              [directoryNumber]=\"this.lineAssociation.directoryNumber.directoryNumber\"\r\n              (onChange)=\"onDirectoryNumberChange($event)\">\r\n            </app-user-calling-extension> -->\r\n"]}
89
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"user-calling.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.ts","../../../../../../../projects/tuki/widgets/user-manage/src/user-calling/user-calling.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { SimplifiedUser } from '../classes/simplified-user';\r\nimport { LineAssociation } from '../classes/line-association';\r\nimport { LineAssociationInterface } from '../classes/line-association-interface';\r\nimport { UserService } from '../services/user.service';\r\nimport { DnsService } from '../services/dns.service';\r\n\r\n@Component({\r\n  selector: 'app-user-calling',\r\n  templateUrl: './user-calling.component.html',\r\n  styleUrls: ['./user-calling.component.scss'],\r\n})\r\nexport class UserCallingComponent implements OnInit {\r\n  @Input() siteId!: number;\r\n  @Input() userId!: string;\r\n  @Output() onExtensionChange = new EventEmitter<any>();\r\n  public dataPending!: boolean;\r\n\r\n  get form(): FormGroup {\r\n    return this.userService?.user?.devices[0] && this.userService?.user?.devices[0].lineAssociations[0].form;\r\n  }\r\n\r\n  get isWebex() {\r\n    return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID') !== 'null';\r\n  }\r\n\r\n  get formControl(): FormControl {\r\n    const control = this.form?.get('directoryNumber') as FormControl;\r\n    return control;\r\n  }\r\n\r\n  get phoneNumberValue(): string {\r\n    // const control = this.form?.get('directoryNumber') as FormControl;\r\n    // return control;\r\n    return this.userService?.user?.devices[0] && this.userService?.user?.devices[0]?.lineAssociations[0]?.mappedDids[0];\r\n  }\r\n\r\n  get lineAssociation(): LineAssociation | LineAssociationInterface {\r\n    return this.userService?.user?.devices[0].lineAssociations[0];\r\n  }\r\n\r\n  get user(): SimplifiedUser {\r\n    return this.userService.user;\r\n  }\r\n\r\n\r\n  constructor(\r\n    public userService: UserService,\r\n    private dnsService: DnsService\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    // this.getData();\r\n  }\r\n\r\n  onExtensionLineChange(event: Event): void {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n    (this.userService?.user && this.userService?.user?.lines && this.userService?.user?.lines[0]?.mappedDids[0]) ? this.userService.user.lines[0].mappedDids[0] = value : void 0;\r\n    this.onExtensionChange.next(true);\r\n  }\r\n\r\n  onDirectoryNumberChange(event: Event): void {\r\n    const value = (event.target as HTMLElement).innerText.trim();\r\n\r\n    if (this.lineAssociation && this.lineAssociation.directoryNumber) {\r\n      // @ts-ignore\r\n      this.userService.user.devices[0].lineAssociations[0].directoryNumber.directoryNumber = value;\r\n      this.onExtensionChange.next(true);\r\n    }\r\n  }\r\n\r\n  public onChangeField(token: string): void {\r\n    if (!token) {\r\n      return;\r\n    }\r\n    (this.userService.user as any)[token] = this.form?.get(token)?.value;\r\n\r\n  }\r\n\r\n  public toggleEditMode() {\r\n    this.userService.user.toggleEditMode();\r\n  }\r\n\r\n  public isSavingDisabled(): boolean {\r\n    return !this.userService.hasUnsavedChanges() || this.userService.hasExistedUserId;\r\n  }\r\n\r\n  public onChangeExtension(value: string): void {\r\n    if (this.lineAssociation && this.lineAssociation.directoryNumber) {\r\n      // @ts-ignore\r\n      this.userService.user.devices[0].lineAssociations[0].directoryNumber.directoryNumber = value;\r\n    }\r\n  }\r\n\r\n  private getData() {\r\n    this.dataPending = true;\r\n    this.dnsService.getNumberRange(String(this.siteId), this.userId)\r\n      .subscribe({\r\n        complete: (v: any) => {\r\n          this.dataPending = false;\r\n        },\r\n        error: (e: any) => this.dataPending = false,\r\n      });\r\n  }\r\n}\r\n","<!--    NUMBERS BOX -->\r\n<div style=\"display: flex; flex-direction: column; padding: 24px 0; gap: 24px;\">\r\n  <div class=\"user-info-box user-details-box\" style=\"display: flex;\">\r\n    <h3 class=\"user-box-title\" style=\"width: 180px;\">Numbers</h3>\r\n    <div style=\"flex:1; display:flex; flex-direction:column;\">\r\n      <!-- Directory numbers section -->\r\n      <div style=\"display:flex; align-items:flex-start; padding:16px 0;\">\r\n        <div style=\"min-width:170px; font-weight:400; font-size:14px; color:#121212; display:flex; align-items:center;\">\r\n          <span>Directory numbers</span>\r\n          <img style=\"margin-left: .5rem;\" src=\"assets/icons/info-circle-regular.svg\" width=\"16\" alt=\"\">\r\n        </div>\r\n        <div style=\"flex:1; display:flex; flex-direction:column; align-items:flex-start;\">\r\n          <!-- Table -->\r\n          <table style=\"width:100%; border-collapse:collapse; margin-bottom:16px;\">\r\n            <thead>\r\n              <tr style=\"background:#ededed;\">\r\n                <th style=\"padding:10px 16px; font-size:13px; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Type</th>\r\n                <th style=\"padding:10px 16px; font-size:13px; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Phone number</th>\r\n                <th style=\"padding:10px 16px; font-size:13px; font-weight:400; color:#545454; text-align:left; border-bottom:1px solid #e8e8e8;\">Extension</th>\r\n                <th style=\"padding:10px 8px; border-bottom:1px solid #e8e8e8; width:30px;\"></th>\r\n              </tr>\r\n            </thead>\r\n            <tbody>\r\n              <tr style=\"background:#fff; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='#fff'\">\r\n                <td style=\"padding:12px 16px; border-bottom:1px solid #e8e8e8;\">\r\n                  <span style=\"display:inline-block; background:#e8f4fc; color:#1170a8; padding:4px 14px; border-radius:14px; font-size:13px; font-weight:400; border:1px solid #b8d9ed;\">Primary</span>\r\n                </td>\r\n                <td style=\"padding:12px 16px; color:#333; font-size:14px; border-bottom:1px solid #e8e8e8;\">\r\n                  <span\r\n                    [attr.contenteditable]=\"!isWebex\"\r\n                    (blur)=\"onExtensionLineChange($event)\">\r\n                    {{ phoneNumberValue }}\r\n                  </span>\r\n                </td>\r\n                <td style=\"padding:12px 16px; color:#333; font-size:14px; border-bottom:1px solid #e8e8e8;\">\r\n                  <div>\r\n                    <span\r\n                      [attr.contenteditable]=\"!isWebex\"\r\n                      (blur)=\"onDirectoryNumberChange($event)\">\r\n                      {{ formControl.value }}\r\n                    </span>\r\n                    <img style=\"margin-left: .5rem;\" src=\"assets/icons/copy-regular.svg\" width=\"16\" alt=\"\">\r\n                  </div>\r\n                </td>\r\n                <td style=\"padding:19px 8px; text-align:center; border-bottom:1px solid #e8e8e8; display:flex; align-items:center; justify-content:center; line-height:0;\">\r\n                  <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style=\"width:16px; height:16px; color:#222222; transform:rotate(-90deg); transform-origin:center; display:block; margin:0;\" aria-hidden=\"true\">\r\n                    <path fill=\"currentColor\" d=\"M28.708 9.293a1 1 0 0 0-1.415 0L16 20.586 4.707 9.293a1 1 0 0 0-1.414 1.414l12 12a1 1 0 0 0 1.414 0l12-12a1 1 0 0 0 0-1.414\"/>\r\n                  </svg>\r\n                </td>\r\n              </tr>\r\n            </tbody>\r\n          </table>\r\n          <!-- Add secondary number button -->\r\n          <button style=\"background:#fff; border:1px solid #c4c4c4; padding:8px 20px; border-radius:18px; font-size:14px; font-weight:400; cursor:pointer; color:#333;\" onmouseover=\"this.style.background='#ededed'\" onmouseout=\"this.style.background='#fff'\">Add secondary number</button>\r\n        </div>\r\n      </div>\r\n\r\n      <div style=\"height:1px; background:#e8e8e8; margin:8px 0;\"></div>\r\n\r\n      <!-- Caller ID section -->\r\n      <div style=\"display:flex; align-items:center; padding:16px 0; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='transparent'\">\r\n        <div style=\"min-width:170px; font-weight:400; font-size:14px; color:#121212; display:flex; align-items:center;\">\r\n          <span>Caller ID</span>\r\n          <img style=\"margin-left: .5rem;\" src=\"assets/icons/info-circle-regular.svg\" width=\"16\" alt=\"\">\r\n        </div>\r\n        <div style=\"flex:1;\"></div>\r\n        <div style=\"padding-right:8px; display:flex; align-items:center;\">\r\n          <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style=\"width:16px; height:16px; color:#222222; transform:rotate(-90deg); transform-origin:center; display:block; margin:0;\" aria-hidden=\"true\">\r\n            <path fill=\"currentColor\" d=\"M28.708 9.293a1 1 0 0 0-1.415 0L16 20.586 4.707 9.293a1 1 0 0 0-1.414 1.414l12 12a1 1 0 0 0 1.414 0l12-12a1 1 0 0 0 0-1.414\"/>\r\n          </svg>\r\n        </div>\r\n      </div>\r\n      <div style=\"height:1px; background:#e8e8e8; margin:8px 0;\"></div>\r\n\r\n      <!-- Emergency callback number section -->\r\n      <div style=\"display:flex; align-items:flex-start; padding:16px 0; cursor:pointer;\" onmouseover=\"this.style.background='#fafafa'\" onmouseout=\"this.style.background='transparent'\">\r\n        <div style=\"min-width:170px; font-weight:400; font-size:14px; color:#121212; display:flex; align-items:flex-start;\">\r\n          <div>\r\n            <div style=\"display:flex; align-items:center;\">\r\n              <span>Emergency callback</span>\r\n            </div>\r\n            <div style=\"display:flex; align-items:center;\">\r\n              <span>number</span>\r\n              <img style=\"margin-left: .5rem;\" src=\"assets/icons/info-circle-regular.svg\" width=\"16\" alt=\"\">\r\n            </div>\r\n          </div>\r\n        </div>\r\n        <div style=\"flex:1; display:flex; align-items:flex-start; padding-top:2px;\">\r\n          <i class=\"fa fa-times-circle\" style=\"color:#c62828; margin-right:8px; margin-top: 2px; font-size:14px;\"></i>\r\n          <span style=\"color:#c62828; font-size:13px; line-height:1.4;\">All calls will be blocked if there's no ECBN, assign a phone number to this user or set the location default ECBN.</span>\r\n        </div>\r\n        <div style=\"padding-right:8px; display:flex; align-items:center;\">\r\n          <svg xmlns=\"http://www.w3.org/2000/svg\" viewBox=\"0 0 32 32\" style=\"width:16px; height:16px; color:#222222; transform:rotate(-90deg); transform-origin:center; display:block; margin:0;\" aria-hidden=\"true\">\r\n            <path fill=\"currentColor\" d=\"M28.708 9.293a1 1 0 0 0-1.415 0L16 20.586 4.707 9.293a1 1 0 0 0-1.414 1.414l12 12a1 1 0 0 0 1.414 0l12-12a1 1 0 0 0 0-1.414\"/>\r\n          </svg>\r\n        </div>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<!-- user-calling-extension\r\n    *ngIf=\"formControl\"\r\n    [siteId]=\"this.siteId\"\r\n              [control]=\"formControl\"\r\n              [routePartition]=\"this.lineAssociation.directoryNumber.routePartitionName\"\r\n              [directoryNumber]=\"this.lineAssociation.directoryNumber.directoryNumber\"\r\n              (onChange)=\"onDirectoryNumberChange($event)\">\r\n            </app-user-calling-extension> -->\r\n"]}
@@ -2909,8 +2909,7 @@ class DeviceManageWidgetComponent {
2909
2909
  return (_a = this.userService.userDevice) === null || _a === void 0 ? void 0 : _a.form;
2910
2910
  }
2911
2911
  get isWebex() {
2912
- var _a;
2913
- return localStorage.getItem('webexUUID') && ((_a = localStorage.getItem('webexUUID')) === null || _a === void 0 ? void 0 : _a.length);
2912
+ return localStorage.getItem('webexUUID') && localStorage.getItem('webexUUID') !== 'null';
2914
2913
  }
2915
2914
  constructor(userService, deviceService, apiService, lineService, siteSettingsService, validationService, dialog) {
2916
2915
  this.userService = userService;