Alfresco Upload Component for Angular
Content
Components
- FileUploadingDialogComponent
- FileUploadingListComponent
- UploadButtonComponent
- UploadDragAreaComponent
Services
Directives
- FileDraggableDirective
Prerequisites
Before you start using this development framework, make sure you have installed all required software and done all the necessary configuration prerequisites.
Install
Follow the 3 steps below:
-
Npm
npm install ng2-alfresco-upload --save
-
Html
Include these dependencies in your index.html page:
<!-- Google Material Design Lite --> <link rel="stylesheet" href="node_modules/material-design-lite/material.min.css"> <script src="node_modules/material-design-lite/material.min.js"></script> <link rel="stylesheet" href="node_modules/material-design-icons/iconfont/material-icons.css"> <!-- Load the Angular Material 2 stylesheet --> <link href="node_modules/@angular/material/core/theming/prebuilt/deeppurple-amber.css" rel="stylesheet"> <!-- Polyfill(s) for Safari (pre-10.x) --> <script src="node_modules/intl/dist/Intl.min.js"></script> <script src="node_modules/intl/locale-data/jsonp/en.js"></script> <!-- Polyfill(s) for older browsers --> <script src="node_modules/core-js/client/shim.min.js"></script> <script src="//cdnjs.cloudflare.com/ajax/libs/dom4/1.8.3/dom4.js"></script> <script src="node_modules/element.scrollintoviewifneeded-polyfill/index.js"></script> <!-- Polyfill(s) for dialogs --> <script src="node_modules/dialog-polyfill/dialog-polyfill.js"></script> <link rel="stylesheet" type="text/css" href="node_modules/dialog-polyfill/dialog-polyfill.css" /> <style>._dialog_overlay { position: static !important; } </style> <!-- Modules --> <script src="node_modules/zone.js/dist/zone.js"></script> <script src="node_modules/reflect-metadata/Reflect.js"></script> <script src="node_modules/systemjs/dist/system.src.js"></script>
-
SystemJs
Add the following components to your systemjs.config.js file:
- ng2-translate
- alfresco-js-api
- ng2-alfresco-core
- ng2-alfresco-upload
Please refer to the following example file: systemjs.config.js .
UploadButtonComponent
<alfresco-upload-button
[rootFolderId]="-my-"
[uploadFolders]="true"
[multipleFiles]="false"
[acceptedFilesType]=".jpg,.gif,.png,.svg"
[versioning]="false"
(onSuccess)="customMethod($event)">
</alfresco-upload-button>
<file-uploading-dialog></file-uploading-dialog>
Events
Name | Description |
---|---|
onSuccess |
The event is emitted when the file is uploaded |
Properties
Name | Type | Default | Description |
---|---|---|---|
disabled |
boolean | false | Toggle component disabled state |
(deprecated) showNotificationBar |
boolean | true | Hide/show notification bar. Deprecated in 1.6.0: use UploadService events and NotificationService api instead. |
uploadFolders |
boolean | false | Allow/disallow upload folders (only for chrome) |
multipleFiles |
boolean | false | Allow/disallow multiple files |
acceptedFilesType |
string | * | array of allowed file extensions , example: ".jpg,.gif,.png,.svg" |
(deprecated) currentFolderPath |
string | '/Sites/swsdp/documentLibrary' | define the path where the files are uploaded. Deprecated in 1.6.0: use rootFolderId instead. |
rootFolderId |
string | '-root-' | The ID of the root folder node. |
versioning |
boolean | false | Versioning false is the default uploader behaviour and it rename using an integer suffix if there is a name clash. Versioning true to indicate that a major version should be created |
staticTitle |
string | 'FILE_UPLOAD.BUTTON.UPLOAD_FILE' or 'FILE_UPLOAD.BUTTON.UPLOAD_FOLDER' string in the JSON text file | define the text of the upload button |
disableWithNoPermission |
boolean | false | If the value is true and the user doesn't have the permission to delete the node the button will be disabled |
Advanced usage
How to show notification message with no permission
You can show a notification error when the user doesn't have the right permission to perform the action. The UploadButtonComponent provides the event permissionEvent that is raised when the delete permission is missing You can subscribe to this event from your component and use the NotificationService to show a message.
<alfresco-upload-button
[rootFolderId]="currentFolderId"
(permissionEvent)="onUploadPermissionFailed($event)">
</alfresco-upload-button>
export class MyComponent {
onUploadPermissionFailed(event: any) {
this.notificationService.openSnackMessage(
`you don't have the ${event.permission} permission to ${event.action} the ${event.type} `, 4000
);
}
}
How to disable the button when the delete permission is missing
You can easily disable the button when the user doesn't own the permission to perform the action. The UploadButtonComponent provides the property disableWithNoPermission that can be true. In this way the button should be disabled if the delete permission is missing for the node.
<alfresco-upload-button
[rootFolderId]="currentFolderId"
[disableWithNoPermission]="true">
</alfresco-upload-button>
UploadDragAreaComponent
This component, provide a drag and drop are to upload files to alfresco.
<alfresco-upload-drag-area (onSuccess)="customMethod($event)">
<div style="width: 200px; height: 100px; border: 1px solid #888888">
DRAG HERE
</div>
</alfresco-upload-drag-area>
<file-uploading-dialog></file-uploading-dialog>
export class AppComponent {
public onSuccess(event: Object): void {
console.log('File uploaded');
}
}
Events
Name | Description |
---|---|
onSuccess |
The event is emitted when the file is uploaded |
Properties
Name | Type | Default | Description |
---|---|---|---|
enabled |
boolean | true | Toggle component enabled state |
(deprecated) showNotificationBar |
boolean | true | Hide/show notification bar. Deprecated in 1.6.0: use UploadService events and NotificationService api instead. |
rootFolderId |
string | '-root-' | The ID of the root folder node. |
(deprecated) currentFolderPath |
string | '/' | define the path where the files are uploaded. Deprecated in 1.6.0: use rootFolderId instead. |
versioning |
boolean | false | Versioning false is the default uploader behaviour and it rename using an integer suffix if there is a name clash. Versioning true to indicate that a major version should be created |
FileUploadingDialogComponent
This component provides a dialog that shows all the files uploaded with upload button or drag & drop area components. This component should be used in combination with upload button or drag & drop area.
<file-uploading-dialog></file-uploading-dialog>
UploadService
Provides access to various APIs related to file upload features.
Events
Name | Type | Description |
---|---|---|
queueChanged | FileModel[] | Raised every time the file queue changes. |
fileUpload | FileUploadEvent | Raised every time a File model changes its state. |
fileUploadStarting | FileUploadEvent | Raised when upload starts. |
fileUploadCancelled | FileUploadEvent | Raised when upload gets cancelled by user. |
fileUploadProgress | FileUploadEvent | Raised during file upload process and contains the current progress for the particular File model. |
fileUploadAborted | FileUploadEvent | Raised when file upload gets aborted by the server. |
fileUploadError | FileUploadEvent | Raised when an error occurs to file upload. |
fileUploadComplete | FileUploadCompleteEvent | Raised when file upload is complete. |
Build from sources
Alternatively you can build component from sources with the following commands:
npm install
npm run build
Running unit tests
npm test
Running unit tests in browser
npm test-browser
This task rebuilds all the code, runs tslint, license checks and other quality check tools before performing unit testing.
Code coverage
npm run coverage
Demo
If you want have a demo of how the component works, please check the demo folder :
cd demo
npm install
npm start
NPM scripts
Command | Description |
---|---|
npm run build | Build component |
npm run test | Run unit tests in the console |
npm run test-browser | Run unit tests in the browser |
npm run coverage | Run unit tests and display code coverage report |