mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-05-12 17:04:46 +00:00
* ACA-4709 Added use-none-component-view-encapsulation eslint rule and correct part of components * ACA-4709 More changes for encapsulation * ACA-4709 Installed eslint-plugin-eslint-angular dependency * ACA-4709 Corrected rest places with did not use none encapsulation * ACA-4709 Exclude process inline templates plugin from spec files
84 lines
3.1 KiB
TypeScript
84 lines
3.1 KiB
TypeScript
/*!
|
|
* Copyright © 2005-2023 Hyland Software, Inc. and its affiliates. All rights reserved.
|
|
*
|
|
* Alfresco Example Content Application
|
|
*
|
|
* This file is part of the Alfresco Example Content Application.
|
|
* If the software was purchased under a paid Alfresco license, the terms of
|
|
* the paid license agreement will prevail. Otherwise, the software is
|
|
* provided under the following open source license terms:
|
|
*
|
|
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
* (at your option) any later version.
|
|
*
|
|
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU Lesser General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
* from Hyland Software. If not, see <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { Component, Input, OnDestroy, OnInit, ViewEncapsulation } from '@angular/core';
|
|
import { Observable, Subject } from 'rxjs';
|
|
import { Store } from '@ngrx/store';
|
|
import { SelectionState } from '@alfresco/adf-extensions';
|
|
import { AppStore, ShareNodeAction, getAppSelection } from '@alfresco/aca-shared/store';
|
|
import { CommonModule } from '@angular/common';
|
|
import { MatMenuModule } from '@angular/material/menu';
|
|
import { MatIconModule } from '@angular/material/icon';
|
|
import { TranslateModule } from '@ngx-translate/core';
|
|
import { MatButtonModule } from '@angular/material/button';
|
|
import { takeUntil } from 'rxjs/operators';
|
|
|
|
@Component({
|
|
standalone: true,
|
|
imports: [CommonModule, MatMenuModule, MatIconModule, TranslateModule, MatButtonModule],
|
|
selector: 'app-toggle-shared',
|
|
templateUrl: './toggle-shared.component.html',
|
|
encapsulation: ViewEncapsulation.None
|
|
})
|
|
export class ToggleSharedComponent implements OnInit, OnDestroy {
|
|
@Input()
|
|
data: {
|
|
iconButton?: string;
|
|
};
|
|
|
|
selection$: Observable<SelectionState>;
|
|
selectionState: SelectionState;
|
|
selectionLabel = '';
|
|
isShared = false;
|
|
|
|
onDestroy$ = new Subject<void>();
|
|
|
|
constructor(private store: Store<AppStore>) {}
|
|
|
|
ngOnInit() {
|
|
this.selection$ = this.store.select(getAppSelection);
|
|
this.selection$.pipe(takeUntil(this.onDestroy$)).subscribe((selectionState) => {
|
|
this.selectionState = selectionState;
|
|
|
|
this.isShared =
|
|
(this.selectionState.first && this.selectionState.first.entry && (this.selectionState.first.entry as any).sharedByUser) ||
|
|
!!this.selectionState?.first?.entry?.properties?.['qshare:sharedId'];
|
|
|
|
this.selectionLabel = this.isShared ? 'APP.ACTIONS.SHARE_EDIT' : 'APP.ACTIONS.SHARE';
|
|
});
|
|
}
|
|
|
|
ngOnDestroy(): void {
|
|
this.onDestroy$.next();
|
|
this.onDestroy$.complete();
|
|
}
|
|
editSharedNode(selection: SelectionState, focusedElementOnCloseSelector: string) {
|
|
this.store.dispatch(
|
|
new ShareNodeAction(selection.first, {
|
|
focusedElementOnCloseSelector
|
|
})
|
|
);
|
|
}
|
|
}
|