@tuki-io/tuki-widgets 0.0.165 → 0.0.167
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.
- package/esm2020/contact-center/cc-readiness/cc-readiness.module.mjs +1 -1
- package/esm2020/contact-center/cc-readiness/cc-readiness.service.mjs +1 -1
- package/esm2020/contact-center/cc-readiness/widgets/licences-requirement/licences-requirement.component.mjs +3 -3
- package/esm2020/di2mt/shared/services/api.service.mjs +2 -2
- package/esm2020/di2mt/widgets/site-upgrade/progress-bar/progress-bar.component.mjs +3 -3
- package/esm2020/di2mt/widgets/site-upgrade/site-upgrade-data-table/site-upgrade-data-table.component.mjs +2 -2
- package/esm2020/di2mt/widgets/upgrade-overview/cards/pending-activation-users/pending-activation-users.component.mjs +17 -17
- package/esm2020/user-creation/src/app.constants.mjs +1 -1
- package/esm2020/user-creation/src/classes/site.mjs +1 -1
- package/esm2020/user-creation/src/shared/api/api.service.mjs +2 -2
- package/esm2020/user-creation/src/shared/services/user-creation-api.service.mjs +1 -1
- package/esm2020/user-creation/src/shared/services/utils.mjs +1 -1
- package/esm2020/user-creation/src/widgets/user-creation-wizard/user-creation-wizard.component.mjs +3 -3
- package/esm2020/user-device-manage/src/app.constants.mjs +1 -1
- package/esm2020/user-device-manage/src/classes/deviceProfile.mjs +1 -1
- package/esm2020/user-device-manage/src/device-associated-line/device-associated-line-extension/device-associated-line-extension.component.mjs +3 -3
- package/esm2020/user-device-manage/src/device-info/device-info.component.mjs +3 -3
- package/esm2020/user-device-manage/src/device-manage-widget.component.mjs +2 -2
- package/esm2020/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.mjs +3 -3
- package/esm2020/user-device-manage/src/pipes/mac-address.pipe.mjs +1 -1
- package/esm2020/user-device-manage/src/services/api.service.mjs +1 -1
- package/esm2020/user-device-manage/src/services/dns.service.mjs +1 -1
- package/esm2020/user-device-manage/src/services/line.service.mjs +2 -2
- package/esm2020/user-device-manage/src/services/user.service.mjs +1 -1
- package/esm2020/user-device-manage/src/shared/tk-page-section/page-section.component.mjs +1 -1
- package/esm2020/user-device-manage/src/utils/app-loader/app-loader.mjs +3 -3
- package/esm2020/user-manage/src/app.constants.mjs +1 -1
- package/esm2020/user-manage/src/classes/line-association-interface.mjs +1 -1
- package/esm2020/user-manage/src/classes/line-directory.mjs +1 -1
- package/esm2020/user-manage/src/classes/line.mjs +1 -1
- package/esm2020/user-manage/src/classes/pagination.mjs +1 -1
- package/esm2020/user-manage/src/classes/simplified-user.mjs +1 -1
- package/esm2020/user-manage/src/device-list/device-list.component.mjs +3 -3
- package/esm2020/user-manage/src/device-list/device-row/device-row.component.mjs +3 -3
- package/esm2020/user-manage/src/lazy-loading-select/lazy-loading-select.component.mjs +3 -3
- package/esm2020/user-manage/src/services/api.service.mjs +1 -1
- package/esm2020/user-manage/src/services/user.service.mjs +1 -1
- package/esm2020/user-manage/src/user-info/user-info.component.mjs +3 -3
- package/esm2020/user-manage/src/user-manage.module.mjs +1 -1
- package/esm2020/user-manage/src/utils/app-loader/app-loader.mjs +3 -3
- package/esm2020/users-list/src/app.constants.mjs +1 -1
- package/esm2020/users-list/src/classes/move-user.mjs +1 -1
- package/esm2020/users-list/src/services/dns.service.mjs +1 -1
- package/esm2020/users-list/src/services/user.service.mjs +1 -1
- package/esm2020/users-list/src/utils/app-loader/app-loader.mjs +3 -3
- package/fesm2015/tuki-io-tuki-widgets-contact-center.mjs +2 -2
- package/fesm2015/tuki-io-tuki-widgets-contact-center.mjs.map +1 -1
- package/fesm2015/tuki-io-tuki-widgets-di2mt.mjs +21 -21
- package/fesm2015/tuki-io-tuki-widgets-di2mt.mjs.map +1 -1
- package/fesm2015/tuki-io-tuki-widgets-user-creation.mjs +3 -3
- package/fesm2015/tuki-io-tuki-widgets-user-creation.mjs.map +1 -1
- package/fesm2015/tuki-io-tuki-widgets-user-device-manage.mjs +10 -10
- package/fesm2015/tuki-io-tuki-widgets-user-device-manage.mjs.map +1 -1
- package/fesm2015/tuki-io-tuki-widgets-user-manage.mjs +10 -10
- package/fesm2015/tuki-io-tuki-widgets-user-manage.mjs.map +1 -1
- package/fesm2015/tuki-io-tuki-widgets-users-list.mjs +2 -2
- package/fesm2015/tuki-io-tuki-widgets-users-list.mjs.map +1 -1
- package/fesm2020/tuki-io-tuki-widgets-contact-center.mjs +2 -2
- package/fesm2020/tuki-io-tuki-widgets-contact-center.mjs.map +1 -1
- package/fesm2020/tuki-io-tuki-widgets-di2mt.mjs +21 -21
- package/fesm2020/tuki-io-tuki-widgets-di2mt.mjs.map +1 -1
- package/fesm2020/tuki-io-tuki-widgets-user-creation.mjs +3 -3
- package/fesm2020/tuki-io-tuki-widgets-user-creation.mjs.map +1 -1
- package/fesm2020/tuki-io-tuki-widgets-user-device-manage.mjs +10 -10
- package/fesm2020/tuki-io-tuki-widgets-user-device-manage.mjs.map +1 -1
- package/fesm2020/tuki-io-tuki-widgets-user-manage.mjs +10 -10
- package/fesm2020/tuki-io-tuki-widgets-user-manage.mjs.map +1 -1
- package/fesm2020/tuki-io-tuki-widgets-users-list.mjs +2 -2
- package/fesm2020/tuki-io-tuki-widgets-users-list.mjs.map +1 -1
- package/package.json +1 -1
- package/user-device-manage/src/services/line.service.d.ts +1 -1
|
@@ -122,7 +122,7 @@ export class DeviceManageWidgetComponent {
|
|
|
122
122
|
// const value = (event.target as HTMLElement).innerText.trim();
|
|
123
123
|
const extension = this.dnsService.getDnValue(value);
|
|
124
124
|
const number = this.dnsService.getMappedDids(extension, '0');
|
|
125
|
-
this.device.lines[index].extension =
|
|
125
|
+
this.device.lines[index].extension = extension;
|
|
126
126
|
this.device.lines[index].number = number || '';
|
|
127
127
|
this.linesControls.at(index).setValue(extension);
|
|
128
128
|
this.onChange.emit();
|
|
@@ -175,4 +175,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
175
175
|
type: ViewChild,
|
|
176
176
|
args: ['tagInput']
|
|
177
177
|
}] } });
|
|
178
|
-
//# 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 { FormArray, 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\nimport { DnsService } from './services/dns.service';\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  linesControls = new FormArray<FormControl<string>>([]);\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    private readonly dnsService: DnsService,\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    // const deviceType = this.deviceName;\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      this.initFormData(this.device);\r\n    });\r\n  }\r\n\r\n  initFormData(device: any) {\r\n\r\n    this.linesControls = new FormArray(\r\n      this.device.lines.map((line: any) =>\r\n        new FormControl(String(line.extension) || '')\r\n      )\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(value: string, index: number) {\r\n    // const value = (event.target as HTMLElement).innerText.trim();\r\n    const extension = this.dnsService.getDnValue(value);\r\n    const number = this.dnsService.getMappedDids(extension, '0');\r\n    this.device.lines[index].extension = value;\r\n    this.device.lines[index].number = number || '';\r\n    this.linesControls.at(index).setValue(extension);\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) => this.userService.saveNewLine(line));\r\n\r\n    this.dataPending = true;\r\n    setTimeout(() => {\r\n      this.dataPending = false;\r\n    }, 20000);\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                                    <div style=\"display: flex; align-items: center;\">\r\n                                        <div style=\"width: 120px;\"\r\n                                            [attr.contenteditable]=\"!isWebex\"\r\n                                            (blur)=\"onNumberChange($event, i)\">\r\n                                            {{ line?.number || 'NA' }}\r\n                                        </div> \r\n                                        <span> &nbsp;/&nbsp; </span>\r\n                                        <!-- <span\r\n                                            [attr.contenteditable]=\"!isWebex\"\r\n                                            (blur)=\"onExtensionChange($event, i)\">\r\n                                            {{ line?.extension }}\r\n                                        </span> -->\r\n                                        <app-device-associated-line-extension\r\n                                                [control]=\"linesControls.at(i)\"\r\n                                                [routePartition]=\"line.routePartitionName\"\r\n                                                [directoryNumber]=\"line.directoryNumber\"\r\n                                                [siteId]=\"siteId\"\r\n                                                (onChange)=\"onExtensionChange($event, i)\">\r\n                                            </app-device-associated-line-extension>\r\n                                    </div>\r\n                                    \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>"]}
|
|
178
|
+
//# 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 { FormArray, 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\nimport { DnsService } from './services/dns.service';\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  linesControls = new FormArray<FormControl<string>>([]);\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    private readonly dnsService: DnsService,\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    // const deviceType = this.deviceName;\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      this.initFormData(this.device);\r\n    });\r\n  }\r\n\r\n  initFormData(device: any) {\r\n\r\n    this.linesControls = new FormArray(\r\n      this.device.lines.map((line: any) =>\r\n        new FormControl(String(line.extension) || '')\r\n      )\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(value: string, index: number) {\r\n    // const value = (event.target as HTMLElement).innerText.trim();\r\n    const extension = this.dnsService.getDnValue(value);\r\n    const number = this.dnsService.getMappedDids(extension, '0');\r\n    this.device.lines[index].extension = extension;\r\n    this.device.lines[index].number = number || '';\r\n    this.linesControls.at(index).setValue(extension);\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) => this.userService.saveNewLine(line));\r\n\r\n    this.dataPending = true;\r\n    setTimeout(() => {\r\n      this.dataPending = false;\r\n    }, 20000);\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                                    <div style=\"display: flex; align-items: center;\">\r\n                                        <div style=\"width: 120px;\"\r\n                                            [attr.contenteditable]=\"!isWebex\"\r\n                                            (blur)=\"onNumberChange($event, i)\">\r\n                                            {{ line?.number || 'NA' }}\r\n                                        </div> \r\n                                        <span> &nbsp;/&nbsp; </span>\r\n                                        <!-- <span\r\n                                            [attr.contenteditable]=\"!isWebex\"\r\n                                            (blur)=\"onExtensionChange($event, i)\">\r\n                                            {{ line?.extension }}\r\n                                        </span> -->\r\n                                        <app-device-associated-line-extension\r\n                                                [control]=\"linesControls.at(i)\"\r\n                                                [routePartition]=\"line.routePartitionName\"\r\n                                                [directoryNumber]=\"line.directoryNumber\"\r\n                                                [siteId]=\"siteId\"\r\n                                                (onChange)=\"onExtensionChange($event, i)\">\r\n                                            </app-device-associated-line-extension>\r\n                                    </div>\r\n                                    \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>"]}
|
package/esm2020/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.mjs
CHANGED
|
@@ -42,10 +42,10 @@ export class LazyLoadingSelectComponent {
|
|
|
42
42
|
}
|
|
43
43
|
}
|
|
44
44
|
LazyLoadingSelectComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: LazyLoadingSelectComponent, deps: [{ token: i1.NotificationService }, { token: i2.SiteSettingsService }], target: i0.ɵɵFactoryTarget.Component });
|
|
45
|
-
LazyLoadingSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: LazyLoadingSelectComponent, selector: "app-lazy-loading-select", inputs: { siteId: "siteId", form: "form", standalone: "standalone", placeholder: "placeholder", controlName: "controlName", optionsToken: "optionsToken", appearance: "appearance", errorCode: "errorCode", errorText: "errorText", default: "default", id: "id" }, outputs: { changeField: "changeField" }, ngImport: i0, template: "<ng-container *ngIf=\"standalone\">\n <mat-form-field appearance=\"outline\">\n <mat-select [formControl]=\"formControl\"\n (openedChange)=\"getOptions()\"\n [placeholder]=\"placeholder\"\n (selectionChange)=\"onFieldChange(controlName)\"\n [id]=\"id\">\n <mat-option>\n <div class=\"select-search-wrapper\">\n <input\n type=\"text\"\n placeholder=\"Search\"\n class=\"select-search-input\"\n (click)=\"$event.stopPropagation()\"\n (keydown)=\"$event.stopPropagation()\"\n >\n <span class=\"search-icon-inside\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 32 32\">\n <path d=\"M13 2.25C7.063 2.25 2.25 7.063 2.25 13S7.063 23.75 13 23.75c2.699 0 5.165-.994 7.053-2.637l8.417 8.417a.75.75 0 1 0 1.06-1.06l-8.417-8.417A10.7 10.7 0 0 0 23.75 13c0-5.937-4.813-10.75-10.75-10.75M3.75 13a9.25 9.25 0 1 1 18.5 0 9.25 9.25 0 0 1-18.5 0\" fill=\"#000\"/>\n </svg>\n </span>\n </div>\n </mat-option>\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\n {{type}}\n </mat-option>\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"70\"\n strokeWidth=\"3\"\n mode=\"indeterminate\"\n *ngIf=\"optionsPending\"></mat-progress-spinner>\n </mat-select>\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\n <i class=\"fa fa-exclamation-triangle\"></i>\n {{errorText}}\n </mat-error>\n </mat-form-field>\n</ng-container>\n\n<!--\nThis duplication is caused by the following bug: https://github.com/angular/components/issues/9411\nWhich doesn't allow projection in mat-form-field\n-->\n\n<ng-container *ngIf=\"!standalone\">\n <mat-select *ngIf=\"form.get(controlName)\"\n [formControl]=\"formControl\"\n (openedChange)=\"getOptions()\"\n [placeholder]=\"placeholder\"\n (selectionChange)=\"onFieldChange(controlName)\"\n [id]=\"id\"\n >\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\n {{type}}\n </mat-option>\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"20\"\n mode=\"indeterminate\"\n *ngIf=\"optionsPending\"></mat-progress-spinner>\n </mat-select>\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\n <i class=\"fa fa-exclamation-triangle\"></i>\n {{errorText}}\n </mat-error>\n</ng-container>\n", styles: ["mat-form-field{width:300px;max-width:300px}::ng-deep .mat-option{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:block!important;line-height:48px!important;height:48px!important;padding:0 10px!important;text-align:left!important;text-decoration:none!important;position:relative!important;cursor:pointer!important;outline:none!important;display:flex!important;flex-direction:row!important;max-width:100%!important;box-sizing:border-box!important;align-items:center!important;-webkit-tap-highlight-color:rgba(0,0,0,0)!important}.select-search-wrapper{position:relative;width:100%}.search-icon-inside{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;display:flex;align-items:center}:host{height:35px;width:93%!important;max-width:93%!important;min-width:0!important;height:auto!important;box-sizing:border-box}:host ::ng-deep mat-form-field{width:100%;max-width:100%;height:35px}:host ::ng-deep mat-form-field .mat-form-field-flex .mat-form-field-outline .mat-form-field-outline-start{border:none!important}.select-search-input{width:100%;box-sizing:border-box;padding:7px 14px 7px 38px;margin:10px 0;border:3px solid #ccc;border-radius:.5rem;outline:none;font-size:14px;transition:border-color .2s}.select-search-input:focus{border-color:#1170cf}.field-spinner{margin-top:-30px}::ng-deep .mat-select-arrow{display:none}::ng-deep .mat-select-trigger{background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2232%22 height%3D%2232%22 viewBox%3D%220 0 32 32%22%3E%3Cpath d%3D%22M28.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%22%2F%3E%3C%2Fsvg%3E\") no-repeat right 12px center;background-size:16px;padding-right:32px}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i6.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i7.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }] });
|
|
45
|
+
LazyLoadingSelectComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: LazyLoadingSelectComponent, selector: "app-lazy-loading-select", inputs: { siteId: "siteId", form: "form", standalone: "standalone", placeholder: "placeholder", controlName: "controlName", optionsToken: "optionsToken", appearance: "appearance", errorCode: "errorCode", errorText: "errorText", default: "default", id: "id" }, outputs: { changeField: "changeField" }, ngImport: i0, template: "<ng-container *ngIf=\"standalone\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-select [formControl]=\"formControl\"\r\n (openedChange)=\"getOptions()\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onFieldChange(controlName)\"\r\n [id]=\"id\">\r\n <mat-option>\r\n <div class=\"select-search-wrapper\">\r\n <input\r\n type=\"text\"\r\n placeholder=\"Search\"\r\n class=\"select-search-input\"\r\n (click)=\"$event.stopPropagation()\"\r\n (keydown)=\"$event.stopPropagation()\"\r\n >\r\n <span class=\"search-icon-inside\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 32 32\">\r\n <path d=\"M13 2.25C7.063 2.25 2.25 7.063 2.25 13S7.063 23.75 13 23.75c2.699 0 5.165-.994 7.053-2.637l8.417 8.417a.75.75 0 1 0 1.06-1.06l-8.417-8.417A10.7 10.7 0 0 0 23.75 13c0-5.937-4.813-10.75-10.75-10.75M3.75 13a9.25 9.25 0 1 1 18.5 0 9.25 9.25 0 0 1-18.5 0\" fill=\"#000\"/>\r\n </svg>\r\n </span>\r\n </div>\r\n </mat-option>\r\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\r\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\r\n {{type}}\r\n </mat-option>\r\n <mat-progress-spinner class=\"field-spinner\"\r\n [diameter]=\"70\"\r\n strokeWidth=\"3\"\r\n mode=\"indeterminate\"\r\n *ngIf=\"optionsPending\"></mat-progress-spinner>\r\n </mat-select>\r\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\r\n <i class=\"fa fa-exclamation-triangle\"></i>\r\n {{errorText}}\r\n </mat-error>\r\n </mat-form-field>\r\n</ng-container>\r\n\r\n<!--\r\nThis duplication is caused by the following bug: https://github.com/angular/components/issues/9411\r\nWhich doesn't allow projection in mat-form-field\r\n-->\r\n\r\n<ng-container *ngIf=\"!standalone\">\r\n <mat-select *ngIf=\"form.get(controlName)\"\r\n [formControl]=\"formControl\"\r\n (openedChange)=\"getOptions()\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onFieldChange(controlName)\"\r\n [id]=\"id\"\r\n >\r\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\r\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\r\n {{type}}\r\n </mat-option>\r\n <mat-progress-spinner class=\"field-spinner\"\r\n [diameter]=\"20\"\r\n mode=\"indeterminate\"\r\n *ngIf=\"optionsPending\"></mat-progress-spinner>\r\n </mat-select>\r\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\r\n <i class=\"fa fa-exclamation-triangle\"></i>\r\n {{errorText}}\r\n </mat-error>\r\n</ng-container>\r\n", styles: ["mat-form-field{width:300px;max-width:300px}::ng-deep .mat-option{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:block!important;line-height:48px!important;height:48px!important;padding:0 10px!important;text-align:left!important;text-decoration:none!important;position:relative!important;cursor:pointer!important;outline:none!important;display:flex!important;flex-direction:row!important;max-width:100%!important;box-sizing:border-box!important;align-items:center!important;-webkit-tap-highlight-color:rgba(0,0,0,0)!important}.select-search-wrapper{position:relative;width:100%}.search-icon-inside{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;display:flex;align-items:center}:host{height:35px;width:93%!important;max-width:93%!important;min-width:0!important;height:auto!important;box-sizing:border-box}:host ::ng-deep mat-form-field{width:100%;max-width:100%;height:35px}:host ::ng-deep mat-form-field .mat-form-field-flex .mat-form-field-outline .mat-form-field-outline-start{border:none!important}.select-search-input{width:100%;box-sizing:border-box;padding:7px 14px 7px 38px;margin:10px 0;border:3px solid #ccc;border-radius:.5rem;outline:none;font-size:14px;transition:border-color .2s}.select-search-input:focus{border-color:#1170cf}.field-spinner{margin-top:-30px}::ng-deep .mat-select-arrow{display:none}::ng-deep .mat-select-trigger{background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2232%22 height%3D%2232%22 viewBox%3D%220 0 32 32%22%3E%3Cpath d%3D%22M28.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%22%2F%3E%3C%2Fsvg%3E\") no-repeat right 12px center;background-size:16px;padding-right:32px}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i4.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "component", type: i5.MatProgressSpinner, selector: "mat-progress-spinner, mat-spinner", inputs: ["color", "diameter", "strokeWidth", "mode", "value"], exportAs: ["matProgressSpinner"] }, { kind: "directive", type: i6.MatError, selector: "mat-error", inputs: ["id"] }, { kind: "component", type: i6.MatFormField, selector: "mat-form-field", inputs: ["color", "appearance", "hideRequiredMarker", "hintLabel", "floatLabel"], exportAs: ["matFormField"] }, { kind: "component", type: i7.MatOption, selector: "mat-option", exportAs: ["matOption"] }, { kind: "component", type: i8.MatSelect, selector: "mat-select", inputs: ["disabled", "disableRipple", "tabIndex"], exportAs: ["matSelect"] }] });
|
|
46
46
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: LazyLoadingSelectComponent, decorators: [{
|
|
47
47
|
type: Component,
|
|
48
|
-
args: [{ selector: 'app-lazy-loading-select', template: "<ng-container *ngIf=\"standalone\">\n <mat-form-field appearance=\"outline\">\n <mat-select [formControl]=\"formControl\"\n (openedChange)=\"getOptions()\"\n [placeholder]=\"placeholder\"\n (selectionChange)=\"onFieldChange(controlName)\"\n [id]=\"id\">\n <mat-option>\n <div class=\"select-search-wrapper\">\n <input\n type=\"text\"\n placeholder=\"Search\"\n class=\"select-search-input\"\n (click)=\"$event.stopPropagation()\"\n (keydown)=\"$event.stopPropagation()\"\n >\n <span class=\"search-icon-inside\">\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 32 32\">\n <path d=\"M13 2.25C7.063 2.25 2.25 7.063 2.25 13S7.063 23.75 13 23.75c2.699 0 5.165-.994 7.053-2.637l8.417 8.417a.75.75 0 1 0 1.06-1.06l-8.417-8.417A10.7 10.7 0 0 0 23.75 13c0-5.937-4.813-10.75-10.75-10.75M3.75 13a9.25 9.25 0 1 1 18.5 0 9.25 9.25 0 0 1-18.5 0\" fill=\"#000\"/>\n </svg>\n </span>\n </div>\n </mat-option>\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\n {{type}}\n </mat-option>\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"70\"\n strokeWidth=\"3\"\n mode=\"indeterminate\"\n *ngIf=\"optionsPending\"></mat-progress-spinner>\n </mat-select>\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\n <i class=\"fa fa-exclamation-triangle\"></i>\n {{errorText}}\n </mat-error>\n </mat-form-field>\n</ng-container>\n\n<!--\nThis duplication is caused by the following bug: https://github.com/angular/components/issues/9411\nWhich doesn't allow projection in mat-form-field\n-->\n\n<ng-container *ngIf=\"!standalone\">\n <mat-select *ngIf=\"form.get(controlName)\"\n [formControl]=\"formControl\"\n (openedChange)=\"getOptions()\"\n [placeholder]=\"placeholder\"\n (selectionChange)=\"onFieldChange(controlName)\"\n [id]=\"id\"\n >\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\n {{type}}\n </mat-option>\n <mat-progress-spinner class=\"field-spinner\"\n [diameter]=\"20\"\n mode=\"indeterminate\"\n *ngIf=\"optionsPending\"></mat-progress-spinner>\n </mat-select>\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\n <i class=\"fa fa-exclamation-triangle\"></i>\n {{errorText}}\n </mat-error>\n</ng-container>\n", styles: ["mat-form-field{width:300px;max-width:300px}::ng-deep .mat-option{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:block!important;line-height:48px!important;height:48px!important;padding:0 10px!important;text-align:left!important;text-decoration:none!important;position:relative!important;cursor:pointer!important;outline:none!important;display:flex!important;flex-direction:row!important;max-width:100%!important;box-sizing:border-box!important;align-items:center!important;-webkit-tap-highlight-color:rgba(0,0,0,0)!important}.select-search-wrapper{position:relative;width:100%}.search-icon-inside{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;display:flex;align-items:center}:host{height:35px;width:93%!important;max-width:93%!important;min-width:0!important;height:auto!important;box-sizing:border-box}:host ::ng-deep mat-form-field{width:100%;max-width:100%;height:35px}:host ::ng-deep mat-form-field .mat-form-field-flex .mat-form-field-outline .mat-form-field-outline-start{border:none!important}.select-search-input{width:100%;box-sizing:border-box;padding:7px 14px 7px 38px;margin:10px 0;border:3px solid #ccc;border-radius:.5rem;outline:none;font-size:14px;transition:border-color .2s}.select-search-input:focus{border-color:#1170cf}.field-spinner{margin-top:-30px}::ng-deep .mat-select-arrow{display:none}::ng-deep .mat-select-trigger{background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2232%22 height%3D%2232%22 viewBox%3D%220 0 32 32%22%3E%3Cpath d%3D%22M28.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%22%2F%3E%3C%2Fsvg%3E\") no-repeat right 12px center;background-size:16px;padding-right:32px}\n"] }]
|
|
48
|
+
args: [{ selector: 'app-lazy-loading-select', template: "<ng-container *ngIf=\"standalone\">\r\n <mat-form-field appearance=\"outline\">\r\n <mat-select [formControl]=\"formControl\"\r\n (openedChange)=\"getOptions()\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onFieldChange(controlName)\"\r\n [id]=\"id\">\r\n <mat-option>\r\n <div class=\"select-search-wrapper\">\r\n <input\r\n type=\"text\"\r\n placeholder=\"Search\"\r\n class=\"select-search-input\"\r\n (click)=\"$event.stopPropagation()\"\r\n (keydown)=\"$event.stopPropagation()\"\r\n >\r\n <span class=\"search-icon-inside\">\r\n <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 32 32\">\r\n <path d=\"M13 2.25C7.063 2.25 2.25 7.063 2.25 13S7.063 23.75 13 23.75c2.699 0 5.165-.994 7.053-2.637l8.417 8.417a.75.75 0 1 0 1.06-1.06l-8.417-8.417A10.7 10.7 0 0 0 23.75 13c0-5.937-4.813-10.75-10.75-10.75M3.75 13a9.25 9.25 0 1 1 18.5 0 9.25 9.25 0 0 1-18.5 0\" fill=\"#000\"/>\r\n </svg>\r\n </span>\r\n </div>\r\n </mat-option>\r\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\r\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\r\n {{type}}\r\n </mat-option>\r\n <mat-progress-spinner class=\"field-spinner\"\r\n [diameter]=\"70\"\r\n strokeWidth=\"3\"\r\n mode=\"indeterminate\"\r\n *ngIf=\"optionsPending\"></mat-progress-spinner>\r\n </mat-select>\r\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\r\n <i class=\"fa fa-exclamation-triangle\"></i>\r\n {{errorText}}\r\n </mat-error>\r\n </mat-form-field>\r\n</ng-container>\r\n\r\n<!--\r\nThis duplication is caused by the following bug: https://github.com/angular/components/issues/9411\r\nWhich doesn't allow projection in mat-form-field\r\n-->\r\n\r\n<ng-container *ngIf=\"!standalone\">\r\n <mat-select *ngIf=\"form.get(controlName)\"\r\n [formControl]=\"formControl\"\r\n (openedChange)=\"getOptions()\"\r\n [placeholder]=\"placeholder\"\r\n (selectionChange)=\"onFieldChange(controlName)\"\r\n [id]=\"id\"\r\n >\r\n <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\r\n <mat-option *ngFor=\"let type of options\" [value]=\"type\">\r\n {{type}}\r\n </mat-option>\r\n <mat-progress-spinner class=\"field-spinner\"\r\n [diameter]=\"20\"\r\n mode=\"indeterminate\"\r\n *ngIf=\"optionsPending\"></mat-progress-spinner>\r\n </mat-select>\r\n <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\r\n <i class=\"fa fa-exclamation-triangle\"></i>\r\n {{errorText}}\r\n </mat-error>\r\n</ng-container>\r\n", styles: ["mat-form-field{width:300px;max-width:300px}::ng-deep .mat-option{white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important;display:block!important;line-height:48px!important;height:48px!important;padding:0 10px!important;text-align:left!important;text-decoration:none!important;position:relative!important;cursor:pointer!important;outline:none!important;display:flex!important;flex-direction:row!important;max-width:100%!important;box-sizing:border-box!important;align-items:center!important;-webkit-tap-highlight-color:rgba(0,0,0,0)!important}.select-search-wrapper{position:relative;width:100%}.search-icon-inside{position:absolute;left:12px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:2;display:flex;align-items:center}:host{height:35px;width:93%!important;max-width:93%!important;min-width:0!important;height:auto!important;box-sizing:border-box}:host ::ng-deep mat-form-field{width:100%;max-width:100%;height:35px}:host ::ng-deep mat-form-field .mat-form-field-flex .mat-form-field-outline .mat-form-field-outline-start{border:none!important}.select-search-input{width:100%;box-sizing:border-box;padding:7px 14px 7px 38px;margin:10px 0;border:3px solid #ccc;border-radius:.5rem;outline:none;font-size:14px;transition:border-color .2s}.select-search-input:focus{border-color:#1170cf}.field-spinner{margin-top:-30px}::ng-deep .mat-select-arrow{display:none}::ng-deep .mat-select-trigger{background:url(\"data:image/svg+xml,%3Csvg xmlns%3D%22http%3A%2F%2Fwww.w3.org%2F2000%2Fsvg%22 width%3D%2232%22 height%3D%2232%22 viewBox%3D%220 0 32 32%22%3E%3Cpath d%3D%22M28.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%22%2F%3E%3C%2Fsvg%3E\") no-repeat right 12px center;background-size:16px;padding-right:32px}\n"] }]
|
|
49
49
|
}], ctorParameters: function () { return [{ type: i1.NotificationService }, { type: i2.SiteSettingsService }]; }, propDecorators: { siteId: [{
|
|
50
50
|
type: Input
|
|
51
51
|
}], form: [{
|
|
@@ -71,4 +71,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
71
71
|
}], changeField: [{
|
|
72
72
|
type: Output
|
|
73
73
|
}] } });
|
|
74
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
74
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lazy-loading-select.component.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.ts","../../../../../../../projects/tuki/widgets/user-device-manage/src/lazy-loading-select/lazy-loading-select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoB,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;;;;;;;;;;AAgBzF,MAAM,OAAO,0BAA0B;IA6BrC,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,WAAW,CAAgB,CAAC;IACzD,CAAC;IAGD,YACU,mBAAwC,EACxC,mBAAwC;QADxC,wBAAmB,GAAnB,mBAAmB,CAAqB;QACxC,wBAAmB,GAAnB,mBAAmB,CAAqB;QA3B3C,eAAU,GAAG,IAAI,CAAC;QAQlB,eAAU,GAAG,UAAU,CAAC;QAUxB,gBAAW,GAAG,IAAI,YAAY,EAAU,CAAC;IAWhD,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,OAAO,GAAG,CAAC,IAAI,CAAC,IAAI,EAAE,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE;YAC3C,OAAO;SACR;QACD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC3B,IAAI,CAAC,mBAAmB,CAAC,mBAAmB,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,YAAY,CAAC;aACzE,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,aAAa;YACb,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC7D,CAAC,EAAE,GAAG,EAAE;YACN,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAC5B,+FAA+F;QACjG,CAAC,CAAC,CAAC;IACP,CAAC;IAEM,aAAa,CAAC,KAAa;QAChC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC/B,CAAC;;wHA9DU,0BAA0B;4GAA1B,0BAA0B,4WChBvC,mjGAmEA;4FDnDa,0BAA0B;kBALtC,SAAS;+BACE,yBAAyB;4IAS5B,MAAM;sBADZ,KAAK;gBAGC,IAAI;sBADV,KAAK;gBAGC,UAAU;sBADhB,KAAK;gBAGC,WAAW;sBADjB,KAAK;gBAGC,WAAW;sBADjB,KAAK;gBAGC,YAAY;sBADlB,KAAK;gBAGC,UAAU;sBADhB,KAAK;gBAGC,SAAS;sBADf,KAAK;gBAGC,SAAS;sBADf,KAAK;gBAGC,OAAO;sBADb,KAAK;gBAGC,EAAE;sBADR,KAAK;gBAGC,WAAW;sBADjB,MAAM","sourcesContent":["import { AfterContentInit, Component, EventEmitter, Input, Output } from '@angular/core';\r\nimport { FormControl, FormGroup } from '@angular/forms';\r\nimport { NotificationService } from '../services/notification.service';\r\nimport { SiteSettingsService } from '../services/site-settings.service';\r\n\r\nexport interface OptionValue {\r\n  key: string;\r\n  value: string;\r\n  disabled: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'app-lazy-loading-select',\r\n  templateUrl: './lazy-loading-select.component.html',\r\n  styleUrls: ['./lazy-loading-select.component.scss']\r\n})\r\nexport class LazyLoadingSelectComponent implements AfterContentInit {\r\n  optionsPending!: boolean;\r\n  options!: any;\r\n\r\n  @Input()\r\n  public siteId!: number\r\n  @Input()\r\n  public form!: FormGroup;\r\n  @Input()\r\n  public standalone = true;\r\n  @Input()\r\n  public placeholder!: string;\r\n  @Input()\r\n  public controlName!: string;\r\n  @Input()\r\n  public optionsToken!: string;\r\n  @Input()\r\n  public appearance = 'standard';\r\n  @Input()\r\n  public errorCode!: string;\r\n  @Input()\r\n  public errorText!: string;\r\n  @Input()\r\n  public default!: OptionValue;\r\n  @Input()\r\n  public id!: string;\r\n  @Output()\r\n  public changeField = new EventEmitter<string>();\r\n\r\n  get formControl(): FormControl {\r\n    return this.form?.get(this.controlName) as FormControl;\r\n  }\r\n\r\n\r\n  constructor(\r\n    private notificationService: NotificationService,\r\n    private siteSettingsService: SiteSettingsService,\r\n  ) {\r\n  }\r\n\r\n  ngAfterContentInit() {\r\n    this.options = [this.form?.get(this.controlName)?.value];\r\n  }\r\n\r\n  getOptions() {\r\n    if (!this.siteId && this.options.length > 1) {\r\n      return;\r\n    }\r\n    this.optionsPending = true;\r\n    this.siteSettingsService.getSelectionOptions(this.siteId, this.optionsToken)\r\n      .subscribe(() => {\r\n        this.optionsPending = false;\r\n        // @ts-ignore\r\n        this.options = this.siteSettingsService[this.optionsToken];\r\n      }, () => {\r\n        this.optionsPending = false;\r\n        // this.notificationService.error(this.translate.instant('COMMON.LOAD_SELECT_OPTIONS_FAILED'));\r\n      });\r\n  }\r\n\r\n  public onFieldChange(token: string) {\r\n    this.changeField.emit(token);\r\n  }\r\n\r\n}\r\n","<ng-container *ngIf=\"standalone\">\r\n  <mat-form-field appearance=\"outline\">\r\n    <mat-select [formControl]=\"formControl\"\r\n                (openedChange)=\"getOptions()\"\r\n                [placeholder]=\"placeholder\"\r\n                (selectionChange)=\"onFieldChange(controlName)\"\r\n                [id]=\"id\">\r\n      <mat-option>\r\n        <div class=\"select-search-wrapper\">\r\n          <input\r\n            type=\"text\"\r\n            placeholder=\"Search\"\r\n            class=\"select-search-input\"\r\n            (click)=\"$event.stopPropagation()\"\r\n            (keydown)=\"$event.stopPropagation()\"\r\n          >\r\n          <span class=\"search-icon-inside\">\r\n            <svg xmlns=\"http://www.w3.org/2000/svg\" width=\"20\" height=\"20\" viewBox=\"0 0 32 32\">\r\n              <path d=\"M13 2.25C7.063 2.25 2.25 7.063 2.25 13S7.063 23.75 13 23.75c2.699 0 5.165-.994 7.053-2.637l8.417 8.417a.75.75 0 1 0 1.06-1.06l-8.417-8.417A10.7 10.7 0 0 0 23.75 13c0-5.937-4.813-10.75-10.75-10.75M3.75 13a9.25 9.25 0 1 1 18.5 0 9.25 9.25 0 0 1-18.5 0\" fill=\"#000\"/>\r\n            </svg>\r\n          </span>\r\n        </div>\r\n      </mat-option>\r\n      <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\r\n      <mat-option *ngFor=\"let type of options\" [value]=\"type\">\r\n        {{type}}\r\n      </mat-option>\r\n      <mat-progress-spinner class=\"field-spinner\"\r\n                            [diameter]=\"70\"\r\n                            strokeWidth=\"3\"\r\n                            mode=\"indeterminate\"\r\n                            *ngIf=\"optionsPending\"></mat-progress-spinner>\r\n    </mat-select>\r\n    <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\r\n      <i class=\"fa fa-exclamation-triangle\"></i>\r\n      {{errorText}}\r\n    </mat-error>\r\n  </mat-form-field>\r\n</ng-container>\r\n\r\n<!--\r\nThis duplication is caused by the following bug: https://github.com/angular/components/issues/9411\r\nWhich doesn't allow projection in mat-form-field\r\n-->\r\n\r\n<ng-container *ngIf=\"!standalone\">\r\n  <mat-select *ngIf=\"form.get(controlName)\"\r\n              [formControl]=\"formControl\"\r\n              (openedChange)=\"getOptions()\"\r\n              [placeholder]=\"placeholder\"\r\n              (selectionChange)=\"onFieldChange(controlName)\"\r\n              [id]=\"id\"\r\n  >\r\n    <mat-option *ngIf=\"default\" [disabled]=\"default.disabled\" [value]=\"default.key\">{{default.value}}</mat-option>\r\n    <mat-option *ngFor=\"let type of options\" [value]=\"type\">\r\n      {{type}}\r\n    </mat-option>\r\n    <mat-progress-spinner class=\"field-spinner\"\r\n                          [diameter]=\"20\"\r\n                          mode=\"indeterminate\"\r\n                          *ngIf=\"optionsPending\"></mat-progress-spinner>\r\n  </mat-select>\r\n  <mat-error *ngIf=\"form.get(controlName)?.hasError(errorCode)\">\r\n    <i class=\"fa fa-exclamation-triangle\"></i>\r\n    {{errorText}}\r\n  </mat-error>\r\n</ng-container>\r\n"]}
|
|
@@ -23,4 +23,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
|
|
|
23
23
|
name: 'macAddress'
|
|
24
24
|
}]
|
|
25
25
|
}] });
|
|
26
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
26
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFjLWFkZHJlc3MucGlwZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3R1a2kvd2lkZ2V0cy91c2VyLWRldmljZS1tYW5hZ2Uvc3JjL3BpcGVzL21hYy1hZGRyZXNzLnBpcGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLElBQUksRUFBaUIsTUFBTSxlQUFlLENBQUM7O0FBS3BELE1BQU0sT0FBTyxjQUFjO0lBRXpCLFNBQVMsQ0FBQyxLQUFhO1FBQ3JCLElBQUksQ0FBQyxLQUFLLEVBQUU7WUFDVixPQUFPLEVBQUUsQ0FBQztTQUNYO1FBRUQsTUFBTSxPQUFPLEdBQUcsS0FBSyxDQUFDLE9BQU8sQ0FBQyxlQUFlLEVBQUUsRUFBRSxDQUFDLENBQUM7UUFFbkQsSUFBSSxPQUFPLENBQUMsTUFBTSxLQUFLLEVBQUUsRUFBRTtZQUN6QixPQUFPLEtBQUssQ0FBQztTQUNkO1FBRUQsT0FBTyxPQUFPO2FBQ1gsS0FBSyxDQUFDLFNBQVMsQ0FBQztZQUNqQixFQUFFLElBQUksQ0FBQyxHQUFHLENBQUM7YUFDVixXQUFXLEVBQUUsSUFBSSxLQUFLLENBQUM7SUFDNUIsQ0FBQzs7NEdBakJVLGNBQWM7MEdBQWQsY0FBYzs0RkFBZCxjQUFjO2tCQUgxQixJQUFJO21CQUFDO29CQUNKLElBQUksRUFBRSxZQUFZO2lCQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFBpcGUsIFBpcGVUcmFuc2Zvcm0gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnbWFjQWRkcmVzcydcclxufSlcclxuZXhwb3J0IGNsYXNzIE1hY0FkZHJlc3NQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcblxyXG4gIHRyYW5zZm9ybSh2YWx1ZTogc3RyaW5nKTogc3RyaW5nIHtcclxuICAgIGlmICghdmFsdWUpIHtcclxuICAgICAgcmV0dXJuICcnO1xyXG4gICAgfVxyXG5cclxuICAgIGNvbnN0IGNsZWFuZWQgPSB2YWx1ZS5yZXBsYWNlKC9bXmEtZkEtRjAtOV0vZywgJycpO1xyXG5cclxuICAgIGlmIChjbGVhbmVkLmxlbmd0aCAhPT0gMTIpIHtcclxuICAgICAgcmV0dXJuIHZhbHVlO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBjbGVhbmVkXHJcbiAgICAgIC5tYXRjaCgvLnsxLDJ9L2cpXHJcbiAgICAgID8uam9pbignOicpXHJcbiAgICAgIC50b1VwcGVyQ2FzZSgpIHx8IHZhbHVlO1xyXG4gIH1cclxufSJdfQ==
|
|
@@ -76,4 +76,4 @@ APIService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version:
|
|
|
76
76
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: APIService, decorators: [{
|
|
77
77
|
type: Injectable
|
|
78
78
|
}], ctorParameters: function () { return [{ type: i1.HttpClient }]; } });
|
|
79
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
79
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"api.service.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-device-manage/src/services/api.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { HttpClient, HttpHeaders } from '@angular/common/http';\r\nimport { Observable } from 'rxjs';\r\n\r\n\r\n@Injectable()\r\nexport class APIService {\r\n  public token: any;\r\n  apiUrl = window.location.protocol + '//' + window.location.hostname + '/dcp';\r\n  constructor(\r\n    private httpClient: HttpClient\r\n  ) {\r\n  }\r\n\r\n  fetch(url: string, params?: any, cache?: boolean): Observable<any> {\r\n    const headers = this.getHeaders(cache);\r\n    params = params || {};\r\n    return this.httpClient.get(this.apiUrl + url, {params: this.prepareEncodedParams(params), headers});\r\n  }\r\n\r\n  post(url: string, body: any, params = {}): any {\r\n    body = body || null;\r\n    const headers = this.getHeaders();\r\n    return this.httpClient.post(this.apiUrl + url, body, {params: this.prepareEncodedParams(params), headers});\r\n  }\r\n\r\n  // use when response extended data is necessary:\r\n  postExtended(url: string, body = null, params = {}, headers = {}) {\r\n    headers = headers || this.getHeaders();\r\n    return this.httpClient.post(this.apiUrl + url, body, {\r\n      headers,\r\n      observe: 'response',\r\n      params: this.prepareEncodedParams(params)\r\n    });\r\n  }\r\n\r\n  put(url: string, body: any = null, params = {}) {\r\n    const headers = this.getHeaders();\r\n    return this.httpClient.put(this.apiUrl + url, body, {headers, params: this.prepareEncodedParams(params)});\r\n  }\r\n\r\n  delete(url: string, params = {}) {\r\n    const headers = this.getHeaders();\r\n    return this.httpClient.delete(this.apiUrl + url, {headers, params: this.prepareEncodedParams(params)});\r\n  }\r\n\r\n  fetchPagination(url: string, pageSize: number, pageNumber: number, additionalParams = {}, cache?: boolean): Observable<any> {\r\n    const copyAdditionalParams = JSON.parse(JSON.stringify(additionalParams));\r\n    const params = Object.assign(copyAdditionalParams, {size: pageSize.toString(), page: pageNumber.toString()});\r\n    return this.fetch(url, params, cache) as Observable<any>;\r\n  }\r\n\r\n  private prepareEncodedParams(params: any) {\r\n    const result: any = {};\r\n\r\n    if (!params) {\r\n      return {};\r\n    }\r\n    for (const key of Object.keys(params)) {\r\n      if (params[key]) {\r\n        const stringParam = params[key].toString();\r\n        result[key] = stringParam.includes('+') ? encodeURIComponent(stringParam) : stringParam;\r\n      }\r\n    }\r\n    return result;\r\n  }\r\n\r\n  private getHeaders(cache?: boolean): HttpHeaders {\r\n    let headers = new HttpHeaders();\r\n    if (cache) {\r\n      headers = headers.append('_Cache', 'true ');\r\n    }\r\n    const token = this.token || this.getParameterByName('token');\r\n    headers = headers.append('Authorization', 'Bearer '+ token);\r\n    return headers;\r\n  }\r\n\r\n  private getParameterByName(name: any, url = window.location.href) {\r\n    name = name.replace(/[\\[\\]]/g, '\\\\$&');\r\n    var regex = new RegExp('[?&]' + name + '(=([^&#]*)|&|#|$)'),\r\n      results = regex.exec(url);\r\n    if (!results) return null;\r\n    if (!results[2]) return '';\r\n    return decodeURIComponent(results[2].replace(/\\+/g, ' '));\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -133,4 +133,4 @@ DnsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version:
|
|
|
133
133
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: DnsService, decorators: [{
|
|
134
134
|
type: Injectable
|
|
135
135
|
}], ctorParameters: function () { return [{ type: i1.APIService }]; } });
|
|
136
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns.service.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-device-manage/src/services/dns.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAC3C,OAAO,EAAE,GAAG,EAAE,MAAM,kBAAkB,CAAC;AAEvC,OAAO,EAAE,GAAG,EAAE,MAAM,gBAAgB,CAAC;AACrC,OAAO,EAAsC,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACpF,OAAO,GAAG,MAAM,QAAQ,CAAC;AACzB,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;;;AAElC,MAAM,CAAC,MAAM,SAAS,GAAG,IAAI,CAAC;AAG9B,MAAM,OAAO,UAAU;IAIrB,YACU,UAAsB;QAAtB,eAAU,GAAV,UAAU,CAAY;QAJhC,qBAAgB,GAAG,EAAE,CAAC;IAOtB,CAAC;IACM,cAAc,CAAC,MAAc,EAAE,cAAsB,EAAE,QAAkB,EAAE,IAAa,EAAE,QAAiB;QAChH,aAAa;QACb,IAAI,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,EAAE,MAAM,EAAE;YACjD,OAAO,IAAI,UAAU,CAAM,QAAQ,CAAC,EAAE;gBACpC,aAAa;gBACb,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,CAAC,CAAC;YACvD,CAAC,CAAC,CAAC;SACJ;QAED,IAAI,CAAC,8BAA8B,GAAG,EAAE,CAAC;QACzC,QAAQ,GAAG,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,CAAC;QACpC,MAAM,MAAM,GAAG,EAAC,MAAM,EAAE,WAAW,CAAC,SAAS,EAAE,cAAc,EAAE,cAAc,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,EAAC,CAAC;QACxG,IAAI,QAAQ,EAAE;YACZ,aAAa;YACb,MAAM,CAAC,UAAU,CAAC,GAAG,MAAM,CAAC;SAC7B;QACD,IAAI,IAAI,EAAE;YACR,aAAa;YACb,MAAM,CAAC,MAAM,CAAC,GAAG,IAAI,CAAC;SACvB;QACD,aAAa;QACb,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,IAAI,EAAE,CAAC;QAEpF,OAAO,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,sBAAsB,CAAC,OAAO,CAAC,SAAS,EAAE,MAAM,CAAC,EAAE,MAAM,CAAC;aACxF,IAAI,CAAC,GAAG,CAAC,CAAC,GAAQ,EAAE,EAAE;YACnB,GAAG,CAAC,mBAAmB,CAAC,OAAO,CAAC,CAAC,eAAmD,EAAE,EAAE;gBACtF,IAAI,CAAC,yBAAyB,CAAC,eAAe,CAAC,CAAC;gBAChD,aAAa;gBACb,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAC,EAAE,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,CAAC,CAAC;YACpI,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CACH,CAAA;QACD,wCAAwC;IAC5C,CAAC;IAEM,yBAAyB,CAAC,eAAoB;QACnD,IAAI,eAAe,CAAC,qBAAqB,IAAI,eAAe,CAAC,qBAAqB,CAAC,MAAM,EAAE;YAEzF,eAAe,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,cAAmB,EAAE,EAAE;gBACpE,MAAM,EAAE,GAAG,cAAc,CAAC,cAAc,CAAC,CAAC;gBAC1C,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;gBAC/C,IAAI,cAAc,CAAC,wBAAwB,CAAC,IAAI,cAAc,CAAC,wBAAwB,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;oBACnG,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,GAAG,cAAc,CAAC,wBAAwB,CAAC,CAAC;oBACnF,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC;oBAChE,IAAI,cAAc,CAAC,YAAY,CAAC,IAAI,cAAc,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;wBAC3E,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,GAAG,cAAc,CAAC,YAAY,CAAC,CAAC;qBACzF;iBACF;gBACD,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,cAAc,CAAC,IAAI,CAAC,CAAC;YAC1E,CAAC,CAAC,CAAC;SACJ;IACH,CAAC;IAEM,oBAAoB,CAAC,eAAoB;QAC9C,IAAI,iBAAiB,GAAG,IAAI,CAAC,iBAAiB,CAAC,eAAe,CAAC,gBAAgB,CAAC,IAAI,EAAE,eAAe,CAAC,gBAAgB,CAAC,EAAE,CAAC;aACvH,GAAG,CAAC,CAAC,eAAuB,EAAE,EAAE;YAC/B,MAAM,EAAE,GAAG,eAAe,CAAC,gBAAgB,CAAC,MAAM,GAAG,eAAe,CAAC;YACrE,IAAI,GAAG,GAAG,EAAE,CAAC;YACb,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;gBACjG,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,EAAE;oBACnI,OAAO,CAAC,GAAG,CAAC,OAAO,CAAC,CAAC;oBACrB,GAAG,IAAI,gBAAgB,GAAG,CAAC,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC;wBAC3G,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;iBAChE;gBACD,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,EAAE;oBACpD,GAAG,IAAI,qBAAqB,CAAC;iBAC9B;aACF;YACD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,CAAC;QACL,iBAAiB,GAAG,iBAAiB,CAAC,MAAM,CAAC,CAAC,eAAuB,EAAE,EAAE,CAAC,CAAC,eAAe,CAAC,WAAW,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,CAAC;QAClI,OAAO,iBAAiB,CAAC;IAC3B,CAAC;IAEM,iBAAiB,CAAC,KAAa,EAAE,GAAW;QACjD,MAAM,MAAM,GAAG,OAAO,CAAC;QACvB,IAAI,YAAY,GAAG,EAAE,CAAC;QACtB,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;QACpC,IAAI,OAAO,EAAE;YACX,YAAY,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;SAC3B;QACD,MAAM,YAAY,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC;QACpC,MAAM,UAAU,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;QAChC,aAAa;QACb,OAAO,KAAK,CAAC,IAAI,CAAC,EAAC,MAAM,EAAE,CAAC,UAAU,CAAC,KAAK,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAC,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACjG,MAAM,MAAM,GAAG,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;YAChE,IAAI,CAAC,YAAY,GAAG,MAAM,CAAC,CAAC,MAAM,GAAG,KAAK,CAAC,MAAM,EAAE;gBACjD,YAAY,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;aACvC;YACD,OAAO,YAAY,GAAG,MAAM,CAAC;QAC/B,CAAC,CAAC,CAAC;IACL,CAAC;IAEM,UAAU,CAAC,SAAiB;QACjC,MAAM,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,EAAE,GAAG,SAAS,CAAC;QACnB,IAAI,GAAG,GAAG,CAAC,CAAC,EAAE;YACZ,EAAE,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;YAC7B,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;SAChB;QACD,IAAI,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,KAAK,IAAI,EAAE;YACzB,EAAE,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SAClB;QACD,OAAO,IAAI,CAAC,qBAAqB,CAAC,EAAE,CAAC,CAAC;IACxC,CAAC;IAEM,qBAAqB,CAAC,SAAiB;QAC5C,MAAM,GAAG,GAAG,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC;QACxC,IAAI,EAAE,GAAG,SAAS,CAAC;QACnB,IAAI,GAAG,GAAG,CAAC,CAAC,EAAE;YACZ,EAAE,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;YAC7B,EAAE,GAAG,EAAE,CAAC,IAAI,EAAE,CAAC;SAChB;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;IAEM,aAAa,CAAE,SAAiB,EAAE,KAAa;QACpD,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC;QACtC,IAAI,IAAI,CAAC,8BAA8B,IAAI,IAAI,CAAC,8BAA8B,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC;YACvH,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC;YACtG,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,MAAM,EAAE;YACjE,OAAO,IAAI,CAAC,8BAA8B,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SACjF;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;;wGArIU,UAAU;4GAAV,UAAU;4FAAV,UAAU;kBADtB,UAAU","sourcesContent":["import { Injectable } from '@angular/core';\nimport { API } from '../app.constants';\nimport { APIService } from './api.service';\nimport { map } from 'rxjs/operators';\nimport { AvailablePhoneNumberRangeInterface, DnRangeType } from './../classes/line';\nimport Big from 'big.js';\nimport { Observable } from 'rxjs';\n\nexport const DELIMITER = ', ';\n\n@Injectable()\nexport class DnsService {\n  availableNumbers = {};\n  availableDidPatternsMappedToDn!: any;\n\n  constructor(\n    private apiService: APIService\n  ) {\n\n  }\n  public getNumberRange(siteId: string, routePartition: string, withdids?: boolean, from?: string, pageSize?: number): any {\n    // @ts-ignore\n    if (this.availableNumbers[routePartition]?.length) {\n      return new Observable<any>(observer => {\n        // @ts-ignore\n        observer.next(this.availableNumbers[routePartition]);\n      });\n    }\n\n    this.availableDidPatternsMappedToDn = {};\n    pageSize = pageSize ? pageSize : 20;\n    const params = {dntype: DnRangeType.extension, routepartition: routePartition, size: pageSize, page: 0};\n    if (withdids) {\n      // @ts-ignore\n      params['withdids'] = 'true';\n    }\n    if (from) {\n      // @ts-ignore\n      params['from'] = from;\n    }\n    // @ts-ignore\n    this.availableNumbers[routePartition] = this.availableNumbers[routePartition] || [];\n\n    return this.apiService.fetch(API.AVAILABLE_DN_IN_RANGES.replace(':siteId', siteId), params)\n      .pipe(map((res: any) => {\n          res.availableNumberList.forEach((availableNumber: AvailablePhoneNumberRangeInterface) => {\n            this.setAvailableDidMappedToDn(availableNumber);\n            // @ts-ignore\n            this.availableNumbers[routePartition] = [...this.availableNumbers[routePartition], ...this.getUnwrapNumberRange(availableNumber)];\n          });\n        })\n      )\n      // .pipe(this.handleError(true, false));\n  }\n\n  public setAvailableDidMappedToDn(availableNumber: any): void {\n    if (availableNumber.unUsedNumbersWithDids && availableNumber.unUsedNumbersWithDids.length) {\n\n      availableNumber.unUsedNumbersWithDids.forEach((numberWithDids: any) => {\n        const dn = numberWithDids['unUsedNumber'];\n        this.availableDidPatternsMappedToDn[dn] = [{}];\n        if (numberWithDids['translationPatternList'] && numberWithDids['translationPatternList'].length > 0) {\n          this.availableDidPatternsMappedToDn[dn] = numberWithDids['translationPatternList'];\n          this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] = [{}];\n          if (numberWithDids['mappedDids'] && numberWithDids['mappedDids'].length > 0) {\n            this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] = numberWithDids['mappedDids'];\n          }\n        }\n        this.availableDidPatternsMappedToDn[dn][0]['vm'] = numberWithDids['vm'];\n      });\n    }\n  }\n\n  public getUnwrapNumberRange(availableNumber: any): string[] {\n    let unwrapNumberRange = this.unwrapNumberRange(availableNumber.phoneNumberRange.from, availableNumber.phoneNumberRange.to)\n      .map((unwrappedNumber: string) => {\n        const dn = availableNumber.phoneNumberRange.prefix + unwrappedNumber;\n        let str = dn;\n        if (this.availableDidPatternsMappedToDn[dn] && this.availableDidPatternsMappedToDn[dn].length > 0) {\n          if (this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] && this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].length > 0) {\n            console.log('Hello');\n            str += '        DID:  ' + (this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].length > 1 ? 'multiple' :\n              this.availableDidPatternsMappedToDn[dn][0]['mappedDids'][0]);\n          }\n          if (this.availableDidPatternsMappedToDn[dn][0]['vm']) {\n            str += '        In Use - VM';\n          }\n        }\n        return str;\n      });\n    unwrapNumberRange = unwrapNumberRange.filter((unwrappedNumber: string) => !availableNumber.usedNumbers.includes(unwrappedNumber));\n    return unwrapNumberRange;\n  }\n\n  public unwrapNumberRange(start: string, end: string): string[] {\n    const regExp = /(^0+)/;\n    let leadingZeros = '';\n    const matches = start.match(regExp);\n    if (matches) {\n      leadingZeros = matches[1];\n    }\n    const startNumeric = new Big(start);\n    const endNumeric = new Big(end);\n    // @ts-ignore\n    return Array.from({length: (endNumeric.minus(startNumeric).plus(new Big(1)).toFixed(0))}, (v, k) => {\n      const number = String(startNumeric.plus(new Big(k)).toFixed(0));\n      if ((leadingZeros + number).length > start.length) {\n        leadingZeros = leadingZeros.substr(1);\n      }\n      return leadingZeros + number;\n    });\n  }\n\n  public getDnValue(dnWithDid: string): string {\n    const ind = dnWithDid.indexOf('DID');\n    let dn = dnWithDid;\n    if (ind > -1) {\n      dn = dnWithDid.slice(0, ind);\n      dn = dn.trim();\n    }\n    if (dn.charAt(0) === '\\\\') {\n      dn = dn.slice(1);\n    }\n    return this.getDnValueTrimInUseVM(dn);\n  }\n\n  public getDnValueTrimInUseVM(dnWithDid: string): string {\n    const ind = dnWithDid.indexOf('In Use');\n    let dn = dnWithDid;\n    if (ind > -1) {\n      dn = dnWithDid.slice(0, ind);\n      dn = dn.trim();\n    }\n    return dn;\n  }\n\n  public getMappedDids (dnWithDid: string, index: string): string {\n    const dn = this.getDnValue(dnWithDid);\n    if (this.availableDidPatternsMappedToDn && this.availableDidPatternsMappedToDn && this.availableDidPatternsMappedToDn[dn] &&\n      this.availableDidPatternsMappedToDn[dn][0] && this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] &&\n      this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].length) {\n      return this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].join(DELIMITER);\n    }\n    return '';\n  }\n}\n"]}
|
|
136
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dns.service.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-device-manage/src/services/dns.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { API } from '../app.constants';\r\nimport { APIService } from './api.service';\r\nimport { map } from 'rxjs/operators';\r\nimport { AvailablePhoneNumberRangeInterface, DnRangeType } from './../classes/line';\r\nimport Big from 'big.js';\r\nimport { Observable } from 'rxjs';\r\n\r\nexport const DELIMITER = ', ';\r\n\r\n@Injectable()\r\nexport class DnsService {\r\n  availableNumbers = {};\r\n  availableDidPatternsMappedToDn!: any;\r\n\r\n  constructor(\r\n    private apiService: APIService\r\n  ) {\r\n\r\n  }\r\n  public getNumberRange(siteId: string, routePartition: string, withdids?: boolean, from?: string, pageSize?: number): any {\r\n    // @ts-ignore\r\n    if (this.availableNumbers[routePartition]?.length) {\r\n      return new Observable<any>(observer => {\r\n        // @ts-ignore\r\n        observer.next(this.availableNumbers[routePartition]);\r\n      });\r\n    }\r\n\r\n    this.availableDidPatternsMappedToDn = {};\r\n    pageSize = pageSize ? pageSize : 20;\r\n    const params = {dntype: DnRangeType.extension, routepartition: routePartition, size: pageSize, page: 0};\r\n    if (withdids) {\r\n      // @ts-ignore\r\n      params['withdids'] = 'true';\r\n    }\r\n    if (from) {\r\n      // @ts-ignore\r\n      params['from'] = from;\r\n    }\r\n    // @ts-ignore\r\n    this.availableNumbers[routePartition] = this.availableNumbers[routePartition] || [];\r\n\r\n    return this.apiService.fetch(API.AVAILABLE_DN_IN_RANGES.replace(':siteId', siteId), params)\r\n      .pipe(map((res: any) => {\r\n          res.availableNumberList.forEach((availableNumber: AvailablePhoneNumberRangeInterface) => {\r\n            this.setAvailableDidMappedToDn(availableNumber);\r\n            // @ts-ignore\r\n            this.availableNumbers[routePartition] = [...this.availableNumbers[routePartition], ...this.getUnwrapNumberRange(availableNumber)];\r\n          });\r\n        })\r\n      )\r\n      // .pipe(this.handleError(true, false));\r\n  }\r\n\r\n  public setAvailableDidMappedToDn(availableNumber: any): void {\r\n    if (availableNumber.unUsedNumbersWithDids && availableNumber.unUsedNumbersWithDids.length) {\r\n\r\n      availableNumber.unUsedNumbersWithDids.forEach((numberWithDids: any) => {\r\n        const dn = numberWithDids['unUsedNumber'];\r\n        this.availableDidPatternsMappedToDn[dn] = [{}];\r\n        if (numberWithDids['translationPatternList'] && numberWithDids['translationPatternList'].length > 0) {\r\n          this.availableDidPatternsMappedToDn[dn] = numberWithDids['translationPatternList'];\r\n          this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] = [{}];\r\n          if (numberWithDids['mappedDids'] && numberWithDids['mappedDids'].length > 0) {\r\n            this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] = numberWithDids['mappedDids'];\r\n          }\r\n        }\r\n        this.availableDidPatternsMappedToDn[dn][0]['vm'] = numberWithDids['vm'];\r\n      });\r\n    }\r\n  }\r\n\r\n  public getUnwrapNumberRange(availableNumber: any): string[] {\r\n    let unwrapNumberRange = this.unwrapNumberRange(availableNumber.phoneNumberRange.from, availableNumber.phoneNumberRange.to)\r\n      .map((unwrappedNumber: string) => {\r\n        const dn = availableNumber.phoneNumberRange.prefix + unwrappedNumber;\r\n        let str = dn;\r\n        if (this.availableDidPatternsMappedToDn[dn] && this.availableDidPatternsMappedToDn[dn].length > 0) {\r\n          if (this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] && this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].length > 0) {\r\n            console.log('Hello');\r\n            str += '        DID:  ' + (this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].length > 1 ? 'multiple' :\r\n              this.availableDidPatternsMappedToDn[dn][0]['mappedDids'][0]);\r\n          }\r\n          if (this.availableDidPatternsMappedToDn[dn][0]['vm']) {\r\n            str += '        In Use - VM';\r\n          }\r\n        }\r\n        return str;\r\n      });\r\n    unwrapNumberRange = unwrapNumberRange.filter((unwrappedNumber: string) => !availableNumber.usedNumbers.includes(unwrappedNumber));\r\n    return unwrapNumberRange;\r\n  }\r\n\r\n  public unwrapNumberRange(start: string, end: string): string[] {\r\n    const regExp = /(^0+)/;\r\n    let leadingZeros = '';\r\n    const matches = start.match(regExp);\r\n    if (matches) {\r\n      leadingZeros = matches[1];\r\n    }\r\n    const startNumeric = new Big(start);\r\n    const endNumeric = new Big(end);\r\n    // @ts-ignore\r\n    return Array.from({length: (endNumeric.minus(startNumeric).plus(new Big(1)).toFixed(0))}, (v, k) => {\r\n      const number = String(startNumeric.plus(new Big(k)).toFixed(0));\r\n      if ((leadingZeros + number).length > start.length) {\r\n        leadingZeros = leadingZeros.substr(1);\r\n      }\r\n      return leadingZeros + number;\r\n    });\r\n  }\r\n\r\n  public getDnValue(dnWithDid: string): string {\r\n    const ind = dnWithDid.indexOf('DID');\r\n    let dn = dnWithDid;\r\n    if (ind > -1) {\r\n      dn = dnWithDid.slice(0, ind);\r\n      dn = dn.trim();\r\n    }\r\n    if (dn.charAt(0) === '\\\\') {\r\n      dn = dn.slice(1);\r\n    }\r\n    return this.getDnValueTrimInUseVM(dn);\r\n  }\r\n\r\n  public getDnValueTrimInUseVM(dnWithDid: string): string {\r\n    const ind = dnWithDid.indexOf('In Use');\r\n    let dn = dnWithDid;\r\n    if (ind > -1) {\r\n      dn = dnWithDid.slice(0, ind);\r\n      dn = dn.trim();\r\n    }\r\n    return dn;\r\n  }\r\n\r\n  public getMappedDids (dnWithDid: string, index: string): string {\r\n    const dn = this.getDnValue(dnWithDid);\r\n    if (this.availableDidPatternsMappedToDn && this.availableDidPatternsMappedToDn && this.availableDidPatternsMappedToDn[dn] &&\r\n      this.availableDidPatternsMappedToDn[dn][0] && this.availableDidPatternsMappedToDn[dn][0]['mappedDids'] &&\r\n      this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].length) {\r\n      return this.availableDidPatternsMappedToDn[dn][0]['mappedDids'].join(DELIMITER);\r\n    }\r\n    return '';\r\n  }\r\n}\r\n"]}
|
|
@@ -13,7 +13,7 @@ export class LineService {
|
|
|
13
13
|
return {
|
|
14
14
|
directoryNumber: lineAssociation ? this.generateLineDirectory(lineAssociation) : null,
|
|
15
15
|
didPattern: lineAssociation ? this.generateDidPatternForLineAssociation(lineAssociation) : null,
|
|
16
|
-
mappedDids: lineAssociation ?
|
|
16
|
+
mappedDids: lineAssociation ? lineAssociation.number : 'null',
|
|
17
17
|
index: lineAssociation ? lineAssociation.index : null,
|
|
18
18
|
position: lineAssociation ? lineAssociation.position : null,
|
|
19
19
|
textLabel: lineAssociation ? lineAssociation.textLabel : null,
|
|
@@ -73,4 +73,4 @@ LineService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version:
|
|
|
73
73
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: LineService, decorators: [{
|
|
74
74
|
type: Injectable
|
|
75
75
|
}], ctorParameters: function () { return [{ type: i1.APIService }]; } });
|
|
76
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
76
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"line.service.js","sourceRoot":"","sources":["../../../../../../../projects/tuki/widgets/user-device-manage/src/services/line.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { APIService } from './api.service';\r\nimport { LineAssociation } from './../classes/line-association';\r\nimport { API } from '../app.constants';\r\nimport { SortingUtilsService } from './sorting-utils.service';\r\nimport { Subject } from 'rxjs';\r\nimport { LineAssociationInterface } from './../classes/line-association-interface';\r\n\r\n@Injectable()\r\nexport class LineService {\r\n  line!: LineAssociation;\r\n  originLine!: LineAssociation;\r\n  currentActiveLinePkid!: string | null;\r\n  onSaveLineAssociationEvent = new Subject();\r\n\r\n  constructor(\r\n    private apiService: APIService\r\n  ) {\r\n\r\n  }\r\n  public generateLineAssociationFromLine(lineAssociation?: any) {\r\n   return {\r\n     directoryNumber: lineAssociation ? this.generateLineDirectory(lineAssociation) : null,\r\n     didPattern: lineAssociation ? this.generateDidPatternForLineAssociation(lineAssociation) : null,\r\n     mappedDids: lineAssociation ? lineAssociation.number : 'null',\r\n     index: lineAssociation ? lineAssociation.index : null,\r\n     position: lineAssociation ? lineAssociation.position : null,\r\n     textLabel: lineAssociation ? lineAssociation.textLabel : null,\r\n     // displayLabel: lineAssociation ? lineAssociation.displayLabel  : 'null',\r\n     alertingName: lineAssociation ? lineAssociation.alertingName : null,\r\n     callerNumber: lineAssociation ? '' : 'null'\r\n   }\r\n  }\r\n\r\n  hasUnsavedChanges(): boolean {\r\n    if (this.line && this.originLine) {\r\n      return JSON.stringify(this.line.getSavableData()) !== JSON.stringify(this.originLine.getSavableData())\r\n    }\r\n    return false;\r\n  }\r\n\r\n  generateLineDirectory(lineAssociation?: any): any {\r\n    return {\r\n      directoryNumber: lineAssociation.extension,\r\n      routePartitionName: lineAssociation.routePartitionName,\r\n    }\r\n  }\r\n\r\n  generateDidPatternForLineAssociation(lineAssociation?: any): any {\r\n    return {\r\n      calledPartyTransformationMask: lineAssociation.directoryNumber\r\n    }\r\n  }\r\n\r\n  public checkLineDeletion(line: LineAssociation, siteId: number): any {\r\n    const params = {\r\n      extension: line.directoryNumber.directoryNumber,\r\n      routePartition: line.directoryNumber.routePartitionName,\r\n    };\r\n    return this.apiService.fetch(API.CHECK_DELETE_LINE.replace(':siteId', String(siteId)), params)\r\n      // .pipe(this.handleError(true, true));\r\n  }\r\n\r\n  public deleteLine(siteId: number, pkid: string, token: string) {\r\n    return this.apiService.delete(API.DELETE_LINE.replace(':siteId', String(siteId)).replace(':pkid', pkid).replace(':token', encodeURIComponent(token)), {})\r\n    // .pipe(this.handleError(true, false));\r\n  }\r\n\r\n  public disassociateLine(siteId: number, linePkid: string, token: string, deviceName: string) {\r\n    return this.apiService.delete(\r\n      API.DISASSOCIATE_LINE.replace(':siteId', String(siteId))\r\n        .replace(':linePkid', linePkid)\r\n        .replace(':deviceName', deviceName)\r\n        .replace(':token', encodeURIComponent(token)), {})\r\n    // .pipe(this.handleError(true, false));\r\n  }\r\n\r\n  public updateLineFields(siteId: number, pkid: string, token: string, alertingName: any) {\r\n    const body = ['line.description=', `line.alertingName=${alertingName}`];\r\n    return this.apiService.post(API.UPDATE_LINE_FIELDS.replace(':siteId', String(siteId)).replace(':pkid', encodeURIComponent(pkid)).replace(':token', encodeURIComponent(token)), body)\r\n    // .pipe(this.handleError(true, false));\r\n  }\r\n\r\n  getLineAssociationBody(originLineAssociation: LineAssociation | LineAssociationInterface, lineAssociation: LineAssociation | LineAssociationInterface) {\r\n    const body = SortingUtilsService.diff(originLineAssociation.getSavableData(), lineAssociation.getSavableData(),\r\n      `device.lineAssociations.${lineAssociation.linePkid}`, null);\r\n    return body;\r\n  }\r\n}\r\n"]}
|