Denys Vuika e4b9cf3dbe
ACS-7390: Migrating content components to Standalone (#9997)
* ACS-7393: content metadata as standalone

* ACS-7408: version manager as standalone

* ACS-7408: version manager as standalone

* ACS-7408: version manager as standalone

* ACS-7407: upload as standalone

* ACS-7404: tag as standalone

* ACS-7404: tag as standalone

* ACS-7401: permission manager as standalone

* ACS-7395: content node share as standalone

* ACS-7402: search components [ci:force]

* ACS-7402: search components [ci:force]

* content node selector panel

* content node selector panel

* Revert "content node selector panel"

This reverts commit 3ad828e443a51b9c058f97d3c9090ed0f5b2519f.

* Revert "content node selector panel"

This reverts commit 5a2cd5a5b32bed1ad0b0ca6004c39aaaac751b42.
2024-07-26 11:04:02 -04:00

171 lines
5.2 KiB
TypeScript

/*!
* @license
* Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, ViewEncapsulation } from '@angular/core';
import { Node, Version } from '@alfresco/js-api';
import { Subject } from 'rxjs';
import { takeUntil } from 'rxjs/operators';
import { ContentService } from '../common/services/content.service';
import { UploadService } from '../common/services/upload.service';
import { FileUploadErrorEvent, FileUploadEvent } from '../common/events/file.event';
import { CommonModule } from '@angular/common';
import { MatRadioModule } from '@angular/material/radio';
import { FormsModule } from '@angular/forms';
import { TranslateModule } from '@ngx-translate/core';
import { MatFormFieldModule } from '@angular/material/form-field';
import { MatInputModule } from '@angular/material/input';
import { MatButtonModule } from '@angular/material/button';
import { UploadVersionButtonComponent } from '../upload';
@Component({
selector: 'adf-version-upload',
standalone: true,
imports: [
CommonModule,
MatRadioModule,
FormsModule,
TranslateModule,
MatFormFieldModule,
MatInputModule,
MatButtonModule,
UploadVersionButtonComponent
],
templateUrl: './version-upload.component.html',
styleUrls: ['./version-upload.component.scss'],
encapsulation: ViewEncapsulation.None,
host: { class: 'adf-version-upload' }
})
export class VersionUploadComponent implements OnInit, OnDestroy {
semanticVersion: string = 'minor';
comment: string;
uploadVersion: boolean = false;
disabled: boolean = false;
onDestroy$ = new Subject<void>();
majorVersion = '2.0';
minorVersion = '1.1';
/** The target node. */
@Input()
node: Node;
/** New file for updating current version. */
@Input()
newFileVersion: File;
/** Toggles showing/hiding upload button. */
@Input()
showUploadButton: boolean = true;
/** Toggles showing/hiding of cancel button. */
@Input()
showCancelButton: boolean = true;
/** Current version for a target node */
@Input()
set currentVersion(version: Version) {
if (version) {
this.minorVersion = this.getNextMinorVersion(version.id);
this.majorVersion = this.getNextMajorVersion(version.id);
}
}
/** Emitted when the file is uploaded successfully. */
@Output()
success = new EventEmitter();
/** Emitted when an error occurs. */
@Output()
error = new EventEmitter<FileUploadErrorEvent>();
/** Emitted when an cancelling during upload. */
@Output()
cancel = new EventEmitter();
/** Emitted when the version is changed. */
@Output()
versionChanged = new EventEmitter<boolean>();
/** Emitted when the comment is changed. */
@Output()
commentChanged = new EventEmitter<string>();
/** Emitted when the upload starts */
@Output()
uploadStarted = new EventEmitter<FileUploadEvent>();
constructor(private contentService: ContentService, private uploadService: UploadService) {}
ngOnInit() {
this.uploadService.fileUploadStarting.pipe(takeUntil(this.onDestroy$)).subscribe((event: FileUploadEvent) => {
this.disabled = true;
this.uploadStarted.emit(event);
});
}
canUpload(): boolean {
return this.contentService.hasAllowableOperations(this.node, 'update') && !this.disabled;
}
isMajorVersion(): boolean {
return this.semanticVersion !== 'minor';
}
cancelUpload() {
this.disabled = false;
this.cancel.emit();
}
onVersionChange() {
this.versionChanged.emit(this.isMajorVersion());
}
onCommentChange() {
this.commentChanged.emit(this.comment);
}
onSuccess(event: any) {
this.disabled = false;
this.success.emit(event);
}
onError(event: FileUploadErrorEvent) {
this.disabled = false;
this.error.emit(event);
}
ngOnDestroy() {
this.onDestroy$.next(undefined);
this.onDestroy$.complete();
}
getNextMinorVersion(version: string): string {
const { major, minor } = this.getParsedVersion(version);
return `${major}.${minor + 1}`;
}
getNextMajorVersion(version: string): string {
const { major } = this.getParsedVersion(version);
return `${major + 1}.0`;
}
private getParsedVersion(version: string) {
const minor = version.indexOf('.') !== -1 ? Number(version.substr(version.indexOf('.') + 1)) : 0;
const major = parseInt(version, 10);
return { minor, major };
}
}