import { Directive, EventEmitter, Input, OnInit, Output, } from '@angular/core'; import { CipherService } from 'jslib-common/abstractions/cipher.service'; import { CollectionService } from 'jslib-common/abstractions/collection.service'; import { I18nService } from 'jslib-common/abstractions/i18n.service'; import { LogService } from 'jslib-common/abstractions/log.service'; import { PlatformUtilsService } from 'jslib-common/abstractions/platformUtils.service'; import { CipherView } from 'jslib-common/models/view/cipherView'; import { CollectionView } from 'jslib-common/models/view/collectionView'; import { Cipher } from 'jslib-common/models/domain/cipher'; @Directive() export class CollectionsComponent implements OnInit { @Input() cipherId: string; @Input() allowSelectNone = false; @Output() onSavedCollections = new EventEmitter(); formPromise: Promise; cipher: CipherView; collectionIds: string[]; collections: CollectionView[] = []; protected cipherDomain: Cipher; constructor(protected collectionService: CollectionService, protected platformUtilsService: PlatformUtilsService, protected i18nService: I18nService, protected cipherService: CipherService, private logService: LogService) { } async ngOnInit() { await this.load(); } async load() { this.cipherDomain = await this.loadCipher(); this.collectionIds = this.loadCipherCollections(); this.cipher = await this.cipherDomain.decrypt(); this.collections = await this.loadCollections(); this.collections.forEach(c => (c as any).checked = false); if (this.collectionIds != null) { this.collections.forEach(c => { (c as any).checked = this.collectionIds != null && this.collectionIds.indexOf(c.id) > -1; }); } } async submit() { const selectedCollectionIds = this.collections .filter(c => !!(c as any).checked) .map(c => c.id); if (!this.allowSelectNone && selectedCollectionIds.length === 0) { this.platformUtilsService.showToast('error', this.i18nService.t('errorOccurred'), this.i18nService.t('selectOneCollection')); return; } this.cipherDomain.collectionIds = selectedCollectionIds; try { this.formPromise = this.saveCollections(); await this.formPromise; this.onSavedCollections.emit(); this.platformUtilsService.showToast('success', null, this.i18nService.t('editedItem')); } catch (e) { this.logService.error(e); } } protected loadCipher() { return this.cipherService.get(this.cipherId); } protected loadCipherCollections() { return this.cipherDomain.collectionIds; } protected async loadCollections() { const allCollections = await this.collectionService.getAllDecrypted(); return allCollections.filter(c => !c.readOnly && c.organizationId === this.cipher.organizationId); } protected saveCollections() { return this.cipherService.saveCollectionsWithServer(this.cipherDomain); } }