c3-components 0.0.2 → 0.0.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +67 -13
- package/esm2020/lib/c3-file-viewer/c3-file-viewer.module.mjs +19 -6
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer-dialog/c3-file-viewer-dialog.mjs +20 -0
- package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer/c3-file-viewer.component.mjs +86 -0
- package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component.mjs +34 -0
- package/esm2020/lib/c3-file-viewer/models/file-viewer.mjs +6 -5
- package/esm2020/public-api.mjs +3 -2
- package/fesm2015/c3-components.mjs +77 -23
- package/fesm2015/c3-components.mjs.map +1 -1
- package/fesm2020/c3-components.mjs +78 -22
- package/fesm2020/c3-components.mjs.map +1 -1
- package/lib/c3-file-viewer/c3-file-viewer.module.d.ts +8 -5
- package/lib/c3-file-viewer/components/c3-file-viewer-dialog/c3-file-viewer-dialog.d.ts +8 -0
- package/lib/c3-file-viewer/components/{c3-file-viewer → public/c3-file-viewer}/c3-file-viewer.component.d.ts +4 -3
- package/lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component.d.ts +12 -0
- package/lib/c3-file-viewer/models/file-viewer.d.ts +1 -4
- package/package.json +5 -1
- package/public-api.d.ts +2 -1
- package/esm2020/lib/c3-file-viewer/components/c3-file-viewer/c3-file-viewer.component.mjs +0 -84
package/README.md
CHANGED
|
@@ -1,24 +1,78 @@
|
|
|
1
|
-
#
|
|
1
|
+
# C3-components
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
C3-components is an open-source component library that extends the [@angular/material](https://material.angular.io/) library. This collection of components aims to facilitate and accelerate the development of modern Angular applications by providing reusable and customizable components to meet specific needs.
|
|
4
4
|
|
|
5
|
-
##
|
|
5
|
+
## Table of Contents
|
|
6
6
|
|
|
7
|
-
|
|
8
|
-
|
|
7
|
+
- [Installation](#installation)
|
|
8
|
+
- [Components](#components)
|
|
9
|
+
- [Documentation](#documentation)
|
|
10
|
+
- [Development](#development)
|
|
11
|
+
- [Contributing](#contributing)
|
|
12
|
+
- [License](#license)
|
|
9
13
|
|
|
10
|
-
##
|
|
14
|
+
## Installation
|
|
11
15
|
|
|
12
|
-
|
|
16
|
+
To install C3-components in your Angular project, run the following command:
|
|
13
17
|
|
|
14
|
-
|
|
18
|
+
```bash
|
|
19
|
+
npm install C3-components
|
|
20
|
+
```
|
|
15
21
|
|
|
16
|
-
|
|
22
|
+
Also, make sure you have installed and configured @angular/material as per [their documentation](https://material.angular.io/guide/getting-started).
|
|
17
23
|
|
|
18
|
-
##
|
|
24
|
+
## Components
|
|
19
25
|
|
|
20
|
-
|
|
26
|
+
C3-components offer a variety of components that extend the functionality of @angular/material. Below is a table listing the available components and the progress status of their documentation:
|
|
21
27
|
|
|
22
|
-
|
|
28
|
+
| Component | Documentation Status |
|
|
29
|
+
| -------------- | --------------------------------------------------------------------------- |
|
|
30
|
+
| Dialog |  Completed |
|
|
31
|
+
| Dropdown |  Completed |
|
|
32
|
+
| File Upload |  Planned |
|
|
33
|
+
| File Viewer |  In Progress |
|
|
34
|
+
| Highlight Text |  Completed |
|
|
35
|
+
| Menu |  Planned |
|
|
36
|
+
| Modal |  Planned |
|
|
37
|
+
| NavBar |  Planned |
|
|
38
|
+
| Pdf Dialog |  Planned |
|
|
39
|
+
| Rounded Title |  Planned |
|
|
40
|
+
| Tabs |  Planned |
|
|
23
41
|
|
|
24
|
-
|
|
42
|
+
## Documentation
|
|
43
|
+
|
|
44
|
+
Complete documentation for the C3-components is available on our [documentation website](https://C3-components.example.com/). You'll find usage examples, guides, and API references for each component.
|
|
45
|
+
|
|
46
|
+
## Development
|
|
47
|
+
|
|
48
|
+
If you'd like to contribute to the development of C3-components, follow the steps below to set up your development environment:
|
|
49
|
+
|
|
50
|
+
1. Clone the repository:
|
|
51
|
+
|
|
52
|
+
```bash
|
|
53
|
+
git clone https://github.com/Kroenen62/C3-components.git
|
|
54
|
+
```
|
|
55
|
+
|
|
56
|
+
2. Install the dependencies:
|
|
57
|
+
|
|
58
|
+
```bash
|
|
59
|
+
npm install
|
|
60
|
+
```
|
|
61
|
+
|
|
62
|
+
3. Start the development server:
|
|
63
|
+
|
|
64
|
+
```bash
|
|
65
|
+
npm start
|
|
66
|
+
```
|
|
67
|
+
|
|
68
|
+
This will launch a local instance of the demo application to aid in the development and testing of the components.
|
|
69
|
+
|
|
70
|
+
## Contributing
|
|
71
|
+
|
|
72
|
+
This is my first contribution, and I am learning as I go. Please be understanding and patient as I work to improve this project.
|
|
73
|
+
|
|
74
|
+
Before contributing, please read our [contribution guide](./CONTRIBUTING.md) for best practices and guidelines for our project.
|
|
75
|
+
|
|
76
|
+
## License
|
|
77
|
+
|
|
78
|
+
C3-components are licensed under the [MIT License](./LICENSE). You are free to use, modify, and distribute it, subject to the terms of this license.
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { NgModule } from '@angular/core';
|
|
2
2
|
import { FullScreenDirective } from './directives/full-screen.directive';
|
|
3
|
-
import { C3FileViewerComponent } from './components/c3-file-viewer/c3-file-viewer.component';
|
|
3
|
+
import { C3FileViewerComponent } from './components/public/c3-file-viewer/c3-file-viewer.component';
|
|
4
4
|
import { CommonModule } from '@angular/common';
|
|
5
5
|
import { C3FileViewerActionsComponent } from './components/c3-file-viewer-actions/c3-file-viewer-actions.component';
|
|
6
6
|
import { C3FileViewerImageComponent } from './components/c3-file-viewer-image/c3-file-viewer-image.component';
|
|
@@ -8,6 +8,9 @@ import { C3FileViewerPdfComponent } from './components/c3-file-viewer-pdf/c3-fil
|
|
|
8
8
|
import { C3FileViewerVideoComponent } from './components/c3-file-viewer-video/c3-file-viewer-video.component';
|
|
9
9
|
import { HttpClientModule } from '@angular/common/http';
|
|
10
10
|
import { C3SafeUrlPipe } from '../../public-api';
|
|
11
|
+
import { C3FileViewerDialogComponent } from './components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component';
|
|
12
|
+
import { MatDialogModule } from '@angular/material/dialog';
|
|
13
|
+
import { C3FileViewerDialog } from './components/c3-file-viewer-dialog/c3-file-viewer-dialog';
|
|
11
14
|
import * as i0 from "@angular/core";
|
|
12
15
|
export class C3FileViewerModule {
|
|
13
16
|
}
|
|
@@ -17,8 +20,12 @@ C3FileViewerModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", vers
|
|
|
17
20
|
C3FileViewerActionsComponent,
|
|
18
21
|
C3FileViewerImageComponent,
|
|
19
22
|
C3FileViewerPdfComponent,
|
|
20
|
-
C3FileViewerVideoComponent
|
|
21
|
-
|
|
23
|
+
C3FileViewerVideoComponent,
|
|
24
|
+
C3FileViewerDialogComponent,
|
|
25
|
+
C3FileViewerDialog], imports: [CommonModule, HttpClientModule, C3SafeUrlPipe, MatDialogModule], exports: [FullScreenDirective,
|
|
26
|
+
C3FileViewerComponent,
|
|
27
|
+
C3FileViewerDialogComponent] });
|
|
28
|
+
C3FileViewerModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, imports: [CommonModule, HttpClientModule, MatDialogModule] });
|
|
22
29
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerModule, decorators: [{
|
|
23
30
|
type: NgModule,
|
|
24
31
|
args: [{
|
|
@@ -30,9 +37,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImpor
|
|
|
30
37
|
C3FileViewerImageComponent,
|
|
31
38
|
C3FileViewerPdfComponent,
|
|
32
39
|
C3FileViewerVideoComponent,
|
|
40
|
+
C3FileViewerDialogComponent,
|
|
41
|
+
C3FileViewerDialog,
|
|
42
|
+
],
|
|
43
|
+
imports: [CommonModule, HttpClientModule, C3SafeUrlPipe, MatDialogModule],
|
|
44
|
+
exports: [
|
|
45
|
+
FullScreenDirective,
|
|
46
|
+
C3FileViewerComponent,
|
|
47
|
+
C3FileViewerDialogComponent,
|
|
33
48
|
],
|
|
34
|
-
imports: [CommonModule, HttpClientModule, C3SafeUrlPipe],
|
|
35
|
-
exports: [FullScreenDirective, C3FileViewerComponent],
|
|
36
49
|
}]
|
|
37
50
|
}] });
|
|
38
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDZEQUE2RCxDQUFDO0FBQ3BHLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsNEJBQTRCLEVBQUUsTUFBTSxzRUFBc0UsQ0FBQztBQUNwSCxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQztBQUN4RyxPQUFPLEVBQUUsMEJBQTBCLEVBQUUsTUFBTSxrRUFBa0UsQ0FBQztBQUM5RyxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFDakQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0sMkVBQTJFLENBQUM7QUFDeEgsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQzNELE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLDBEQUEwRCxDQUFDOztBQXFCOUYsTUFBTSxPQUFPLGtCQUFrQjs7K0dBQWxCLGtCQUFrQjtnSEFBbEIsa0JBQWtCLGlCQWhCM0IsbUJBQW1CO1FBQ25CLHFCQUFxQjtRQUNyQiw0QkFBNEI7UUFDNUIsMEJBQTBCO1FBQzFCLHdCQUF3QjtRQUN4QiwwQkFBMEI7UUFDMUIsMkJBQTJCO1FBQzNCLGtCQUFrQixhQUVWLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxhQUV0RSxtQkFBbUI7UUFDbkIscUJBQXFCO1FBQ3JCLDJCQUEyQjtnSEFHbEIsa0JBQWtCLFlBUG5CLFlBQVksRUFBRSxnQkFBZ0IsRUFBaUIsZUFBZTsyRkFPN0Qsa0JBQWtCO2tCQW5COUIsUUFBUTttQkFBQztvQkFDUixTQUFTLEVBQUUsRUFBRTtvQkFDYixZQUFZLEVBQUU7d0JBQ1osbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLDRCQUE0Qjt3QkFDNUIsMEJBQTBCO3dCQUMxQix3QkFBd0I7d0JBQ3hCLDBCQUEwQjt3QkFDMUIsMkJBQTJCO3dCQUMzQixrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxnQkFBZ0IsRUFBRSxhQUFhLEVBQUUsZUFBZSxDQUFDO29CQUN6RSxPQUFPLEVBQUU7d0JBQ1AsbUJBQW1CO3dCQUNuQixxQkFBcUI7d0JBQ3JCLDJCQUEyQjtxQkFDNUI7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRnVsbFNjcmVlbkRpcmVjdGl2ZSB9IGZyb20gJy4vZGlyZWN0aXZlcy9mdWxsLXNjcmVlbi5kaXJlY3RpdmUnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci9jMy1maWxlLXZpZXdlci5jb21wb25lbnQnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlckFjdGlvbnNDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItYWN0aW9ucy9jMy1maWxlLXZpZXdlci1hY3Rpb25zLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXJJbWFnZUNvbXBvbmVudCB9IGZyb20gJy4vY29tcG9uZW50cy9jMy1maWxlLXZpZXdlci1pbWFnZS9jMy1maWxlLXZpZXdlci1pbWFnZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyUGRmQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLXBkZi9jMy1maWxlLXZpZXdlci1wZGYuY29tcG9uZW50JztcbmltcG9ydCB7IEMzRmlsZVZpZXdlclZpZGVvQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLXZpZGVvL2MzLWZpbGUtdmlld2VyLXZpZGVvLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBIdHRwQ2xpZW50TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xuaW1wb3J0IHsgQzNTYWZlVXJsUGlwZSB9IGZyb20gJy4uLy4uL3B1YmxpYy1hcGknO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci1kaWFsb2cvYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudCc7XG5pbXBvcnQgeyBNYXREaWFsb2dNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nIH0gZnJvbSAnLi9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLWRpYWxvZy9jMy1maWxlLXZpZXdlci1kaWFsb2cnO1xuXG5ATmdNb2R1bGUoe1xuICBwcm92aWRlcnM6IFtdLFxuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBGdWxsU2NyZWVuRGlyZWN0aXZlLFxuICAgIEMzRmlsZVZpZXdlckNvbXBvbmVudCxcbiAgICBDM0ZpbGVWaWV3ZXJBY3Rpb25zQ29tcG9uZW50LFxuICAgIEMzRmlsZVZpZXdlckltYWdlQ29tcG9uZW50LFxuICAgIEMzRmlsZVZpZXdlclBkZkNvbXBvbmVudCxcbiAgICBDM0ZpbGVWaWV3ZXJWaWRlb0NvbXBvbmVudCxcbiAgICBDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQsXG4gICAgQzNGaWxlVmlld2VyRGlhbG9nLFxuICBdLFxuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBIdHRwQ2xpZW50TW9kdWxlLCBDM1NhZmVVcmxQaXBlLCBNYXREaWFsb2dNb2R1bGVdLFxuICBleHBvcnRzOiBbXG4gICAgRnVsbFNjcmVlbkRpcmVjdGl2ZSxcbiAgICBDM0ZpbGVWaWV3ZXJDb21wb25lbnQsXG4gICAgQzNGaWxlVmlld2VyRGlhbG9nQ29tcG9uZW50LFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJNb2R1bGUge31cbiJdfQ==
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { Component, Inject } from '@angular/core';
|
|
2
|
+
import { MAT_DIALOG_DATA } from '@angular/material/dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../public/c3-file-viewer/c3-file-viewer.component";
|
|
5
|
+
import * as i2 from "../../models/file-viewer";
|
|
6
|
+
export class C3FileViewerDialog {
|
|
7
|
+
constructor(fileViewer) {
|
|
8
|
+
this.fileViewer = fileViewer;
|
|
9
|
+
}
|
|
10
|
+
}
|
|
11
|
+
C3FileViewerDialog.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialog, deps: [{ token: MAT_DIALOG_DATA }], target: i0.ɵɵFactoryTarget.Component });
|
|
12
|
+
C3FileViewerDialog.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerDialog, selector: "ng-component", ngImport: i0, template: "<c3-file-viewer [fileViewer]=\"fileViewer\" [screenHeightOccupied]=\"0\" />\n", styles: [""], dependencies: [{ kind: "component", type: i1.C3FileViewerComponent, selector: "c3-file-viewer", inputs: ["screenHeightOccupied", "fileViewer"], outputs: ["indexChange", "configChange", "customFileEvent"] }] });
|
|
13
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialog, decorators: [{
|
|
14
|
+
type: Component,
|
|
15
|
+
args: [{ template: "<c3-file-viewer [fileViewer]=\"fileViewer\" [screenHeightOccupied]=\"0\" />\n" }]
|
|
16
|
+
}], ctorParameters: function () { return [{ type: i2.C3FileViewer, decorators: [{
|
|
17
|
+
type: Inject,
|
|
18
|
+
args: [MAT_DIALOG_DATA]
|
|
19
|
+
}] }]; } });
|
|
20
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItZGlhbG9nLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL2MzLWZpbGUtdmlld2VyLWRpYWxvZy9jMy1maWxlLXZpZXdlci1kaWFsb2cuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sMEJBQTBCLENBQUM7Ozs7QUFPM0QsTUFBTSxPQUFPLGtCQUFrQjtJQUM3QixZQUE0QyxVQUF3QjtRQUF4QixlQUFVLEdBQVYsVUFBVSxDQUFjO0lBQUcsQ0FBQzs7K0dBRDdELGtCQUFrQixrQkFDVCxlQUFlO21HQUR4QixrQkFBa0Isb0RDUi9CLCtFQUNBOzJGRE9hLGtCQUFrQjtrQkFKOUIsU0FBUzs7OzBCQUtLLE1BQU07MkJBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNQVRfRElBTE9HX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2ZpbGUtdmlld2VyJztcblxuQENvbXBvbmVudCh7XG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci1kaWFsb2cuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jc3MnXSxcbn0pXG5leHBvcnQgY2xhc3MgQzNGaWxlVmlld2VyRGlhbG9nIHtcbiAgY29uc3RydWN0b3IoQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBmaWxlVmlld2VyOiBDM0ZpbGVWaWV3ZXIpIHt9XG59XG4iLCI8YzMtZmlsZS12aWV3ZXIgW2ZpbGVWaWV3ZXJdPVwiZmlsZVZpZXdlclwiIFtzY3JlZW5IZWlnaHRPY2N1cGllZF09XCIwXCIgLz5cbiJdfQ==
|
package/esm2020/lib/c3-file-viewer/components/public/c3-file-viewer/c3-file-viewer.component.mjs
ADDED
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import { Component, EventEmitter, HostListener, Inject, Input, Optional, Output, ViewEncapsulation, } from '@angular/core';
|
|
2
|
+
import * as i0 from "@angular/core";
|
|
3
|
+
import * as i1 from "@angular/common/http";
|
|
4
|
+
import * as i2 from "@angular/common";
|
|
5
|
+
import * as i3 from "../../../directives/full-screen.directive";
|
|
6
|
+
import * as i4 from "../../c3-file-viewer-actions/c3-file-viewer-actions.component";
|
|
7
|
+
import * as i5 from "../../c3-file-viewer-image/c3-file-viewer-image.component";
|
|
8
|
+
import * as i6 from "../../c3-file-viewer-pdf/c3-file-viewer-pdf.component";
|
|
9
|
+
import * as i7 from "../../c3-file-viewer-video/c3-file-viewer-video.component";
|
|
10
|
+
export class C3FileViewerComponent {
|
|
11
|
+
constructor(moduleConfig, _http) {
|
|
12
|
+
this.moduleConfig = moduleConfig;
|
|
13
|
+
this._http = _http;
|
|
14
|
+
this.indexChange = new EventEmitter();
|
|
15
|
+
this.configChange = new EventEmitter();
|
|
16
|
+
this.customFileEvent = new EventEmitter();
|
|
17
|
+
}
|
|
18
|
+
ngOnInit() {
|
|
19
|
+
this.defineStyleHeight();
|
|
20
|
+
this.fileViewer.customFile$.subscribe((event) => {
|
|
21
|
+
this.customFileEvent.emit(event);
|
|
22
|
+
});
|
|
23
|
+
this.fileViewer.index$.subscribe((index) => {
|
|
24
|
+
this.indexChange.emit(index);
|
|
25
|
+
});
|
|
26
|
+
this.fileViewer.config$.subscribe((config) => {
|
|
27
|
+
this.configChange.emit(config);
|
|
28
|
+
});
|
|
29
|
+
}
|
|
30
|
+
onMouseOver() {
|
|
31
|
+
this.fileViewer.hovered = true;
|
|
32
|
+
}
|
|
33
|
+
onMouseLeave() {
|
|
34
|
+
this.fileViewer.hovered = false;
|
|
35
|
+
}
|
|
36
|
+
ngOnChanges(changes) {
|
|
37
|
+
if (changes['screenHeightOccupied'] && this.fileViewer)
|
|
38
|
+
this.defineStyleHeight();
|
|
39
|
+
}
|
|
40
|
+
next(event) {
|
|
41
|
+
this.fileViewer.nextImage(event);
|
|
42
|
+
}
|
|
43
|
+
previous(event) {
|
|
44
|
+
this.fileViewer.previousImage(event);
|
|
45
|
+
}
|
|
46
|
+
defineStyleHeight() {
|
|
47
|
+
this.fileViewer.styleHeight =
|
|
48
|
+
'calc(100% - ' + this.screenHeightOccupied + 'px)';
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
C3FileViewerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerComponent, deps: [{ token: 'config', optional: true }, { token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Component });
|
|
52
|
+
C3FileViewerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerComponent, selector: "c3-file-viewer", inputs: { screenHeightOccupied: "screenHeightOccupied", fileViewer: "fileViewer" }, outputs: { indexChange: "indexChange", configChange: "configChange", customFileEvent: "customFileEvent" }, host: { listeners: { "mouseover": "onMouseOver()", "mouseleave": "onMouseLeave()", "window:keyup.ArrowRight": "next($event)", "window:keyup.ArrowLeft": "previous($event)" }, classAttribute: "c3-file-viewer" }, usesOnChanges: true, ngImport: i0, template: "<div\n class=\"container\"\n *ngIf=\"fileViewer\"\n [c3-full-screen]=\"fileViewer.fullscreen$ | async\"\n [style.height]=\"fileViewer.styleHeight\"\n [style.backgroundColor]=\"fileViewer.config.containerBackgroundColor\"\n (wheel)=\"fileViewer.scrollZoom($event)\"\n (dragover)=\"fileViewer.onDragOver($event)\"\n>\n <c3-file-viewer-image\n *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n [fileViewer]=\"fileViewer\"\n [style]=\"fileViewer.style\"\n (dragstart)=\"fileViewer.onDragStart($event)\"\n />\n\n <c3-file-viewer-video\n *ngIf=\"fileViewer.currentFile.type.startsWith('video')\"\n />\n\n <c3-file-viewer-pdf\n *ngIf=\"fileViewer.currentFile.type.startsWith('application/pdf')\"\n [fileViewer]=\"fileViewer\"\n />\n <!-- Div below will be used to hide the 'ghost' image when dragging -->\n <div></div>\n <div class=\"spinner-container\" *ngIf=\"fileViewer.loading\">\n <div class=\"spinner\"></div>\n </div>\n\n <c3-file-viewer-actions [fileViewer]=\"fileViewer\" />\n</div>\n", dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.FullScreenDirective, selector: "[C3FullScreen], [c3-full-screen]", inputs: ["c3Screenfull", "c3-full-screen"] }, { kind: "component", type: i4.C3FileViewerActionsComponent, selector: "c3-file-viewer-actions", inputs: ["fileViewer"] }, { kind: "component", type: i5.C3FileViewerImageComponent, selector: "c3-file-viewer-image, [c3-file-viewer-image]", inputs: ["fileViewer"], outputs: ["dragstart"] }, { kind: "component", type: i6.C3FileViewerPdfComponent, selector: "c3-file-viewer-pdf", inputs: ["fileViewer"], outputs: ["dragstart"] }, { kind: "component", type: i7.C3FileViewerVideoComponent, selector: "c3-file-viewer-video", inputs: ["file", "fileViewer"] }, { kind: "pipe", type: i2.AsyncPipe, name: "async" }], encapsulation: i0.ViewEncapsulation.None });
|
|
53
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerComponent, decorators: [{
|
|
54
|
+
type: Component,
|
|
55
|
+
args: [{ selector: 'c3-file-viewer', encapsulation: ViewEncapsulation.None, host: {
|
|
56
|
+
class: 'c3-file-viewer',
|
|
57
|
+
}, template: "<div\n class=\"container\"\n *ngIf=\"fileViewer\"\n [c3-full-screen]=\"fileViewer.fullscreen$ | async\"\n [style.height]=\"fileViewer.styleHeight\"\n [style.backgroundColor]=\"fileViewer.config.containerBackgroundColor\"\n (wheel)=\"fileViewer.scrollZoom($event)\"\n (dragover)=\"fileViewer.onDragOver($event)\"\n>\n <c3-file-viewer-image\n *ngIf=\"fileViewer.currentFile.type.startsWith('image')\"\n [fileViewer]=\"fileViewer\"\n [style]=\"fileViewer.style\"\n (dragstart)=\"fileViewer.onDragStart($event)\"\n />\n\n <c3-file-viewer-video\n *ngIf=\"fileViewer.currentFile.type.startsWith('video')\"\n />\n\n <c3-file-viewer-pdf\n *ngIf=\"fileViewer.currentFile.type.startsWith('application/pdf')\"\n [fileViewer]=\"fileViewer\"\n />\n <!-- Div below will be used to hide the 'ghost' image when dragging -->\n <div></div>\n <div class=\"spinner-container\" *ngIf=\"fileViewer.loading\">\n <div class=\"spinner\"></div>\n </div>\n\n <c3-file-viewer-actions [fileViewer]=\"fileViewer\" />\n</div>\n" }]
|
|
58
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
59
|
+
type: Optional
|
|
60
|
+
}, {
|
|
61
|
+
type: Inject,
|
|
62
|
+
args: ['config']
|
|
63
|
+
}] }, { type: i1.HttpClient }]; }, propDecorators: { screenHeightOccupied: [{
|
|
64
|
+
type: Input
|
|
65
|
+
}], fileViewer: [{
|
|
66
|
+
type: Input
|
|
67
|
+
}], indexChange: [{
|
|
68
|
+
type: Output
|
|
69
|
+
}], configChange: [{
|
|
70
|
+
type: Output
|
|
71
|
+
}], customFileEvent: [{
|
|
72
|
+
type: Output
|
|
73
|
+
}], onMouseOver: [{
|
|
74
|
+
type: HostListener,
|
|
75
|
+
args: ['mouseover']
|
|
76
|
+
}], onMouseLeave: [{
|
|
77
|
+
type: HostListener,
|
|
78
|
+
args: ['mouseleave']
|
|
79
|
+
}], next: [{
|
|
80
|
+
type: HostListener,
|
|
81
|
+
args: ['window:keyup.ArrowRight', ['$event']]
|
|
82
|
+
}], previous: [{
|
|
83
|
+
type: HostListener,
|
|
84
|
+
args: ['window:keyup.ArrowLeft', ['$event']]
|
|
85
|
+
}] } });
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYzMtY29tcG9uZW50cy9zcmMvbGliL2MzLWZpbGUtdmlld2VyL2NvbXBvbmVudHMvcHVibGljL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci9jMy1maWxlLXZpZXdlci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsU0FBUyxFQUNULFlBQVksRUFDWixZQUFZLEVBQ1osTUFBTSxFQUNOLEtBQUssRUFFTCxRQUFRLEVBQ1IsTUFBTSxFQUVOLGlCQUFpQixHQUNsQixNQUFNLGVBQWUsQ0FBQzs7Ozs7Ozs7O0FBZXZCLE1BQU0sT0FBTyxxQkFBcUI7SUFnQmhDLFlBQ3VDLFlBQWdDLEVBQzlELEtBQWlCO1FBRGEsaUJBQVksR0FBWixZQUFZLENBQW9CO1FBQzlELFVBQUssR0FBTCxLQUFLLENBQVk7UUFWbkIsZ0JBQVcsR0FBeUIsSUFBSSxZQUFZLEVBQUUsQ0FBQztRQUd2RCxpQkFBWSxHQUFxQyxJQUFJLFlBQVksRUFBRSxDQUFDO1FBR3BFLG9CQUFlLEdBQWtDLElBQUksWUFBWSxFQUFFLENBQUM7SUFLeEUsQ0FBQztJQUVKLFFBQVE7UUFDTixJQUFJLENBQUMsaUJBQWlCLEVBQUUsQ0FBQztRQUV6QixJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVcsQ0FBQyxTQUFTLENBQUMsQ0FBQyxLQUFLLEVBQUUsRUFBRTtZQUM5QyxJQUFJLENBQUMsZUFBZSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztRQUNuQyxDQUFDLENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLFNBQVMsQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFO1lBQ3pDLElBQUksQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQy9CLENBQUMsQ0FBQyxDQUFDO1FBRUgsSUFBSSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsTUFBTSxFQUFFLEVBQUU7WUFDM0MsSUFBSSxDQUFDLFlBQVksQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFDakMsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBR0QsV0FBVztRQUNULElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQztJQUNqQyxDQUFDO0lBR0QsWUFBWTtRQUNWLElBQUksQ0FBQyxVQUFVLENBQUMsT0FBTyxHQUFHLEtBQUssQ0FBQztJQUNsQyxDQUFDO0lBRUQsV0FBVyxDQUFDLE9BQXNCO1FBQ2hDLElBQUksT0FBTyxDQUFDLHNCQUFzQixDQUFDLElBQUksSUFBSSxDQUFDLFVBQVU7WUFDcEQsSUFBSSxDQUFDLGlCQUFpQixFQUFFLENBQUM7SUFDN0IsQ0FBQztJQUdELElBQUksQ0FBQyxLQUFvQjtRQUN2QixJQUFJLENBQUMsVUFBVSxDQUFDLFNBQVMsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNuQyxDQUFDO0lBR0QsUUFBUSxDQUFDLEtBQW9CO1FBQzNCLElBQUksQ0FBQyxVQUFVLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO0lBQ3ZDLENBQUM7SUFFRCxpQkFBaUI7UUFDZixJQUFJLENBQUMsVUFBVSxDQUFDLFdBQVc7WUFDekIsY0FBYyxHQUFHLElBQUksQ0FBQyxvQkFBb0IsR0FBRyxLQUFLLENBQUM7SUFDdkQsQ0FBQzs7a0hBakVVLHFCQUFxQixrQkFpQlYsUUFBUTtzR0FqQm5CLHFCQUFxQiw0ZEMxQmxDLGdoQ0FnQ0E7MkZETmEscUJBQXFCO2tCQVRqQyxTQUFTOytCQUNFLGdCQUFnQixpQkFHWCxpQkFBaUIsQ0FBQyxJQUFJLFFBQy9CO3dCQUNKLEtBQUssRUFBRSxnQkFBZ0I7cUJBQ3hCOzswQkFtQkUsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxRQUFRO3FFQWZ2QixvQkFBb0I7c0JBRDFCLEtBQUs7Z0JBSUMsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxXQUFXO3NCQURqQixNQUFNO2dCQUlBLFlBQVk7c0JBRGxCLE1BQU07Z0JBSUEsZUFBZTtzQkFEckIsTUFBTTtnQkF5QlAsV0FBVztzQkFEVixZQUFZO3VCQUFDLFdBQVc7Z0JBTXpCLFlBQVk7c0JBRFgsWUFBWTt1QkFBQyxZQUFZO2dCQVcxQixJQUFJO3NCQURILFlBQVk7dUJBQUMseUJBQXlCLEVBQUUsQ0FBQyxRQUFRLENBQUM7Z0JBTW5ELFFBQVE7c0JBRFAsWUFBWTt1QkFBQyx3QkFBd0IsRUFBRSxDQUFDLFFBQVEsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIENvbXBvbmVudCxcbiAgRXZlbnRFbWl0dGVyLFxuICBIb3N0TGlzdGVuZXIsXG4gIEluamVjdCxcbiAgSW5wdXQsXG4gIE9uSW5pdCxcbiAgT3B0aW9uYWwsXG4gIE91dHB1dCxcbiAgU2ltcGxlQ2hhbmdlcyxcbiAgVmlld0VuY2Fwc3VsYXRpb24sXG59IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyQ29uZmlnIH0gZnJvbSAnLi4vLi4vLi4vbW9kZWxzL2ZpbGUtdmlld2VyLWNvbmZpZy5tb2RlbCc7XG5pbXBvcnQgeyBDdXN0b21GaWxlRXZlbnQgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvY3VzdG9tLWZpbGUtZXZlbnQubW9kZWwnO1xuaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IEMzRmlsZVZpZXdlciB9IGZyb20gJy4uLy4uLy4uL21vZGVscy9maWxlLXZpZXdlcic7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtdmlld2VyJyxcbiAgdGVtcGxhdGVVcmw6ICcuL2MzLWZpbGUtdmlld2VyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbXSxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgaG9zdDoge1xuICAgIGNsYXNzOiAnYzMtZmlsZS12aWV3ZXInLFxuICB9LFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgc2NyZWVuSGVpZ2h0T2NjdXBpZWQ/OiAwOyAvLyBJbiBQeFxuXG4gIEBJbnB1dCgpXG4gIHB1YmxpYyBmaWxlVmlld2VyITogQzNGaWxlVmlld2VyO1xuXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgaW5kZXhDaGFuZ2U6IEV2ZW50RW1pdHRlcjxudW1iZXI+ID0gbmV3IEV2ZW50RW1pdHRlcigpO1xuXG4gIEBPdXRwdXQoKVxuICBwdWJsaWMgY29uZmlnQ2hhbmdlOiBFdmVudEVtaXR0ZXI8QzNGaWxlVmlld2VyQ29uZmlnPiA9IG5ldyBFdmVudEVtaXR0ZXIoKTtcblxuICBAT3V0cHV0KClcbiAgcHVibGljIGN1c3RvbUZpbGVFdmVudDogRXZlbnRFbWl0dGVyPEN1c3RvbUZpbGVFdmVudD4gPSBuZXcgRXZlbnRFbWl0dGVyKCk7XG5cbiAgY29uc3RydWN0b3IoXG4gICAgQE9wdGlvbmFsKCkgQEluamVjdCgnY29uZmlnJykgcHVibGljIG1vZHVsZUNvbmZpZzogQzNGaWxlVmlld2VyQ29uZmlnLFxuICAgIHB1YmxpYyBfaHR0cDogSHR0cENsaWVudFxuICApIHt9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5kZWZpbmVTdHlsZUhlaWdodCgpO1xuXG4gICAgdGhpcy5maWxlVmlld2VyLmN1c3RvbUZpbGUkLnN1YnNjcmliZSgoZXZlbnQpID0+IHtcbiAgICAgIHRoaXMuY3VzdG9tRmlsZUV2ZW50LmVtaXQoZXZlbnQpO1xuICAgIH0pO1xuXG4gICAgdGhpcy5maWxlVmlld2VyLmluZGV4JC5zdWJzY3JpYmUoKGluZGV4KSA9PiB7XG4gICAgICB0aGlzLmluZGV4Q2hhbmdlLmVtaXQoaW5kZXgpO1xuICAgIH0pO1xuXG4gICAgdGhpcy5maWxlVmlld2VyLmNvbmZpZyQuc3Vic2NyaWJlKChjb25maWcpID0+IHtcbiAgICAgIHRoaXMuY29uZmlnQ2hhbmdlLmVtaXQoY29uZmlnKTtcbiAgICB9KTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlb3ZlcicpXG4gIG9uTW91c2VPdmVyKCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5ob3ZlcmVkID0gdHJ1ZTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ21vdXNlbGVhdmUnKVxuICBvbk1vdXNlTGVhdmUoKSB7XG4gICAgdGhpcy5maWxlVmlld2VyLmhvdmVyZWQgPSBmYWxzZTtcbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICBpZiAoY2hhbmdlc1snc2NyZWVuSGVpZ2h0T2NjdXBpZWQnXSAmJiB0aGlzLmZpbGVWaWV3ZXIpXG4gICAgICB0aGlzLmRlZmluZVN0eWxlSGVpZ2h0KCk7XG4gIH1cblxuICBASG9zdExpc3RlbmVyKCd3aW5kb3c6a2V5dXAuQXJyb3dSaWdodCcsIFsnJGV2ZW50J10pXG4gIG5leHQoZXZlbnQ6IEtleWJvYXJkRXZlbnQpIHtcbiAgICB0aGlzLmZpbGVWaWV3ZXIubmV4dEltYWdlKGV2ZW50KTtcbiAgfVxuXG4gIEBIb3N0TGlzdGVuZXIoJ3dpbmRvdzprZXl1cC5BcnJvd0xlZnQnLCBbJyRldmVudCddKVxuICBwcmV2aW91cyhldmVudDogS2V5Ym9hcmRFdmVudCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5wcmV2aW91c0ltYWdlKGV2ZW50KTtcbiAgfVxuXG4gIGRlZmluZVN0eWxlSGVpZ2h0KCkge1xuICAgIHRoaXMuZmlsZVZpZXdlci5zdHlsZUhlaWdodCA9XG4gICAgICAnY2FsYygxMDAlIC0gJyArIHRoaXMuc2NyZWVuSGVpZ2h0T2NjdXBpZWQgKyAncHgpJztcbiAgfVxufVxuIiwiPGRpdlxuICBjbGFzcz1cImNvbnRhaW5lclwiXG4gICpuZ0lmPVwiZmlsZVZpZXdlclwiXG4gIFtjMy1mdWxsLXNjcmVlbl09XCJmaWxlVmlld2VyLmZ1bGxzY3JlZW4kIHwgYXN5bmNcIlxuICBbc3R5bGUuaGVpZ2h0XT1cImZpbGVWaWV3ZXIuc3R5bGVIZWlnaHRcIlxuICBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImZpbGVWaWV3ZXIuY29uZmlnLmNvbnRhaW5lckJhY2tncm91bmRDb2xvclwiXG4gICh3aGVlbCk9XCJmaWxlVmlld2VyLnNjcm9sbFpvb20oJGV2ZW50KVwiXG4gIChkcmFnb3Zlcik9XCJmaWxlVmlld2VyLm9uRHJhZ092ZXIoJGV2ZW50KVwiXG4+XG4gIDxjMy1maWxlLXZpZXdlci1pbWFnZVxuICAgICpuZ0lmPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2ltYWdlJylcIlxuICAgIFtmaWxlVmlld2VyXT1cImZpbGVWaWV3ZXJcIlxuICAgIFtzdHlsZV09XCJmaWxlVmlld2VyLnN0eWxlXCJcbiAgICAoZHJhZ3N0YXJ0KT1cImZpbGVWaWV3ZXIub25EcmFnU3RhcnQoJGV2ZW50KVwiXG4gIC8+XG5cbiAgPGMzLWZpbGUtdmlld2VyLXZpZGVvXG4gICAgKm5nSWY9XCJmaWxlVmlld2VyLmN1cnJlbnRGaWxlLnR5cGUuc3RhcnRzV2l0aCgndmlkZW8nKVwiXG4gIC8+XG5cbiAgPGMzLWZpbGUtdmlld2VyLXBkZlxuICAgICpuZ0lmPVwiZmlsZVZpZXdlci5jdXJyZW50RmlsZS50eXBlLnN0YXJ0c1dpdGgoJ2FwcGxpY2F0aW9uL3BkZicpXCJcbiAgICBbZmlsZVZpZXdlcl09XCJmaWxlVmlld2VyXCJcbiAgLz5cbiAgPCEtLSBEaXYgYmVsb3cgd2lsbCBiZSB1c2VkIHRvIGhpZGUgdGhlICdnaG9zdCcgaW1hZ2Ugd2hlbiBkcmFnZ2luZyAtLT5cbiAgPGRpdj48L2Rpdj5cbiAgPGRpdiBjbGFzcz1cInNwaW5uZXItY29udGFpbmVyXCIgKm5nSWY9XCJmaWxlVmlld2VyLmxvYWRpbmdcIj5cbiAgICA8ZGl2IGNsYXNzPVwic3Bpbm5lclwiPjwvZGl2PlxuICA8L2Rpdj5cblxuICA8YzMtZmlsZS12aWV3ZXItYWN0aW9ucyBbZmlsZVZpZXdlcl09XCJmaWxlVmlld2VyXCIgLz5cbjwvZGl2PlxuIl19
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { Component, HostListener, Input } from '@angular/core';
|
|
2
|
+
import { C3FileViewerDialog } from '../../c3-file-viewer-dialog/c3-file-viewer-dialog';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "@angular/material/dialog";
|
|
5
|
+
export class C3FileViewerDialogComponent {
|
|
6
|
+
constructor(_dialog) {
|
|
7
|
+
this._dialog = _dialog;
|
|
8
|
+
this.dialogConfig = {
|
|
9
|
+
panelClass: 'c3-file-viewer-dialog',
|
|
10
|
+
width: '80%',
|
|
11
|
+
height: '80%',
|
|
12
|
+
};
|
|
13
|
+
}
|
|
14
|
+
openDialog() {
|
|
15
|
+
this._dialog.open(C3FileViewerDialog, {
|
|
16
|
+
data: this.fileViewer,
|
|
17
|
+
...this.dialogConfig,
|
|
18
|
+
});
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
C3FileViewerDialogComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialogComponent, deps: [{ token: i1.MatDialog }], target: i0.ɵɵFactoryTarget.Component });
|
|
22
|
+
C3FileViewerDialogComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.8", type: C3FileViewerDialogComponent, selector: "c3-file-viewer-dialog", inputs: { fileViewer: "fileViewer", dialogConfig: "dialogConfig" }, host: { listeners: { "click": "openDialog()" } }, ngImport: i0, template: "<ng-content></ng-content>\n", styles: [""] });
|
|
23
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.8", ngImport: i0, type: C3FileViewerDialogComponent, decorators: [{
|
|
24
|
+
type: Component,
|
|
25
|
+
args: [{ selector: 'c3-file-viewer-dialog', template: "<ng-content></ng-content>\n" }]
|
|
26
|
+
}], ctorParameters: function () { return [{ type: i1.MatDialog }]; }, propDecorators: { fileViewer: [{
|
|
27
|
+
type: Input
|
|
28
|
+
}], dialogConfig: [{
|
|
29
|
+
type: Input
|
|
30
|
+
}], openDialog: [{
|
|
31
|
+
type: HostListener,
|
|
32
|
+
args: ['click']
|
|
33
|
+
}] } });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci1kaWFsb2cvYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci1kaWFsb2cvYzMtZmlsZS12aWV3ZXItZGlhbG9nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFVLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQU92RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtREFBbUQsQ0FBQzs7O0FBT3ZGLE1BQU0sT0FBTywyQkFBMkI7SUFXdEMsWUFBb0IsT0FBa0I7UUFBbEIsWUFBTyxHQUFQLE9BQU8sQ0FBVztRQU4vQixpQkFBWSxHQUE2QjtZQUM5QyxVQUFVLEVBQUUsdUJBQXVCO1lBQ25DLEtBQUssRUFBRSxLQUFLO1lBQ1osTUFBTSxFQUFFLEtBQUs7U0FDZCxDQUFDO0lBRXVDLENBQUM7SUFHMUMsVUFBVTtRQUNSLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGtCQUFrQixFQUFFO1lBQ3BDLElBQUksRUFBRSxJQUFJLENBQUMsVUFBVTtZQUNyQixHQUFHLElBQUksQ0FBQyxZQUFZO1NBQ3JCLENBQUMsQ0FBQztJQUNMLENBQUM7O3dIQW5CVSwyQkFBMkI7NEdBQTNCLDJCQUEyQixtTENkeEMsNkJBQ0E7MkZEYWEsMkJBQTJCO2tCQUx2QyxTQUFTOytCQUNFLHVCQUF1QjtnR0FNMUIsVUFBVTtzQkFEaEIsS0FBSztnQkFJQyxZQUFZO3NCQURsQixLQUFLO2dCQVVOLFVBQVU7c0JBRFQsWUFBWTt1QkFBQyxPQUFPIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBIb3N0TGlzdGVuZXIsIEluamVjdCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7XG4gIE1BVF9ESUFMT0dfREFUQSxcbiAgTWF0RGlhbG9nLFxuICBNYXREaWFsb2dDb25maWcsXG59IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2RpYWxvZyc7XG5pbXBvcnQgeyBDM0ZpbGVWaWV3ZXIgfSBmcm9tICcuLi8uLi8uLi9tb2RlbHMvZmlsZS12aWV3ZXInO1xuaW1wb3J0IHsgQzNGaWxlVmlld2VyRGlhbG9nIH0gZnJvbSAnLi4vLi4vYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZyc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2MzLWZpbGUtdmlld2VyLWRpYWxvZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9jMy1maWxlLXZpZXdlci1kaWFsb2cuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9jMy1maWxlLXZpZXdlci1kaWFsb2cuY29tcG9uZW50LmNzcyddLFxufSlcbmV4cG9ydCBjbGFzcyBDM0ZpbGVWaWV3ZXJEaWFsb2dDb21wb25lbnQge1xuICBASW5wdXQoKVxuICBwdWJsaWMgZmlsZVZpZXdlciE6IEMzRmlsZVZpZXdlcjtcblxuICBASW5wdXQoKVxuICBwdWJsaWMgZGlhbG9nQ29uZmlnOiBQYXJ0aWFsPE1hdERpYWxvZ0NvbmZpZz4gPSB7XG4gICAgcGFuZWxDbGFzczogJ2MzLWZpbGUtdmlld2VyLWRpYWxvZycsXG4gICAgd2lkdGg6ICc4MCUnLFxuICAgIGhlaWdodDogJzgwJScsXG4gIH07XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBfZGlhbG9nOiBNYXREaWFsb2cpIHt9XG5cbiAgQEhvc3RMaXN0ZW5lcignY2xpY2snKVxuICBvcGVuRGlhbG9nKCkge1xuICAgIHRoaXMuX2RpYWxvZy5vcGVuKEMzRmlsZVZpZXdlckRpYWxvZywge1xuICAgICAgZGF0YTogdGhpcy5maWxlVmlld2VyLFxuICAgICAgLi4udGhpcy5kaWFsb2dDb25maWcsXG4gICAgfSk7XG4gIH1cbn1cbiIsIjxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiJdfQ==
|
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
import { BehaviorSubject, map, tap } from 'rxjs';
|
|
2
2
|
import { DEFAULT_CONFIG } from '../consts/default.config';
|
|
3
|
+
import { HttpClient } from '@angular/common/http';
|
|
3
4
|
import { CustomFileEvent } from './custom-file-event.model';
|
|
5
|
+
import { inject } from '@angular/core';
|
|
4
6
|
export class C3FileViewer {
|
|
5
7
|
get config() {
|
|
6
8
|
return this._config;
|
|
@@ -26,7 +28,7 @@ export class C3FileViewer {
|
|
|
26
28
|
get files() {
|
|
27
29
|
return this._files;
|
|
28
30
|
}
|
|
29
|
-
constructor({
|
|
31
|
+
constructor({ config, files, }) {
|
|
30
32
|
this._config = DEFAULT_CONFIG;
|
|
31
33
|
this.config$ = new BehaviorSubject(DEFAULT_CONFIG);
|
|
32
34
|
this.fullscreen$ = new BehaviorSubject(false);
|
|
@@ -56,8 +58,6 @@ export class C3FileViewer {
|
|
|
56
58
|
this.translateY = 0;
|
|
57
59
|
this.prevX = 0;
|
|
58
60
|
this.prevY = 0;
|
|
59
|
-
if (http)
|
|
60
|
-
this.http = http;
|
|
61
61
|
if (config)
|
|
62
62
|
this.config = config;
|
|
63
63
|
if (files)
|
|
@@ -79,7 +79,8 @@ export class C3FileViewer {
|
|
|
79
79
|
return this.getFile(file.location).pipe(map((response) => URL.createObjectURL(response)), tap(() => this.onLoad(file)));
|
|
80
80
|
}
|
|
81
81
|
getFile(location) {
|
|
82
|
-
const client = this.config.customClient ||
|
|
82
|
+
const client = this.config.customClient ||
|
|
83
|
+
inject(HttpClient).get.bind(inject(HttpClient));
|
|
83
84
|
if (!client) {
|
|
84
85
|
throw new Error('No http client provided. Please provide a custom client or import HttpClientModule');
|
|
85
86
|
}
|
|
@@ -202,4 +203,4 @@ export class C3FileViewer {
|
|
|
202
203
|
return result;
|
|
203
204
|
}
|
|
204
205
|
}
|
|
205
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-viewer.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-file-viewer/models/file-viewer.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Observable, map, tap } from 'rxjs';\nimport { DEFAULT_CONFIG } from '../consts/default.config';\nimport { C3FileViewerConfig } from './file-viewer-config.model';\nimport { HttpClient } from '@angular/common/http';\nimport { CustomFileEvent } from './custom-file-event.model';\nimport { FileMetadata } from './file-metadata';\n\nexport class C3FileViewer {\n  private _config: C3FileViewerConfig = DEFAULT_CONFIG;\n  get config(): C3FileViewerConfig {\n    return this._config;\n  }\n\n  set config(value: C3FileViewerConfig) {\n    this._config = this.mergeConfig(DEFAULT_CONFIG, value);\n    this.config$.next(this._config);\n  }\n  public config$ = new BehaviorSubject<C3FileViewerConfig>(DEFAULT_CONFIG);\n\n  public fullscreen$ = new BehaviorSubject<Boolean>(false);\n\n  public customFile$ = new BehaviorSubject<any>(null);\n  public index$ = new BehaviorSubject<number>(0);\n  public loading: boolean = true;\n  public currentIndex: number = 0;\n\n  get currentFile(): FileMetadata {\n    return this.filesObjectUrl[this.currentIndex];\n  }\n\n  public style = {\n    transform: '',\n    msTransform: '',\n    oTransform: '',\n    webkitTransform: '',\n    minHeight: 'auto',\n    maxHeight: 'auto',\n    height: 'auto',\n    minWidth: 'auto',\n    maxWidth: 'auto',\n    width: 'auto',\n  };\n  public styleHeight = '100%';\n  public hovered = false;\n\n  public set files(value: FileMetadata[]) {\n    this._files = value;\n    this.currentIndex = 0;\n    this.index$.next(this.currentIndex);\n\n    this.filesObjectUrl = value.map((file) => {\n      return {\n        ...file,\n        objectUrl: file.objectUrl || this.createObjectURL(file),\n      };\n    });\n  }\n  public get files(): FileMetadata[] {\n    return this._files;\n  }\n  private _files: FileMetadata[] = [];\n\n  public filesObjectUrl: Array<\n    FileMetadata & {\n      objectUrl?: Observable<string>;\n    }\n  > = [];\n\n  private scale = 1;\n  private rotation = 0;\n  private translateX = 0;\n  private translateY = 0;\n  private prevX: number = 0;\n  private prevY: number = 0;\n  public http?: HttpClient;\n\n  constructor({\n    http,\n    config,\n    files,\n  }: {\n    http?: HttpClient;\n    config?: C3FileViewerConfig;\n    files?: FileMetadata[];\n  }) {\n    if (http) this.http = http;\n    if (config) this.config = config;\n    if (files) this.files = files;\n\n    this.config$.subscribe((config) => {\n      const { minHeight, maxHeight, minWidth, maxWidth, height, width } =\n        config;\n      this.style.minHeight = this.valueToCss(minHeight);\n      this.style.height = this.valueToCss(height);\n      this.style.width = this.valueToCss(width);\n      this.style.maxHeight = this.valueToCss(maxHeight);\n      this.style.minWidth = this.valueToCss(minWidth);\n      this.style.maxWidth = this.valueToCss(maxWidth);\n      this.styleHeight = this.valueToCss(height);\n\n      this.updateStyle();\n    });\n  }\n\n  createObjectURL(file: FileMetadata) {\n    this.onLoadStart(file);\n    return this.getFile(file.location).pipe(\n      map((response) => URL.createObjectURL(response)),\n      tap(() => this.onLoad(file))\n    );\n  }\n\n  getFile(location: string) {\n    const client = this.config.customClient || this.http?.get.bind(this.http);\n    if (!client) {\n      throw new Error(\n        'No http client provided. Please provide a custom client or import HttpClientModule'\n      );\n    }\n\n    return client(location, {\n      responseType: 'blob',\n    });\n  }\n\n  previousImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex > 0) this.currentIndex--;\n      else this.currentIndex = this.files.length - 1;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  nextImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex < this.files.length - 1) this.currentIndex++;\n      else this.currentIndex = 0;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  zoomIn() {\n    this.scale *= 1 + (this.config.zoomFactor || 0);\n    this.updateStyle();\n  }\n\n  zoomOut() {\n    if (this.scale > (this.config.zoomFactor || 0)) {\n      this.scale /= 1 + (this.config.zoomFactor || 0);\n    }\n    this.updateStyle();\n  }\n\n  scrollZoom(evt: WheelEvent) {\n    if (this.config.wheelZoom) {\n      evt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  rotateClockwise() {\n    this.rotation += 90;\n    this.updateStyle();\n  }\n\n  rotateCounterClockwise() {\n    this.rotation -= 90;\n    this.updateStyle();\n  }\n\n  onLoad(file: FileMetadata) {\n    this.loading = false;\n  }\n\n  onLoadStart(file: FileMetadata) {\n    this.loading = true;\n  }\n\n  imageNotFound(file: FileMetadata) {\n    this.loading = false;\n    this.customFile$.next(new CustomFileEvent('imageNotFound', file.location));\n  }\n\n  onDragOver(evt: DragEvent) {\n    this.translateX += evt.clientX - this.prevX;\n    this.translateY += evt.clientY - this.prevY;\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n    this.updateStyle();\n  }\n\n  onDragStart(evt: DragEvent) {\n    if (evt.target && evt.dataTransfer && evt.dataTransfer.setDragImage) {\n      const target = evt.target as HTMLDivElement;\n      const nextElementSibling = target.nextElementSibling as HTMLDivElement;\n\n      if (nextElementSibling)\n        evt.dataTransfer.setDragImage(nextElementSibling, 0, 0);\n    }\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n  }\n\n  toggleFullscreen() {\n    const fullScreenValue = this.fullscreen$.getValue();\n    this.fullscreen$.next(!fullScreenValue);\n    if (fullScreenValue) this.reset();\n  }\n\n  reset() {\n    this.scale = 1;\n    this.rotation = 0;\n    this.translateX = 0;\n    this.translateY = 0;\n    this.updateStyle();\n  }\n\n  private canNavigate(event: any) {\n    return (\n      event == null || (this.config.allowKeyboardNavigation && this.hovered)\n    );\n  }\n\n  private updateStyle() {\n    this.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n    this.style.msTransform = this.style.transform;\n    this.style.webkitTransform = this.style.transform;\n    this.style.oTransform = this.style.transform;\n  }\n\n  private valueToCss(value: number | string | undefined) {\n    return value ? (typeof value === 'string' ? value : value + 'px') : 'auto';\n  }\n\n  private mergeConfig(\n    defaultValues: C3FileViewerConfig,\n    overrideValues: C3FileViewerConfig\n  ): C3FileViewerConfig {\n    let result: C3FileViewerConfig = { ...defaultValues };\n    if (overrideValues) {\n      result = { ...defaultValues, ...overrideValues };\n\n      if (overrideValues.btnIcons) {\n        result.btnIcons = {\n          ...defaultValues.btnIcons,\n          ...overrideValues.btnIcons,\n        };\n      }\n    }\n    return result;\n  }\n}\n"]}
|
|
206
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"file-viewer.js","sourceRoot":"","sources":["../../../../../../projects/c3-components/src/lib/c3-file-viewer/models/file-viewer.ts"],"names":[],"mappings":"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","sourcesContent":["import { BehaviorSubject, Observable, map, tap } from 'rxjs';\nimport { DEFAULT_CONFIG } from '../consts/default.config';\nimport { C3FileViewerConfig } from './file-viewer-config.model';\nimport { HttpClient } from '@angular/common/http';\nimport { CustomFileEvent } from './custom-file-event.model';\nimport { FileMetadata } from './file-metadata';\nimport { inject } from '@angular/core';\n\nexport class C3FileViewer {\n  private _config: C3FileViewerConfig = DEFAULT_CONFIG;\n  get config(): C3FileViewerConfig {\n    return this._config;\n  }\n\n  set config(value: C3FileViewerConfig) {\n    this._config = this.mergeConfig(DEFAULT_CONFIG, value);\n    this.config$.next(this._config);\n  }\n  public config$ = new BehaviorSubject<C3FileViewerConfig>(DEFAULT_CONFIG);\n\n  public fullscreen$ = new BehaviorSubject<Boolean>(false);\n\n  public customFile$ = new BehaviorSubject<any>(null);\n  public index$ = new BehaviorSubject<number>(0);\n  public loading: boolean = true;\n  public currentIndex: number = 0;\n\n  get currentFile(): FileMetadata {\n    return this.filesObjectUrl[this.currentIndex];\n  }\n\n  public style = {\n    transform: '',\n    msTransform: '',\n    oTransform: '',\n    webkitTransform: '',\n    minHeight: 'auto',\n    maxHeight: 'auto',\n    height: 'auto',\n    minWidth: 'auto',\n    maxWidth: 'auto',\n    width: 'auto',\n  };\n  public styleHeight = '100%';\n  public hovered = false;\n\n  public set files(value: FileMetadata[]) {\n    this._files = value;\n    this.currentIndex = 0;\n    this.index$.next(this.currentIndex);\n\n    this.filesObjectUrl = value.map((file) => {\n      return {\n        ...file,\n        objectUrl: file.objectUrl || this.createObjectURL(file),\n      };\n    });\n  }\n\n  public get files(): FileMetadata[] {\n    return this._files;\n  }\n\n  private _files: FileMetadata[] = [];\n\n  public filesObjectUrl: Array<\n    FileMetadata & {\n      objectUrl?: Observable<string>;\n    }\n  > = [];\n\n  private scale = 1;\n  private rotation = 0;\n  private translateX = 0;\n  private translateY = 0;\n  private prevX: number = 0;\n  private prevY: number = 0;\n\n  constructor({\n    config,\n    files,\n  }: {\n    config?: C3FileViewerConfig;\n    files?: FileMetadata[];\n  }) {\n    if (config) this.config = config;\n    if (files) this.files = files;\n\n    this.config$.subscribe((config) => {\n      const { minHeight, maxHeight, minWidth, maxWidth, height, width } =\n        config;\n      this.style.minHeight = this.valueToCss(minHeight);\n      this.style.height = this.valueToCss(height);\n      this.style.width = this.valueToCss(width);\n      this.style.maxHeight = this.valueToCss(maxHeight);\n      this.style.minWidth = this.valueToCss(minWidth);\n      this.style.maxWidth = this.valueToCss(maxWidth);\n      this.styleHeight = this.valueToCss(height);\n\n      this.updateStyle();\n    });\n  }\n\n  createObjectURL(file: FileMetadata) {\n    this.onLoadStart(file);\n    return this.getFile(file.location).pipe(\n      map((response) => URL.createObjectURL(response)),\n      tap(() => this.onLoad(file))\n    );\n  }\n\n  getFile(location: string) {\n    const client =\n      this.config.customClient ||\n      inject(HttpClient).get.bind(inject(HttpClient));\n    if (!client) {\n      throw new Error(\n        'No http client provided. Please provide a custom client or import HttpClientModule'\n      );\n    }\n\n    return client(location, {\n      responseType: 'blob',\n    });\n  }\n\n  previousImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex > 0) this.currentIndex--;\n      else this.currentIndex = this.files.length - 1;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  nextImage(event: KeyboardEvent | MouseEvent) {\n    if (this.canNavigate(event)) {\n      this.loading = true;\n      if (this.currentIndex < this.files.length - 1) this.currentIndex++;\n      else this.currentIndex = 0;\n      this.index$.next(this.currentIndex);\n      this.reset();\n    }\n  }\n\n  zoomIn() {\n    this.scale *= 1 + (this.config.zoomFactor || 0);\n    this.updateStyle();\n  }\n\n  zoomOut() {\n    if (this.scale > (this.config.zoomFactor || 0)) {\n      this.scale /= 1 + (this.config.zoomFactor || 0);\n    }\n    this.updateStyle();\n  }\n\n  scrollZoom(evt: WheelEvent) {\n    if (this.config.wheelZoom) {\n      evt.deltaY > 0 ? this.zoomOut() : this.zoomIn();\n      return false;\n    } else {\n      return true;\n    }\n  }\n\n  rotateClockwise() {\n    this.rotation += 90;\n    this.updateStyle();\n  }\n\n  rotateCounterClockwise() {\n    this.rotation -= 90;\n    this.updateStyle();\n  }\n\n  onLoad(file: FileMetadata) {\n    this.loading = false;\n  }\n\n  onLoadStart(file: FileMetadata) {\n    this.loading = true;\n  }\n\n  imageNotFound(file: FileMetadata) {\n    this.loading = false;\n    this.customFile$.next(new CustomFileEvent('imageNotFound', file.location));\n  }\n\n  onDragOver(evt: DragEvent) {\n    this.translateX += evt.clientX - this.prevX;\n    this.translateY += evt.clientY - this.prevY;\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n    this.updateStyle();\n  }\n\n  onDragStart(evt: DragEvent) {\n    if (evt.target && evt.dataTransfer && evt.dataTransfer.setDragImage) {\n      const target = evt.target as HTMLDivElement;\n      const nextElementSibling = target.nextElementSibling as HTMLDivElement;\n\n      if (nextElementSibling)\n        evt.dataTransfer.setDragImage(nextElementSibling, 0, 0);\n    }\n    this.prevX = evt.clientX;\n    this.prevY = evt.clientY;\n  }\n\n  toggleFullscreen() {\n    const fullScreenValue = this.fullscreen$.getValue();\n    this.fullscreen$.next(!fullScreenValue);\n    if (fullScreenValue) this.reset();\n  }\n\n  reset() {\n    this.scale = 1;\n    this.rotation = 0;\n    this.translateX = 0;\n    this.translateY = 0;\n    this.updateStyle();\n  }\n\n  private canNavigate(event: any) {\n    return (\n      event == null || (this.config.allowKeyboardNavigation && this.hovered)\n    );\n  }\n\n  private updateStyle() {\n    this.style.transform = `translate(${this.translateX}px, ${this.translateY}px) rotate(${this.rotation}deg) scale(${this.scale})`;\n    this.style.msTransform = this.style.transform;\n    this.style.webkitTransform = this.style.transform;\n    this.style.oTransform = this.style.transform;\n  }\n\n  private valueToCss(value: number | string | undefined) {\n    return value ? (typeof value === 'string' ? value : value + 'px') : 'auto';\n  }\n\n  private mergeConfig(\n    defaultValues: C3FileViewerConfig,\n    overrideValues: C3FileViewerConfig\n  ): C3FileViewerConfig {\n    let result: C3FileViewerConfig = { ...defaultValues };\n    if (overrideValues) {\n      result = { ...defaultValues, ...overrideValues };\n\n      if (overrideValues.btnIcons) {\n        result.btnIcons = {\n          ...defaultValues.btnIcons,\n          ...overrideValues.btnIcons,\n        };\n      }\n    }\n    return result;\n  }\n}\n"]}
|
package/esm2020/public-api.mjs
CHANGED
|
@@ -19,7 +19,8 @@ export * from './lib/c3-dialog/c3-dialog.module';
|
|
|
19
19
|
/**
|
|
20
20
|
* File Viewer
|
|
21
21
|
*/
|
|
22
|
-
export * from './lib/c3-file-viewer/components/c3-file-viewer/c3-file-viewer.component';
|
|
22
|
+
export * from './lib/c3-file-viewer/components/public/c3-file-viewer/c3-file-viewer.component';
|
|
23
|
+
export * from './lib/c3-file-viewer/components/public/c3-file-viewer-dialog/c3-file-viewer-dialog.component';
|
|
23
24
|
export * from './lib/c3-file-viewer/directives/full-screen.directive';
|
|
24
25
|
export * from './lib/c3-file-viewer/models/custom-file-event.model';
|
|
25
26
|
export * from './lib/c3-file-viewer/models/file-viewer-config.model';
|
|
@@ -30,4 +31,4 @@ export * from './lib/c3-file-viewer/c3-file-viewer.module';
|
|
|
30
31
|
* Safe Url
|
|
31
32
|
*/
|
|
32
33
|
export * from './lib/c3-safe-url/pipes/c3-safe-url.pipe';
|
|
33
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2MzLWNvbXBvbmVudHMvc3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLHlDQUF5QyxDQUFDO0FBRXhEOztHQUVHO0FBQ0gsY0FBYyxvREFBb0QsQ0FBQztBQUNuRSxjQUFjLGtEQUFrRCxDQUFDO0FBQ2pFLGNBQWMsc0NBQXNDLENBQUM7QUFFckQ7O0dBRUc7QUFDSCxjQUFjLHdEQUF3RCxDQUFDO0FBQ3ZFLGNBQWMsdURBQXVELENBQUM7QUFDdEUsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsa0NBQWtDLENBQUM7QUFFakQ7O0dBRUc7QUFDSCxjQUFjLGdGQUFnRixDQUFDO0FBQy9GLGNBQWMsOEZBQThGLENBQUM7QUFDN0csY0FBYyx1REFBdUQsQ0FBQztBQUN0RSxjQUFjLHFEQUFxRCxDQUFDO0FBQ3BFLGNBQWMsc0RBQXNELENBQUM7QUFDckUsY0FBYyx5Q0FBeUMsQ0FBQztBQUN4RCxjQUFjLDJDQUEyQyxDQUFDO0FBQzFELGNBQWMsNENBQTRDLENBQUM7QUFFM0Q7O0dBRUc7QUFDSCxjQUFjLDBDQUEwQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBjMy1jb21wb25lbnRzXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2h0dHAuY2xpZW50JztcblxuLyoqXG4gKiBEcm9wZG93blxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kcm9wZG93bi9jb21wb25lbnRzL2MzLWRyb3Bkb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1kcm9wZG93bi9kaXJlY3RpdmVzL2MzLWRyb3Bkb3duLnRyaWdnZXInO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZHJvcGRvd24vYzMtZHJvcGRvd24ubW9kdWxlJztcblxuLyoqXG4gKiBEaWFsb2dcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZGlhbG9nL2NvbXBvbmVudHMvYzMtZGlhbG9nLWNvbmZpcm0uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jb21wb25lbnRzL2MzLWRpYWxvZy1wcm9tcHQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jb21wb25lbnRzL2MzLWRpYWxvZy1lbWJlZC1jaGlsZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZGlhbG9nL3NlcnZpY2VzL2MzLWRpYWxvZy5zZXJ2aWNlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWRpYWxvZy9jMy1kaWFsb2cubW9kdWxlJztcblxuLyoqXG4gKiBGaWxlIFZpZXdlclxuICovXG5leHBvcnQgKiBmcm9tICcuL2xpYi9jMy1maWxlLXZpZXdlci9jb21wb25lbnRzL3B1YmxpYy9jMy1maWxlLXZpZXdlci9jMy1maWxlLXZpZXdlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvY29tcG9uZW50cy9wdWJsaWMvYzMtZmlsZS12aWV3ZXItZGlhbG9nL2MzLWZpbGUtdmlld2VyLWRpYWxvZy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvZGlyZWN0aXZlcy9mdWxsLXNjcmVlbi5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2N1c3RvbS1maWxlLWV2ZW50Lm1vZGVsJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLXZpZXdlci1jb25maWcubW9kZWwnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtZmlsZS12aWV3ZXIvbW9kZWxzL2ZpbGUtdmlld2VyJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL21vZGVscy9maWxlLW1ldGFkYXRhJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2MzLWZpbGUtdmlld2VyL2MzLWZpbGUtdmlld2VyLm1vZHVsZSc7XG5cbi8qKlxuICogU2FmZSBVcmxcbiAqL1xuZXhwb3J0ICogZnJvbSAnLi9saWIvYzMtc2FmZS11cmwvcGlwZXMvYzMtc2FmZS11cmwucGlwZSc7XG4iXX0=
|