ngx-tethys 13.2.1 → 13.2.4
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/CHANGELOG.md +41 -0
- package/collapse/styles/collapse.scss +3 -0
- package/drag-drop/drag-content.directive.d.ts +3 -0
- package/drag-drop/drag-drop.service.d.ts +14 -0
- package/drag-drop/drag-handle.directive.d.ts +3 -0
- package/drag-drop/drag.directive.d.ts +15 -0
- package/drag-drop/drop-container.directive.d.ts +36 -0
- package/drag-drop/examples/{basic/basic.component.scss → tree-drag/tree-drag.component.scss} +0 -0
- package/esm2020/drag-drop/drag-content.directive.mjs +4 -1
- package/esm2020/drag-drop/drag-drop.service.mjs +8 -1
- package/esm2020/drag-drop/drag-handle.directive.mjs +4 -1
- package/esm2020/drag-drop/drag.directive.mjs +12 -1
- package/esm2020/drag-drop/drop-container.directive.mjs +17 -1
- package/esm2020/image/preview/image-preview.component.mjs +2 -5
- package/esm2020/property/properties.component.mjs +54 -36
- package/esm2020/property/property-item.component.mjs +10 -1
- package/esm2020/time-picker/index.mjs +3 -1
- package/esm2020/time-picker/time-picker-panel.component.mjs +230 -0
- package/esm2020/time-picker/time-picker.component.mjs +299 -0
- package/esm2020/time-picker/time-picker.module.mjs +16 -6
- package/esm2020/version.mjs +2 -2
- package/esm2020/watermark/config.mjs +5 -10
- package/esm2020/watermark/watermark.directive.mjs +59 -43
- package/fesm2015/ngx-tethys-drag-drop.mjs +40 -0
- package/fesm2015/ngx-tethys-drag-drop.mjs.map +1 -1
- package/fesm2015/ngx-tethys-image.mjs +1 -1
- package/fesm2015/ngx-tethys-image.mjs.map +1 -1
- package/fesm2015/ngx-tethys-property.mjs +62 -35
- package/fesm2015/ngx-tethys-property.mjs.map +1 -1
- package/fesm2015/ngx-tethys-time-picker.mjs +532 -12
- package/fesm2015/ngx-tethys-time-picker.mjs.map +1 -1
- package/fesm2015/ngx-tethys-watermark.mjs +61 -49
- package/fesm2015/ngx-tethys-watermark.mjs.map +1 -1
- package/fesm2015/ngx-tethys.mjs +1 -1
- package/fesm2015/ngx-tethys.mjs.map +1 -1
- package/fesm2020/ngx-tethys-drag-drop.mjs +40 -0
- package/fesm2020/ngx-tethys-drag-drop.mjs.map +1 -1
- package/fesm2020/ngx-tethys-image.mjs +1 -4
- package/fesm2020/ngx-tethys-image.mjs.map +1 -1
- package/fesm2020/ngx-tethys-property.mjs +62 -35
- package/fesm2020/ngx-tethys-property.mjs.map +1 -1
- package/fesm2020/ngx-tethys-time-picker.mjs +531 -12
- package/fesm2020/ngx-tethys-time-picker.mjs.map +1 -1
- package/fesm2020/ngx-tethys-watermark.mjs +62 -51
- package/fesm2020/ngx-tethys-watermark.mjs.map +1 -1
- package/fesm2020/ngx-tethys.mjs +1 -1
- package/fesm2020/ngx-tethys.mjs.map +1 -1
- package/package.json +1 -1
- package/property/properties.component.d.ts +10 -4
- package/property/property-item.component.d.ts +5 -1
- package/property/styles/properties.scss +13 -4
- package/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/styles/variables.scss +4 -1
- package/tabs/styles/tabs.scss +4 -2
- package/time-picker/index.d.ts +2 -0
- package/time-picker/styles/index.scss +2 -0
- package/time-picker/styles/time-panel.scss +108 -0
- package/time-picker/styles/time-picker.scss +43 -0
- package/time-picker/styles/variables.scss +26 -0
- package/time-picker/time-picker-panel.component.d.ts +74 -0
- package/time-picker/time-picker.component.d.ts +72 -0
- package/time-picker/time-picker.module.d.ts +11 -2
- package/watermark/config.d.ts +4 -9
- package/watermark/styles/watermark.scss +0 -8
- package/watermark/watermark.directive.d.ts +12 -7
- package/drag-drop/examples/with-handle/with-handle.component.scss +0 -7
- package/property/examples/dynamic-rendering/dynamic-rendering.component.scss +0 -4
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,47 @@
|
|
|
2
2
|
|
|
3
3
|
All notable changes to this project will be documented in this file. See [standard-version](https://github.com/conventional-changelog/standard-version) for commit guidelines.
|
|
4
4
|
|
|
5
|
+
## [13.2.4](https://github.com/atinc/ngx-tethys/compare/13.2.3...13.2.4) (2022-08-23)
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+
### Bug Fixes
|
|
9
|
+
|
|
10
|
+
* **image:** fix blob image preview error #INFR-4333 ([#2103](https://github.com/atinc/ngx-tethys/issues/2103)) ([2e8c34d](https://github.com/atinc/ngx-tethys/commit/2e8c34d72ed436ce6dee4eadf5ad997e72a719d5)), closes [#INFR-4333](https://github.com/atinc/ngx-tethys/issues/INFR-4333)
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
|
|
14
|
+
## [13.2.3](https://github.com/atinc/ngx-tethys/compare/13.2.2...13.2.3) (2022-08-19)
|
|
15
|
+
|
|
16
|
+
|
|
17
|
+
### Bug Fixes
|
|
18
|
+
|
|
19
|
+
* **property:** update property item align-items is baseline #INFR-4285 ([d8d7c22](https://github.com/atinc/ngx-tethys/commit/d8d7c2295d017e15cb3bb1ad8328dff87678bdc0)), closes [#INFR-4285](https://github.com/atinc/ngx-tethys/issues/INFR-4285)
|
|
20
|
+
* **property:** update style, property label aalways top alignment ##INFR-4285 ([005344b](https://github.com/atinc/ngx-tethys/commit/005344b39b145b8870cbc5752f959c0e21b402c6)), closes [#INFR-4285](https://github.com/atinc/ngx-tethys/issues/INFR-4285)
|
|
21
|
+
* **watermark:** adjust the fake-box style #INFR-4287 ([7e4d96e](https://github.com/atinc/ngx-tethys/commit/7e4d96e076a455e2ac9873f6006a20a098929b33)), closes [#INFR-4287](https://github.com/atinc/ngx-tethys/issues/INFR-4287)
|
|
22
|
+
|
|
23
|
+
|
|
24
|
+
### Features
|
|
25
|
+
|
|
26
|
+
* **property:** support keep editing #INFR-4275 ([#2091](https://github.com/atinc/ngx-tethys/issues/2091)) ([ceb67a0](https://github.com/atinc/ngx-tethys/commit/ceb67a0564155154be57dc58e923a3f826425831)), closes [#INFR-4275](https://github.com/atinc/ngx-tethys/issues/INFR-4275)
|
|
27
|
+
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
## [13.2.2](https://github.com/atinc/ngx-tethys/compare/13.2.1...13.2.2) (2022-08-17)
|
|
31
|
+
|
|
32
|
+
|
|
33
|
+
### Bug Fixes
|
|
34
|
+
|
|
35
|
+
* **collapse:** fix collapse empty box style #INFR-4220 ([1f5a788](https://github.com/atinc/ngx-tethys/commit/1f5a7882aef62b23895c290b35787058f3d7bdce)), closes [#INFR-4220](https://github.com/atinc/ngx-tethys/issues/INFR-4220)
|
|
36
|
+
* **watermark:** adjust the var name & add test #INFO-4106 ([#2085](https://github.com/atinc/ngx-tethys/issues/2085)) ([aa4ad36](https://github.com/atinc/ngx-tethys/commit/aa4ad361337935a23fbf35bf41f516e8f326bada)), closes [#INFO-4106](https://github.com/atinc/ngx-tethys/issues/INFO-4106)
|
|
37
|
+
|
|
38
|
+
|
|
39
|
+
### Features
|
|
40
|
+
|
|
41
|
+
* **tabs:** change padding of tabs content to 16px #INFR-4204 ([#2082](https://github.com/atinc/ngx-tethys/issues/2082)) ([330c1de](https://github.com/atinc/ngx-tethys/commit/330c1deff97b4008e77db9442c2c876f84e9d6f0)), closes [#INFR-4204](https://github.com/atinc/ngx-tethys/issues/INFR-4204)
|
|
42
|
+
* **time-picker:** add new TimePicker #INFR-4147 ([#2087](https://github.com/atinc/ngx-tethys/issues/2087)) ([fa8cc62](https://github.com/atinc/ngx-tethys/commit/fa8cc62f18446ea727a848dc4b76c7222cdf7a53)), closes [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147) [#INFR-4147](https://github.com/atinc/ngx-tethys/issues/INFR-4147)
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
|
|
5
46
|
## [13.2.1](https://github.com/atinc/ngx-tethys/compare/13.2.0...13.2.1) (2022-08-11)
|
|
6
47
|
|
|
7
48
|
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import { ElementRef } from '@angular/core';
|
|
2
2
|
import { ThyDragDirective } from './drag.directive';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* 自定义拖拽时可经过,拖拽结束时可放置的区域内容
|
|
6
|
+
*/
|
|
4
7
|
export declare class ThyDragContentDirective {
|
|
5
8
|
element: ElementRef<HTMLElement>;
|
|
6
9
|
contentClass: boolean;
|
|
@@ -1,9 +1,23 @@
|
|
|
1
1
|
import { ThyDragDirective } from './drag.directive';
|
|
2
2
|
import { ThyDropPosition } from './drag-drop.class';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* 自定义可放置区域内容
|
|
6
|
+
*/
|
|
4
7
|
export declare class ThyDragDropService<T = any> {
|
|
8
|
+
/**
|
|
9
|
+
* 当前拖拽项,dragEnd 后重置为 undefined
|
|
10
|
+
*/
|
|
5
11
|
previousDrag: ThyDragDirective<T>;
|
|
12
|
+
/**
|
|
13
|
+
* 拖拽的时候,针对 dragOver 的节点有三种情况,即拖拽到节点之上 before ,拖拽到节点上 in ,拖拽到节点之下 after
|
|
14
|
+
* @type ThyDropPosition
|
|
15
|
+
*/
|
|
6
16
|
dropPosition: ThyDropPosition;
|
|
17
|
+
/**
|
|
18
|
+
* 用于拖动过程对 dragover 的元素设置相应的样式
|
|
19
|
+
* @type Map<Element, string>
|
|
20
|
+
*/
|
|
7
21
|
classMap: Map<Element, string>;
|
|
8
22
|
constructor();
|
|
9
23
|
static ɵfac: i0.ɵɵFactoryDeclaration<ThyDragDropService<any>, never>;
|
|
@@ -1,6 +1,9 @@
|
|
|
1
1
|
import { ElementRef } from '@angular/core';
|
|
2
2
|
import { ThyDragDirective } from './drag.directive';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
|
+
/**
|
|
5
|
+
* 自定义可拖拽区域内容
|
|
6
|
+
*/
|
|
4
7
|
export declare class ThyDragHandleDirective {
|
|
5
8
|
element: ElementRef<HTMLElement>;
|
|
6
9
|
private _disabled;
|
|
@@ -5,13 +5,28 @@ import { MixinBase, Constructor, ThyUnsubscribe } from 'ngx-tethys/core';
|
|
|
5
5
|
import { IThyDropContainerDirective } from './drop-container.class';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
7
7
|
declare const _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase;
|
|
8
|
+
/**
|
|
9
|
+
* 拖拽项
|
|
10
|
+
*/
|
|
8
11
|
export declare class ThyDragDirective<T = any> extends _MixinBase implements OnDestroy {
|
|
9
12
|
container: IThyDropContainerDirective;
|
|
10
13
|
private elementRef;
|
|
14
|
+
/**
|
|
15
|
+
* 元数据
|
|
16
|
+
* @type any
|
|
17
|
+
*/
|
|
11
18
|
set dragData(data: T);
|
|
19
|
+
/**
|
|
20
|
+
* 元数据
|
|
21
|
+
* @type any
|
|
22
|
+
*/
|
|
12
23
|
data: T;
|
|
13
24
|
isDraggable: boolean;
|
|
14
25
|
private _disabled;
|
|
26
|
+
/**
|
|
27
|
+
* 是否禁用拖拽
|
|
28
|
+
* @default false
|
|
29
|
+
*/
|
|
15
30
|
set disabled(isDisabled: boolean);
|
|
16
31
|
get disabled(): boolean;
|
|
17
32
|
dragRef: DragRef<T>;
|
|
@@ -7,16 +7,52 @@ import * as i0 from "@angular/core";
|
|
|
7
7
|
declare const _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase;
|
|
8
8
|
export declare class ThyDropContainerDirective<T = any> extends _MixinBase implements OnInit, AfterContentInit, IThyDropContainerDirective {
|
|
9
9
|
private ngZone;
|
|
10
|
+
/**
|
|
11
|
+
* 元数据
|
|
12
|
+
* @type any[]
|
|
13
|
+
*/
|
|
10
14
|
set dragContainer(data: T[]);
|
|
15
|
+
/**
|
|
16
|
+
* 元数据
|
|
17
|
+
* @type any[]
|
|
18
|
+
*/
|
|
11
19
|
data: T[];
|
|
20
|
+
/**
|
|
21
|
+
* 是否禁用拖拽
|
|
22
|
+
* @default false
|
|
23
|
+
*/
|
|
12
24
|
disabled: boolean;
|
|
25
|
+
/**
|
|
26
|
+
* 拖拽之前的回调,函数返回 false 则阻止拖拽
|
|
27
|
+
*/
|
|
13
28
|
beforeStart: (e: ThyDragStartEvent<T>) => boolean;
|
|
29
|
+
/**
|
|
30
|
+
* 拖拽时回调,函数返回 false 则阻止移入
|
|
31
|
+
*/
|
|
14
32
|
beforeOver: (e: ThyDragOverEvent<T>) => boolean;
|
|
33
|
+
/**
|
|
34
|
+
* 拖放到元素时回调,函数返回 false 则阻止放置
|
|
35
|
+
*/
|
|
15
36
|
beforeDrop: (e: ThyDragDropEvent<T>) => boolean;
|
|
37
|
+
/**
|
|
38
|
+
* 开始拖拽时调用
|
|
39
|
+
*/
|
|
16
40
|
started: EventEmitter<ThyDragStartEvent<ThyDragDirective<any>>>;
|
|
41
|
+
/**
|
|
42
|
+
* dragend 触发时调用
|
|
43
|
+
*/
|
|
17
44
|
ended: EventEmitter<ThyDragEndEvent<ThyDragDirective<any>>>;
|
|
45
|
+
/**
|
|
46
|
+
* dragover 触发时调用
|
|
47
|
+
*/
|
|
18
48
|
overed: EventEmitter<ThyDragOverEvent<ThyDragDirective<any>>>;
|
|
49
|
+
/**
|
|
50
|
+
* drop 触发时调用
|
|
51
|
+
*/
|
|
19
52
|
dropped: EventEmitter<ThyDragDropEvent<ThyDragDirective<any>>>;
|
|
53
|
+
/**
|
|
54
|
+
* @internal
|
|
55
|
+
*/
|
|
20
56
|
draggables: QueryList<ThyDragDirective>;
|
|
21
57
|
constructor(ngZone: NgZone);
|
|
22
58
|
ngOnInit(): void;
|
package/drag-drop/examples/{basic/basic.component.scss → tree-drag/tree-drag.component.scss}
RENAMED
|
File without changes
|
|
@@ -2,6 +2,9 @@ import { Directive, ElementRef, HostBinding, Optional } from '@angular/core';
|
|
|
2
2
|
import { ThyDragDirective } from './drag.directive';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "./drag.directive";
|
|
5
|
+
/**
|
|
6
|
+
* 自定义拖拽时可经过,拖拽结束时可放置的区域内容
|
|
7
|
+
*/
|
|
5
8
|
export class ThyDragContentDirective {
|
|
6
9
|
constructor(element, drag) {
|
|
7
10
|
this.element = element;
|
|
@@ -24,4 +27,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
24
27
|
type: HostBinding,
|
|
25
28
|
args: ['class.thy-drag-content']
|
|
26
29
|
}] } });
|
|
27
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
30
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1jb250ZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9kcmFnLWRyb3AvZHJhZy1jb250ZW50LmRpcmVjdGl2ZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFVBQVUsRUFBUyxXQUFXLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3BGLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtCQUFrQixDQUFDOzs7QUFFcEQ7O0dBRUc7QUFJSCxNQUFNLE9BQU8sdUJBQXVCO0lBR2hDLFlBQW1CLE9BQWdDLEVBQWMsSUFBc0I7UUFBcEUsWUFBTyxHQUFQLE9BQU8sQ0FBeUI7UUFGWixpQkFBWSxHQUFHLElBQUksQ0FBQztRQUd2RCxJQUFJLElBQUksRUFBRTtZQUNOLElBQUksQ0FBQyxPQUFPLENBQUMsa0JBQWtCLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDO1NBQ2pEO0lBQ0wsQ0FBQzs7b0hBUFEsdUJBQXVCO3dHQUF2Qix1QkFBdUI7MkZBQXZCLHVCQUF1QjtrQkFIbkMsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsbUNBQW1DO2lCQUNoRDs7MEJBSXlELFFBQVE7NENBRnZCLFlBQVk7c0JBQWxELFdBQVc7dUJBQUMsd0JBQXdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRGlyZWN0aXZlLCBFbGVtZW50UmVmLCBJbnB1dCwgSG9zdEJpbmRpbmcsIE9wdGlvbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBUaHlEcmFnRGlyZWN0aXZlIH0gZnJvbSAnLi9kcmFnLmRpcmVjdGl2ZSc7XG5cbi8qKlxuICog6Ieq5a6a5LmJ5ouW5ou95pe25Y+v57uP6L+H77yM5ouW5ou957uT5p2f5pe25Y+v5pS+572u55qE5Yy65Z+f5YaF5a65XG4gKi9cbkBEaXJlY3RpdmUoe1xuICAgIHNlbGVjdG9yOiAndGh5LWRyYWctY29udGVudCxbdGh5RHJhZ0NvbnRlbnRdJ1xufSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnQ29udGVudERpcmVjdGl2ZSB7XG4gICAgQEhvc3RCaW5kaW5nKCdjbGFzcy50aHktZHJhZy1jb250ZW50JykgY29udGVudENsYXNzID0gdHJ1ZTtcblxuICAgIGNvbnN0cnVjdG9yKHB1YmxpYyBlbGVtZW50OiBFbGVtZW50UmVmPEhUTUxFbGVtZW50PiwgQE9wdGlvbmFsKCkgZHJhZzogVGh5RHJhZ0RpcmVjdGl2ZSkge1xuICAgICAgICBpZiAoZHJhZykge1xuICAgICAgICAgICAgZHJhZy5kcmFnUmVmLndpdGhDb250ZW50RWxlbWVudCh0aGlzLmVsZW1lbnQpO1xuICAgICAgICB9XG4gICAgfVxufVxuIl19
|
|
@@ -1,7 +1,14 @@
|
|
|
1
1
|
import { Injectable } from '@angular/core';
|
|
2
2
|
import * as i0 from "@angular/core";
|
|
3
|
+
/**
|
|
4
|
+
* 自定义可放置区域内容
|
|
5
|
+
*/
|
|
3
6
|
export class ThyDragDropService {
|
|
4
7
|
constructor() {
|
|
8
|
+
/**
|
|
9
|
+
* 用于拖动过程对 dragover 的元素设置相应的样式
|
|
10
|
+
* @type Map<Element, string>
|
|
11
|
+
*/
|
|
5
12
|
this.classMap = new Map();
|
|
6
13
|
}
|
|
7
14
|
}
|
|
@@ -11,4 +18,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
11
18
|
type: Injectable,
|
|
12
19
|
args: [{ providedIn: 'root' }]
|
|
13
20
|
}], ctorParameters: function () { return []; } });
|
|
14
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1kcm9wLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZHJhZy1kcm9wL2RyYWctZHJvcC5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7O0FBSTNDOztHQUVHO0FBRUgsTUFBTSxPQUFPLGtCQUFrQjtJQWlCM0I7UUFMQTs7O1dBR0c7UUFDSSxhQUFRLEdBQUcsSUFBSSxHQUFHLEVBQW1CLENBQUM7SUFDOUIsQ0FBQzs7K0dBakJQLGtCQUFrQjttSEFBbEIsa0JBQWtCLGNBREwsTUFBTTsyRkFDbkIsa0JBQWtCO2tCQUQ5QixVQUFVO21CQUFDLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFRoeURyYWdEaXJlY3RpdmUgfSBmcm9tICcuL2RyYWcuZGlyZWN0aXZlJztcbmltcG9ydCB7IFRoeURyb3BQb3NpdGlvbiB9IGZyb20gJy4vZHJhZy1kcm9wLmNsYXNzJztcblxuLyoqXG4gKiDoh6rlrprkuYnlj6/mlL7nva7ljLrln5/lhoXlrrlcbiAqL1xuQEluamVjdGFibGUoeyBwcm92aWRlZEluOiAncm9vdCcgfSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRHJvcFNlcnZpY2U8VCA9IGFueT4ge1xuICAgIC8qKlxuICAgICAqIOW9k+WJjeaLluaLvemhue+8jGRyYWdFbmQg5ZCO6YeN572u5Li6IHVuZGVmaW5lZFxuICAgICAqL1xuICAgIHB1YmxpYyBwcmV2aW91c0RyYWc6IFRoeURyYWdEaXJlY3RpdmU8VD47XG5cbiAgICAvKipcbiAgICAgKiDmi5bmi73nmoTml7blgJnvvIzpkojlr7kgZHJhZ092ZXIg55qE6IqC54K55pyJ5LiJ56eN5oOF5Ya177yM5Y2z5ouW5ou95Yiw6IqC54K55LmL5LiKIGJlZm9yZSDvvIzmi5bmi73liLDoioLngrnkuIogaW4g77yM5ouW5ou95Yiw6IqC54K55LmL5LiLIGFmdGVyXG4gICAgICogQHR5cGUgVGh5RHJvcFBvc2l0aW9uXG4gICAgICovXG4gICAgcHVibGljIGRyb3BQb3NpdGlvbjogVGh5RHJvcFBvc2l0aW9uO1xuXG4gICAgLyoqXG4gICAgICog55So5LqO5ouW5Yqo6L+H56iL5a+5IGRyYWdvdmVyIOeahOWFg+e0oOiuvue9ruebuOW6lOeahOagt+W8j1xuICAgICAqIEB0eXBlIE1hcDxFbGVtZW50LCBzdHJpbmc+XG4gICAgICovXG4gICAgcHVibGljIGNsYXNzTWFwID0gbmV3IE1hcDxFbGVtZW50LCBzdHJpbmc+KCk7XG4gICAgY29uc3RydWN0b3IoKSB7fVxufVxuIl19
|
|
@@ -3,6 +3,9 @@ import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
|
|
3
3
|
import { ThyDragDirective } from './drag.directive';
|
|
4
4
|
import * as i0 from "@angular/core";
|
|
5
5
|
import * as i1 from "./drag.directive";
|
|
6
|
+
/**
|
|
7
|
+
* 自定义可拖拽区域内容
|
|
8
|
+
*/
|
|
6
9
|
export class ThyDragHandleDirective {
|
|
7
10
|
constructor(element, drag) {
|
|
8
11
|
this.element = element;
|
|
@@ -31,4 +34,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
31
34
|
type: Input,
|
|
32
35
|
args: ['thyDisabled']
|
|
33
36
|
}] } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
37
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy1oYW5kbGUuZGlyZWN0aXZlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2RyYWctZHJvcC9kcmFnLWhhbmRsZS5kaXJlY3RpdmUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxVQUFVLEVBQUUsS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN2RSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUM5RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQzs7O0FBRXBEOztHQUVHO0FBSUgsTUFBTSxPQUFPLHNCQUFzQjtJQVcvQixZQUFtQixPQUFnQyxFQUFjLElBQXNCO1FBQXBFLFlBQU8sR0FBUCxPQUFPLENBQXlCO1FBVjNDLGNBQVMsR0FBRyxLQUFLLENBQUM7UUFXdEIsSUFBSSxJQUFJLEVBQUU7WUFDTixJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNsQztJQUNMLENBQUM7SUFaRCxJQUNJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQUNELElBQUksUUFBUSxDQUFDLEtBQWM7UUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxxQkFBcUIsQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUNsRCxDQUFDOzttSEFUUSxzQkFBc0I7dUdBQXRCLHNCQUFzQjsyRkFBdEIsc0JBQXNCO2tCQUhsQyxTQUFTO21CQUFDO29CQUNQLFFBQVEsRUFBRSxpQ0FBaUM7aUJBQzlDOzswQkFZeUQsUUFBUTs0Q0FQMUQsUUFBUTtzQkFEWCxLQUFLO3VCQUFDLGFBQWEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIEVsZW1lbnRSZWYsIElucHV0LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgY29lcmNlQm9vbGVhblByb3BlcnR5IH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2NvZXJjaW9uJztcbmltcG9ydCB7IFRoeURyYWdEaXJlY3RpdmUgfSBmcm9tICcuL2RyYWcuZGlyZWN0aXZlJztcblxuLyoqXG4gKiDoh6rlrprkuYnlj6/mi5bmi73ljLrln5/lhoXlrrlcbiAqL1xuQERpcmVjdGl2ZSh7XG4gICAgc2VsZWN0b3I6ICd0aHktZHJhZy1oYW5kbGUsW3RoeURyYWdIYW5kbGVdJ1xufSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnSGFuZGxlRGlyZWN0aXZlIHtcbiAgICBwcml2YXRlIF9kaXNhYmxlZCA9IGZhbHNlO1xuXG4gICAgQElucHV0KCd0aHlEaXNhYmxlZCcpXG4gICAgZ2V0IGRpc2FibGVkKCk6IGJvb2xlYW4ge1xuICAgICAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7XG4gICAgfVxuICAgIHNldCBkaXNhYmxlZCh2YWx1ZTogYm9vbGVhbikge1xuICAgICAgICB0aGlzLl9kaXNhYmxlZCA9IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSh2YWx1ZSk7XG4gICAgfVxuXG4gICAgY29uc3RydWN0b3IocHVibGljIGVsZW1lbnQ6IEVsZW1lbnRSZWY8SFRNTEVsZW1lbnQ+LCBAT3B0aW9uYWwoKSBkcmFnOiBUaHlEcmFnRGlyZWN0aXZlKSB7XG4gICAgICAgIGlmIChkcmFnKSB7XG4gICAgICAgICAgICBkcmFnLmRyYWdSZWYud2l0aEhhbmRsZXModGhpcyk7XG4gICAgICAgIH1cbiAgICB9XG59XG4iXX0=
|
|
@@ -8,6 +8,9 @@ import { THY_DROP_CONTAINER_DIRECTIVE } from './drop-container.class';
|
|
|
8
8
|
import * as i0 from "@angular/core";
|
|
9
9
|
import * as i1 from "./drag-drop.service";
|
|
10
10
|
const _MixinBase = mixinUnsubscribe(MixinBase);
|
|
11
|
+
/**
|
|
12
|
+
* 拖拽项
|
|
13
|
+
*/
|
|
11
14
|
export class ThyDragDirective extends _MixinBase {
|
|
12
15
|
constructor(document, container, ngZone, elementRef, service, renderer) {
|
|
13
16
|
super();
|
|
@@ -17,9 +20,17 @@ export class ThyDragDirective extends _MixinBase {
|
|
|
17
20
|
this._disabled = false;
|
|
18
21
|
this.dragRef = new DragRef(elementRef, this, container, service, document, ngZone, renderer);
|
|
19
22
|
}
|
|
23
|
+
/**
|
|
24
|
+
* 元数据
|
|
25
|
+
* @type any
|
|
26
|
+
*/
|
|
20
27
|
set dragData(data) {
|
|
21
28
|
this.data = data;
|
|
22
29
|
}
|
|
30
|
+
/**
|
|
31
|
+
* 是否禁用拖拽
|
|
32
|
+
* @default false
|
|
33
|
+
*/
|
|
23
34
|
set disabled(isDisabled) {
|
|
24
35
|
this._disabled = isDisabled;
|
|
25
36
|
this.isDraggable = !isDisabled;
|
|
@@ -63,4 +74,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
63
74
|
type: Input,
|
|
64
75
|
args: ['thyDragDisabled']
|
|
65
76
|
}] } });
|
|
66
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJhZy5kaXJlY3RpdmUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvZHJhZy1kcm9wL2RyYWcuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLEtBQUssRUFBRSxNQUFNLEVBQWEsUUFBUSxFQUFFLFNBQVMsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMxSCxPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sWUFBWSxDQUFDO0FBQ3JDLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMzQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsU0FBUyxFQUErQixZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUN6RyxPQUFPLEVBQUUsNEJBQTRCLEVBQThCLE1BQU0sd0JBQXdCLENBQUM7OztBQUVsRyxNQUFNLFVBQVUsR0FBbUQsZ0JBQWdCLENBQUMsU0FBUyxDQUFDLENBQUM7QUFFL0Y7O0dBRUc7QUFFSCxNQUFNLE9BQU8sZ0JBQTBCLFNBQVEsVUFBVTtJQW9DckQsWUFDc0IsUUFBYSxFQUMwQixTQUFxQyxFQUM5RixNQUFjLEVBQ04sVUFBbUMsRUFDM0MsT0FBOEIsRUFDOUIsUUFBbUI7UUFFbkIsS0FBSyxFQUFFLENBQUM7UUFOaUQsY0FBUyxHQUFULFNBQVMsQ0FBNEI7UUFFdEYsZUFBVSxHQUFWLFVBQVUsQ0FBeUI7UUF4QmhCLGdCQUFXLEdBQUcsSUFBSSxDQUFDO1FBRTFDLGNBQVMsR0FBRyxLQUFLLENBQUM7UUEyQnRCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxPQUFPLENBQUksVUFBVSxFQUFFLElBQUksRUFBRSxTQUFTLEVBQUUsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLEVBQUUsUUFBUSxDQUFDLENBQUM7SUFDcEcsQ0FBQztJQTdDRDs7O09BR0c7SUFDSCxJQUNJLFFBQVEsQ0FBQyxJQUFPO1FBQ2hCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFDO0lBQ3JCLENBQUM7SUFZRDs7O09BR0c7SUFHSCxJQUFJLFFBQVEsQ0FBQyxVQUFtQjtRQUM1QixJQUFJLENBQUMsU0FBUyxHQUFHLFVBQVUsQ0FBQztRQUM1QixJQUFJLENBQUMsV0FBVyxHQUFHLENBQUMsVUFBVSxDQUFDO0lBQ25DLENBQUM7SUFDRCxJQUFJLFFBQVE7UUFDUixPQUFPLElBQUksQ0FBQyxTQUFTLENBQUM7SUFDMUIsQ0FBQztJQWdCRCxXQUFXO1FBQ1AsS0FBSyxDQUFDLFdBQVcsRUFBRSxDQUFDO1FBQ3BCLElBQUksQ0FBQyxPQUFPLENBQUMsT0FBTyxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7NkdBbkRRLGdCQUFnQixrQkFxQ2IsUUFBUSxhQUNJLDRCQUE0QjtpR0F0QzNDLGdCQUFnQjtBQTBCekI7SUFEQyxZQUFZLEVBQUU7OztnREFJZDsyRkE3QlEsZ0JBQWdCO2tCQUQ1QixTQUFTO21CQUFDLEVBQUUsUUFBUSxFQUFFLG9CQUFvQixFQUFFOzswQkFzQ3BDLE1BQU07MkJBQUMsUUFBUTs7MEJBQ2YsUUFBUTs7MEJBQUksTUFBTTsyQkFBQyw0QkFBNEI7bUpBaENoRCxRQUFRO3NCQURYLEtBQUs7dUJBQUMsU0FBUztnQkFTTSxJQUFJO3NCQUF6QixLQUFLO3VCQUFDLGFBQWE7Z0JBRVcsV0FBVztzQkFBekMsV0FBVzt1QkFBQyxnQkFBZ0I7Z0JBVXpCLFFBQVE7c0JBRlgsS0FBSzt1QkFBQyxpQkFBaUIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBEaXJlY3RpdmUsIE5nWm9uZSwgRWxlbWVudFJlZiwgSG9zdEJpbmRpbmcsIElucHV0LCBJbmplY3QsIE9uRGVzdHJveSwgT3B0aW9uYWwsIFJlbmRlcmVyMiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgRHJhZ1JlZiB9IGZyb20gJy4vZHJhZy1yZWYnO1xuaW1wb3J0IHsgRE9DVU1FTlQgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgVGh5RHJhZ0Ryb3BTZXJ2aWNlIH0gZnJvbSAnLi9kcmFnLWRyb3Auc2VydmljZSc7XG5pbXBvcnQgeyBtaXhpblVuc3Vic2NyaWJlLCBNaXhpbkJhc2UsIENvbnN0cnVjdG9yLCBUaHlVbnN1YnNjcmliZSwgSW5wdXRCb29sZWFuIH0gZnJvbSAnbmd4LXRldGh5cy9jb3JlJztcbmltcG9ydCB7IFRIWV9EUk9QX0NPTlRBSU5FUl9ESVJFQ1RJVkUsIElUaHlEcm9wQ29udGFpbmVyRGlyZWN0aXZlIH0gZnJvbSAnLi9kcm9wLWNvbnRhaW5lci5jbGFzcyc7XG5cbmNvbnN0IF9NaXhpbkJhc2U6IENvbnN0cnVjdG9yPFRoeVVuc3Vic2NyaWJlPiAmIHR5cGVvZiBNaXhpbkJhc2UgPSBtaXhpblVuc3Vic2NyaWJlKE1peGluQmFzZSk7XG5cbi8qKlxuICog5ouW5ou96aG5XG4gKi9cbkBEaXJlY3RpdmUoeyBzZWxlY3RvcjogJ3RoeS1kcmFnLFt0aHlEcmFnXScgfSlcbmV4cG9ydCBjbGFzcyBUaHlEcmFnRGlyZWN0aXZlPFQgPSBhbnk+IGV4dGVuZHMgX01peGluQmFzZSBpbXBsZW1lbnRzIE9uRGVzdHJveSB7XG4gICAgLyoqXG4gICAgICog5YWD5pWw5o2uXG4gICAgICogQHR5cGUgYW55XG4gICAgICovXG4gICAgQElucHV0KCd0aHlEcmFnJylcbiAgICBzZXQgZHJhZ0RhdGEoZGF0YTogVCkge1xuICAgICAgICB0aGlzLmRhdGEgPSBkYXRhO1xuICAgIH1cblxuICAgIC8qKlxuICAgICAqIOWFg+aVsOaNrlxuICAgICAqIEB0eXBlIGFueVxuICAgICAqL1xuICAgIEBJbnB1dCgndGh5RHJhZ0RhdGEnKSBkYXRhOiBUO1xuXG4gICAgQEhvc3RCaW5kaW5nKCdhdHRyLmRyYWdnYWJsZScpIGlzRHJhZ2dhYmxlID0gdHJ1ZTtcblxuICAgIHByaXZhdGUgX2Rpc2FibGVkID0gZmFsc2U7XG5cbiAgICAvKipcbiAgICAgKiDmmK/lkKbnpoHnlKjmi5bmi71cbiAgICAgKiBAZGVmYXVsdCBmYWxzZVxuICAgICAqL1xuICAgIEBJbnB1dCgndGh5RHJhZ0Rpc2FibGVkJylcbiAgICBASW5wdXRCb29sZWFuKClcbiAgICBzZXQgZGlzYWJsZWQoaXNEaXNhYmxlZDogYm9vbGVhbikge1xuICAgICAgICB0aGlzLl9kaXNhYmxlZCA9IGlzRGlzYWJsZWQ7XG4gICAgICAgIHRoaXMuaXNEcmFnZ2FibGUgPSAhaXNEaXNhYmxlZDtcbiAgICB9XG4gICAgZ2V0IGRpc2FibGVkKCkge1xuICAgICAgICByZXR1cm4gdGhpcy5fZGlzYWJsZWQ7XG4gICAgfVxuXG4gICAgcHVibGljIGRyYWdSZWY6IERyYWdSZWY8VD47XG5cbiAgICBjb25zdHJ1Y3RvcihcbiAgICAgICAgQEluamVjdChET0NVTUVOVCkgZG9jdW1lbnQ6IGFueSxcbiAgICAgICAgQE9wdGlvbmFsKCkgQEluamVjdChUSFlfRFJPUF9DT05UQUlORVJfRElSRUNUSVZFKSBwdWJsaWMgY29udGFpbmVyOiBJVGh5RHJvcENvbnRhaW5lckRpcmVjdGl2ZSxcbiAgICAgICAgbmdab25lOiBOZ1pvbmUsXG4gICAgICAgIHByaXZhdGUgZWxlbWVudFJlZjogRWxlbWVudFJlZjxIVE1MRWxlbWVudD4sXG4gICAgICAgIHNlcnZpY2U6IFRoeURyYWdEcm9wU2VydmljZTxUPixcbiAgICAgICAgcmVuZGVyZXI6IFJlbmRlcmVyMlxuICAgICkge1xuICAgICAgICBzdXBlcigpO1xuICAgICAgICB0aGlzLmRyYWdSZWYgPSBuZXcgRHJhZ1JlZjxUPihlbGVtZW50UmVmLCB0aGlzLCBjb250YWluZXIsIHNlcnZpY2UsIGRvY3VtZW50LCBuZ1pvbmUsIHJlbmRlcmVyKTtcbiAgICB9XG5cbiAgICBuZ09uRGVzdHJveSgpIHtcbiAgICAgICAgc3VwZXIubmdPbkRlc3Ryb3koKTtcbiAgICAgICAgdGhpcy5kcmFnUmVmLmRpc3Bvc2UoKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -10,11 +10,27 @@ export class ThyDropContainerDirective extends _MixinBase {
|
|
|
10
10
|
constructor(ngZone) {
|
|
11
11
|
super();
|
|
12
12
|
this.ngZone = ngZone;
|
|
13
|
+
/**
|
|
14
|
+
* 开始拖拽时调用
|
|
15
|
+
*/
|
|
13
16
|
this.started = new EventEmitter();
|
|
17
|
+
/**
|
|
18
|
+
* dragend 触发时调用
|
|
19
|
+
*/
|
|
14
20
|
this.ended = new EventEmitter();
|
|
21
|
+
/**
|
|
22
|
+
* dragover 触发时调用
|
|
23
|
+
*/
|
|
15
24
|
this.overed = new EventEmitter();
|
|
25
|
+
/**
|
|
26
|
+
* drop 触发时调用
|
|
27
|
+
*/
|
|
16
28
|
this.dropped = new EventEmitter();
|
|
17
29
|
}
|
|
30
|
+
/**
|
|
31
|
+
* 元数据
|
|
32
|
+
* @type any[]
|
|
33
|
+
*/
|
|
18
34
|
set dragContainer(data) {
|
|
19
35
|
this.data = data;
|
|
20
36
|
}
|
|
@@ -101,4 +117,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
101
117
|
descendants: false
|
|
102
118
|
}]
|
|
103
119
|
}] } });
|
|
104
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"drop-container.directive.js","sourceRoot":"","sources":["../../../../src/drag-drop/drop-container.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { OnInit, Directive, Output, EventEmitter, ContentChildren, QueryList, AfterContentInit, NgZone, Input } from '@angular/core';\nimport { ThyDragDirective } from './drag.directive';\nimport { merge, Observable, defer } from 'rxjs';\nimport { mixinUnsubscribe, MixinBase, Constructor, ThyUnsubscribe } from 'ngx-tethys/core';\nimport { takeUntil, startWith, take, switchMap } from 'rxjs/operators';\nimport { ThyDragDropEvent, ThyDragStartEvent, ThyDragEndEvent, ThyDragOverEvent } from './drag-drop.class';\nimport { THY_DROP_CONTAINER_DIRECTIVE, IThyDropContainerDirective } from './drop-container.class';\n\nconst _MixinBase: Constructor<ThyUnsubscribe> & typeof MixinBase = mixinUnsubscribe(MixinBase);\n\n@Directive({\n    selector: 'thy-drop-container,[thyDropContainer]',\n    providers: [\n        {\n            provide: THY_DROP_CONTAINER_DIRECTIVE,\n            useExisting: ThyDropContainerDirective\n        }\n    ]\n})\nexport class ThyDropContainerDirective<T = any> extends _MixinBase implements OnInit, AfterContentInit, IThyDropContainerDirective {\n    /**\n     * 元数据\n     * @type any[]\n     */\n    @Input('thyDropContainer')\n    set dragContainer(data: T[]) {\n        this.data = data;\n    }\n\n    /**\n     * 元数据\n     * @type any[]\n     */\n    @Input('thyDropContainerData') data: T[];\n\n    /**\n     * 是否禁用拖拽\n     * @default false\n     */\n    @Input('thyDropContainerDisabled') disabled: boolean;\n\n    /**\n     * 拖拽之前的回调，函数返回 false 则阻止拖拽\n     */\n    @Input('thyBeforeDragStart') beforeStart: (e: ThyDragStartEvent<T>) => boolean;\n\n    /**\n     * 拖拽时回调，函数返回 false 则阻止移入\n     */\n    @Input('thyBeforeDragOver') beforeOver: (e: ThyDragOverEvent<T>) => boolean;\n\n    /**\n     * 拖放到元素时回调，函数返回 false 则阻止放置\n     */\n    @Input('thyBeforeDragDrop') beforeDrop: (e: ThyDragDropEvent<T>) => boolean;\n\n    /**\n     * 开始拖拽时调用\n     */\n    @Output('thyDragStarted') started = new EventEmitter<ThyDragStartEvent<ThyDragDirective>>();\n\n    /**\n     * dragend 触发时调用\n     */\n    @Output('thyDragEnded') ended = new EventEmitter<ThyDragEndEvent<ThyDragDirective>>();\n\n    /**\n     * dragover 触发时调用\n     */\n    @Output('thyDragOvered') overed = new EventEmitter<ThyDragOverEvent<ThyDragDirective>>();\n\n    /**\n     * drop 触发时调用\n     */\n    @Output('thyDragDropped') dropped = new EventEmitter<ThyDragDropEvent<ThyDragDirective>>();\n\n    /**\n     * @internal\n     */\n    @ContentChildren(ThyDragDirective, {\n        descendants: false\n    })\n    draggables: QueryList<ThyDragDirective>;\n\n    constructor(private ngZone: NgZone) {\n        super();\n    }\n\n    ngOnInit() {}\n\n    ngAfterContentInit() {\n        this.draggables.changes.pipe(startWith(null), takeUntil(this.ngUnsubscribe$)).subscribe(() => {\n            this.draggableChanges();\n        });\n    }\n\n    private draggableChanges() {\n        this.resetDraggableChanges(item => item.dragRef.started).subscribe(event => {\n            this.started.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.ended).subscribe(event => {\n            this.ended.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.overed).subscribe(event => {\n            this.overed.emit(event);\n        });\n        this.resetDraggableChanges(item => item.dragRef.dropped).subscribe(event => {\n            this.dropped.emit(event);\n        });\n    }\n\n    private resetDraggableChanges(fn: (item: ThyDragDirective) => Observable<any>) {\n        return defer(() => {\n            if (this.draggables) {\n                return merge(...this.draggables.map(fn));\n            }\n            return this.ngZone.onStable.asObservable().pipe(\n                take(1),\n                switchMap(() => this.resetDraggableChanges.bind(this, fn))\n            );\n        }).pipe(takeUntil(merge(this.ngUnsubscribe$, this.draggables.changes))) as Observable<any>;\n    }\n}\n"]}
|
|
@@ -129,10 +129,7 @@ export class ThyImagePreviewComponent extends mixinUnsubscribe(MixinBase) {
|
|
|
129
129
|
get previewImage() {
|
|
130
130
|
const image = this.images[this.previewIndex];
|
|
131
131
|
if (image.size) {
|
|
132
|
-
|
|
133
|
-
...image,
|
|
134
|
-
size: isNumber(image.size) ? humanizeBytes(image.size) : image.size
|
|
135
|
-
};
|
|
132
|
+
image.size = isNumber(image.size) ? humanizeBytes(image.size) : image.size;
|
|
136
133
|
}
|
|
137
134
|
return image;
|
|
138
135
|
}
|
|
@@ -421,4 +418,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
421
418
|
type: ViewChild,
|
|
422
419
|
args: ['imagePreviewWrapper', { static: true }]
|
|
423
420
|
}] } });
|
|
424
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-preview.component.js","sourceRoot":"","sources":["../../../../../src/image/preview/image-preview.component.ts","../../../../../src/image/preview/image-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    OnInit,\n    ViewEncapsulation,\n    ChangeDetectorRef,\n    ElementRef,\n    ViewChild,\n    NgZone,\n    OnDestroy\n} from '@angular/core';\nimport { InternalImageInfo, ThyImageInfo, ThyImagePreviewMode, ThyImagePreviewOperation, ThyImagePreviewOptions } from '../image.class';\nimport { MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';\nimport { fromEvent, Observable, of } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { ThyDialog } from 'ngx-tethys/dialog';\nimport { getClientSize, getFitContentPosition, getOffset, humanizeBytes, isNumber, isUndefinedOrNull } from 'ngx-tethys/util';\nimport { ThyFullscreen } from 'ngx-tethys/fullscreen';\nimport { ThyCopyEvent } from 'ngx-tethys/copy';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { fetchImageBlob } from '../utils';\n\nconst initialPosition = {\n    x: 0,\n    y: 0\n};\nconst IMAGE_MAX_ZOOM = 3;\nconst IMAGE_MIN_ZOOM = 0.1;\nconst HORIZONTAL_SPACE = 100 * 2; // left: 100px; right: 100px\nconst VERTICAL_SPACE = 96 + 106; // top: 96px; bottom: 106px\n\n/**\n * 图片预览组件\n */\n@Component({\n    selector: 'thy-image-preview',\n    exportAs: 'thyImagePreview',\n    templateUrl: './image-preview.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'thy-image-preview-wrap',\n        '[class.thy-image-preview-moving]': 'isDragging'\n    }\n})\nexport class ThyImagePreviewComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    images: InternalImageInfo[] = [];\n    previewIndex: number = 0;\n    previewConfig: ThyImagePreviewOptions;\n    previewImageTransform = '';\n    previewImageWrapperTransform = '';\n    zoomDisabled = false;\n    zoom: number = 1;\n    position = { ...initialPosition };\n    isDragging = false;\n    isLoadingDone = false;\n    isFullScreen = false;\n    isInsideScreen = true;\n    currentImageMode: ThyImagePreviewMode = 'original-scale';\n    previewOperations: ThyImagePreviewOperation[];\n    defaultPreviewOperations: ThyImagePreviewOperation[] = [\n        {\n            icon: 'zoom-out',\n            name: '缩小',\n            action: (image: ThyImageInfo) => {\n                this.zoomOut();\n            },\n            type: 'zoom-out'\n        },\n        {\n            icon: 'zoom-in',\n            name: '放大',\n            action: (image: ThyImageInfo) => {\n                this.zoomIn();\n            },\n            type: 'zoom-in'\n        },\n        {\n            icon: 'one-to-one',\n            name: '原始比例',\n            action: (image: ThyImageInfo) => {\n                this.setOriginalSize();\n            },\n            type: 'original-scale'\n        },\n        {\n            icon: 'max-view',\n            name: '适应屏幕',\n            action: () => {\n                this.setFitScreen();\n            },\n            type: 'fit-screen'\n        },\n        {\n            icon: 'expand-arrows',\n            name: '全屏显示',\n            action: () => {\n                this.fullScreen();\n            },\n            type: 'full-screen'\n        },\n        {\n            icon: 'rotate-right',\n            name: '旋转',\n            action: (image: ThyImageInfo) => {\n                this.rotateRight();\n            },\n            type: 'rotate-right'\n        },\n        {\n            icon: 'download',\n            name: '下载',\n            action: (image: ThyImageInfo) => {\n                this.download(image);\n            },\n            type: 'download'\n        },\n        {\n            icon: 'preview',\n            name: '查看原图',\n            action: () => {\n                this.viewOriginal();\n            },\n            type: 'view-original'\n        },\n        {\n            icon: 'link-insert',\n            name: '复制链接',\n            type: 'copyLink'\n        }\n    ];\n    private rotate: number;\n\n    get previewImage(): InternalImageInfo {\n        const image = this.images[this.previewIndex];\n        if (image.size) {\n            return {\n                ...image,\n                size: isNumber(image.size) ? humanizeBytes(image.size) : image.size\n            };\n        }\n        return image;\n    }\n\n    get previewImageOriginSrc() {\n        let imageSrc = this.previewImage.origin?.src || this.previewImage.src;\n        if (imageSrc.startsWith('./')) {\n            return window.location.host + '/' + imageSrc.split('./')[1];\n        }\n        return imageSrc;\n    }\n\n    get defaultZoom(): number {\n        if (this.previewConfig?.zoom && this.previewConfig?.zoom > 0) {\n            return this.previewConfig.zoom >= IMAGE_MAX_ZOOM\n                ? IMAGE_MAX_ZOOM\n                : this.previewConfig.zoom <= IMAGE_MIN_ZOOM\n                ? IMAGE_MIN_ZOOM\n                : this.previewConfig.zoom;\n        }\n    }\n\n    @ViewChild('imgRef', { static: false }) imageRef!: ElementRef<HTMLImageElement>;\n    @ViewChild('imagePreviewWrapper', { static: true }) imagePreviewWrapper!: ElementRef<HTMLElement>;\n\n    constructor(\n        public thyDialog: ThyDialog,\n        public thyFullscreen: ThyFullscreen,\n        private cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private notifyService: ThyNotifyService,\n        private host: ElementRef<HTMLElement>,\n        private sanitizer: DomSanitizer\n    ) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.initPreview();\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(this.host.nativeElement, 'click')\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe(event => {\n                    if (\n                        (event.target === event.currentTarget ||\n                            (this.isInsideScreen && this.imagePreviewWrapper.nativeElement.contains(event.target as HTMLElement))) &&\n                        !this.previewConfig?.disableClose\n                    ) {\n                        this.ngZone.run(() => !this.isFullScreen && this.thyDialog.close());\n                    }\n                });\n\n            fromEvent(this.imagePreviewWrapper.nativeElement, 'mousedown')\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe(() => {\n                    this.isDragging = !this.isInsideScreen && true;\n                });\n        });\n    }\n\n    setOriginalSize() {\n        this.reset();\n        this.currentImageMode = 'fit-screen';\n        this.zoom = 1;\n        this.updatePreviewImageTransform();\n        this.calculateInsideScreen();\n        this.isLoadingDone = true;\n        this.cdr.detectChanges();\n    }\n\n    setFitScreen() {\n        this.reset();\n        this.isInsideScreen = true;\n        this.updatePreviewImage();\n    }\n\n    useDefaultZoomUpdate(isUpdateImageWrapper: boolean) {\n        this.zoom = this.defaultZoom;\n        this.isLoadingDone = true;\n        this.updatePreviewImageTransform();\n        if (isUpdateImageWrapper) {\n            this.updatePreviewImageWrapperTransform();\n        }\n        this.cdr.detectChanges();\n    }\n\n    useCalculateZoomUpdate(isUpdateImageWrapper?: boolean) {\n        let img = new Image();\n        img.src = this.previewImage.src;\n        img.onload = () => {\n            const { width: offsetWidth, height: offsetHeight } = getClientSize();\n            const innerWidth = offsetWidth - HORIZONTAL_SPACE;\n            const innerHeight = offsetHeight - VERTICAL_SPACE;\n            const { naturalWidth, naturalHeight } = img;\n            const xRatio = innerWidth / naturalWidth;\n            const yRatio = innerHeight / naturalHeight;\n            const zoom = Math.min(xRatio, yRatio);\n            if (zoom > 1) {\n                this.zoom = 1;\n            } else {\n                this.zoom = zoom;\n            }\n            this.isLoadingDone = true;\n            this.updatePreviewImageTransform();\n            if (isUpdateImageWrapper) {\n                this.updatePreviewImageWrapperTransform();\n            }\n            this.cdr.detectChanges();\n        };\n    }\n\n    updatePreviewImage() {\n        this.resolvePreviewImage().subscribe(result => {\n            if (!result) {\n                // error\n                this.isLoadingDone = true;\n                return;\n            }\n            // image size\n            if (!this.previewImage.size && this.previewImage.blob) {\n                this.previewImage.size = humanizeBytes(this.previewImage.blob.size);\n            }\n            if (this.defaultZoom) {\n                this.useDefaultZoomUpdate(true);\n            } else {\n                this.useCalculateZoomUpdate();\n            }\n        });\n    }\n\n    resolvePreviewImage() {\n        return new Observable<Boolean>(subscriber => {\n            if (this.previewImage.src.startsWith('blob:')) {\n                this.previewImage.objectURL = this.sanitizer.bypassSecurityTrustUrl(this.previewImage.src);\n                subscriber.next(true);\n                subscriber.complete();\n                return;\n            }\n            if (this.previewImage.objectURL || !this.previewConfig.resolveSize) {\n                subscriber.next(true);\n                subscriber.complete();\n            } else {\n                fetchImageBlob(this.previewImage.src).subscribe(\n                    blob => {\n                        const urlCreator = window.URL || window.webkitURL;\n                        const objectURL = urlCreator.createObjectURL(blob);\n                        this.previewImage.objectURL = this.sanitizer.bypassSecurityTrustUrl(objectURL);\n                        this.previewImage.blob = blob;\n                        subscriber.next(true);\n                        subscriber.complete();\n                    },\n                    error => {\n                        subscriber.next(false);\n                        subscriber.complete();\n                    }\n                );\n            }\n        });\n    }\n\n    initPreview() {\n        if (Array.isArray(this.previewConfig?.operations) && this.previewConfig?.operations.length) {\n            this.previewOperations = this.defaultPreviewOperations.filter(item => this.previewConfig.operations.includes(item.type));\n        } else {\n            this.previewOperations = this.defaultPreviewOperations;\n        }\n        this.rotate = this.previewConfig?.rotate ?? 0;\n        this.updatePreviewImage();\n    }\n\n    download(image: ThyImageInfo) {\n        let img = new Image();\n        img.setAttribute('crossOrigin', 'Anonymous');\n        img.onload = () => {\n            let canvas = document.createElement('canvas');\n            let context = canvas.getContext('2d');\n            canvas.width = img.width;\n            canvas.height = img.height;\n            context.drawImage(img, 0, 0, img.width, img.height);\n            let url = canvas.toDataURL('images/png');\n            let a = document.createElement('a');\n            let event = new MouseEvent('click');\n            a.download = image.name || 'default.png';\n            a.href = url;\n            a.dispatchEvent(event);\n        };\n        img.onerror = () => {\n            let a = document.createElement('a');\n            a.download = image.name || 'default.png';\n            a.target = '_blank';\n            a.href = image.origin?.src || image.src;\n            let event = new MouseEvent('click');\n            a.dispatchEvent(event);\n        };\n        img.src = image.origin?.src || image.src;\n    }\n\n    zoomIn(): void {\n        if (this.zoom < IMAGE_MAX_ZOOM) {\n            this.zoom = Math.min(this.zoom + 0.1, IMAGE_MAX_ZOOM);\n            this.calculateInsideScreen();\n            this.updatePreviewImageTransform();\n            this.position = { ...initialPosition };\n        }\n    }\n\n    zoomOut(): void {\n        if (this.zoom > IMAGE_MIN_ZOOM) {\n            this.zoom = Math.max(this.zoom - 0.1, IMAGE_MIN_ZOOM);\n            this.calculateInsideScreen();\n            this.updatePreviewImageTransform();\n            this.position = { ...initialPosition };\n        }\n    }\n\n    calculateInsideScreen() {\n        const width = this.imageRef.nativeElement.offsetWidth * this.zoom;\n        const height = this.imageRef.nativeElement.offsetHeight * this.zoom;\n        const { width: clientWidth, height: clientHeight } = getClientSize();\n        if (width >= clientWidth || height >= clientHeight) {\n            this.isInsideScreen = false;\n        } else {\n            this.isInsideScreen = true;\n        }\n    }\n\n    viewOriginal() {\n        window.open(this.previewImage?.origin?.src || this.previewImage.src, '_blank');\n    }\n\n    rotateRight(): void {\n        this.rotate += 90;\n        this.updatePreviewImageTransform();\n    }\n\n    fullScreen(): void {\n        const targetElement = this.host.nativeElement.querySelector('.thy-image-preview');\n        this.isFullScreen = true;\n        const fullscreenRef = this.thyFullscreen.launch({\n            target: targetElement\n        });\n        fullscreenRef.afterExited().subscribe(() => {\n            this.isFullScreen = false;\n            this.cdr.markForCheck();\n        });\n    }\n\n    copyLink(event: ThyCopyEvent) {\n        if (event.isSuccess) {\n            this.notifyService.success('复制图片地址成功');\n        } else {\n            this.notifyService.error('复制图片地址失败');\n        }\n    }\n\n    prev() {\n        if (this.previewIndex > 0) {\n            this.previewIndex--;\n            this.isLoadingDone = false;\n            this.reset();\n            this.updatePreviewImage();\n        }\n    }\n\n    next() {\n        if (this.previewIndex < this.images.length - 1) {\n            this.previewIndex++;\n            this.isLoadingDone = false;\n            this.reset();\n            this.updatePreviewImage();\n        }\n    }\n\n    dragReleased() {\n        this.isDragging = false;\n        const width = this.imageRef.nativeElement.offsetWidth * this.zoom;\n        const height = this.imageRef.nativeElement.offsetHeight * this.zoom;\n        const { left, top } = getOffset(this.imageRef.nativeElement, window);\n        const { width: clientWidth, height: clientHeight } = getClientSize();\n        const isRotate = this.rotate % 180 !== 0;\n        const fitContentParams = {\n            width: isRotate ? height : width,\n            height: isRotate ? width : height,\n            left,\n            top,\n            clientWidth,\n            clientHeight\n        };\n        const fitContentPos = getFitContentPosition(fitContentParams);\n        if (!isUndefinedOrNull(fitContentPos.x) || !isUndefinedOrNull(fitContentPos.y)) {\n            this.position = { ...this.position, ...fitContentPos };\n        }\n    }\n\n    private reset(): void {\n        this.currentImageMode = 'original-scale';\n        this.rotate = this.previewConfig?.rotate ?? 0;\n        this.position = { ...initialPosition };\n        this.cdr.detectChanges();\n    }\n\n    private updatePreviewImageTransform(): void {\n        this.previewImageTransform = `scale3d(${this.zoom}, ${this.zoom}, 1) rotate(${this.rotate}deg)`;\n    }\n\n    private updatePreviewImageWrapperTransform(): void {\n        this.previewImageWrapperTransform = `translate3d(${this.position.x}px, ${this.position.y}px, 0)`;\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n","<div class=\"thy-image-preview\" [class.thy-image-preview-fullscreen]=\"isFullScreen\">\n  <div class=\"thy-image-preview-header pl-10 pr-8\" *ngIf=\"!isFullScreen\">\n    <div class=\"thy-image-preview-header-info\">\n      <p class=\"thy-image-name text-truncate\" [thyTooltipDisabled]=\"previewImage?.name?.length < 32\" [thyTooltip]=\"previewImage?.name\">\n        {{ previewImage?.name }}\n      </p>\n      <span class=\"thy-image-size\"> {{ previewImage?.size }}</span>\n    </div>\n    <a thyAction thyIcon=\"close\" thyTooltip=\"退出预览\" href=\"javascript:;\" (click)=\"thyDialog.close()\"></a>\n  </div>\n  <a\n    class=\"thy-image-preview-exit-fullscreen\"\n    *ngIf=\"isFullScreen\"\n    thyAction\n    thyIcon=\"close\"\n    thyTooltip=\"退出预览\"\n    href=\"javascript:;\"\n    (click)=\"thyFullscreen.exit()\"\n    thyTooltip=\"退出全屏\"\n  ></a>\n  <div\n    class=\"thy-image-preview-img-wrapper\"\n    #imagePreviewWrapper\n    cdkDrag\n    [class.thy-image-preview-inside]=\"isInsideScreen\"\n    [style.transform]=\"previewImageWrapperTransform\"\n    [cdkDragFreeDragPosition]=\"position\"\n    (cdkDragReleased)=\"dragReleased()\"\n  >\n    <ng-container *ngFor=\"let image of images; index as imageIndex\">\n      <img\n        #imgRef\n        *ngIf=\"previewIndex === imageIndex && isLoadingDone\"\n        class=\"thy-image-preview-img\"\n        [src]=\"image.objectURL || image.src\"\n        [style.transform]=\"previewImageTransform\"\n      />\n    </ng-container>\n    <thy-loading [thyDone]=\"isLoadingDone\"></thy-loading>\n  </div>\n\n  <ng-container *ngIf=\"images.length > 1 && !isFullScreen\">\n    <div\n      class=\"thy-image-preview-switch-left\"\n      [thyTooltipDisabled]=\"previewIndex <= 0\"\n      thyTooltip=\"上一张\"\n      [class.thy-image-preview-switch-left-disabled]=\"previewIndex <= 0\"\n      (click)=\"prev()\"\n    >\n      <thy-icon thyIconName=\"angle-left-bold\"></thy-icon>\n    </div>\n    <div\n      class=\"thy-image-preview-switch-right\"\n      thyTooltip=\"下一张\"\n      [thyTooltipDisabled]=\"previewIndex >= images.length - 1\"\n      [class.thy-image-preview-switch-right-disabled]=\"previewIndex >= images.length - 1\"\n      (click)=\"next()\"\n    >\n      <thy-icon thyIconName=\"angle-right-bold\"> </thy-icon>\n    </div>\n  </ng-container>\n  <thy-actions thySize=\"xs\" class=\"thy-image-preview-operations py-3 px-4\" *ngIf=\"!isFullScreen\">\n    <ng-container *ngFor=\"let option of previewOperations; let i = index\">\n      <a\n        *ngIf=\"!['original-scale', 'fit-screen', 'copyLink'].includes(option.type) || currentImageMode === option.type\"\n        href=\"javascript:;\"\n        thyAction\n        [thyActionIcon]=\"option.icon\"\n        [thyTooltip]=\"option.name\"\n        [thyTooltipOffset]=\"13\"\n        (click)=\"option.action(previewImage)\"\n      ></a>\n      <span class=\"mr-2\" *ngIf=\"option?.type === 'zoom-out'\"> {{ (zoom * 100).toFixed(0) + '%' }} </span>\n      <thy-divider class=\"ml-2\" [thyVertical]=\"true\" *ngIf=\"option?.type === 'rotate-right'\"></thy-divider>\n      <a\n        *ngIf=\"option.type === 'copyLink'\"\n        href=\"javascript:;\"\n        thyAction\n        [thyCopyTips]=\"option.name\"\n        [thyActionIcon]=\"option.icon\"\n        [thyCopyTipsOffset]=\"13\"\n        (thyCopy)=\"copyLink($event)\"\n        [thyCopyContent]=\"previewImageOriginSrc\"\n        [thyShowNotify]=\"false\"\n      ></a>\n    </ng-container>\n    <thy-divider [thyVertical]=\"true\"></thy-divider>\n    <span class=\"thy-image-preview-operations-text\"> {{ previewIndex + 1 }} / {{ images.length }} </span>\n  </thy-actions>\n</div>\n"]}
|
|
421
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"image-preview.component.js","sourceRoot":"","sources":["../../../../../src/image/preview/image-preview.component.ts","../../../../../src/image/preview/image-preview.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    Component,\n    OnInit,\n    ViewEncapsulation,\n    ChangeDetectorRef,\n    ElementRef,\n    ViewChild,\n    NgZone,\n    OnDestroy\n} from '@angular/core';\nimport { InternalImageInfo, ThyImageInfo, ThyImagePreviewMode, ThyImagePreviewOperation, ThyImagePreviewOptions } from '../image.class';\nimport { MixinBase, mixinUnsubscribe } from 'ngx-tethys/core';\nimport { fromEvent, Observable, of } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\nimport { ThyDialog } from 'ngx-tethys/dialog';\nimport { getClientSize, getFitContentPosition, getOffset, humanizeBytes, isNumber, isUndefinedOrNull } from 'ngx-tethys/util';\nimport { ThyFullscreen } from 'ngx-tethys/fullscreen';\nimport { ThyCopyEvent } from 'ngx-tethys/copy';\nimport { ThyNotifyService } from 'ngx-tethys/notify';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { fetchImageBlob } from '../utils';\n\nconst initialPosition = {\n    x: 0,\n    y: 0\n};\nconst IMAGE_MAX_ZOOM = 3;\nconst IMAGE_MIN_ZOOM = 0.1;\nconst HORIZONTAL_SPACE = 100 * 2; // left: 100px; right: 100px\nconst VERTICAL_SPACE = 96 + 106; // top: 96px; bottom: 106px\n\n/**\n * 图片预览组件\n */\n@Component({\n    selector: 'thy-image-preview',\n    exportAs: 'thyImagePreview',\n    templateUrl: './image-preview.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    encapsulation: ViewEncapsulation.None,\n    host: {\n        class: 'thy-image-preview-wrap',\n        '[class.thy-image-preview-moving]': 'isDragging'\n    }\n})\nexport class ThyImagePreviewComponent extends mixinUnsubscribe(MixinBase) implements OnInit, OnDestroy {\n    images: InternalImageInfo[] = [];\n    previewIndex: number = 0;\n    previewConfig: ThyImagePreviewOptions;\n    previewImageTransform = '';\n    previewImageWrapperTransform = '';\n    zoomDisabled = false;\n    zoom: number = 1;\n    position = { ...initialPosition };\n    isDragging = false;\n    isLoadingDone = false;\n    isFullScreen = false;\n    isInsideScreen = true;\n    currentImageMode: ThyImagePreviewMode = 'original-scale';\n    previewOperations: ThyImagePreviewOperation[];\n    defaultPreviewOperations: ThyImagePreviewOperation[] = [\n        {\n            icon: 'zoom-out',\n            name: '缩小',\n            action: (image: ThyImageInfo) => {\n                this.zoomOut();\n            },\n            type: 'zoom-out'\n        },\n        {\n            icon: 'zoom-in',\n            name: '放大',\n            action: (image: ThyImageInfo) => {\n                this.zoomIn();\n            },\n            type: 'zoom-in'\n        },\n        {\n            icon: 'one-to-one',\n            name: '原始比例',\n            action: (image: ThyImageInfo) => {\n                this.setOriginalSize();\n            },\n            type: 'original-scale'\n        },\n        {\n            icon: 'max-view',\n            name: '适应屏幕',\n            action: () => {\n                this.setFitScreen();\n            },\n            type: 'fit-screen'\n        },\n        {\n            icon: 'expand-arrows',\n            name: '全屏显示',\n            action: () => {\n                this.fullScreen();\n            },\n            type: 'full-screen'\n        },\n        {\n            icon: 'rotate-right',\n            name: '旋转',\n            action: (image: ThyImageInfo) => {\n                this.rotateRight();\n            },\n            type: 'rotate-right'\n        },\n        {\n            icon: 'download',\n            name: '下载',\n            action: (image: ThyImageInfo) => {\n                this.download(image);\n            },\n            type: 'download'\n        },\n        {\n            icon: 'preview',\n            name: '查看原图',\n            action: () => {\n                this.viewOriginal();\n            },\n            type: 'view-original'\n        },\n        {\n            icon: 'link-insert',\n            name: '复制链接',\n            type: 'copyLink'\n        }\n    ];\n    private rotate: number;\n\n    get previewImage(): InternalImageInfo {\n        const image = this.images[this.previewIndex];\n        if (image.size) {\n            image.size = isNumber(image.size) ? humanizeBytes(image.size) : image.size;\n        }\n        return image;\n    }\n\n    get previewImageOriginSrc() {\n        let imageSrc = this.previewImage.origin?.src || this.previewImage.src;\n        if (imageSrc.startsWith('./')) {\n            return window.location.host + '/' + imageSrc.split('./')[1];\n        }\n        return imageSrc;\n    }\n\n    get defaultZoom(): number {\n        if (this.previewConfig?.zoom && this.previewConfig?.zoom > 0) {\n            return this.previewConfig.zoom >= IMAGE_MAX_ZOOM\n                ? IMAGE_MAX_ZOOM\n                : this.previewConfig.zoom <= IMAGE_MIN_ZOOM\n                ? IMAGE_MIN_ZOOM\n                : this.previewConfig.zoom;\n        }\n    }\n\n    @ViewChild('imgRef', { static: false }) imageRef!: ElementRef<HTMLImageElement>;\n    @ViewChild('imagePreviewWrapper', { static: true }) imagePreviewWrapper!: ElementRef<HTMLElement>;\n\n    constructor(\n        public thyDialog: ThyDialog,\n        public thyFullscreen: ThyFullscreen,\n        private cdr: ChangeDetectorRef,\n        private ngZone: NgZone,\n        private notifyService: ThyNotifyService,\n        private host: ElementRef<HTMLElement>,\n        private sanitizer: DomSanitizer\n    ) {\n        super();\n    }\n\n    ngOnInit(): void {\n        this.initPreview();\n        this.ngZone.runOutsideAngular(() => {\n            fromEvent(this.host.nativeElement, 'click')\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe(event => {\n                    if (\n                        (event.target === event.currentTarget ||\n                            (this.isInsideScreen && this.imagePreviewWrapper.nativeElement.contains(event.target as HTMLElement))) &&\n                        !this.previewConfig?.disableClose\n                    ) {\n                        this.ngZone.run(() => !this.isFullScreen && this.thyDialog.close());\n                    }\n                });\n\n            fromEvent(this.imagePreviewWrapper.nativeElement, 'mousedown')\n                .pipe(takeUntil(this.ngUnsubscribe$))\n                .subscribe(() => {\n                    this.isDragging = !this.isInsideScreen && true;\n                });\n        });\n    }\n\n    setOriginalSize() {\n        this.reset();\n        this.currentImageMode = 'fit-screen';\n        this.zoom = 1;\n        this.updatePreviewImageTransform();\n        this.calculateInsideScreen();\n        this.isLoadingDone = true;\n        this.cdr.detectChanges();\n    }\n\n    setFitScreen() {\n        this.reset();\n        this.isInsideScreen = true;\n        this.updatePreviewImage();\n    }\n\n    useDefaultZoomUpdate(isUpdateImageWrapper: boolean) {\n        this.zoom = this.defaultZoom;\n        this.isLoadingDone = true;\n        this.updatePreviewImageTransform();\n        if (isUpdateImageWrapper) {\n            this.updatePreviewImageWrapperTransform();\n        }\n        this.cdr.detectChanges();\n    }\n\n    useCalculateZoomUpdate(isUpdateImageWrapper?: boolean) {\n        let img = new Image();\n        img.src = this.previewImage.src;\n        img.onload = () => {\n            const { width: offsetWidth, height: offsetHeight } = getClientSize();\n            const innerWidth = offsetWidth - HORIZONTAL_SPACE;\n            const innerHeight = offsetHeight - VERTICAL_SPACE;\n            const { naturalWidth, naturalHeight } = img;\n            const xRatio = innerWidth / naturalWidth;\n            const yRatio = innerHeight / naturalHeight;\n            const zoom = Math.min(xRatio, yRatio);\n            if (zoom > 1) {\n                this.zoom = 1;\n            } else {\n                this.zoom = zoom;\n            }\n            this.isLoadingDone = true;\n            this.updatePreviewImageTransform();\n            if (isUpdateImageWrapper) {\n                this.updatePreviewImageWrapperTransform();\n            }\n            this.cdr.detectChanges();\n        };\n    }\n\n    updatePreviewImage() {\n        this.resolvePreviewImage().subscribe(result => {\n            if (!result) {\n                // error\n                this.isLoadingDone = true;\n                return;\n            }\n            // image size\n            if (!this.previewImage.size && this.previewImage.blob) {\n                this.previewImage.size = humanizeBytes(this.previewImage.blob.size);\n            }\n            if (this.defaultZoom) {\n                this.useDefaultZoomUpdate(true);\n            } else {\n                this.useCalculateZoomUpdate();\n            }\n        });\n    }\n\n    resolvePreviewImage() {\n        return new Observable<Boolean>(subscriber => {\n            if (this.previewImage.src.startsWith('blob:')) {\n                this.previewImage.objectURL = this.sanitizer.bypassSecurityTrustUrl(this.previewImage.src);\n                subscriber.next(true);\n                subscriber.complete();\n                return;\n            }\n            if (this.previewImage.objectURL || !this.previewConfig.resolveSize) {\n                subscriber.next(true);\n                subscriber.complete();\n            } else {\n                fetchImageBlob(this.previewImage.src).subscribe(\n                    blob => {\n                        const urlCreator = window.URL || window.webkitURL;\n                        const objectURL = urlCreator.createObjectURL(blob);\n                        this.previewImage.objectURL = this.sanitizer.bypassSecurityTrustUrl(objectURL);\n                        this.previewImage.blob = blob;\n                        subscriber.next(true);\n                        subscriber.complete();\n                    },\n                    error => {\n                        subscriber.next(false);\n                        subscriber.complete();\n                    }\n                );\n            }\n        });\n    }\n\n    initPreview() {\n        if (Array.isArray(this.previewConfig?.operations) && this.previewConfig?.operations.length) {\n            this.previewOperations = this.defaultPreviewOperations.filter(item => this.previewConfig.operations.includes(item.type));\n        } else {\n            this.previewOperations = this.defaultPreviewOperations;\n        }\n        this.rotate = this.previewConfig?.rotate ?? 0;\n        this.updatePreviewImage();\n    }\n\n    download(image: ThyImageInfo) {\n        let img = new Image();\n        img.setAttribute('crossOrigin', 'Anonymous');\n        img.onload = () => {\n            let canvas = document.createElement('canvas');\n            let context = canvas.getContext('2d');\n            canvas.width = img.width;\n            canvas.height = img.height;\n            context.drawImage(img, 0, 0, img.width, img.height);\n            let url = canvas.toDataURL('images/png');\n            let a = document.createElement('a');\n            let event = new MouseEvent('click');\n            a.download = image.name || 'default.png';\n            a.href = url;\n            a.dispatchEvent(event);\n        };\n        img.onerror = () => {\n            let a = document.createElement('a');\n            a.download = image.name || 'default.png';\n            a.target = '_blank';\n            a.href = image.origin?.src || image.src;\n            let event = new MouseEvent('click');\n            a.dispatchEvent(event);\n        };\n        img.src = image.origin?.src || image.src;\n    }\n\n    zoomIn(): void {\n        if (this.zoom < IMAGE_MAX_ZOOM) {\n            this.zoom = Math.min(this.zoom + 0.1, IMAGE_MAX_ZOOM);\n            this.calculateInsideScreen();\n            this.updatePreviewImageTransform();\n            this.position = { ...initialPosition };\n        }\n    }\n\n    zoomOut(): void {\n        if (this.zoom > IMAGE_MIN_ZOOM) {\n            this.zoom = Math.max(this.zoom - 0.1, IMAGE_MIN_ZOOM);\n            this.calculateInsideScreen();\n            this.updatePreviewImageTransform();\n            this.position = { ...initialPosition };\n        }\n    }\n\n    calculateInsideScreen() {\n        const width = this.imageRef.nativeElement.offsetWidth * this.zoom;\n        const height = this.imageRef.nativeElement.offsetHeight * this.zoom;\n        const { width: clientWidth, height: clientHeight } = getClientSize();\n        if (width >= clientWidth || height >= clientHeight) {\n            this.isInsideScreen = false;\n        } else {\n            this.isInsideScreen = true;\n        }\n    }\n\n    viewOriginal() {\n        window.open(this.previewImage?.origin?.src || this.previewImage.src, '_blank');\n    }\n\n    rotateRight(): void {\n        this.rotate += 90;\n        this.updatePreviewImageTransform();\n    }\n\n    fullScreen(): void {\n        const targetElement = this.host.nativeElement.querySelector('.thy-image-preview');\n        this.isFullScreen = true;\n        const fullscreenRef = this.thyFullscreen.launch({\n            target: targetElement\n        });\n        fullscreenRef.afterExited().subscribe(() => {\n            this.isFullScreen = false;\n            this.cdr.markForCheck();\n        });\n    }\n\n    copyLink(event: ThyCopyEvent) {\n        if (event.isSuccess) {\n            this.notifyService.success('复制图片地址成功');\n        } else {\n            this.notifyService.error('复制图片地址失败');\n        }\n    }\n\n    prev() {\n        if (this.previewIndex > 0) {\n            this.previewIndex--;\n            this.isLoadingDone = false;\n            this.reset();\n            this.updatePreviewImage();\n        }\n    }\n\n    next() {\n        if (this.previewIndex < this.images.length - 1) {\n            this.previewIndex++;\n            this.isLoadingDone = false;\n            this.reset();\n            this.updatePreviewImage();\n        }\n    }\n\n    dragReleased() {\n        this.isDragging = false;\n        const width = this.imageRef.nativeElement.offsetWidth * this.zoom;\n        const height = this.imageRef.nativeElement.offsetHeight * this.zoom;\n        const { left, top } = getOffset(this.imageRef.nativeElement, window);\n        const { width: clientWidth, height: clientHeight } = getClientSize();\n        const isRotate = this.rotate % 180 !== 0;\n        const fitContentParams = {\n            width: isRotate ? height : width,\n            height: isRotate ? width : height,\n            left,\n            top,\n            clientWidth,\n            clientHeight\n        };\n        const fitContentPos = getFitContentPosition(fitContentParams);\n        if (!isUndefinedOrNull(fitContentPos.x) || !isUndefinedOrNull(fitContentPos.y)) {\n            this.position = { ...this.position, ...fitContentPos };\n        }\n    }\n\n    private reset(): void {\n        this.currentImageMode = 'original-scale';\n        this.rotate = this.previewConfig?.rotate ?? 0;\n        this.position = { ...initialPosition };\n        this.cdr.detectChanges();\n    }\n\n    private updatePreviewImageTransform(): void {\n        this.previewImageTransform = `scale3d(${this.zoom}, ${this.zoom}, 1) rotate(${this.rotate}deg)`;\n    }\n\n    private updatePreviewImageWrapperTransform(): void {\n        this.previewImageWrapperTransform = `translate3d(${this.position.x}px, ${this.position.y}px, 0)`;\n    }\n\n    ngOnDestroy(): void {\n        super.ngOnDestroy();\n    }\n}\n","<div class=\"thy-image-preview\" [class.thy-image-preview-fullscreen]=\"isFullScreen\">\n  <div class=\"thy-image-preview-header pl-10 pr-8\" *ngIf=\"!isFullScreen\">\n    <div class=\"thy-image-preview-header-info\">\n      <p class=\"thy-image-name text-truncate\" [thyTooltipDisabled]=\"previewImage?.name?.length < 32\" [thyTooltip]=\"previewImage?.name\">\n        {{ previewImage?.name }}\n      </p>\n      <span class=\"thy-image-size\"> {{ previewImage?.size }}</span>\n    </div>\n    <a thyAction thyIcon=\"close\" thyTooltip=\"退出预览\" href=\"javascript:;\" (click)=\"thyDialog.close()\"></a>\n  </div>\n  <a\n    class=\"thy-image-preview-exit-fullscreen\"\n    *ngIf=\"isFullScreen\"\n    thyAction\n    thyIcon=\"close\"\n    thyTooltip=\"退出预览\"\n    href=\"javascript:;\"\n    (click)=\"thyFullscreen.exit()\"\n    thyTooltip=\"退出全屏\"\n  ></a>\n  <div\n    class=\"thy-image-preview-img-wrapper\"\n    #imagePreviewWrapper\n    cdkDrag\n    [class.thy-image-preview-inside]=\"isInsideScreen\"\n    [style.transform]=\"previewImageWrapperTransform\"\n    [cdkDragFreeDragPosition]=\"position\"\n    (cdkDragReleased)=\"dragReleased()\"\n  >\n    <ng-container *ngFor=\"let image of images; index as imageIndex\">\n      <img\n        #imgRef\n        *ngIf=\"previewIndex === imageIndex && isLoadingDone\"\n        class=\"thy-image-preview-img\"\n        [src]=\"image.objectURL || image.src\"\n        [style.transform]=\"previewImageTransform\"\n      />\n    </ng-container>\n    <thy-loading [thyDone]=\"isLoadingDone\"></thy-loading>\n  </div>\n\n  <ng-container *ngIf=\"images.length > 1 && !isFullScreen\">\n    <div\n      class=\"thy-image-preview-switch-left\"\n      [thyTooltipDisabled]=\"previewIndex <= 0\"\n      thyTooltip=\"上一张\"\n      [class.thy-image-preview-switch-left-disabled]=\"previewIndex <= 0\"\n      (click)=\"prev()\"\n    >\n      <thy-icon thyIconName=\"angle-left-bold\"></thy-icon>\n    </div>\n    <div\n      class=\"thy-image-preview-switch-right\"\n      thyTooltip=\"下一张\"\n      [thyTooltipDisabled]=\"previewIndex >= images.length - 1\"\n      [class.thy-image-preview-switch-right-disabled]=\"previewIndex >= images.length - 1\"\n      (click)=\"next()\"\n    >\n      <thy-icon thyIconName=\"angle-right-bold\"> </thy-icon>\n    </div>\n  </ng-container>\n  <thy-actions thySize=\"xs\" class=\"thy-image-preview-operations py-3 px-4\" *ngIf=\"!isFullScreen\">\n    <ng-container *ngFor=\"let option of previewOperations; let i = index\">\n      <a\n        *ngIf=\"!['original-scale', 'fit-screen', 'copyLink'].includes(option.type) || currentImageMode === option.type\"\n        href=\"javascript:;\"\n        thyAction\n        [thyActionIcon]=\"option.icon\"\n        [thyTooltip]=\"option.name\"\n        [thyTooltipOffset]=\"13\"\n        (click)=\"option.action(previewImage)\"\n      ></a>\n      <span class=\"mr-2\" *ngIf=\"option?.type === 'zoom-out'\"> {{ (zoom * 100).toFixed(0) + '%' }} </span>\n      <thy-divider class=\"ml-2\" [thyVertical]=\"true\" *ngIf=\"option?.type === 'rotate-right'\"></thy-divider>\n      <a\n        *ngIf=\"option.type === 'copyLink'\"\n        href=\"javascript:;\"\n        thyAction\n        [thyCopyTips]=\"option.name\"\n        [thyActionIcon]=\"option.icon\"\n        [thyCopyTipsOffset]=\"13\"\n        (thyCopy)=\"copyLink($event)\"\n        [thyCopyContent]=\"previewImageOriginSrc\"\n        [thyShowNotify]=\"false\"\n      ></a>\n    </ng-container>\n    <thy-divider [thyVertical]=\"true\"></thy-divider>\n    <span class=\"thy-image-preview-operations-text\"> {{ previewIndex + 1 }} / {{ images.length }} </span>\n  </thy-actions>\n</div>\n"]}
|