UNPKG

@c8y/ngx-components

Version:

Angular modules for Cumulocity IoT applications

82 lines 12 kB
import { Injectable } from '@angular/core'; import { gettext, OptionsService, UserPreferencesService } from '@c8y/ngx-components'; import { TranslateService } from '@ngx-translate/core'; import { uniqBy } from 'lodash-es'; import { firstValueFrom, map } from 'rxjs'; import * as i0 from "@angular/core"; import * as i1 from "@ngx-translate/core"; import * as i2 from "@c8y/ngx-components"; export class BookmarkService { constructor(translateService, userPreferencesService, options) { this.translateService = translateService; this.userPreferencesService = userPreferencesService; this.options = options; this.USER_PREFERENCES_BOOKMARKS_KEY = 'bookmarks'; } async updateBookmarksInStorage(newBookmarks) { const existingBookmarks = await this.getBookmarks(); const mergedBookmarks = [...newBookmarks, ...existingBookmarks]; const cleanedBookmarks = uniqBy(mergedBookmarks, 'id').filter((bookmark) => !bookmark.markToRemove); this.setUserPreferencesBookmarks(cleanedBookmarks); } getCurrentActiveNodeIcon(document) { const BOOKMARK = 'bookmark'; const iconElement = this.getIconElement(document); if (!iconElement) { return BOOKMARK; } const iconClassName = iconElement.className; const iconName = this.extractIconName(iconClassName); return iconName || BOOKMARK; } extractIconName(input) { const iconRegex = /\b(dlt-)?c8y-icon-(\w+(?:-\w+)*)\b/g; const matches = [...input.matchAll(iconRegex)]; const match = matches?.pop(); if (!match) { return null; } const [, prefix, name] = match; return prefix ? name : `c8y-${name}`; } async getBookmarks() { return await firstValueFrom(this.userPreferencesService .get(this.USER_PREFERENCES_BOOKMARKS_KEY) .pipe(map((bookmarks) => bookmarks ?? []))); } generateRandomID() { const array = new Uint8Array(16); crypto.getRandomValues(array); return Array.from(array, byte => byte.toString(16).padStart(2, '0')).join(''); } convertBookmarkLinkToObject(title, url, icon) { const globalTitle = this.options.globalTitle ?? 'Cumulocity'; return { id: this.generateRandomID(), label: title.includes(globalTitle) ? title.replace(`${globalTitle} - `, '') : this.translateService.instant(gettext('Bookmark')), url, icon }; } getIconElement(document) { const currentActiveNode = document.querySelectorAll('.link.active'); if (!currentActiveNode.length) { return null; } const activeNode = currentActiveNode.item(0); return activeNode.firstElementChild.firstChild; } setUserPreferencesBookmarks(bookmarks) { this.userPreferencesService.set(this.USER_PREFERENCES_BOOKMARKS_KEY, bookmarks); this.updatedBookmarks = bookmarks; } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BookmarkService, deps: [{ token: i1.TranslateService }, { token: i2.UserPreferencesService }, { token: i2.OptionsService }], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BookmarkService, providedIn: 'root' }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: BookmarkService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: () => [{ type: i1.TranslateService }, { type: i2.UserPreferencesService }, { type: i2.OptionsService }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bookmarks.service.js","sourceRoot":"","sources":["../../../bookmarks/bookmarks.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { gettext, OptionsService, UserPreferencesService } from '@c8y/ngx-components';\nimport { TranslateService } from '@ngx-translate/core';\nimport { uniqBy } from 'lodash-es';\nimport { firstValueFrom, map } from 'rxjs';\nimport { Bookmark } from './bookmark.model';\n\n@Injectable({ providedIn: 'root' })\nexport class BookmarkService {\n  readonly USER_PREFERENCES_BOOKMARKS_KEY = 'bookmarks';\n\n  updatedBookmarks: Bookmark[];\n\n  constructor(\n    private translateService: TranslateService,\n    private userPreferencesService: UserPreferencesService,\n    private options: OptionsService\n  ) {}\n\n  async updateBookmarksInStorage(newBookmarks: Bookmark[]): Promise<void> {\n    const existingBookmarks = await this.getBookmarks();\n    const mergedBookmarks = [...newBookmarks, ...existingBookmarks];\n    const cleanedBookmarks = uniqBy(mergedBookmarks, 'id').filter(\n      (bookmark: Bookmark) => !bookmark.markToRemove\n    );\n\n    this.setUserPreferencesBookmarks(cleanedBookmarks);\n  }\n\n  getCurrentActiveNodeIcon(document: Document): string {\n    const BOOKMARK = 'bookmark';\n\n    const iconElement = this.getIconElement(document);\n\n    if (!iconElement) {\n      return BOOKMARK;\n    }\n\n    const iconClassName = iconElement.className;\n    const iconName = this.extractIconName(iconClassName);\n    return iconName || BOOKMARK;\n  }\n\n  extractIconName(input: string): string | null {\n    const iconRegex = /\\b(dlt-)?c8y-icon-(\\w+(?:-\\w+)*)\\b/g;\n    const matches = [...input.matchAll(iconRegex)];\n    const match = matches?.pop();\n\n    if (!match) {\n      return null;\n    }\n    const [, prefix, name] = match;\n\n    return prefix ? name : `c8y-${name}`;\n  }\n\n  async getBookmarks(): Promise<Bookmark[]> {\n    return await firstValueFrom(\n      this.userPreferencesService\n        .get(this.USER_PREFERENCES_BOOKMARKS_KEY)\n        .pipe(map((bookmarks: Bookmark[]) => bookmarks ?? []))\n    );\n  }\n\n  generateRandomID() {\n    const array = new Uint8Array(16);\n    crypto.getRandomValues(array);\n\n    return Array.from(array, byte => byte.toString(16).padStart(2, '0')).join('');\n  }\n\n  convertBookmarkLinkToObject(title: string, url: string, icon: string): Bookmark {\n    const globalTitle = this.options.globalTitle ?? 'Cumulocity';\n    return {\n      id: this.generateRandomID(),\n      label: title.includes(globalTitle)\n        ? title.replace(`${globalTitle} - `, '')\n        : this.translateService.instant(gettext('Bookmark')),\n      url,\n      icon\n    };\n  }\n\n  private getIconElement(document: Document): HTMLElement | null {\n    const currentActiveNode = document.querySelectorAll('.link.active') as NodeList;\n    if (!currentActiveNode.length) {\n      return null;\n    }\n    const activeNode = currentActiveNode.item(0) as HTMLElement;\n    return activeNode.firstElementChild.firstChild as HTMLElement;\n  }\n\n  private setUserPreferencesBookmarks(bookmarks: Bookmark[]): void {\n    this.userPreferencesService.set(this.USER_PREFERENCES_BOOKMARKS_KEY, bookmarks);\n    this.updatedBookmarks = bookmarks;\n  }\n}\n"]}