ngx-tethys 13.2.3 → 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 +9 -0
- package/esm2020/image/preview/image-preview.component.mjs +2 -5
- package/esm2020/time-picker/time-picker-panel.component.mjs +8 -3
- package/esm2020/time-picker/time-picker.component.mjs +14 -7
- package/esm2020/version.mjs +2 -2
- package/fesm2015/ngx-tethys-image.mjs +1 -1
- package/fesm2015/ngx-tethys-image.mjs.map +1 -1
- package/fesm2015/ngx-tethys-time-picker.mjs +20 -8
- package/fesm2015/ngx-tethys-time-picker.mjs.map +1 -1
- package/fesm2015/ngx-tethys.mjs +1 -1
- package/fesm2015/ngx-tethys.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-time-picker.mjs +20 -8
- package/fesm2020/ngx-tethys-time-picker.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/schematics/version.d.ts +1 -1
- package/schematics/version.js +1 -1
- package/time-picker/time-picker.component.d.ts +4 -1
package/CHANGELOG.md
CHANGED
|
@@ -2,6 +2,15 @@
|
|
|
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
|
+
|
|
5
14
|
## [13.2.3](https://github.com/atinc/ngx-tethys/compare/13.2.2...13.2.3) (2022-08-19)
|
|
6
15
|
|
|
7
16
|
|
|
@@ -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"]}
|
|
@@ -90,8 +90,13 @@ export class ThyTimePanelComponent {
|
|
|
90
90
|
this.runScrollAnimationFrame(container, offsetTop, duration);
|
|
91
91
|
}
|
|
92
92
|
writeValue(value) {
|
|
93
|
-
|
|
94
|
-
|
|
93
|
+
if (value && isValid(value)) {
|
|
94
|
+
this.value = new Date(value);
|
|
95
|
+
this.setHMSProperty();
|
|
96
|
+
}
|
|
97
|
+
else {
|
|
98
|
+
this.initialValue();
|
|
99
|
+
}
|
|
95
100
|
this.autoScroll(this.initialScrollPosition ? this.SCROLL_DEFAULT_DURATION : 0);
|
|
96
101
|
this.cdr.markForCheck();
|
|
97
102
|
}
|
|
@@ -222,4 +227,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
222
227
|
}], thyPickChange: [{
|
|
223
228
|
type: Output
|
|
224
229
|
}] } });
|
|
225
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker-panel.component.js","sourceRoot":"","sources":["../../../../src/time-picker/time-picker-panel.component.ts","../../../../src/time-picker/time-picker-panel.component.html"],"names":[],"mappings":";AAAA,OAAO,EACH,uBAAuB,EACvB,iBAAiB,EACjB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,UAAU,EACV,KAAK,EACL,MAAM,EAGN,MAAM,EACN,SAAS,EACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,OAAO,EAAE,MAAM,UAAU,CAAC;AACnC,OAAO,EAAE,YAAY,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC7D,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;;;;AAoB3C,MAAM,OAAO,qBAAqB;IAqE9B,YAAoB,GAAsB,EAAU,MAAc;QAA9C,QAAG,GAAH,GAAG,CAAmB;QAAU,WAAM,GAAN,MAAM,CAAQ;QA/CzD,gBAAW,GAAW,CAAC,CAAC;QAExB,kBAAa,GAAW,CAAC,CAAC;QAE1B,kBAAa,GAAW,CAAC,CAAC;QAEV,qBAAgB,GAAG,IAAI,CAAC;QAExB,sBAAiB,GAAG,IAAI,CAAC;QAExC,kBAAa,GAAG,IAAI,YAAY,EAAQ,CAAC;QAEnD,0BAA0B;QAC1B,0BAAqB,GAAG,CAAC,CAAC;QAE1B,4BAAuB,GAAG,GAAG,CAAC;QAE9B,cAAS,GAAG,uBAAuB,CAAC;QAEpC,cAAS,GAAwD,EAAE,CAAC;QAEpE,gBAAW,GAAwD,EAAE,CAAC;QAEtE,gBAAW,GAAwD,EAAE,CAAC;QAEtE,mBAAc,GAAG,IAAI,CAAC;QAEtB,qBAAgB,GAAG,IAAI,CAAC;QAExB,qBAAgB,GAAG,IAAI,CAAC;QAExB,oBAAe,GAAW,CAAC,CAAC;QAY5B,oBAAe,GAAwB,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;QAEpD,gBAAW,GAAe,GAAG,EAAE,CAAC,KAAK,CAAC,CAAC;IAE8B,CAAC;IA9DtE,IAAa,SAAS,CAAC,KAAa;QAChC,IAAI,KAAK,EAAE;YACP,MAAM,SAAS,GAAG,IAAI,GAAG,CAAC,KAAK,CAAC,CAAC;YACjC,IAAI,CAAC,cAAc,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAC/D,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAC3C,IAAI,CAAC,gBAAgB,GAAG,SAAS,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;SAC9C;aAAM;YACH,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC3B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;SAChC;QACD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC,gBAAgB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACrD,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAmDD,QAAQ;QACJ,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,UAAU,CAAC,GAAG,EAAE;YACZ,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC;QACtC,CAAC,CAAC,CAAC;IACP,CAAC;IAED,iBAAiB;QACb,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QAC3D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAC/D,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,cAAc,CAAC,EAAE,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;IACnE,CAAC;IAED,SAAS,CAAC,KAA2C,EAAE,KAAa;QAChE,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC;QACjC,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC;QACxB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IACzD,CAAC;IAED,WAAW,CAAC,OAA6C,EAAE,KAAa;QACpE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAED,WAAW,CAAC,OAA6C,EAAE,KAAa;QACpE,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,KAAK,CAAC;QAC5B,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,aAAa,CAAC,aAAa,EAAE,KAAK,CAAC,CAAC;IAC3D,CAAC;IAED,SAAS;QACL,IAAI,CAAC,KAAK,GAAG,IAAI,IAAI,EAAE,CAAC;QACxB,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACpC,IAAI,CAAC,UAAU,EAAE,CAAC;IACtB,CAAC;IAED,eAAe;QACX,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,IAAI,IAAI,IAAI,EAAE,CAAC,CAAC;IACnD,CAAC;IAED,QAAQ,CAAC,SAAsB,EAAE,QAAgB,CAAC,EAAE,WAAmB,IAAI,CAAC,uBAAuB;QAC/F,MAAM,SAAS,GAAI,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAiB,CAAC,SAAS,GAAG,IAAI,CAAC,qBAAqB,CAAC;QACpG,IAAI,CAAC,uBAAuB,CAAC,SAAS,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAC;IACjE,CAAC;IAED,UAAU,CAAC,KAAW;QAClB,IAAI,CAAC,KAAK,GAAG,KAAK,IAAI,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC;QACpE,IAAI,CAAC,cAAc,EAAE,CAAC;QACtB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAE/E,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;IAC5B,CAAC;IAED,gBAAgB,CAAC,EAAyB;QACtC,IAAI,CAAC,eAAe,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,iBAAiB,CAAC,EAAc;QAC5B,IAAI,CAAC,WAAW,GAAG,EAAE,CAAC;IAC1B,CAAC;IAED,SAAS,CAAC,KAAa;QACnB,OAAO,KAAK,CAAC;IACjB,CAAC;IAEO,YAAY;QAChB,IAAI,CAAC,IAAI,GAAG,CAAC,CAAC;QACd,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC;QAChB,IAAI,CAAC,KAAK,GAAG,IAAI,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC;IAC3D,CAAC;IAEO,cAAc,CAAC,MAAc,EAAE,OAAe,CAAC,EAAE,QAAgB,CAAC,EAAE,WAAqB,EAAE;QAC/F,OAAO,IAAI,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YAC5D,MAAM,KAAK,GAAG,CAAC,CAAC,GAAG,KAAK,CAAC,GAAG,IAAI,CAAC;YACjC,OAAO;gBACH,KAAK,EAAE,KAAK;gBACZ,QAAQ,EAAE,QAAQ,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;aACzC,CAAC;QACN,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,cAAc;QAClB,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC;QAClC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;QACtC,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,EAAE,CAAC;IAC1C,CAAC;IAEO,mBAAmB;QACvB,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,SAAS,GAAG,CAAC,CAAC;SAChD;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,GAAG,CAAC,CAAC;SAClD;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,SAAS,GAAG,CAAC,CAAC;SAClD;QACD,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;IACvC,CAAC;IAEO,uBAAuB,CAAC,SAAsB,EAAE,EAAU,EAAE,WAAmB,IAAI,CAAC,uBAAuB;QAC/G,IAAI,QAAQ,IAAI,CAAC,EAAE;YACf,SAAS,CAAC,SAAS,GAAG,EAAE,CAAC;YACzB,OAAO;SACV;QACD,MAAM,MAAM,GAAG,EAAE,GAAG,SAAS,CAAC,SAAS,CAAC;QACxC,MAAM,KAAK,GAAG,CAAC,MAAM,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC;QACvC,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,GAAG,EAAE;YAC/B,YAAY,CAAC,GAAG,EAAE;gBACd,SAAS,CAAC,SAAS,IAAI,KAAK,CAAC;gBAC7B,IAAI,SAAS,CAAC,SAAS,KAAK,EAAE,EAAE;oBAC5B,OAAO;iBACV;gBACD,IAAI,CAAC,uBAAuB,CAAC,SAAS,EAAE,EAAE,EAAE,QAAQ,GAAG,EAAE,CAAC,CAAC;YAC/D,CAAC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAEO,UAAU,CAAC,WAAmB,IAAI,CAAC,uBAAuB;QAC9D,IAAI,IAAI,CAAC,WAAW,EAAE;YAClB,IAAI,CAAC,QAAQ,CACT,IAAI,CAAC,WAAW,CAAC,aAAa,EAC9B,IAAI,CAAC,SAAS,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,EACpD,QAAQ,CACX,CAAC;SACL;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,QAAQ,CACT,IAAI,CAAC,aAAa,CAAC,aAAa,EAChC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC,EACxD,QAAQ,CACX,CAAC;SACL;QACD,IAAI,IAAI,CAAC,aAAa,EAAE;YACpB,IAAI,CAAC,QAAQ,CACT,IAAI,CAAC,aAAa,CAAC,aAAa,EAChC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,CAAC,EACxD,QAAQ,CACX,CAAC;SACL;IACL,CAAC;IAED,WAAW;QACP,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC/B,CAAC;;kHA9NQ,qBAAqB;sGAArB,qBAAqB,2jBAdnB;QACP;YACI,OAAO,EAAE,iBAAiB;YAC1B,KAAK,EAAE,IAAI;YACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,qBAAqB,CAAC;SACvD;KACJ,oVC7BL,ikEAwCA;ADyB6B;IAAf,YAAY,EAAE;;+DAAyB;AAExB;IAAf,YAAY,EAAE;;gEAA0B;2FA9BzC,qBAAqB;kBAlBjC,SAAS;+BACI,uBAAuB,mBAEhB,uBAAuB,CAAC,MAAM,aACpC;wBACP;4BACI,OAAO,EAAE,iBAAiB;4BAC1B,KAAK,EAAE,IAAI;4BACX,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,sBAAsB,CAAC;yBACvD;qBACJ,QACK;wBACF,KAAK,EAAE,uBAAuB;wBAC9B,oDAAoD,EAAE,mBAAmB;wBACzE,yCAAyC,EAAE,uBAAuB;wBAClE,yCAAyC,EAAE,uBAAuB;qBACrE;6HAGgD,WAAW;sBAA3D,SAAS;uBAAC,iBAAiB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAEI,aAAa;sBAA/D,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAEE,aAAa;sBAA/D,SAAS;uBAAC,mBAAmB,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE;gBAEpC,SAAS;sBAArB,KAAK;gBAeG,WAAW;sBAAnB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEG,aAAa;sBAArB,KAAK;gBAEmB,gBAAgB;sBAAxC,KAAK;gBAEmB,iBAAiB;sBAAzC,KAAK;gBAEI,aAAa;sBAAtB,MAAM","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isValid } from 'date-fns';\nimport { InputBoolean, reqAnimFrame } from 'ngx-tethys/core';\nimport { TinyDate } from 'ngx-tethys/util';\n\n@Component({\n    selector: 'thy-time-picker-panel',\n    templateUrl: './time-picker-panel.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => ThyTimePanelComponent)\n        }\n    ],\n    host: {\n        class: 'thy-time-picker-panel',\n        '[class.thy-time-picker-panel-has-bottom-operation]': `thyShowOperations`,\n        '[class.thy-time-picker-panel-columns-2]': `showColumnCount === 2`,\n        '[class.thy-time-picker-panel-columns-3]': `showColumnCount === 3`\n    }\n})\nexport class ThyTimePanelComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @ViewChild('hourListElement', { static: false }) hourListRef: ElementRef<HTMLElement>;\n\n    @ViewChild('minuteListElement', { static: false }) minuteListRef: ElementRef<HTMLElement>;\n\n    @ViewChild('secondListElement', { static: false }) secondListRef: ElementRef<HTMLElement>;\n\n    @Input() set thyFormat(value: string) {\n        if (value) {\n            const formatSet = new Set(value);\n            this.showHourColumn = formatSet.has('H') || formatSet.has('h');\n            this.showMinuteColumn = formatSet.has('m');\n            this.showSecondColumn = formatSet.has('s');\n        } else {\n            this.showHourColumn = true;\n            this.showMinuteColumn = true;\n            this.showSecondColumn = true;\n        }\n        this.showColumnCount = this.showSecondColumn ? 3 : 2;\n        this.cdr.markForCheck();\n    }\n\n    @Input() thyHourStep: number = 1;\n\n    @Input() thyMinuteStep: number = 1;\n\n    @Input() thySecondStep: number = 1;\n\n    @Input() @InputBoolean() thyShowSelectNow = true;\n\n    @Input() @InputBoolean() thyShowOperations = true;\n\n    @Output() thyPickChange = new EventEmitter<Date>();\n\n    // margin-top + 1px border\n    SCROLL_OFFSET_SPACING = 5;\n\n    SCROLL_DEFAULT_DURATION = 120;\n\n    prefixCls = 'thy-time-picker-panel';\n\n    hourRange: ReadonlyArray<{ value: number; disabled: boolean }> = [];\n\n    minuteRange: ReadonlyArray<{ value: number; disabled: boolean }> = [];\n\n    secondRange: ReadonlyArray<{ value: number; disabled: boolean }> = [];\n\n    showHourColumn = true;\n\n    showMinuteColumn = true;\n\n    showSecondColumn = true;\n\n    showColumnCount: number = 3;\n\n    value: Date;\n\n    hour: number;\n\n    minute: number;\n\n    second: number;\n\n    initialScrollPosition: boolean;\n\n    onValueChangeFn: (val: Date) => void = () => void 0;\n\n    onTouchedFn: () => void = () => void 0;\n\n    constructor(private cdr: ChangeDetectorRef, private ngZone: NgZone) {}\n\n    ngOnInit(): void {\n        this.generateTimeRange();\n        this.initialValue();\n        setTimeout(() => {\n            this.initialScrollPosition = true;\n        });\n    }\n\n    generateTimeRange() {\n        this.hourRange = this.buildTimeRange(24, this.thyHourStep);\n        this.minuteRange = this.buildTimeRange(60, this.thyMinuteStep);\n        this.secondRange = this.buildTimeRange(60, this.thySecondStep);\n    }\n\n    pickHours(hours: { value: number; disabled: boolean }, index: number) {\n        this.value.setHours(hours.value);\n        this.hour = hours.value;\n        this.thyPickChange.emit(this.value);\n        this.scrollTo(this.hourListRef.nativeElement, index);\n    }\n\n    pickMinutes(minutes: { value: number; disabled: boolean }, index: number) {\n        this.value.setMinutes(minutes.value);\n        this.minute = minutes.value;\n        this.thyPickChange.emit(this.value);\n        this.scrollTo(this.minuteListRef.nativeElement, index);\n    }\n\n    pickSeconds(seconds: { value: number; disabled: boolean }, index: number) {\n        this.value.setSeconds(seconds.value);\n        this.second = seconds.value;\n        this.thyPickChange.emit(this.value);\n        this.scrollTo(this.secondListRef.nativeElement, index);\n    }\n\n    selectNow() {\n        this.value = new Date();\n        this.setHMSProperty();\n        this.thyPickChange.emit(this.value);\n        this.autoScroll();\n    }\n\n    confirmPickTime() {\n        this.onValueChangeFn(this.value || new Date());\n    }\n\n    scrollTo(container: HTMLElement, index: number = 0, duration: number = this.SCROLL_DEFAULT_DURATION) {\n        const offsetTop = (container.children[index] as HTMLElement).offsetTop - this.SCROLL_OFFSET_SPACING;\n        this.runScrollAnimationFrame(container, offsetTop, duration);\n    }\n\n    writeValue(value: Date): void {\n        this.value = value && isValid(value) ? new Date(value) : new Date();\n        this.setHMSProperty();\n        this.autoScroll(this.initialScrollPosition ? this.SCROLL_DEFAULT_DURATION : 0);\n\n        this.cdr.markForCheck();\n    }\n\n    registerOnChange(fn: (value: Date) => void): void {\n        this.onValueChangeFn = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouchedFn = fn;\n    }\n\n    trackByFn(index: number): number {\n        return index;\n    }\n\n    private initialValue() {\n        this.hour = 0;\n        this.minute = 0;\n        this.second = 0;\n        this.value = new TinyDate().setHms(0, 0, 0).nativeDate;\n    }\n\n    private buildTimeRange(length: number, step: number = 1, start: number = 0, disables: number[] = []) {\n        return new Array(Math.ceil(length / step)).fill(0).map((_, i) => {\n            const value = (i + start) * step;\n            return {\n                value: value,\n                disabled: disables.indexOf(value) > -1\n            };\n        });\n    }\n\n    private setHMSProperty() {\n        this.hour = this.value.getHours();\n        this.minute = this.value.getMinutes();\n        this.second = this.value.getSeconds();\n    }\n\n    private resetScrollPosition() {\n        if (this.hourListRef) {\n            this.hourListRef.nativeElement.scrollTop = 0;\n        }\n        if (this.minuteListRef) {\n            this.minuteListRef.nativeElement.scrollTop = 0;\n        }\n        if (this.secondListRef) {\n            this.secondListRef.nativeElement.scrollTop = 0;\n        }\n        this.initialScrollPosition = false;\n    }\n\n    private runScrollAnimationFrame(container: HTMLElement, to: number, duration: number = this.SCROLL_DEFAULT_DURATION) {\n        if (duration <= 0) {\n            container.scrollTop = to;\n            return;\n        }\n        const offset = to - container.scrollTop;\n        const frame = (offset / duration) * 10;\n        this.ngZone.runOutsideAngular(() => {\n            reqAnimFrame(() => {\n                container.scrollTop += frame;\n                if (container.scrollTop === to) {\n                    return;\n                }\n                this.runScrollAnimationFrame(container, to, duration - 10);\n            });\n        });\n    }\n\n    private autoScroll(duration: number = this.SCROLL_DEFAULT_DURATION) {\n        if (this.hourListRef) {\n            this.scrollTo(\n                this.hourListRef.nativeElement,\n                this.hourRange.findIndex(m => m.value === this.hour),\n                duration\n            );\n        }\n        if (this.minuteListRef) {\n            this.scrollTo(\n                this.minuteListRef.nativeElement,\n                this.minuteRange.findIndex(m => m.value === this.minute),\n                duration\n            );\n        }\n        if (this.secondListRef) {\n            this.scrollTo(\n                this.secondListRef.nativeElement,\n                this.secondRange.findIndex(m => m.value === this.second),\n                duration\n            );\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.resetScrollPosition();\n    }\n}\n","<div class=\"{{ prefixCls }}-content\">\n  <ul #hourListElement *ngIf=\"showHourColumn\" class=\"{{ prefixCls }}-time-column {{ prefixCls }}-hour-column\">\n    <ng-container *ngFor=\"let time of hourRange; let i = index; trackBy: trackByFn\">\n      <li\n        class=\"{{ prefixCls }}-time-column-cell\"\n        [class.thy-time-picker-panel-time-column-cell-selected]=\"hour === time.value\"\n        (click)=\"pickHours(time, i)\"\n      >\n        <span class=\"{{ prefixCls }}-time-column-cell-inner\">{{ time.value | number: '2.0-0' }}</span>\n      </li>\n    </ng-container>\n  </ul>\n  <ul #minuteListElement *ngIf=\"showMinuteColumn\" class=\"{{ prefixCls }}-time-column {{ prefixCls }}-minute-column\">\n    <ng-container *ngFor=\"let time of minuteRange; let i = index; trackBy: trackByFn\">\n      <li\n        class=\"{{ prefixCls }}-time-column-cell\"\n        [class.thy-time-picker-panel-time-column-cell-selected]=\"minute === time.value\"\n        (click)=\"pickMinutes(time, i)\"\n      >\n        <span class=\"{{ prefixCls }}-time-column-cell-inner\">{{ time.value | number: '2.0-0' }}</span>\n      </li>\n    </ng-container>\n  </ul>\n  <ul #secondListElement *ngIf=\"showSecondColumn\" class=\"{{ prefixCls }}-time-column {{ prefixCls }}-second-column\">\n    <ng-container *ngFor=\"let time of secondRange; let i = index; trackBy: trackByFn\">\n      <li\n        class=\"{{ prefixCls }}-time-column-cell\"\n        [class.thy-time-picker-panel-time-column-cell-selected]=\"second === time.value\"\n        (click)=\"pickSeconds(time, i)\"\n      >\n        <span class=\"{{ prefixCls }}-time-column-cell-inner\">{{ time.value | number: '2.0-0' }}</span>\n      </li>\n    </ng-container>\n  </ul>\n</div>\n\n<div *ngIf=\"thyShowOperations\" class=\"{{ prefixCls }}-bottom-operation\">\n  <a *ngIf=\"thyShowSelectNow\" href=\"javascript:;\" class=\"{{ prefixCls }}-time-now\" (click)=\"selectNow()\">此刻</a>\n  <button class=\"{{ prefixCls }}-time-confirm\" thyButton=\"primary\" thySize=\"xs\" class=\"confirm\" (click)=\"confirmPickTime()\">确定</button>\n</div>\n"]}
|
|
230
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker-panel.component.js","sourceRoot":"","sources":["../../../../src/time-picker/time-picker-panel.component.ts","../../../../src/time-picker/time-picker-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    NgZone,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isValid } from 'date-fns';\nimport { InputBoolean, reqAnimFrame } from 'ngx-tethys/core';\nimport { TinyDate } from 'ngx-tethys/util';\n\n@Component({\n    selector: 'thy-time-picker-panel',\n    templateUrl: './time-picker-panel.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => ThyTimePanelComponent)\n        }\n    ],\n    host: {\n        class: 'thy-time-picker-panel',\n        '[class.thy-time-picker-panel-has-bottom-operation]': `thyShowOperations`,\n        '[class.thy-time-picker-panel-columns-2]': `showColumnCount === 2`,\n        '[class.thy-time-picker-panel-columns-3]': `showColumnCount === 3`\n    }\n})\nexport class ThyTimePanelComponent implements OnInit, OnDestroy, ControlValueAccessor {\n    @ViewChild('hourListElement', { static: false }) hourListRef: ElementRef<HTMLElement>;\n\n    @ViewChild('minuteListElement', { static: false }) minuteListRef: ElementRef<HTMLElement>;\n\n    @ViewChild('secondListElement', { static: false }) secondListRef: ElementRef<HTMLElement>;\n\n    @Input() set thyFormat(value: string) {\n        if (value) {\n            const formatSet = new Set(value);\n            this.showHourColumn = formatSet.has('H') || formatSet.has('h');\n            this.showMinuteColumn = formatSet.has('m');\n            this.showSecondColumn = formatSet.has('s');\n        } else {\n            this.showHourColumn = true;\n            this.showMinuteColumn = true;\n            this.showSecondColumn = true;\n        }\n        this.showColumnCount = this.showSecondColumn ? 3 : 2;\n        this.cdr.markForCheck();\n    }\n\n    @Input() thyHourStep: number = 1;\n\n    @Input() thyMinuteStep: number = 1;\n\n    @Input() thySecondStep: number = 1;\n\n    @Input() @InputBoolean() thyShowSelectNow = true;\n\n    @Input() @InputBoolean() thyShowOperations = true;\n\n    @Output() thyPickChange = new EventEmitter<Date>();\n\n    // margin-top + 1px border\n    SCROLL_OFFSET_SPACING = 5;\n\n    SCROLL_DEFAULT_DURATION = 120;\n\n    prefixCls = 'thy-time-picker-panel';\n\n    hourRange: ReadonlyArray<{ value: number; disabled: boolean }> = [];\n\n    minuteRange: ReadonlyArray<{ value: number; disabled: boolean }> = [];\n\n    secondRange: ReadonlyArray<{ value: number; disabled: boolean }> = [];\n\n    showHourColumn = true;\n\n    showMinuteColumn = true;\n\n    showSecondColumn = true;\n\n    showColumnCount: number = 3;\n\n    value: Date;\n\n    hour: number;\n\n    minute: number;\n\n    second: number;\n\n    initialScrollPosition: boolean;\n\n    onValueChangeFn: (val: Date) => void = () => void 0;\n\n    onTouchedFn: () => void = () => void 0;\n\n    constructor(private cdr: ChangeDetectorRef, private ngZone: NgZone) {}\n\n    ngOnInit(): void {\n        this.generateTimeRange();\n        this.initialValue();\n        setTimeout(() => {\n            this.initialScrollPosition = true;\n        });\n    }\n\n    generateTimeRange() {\n        this.hourRange = this.buildTimeRange(24, this.thyHourStep);\n        this.minuteRange = this.buildTimeRange(60, this.thyMinuteStep);\n        this.secondRange = this.buildTimeRange(60, this.thySecondStep);\n    }\n\n    pickHours(hours: { value: number; disabled: boolean }, index: number) {\n        this.value.setHours(hours.value);\n        this.hour = hours.value;\n        this.thyPickChange.emit(this.value);\n        this.scrollTo(this.hourListRef.nativeElement, index);\n    }\n\n    pickMinutes(minutes: { value: number; disabled: boolean }, index: number) {\n        this.value.setMinutes(minutes.value);\n        this.minute = minutes.value;\n        this.thyPickChange.emit(this.value);\n        this.scrollTo(this.minuteListRef.nativeElement, index);\n    }\n\n    pickSeconds(seconds: { value: number; disabled: boolean }, index: number) {\n        this.value.setSeconds(seconds.value);\n        this.second = seconds.value;\n        this.thyPickChange.emit(this.value);\n        this.scrollTo(this.secondListRef.nativeElement, index);\n    }\n\n    selectNow() {\n        this.value = new Date();\n        this.setHMSProperty();\n        this.thyPickChange.emit(this.value);\n        this.autoScroll();\n    }\n\n    confirmPickTime() {\n        this.onValueChangeFn(this.value || new Date());\n    }\n\n    scrollTo(container: HTMLElement, index: number = 0, duration: number = this.SCROLL_DEFAULT_DURATION) {\n        const offsetTop = (container.children[index] as HTMLElement).offsetTop - this.SCROLL_OFFSET_SPACING;\n        this.runScrollAnimationFrame(container, offsetTop, duration);\n    }\n\n    writeValue(value: Date): void {\n        if (value && isValid(value)) {\n            this.value = new Date(value);\n            this.setHMSProperty();\n        } else {\n            this.initialValue();\n        }\n        this.autoScroll(this.initialScrollPosition ? this.SCROLL_DEFAULT_DURATION : 0);\n\n        this.cdr.markForCheck();\n    }\n\n    registerOnChange(fn: (value: Date) => void): void {\n        this.onValueChangeFn = fn;\n    }\n\n    registerOnTouched(fn: () => void): void {\n        this.onTouchedFn = fn;\n    }\n\n    trackByFn(index: number): number {\n        return index;\n    }\n\n    private initialValue() {\n        this.hour = 0;\n        this.minute = 0;\n        this.second = 0;\n        this.value = new TinyDate().setHms(0, 0, 0).nativeDate;\n    }\n\n    private buildTimeRange(length: number, step: number = 1, start: number = 0, disables: number[] = []) {\n        return new Array(Math.ceil(length / step)).fill(0).map((_, i) => {\n            const value = (i + start) * step;\n            return {\n                value: value,\n                disabled: disables.indexOf(value) > -1\n            };\n        });\n    }\n\n    private setHMSProperty() {\n        this.hour = this.value.getHours();\n        this.minute = this.value.getMinutes();\n        this.second = this.value.getSeconds();\n    }\n\n    private resetScrollPosition() {\n        if (this.hourListRef) {\n            this.hourListRef.nativeElement.scrollTop = 0;\n        }\n        if (this.minuteListRef) {\n            this.minuteListRef.nativeElement.scrollTop = 0;\n        }\n        if (this.secondListRef) {\n            this.secondListRef.nativeElement.scrollTop = 0;\n        }\n        this.initialScrollPosition = false;\n    }\n\n    private runScrollAnimationFrame(container: HTMLElement, to: number, duration: number = this.SCROLL_DEFAULT_DURATION) {\n        if (duration <= 0) {\n            container.scrollTop = to;\n            return;\n        }\n        const offset = to - container.scrollTop;\n        const frame = (offset / duration) * 10;\n        this.ngZone.runOutsideAngular(() => {\n            reqAnimFrame(() => {\n                container.scrollTop += frame;\n                if (container.scrollTop === to) {\n                    return;\n                }\n                this.runScrollAnimationFrame(container, to, duration - 10);\n            });\n        });\n    }\n\n    private autoScroll(duration: number = this.SCROLL_DEFAULT_DURATION) {\n        if (this.hourListRef) {\n            this.scrollTo(\n                this.hourListRef.nativeElement,\n                this.hourRange.findIndex(m => m.value === this.hour),\n                duration\n            );\n        }\n        if (this.minuteListRef) {\n            this.scrollTo(\n                this.minuteListRef.nativeElement,\n                this.minuteRange.findIndex(m => m.value === this.minute),\n                duration\n            );\n        }\n        if (this.secondListRef) {\n            this.scrollTo(\n                this.secondListRef.nativeElement,\n                this.secondRange.findIndex(m => m.value === this.second),\n                duration\n            );\n        }\n    }\n\n    ngOnDestroy(): void {\n        this.resetScrollPosition();\n    }\n}\n","<div class=\"{{ prefixCls }}-content\">\n  <ul #hourListElement *ngIf=\"showHourColumn\" class=\"{{ prefixCls }}-time-column {{ prefixCls }}-hour-column\">\n    <ng-container *ngFor=\"let time of hourRange; let i = index; trackBy: trackByFn\">\n      <li\n        class=\"{{ prefixCls }}-time-column-cell\"\n        [class.thy-time-picker-panel-time-column-cell-selected]=\"hour === time.value\"\n        (click)=\"pickHours(time, i)\"\n      >\n        <span class=\"{{ prefixCls }}-time-column-cell-inner\">{{ time.value | number: '2.0-0' }}</span>\n      </li>\n    </ng-container>\n  </ul>\n  <ul #minuteListElement *ngIf=\"showMinuteColumn\" class=\"{{ prefixCls }}-time-column {{ prefixCls }}-minute-column\">\n    <ng-container *ngFor=\"let time of minuteRange; let i = index; trackBy: trackByFn\">\n      <li\n        class=\"{{ prefixCls }}-time-column-cell\"\n        [class.thy-time-picker-panel-time-column-cell-selected]=\"minute === time.value\"\n        (click)=\"pickMinutes(time, i)\"\n      >\n        <span class=\"{{ prefixCls }}-time-column-cell-inner\">{{ time.value | number: '2.0-0' }}</span>\n      </li>\n    </ng-container>\n  </ul>\n  <ul #secondListElement *ngIf=\"showSecondColumn\" class=\"{{ prefixCls }}-time-column {{ prefixCls }}-second-column\">\n    <ng-container *ngFor=\"let time of secondRange; let i = index; trackBy: trackByFn\">\n      <li\n        class=\"{{ prefixCls }}-time-column-cell\"\n        [class.thy-time-picker-panel-time-column-cell-selected]=\"second === time.value\"\n        (click)=\"pickSeconds(time, i)\"\n      >\n        <span class=\"{{ prefixCls }}-time-column-cell-inner\">{{ time.value | number: '2.0-0' }}</span>\n      </li>\n    </ng-container>\n  </ul>\n</div>\n\n<div *ngIf=\"thyShowOperations\" class=\"{{ prefixCls }}-bottom-operation\">\n  <a *ngIf=\"thyShowSelectNow\" href=\"javascript:;\" class=\"{{ prefixCls }}-time-now\" (click)=\"selectNow()\">此刻</a>\n  <button class=\"{{ prefixCls }}-time-confirm\" thyButton=\"primary\" thySize=\"xs\" class=\"confirm\" (click)=\"confirmPickTime()\">确定</button>\n</div>\n"]}
|
|
@@ -19,7 +19,6 @@ export class ThyTimePickerComponent {
|
|
|
19
19
|
this.thySize = 'default';
|
|
20
20
|
this.thyPlaceholder = '选择时间';
|
|
21
21
|
this.thyPlacement = 'bottomLeft';
|
|
22
|
-
this.thyFormat = 'HH:mm:ss';
|
|
23
22
|
this.thyHourStep = 1;
|
|
24
23
|
this.thyMinuteStep = 1;
|
|
25
24
|
this.thySecondStep = 1;
|
|
@@ -28,14 +27,27 @@ export class ThyTimePickerComponent {
|
|
|
28
27
|
this.thyOpenChange = new EventEmitter();
|
|
29
28
|
this.prefixCls = 'thy-time-picker';
|
|
30
29
|
this.overlayPositions = getFlexiblePositions(this.thyPlacement, 4);
|
|
30
|
+
this.format = 'HH:mm:ss';
|
|
31
31
|
this.showText = '';
|
|
32
32
|
this.value = new TinyDate().setHms(0, 0, 0).nativeDate;
|
|
33
33
|
this.onValueChangeFn = () => void 0;
|
|
34
34
|
this.onTouchedFn = () => void 0;
|
|
35
35
|
}
|
|
36
|
+
set thyFormat(value) {
|
|
37
|
+
this.format = value || 'HH:mm:ss';
|
|
38
|
+
if (this.value && isValid(this.value)) {
|
|
39
|
+
this.showText = new TinyDate(this.value).format(this.format);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
36
42
|
set thyDisabled(value) {
|
|
37
43
|
this.disabled = value;
|
|
38
44
|
}
|
|
45
|
+
get thyFormat() {
|
|
46
|
+
return this.format;
|
|
47
|
+
}
|
|
48
|
+
get thyDisabled() {
|
|
49
|
+
return this.disabled;
|
|
50
|
+
}
|
|
39
51
|
ngOnInit() { }
|
|
40
52
|
ngAfterViewInit() {
|
|
41
53
|
this.overlayPositions = getFlexiblePositions(this.thyPlacement, 4);
|
|
@@ -50,11 +62,6 @@ export class ThyTimePickerComponent {
|
|
|
50
62
|
if (this.keepFocus) {
|
|
51
63
|
this.focus();
|
|
52
64
|
}
|
|
53
|
-
else {
|
|
54
|
-
if (this.openState) {
|
|
55
|
-
this.closeOverlay();
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
65
|
}
|
|
59
66
|
onPickTime(value) {
|
|
60
67
|
this.setValue(value);
|
|
@@ -289,4 +296,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.6", ngImpor
|
|
|
289
296
|
}], thyOpenChange: [{
|
|
290
297
|
type: Output
|
|
291
298
|
}] } });
|
|
292
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../src/time-picker/time-picker.component.ts","../../../../src/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isValid } from 'date-fns';\nimport { getFlexiblePositions, InputBoolean, ThyPlacement } from 'ngx-tethys/core';\nimport { TinyDate } from 'ngx-tethys/util';\nimport { Subject } from 'rxjs';\n\nexport type TimePickerSize = 'xs' | 'sm' | 'md' | 'lg' | 'default';\n\n@Component({\n    selector: 'thy-time-picker',\n    templateUrl: './time-picker.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => ThyTimePickerComponent)\n        }\n    ],\n    host: {\n        class: 'thy-time-picker',\n        '[class.thy-time-picker-disabled]': `thyDisabled`,\n        '[class.thy-time-picker-readonly]': `thyReadonly`\n    }\n})\nexport class ThyTimePickerComponent implements OnInit, AfterViewInit, ControlValueAccessor {\n    @ViewChild(CdkConnectedOverlay, { static: true }) cdkConnectedOverlay: CdkConnectedOverlay;\n\n    @ViewChild('origin', { static: true }) origin: CdkOverlayOrigin;\n\n    @ViewChild('pickerInput', { static: true }) inputRef: ElementRef<HTMLInputElement>;\n\n    @ViewChild('overlayContainer', { static: false }) overlayContainer: ElementRef<HTMLElement>;\n\n    @Input() thySize: TimePickerSize = 'default';\n\n    @Input() thyPlaceholder: string = '选择时间';\n\n    @Input() thyPlacement: ThyPlacement = 'bottomLeft';\n\n    @Input() thyFormat: string = 'HH:mm:ss';\n\n    @Input() thyHourStep: number = 1;\n\n    @Input() thyMinuteStep: number = 1;\n\n    @Input() thySecondStep: number = 1;\n\n    @Input() thyPopupClass: string;\n\n    @Input() @InputBoolean() thyBackdrop: boolean;\n\n    @Input() @InputBoolean() set thyDisabled(value: boolean) {\n        this.disabled = value;\n    }\n\n    @Input() @InputBoolean() thyReadonly: boolean;\n\n    @Input() @InputBoolean() thyShowSelectNow = true;\n\n    @Input() @InputBoolean() thyAllowClear = true;\n\n    @Output() thyOpenChange = new EventEmitter<boolean>();\n\n    prefixCls = 'thy-time-picker';\n\n    overlayPositions = getFlexiblePositions(this.thyPlacement, 4);\n\n    disabled: boolean;\n\n    showText: string = '';\n\n    openState: boolean;\n\n    value: Date = new TinyDate().setHms(0, 0, 0).nativeDate;\n\n    keepFocus: boolean;\n\n    onValueChangeFn: (val: number | Date) => void = () => void 0;\n\n    onTouchedFn: () => void = () => void 0;\n\n    constructor(private cdr: ChangeDetectorRef, private elementRef: ElementRef) {}\n\n    ngOnInit() {}\n\n    ngAfterViewInit() {\n        this.overlayPositions = getFlexiblePositions(this.thyPlacement, 4);\n    }\n\n    onInputPickerClick() {\n        if (this.disabledUserOperation()) {\n            return;\n        }\n        this.openOverlay();\n    }\n\n    onInputPickerBlur() {\n        if (this.keepFocus) {\n            this.focus();\n        } else {\n            if (this.openState) {\n                this.closeOverlay();\n            }\n        }\n    }\n\n    onPickTime(value: Date) {\n        this.setValue(value);\n        this.emitValue();\n    }\n\n    onPickTimeConfirm(value: Date) {\n        this.confirmValue(value);\n    }\n\n    onClearTime(e: Event) {\n        e.stopPropagation();\n        this.setValue(null);\n        this.emitValue();\n    }\n\n    onCustomizeInput(value: string) {\n        this.formatInputValue(value);\n        this.cdr.detectChanges();\n    }\n\n    onKeyupEnter() {\n        this.confirmValue(this.value);\n        this.closeOverlay();\n    }\n\n    onKeyupEsc() {\n        this.closeOverlay();\n    }\n\n    onPositionChange(e: Event) {\n        this.cdr.detectChanges();\n    }\n\n    onClickBackdrop() {\n        this.closeOverlay();\n    }\n\n    onOverlayDetach() {\n        this.closeOverlay();\n    }\n\n    onOutsideClick(event: Event) {\n        if (\n            this.openState &&\n            !this.elementRef.nativeElement.contains(event.target) &&\n            !this.overlayContainer.nativeElement.contains(event.target as Node)\n        ) {\n            this.closeOverlay();\n            this.cdr.detectChanges();\n        }\n    }\n\n    onOverlayAttach() {\n        if (this.cdkConnectedOverlay && this.cdkConnectedOverlay.overlayRef) {\n            this.cdkConnectedOverlay.overlayRef.updatePosition();\n        }\n    }\n\n    openOverlay() {\n        if (this.disabledUserOperation()) {\n            return;\n        }\n        this.keepFocus = true;\n        this.openState = true;\n        this.thyOpenChange.emit(this.openState);\n    }\n\n    closeOverlay() {\n        this.keepFocus = false;\n        this.openState = false;\n        this.blur();\n        if (this.showText?.length) {\n            if (!this.validateCustomizeInput(this.showText)) {\n                this.setValue(this.value);\n            } else {\n                this.showText = new TinyDate(this.value).format(this.thyFormat);\n            }\n        }\n        this.thyOpenChange.emit(this.openState);\n    }\n\n    focus() {\n        if (this.inputRef) {\n            this.inputRef.nativeElement.focus();\n        }\n    }\n\n    blur() {\n        if (this.inputRef) {\n            this.inputRef.nativeElement.blur();\n        }\n    }\n\n    writeValue(value: Date): void {\n        this.setValue(value);\n    }\n\n    registerOnChange(fn: any): void {\n        this.onValueChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    private setValue(value: Date, formatText: boolean = true) {\n        if (value && isValid(value)) {\n            this.value = new Date(value);\n            if (formatText) {\n                this.showText = new TinyDate(this.value).format(this.thyFormat);\n            }\n        } else {\n            this.value = null;\n            this.showText = '';\n        }\n        this.cdr.markForCheck();\n    }\n\n    private confirmValue(value: Date) {\n        this.setValue(value);\n        this.closeOverlay();\n        this.emitValue();\n        this.cdr.markForCheck();\n    }\n\n    private emitValue() {\n        if (this.onValueChangeFn) {\n            this.onValueChangeFn(this.value);\n        }\n        if (this.onTouchedFn) {\n            this.onTouchedFn();\n        }\n    }\n\n    private formatInputValue(value: string) {\n        if (!this.openState) {\n            this.openOverlay();\n        }\n        if (value?.length > 0) {\n            if (this.validateCustomizeInput(value)) {\n                const formatter = value.split(':');\n                const hour = formatter[0] || 0;\n                const minute = formatter[1] || 0;\n                const second = formatter[2] || 0;\n                this.setValue(new TinyDate().setHms(+hour, +minute, +second).nativeDate, false);\n                this.emitValue();\n            }\n        } else {\n            this.setValue(null);\n            this.emitValue();\n        }\n    }\n\n    private validateCustomizeInput(value: string): boolean {\n        let valid: boolean = false;\n        const formatRule = this.thyFormat.split(':');\n        const formatter = value.split(':');\n        valid = !formatRule\n            .map((m, i) => {\n                return !!formatter[i];\n            })\n            .includes(false);\n        return valid;\n    }\n\n    private disabledUserOperation() {\n        return this.thyDisabled || this.thyReadonly;\n    }\n}\n","<span cdkOverlayOrigin #origin=\"cdkOverlayOrigin\" (click)=\"onInputPickerClick()\">\n  <ng-container>\n    <input\n      #pickerInput\n      thyInput\n      class=\"form-control {{ prefixCls }}-input\"\n      [class.thy-input-disabled]=\"thyDisabled\"\n      [class.thy-input-readonly]=\"thyReadonly\"\n      [class.thy-time-picker-panel-opened]=\"openState\"\n      [(ngModel)]=\"showText\"\n      [thySize]=\"thySize\"\n      [disabled]=\"disabled\"\n      [readonly]=\"thyReadonly\"\n      [placeholder]=\"thyPlaceholder\"\n      (blur)=\"onInputPickerBlur()\"\n      (keyup.enter)=\"onKeyupEnter()\"\n      (keyup.escape)=\"onKeyupEsc()\"\n      (ngModelChange)=\"onCustomizeInput($event)\"\n    />\n    <ng-container *ngTemplateOutlet=\"rightIcon\"></ng-container>\n  </ng-container>\n</span>\n\n<ng-template #rightIcon>\n  <span class=\"{{ prefixCls }}-clear\" *ngIf=\"!thyDisabled && thyAllowClear && !thyReadonly && showText\">\n    <thy-icon thyIconName=\"close-circle-bold-fill\" (click)=\"onClearTime($event)\" ngClass=\"remove-link remove-link-{{ thySize }}\"></thy-icon>\n  </span>\n  <span class=\"{{ prefixCls }}-icon\">\n    <thy-icon [thyIconName]=\"'clock-circle-moment'\" ngClass=\"remove-link-{{ thySize }}\"></thy-icon>\n  </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"origin\"\n  [cdkConnectedOverlayOpen]=\"openState\"\n  [cdkConnectedOverlayHasBackdrop]=\"thyBackdrop\"\n  [cdkConnectedOverlayPositions]=\"overlayPositions\"\n  cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n  (positionChange)=\"onPositionChange($event)\"\n  (backdropClick)=\"onClickBackdrop()\"\n  (overlayOutsideClick)=\"onOutsideClick($event)\"\n  (detach)=\"onOverlayDetach()\"\n  (attach)=\"onOverlayAttach()\"\n>\n  <div #overlayContainer style=\"position: relative;\">\n    <!-- Compatible for overlay that not support offset dynamically and immediately -->\n    <thy-time-picker-panel\n      [ngClass]=\"thyPopupClass\"\n      [(ngModel)]=\"value\"\n      [thyFormat]=\"thyFormat\"\n      [thyHourStep]=\"thyHourStep\"\n      [thyMinuteStep]=\"thyMinuteStep\"\n      [thySecondStep]=\"thySecondStep\"\n      [thyShowSelectNow]=\"thyShowSelectNow\"\n      (ngModelChange)=\"onPickTimeConfirm($event)\"\n      (thyPickChange)=\"onPickTime($event)\"\n    ></thy-time-picker-panel>\n  </div>\n</ng-template>\n"]}
|
|
299
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"time-picker.component.js","sourceRoot":"","sources":["../../../../src/time-picker/time-picker.component.ts","../../../../src/time-picker/time-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin } from '@angular/cdk/overlay';\nimport {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    ChangeDetectorRef,\n    Component,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    Input,\n    OnDestroy,\n    OnInit,\n    Output,\n    ViewChild\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { isValid } from 'date-fns';\nimport { getFlexiblePositions, InputBoolean, ThyPlacement } from 'ngx-tethys/core';\nimport { TinyDate } from 'ngx-tethys/util';\nimport { Subject } from 'rxjs';\n\nexport type TimePickerSize = 'xs' | 'sm' | 'md' | 'lg' | 'default';\n\n@Component({\n    selector: 'thy-time-picker',\n    templateUrl: './time-picker.component.html',\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    providers: [\n        {\n            provide: NG_VALUE_ACCESSOR,\n            multi: true,\n            useExisting: forwardRef(() => ThyTimePickerComponent)\n        }\n    ],\n    host: {\n        class: 'thy-time-picker',\n        '[class.thy-time-picker-disabled]': `thyDisabled`,\n        '[class.thy-time-picker-readonly]': `thyReadonly`\n    }\n})\nexport class ThyTimePickerComponent implements OnInit, AfterViewInit, ControlValueAccessor {\n    @ViewChild(CdkConnectedOverlay, { static: true }) cdkConnectedOverlay: CdkConnectedOverlay;\n\n    @ViewChild('origin', { static: true }) origin: CdkOverlayOrigin;\n\n    @ViewChild('pickerInput', { static: true }) inputRef: ElementRef<HTMLInputElement>;\n\n    @ViewChild('overlayContainer', { static: false }) overlayContainer: ElementRef<HTMLElement>;\n\n    @Input() thySize: TimePickerSize = 'default';\n\n    @Input() thyPlaceholder: string = '选择时间';\n\n    @Input() thyPlacement: ThyPlacement = 'bottomLeft';\n\n    @Input() set thyFormat(value: string) {\n        this.format = value || 'HH:mm:ss';\n        if (this.value && isValid(this.value)) {\n            this.showText = new TinyDate(this.value).format(this.format);\n        }\n    }\n\n    @Input() thyHourStep: number = 1;\n\n    @Input() thyMinuteStep: number = 1;\n\n    @Input() thySecondStep: number = 1;\n\n    @Input() thyPopupClass: string;\n\n    @Input() @InputBoolean() thyBackdrop: boolean;\n\n    @Input() @InputBoolean() set thyDisabled(value: boolean) {\n        this.disabled = value;\n    }\n\n    @Input() @InputBoolean() thyReadonly: boolean;\n\n    @Input() @InputBoolean() thyShowSelectNow = true;\n\n    @Input() @InputBoolean() thyAllowClear = true;\n\n    @Output() thyOpenChange = new EventEmitter<boolean>();\n\n    get thyFormat() {\n        return this.format;\n    }\n\n    get thyDisabled() {\n        return this.disabled;\n    }\n\n    prefixCls = 'thy-time-picker';\n\n    overlayPositions = getFlexiblePositions(this.thyPlacement, 4);\n\n    format: string = 'HH:mm:ss';\n\n    disabled: boolean;\n\n    showText: string = '';\n\n    openState: boolean;\n\n    value: Date = new TinyDate().setHms(0, 0, 0).nativeDate;\n\n    keepFocus: boolean;\n\n    onValueChangeFn: (val: number | Date) => void = () => void 0;\n\n    onTouchedFn: () => void = () => void 0;\n\n    constructor(private cdr: ChangeDetectorRef, private elementRef: ElementRef) {}\n\n    ngOnInit() {}\n\n    ngAfterViewInit() {\n        this.overlayPositions = getFlexiblePositions(this.thyPlacement, 4);\n    }\n\n    onInputPickerClick() {\n        if (this.disabledUserOperation()) {\n            return;\n        }\n        this.openOverlay();\n    }\n\n    onInputPickerBlur() {\n        if (this.keepFocus) {\n            this.focus();\n        }\n    }\n\n    onPickTime(value: Date) {\n        this.setValue(value);\n        this.emitValue();\n    }\n\n    onPickTimeConfirm(value: Date) {\n        this.confirmValue(value);\n    }\n\n    onClearTime(e: Event) {\n        e.stopPropagation();\n        this.setValue(null);\n        this.emitValue();\n    }\n\n    onCustomizeInput(value: string) {\n        this.formatInputValue(value);\n        this.cdr.detectChanges();\n    }\n\n    onKeyupEnter() {\n        this.confirmValue(this.value);\n        this.closeOverlay();\n    }\n\n    onKeyupEsc() {\n        this.closeOverlay();\n    }\n\n    onPositionChange(e: Event) {\n        this.cdr.detectChanges();\n    }\n\n    onClickBackdrop() {\n        this.closeOverlay();\n    }\n\n    onOverlayDetach() {\n        this.closeOverlay();\n    }\n\n    onOutsideClick(event: Event) {\n        if (\n            this.openState &&\n            !this.elementRef.nativeElement.contains(event.target) &&\n            !this.overlayContainer.nativeElement.contains(event.target as Node)\n        ) {\n            this.closeOverlay();\n            this.cdr.detectChanges();\n        }\n    }\n\n    onOverlayAttach() {\n        if (this.cdkConnectedOverlay && this.cdkConnectedOverlay.overlayRef) {\n            this.cdkConnectedOverlay.overlayRef.updatePosition();\n        }\n    }\n\n    openOverlay() {\n        if (this.disabledUserOperation()) {\n            return;\n        }\n        this.keepFocus = true;\n        this.openState = true;\n        this.thyOpenChange.emit(this.openState);\n    }\n\n    closeOverlay() {\n        this.keepFocus = false;\n        this.openState = false;\n        this.blur();\n        if (this.showText?.length) {\n            if (!this.validateCustomizeInput(this.showText)) {\n                this.setValue(this.value);\n            } else {\n                this.showText = new TinyDate(this.value).format(this.thyFormat);\n            }\n        }\n        this.thyOpenChange.emit(this.openState);\n    }\n\n    focus() {\n        if (this.inputRef) {\n            this.inputRef.nativeElement.focus();\n        }\n    }\n\n    blur() {\n        if (this.inputRef) {\n            this.inputRef.nativeElement.blur();\n        }\n    }\n\n    writeValue(value: Date): void {\n        this.setValue(value);\n    }\n\n    registerOnChange(fn: any): void {\n        this.onValueChangeFn = fn;\n    }\n\n    registerOnTouched(fn: any): void {\n        this.onTouchedFn = fn;\n    }\n\n    setDisabledState?(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    private setValue(value: Date, formatText: boolean = true) {\n        if (value && isValid(value)) {\n            this.value = new Date(value);\n            if (formatText) {\n                this.showText = new TinyDate(this.value).format(this.thyFormat);\n            }\n        } else {\n            this.value = null;\n            this.showText = '';\n        }\n        this.cdr.markForCheck();\n    }\n\n    private confirmValue(value: Date) {\n        this.setValue(value);\n        this.closeOverlay();\n        this.emitValue();\n        this.cdr.markForCheck();\n    }\n\n    private emitValue() {\n        if (this.onValueChangeFn) {\n            this.onValueChangeFn(this.value);\n        }\n        if (this.onTouchedFn) {\n            this.onTouchedFn();\n        }\n    }\n\n    private formatInputValue(value: string) {\n        if (!this.openState) {\n            this.openOverlay();\n        }\n        if (value?.length > 0) {\n            if (this.validateCustomizeInput(value)) {\n                const formatter = value.split(':');\n                const hour = formatter[0] || 0;\n                const minute = formatter[1] || 0;\n                const second = formatter[2] || 0;\n                this.setValue(new TinyDate().setHms(+hour, +minute, +second).nativeDate, false);\n                this.emitValue();\n            }\n        } else {\n            this.setValue(null);\n            this.emitValue();\n        }\n    }\n\n    private validateCustomizeInput(value: string): boolean {\n        let valid: boolean = false;\n        const formatRule = this.thyFormat.split(':');\n        const formatter = value.split(':');\n        valid = !formatRule\n            .map((m, i) => {\n                return !!formatter[i];\n            })\n            .includes(false);\n        return valid;\n    }\n\n    private disabledUserOperation() {\n        return this.thyDisabled || this.thyReadonly;\n    }\n}\n","<span cdkOverlayOrigin #origin=\"cdkOverlayOrigin\" (click)=\"onInputPickerClick()\">\n  <ng-container>\n    <input\n      #pickerInput\n      thyInput\n      class=\"form-control {{ prefixCls }}-input\"\n      [class.thy-input-disabled]=\"thyDisabled\"\n      [class.thy-input-readonly]=\"thyReadonly\"\n      [class.thy-time-picker-panel-opened]=\"openState\"\n      [(ngModel)]=\"showText\"\n      [thySize]=\"thySize\"\n      [disabled]=\"disabled\"\n      [readonly]=\"thyReadonly\"\n      [placeholder]=\"thyPlaceholder\"\n      (blur)=\"onInputPickerBlur()\"\n      (keyup.enter)=\"onKeyupEnter()\"\n      (keyup.escape)=\"onKeyupEsc()\"\n      (ngModelChange)=\"onCustomizeInput($event)\"\n    />\n    <ng-container *ngTemplateOutlet=\"rightIcon\"></ng-container>\n  </ng-container>\n</span>\n\n<ng-template #rightIcon>\n  <span class=\"{{ prefixCls }}-clear\" *ngIf=\"!thyDisabled && thyAllowClear && !thyReadonly && showText\">\n    <thy-icon thyIconName=\"close-circle-bold-fill\" (click)=\"onClearTime($event)\" ngClass=\"remove-link remove-link-{{ thySize }}\"></thy-icon>\n  </span>\n  <span class=\"{{ prefixCls }}-icon\">\n    <thy-icon [thyIconName]=\"'clock-circle-moment'\" ngClass=\"remove-link-{{ thySize }}\"></thy-icon>\n  </span>\n</ng-template>\n\n<!-- Overlay -->\n<ng-template\n  cdkConnectedOverlay\n  [cdkConnectedOverlayOrigin]=\"origin\"\n  [cdkConnectedOverlayOpen]=\"openState\"\n  [cdkConnectedOverlayHasBackdrop]=\"thyBackdrop\"\n  [cdkConnectedOverlayPositions]=\"overlayPositions\"\n  cdkConnectedOverlayBackdropClass=\"cdk-overlay-transparent-backdrop\"\n  (positionChange)=\"onPositionChange($event)\"\n  (backdropClick)=\"onClickBackdrop()\"\n  (overlayOutsideClick)=\"onOutsideClick($event)\"\n  (detach)=\"onOverlayDetach()\"\n  (attach)=\"onOverlayAttach()\"\n>\n  <div #overlayContainer style=\"position: relative;\">\n    <!-- Compatible for overlay that not support offset dynamically and immediately -->\n    <thy-time-picker-panel\n      [ngClass]=\"thyPopupClass\"\n      [(ngModel)]=\"value\"\n      [thyFormat]=\"thyFormat\"\n      [thyHourStep]=\"thyHourStep\"\n      [thyMinuteStep]=\"thyMinuteStep\"\n      [thySecondStep]=\"thySecondStep\"\n      [thyShowSelectNow]=\"thyShowSelectNow\"\n      (ngModelChange)=\"onPickTimeConfirm($event)\"\n      (thyPickChange)=\"onPickTime($event)\"\n    ></thy-time-picker-panel>\n  </div>\n</ng-template>\n"]}
|
package/esm2020/version.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
import { Version } from '@angular/core';
|
|
2
|
-
export const VERSION = new Version('13.2.
|
|
3
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
export const VERSION = new Version('13.2.4');
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmVyc2lvbi5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy92ZXJzaW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxPQUFPLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFeEMsTUFBTSxDQUFDLE1BQU0sT0FBTyxHQUFHLElBQUksT0FBTyxDQUFDLFFBQVEsQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVmVyc2lvbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5leHBvcnQgY29uc3QgVkVSU0lPTiA9IG5ldyBWZXJzaW9uKCcxMy4yLjQnKTtcbiJdfQ==
|
|
@@ -196,7 +196,7 @@ class ThyImagePreviewComponent extends mixinUnsubscribe(MixinBase) {
|
|
|
196
196
|
get previewImage() {
|
|
197
197
|
const image = this.images[this.previewIndex];
|
|
198
198
|
if (image.size) {
|
|
199
|
-
|
|
199
|
+
image.size = isNumber(image.size) ? humanizeBytes(image.size) : image.size;
|
|
200
200
|
}
|
|
201
201
|
return image;
|
|
202
202
|
}
|