mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-05-26 17:24:56 +00:00
#152 Support for custom 'empty folder' template
- default background image for empty folders - support for user-defined custom templates - readme updated
This commit is contained in:
parent
4784740108
commit
e0d8b1fe31
@ -9,6 +9,13 @@
|
|||||||
[breadcrumb]="breadcrumb"
|
[breadcrumb]="breadcrumb"
|
||||||
(itemClick)="showFile($event)"
|
(itemClick)="showFile($event)"
|
||||||
(folderChange)="onFolderChanged($event)">
|
(folderChange)="onFolderChanged($event)">
|
||||||
|
<!--
|
||||||
|
<empty-folder-content>
|
||||||
|
<template>
|
||||||
|
<h1>Sorry, no content here</h1>
|
||||||
|
</template>
|
||||||
|
</empty-folder-content>
|
||||||
|
-->
|
||||||
<content-columns>
|
<content-columns>
|
||||||
<content-column source="$thumbnail"></content-column>
|
<content-column source="$thumbnail"></content-column>
|
||||||
<content-column
|
<content-column
|
||||||
|
@ -458,6 +458,29 @@ export class MyView {
|
|||||||
|
|
||||||
## Advanced usage and customization
|
## Advanced usage and customization
|
||||||
|
|
||||||
|
### Custom 'empty folder' template
|
||||||
|
|
||||||
|
By default Document List provides the following content for the empty folder:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
This can be changed by means of the custom html template:
|
||||||
|
|
||||||
|
```html
|
||||||
|
<alfresco-document-list ...>
|
||||||
|
<empty-folder-content>
|
||||||
|
<template>
|
||||||
|
<h1>Sorry, no content here</h1>
|
||||||
|
</template>
|
||||||
|
</empty-folder-content>
|
||||||
|
</alfresco-document-list>
|
||||||
|
```
|
||||||
|
|
||||||
|
That will give the following output:
|
||||||
|
|
||||||
|

|
||||||
|
|
||||||
|
|
||||||
### Customizing default actions
|
### Customizing default actions
|
||||||
|
|
||||||
It is possible extending or replacing the list of available system actions for documents and folders.
|
It is possible extending or replacing the list of available system actions for documents and folders.
|
||||||
|
Binary file not shown.
After Width: | Height: | Size: 61 KiB |
Binary file not shown.
After Width: | Height: | Size: 198 KiB |
@ -20,6 +20,7 @@ import { ContentColumn } from './src/components/content-column';
|
|||||||
import { ContentColumnList } from './src/components/content-column-list';
|
import { ContentColumnList } from './src/components/content-column-list';
|
||||||
import { ContentAction } from './src/components/content-action';
|
import { ContentAction } from './src/components/content-action';
|
||||||
import { ContentActionList } from './src/components/content-action-list';
|
import { ContentActionList } from './src/components/content-action-list';
|
||||||
|
import { EmptyFolderContent } from './src/components/empty-folder-content';
|
||||||
|
|
||||||
import { FolderActionsService } from './src/services/folder-actions.service';
|
import { FolderActionsService } from './src/services/folder-actions.service';
|
||||||
import { DocumentActionsService } from './src/services/document-actions.service';
|
import { DocumentActionsService } from './src/services/document-actions.service';
|
||||||
@ -31,6 +32,7 @@ export * from './src/components/content-column';
|
|||||||
export * from './src/components/content-column-list';
|
export * from './src/components/content-column-list';
|
||||||
export * from './src/components/content-action';
|
export * from './src/components/content-action';
|
||||||
export * from './src/components/content-action-list';
|
export * from './src/components/content-action-list';
|
||||||
|
export * from './src/components/empty-folder-content';
|
||||||
|
|
||||||
// models
|
// models
|
||||||
export * from './src/models/column-sorting.model';
|
export * from './src/models/column-sorting.model';
|
||||||
@ -60,7 +62,8 @@ export const DOCUMENT_LIST_DIRECTIVES: [any] = [
|
|||||||
ContentColumn,
|
ContentColumn,
|
||||||
ContentColumnList,
|
ContentColumnList,
|
||||||
ContentAction,
|
ContentAction,
|
||||||
ContentActionList
|
ContentActionList,
|
||||||
|
EmptyFolderContent
|
||||||
];
|
];
|
||||||
|
|
||||||
export const DOCUMENT_LIST_PROVIDERS: [any] = [
|
export const DOCUMENT_LIST_PROVIDERS: [any] = [
|
||||||
|
@ -64,6 +64,10 @@
|
|||||||
color: #777;
|
color: #777;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
:host .empty-folder-content > img {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
/* Utils */
|
/* Utils */
|
||||||
|
|
||||||
:host .sr-only {
|
:host .sr-only {
|
||||||
|
Binary file not shown.
After Width: | Height: | Size: 226 KiB |
@ -100,5 +100,18 @@
|
|||||||
</ul>
|
</ul>
|
||||||
</td>
|
</td>
|
||||||
</tr>
|
</tr>
|
||||||
|
|
||||||
|
<tr *ngIf="folder?.list?.entries?.length === 0">
|
||||||
|
<td class="mdl-data-table__cell--non-numeric empty-folder-content"
|
||||||
|
[attr.colspan]="1 + columns?.length">
|
||||||
|
<template *ngIf="emptyFolderTemplate"
|
||||||
|
ngFor [ngForOf]="[folder]"
|
||||||
|
[ngForTemplate]="emptyFolderTemplate">
|
||||||
|
</template>
|
||||||
|
<img *ngIf="!emptyFolderTemplate"
|
||||||
|
[src]="__baseUrl + '/document-list.empty-folder.png'">
|
||||||
|
</td>
|
||||||
|
</tr>
|
||||||
|
|
||||||
</tbody>
|
</tbody>
|
||||||
</table>
|
</table>
|
||||||
|
@ -23,7 +23,8 @@ import {
|
|||||||
EventEmitter,
|
EventEmitter,
|
||||||
AfterContentInit,
|
AfterContentInit,
|
||||||
AfterViewChecked,
|
AfterViewChecked,
|
||||||
OnChanges
|
OnChanges,
|
||||||
|
TemplateRef
|
||||||
} from 'angular2/core';
|
} from 'angular2/core';
|
||||||
import { AlfrescoService } from './../services/alfresco.service';
|
import { AlfrescoService } from './../services/alfresco.service';
|
||||||
import { MinimalNodeEntity, NodePaging } from './../models/document-library.model';
|
import { MinimalNodeEntity, NodePaging } from './../models/document-library.model';
|
||||||
@ -45,6 +46,8 @@ export class DocumentList implements OnInit, AfterViewChecked, AfterContentInit,
|
|||||||
|
|
||||||
DEFAULT_ROOT_FOLDER: string = '/Sites/swsdp/documentLibrary';
|
DEFAULT_ROOT_FOLDER: string = '/Sites/swsdp/documentLibrary';
|
||||||
|
|
||||||
|
__baseUrl = __moduleName.replace('/document-list.js', '');
|
||||||
|
|
||||||
@Input()
|
@Input()
|
||||||
navigate: boolean = true;
|
navigate: boolean = true;
|
||||||
|
|
||||||
@ -73,6 +76,7 @@ export class DocumentList implements OnInit, AfterViewChecked, AfterContentInit,
|
|||||||
|
|
||||||
actions: ContentActionModel[] = [];
|
actions: ContentActionModel[] = [];
|
||||||
columns: ContentColumnModel[] = [];
|
columns: ContentColumnModel[] = [];
|
||||||
|
emptyFolderTemplate: TemplateRef;
|
||||||
|
|
||||||
private _folder: NodePaging;
|
private _folder: NodePaging;
|
||||||
|
|
||||||
|
@ -0,0 +1,45 @@
|
|||||||
|
/*!
|
||||||
|
* @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 {
|
||||||
|
Directive,
|
||||||
|
ContentChild,
|
||||||
|
TemplateRef,
|
||||||
|
OnInit,
|
||||||
|
AfterContentInit
|
||||||
|
} from 'angular2/core';
|
||||||
|
import { DocumentList } from './document-list';
|
||||||
|
|
||||||
|
@Directive({
|
||||||
|
selector: 'empty-folder-content'
|
||||||
|
})
|
||||||
|
export class EmptyFolderContent implements OnInit, AfterContentInit {
|
||||||
|
|
||||||
|
@ContentChild(TemplateRef)
|
||||||
|
template: any;
|
||||||
|
|
||||||
|
constructor(
|
||||||
|
private documentList: DocumentList) {
|
||||||
|
}
|
||||||
|
|
||||||
|
ngOnInit() {
|
||||||
|
}
|
||||||
|
|
||||||
|
ngAfterContentInit() {
|
||||||
|
this.documentList.emptyFolderTemplate = this.template;
|
||||||
|
}
|
||||||
|
}
|
@ -17,10 +17,12 @@
|
|||||||
|
|
||||||
// note: contains only limited subset of available fields
|
// note: contains only limited subset of available fields
|
||||||
|
|
||||||
|
// TODO: deprecated
|
||||||
export class FolderEntity {
|
export class FolderEntity {
|
||||||
items: DocumentEntity[];
|
items: DocumentEntity[];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: deprecated
|
||||||
export class DocumentEntity {
|
export class DocumentEntity {
|
||||||
nodeRef: string;
|
nodeRef: string;
|
||||||
nodeType: string;
|
nodeType: string;
|
||||||
@ -52,6 +54,7 @@ export class DocumentEntity {
|
|||||||
location: LocationEntity;
|
location: LocationEntity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: deprecated
|
||||||
export class LocationEntity {
|
export class LocationEntity {
|
||||||
repositoryId: string;
|
repositoryId: string;
|
||||||
site: string;
|
site: string;
|
||||||
@ -62,6 +65,7 @@ export class LocationEntity {
|
|||||||
parent: LocationParentEntity;
|
parent: LocationParentEntity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// TODO: deprecated
|
||||||
export class LocationParentEntity {
|
export class LocationParentEntity {
|
||||||
nodeRef: string;
|
nodeRef: string;
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user