mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[ADF-4225] Viewer extension accept multiple file type (#4427)
* viewer extension can target multiple types. * fix lint
This commit is contained in:
@@ -17,6 +17,7 @@ for more information about installing and using the source code.
|
||||
| Name | Description | Source link |
|
||||
| ---- | ----------- | ----------- |
|
||||
| [Dynamic component](dynamic.component.md)  | Displays dynamically-loaded extension components. | [Source](../../lib/extensions/src/lib/components/dynamic-component/dynamic.component.ts) |
|
||||
| [Preview Extension component](preview-extension.component.md)  | Preview extension component. | [Source](../../lib/extensions/src/lib/components/viewer/preview-extension.component.ts) |
|
||||
|
||||
## Services
|
||||
|
||||
|
106
docs/extensions/preview-extension.component.md
Normal file
106
docs/extensions/preview-extension.component.md
Normal file
@@ -0,0 +1,106 @@
|
||||
---
|
||||
Title: Dynamic Component
|
||||
Added: v3.1.0
|
||||
Status: Experimental
|
||||
Last reviewed: 2018-04-12
|
||||
---
|
||||
|
||||
# [Preview Extension component](../../lib/extensions/src/lib/components/viewer/preview-extension.component.ts "Defined in preview-extension.component.ts")
|
||||
|
||||
Displays dynamically-loaded extension components.
|
||||
If you want give a look on a real working viewer extension project you can look at [aca monaco extensio](https://github.com/eromano/aca-monaco-extension)
|
||||
## Class members
|
||||
|
||||
### Properties
|
||||
|
||||
The viewer component when it recognize a new extension always pass the following two parameter as input:
|
||||
|
||||
| Name | Type | Default value | Description |
|
||||
| ---- | ---- | ------------- | ----------- |
|
||||
| url | `string` | | URL Of the content in the repository |
|
||||
| node | `Node` | | Node of the content to display |
|
||||
|
||||
|
||||
## Details
|
||||
|
||||
If you want create your custom extension viewer you need to create the following files in a separate project:
|
||||
|
||||
|
||||
The Module needs to know which is the Id of your extension:
|
||||
|
||||
```ts
|
||||
export class YourExtensionViewerModule {
|
||||
constructor(extensions: ExtensionService) {
|
||||
extensions.setComponents({
|
||||
'your-extension.main.component': YourExtensionViewerComponent
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
|
||||
Your viewer component extension business logic:
|
||||
|
||||
```ts
|
||||
import { Node } from '@alfresco/js-api';
|
||||
import { ViewerExtensionInterface } from '@alfresco/adf-extensions';
|
||||
|
||||
@Component({
|
||||
selector: 'your-extension-viewer',
|
||||
templateUrl: './your-extension-view.component.html',
|
||||
styleUrls: ['./your-extension-view.component.css'],
|
||||
encapsulation: ViewEncapsulation.None
|
||||
})
|
||||
export class YourExtensionViewerComponent implements ViewerExtensionInterface {
|
||||
|
||||
showToolbar = true;
|
||||
|
||||
@Input()
|
||||
url: string;
|
||||
|
||||
@Input()
|
||||
node: Node;
|
||||
|
||||
|
||||
....YOUR CUSTOM LOGIC
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
Your viewer component template:
|
||||
|
||||
```HTML
|
||||
|
||||
<div> This is your custom extension viewer template</div>
|
||||
|
||||
```
|
||||
|
||||
Your viewer component extension.json:
|
||||
|
||||
|
||||
```JSON
|
||||
{
|
||||
"$version": "1.0.0",
|
||||
"$name": "my viewer extension",
|
||||
"$description": "my viewer plugin",
|
||||
"features": {
|
||||
"viewer": {
|
||||
"content": [
|
||||
{
|
||||
"id": "dev.tools.viewer.viewer",
|
||||
"fileExtension": ["png", "jpg"],
|
||||
"component": "your-extension.main.component"
|
||||
}
|
||||
]
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
```
|
||||
|
||||
|
||||
|
||||
## See also
|
||||
|
||||
- [Extension service](../../lib/extensions/src/lib/services/extension.service.ts)
|
Reference in New Issue
Block a user