mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-31 17:38:48 +00:00
[ADF-640] reload document list on folder upload (#1895)
* reload document list on folder upload - extend UploadService with 'folderCreated' event to be able reacting on folder uploads globally - extend Demo Shell to reload document list on UploadService events (folderCreated) * readme updates
This commit is contained in:
committed by
Eugenio Romano
parent
9bb7d90670
commit
d8a46c9765
@@ -20,7 +20,7 @@ import { ActivatedRoute, Params, Router } from '@angular/router';
|
|||||||
import { AlfrescoAuthenticationService, LogService, NotificationService } from 'ng2-alfresco-core';
|
import { AlfrescoAuthenticationService, LogService, NotificationService } from 'ng2-alfresco-core';
|
||||||
import { DocumentActionsService, DocumentListComponent, ContentActionHandler, DocumentActionModel, FolderActionModel } from 'ng2-alfresco-documentlist';
|
import { DocumentActionsService, DocumentListComponent, ContentActionHandler, DocumentActionModel, FolderActionModel } from 'ng2-alfresco-documentlist';
|
||||||
import { FormService } from 'ng2-activiti-form';
|
import { FormService } from 'ng2-activiti-form';
|
||||||
import { UploadButtonComponent, UploadDragAreaComponent } from 'ng2-alfresco-upload';
|
import { UploadService, UploadButtonComponent, UploadDragAreaComponent, FolderCreatedEvent } from 'ng2-alfresco-upload';
|
||||||
|
|
||||||
@Component({
|
@Component({
|
||||||
selector: 'files-component',
|
selector: 'files-component',
|
||||||
@@ -72,6 +72,7 @@ export class FilesComponent implements OnInit, AfterViewInit {
|
|||||||
private changeDetector: ChangeDetectorRef,
|
private changeDetector: ChangeDetectorRef,
|
||||||
private router: Router,
|
private router: Router,
|
||||||
private notificationService: NotificationService,
|
private notificationService: NotificationService,
|
||||||
|
private uploadService: UploadService,
|
||||||
@Optional() private route: ActivatedRoute) {
|
@Optional() private route: ActivatedRoute) {
|
||||||
documentActions.setHandler('my-handler', this.myDocumentActionHandler.bind(this));
|
documentActions.setHandler('my-handler', this.myDocumentActionHandler.bind(this));
|
||||||
}
|
}
|
||||||
@@ -120,6 +121,8 @@ export class FilesComponent implements OnInit, AfterViewInit {
|
|||||||
} else {
|
} else {
|
||||||
this.logService.warn('You are not logged in to BPM');
|
this.logService.warn('You are not logged in to BPM');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
this.uploadService.folderCreated.subscribe(value => this.onFolderCreated(value));
|
||||||
}
|
}
|
||||||
|
|
||||||
ngAfterViewInit() {
|
ngAfterViewInit() {
|
||||||
@@ -170,6 +173,14 @@ export class FilesComponent implements OnInit, AfterViewInit {
|
|||||||
}.bind(this);
|
}.bind(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
onFolderCreated(event: FolderCreatedEvent) {
|
||||||
|
console.log('FOLDER CREATED');
|
||||||
|
console.log(event);
|
||||||
|
if (event && event.parentId === this.documentList.currentFolderId) {
|
||||||
|
this.documentList.reload();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
onPermissionsFailed(event: any) {
|
onPermissionsFailed(event: any) {
|
||||||
this.notificationService.openSnackMessage(`you don't have the ${event.permission} permission to ${event.action} the ${event.type} `, 4000);
|
this.notificationService.openSnackMessage(`you don't have the ${event.permission} permission to ${event.action} the ${event.type} `, 4000);
|
||||||
}
|
}
|
||||||
|
@@ -307,6 +307,16 @@ This component should be used in combination with upload button or drag & drop a
|
|||||||
<file-uploading-dialog></file-uploading-dialog>
|
<file-uploading-dialog></file-uploading-dialog>
|
||||||
```
|
```
|
||||||
|
|
||||||
|
### UploadService service
|
||||||
|
|
||||||
|
Provides access to various APIs related to file upload features.
|
||||||
|
|
||||||
|
#### Events
|
||||||
|
|
||||||
|
| Name | Type | Description |
|
||||||
|
| --- | --- | --- |
|
||||||
|
| folderCreated | FolderCreatedEvent | Raised when dropped folder gets created |
|
||||||
|
|
||||||
## Build from sources
|
## Build from sources
|
||||||
|
|
||||||
Alternatively you can build component from sources with the following commands:
|
Alternatively you can build component from sources with the following commands:
|
||||||
|
@@ -49,6 +49,7 @@ export * from './src/directives/file-draggable.directive';
|
|||||||
export * from './src/components/file-uploading-list.component';
|
export * from './src/components/file-uploading-list.component';
|
||||||
export * from './src/models/file.model';
|
export * from './src/models/file.model';
|
||||||
export * from './src/models/permissions.model';
|
export * from './src/models/permissions.model';
|
||||||
|
export * from './src/events/folder-created.event';
|
||||||
|
|
||||||
export const UPLOAD_DIRECTIVES: any[] = [
|
export const UPLOAD_DIRECTIVES: any[] = [
|
||||||
FileDraggableDirective,
|
FileDraggableDirective,
|
||||||
|
@@ -0,0 +1,27 @@
|
|||||||
|
/*!
|
||||||
|
* @license
|
||||||
|
* Copyright 2016 Alfresco Software, Ltd.
|
||||||
|
*
|
||||||
|
* 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 { MinimalNodeEntity } from 'alfresco-js-api';
|
||||||
|
|
||||||
|
export interface FolderCreatedEvent {
|
||||||
|
|
||||||
|
name: string;
|
||||||
|
relativePath?: string;
|
||||||
|
parentId?: string;
|
||||||
|
node?: MinimalNodeEntity;
|
||||||
|
|
||||||
|
}
|
@@ -17,8 +17,9 @@
|
|||||||
|
|
||||||
import { EventEmitter, Injectable } from '@angular/core';
|
import { EventEmitter, Injectable } from '@angular/core';
|
||||||
import { Response } from '@angular/http';
|
import { Response } from '@angular/http';
|
||||||
import { Observer, Observable } from 'rxjs/Rx';
|
import { Observer, Observable, Subject } from 'rxjs/Rx';
|
||||||
import { AlfrescoApiService, LogService } from 'ng2-alfresco-core';
|
import { AlfrescoApiService, LogService } from 'ng2-alfresco-core';
|
||||||
|
import { FolderCreatedEvent } from '../events/folder-created.event';
|
||||||
import { FileModel } from '../models/file.model';
|
import { FileModel } from '../models/file.model';
|
||||||
import { MinimalNodeEntity, MinimalNodeEntryEntity } from 'alfresco-js-api';
|
import { MinimalNodeEntity, MinimalNodeEntryEntity } from 'alfresco-js-api';
|
||||||
|
|
||||||
@@ -39,6 +40,8 @@ export class UploadService {
|
|||||||
filesUpload$: Observable<FileModel[]>;
|
filesUpload$: Observable<FileModel[]>;
|
||||||
totalCompleted$: Observable<any>;
|
totalCompleted$: Observable<any>;
|
||||||
|
|
||||||
|
folderCreated: Subject<FolderCreatedEvent> = new Subject<FolderCreatedEvent>();
|
||||||
|
|
||||||
constructor(private apiService: AlfrescoApiService,
|
constructor(private apiService: AlfrescoApiService,
|
||||||
private logService: LogService) {
|
private logService: LogService) {
|
||||||
this.filesUpload$ = new Observable<FileModel[]>(observer => this.filesUploadObserverProgressBar = observer).share();
|
this.filesUpload$ = new Observable<FileModel[]>(observer => this.filesUploadObserverProgressBar = observer).share();
|
||||||
@@ -134,9 +137,16 @@ export class UploadService {
|
|||||||
* Create a folder
|
* Create a folder
|
||||||
* @param name - the folder name
|
* @param name - the folder name
|
||||||
*/
|
*/
|
||||||
createFolder(relativePath: string, name: string, parentId?: string) {
|
createFolder(relativePath: string, name: string, parentId?: string): Observable<MinimalNodeEntity> {
|
||||||
return Observable.fromPromise(this.callApiCreateFolder(relativePath, name, parentId))
|
return Observable.fromPromise(this.callApiCreateFolder(relativePath, name, parentId))
|
||||||
.do(data => this.logService.info('Node data', data)) // eyeball results in the console
|
.do(data => {
|
||||||
|
this.folderCreated.next({
|
||||||
|
relativePath: relativePath,
|
||||||
|
name: name,
|
||||||
|
parentId: parentId,
|
||||||
|
node: data
|
||||||
|
});
|
||||||
|
})
|
||||||
.catch(err => this.handleError(err));
|
.catch(err => this.handleError(err));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user