@seniorsistemas/angular-components 17.17.13 → 17.18.0
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/bundles/seniorsistemas-angular-components.umd.js +259 -62
- package/bundles/seniorsistemas-angular-components.umd.js.map +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js +1 -1
- package/bundles/seniorsistemas-angular-components.umd.min.js.map +1 -1
- package/components/dynamic-form/configurations/fields/field.d.ts +2 -0
- package/components/index.d.ts +1 -0
- package/components/info-sign/info-sign.directive.d.ts +1 -0
- package/components/thumbnails/components/thumbnail-item/components/thumbnail-item-image/thumbnail-item-image.component.d.ts +3 -0
- package/components/thumbnails/components/thumbnail-item/components/thumbnail-item-video/thumbnail-item-video.component.d.ts +8 -0
- package/components/thumbnails/components/thumbnail-item/thumbnail-item.component.d.ts +18 -0
- package/components/thumbnails/index.d.ts +3 -0
- package/components/thumbnails/models/thumbnails-item.d.ts +20 -0
- package/components/thumbnails/thumbnails.component.d.ts +16 -0
- package/components/thumbnails/thumbnails.module.d.ts +2 -0
- package/components/tooltip/tooltip.directive.d.ts +2 -7
- package/esm2015/components/dynamic-form/components/dynamic-field/dynamic-field.component.js +2 -2
- package/esm2015/components/dynamic-form/components/field-label/field-label.component.js +2 -2
- package/esm2015/components/dynamic-form/components/fields/radio-button/radio-button-field.component.js +9 -2
- package/esm2015/components/dynamic-form/components/grid/row/row.component.js +2 -2
- package/esm2015/components/dynamic-form/configurations/fields/field.js +3 -2
- package/esm2015/components/index.js +2 -1
- package/esm2015/components/info-sign/info-sign.directive.js +12 -5
- package/esm2015/components/thumbnails/components/thumbnail-item/components/thumbnail-item-image/thumbnail-item-image.component.js +16 -0
- package/esm2015/components/thumbnails/components/thumbnail-item/components/thumbnail-item-video/thumbnail-item-video.component.js +41 -0
- package/esm2015/components/thumbnails/components/thumbnail-item/thumbnail-item.component.js +56 -0
- package/esm2015/components/thumbnails/index.js +3 -0
- package/esm2015/components/thumbnails/models/thumbnails-item.js +1 -0
- package/esm2015/components/thumbnails/thumbnails.component.js +52 -0
- package/esm2015/components/thumbnails/thumbnails.module.js +21 -0
- package/esm2015/components/tooltip/tooltip.directive.js +42 -40
- package/esm2015/locale/fallback.js +4 -1
- package/esm2015/seniorsistemas-angular-components.js +15 -12
- package/esm5/components/dynamic-form/components/dynamic-field/dynamic-field.component.js +2 -2
- package/esm5/components/dynamic-form/components/field-label/field-label.component.js +2 -2
- package/esm5/components/dynamic-form/components/fields/radio-button/radio-button-field.component.js +3 -3
- package/esm5/components/dynamic-form/components/grid/row/row.component.js +2 -2
- package/esm5/components/dynamic-form/configurations/fields/field.js +3 -2
- package/esm5/components/index.js +2 -1
- package/esm5/components/info-sign/info-sign.directive.js +12 -5
- package/esm5/components/thumbnails/components/thumbnail-item/components/thumbnail-item-image/thumbnail-item-image.component.js +19 -0
- package/esm5/components/thumbnails/components/thumbnail-item/components/thumbnail-item-video/thumbnail-item-video.component.js +44 -0
- package/esm5/components/thumbnails/components/thumbnail-item/thumbnail-item.component.js +58 -0
- package/esm5/components/thumbnails/index.js +3 -0
- package/esm5/components/thumbnails/models/thumbnails-item.js +1 -0
- package/esm5/components/thumbnails/thumbnails.component.js +57 -0
- package/esm5/components/thumbnails/thumbnails.module.js +24 -0
- package/esm5/components/tooltip/tooltip.directive.js +45 -40
- package/esm5/locale/fallback.js +4 -1
- package/esm5/seniorsistemas-angular-components.js +15 -12
- package/fesm2015/seniorsistemas-angular-components.js +231 -51
- package/fesm2015/seniorsistemas-angular-components.js.map +1 -1
- package/fesm5/seniorsistemas-angular-components.js +244 -52
- package/fesm5/seniorsistemas-angular-components.js.map +1 -1
- package/package.json +1 -1
- package/seniorsistemas-angular-components.d.ts +14 -11
- package/seniorsistemas-angular-components.metadata.json +1 -1
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
3
|
+
import { FormControl, FormGroup } from "@angular/forms";
|
|
4
|
+
import { isNullOrUndefined } from "../../../utils/utils";
|
|
5
|
+
var ThumbnailItemComponent = /** @class */ (function () {
|
|
6
|
+
function ThumbnailItemComponent() {
|
|
7
|
+
this.isCheckable = true;
|
|
8
|
+
this.isChecked = false;
|
|
9
|
+
this.checked = new EventEmitter();
|
|
10
|
+
this.opened = new EventEmitter();
|
|
11
|
+
}
|
|
12
|
+
ThumbnailItemComponent.prototype.ngOnInit = function () {
|
|
13
|
+
this._validateItemData();
|
|
14
|
+
this._createFormGroup();
|
|
15
|
+
};
|
|
16
|
+
ThumbnailItemComponent.prototype.onClick = function () {
|
|
17
|
+
this.opened.emit(this.itemData);
|
|
18
|
+
};
|
|
19
|
+
ThumbnailItemComponent.prototype._createFormGroup = function () {
|
|
20
|
+
var _this = this;
|
|
21
|
+
this.checkboxFormGroup = new FormGroup({
|
|
22
|
+
checkbox: new FormControl({ checked: this.isChecked }),
|
|
23
|
+
});
|
|
24
|
+
this.checkboxFormGroup.get("checkbox").valueChanges.subscribe(function (value) {
|
|
25
|
+
_this.checked.emit({ item: _this.itemData, checked: value.checked });
|
|
26
|
+
});
|
|
27
|
+
};
|
|
28
|
+
ThumbnailItemComponent.prototype._validateItemData = function () {
|
|
29
|
+
if (isNullOrUndefined(this.itemData)) {
|
|
30
|
+
throw new Error("itemData is required");
|
|
31
|
+
}
|
|
32
|
+
};
|
|
33
|
+
__decorate([
|
|
34
|
+
Input()
|
|
35
|
+
], ThumbnailItemComponent.prototype, "itemData", void 0);
|
|
36
|
+
__decorate([
|
|
37
|
+
Input()
|
|
38
|
+
], ThumbnailItemComponent.prototype, "isCheckable", void 0);
|
|
39
|
+
__decorate([
|
|
40
|
+
Input()
|
|
41
|
+
], ThumbnailItemComponent.prototype, "isChecked", void 0);
|
|
42
|
+
__decorate([
|
|
43
|
+
Output()
|
|
44
|
+
], ThumbnailItemComponent.prototype, "checked", void 0);
|
|
45
|
+
__decorate([
|
|
46
|
+
Output()
|
|
47
|
+
], ThumbnailItemComponent.prototype, "opened", void 0);
|
|
48
|
+
ThumbnailItemComponent = __decorate([
|
|
49
|
+
Component({
|
|
50
|
+
selector: "s-thumbnail-item",
|
|
51
|
+
template: "<button *ngIf=\"itemData\" class=\"thumbnail-item\" (click)=\"onClick()\">\n <div class=\"thumbnail-item-content\">\n <div class=\"content\">\n <ng-container *ngIf=\"itemData.type === 'video'\">\n <s-thumbnail-item-video\n [imageUrl]=\"itemData.imageUrl\"\n [videoUrl]=\"itemData.videoUrl\">\n </s-thumbnail-item-video>\n </ng-container>\n <ng-container *ngIf=\"itemData.type === 'image'\">\n <s-thumbnail-item-image [imageUrl]=\"itemData.imageUrl\"></s-thumbnail-item-image>\n </ng-container>\n <ng-container *ngIf=\"itemData.type === 'audio'\">\n <i class=\"icon fas fa-volume-down\"></i>\n <span class=\"label\">{{ \"platform.angular_components.listen\" | translate }}</span>\n </ng-container>\n <ng-container *ngIf=\"itemData.type === 'file'\">\n <i class=\"icon fas fa-file-alt\"></i>\n <span class=\"label\">{{ \"platform.angular_components.view\" | translate }}</span>\n </ng-container>\n </div>\n <form *ngIf=\"isCheckable\" [formGroup]=\"checkboxFormGroup\" class=\"checkbox\">\n <s-checkbox [data]=\"{ label: '' }\" formControlName=\"checkbox\"> </s-checkbox>\n </form>\n </div>\n <span class=\"file-name-label\">{{ itemData.fileName }}</span>\n</button>\n",
|
|
52
|
+
styles: [".thumbnail-item{-ms-flex-align:center;align-items:center;background:0 0;border:none;cursor:pointer;display:-ms-inline-flexbox;display:inline-flex;-ms-flex-direction:column;flex-direction:column;-ms-flex-pack:center;justify-content:center;overflow:hidden;width:100px}.thumbnail-item-content{-ms-flex-align:center;align-items:center;background-image:linear-gradient(to top right,#5288b6,#00c89a);border-radius:8px;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;height:100px;-ms-flex-pack:center;justify-content:center;position:relative;-webkit-user-select:none;-ms-user-select:none;user-select:none;width:100%;overflow:hidden}.thumbnail-item-content .checkbox{position:absolute;right:8px;top:8px}.thumbnail-item-content .content{-ms-flex-align:center;align-items:center;color:#fff;display:-ms-flexbox;display:flex;-ms-flex-direction:column;flex-direction:column;gap:4px;overflow:hidden;width:100%}.thumbnail-item-content .content .icon{font-size:24px}.thumbnail-item-content .content .label{font-size:12px;width:100%;padding:0 8px;overflow:hidden;text-overflow:ellipsis}.thumbnail-item:hover{transform:scale(1.05);transition:.2s ease-in-out}.thumbnail-item .file-name-label{color:#525966;font-family:\"Open Sans\",sans-serif;font-size:12px;overflow:hidden;text-align:center;text-overflow:ellipsis;text-wrap:nowrap;-webkit-user-select:none;-ms-user-select:none;user-select:none;width:100%}"]
|
|
53
|
+
})
|
|
54
|
+
], ThumbnailItemComponent);
|
|
55
|
+
return ThumbnailItemComponent;
|
|
56
|
+
}());
|
|
57
|
+
export { ThumbnailItemComponent };
|
|
58
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlsLWl0ZW0uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvdGh1bWJuYWlscy9jb21wb25lbnRzL3RodW1ibmFpbC1pdGVtL3RodW1ibmFpbC1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFNBQVMsRUFBRSxZQUFZLEVBQUUsS0FBSyxFQUFVLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMvRSxPQUFPLEVBQUUsV0FBVyxFQUFFLFNBQVMsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBR3hELE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBUXpEO0lBQUE7UUFLVyxnQkFBVyxHQUFHLElBQUksQ0FBQztRQUduQixjQUFTLEdBQUcsS0FBSyxDQUFDO1FBR2xCLFlBQU8sR0FBRyxJQUFJLFlBQVksRUFBNEMsQ0FBQztRQUd2RSxXQUFNLEdBQUcsSUFBSSxZQUFZLEVBQWtCLENBQUM7SUE0QnZELENBQUM7SUF4QlUseUNBQVEsR0FBZjtRQUNJLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1FBQ3pCLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxDQUFDO0lBQzVCLENBQUM7SUFFTSx3Q0FBTyxHQUFkO1FBQ0ksSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3BDLENBQUM7SUFFTyxpREFBZ0IsR0FBeEI7UUFBQSxpQkFRQztRQVBHLElBQUksQ0FBQyxpQkFBaUIsR0FBRyxJQUFJLFNBQVMsQ0FBQztZQUNuQyxRQUFRLEVBQUUsSUFBSSxXQUFXLENBQUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1NBQ3pELENBQUMsQ0FBQztRQUVILElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsWUFBWSxDQUFDLFNBQVMsQ0FBQyxVQUFDLEtBQW9CO1lBQy9FLEtBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEVBQUUsSUFBSSxFQUFFLEtBQUksQ0FBQyxRQUFRLEVBQUUsT0FBTyxFQUFFLEtBQUssQ0FBQyxPQUFPLEVBQUUsQ0FBQyxDQUFDO1FBQ3ZFLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVPLGtEQUFpQixHQUF6QjtRQUNJLElBQUksaUJBQWlCLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxFQUFFO1lBQ2xDLE1BQU0sSUFBSSxLQUFLLENBQUMsc0JBQXNCLENBQUMsQ0FBQztTQUMzQztJQUNMLENBQUM7SUF2Q0Q7UUFEQyxLQUFLLEVBQUU7NERBQ3dCO0lBR2hDO1FBREMsS0FBSyxFQUFFOytEQUNrQjtJQUcxQjtRQURDLEtBQUssRUFBRTs2REFDaUI7SUFHekI7UUFEQyxNQUFNLEVBQUU7MkRBQ3FFO0lBRzlFO1FBREMsTUFBTSxFQUFFOzBEQUMwQztJQWQxQyxzQkFBc0I7UUFMbEMsU0FBUyxDQUFDO1lBQ1AsUUFBUSxFQUFFLGtCQUFrQjtZQUM1QixpN0NBQThDOztTQUVqRCxDQUFDO09BQ1csc0JBQXNCLENBMENsQztJQUFELDZCQUFDO0NBQUEsQUExQ0QsSUEwQ0M7U0ExQ1ksc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBGb3JtQ29udHJvbCwgRm9ybUdyb3VwIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5cbmltcG9ydCB7IENoZWNrYm94U3RhdGUgfSBmcm9tIFwiLi4vLi4vLi4vY2hlY2tib3gvbW9kZWxzL2NoZWNrYm94LXN0YXRlXCI7XG5pbXBvcnQgeyBpc051bGxPclVuZGVmaW5lZCB9IGZyb20gXCIuLi8uLi8uLi91dGlscy91dGlsc1wiO1xuaW1wb3J0IHsgVGh1bWJuYWlsc0l0ZW0gfSBmcm9tIFwiLi4vLi4vbW9kZWxzL3RodW1ibmFpbHMtaXRlbVwiO1xuXG5AQ29tcG9uZW50KHtcbiAgICBzZWxlY3RvcjogXCJzLXRodW1ibmFpbC1pdGVtXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi90aHVtYm5haWwtaXRlbS5jb21wb25lbnQuaHRtbFwiLFxuICAgIHN0eWxlVXJsczogW1wiLi90aHVtYm5haWwtaXRlbS5jb21wb25lbnQuc2Nzc1wiXSxcbn0pXG5leHBvcnQgY2xhc3MgVGh1bWJuYWlsSXRlbUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCB7XG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaXRlbURhdGE6IFRodW1ibmFpbHNJdGVtO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaXNDaGVja2FibGUgPSB0cnVlO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgaXNDaGVja2VkID0gZmFsc2U7XG5cbiAgICBAT3V0cHV0KClcbiAgICBwdWJsaWMgY2hlY2tlZCA9IG5ldyBFdmVudEVtaXR0ZXI8e2l0ZW06IFRodW1ibmFpbHNJdGVtLCBjaGVja2VkOiBib29sZWFufT4oKTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBvcGVuZWQgPSBuZXcgRXZlbnRFbWl0dGVyPFRodW1ibmFpbHNJdGVtPigpO1xuXG4gICAgcHVibGljIGNoZWNrYm94Rm9ybUdyb3VwOiBGb3JtR3JvdXA7XG5cbiAgICBwdWJsaWMgbmdPbkluaXQoKTogdm9pZCB7XG4gICAgICAgIHRoaXMuX3ZhbGlkYXRlSXRlbURhdGEoKTtcbiAgICAgICAgdGhpcy5fY3JlYXRlRm9ybUdyb3VwKCk7XG4gICAgfVxuXG4gICAgcHVibGljIG9uQ2xpY2soKSB7XG4gICAgICAgIHRoaXMub3BlbmVkLmVtaXQodGhpcy5pdGVtRGF0YSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfY3JlYXRlRm9ybUdyb3VwKCk6IHZvaWQge1xuICAgICAgICB0aGlzLmNoZWNrYm94Rm9ybUdyb3VwID0gbmV3IEZvcm1Hcm91cCh7XG4gICAgICAgICAgICBjaGVja2JveDogbmV3IEZvcm1Db250cm9sKHsgY2hlY2tlZDogdGhpcy5pc0NoZWNrZWQgfSksXG4gICAgICAgIH0pO1xuXG4gICAgICAgIHRoaXMuY2hlY2tib3hGb3JtR3JvdXAuZ2V0KFwiY2hlY2tib3hcIikudmFsdWVDaGFuZ2VzLnN1YnNjcmliZSgodmFsdWU6IENoZWNrYm94U3RhdGUpID0+IHtcbiAgICAgICAgICAgIHRoaXMuY2hlY2tlZC5lbWl0KHsgaXRlbTogdGhpcy5pdGVtRGF0YSwgY2hlY2tlZDogdmFsdWUuY2hlY2tlZCB9KTtcbiAgICAgICAgfSk7XG4gICAgfVxuXG4gICAgcHJpdmF0ZSBfdmFsaWRhdGVJdGVtRGF0YSgpOiB2b2lkIHtcbiAgICAgICAgaWYgKGlzTnVsbE9yVW5kZWZpbmVkKHRoaXMuaXRlbURhdGEpKSB7XG4gICAgICAgICAgICB0aHJvdyBuZXcgRXJyb3IoXCJpdGVtRGF0YSBpcyByZXF1aXJlZFwiKTtcbiAgICAgICAgfVxuICAgIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export { ThumbnailsComponent } from "./thumbnails.component";
|
|
2
|
+
export { ThumbnailsModule } from "./thumbnails.module";
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90aHVtYm5haWxzL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQzdELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IHsgVGh1bWJuYWlsc0NvbXBvbmVudCB9IGZyb20gXCIuL3RodW1ibmFpbHMuY29tcG9uZW50XCI7XG5leHBvcnQgeyBUaHVtYm5haWxzTW9kdWxlIH0gZnJvbSBcIi4vdGh1bWJuYWlscy5tb2R1bGVcIjtcblxuZXhwb3J0IHsgVGh1bWJuYWlsc0l0ZW0gfSBmcm9tIFwiLi9tb2RlbHMvdGh1bWJuYWlscy1pdGVtXCI7XG4iXX0=
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlscy1pdGVtLmpzIiwic291cmNlUm9vdCI6Im5nOi8vQHNlbmlvcnNpc3RlbWFzL2FuZ3VsYXItY29tcG9uZW50cy8iLCJzb3VyY2VzIjpbImNvbXBvbmVudHMvdGh1bWJuYWlscy9tb2RlbHMvdGh1bWJuYWlscy1pdGVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgdHlwZSBCYXNlVGh1bWJuYWlsc0l0ZW0gPSB7XG4gICAgaWQ6IHN0cmluZztcbiAgICBmaWxlTmFtZTogc3RyaW5nO1xufTtcblxuZXhwb3J0IHR5cGUgVmlkZW9UaHVtYm5haWxzSXRlbSA9IEJhc2VUaHVtYm5haWxzSXRlbSAmIHtcbiAgICB0eXBlOiBcInZpZGVvXCI7XG4gICAgaW1hZ2VVcmw/OiBzdHJpbmc7XG4gICAgdmlkZW9Vcmw/OiBzdHJpbmc7XG59O1xuXG5leHBvcnQgdHlwZSBJbWFnZVRodW1ibmFpbHNJdGVtID0gQmFzZVRodW1ibmFpbHNJdGVtICYge1xuICAgIHR5cGU6IFwiaW1hZ2VcIjtcbiAgICBpbWFnZVVybD86IHN0cmluZztcbn07XG5cbmV4cG9ydCB0eXBlIEF1ZGlvVGh1bWJuYWlsc0l0ZW0gPSBCYXNlVGh1bWJuYWlsc0l0ZW0gJiB7XG4gICAgdHlwZTogXCJhdWRpb1wiO1xufTtcblxuZXhwb3J0IHR5cGUgRmlsZVRodW1ibmFpbHNJdGVtID0gQmFzZVRodW1ibmFpbHNJdGVtICYge1xuICAgIHR5cGU6IFwiZmlsZVwiO1xufTtcblxuZXhwb3J0IHR5cGUgVGh1bWJuYWlsc0l0ZW0gPSBWaWRlb1RodW1ibmFpbHNJdGVtIHwgSW1hZ2VUaHVtYm5haWxzSXRlbSB8IEF1ZGlvVGh1bWJuYWlsc0l0ZW0gfCBGaWxlVGh1bWJuYWlsc0l0ZW07XG4iXX0=
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import { __decorate, __read, __spread } from "tslib";
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from "@angular/core";
|
|
3
|
+
var ThumbnailsComponent = /** @class */ (function () {
|
|
4
|
+
function ThumbnailsComponent() {
|
|
5
|
+
this.selectable = true;
|
|
6
|
+
this.selectionChange = new EventEmitter();
|
|
7
|
+
this.itemOpened = new EventEmitter();
|
|
8
|
+
this._selection = [];
|
|
9
|
+
}
|
|
10
|
+
Object.defineProperty(ThumbnailsComponent.prototype, "selection", {
|
|
11
|
+
set: function (items) {
|
|
12
|
+
this._selection = __spread(items);
|
|
13
|
+
},
|
|
14
|
+
enumerable: true,
|
|
15
|
+
configurable: true
|
|
16
|
+
});
|
|
17
|
+
ThumbnailsComponent.prototype.onItemOpened = function (item) {
|
|
18
|
+
this.itemOpened.emit(item);
|
|
19
|
+
};
|
|
20
|
+
ThumbnailsComponent.prototype.onItemSelected = function (items) {
|
|
21
|
+
if (items.selected) {
|
|
22
|
+
this._selection.push(items.item);
|
|
23
|
+
}
|
|
24
|
+
else {
|
|
25
|
+
this._selection.splice(this._selection.findIndex(function (item) { return item === items.item; }), 1);
|
|
26
|
+
}
|
|
27
|
+
this.selectionChange.emit(this._selection);
|
|
28
|
+
};
|
|
29
|
+
ThumbnailsComponent.prototype.isSelected = function (item) {
|
|
30
|
+
return this._selection.some(function (i) { return i.id === item.id; });
|
|
31
|
+
};
|
|
32
|
+
__decorate([
|
|
33
|
+
Input()
|
|
34
|
+
], ThumbnailsComponent.prototype, "items", void 0);
|
|
35
|
+
__decorate([
|
|
36
|
+
Input()
|
|
37
|
+
], ThumbnailsComponent.prototype, "selectable", void 0);
|
|
38
|
+
__decorate([
|
|
39
|
+
Input()
|
|
40
|
+
], ThumbnailsComponent.prototype, "selection", null);
|
|
41
|
+
__decorate([
|
|
42
|
+
Output()
|
|
43
|
+
], ThumbnailsComponent.prototype, "selectionChange", void 0);
|
|
44
|
+
__decorate([
|
|
45
|
+
Output()
|
|
46
|
+
], ThumbnailsComponent.prototype, "itemOpened", void 0);
|
|
47
|
+
ThumbnailsComponent = __decorate([
|
|
48
|
+
Component({
|
|
49
|
+
selector: "s-thumbnails",
|
|
50
|
+
template: "<div class=\"thumbnails\">\n <s-thumbnail-item\n *ngFor=\"let item of items\"\n [itemData]=\"item\"\n [isCheckable]=\"selectable\"\n [isChecked]=\"isSelected(item)\"\n (checked)=\"onItemSelected($event)\"\n (opened)=\"onItemOpened($event)\">\n </s-thumbnail-item>\n</div>\n",
|
|
51
|
+
styles: [".thumbnails{display:-ms-flexbox;display:flex;-ms-flex-wrap:wrap;flex-wrap:wrap;gap:12px}"]
|
|
52
|
+
})
|
|
53
|
+
], ThumbnailsComponent);
|
|
54
|
+
return ThumbnailsComponent;
|
|
55
|
+
}());
|
|
56
|
+
export { ThumbnailsComponent };
|
|
57
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlscy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90aHVtYm5haWxzL3RodW1ibmFpbHMuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLFlBQVksRUFBRSxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBU3ZFO0lBQUE7UUFLVyxlQUFVLEdBQUcsSUFBSSxDQUFDO1FBUWxCLG9CQUFlLEdBQUcsSUFBSSxZQUFZLEVBQW9CLENBQUM7UUFHdkQsZUFBVSxHQUFHLElBQUksWUFBWSxFQUFrQixDQUFDO1FBRS9DLGVBQVUsR0FBcUIsRUFBRSxDQUFDO0lBc0I5QyxDQUFDO0lBaENHLHNCQUFXLDBDQUFTO2FBQXBCLFVBQXFCLEtBQXVCO1lBQ3hDLElBQUksQ0FBQyxVQUFVLFlBQU8sS0FBSyxDQUFDLENBQUM7UUFDakMsQ0FBQzs7O09BQUE7SUFVTSwwQ0FBWSxHQUFuQixVQUFvQixJQUFvQjtRQUNwQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUMvQixDQUFDO0lBRU0sNENBQWMsR0FBckIsVUFBc0IsS0FBa0Q7UUFDcEUsSUFBSSxLQUFLLENBQUMsUUFBUSxFQUFFO1lBQ2hCLElBQUksQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQztTQUNwQzthQUFNO1lBQ0gsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQ2xCLElBQUksQ0FBQyxVQUFVLENBQUMsU0FBUyxDQUFDLFVBQUMsSUFBSSxJQUFLLE9BQUEsSUFBSSxLQUFLLEtBQUssQ0FBQyxJQUFJLEVBQW5CLENBQW1CLENBQUMsRUFDeEQsQ0FBQyxDQUNKLENBQUM7U0FDTDtRQUVELElBQUksQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsQ0FBQztJQUMvQyxDQUFDO0lBRU0sd0NBQVUsR0FBakIsVUFBa0IsSUFBb0I7UUFDbEMsT0FBTyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxVQUFDLENBQWlCLElBQUssT0FBQSxDQUFDLENBQUMsRUFBRSxLQUFLLElBQUksQ0FBQyxFQUFFLEVBQWhCLENBQWdCLENBQUMsQ0FBQztJQUN6RSxDQUFDO0lBckNEO1FBREMsS0FBSyxFQUFFO3NEQUN1QjtJQUcvQjtRQURDLEtBQUssRUFBRTsyREFDaUI7SUFHekI7UUFEQyxLQUFLLEVBQUU7d0RBR1A7SUFHRDtRQURDLE1BQU0sRUFBRTtnRUFDcUQ7SUFHOUQ7UUFEQyxNQUFNLEVBQUU7MkRBQzhDO0lBaEI5QyxtQkFBbUI7UUFML0IsU0FBUyxDQUFDO1lBQ1AsUUFBUSxFQUFFLGNBQWM7WUFDeEIsNlVBQTBDOztTQUU3QyxDQUFDO09BQ1csbUJBQW1CLENBd0MvQjtJQUFELDBCQUFDO0NBQUEsQUF4Q0QsSUF3Q0M7U0F4Q1ksbUJBQW1CIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPdXRwdXQgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuXG5pbXBvcnQgeyBUaHVtYm5haWxzSXRlbSB9IGZyb20gXCIuL21vZGVscy90aHVtYm5haWxzLWl0ZW1cIjtcblxuQENvbXBvbmVudCh7XG4gICAgc2VsZWN0b3I6IFwicy10aHVtYm5haWxzXCIsXG4gICAgdGVtcGxhdGVVcmw6IFwiLi90aHVtYm5haWxzLmNvbXBvbmVudC5odG1sXCIsXG4gICAgc3R5bGVVcmxzOiBbXCIuL3RodW1ibmFpbHMuY29tcG9uZW50LnNjc3NcIl0sXG59KVxuZXhwb3J0IGNsYXNzIFRodW1ibmFpbHNDb21wb25lbnQge1xuICAgIEBJbnB1dCgpXG4gICAgcHVibGljIGl0ZW1zOiBUaHVtYm5haWxzSXRlbVtdO1xuXG4gICAgQElucHV0KClcbiAgICBwdWJsaWMgc2VsZWN0YWJsZSA9IHRydWU7XG5cbiAgICBASW5wdXQoKVxuICAgIHB1YmxpYyBzZXQgc2VsZWN0aW9uKGl0ZW1zOiBUaHVtYm5haWxzSXRlbVtdKSB7XG4gICAgICAgIHRoaXMuX3NlbGVjdGlvbiA9IFsuLi5pdGVtc107XG4gICAgfVxuXG4gICAgQE91dHB1dCgpXG4gICAgcHVibGljIHNlbGVjdGlvbkNoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8VGh1bWJuYWlsc0l0ZW1bXT4oKTtcblxuICAgIEBPdXRwdXQoKVxuICAgIHB1YmxpYyBpdGVtT3BlbmVkID0gbmV3IEV2ZW50RW1pdHRlcjxUaHVtYm5haWxzSXRlbT4oKTtcblxuICAgIHByaXZhdGUgX3NlbGVjdGlvbjogVGh1bWJuYWlsc0l0ZW1bXSA9IFtdO1xuXG4gICAgcHVibGljIG9uSXRlbU9wZW5lZChpdGVtOiBUaHVtYm5haWxzSXRlbSk6IHZvaWQge1xuICAgICAgICB0aGlzLml0ZW1PcGVuZWQuZW1pdChpdGVtKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgb25JdGVtU2VsZWN0ZWQoaXRlbXM6IHsgaXRlbTogVGh1bWJuYWlsc0l0ZW07IHNlbGVjdGVkOiBib29sZWFuIH0pOiB2b2lkIHtcbiAgICAgICAgaWYgKGl0ZW1zLnNlbGVjdGVkKSB7XG4gICAgICAgICAgICB0aGlzLl9zZWxlY3Rpb24ucHVzaChpdGVtcy5pdGVtKTtcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICAgIHRoaXMuX3NlbGVjdGlvbi5zcGxpY2UoXG4gICAgICAgICAgICAgICAgdGhpcy5fc2VsZWN0aW9uLmZpbmRJbmRleCgoaXRlbSkgPT4gaXRlbSA9PT0gaXRlbXMuaXRlbSksXG4gICAgICAgICAgICAgICAgMVxuICAgICAgICAgICAgKTtcbiAgICAgICAgfVxuXG4gICAgICAgIHRoaXMuc2VsZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5fc2VsZWN0aW9uKTtcbiAgICB9XG5cbiAgICBwdWJsaWMgaXNTZWxlY3RlZChpdGVtOiBUaHVtYm5haWxzSXRlbSkge1xuICAgICAgICByZXR1cm4gdGhpcy5fc2VsZWN0aW9uLnNvbWUoKGk6IFRodW1ibmFpbHNJdGVtKSA9PiBpLmlkID09PSBpdGVtLmlkKTtcbiAgICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
import { __decorate } from "tslib";
|
|
2
|
+
import { NgModule } from "@angular/core";
|
|
3
|
+
import { CommonModule } from "@angular/common";
|
|
4
|
+
import { ReactiveFormsModule } from "@angular/forms";
|
|
5
|
+
import { TranslateModule } from "@ngx-translate/core";
|
|
6
|
+
import { CheckboxModule } from "../checkbox/checkbox.module";
|
|
7
|
+
import { ThumbnailItemComponent } from "./components/thumbnail-item/thumbnail-item.component";
|
|
8
|
+
import { ThumbnailItemVideoComponent } from "./components/thumbnail-item/components/thumbnail-item-video/thumbnail-item-video.component";
|
|
9
|
+
import { ThumbnailItemImageComponent } from "./components/thumbnail-item/components/thumbnail-item-image/thumbnail-item-image.component";
|
|
10
|
+
import { ThumbnailsComponent } from "./thumbnails.component";
|
|
11
|
+
var ThumbnailsModule = /** @class */ (function () {
|
|
12
|
+
function ThumbnailsModule() {
|
|
13
|
+
}
|
|
14
|
+
ThumbnailsModule = __decorate([
|
|
15
|
+
NgModule({
|
|
16
|
+
imports: [CommonModule, ReactiveFormsModule, TranslateModule, CheckboxModule],
|
|
17
|
+
declarations: [ThumbnailsComponent, ThumbnailItemComponent, ThumbnailItemVideoComponent, ThumbnailItemImageComponent],
|
|
18
|
+
exports: [ThumbnailsComponent],
|
|
19
|
+
})
|
|
20
|
+
], ThumbnailsModule);
|
|
21
|
+
return ThumbnailsModule;
|
|
22
|
+
}());
|
|
23
|
+
export { ThumbnailsModule };
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGh1bWJuYWlscy5tb2R1bGUuanMiLCJzb3VyY2VSb290Ijoibmc6Ly9Ac2VuaW9yc2lzdGVtYXMvYW5ndWxhci1jb21wb25lbnRzLyIsInNvdXJjZXMiOlsiY29tcG9uZW50cy90aHVtYm5haWxzL3RodW1ibmFpbHMubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUVyRCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFFdEQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQzdELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLHNEQUFzRCxDQUFDO0FBQzlGLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDRGQUE0RixDQUFDO0FBQ3pJLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDRGQUE0RixDQUFDO0FBQ3pJLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBTzdEO0lBQUE7SUFBK0IsQ0FBQztJQUFuQixnQkFBZ0I7UUFMNUIsUUFBUSxDQUFDO1lBQ04sT0FBTyxFQUFFLENBQUMsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGVBQWUsRUFBRSxjQUFjLENBQUM7WUFDN0UsWUFBWSxFQUFFLENBQUMsbUJBQW1CLEVBQUUsc0JBQXNCLEVBQUUsMkJBQTJCLEVBQUUsMkJBQTJCLENBQUM7WUFDckgsT0FBTyxFQUFFLENBQUMsbUJBQW1CLENBQUM7U0FDakMsQ0FBQztPQUNXLGdCQUFnQixDQUFHO0lBQUQsdUJBQUM7Q0FBQSxBQUFoQyxJQUFnQztTQUFuQixnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29tbW9uXCI7XG5pbXBvcnQgeyBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSBcIkBhbmd1bGFyL2Zvcm1zXCI7XG5cbmltcG9ydCB7IFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gXCJAbmd4LXRyYW5zbGF0ZS9jb3JlXCI7XG5cbmltcG9ydCB7IENoZWNrYm94TW9kdWxlIH0gZnJvbSBcIi4uL2NoZWNrYm94L2NoZWNrYm94Lm1vZHVsZVwiO1xuaW1wb3J0IHsgVGh1bWJuYWlsSXRlbUNvbXBvbmVudCB9IGZyb20gXCIuL2NvbXBvbmVudHMvdGh1bWJuYWlsLWl0ZW0vdGh1bWJuYWlsLWl0ZW0uY29tcG9uZW50XCI7XG5pbXBvcnQgeyBUaHVtYm5haWxJdGVtVmlkZW9Db21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRzL3RodW1ibmFpbC1pdGVtL2NvbXBvbmVudHMvdGh1bWJuYWlsLWl0ZW0tdmlkZW8vdGh1bWJuYWlsLWl0ZW0tdmlkZW8uY29tcG9uZW50XCI7XG5pbXBvcnQgeyBUaHVtYm5haWxJdGVtSW1hZ2VDb21wb25lbnQgfSBmcm9tIFwiLi9jb21wb25lbnRzL3RodW1ibmFpbC1pdGVtL2NvbXBvbmVudHMvdGh1bWJuYWlsLWl0ZW0taW1hZ2UvdGh1bWJuYWlsLWl0ZW0taW1hZ2UuY29tcG9uZW50XCI7XG5pbXBvcnQgeyBUaHVtYm5haWxzQ29tcG9uZW50IH0gZnJvbSBcIi4vdGh1bWJuYWlscy5jb21wb25lbnRcIjtcblxuQE5nTW9kdWxlKHtcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlLCBUcmFuc2xhdGVNb2R1bGUsIENoZWNrYm94TW9kdWxlXSxcbiAgICBkZWNsYXJhdGlvbnM6IFtUaHVtYm5haWxzQ29tcG9uZW50LCBUaHVtYm5haWxJdGVtQ29tcG9uZW50LCBUaHVtYm5haWxJdGVtVmlkZW9Db21wb25lbnQsIFRodW1ibmFpbEl0ZW1JbWFnZUNvbXBvbmVudF0sXG4gICAgZXhwb3J0czogW1RodW1ibmFpbHNDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBUaHVtYm5haWxzTW9kdWxlIHt9XG4iXX0=
|
|
@@ -1,4 +1,5 @@
|
|
|
1
1
|
import { __decorate, __values } from "tslib";
|
|
2
|
+
import { isNullOrUndefined } from './../utils/utils';
|
|
2
3
|
import { ApplicationRef, ComponentFactoryResolver, ComponentRef, Directive, ElementRef, EmbeddedViewRef, HostListener, Injector, Input, OnDestroy, OnInit, Renderer2, } from "@angular/core";
|
|
3
4
|
import { DebounceUtils } from "../utils/debouce";
|
|
4
5
|
import { MobileBehavior, TooltipEvent, TooltipPosition } from "./models";
|
|
@@ -19,8 +20,9 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
19
20
|
this.visible = true;
|
|
20
21
|
this.mobileBehavior = MobileBehavior.Pressing;
|
|
21
22
|
this.componentRef = null;
|
|
23
|
+
this.existFocusedInputRefTooltip = false;
|
|
22
24
|
this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);
|
|
23
|
-
this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(function () { return _this.
|
|
25
|
+
this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(function () { return _this._createTooltip(true, true); });
|
|
24
26
|
}
|
|
25
27
|
TooltipDirective.prototype.ngOnInit = function () {
|
|
26
28
|
this.validatePosition();
|
|
@@ -41,7 +43,7 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
41
43
|
left: Math.min(elementRect.left, toolTipRect.left),
|
|
42
44
|
bottom: Math.max(elementRect.bottom, toolTipRect.bottom),
|
|
43
45
|
};
|
|
44
|
-
if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {
|
|
46
|
+
if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea) && !this.existFocusedInputRefTooltip) {
|
|
45
47
|
this.destroy();
|
|
46
48
|
}
|
|
47
49
|
};
|
|
@@ -56,15 +58,17 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
56
58
|
if (this.focusedInputRef) {
|
|
57
59
|
var inputFocus = this.focusedInputRef;
|
|
58
60
|
var icon_1 = this.getIconFromFocusedInput();
|
|
59
|
-
this.renderer.listen(
|
|
61
|
+
this.renderer.listen(inputFocus, "focus", function () {
|
|
60
62
|
if (icon_1) {
|
|
61
|
-
_this.
|
|
63
|
+
_this.existFocusedInputRefTooltip = true;
|
|
64
|
+
_this._createTooltip(false, false);
|
|
62
65
|
}
|
|
63
66
|
});
|
|
64
67
|
this.renderer.listen(inputFocus, "blur", function () {
|
|
65
68
|
if (icon_1) {
|
|
66
69
|
_this.removeTooltip(icon_1);
|
|
67
70
|
_this.destroy();
|
|
71
|
+
_this.existFocusedInputRefTooltip = false;
|
|
68
72
|
}
|
|
69
73
|
});
|
|
70
74
|
}
|
|
@@ -95,7 +99,7 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
95
99
|
};
|
|
96
100
|
TooltipDirective.prototype.onFocus = function () {
|
|
97
101
|
if (this.tooltipEvent === TooltipEvent.Focus) {
|
|
98
|
-
this.
|
|
102
|
+
this._createTooltip(true, true);
|
|
99
103
|
}
|
|
100
104
|
};
|
|
101
105
|
TooltipDirective.prototype.onBlur = function () {
|
|
@@ -109,14 +113,18 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
109
113
|
}
|
|
110
114
|
};
|
|
111
115
|
TooltipDirective.prototype.onMouseLeave = function () {
|
|
112
|
-
if (this.tooltipEvent === TooltipEvent.Hover) {
|
|
116
|
+
if (this.tooltipEvent === TooltipEvent.Hover && !this.existFocusedInputRefTooltip) {
|
|
113
117
|
this.destroy();
|
|
114
118
|
}
|
|
115
119
|
};
|
|
116
120
|
TooltipDirective.prototype.onTouchStart = function () {
|
|
121
|
+
var _this = this;
|
|
117
122
|
if (this.tooltipEvent === TooltipEvent.Hover) {
|
|
118
123
|
window.clearTimeout(this.touchTimeout);
|
|
119
|
-
|
|
124
|
+
var _delay = this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0;
|
|
125
|
+
this.touchTimeout = window.setTimeout(function () {
|
|
126
|
+
_this._createTooltip(true, true);
|
|
127
|
+
}, _delay);
|
|
120
128
|
}
|
|
121
129
|
};
|
|
122
130
|
TooltipDirective.prototype.onTouchEnd = function () {
|
|
@@ -134,43 +142,37 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
134
142
|
throw new Error("Tooltip " + this.position + " position is unexpected");
|
|
135
143
|
}
|
|
136
144
|
};
|
|
137
|
-
TooltipDirective.prototype.createTootip = function () {
|
|
138
|
-
var _a;
|
|
139
|
-
if (this.componentRef === null && ((_a = this.tooltip) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
140
|
-
var domElem = this.getDomElement();
|
|
141
|
-
document.body.appendChild(domElem);
|
|
142
|
-
this.setTooltipComponentProperties();
|
|
143
|
-
this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);
|
|
144
|
-
this.tooltipDivElement = domElem.querySelector(".tooltip");
|
|
145
|
-
if (this.displayTime) {
|
|
146
|
-
window.setTimeout(this.destroy.bind(this), this.displayTime);
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
};
|
|
150
145
|
TooltipDirective.prototype.getDomElement = function () {
|
|
151
146
|
var componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);
|
|
152
147
|
this.componentRef = componentFactory.create(this.injector);
|
|
153
148
|
this.appRef.attachView(this.componentRef.hostView);
|
|
154
149
|
return this.componentRef.hostView.rootNodes[0];
|
|
155
150
|
};
|
|
156
|
-
|
|
157
|
-
* Cria um tooltip para o icone do input em focus.
|
|
158
|
-
*
|
|
159
|
-
* @param icon O ícone do input em focus.
|
|
160
|
-
*/
|
|
161
|
-
TooltipDirective.prototype.createTootipByFocus = function (icon) {
|
|
151
|
+
TooltipDirective.prototype._createTooltip = function (useShowDelay, autoDestroy) {
|
|
162
152
|
var _this = this;
|
|
153
|
+
if (useShowDelay === void 0) { useShowDelay = false; }
|
|
154
|
+
if (autoDestroy === void 0) { autoDestroy = true; }
|
|
163
155
|
var _a;
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
156
|
+
var hasText = ((_a = this.tooltip) === null || _a === void 0 ? void 0 : _a.length) > 0;
|
|
157
|
+
var hasComponentRef = this.componentRef !== null;
|
|
158
|
+
if (!hasText || hasComponentRef) {
|
|
159
|
+
return;
|
|
160
|
+
}
|
|
161
|
+
var domElement = this.getDomElement();
|
|
162
|
+
document.body.appendChild(domElement);
|
|
163
|
+
this.tooltipDivElement = domElement.querySelector(".tooltip");
|
|
164
|
+
this.setTooltipComponentProperties();
|
|
165
|
+
var _showDelay = useShowDelay ? this.showDelay : 0;
|
|
166
|
+
setTimeout(function () {
|
|
167
|
+
_this.showTooltip();
|
|
168
|
+
}, _showDelay);
|
|
169
|
+
this.renderer.listen(window, "scroll", function () {
|
|
170
|
+
_this.setTooltipPositionProperty();
|
|
171
|
+
});
|
|
172
|
+
if (autoDestroy && this.displayTime) {
|
|
173
|
+
setTimeout(function () {
|
|
174
|
+
_this.destroy();
|
|
175
|
+
}, this.displayTime);
|
|
174
176
|
}
|
|
175
177
|
};
|
|
176
178
|
TooltipDirective.prototype.showTooltip = function () {
|
|
@@ -180,11 +182,14 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
180
182
|
window.addEventListener("mousemove", this.boundOnWindowMouseMoveFunction);
|
|
181
183
|
}
|
|
182
184
|
};
|
|
183
|
-
TooltipDirective.prototype.setTooltipPositionProperty = function (
|
|
185
|
+
TooltipDirective.prototype.setTooltipPositionProperty = function () {
|
|
184
186
|
var e_1, _a;
|
|
187
|
+
if (!this.componentRef) {
|
|
188
|
+
return;
|
|
189
|
+
}
|
|
185
190
|
var margin = 20;
|
|
186
191
|
var anchorSize = 5;
|
|
187
|
-
var domElem =
|
|
192
|
+
var domElem = this.componentRef.hostView.rootNodes[0].querySelector("#tooltip");
|
|
188
193
|
var _b = domElem.getBoundingClientRect(), height = _b.height, width = _b.width;
|
|
189
194
|
var _c = this.elementRef.nativeElement.getBoundingClientRect(), left = _c.left, right = _c.right, top = _c.top, bottom = _c.bottom;
|
|
190
195
|
var positions = [
|
|
@@ -244,7 +249,7 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
244
249
|
}
|
|
245
250
|
};
|
|
246
251
|
TooltipDirective.prototype.destroy = function () {
|
|
247
|
-
if (this.componentRef
|
|
252
|
+
if (!isNullOrUndefined(this.componentRef)) {
|
|
248
253
|
window.clearTimeout(this.showTimeout);
|
|
249
254
|
this.appRef.detachView(this.componentRef.hostView);
|
|
250
255
|
this.componentRef.destroy();
|
|
@@ -319,4 +324,4 @@ var TooltipDirective = /** @class */ (function () {
|
|
|
319
324
|
return TooltipDirective;
|
|
320
325
|
}());
|
|
321
326
|
export { TooltipDirective };
|
|
322
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    ApplicationRef,\n    ComponentFactoryResolver,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    EmbeddedViewRef,\n    HostListener,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Renderer2,\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n    selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n    @Input(\"sTooltip\")\n    public tooltip: string;\n\n    @Input(\"tooltipPosition\")\n    public position: TooltipPosition = TooltipPosition.Top;\n\n    @Input()\n    public showDelay = 500;\n\n    @Input()\n    public displayTime: number;\n\n    @Input()\n    public tooltipEvent = TooltipEvent.Hover;\n\n    @Input()\n    public escape = false;\n\n    @Input()\n    public visible = true;\n\n    @Input()\n    public mobileBehavior = MobileBehavior.Pressing;\n\n    @Input()\n    public focusedInputRef: HTMLInputElement;\n\n    private componentRef: ComponentRef<any> = null;\n    private showTimeout?: number;\n    private touchTimeout?: number;\n    private tooltipDivElement?: HTMLElement;\n    private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n    private readonly debounceCreateTooltipFunction: () => void;\n\n    constructor(\n        private readonly elementRef: ElementRef,\n        private readonly appRef: ApplicationRef,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n        private readonly injector: Injector,\n        private readonly debounceUtils: DebounceUtils,\n        private readonly renderer: Renderer2\n    ) {\n        this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n        this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this.createTootip());\n    }\n\n    public ngOnInit(): void {\n        this.validatePosition();\n        this.updateTooltipVisibilityWhenFocusOnInput();\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy();\n    }\n\n    private onWindowMouseMove(event: MouseEvent) {\n        if (!this.componentRef) {\n            return;\n        }\n        const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n        const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n        const totalElementArea = {\n            top: Math.min(elementRect.top, toolTipRect.top),\n            right: Math.max(elementRect.right, toolTipRect.right),\n            left: Math.min(elementRect.left, toolTipRect.left),\n            bottom: Math.max(elementRect.bottom, toolTipRect.bottom),\n        };\n\n        if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea)) {\n            this.destroy();\n        }\n    }\n\n    private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n        return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n    }\n\n    /**\n     * Manipula a visibilidade do tooltip quando houver uma referência de input.\n     */\n    private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const inputFocus = this.focusedInputRef;\n            const icon = this.getIconFromFocusedInput();\n\n            this.renderer.listen(this.focusedInputRef, \"focus\", () => {\n                if (icon) {\n                    this.createTootipByFocus(icon);\n                }\n            });\n            this.renderer.listen(inputFocus, \"blur\", () => {\n                if (icon) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @returns O ícone do input em focus.\n     */\n    private getIconFromFocusedInput(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector(\".tooltip\") as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n    // whenever the component with the tooltip is clicked I destroy the tooltip.\n    // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n    @HostListener(\"click\")\n    @HostListener(\"keydown\")\n    public onClick(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover && !navigator.userAgent.match(/Android/i) && !navigator.userAgent.match(/iPhone/i)) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"focus\")\n    public onFocus(): void {\n        if (this.tooltipEvent === TooltipEvent.Focus) {\n            this.createTootip();\n        }\n    }\n\n    @HostListener(\"blur\")\n    public onBlur(): void {\n        if (this.tooltipEvent === TooltipEvent.Focus) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"mouseenter\")\n    public onMouseEnter(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            this.debounceCreateTooltipFunction();\n        }\n    }\n\n    @HostListener(\"mouseleave\")\n    @HostListener(\"wheel\")\n    public onMouseLeave(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"touchstart\")\n    public onTouchStart(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            window.clearTimeout(this.touchTimeout);\n            this.touchTimeout = window.setTimeout(\n                this.createTootip.bind(this),\n                this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n            );\n        }\n    }\n\n    @HostListener(\"touchend\")\n    public onTouchEnd(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            if (this.mobileBehavior === MobileBehavior.Pressing) {\n                window.clearTimeout(this.touchTimeout);\n                this.destroy();\n            }\n        }\n    }\n\n    private validatePosition() {\n        const containsPosition = [TooltipPosition.Top, TooltipPosition.Right, TooltipPosition.Bottom, TooltipPosition.Left].includes(\n            this.position\n        );\n\n        if (!containsPosition) {\n            this.position = TooltipPosition.Top;\n            throw new Error(`Tooltip ${this.position} position is unexpected`);\n        }\n    }\n\n    private createTootip() {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            document.body.appendChild(domElem);\n            this.setTooltipComponentProperties();\n            this.showTimeout = window.setTimeout(this.showTooltip.bind(this), this.showDelay);\n\n            this.tooltipDivElement = domElem.querySelector(\".tooltip\");\n\n            if (this.displayTime) {\n                window.setTimeout(this.destroy.bind(this), this.displayTime);\n            }\n        }\n    }\n\n    private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    }\n\n    /**\n     * Cria um tooltip para o icone do input em focus.\n     *\n     * @param icon O ícone do input em focus.\n     */\n    private createTootipByFocus(icon: HTMLElement) {\n        if (this.componentRef === null && this.tooltip?.length) {\n            const domElem = this.getDomElement();\n            const tooltip = domElem.querySelector(\".tooltip\") as HTMLElement;\n            icon.appendChild(tooltip);\n            this.setTooltipComponentProperties();\n            this.setTooltipPositionProperty(icon);\n\n            setTimeout(() => tooltip.classList.add(\"tooltip--visible\"), 0);\n            this.renderer.listen(window, \"scroll\", () => {\n                this.setTooltipPositionProperty(icon);\n            });\n        }\n    }\n\n    private showTooltip() {\n        if (this.componentRef !== null) {\n            this.componentRef.instance.visible = this.visible;\n\n            this.setTooltipPositionProperty();\n\n            window.addEventListener(\"mousemove\", this.boundOnWindowMouseMoveFunction);\n        }\n    }\n\n    private setTooltipPositionProperty(element?: HTMLElement) {\n        const margin = 20;\n        const anchorSize = 5;\n\n        const domElem = element || ((this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement).querySelector(\"#tooltip\");\n        const { height, width } = domElem.getBoundingClientRect();\n        const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n        const positions = [\n            {\n                pos: TooltipPosition.Top,\n                check: () => top > height,\n                set: () => ({ left: left + (right - left) / 2, top: top - margin - anchorSize }),\n            },\n            {\n                pos: TooltipPosition.Bottom,\n                check: () => document.body.clientHeight - bottom > height,\n                set: () => ({ left: left + (right - left) / 2, top: bottom + margin }),\n            },\n            {\n                pos: TooltipPosition.Left,\n                check: () => left > width,\n                set: () => ({ left: left - margin, top: top + height / 2 - anchorSize }),\n            },\n            {\n                pos: TooltipPosition.Right,\n                check: () => document.body.clientWidth - right > width,\n                set: () => ({ left: right + margin, top: top + height / 2 - anchorSize }),\n            },\n        ];\n\n        if(this.componentRef) {\n            for (const { pos, check, set } of positions) {\n                if (check()) {\n                    this.position = pos;\n                    const { left, top } = set();\n                    this.componentRef.instance.left = Math.round(left);\n                    this.componentRef.instance.top = Math.round(top);\n                    this.componentRef.instance.position = this.position;\n                    return;\n                }\n            }\n\n            // Se não conseguir posicionar, mostrar abaixo\n            this.position = TooltipPosition.Bottom;\n            this.componentRef.instance.left = Math.round(left + (right - left) / 2);\n            this.componentRef.instance.top = Math.round(bottom + margin);\n            this.componentRef.instance.position = this.position;\n        }\n    }\n\n    private setTooltipComponentProperties() {\n        if (this.componentRef !== null) {\n            this.componentRef.instance.tooltip = this.tooltip;\n            this.componentRef.instance.escape = this.escape;\n        }\n    }\n\n    private destroy(): void {\n        if (this.componentRef !== null) {\n            window.clearTimeout(this.showTimeout);\n            this.appRef.detachView(this.componentRef.hostView);\n            this.componentRef.destroy();\n            this.componentRef = null;\n            this.tooltipDivElement = null;\n        }\n\n        window.removeEventListener(\"mousemove\", this.boundOnWindowMouseMoveFunction);\n    }\n}\n"]}
|
|
327
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.directive.js","sourceRoot":"ng://@seniorsistemas/angular-components/","sources":["components/tooltip/tooltip.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { isNullOrUndefined } from './../utils/utils';\nimport {\n    ApplicationRef,\n    ComponentFactoryResolver,\n    ComponentRef,\n    Directive,\n    ElementRef,\n    EmbeddedViewRef,\n    HostListener,\n    Injector,\n    Input,\n    OnDestroy,\n    OnInit,\n    Renderer2,\n} from \"@angular/core\";\nimport { DebounceUtils } from \"../utils/debouce\";\nimport { MobileBehavior, TooltipEvent, TooltipPosition } from \"./models\";\nimport { TooltipComponent } from \"./tooltip.component\";\nimport { ElementArea } from \"./models/element-area\";\n\n@Directive({\n    selector: \"[sTooltip]\",\n})\nexport class TooltipDirective implements OnInit, OnDestroy {\n    @Input(\"sTooltip\")\n    public tooltip: string;\n\n    @Input(\"tooltipPosition\")\n    public position: TooltipPosition = TooltipPosition.Top;\n\n    @Input()\n    public showDelay = 500;\n\n    @Input()\n    public displayTime: number;\n\n    @Input()\n    public tooltipEvent = TooltipEvent.Hover;\n\n    @Input()\n    public escape = false;\n\n    @Input()\n    public visible = true;\n\n    @Input()\n    public mobileBehavior = MobileBehavior.Pressing;\n\n    @Input()\n    public focusedInputRef: HTMLInputElement;\n\n    private componentRef: ComponentRef<any> = null;\n    private showTimeout?: number;\n    private touchTimeout?: number;\n    private tooltipDivElement?: HTMLElement;\n    private readonly boundOnWindowMouseMoveFunction: (event: MouseEvent) => void;\n    private readonly debounceCreateTooltipFunction: () => void;\n    private existFocusedInputRefTooltip = false;\n\n    constructor(\n        private readonly elementRef: ElementRef,\n        private readonly appRef: ApplicationRef,\n        private readonly componentFactoryResolver: ComponentFactoryResolver,\n        private readonly injector: Injector,\n        private readonly debounceUtils: DebounceUtils,\n        private readonly renderer: Renderer2\n    ) {\n        this.boundOnWindowMouseMoveFunction = this.onWindowMouseMove.bind(this);\n        this.debounceCreateTooltipFunction = this.debounceUtils.debounceLeading(() => this._createTooltip(true, true));\n    }\n\n    public ngOnInit(): void {\n        this.validatePosition();\n        this.updateTooltipVisibilityWhenFocusOnInput();\n    }\n\n    public ngOnDestroy(): void {\n        this.destroy();\n    }\n\n    private onWindowMouseMove(event: MouseEvent) {\n        if (!this.componentRef) {\n            return;\n        }\n        const elementRect = this.elementRef.nativeElement.getBoundingClientRect();\n        const toolTipRect = this.tooltipDivElement.getBoundingClientRect();\n\n        const totalElementArea = {\n            top: Math.min(elementRect.top, toolTipRect.top),\n            right: Math.max(elementRect.right, toolTipRect.right),\n            left: Math.min(elementRect.left, toolTipRect.left),\n            bottom: Math.max(elementRect.bottom, toolTipRect.bottom),\n        };\n\n        if (this.isMousePositionOutsideOfElement(event.clientX, event.clientY, totalElementArea) && !this.existFocusedInputRefTooltip) {\n            this.destroy();\n        }\n    }\n\n    private isMousePositionOutsideOfElement(mouseX: number, mouseY: number, elementArea: ElementArea) {\n        return mouseX < elementArea.left || mouseX >= elementArea.right || mouseY < elementArea.top || mouseY >= elementArea.bottom;\n    }\n\n    /**\n     * Manipula a visibilidade do tooltip quando houver uma referência de input.\n     */\n    private updateTooltipVisibilityWhenFocusOnInput() {\n        if (this.focusedInputRef) {\n            const inputFocus = this.focusedInputRef;\n            const icon = this.getIconFromFocusedInput();\n            this.renderer.listen(inputFocus, \"focus\", () => {\n                if (icon) {\n                    this.existFocusedInputRefTooltip = true;\n                    this._createTooltip(false, false)\n                }\n            });\n            this.renderer.listen(inputFocus, \"blur\", () => {\n                if (icon) {\n                    this.removeTooltip(icon);\n                    this.destroy();\n                    this.existFocusedInputRefTooltip = false;\n                }\n            });\n        }\n    }\n\n    /**\n     * Obtém o elemento do ícone associado ao label do input em focus.\n     * @returns O ícone do input em focus.\n     */\n    private getIconFromFocusedInput(): HTMLElement {\n        return this.elementRef.nativeElement;\n    }\n\n    /**\n     * Remove o tooltip associado ao ícone do input em focus.\n     * @param icon O ícone do input em focus.\n     */\n    private removeTooltip(icon: HTMLElement): void {\n        const tooltip = icon.querySelector(\".tooltip\") as HTMLElement;\n        if (tooltip) {\n            tooltip.remove();\n        }\n    }\n\n    // whenever the component with the tooltip is clicked I destroy the tooltip.\n    // whenever a key is pressed on the component with the tooltip I destroy the tooltip.\n    @HostListener(\"click\")\n    @HostListener(\"keydown\")\n    public onClick(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover && !navigator.userAgent.match(/Android/i) && !navigator.userAgent.match(/iPhone/i)) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"focus\")\n    public onFocus(): void {\n        if (this.tooltipEvent === TooltipEvent.Focus) {\n            this._createTooltip(true, true)\n        }\n    }\n\n    @HostListener(\"blur\")\n    public onBlur(): void {\n        if (this.tooltipEvent === TooltipEvent.Focus) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"mouseenter\")\n    public onMouseEnter(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            this.debounceCreateTooltipFunction();\n        }\n    }\n\n    @HostListener(\"mouseleave\")\n    @HostListener(\"wheel\")\n    public onMouseLeave(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover && !this.existFocusedInputRefTooltip) {\n            this.destroy();\n        }\n    }\n\n    @HostListener(\"touchstart\")\n    public onTouchStart(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            window.clearTimeout(this.touchTimeout);\n            const _delay = this.mobileBehavior === MobileBehavior.Pressing ? this.showDelay : 0\n            this.touchTimeout = window.setTimeout(() => {\n                this._createTooltip(true, true);\n            }, _delay)\n        }\n    }\n\n    @HostListener(\"touchend\")\n    public onTouchEnd(): void {\n        if (this.tooltipEvent === TooltipEvent.Hover) {\n            if (this.mobileBehavior === MobileBehavior.Pressing) {\n                window.clearTimeout(this.touchTimeout);\n                this.destroy();\n            }\n        }\n    }\n\n    private validatePosition() {\n        const containsPosition = [TooltipPosition.Top, TooltipPosition.Right, TooltipPosition.Bottom, TooltipPosition.Left].includes(\n            this.position\n        );\n\n        if (!containsPosition) {\n            this.position = TooltipPosition.Top;\n            throw new Error(`Tooltip ${this.position} position is unexpected`);\n        }\n    }\n\n    private getDomElement(): HTMLElement {\n        const componentFactory = this.componentFactoryResolver.resolveComponentFactory(TooltipComponent);\n        this.componentRef = componentFactory.create(this.injector);\n        this.appRef.attachView(this.componentRef.hostView);\n        return (this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n    }\n\n    private _createTooltip(useShowDelay = false, autoDestroy = true) {\n        const hasText = this.tooltip?.length > 0;\n        const hasComponentRef = this.componentRef !== null;\n        if (!hasText || hasComponentRef) {\n            return;\n        }\n        const domElement = this.getDomElement();\n        document.body.appendChild(domElement);\n        this.tooltipDivElement = domElement.querySelector(\".tooltip\");\n        this.setTooltipComponentProperties();\n        const _showDelay = useShowDelay ? this.showDelay : 0;\n        setTimeout(() => {\n            this.showTooltip()\n        }, _showDelay)\n\n\n\n        this.renderer.listen(window, \"scroll\", () => {\n            this.setTooltipPositionProperty();\n        });\n\n        if (autoDestroy && this.displayTime) {\n            setTimeout(() => {\n                this.destroy();\n            }, this.displayTime)\n        }\n\n    }\n\n    private showTooltip() {\n        if (this.componentRef !== null) {\n            this.componentRef.instance.visible = this.visible;\n\n            this.setTooltipPositionProperty();\n\n            window.addEventListener(\"mousemove\", this.boundOnWindowMouseMoveFunction);\n        }\n    }\n\n    private setTooltipPositionProperty() {\n        if (!this.componentRef) {\n            return\n        }\n        const margin = 20;\n        const anchorSize = 5;\n        const domElem = ((this.componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement).querySelector(\"#tooltip\");\n        const { height, width } = domElem.getBoundingClientRect();\n        const { left, right, top, bottom } = this.elementRef.nativeElement.getBoundingClientRect();\n\n        const positions = [\n            {\n                pos: TooltipPosition.Top,\n                check: () => top > height,\n                set: () => ({ left: left + (right - left) / 2, top: top - margin - anchorSize }),\n            },\n            {\n                pos: TooltipPosition.Bottom,\n                check: () => document.body.clientHeight - bottom > height,\n                set: () => ({ left: left + (right - left) / 2, top: bottom + margin }),\n            },\n            {\n                pos: TooltipPosition.Left,\n                check: () => left > width,\n                set: () => ({ left: left - margin, top: top + height / 2 - anchorSize }),\n            },\n            {\n                pos: TooltipPosition.Right,\n                check: () => document.body.clientWidth - right > width,\n                set: () => ({ left: right + margin, top: top + height / 2 - anchorSize }),\n            },\n        ];\n\n        if (this.componentRef) {\n            for (const { pos, check, set } of positions) {\n                if (check()) {\n                    this.position = pos;\n                    const { left, top } = set();\n                    this.componentRef.instance.left = Math.round(left);\n                    this.componentRef.instance.top = Math.round(top);\n                    this.componentRef.instance.position = this.position;\n                    return;\n                }\n            }\n\n            // Se não conseguir posicionar, mostrar abaixo\n            this.position = TooltipPosition.Bottom;\n            this.componentRef.instance.left = Math.round(left + (right - left) / 2);\n            this.componentRef.instance.top = Math.round(bottom + margin);\n            this.componentRef.instance.position = this.position;\n        }\n    }\n\n    private setTooltipComponentProperties() {\n        if (this.componentRef !== null) {\n            this.componentRef.instance.tooltip = this.tooltip;\n            this.componentRef.instance.escape = this.escape;\n        }\n    }\n\n    private destroy(): void {\n        if (!isNullOrUndefined(this.componentRef)) {\n            window.clearTimeout(this.showTimeout);\n            this.appRef.detachView(this.componentRef.hostView);\n            this.componentRef.destroy();\n            this.componentRef = null;\n            this.tooltipDivElement = null;\n        }\n\n        window.removeEventListener(\"mousemove\", this.boundOnWindowMouseMoveFunction);\n    }\n}\n"]}
|