@datarailsshared/datarailsshared 1.5.313 → 1.5.315
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/assets/styles/mixins.scss +11 -8
- package/assets/styles/vars.scss +1 -1
- package/datarailsshared-datarailsshared-1.5.315.tgz +0 -0
- package/esm2022/lib/date-tags/any-tag.component.mjs +4 -6
- package/esm2022/lib/date-tags/date-tag.component.mjs +3 -3
- package/esm2022/lib/date-tags/date-tag.module.mjs +5 -19
- package/esm2022/lib/date-tags/day-tag/day-tag.component.mjs +5 -6
- package/esm2022/lib/date-tags/forecast-tag/forecast-tag.component.mjs +12 -10
- package/esm2022/lib/date-tags/month-tag/month-tag.component.mjs +5 -6
- package/esm2022/lib/date-tags/quarter-tag/quarter-tag.component.mjs +7 -10
- package/esm2022/lib/date-tags/week-tag/week-tag.component.mjs +5 -6
- package/esm2022/lib/date-tags/year-tag/year-tag.component.mjs +5 -6
- package/esm2022/lib/directives/click-outside/click-outside.directive.mjs +2 -2
- package/esm2022/lib/directives/click-outside/click-outside.module.mjs +2 -2
- package/esm2022/lib/dr-accordion/accordion-item-body.component.mjs +2 -2
- package/esm2022/lib/dr-accordion/accordion-item-header.component.mjs +3 -9
- package/esm2022/lib/dr-accordion/accordion-item.component.mjs +2 -2
- package/esm2022/lib/dr-accordion/accordion.module.mjs +1 -1
- package/esm2022/lib/dr-alert/dr-alert.component.mjs +3 -3
- package/esm2022/lib/dr-alert/dr-alert.module.mjs +3 -7
- package/esm2022/lib/dr-alert/enums/dr-alert-theme.enum.mjs +1 -2
- package/esm2022/lib/dr-avatar/dr-avatar.component.mjs +3 -3
- package/esm2022/lib/dr-avatar/dr-avatar.module.mjs +6 -22
- package/esm2022/lib/dr-avatar/dr-avatar.pipe.mjs +4 -4
- package/esm2022/lib/dr-badge-status/dr-badge-status.component.mjs +3 -3
- package/esm2022/lib/dr-badge-status/dr-badge-status.module.mjs +5 -12
- package/esm2022/lib/dr-chat/chat.component.mjs +6 -5
- package/esm2022/lib/dr-chat/chat.module.mjs +4 -21
- package/esm2022/lib/dr-chat/dr-chat-alert/dr-chat-alert.component.mjs +3 -3
- package/esm2022/lib/dr-chat/dr-chat-form/chat-form.component.mjs +1 -1
- package/esm2022/lib/dr-chat/dr-chat-message/chat-message.component.mjs +3 -3
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.directive.mjs +1 -1
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-custom/chat-custom-message.service.mjs +1 -1
- package/esm2022/lib/dr-chat/dr-chat-message/dr-chat-message-file/chat-message-file.component.mjs +2 -2
- package/esm2022/lib/dr-chat/dr-chat-suggestions/chat-suggestions.component.mjs +6 -6
- package/esm2022/lib/dr-chat/dr-dot-flashing/dr-dot-flashing.component.mjs +3 -4
- package/esm2022/lib/dr-code-editor/components/dr-codemirror.component.mjs +23 -25
- package/esm2022/lib/dr-code-editor/dr-code-editor.component.mjs +2 -2
- package/esm2022/lib/dr-code-editor/dr-code-editor.module.mjs +4 -18
- package/esm2022/lib/dr-details-list/dr-details-list.component.mjs +3 -4
- package/esm2022/lib/dr-details-list/dr-details-list.module.mjs +2 -4
- package/esm2022/lib/dr-dialog/components/dialog-modal-wrapper/dialog-modal-wrapper.component.mjs +8 -5
- package/esm2022/lib/dr-dialog/components/dialog-wrapper/dialog-wrapper.component.mjs +8 -5
- package/esm2022/lib/dr-dialog/dialog.module.mjs +6 -31
- package/esm2022/lib/dr-dialog/services/dialog.service.mjs +2 -2
- package/esm2022/lib/dr-dropdown/dr-dropdown-item-show.pipe.mjs +3 -3
- package/esm2022/lib/dr-dropdown/dr-dropdown-position.directive.mjs +29 -20
- package/esm2022/lib/dr-dropdown/dr-dropdown.component.mjs +5 -5
- package/esm2022/lib/dr-dropdown/dr-dropdown.directive.mjs +7 -7
- package/esm2022/lib/dr-dropdown/dr-dropdown.module.mjs +7 -32
- package/esm2022/lib/dr-dropdown/dr-dropdown.service.mjs +2 -2
- package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.component.mjs +4 -4
- package/esm2022/lib/dr-dynamic-tag/dr-dynamic-tag.module.mjs +5 -13
- package/esm2022/lib/dr-error/dr-error.component.mjs +3 -3
- package/esm2022/lib/dr-error/dr-error.module.mjs +5 -15
- package/esm2022/lib/dr-inputs/button/button.component.mjs +3 -3
- package/esm2022/lib/dr-inputs/checkbox/checkbox.component.mjs +5 -11
- package/esm2022/lib/dr-inputs/date-pickers/directives/dr-date-picker-format.directive.mjs +8 -8
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker/dr-date-picker.component.mjs +10 -11
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-range/dr-date-picker-range.component.mjs +4 -8
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.mjs +11 -12
- package/esm2022/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.mjs +31 -24
- package/esm2022/lib/dr-inputs/date-pickers/dr-show-timeframe.pipe.mjs +3 -3
- package/esm2022/lib/dr-inputs/date-pickers/services/dr-date-picker.service.mjs +5 -7
- package/esm2022/lib/dr-inputs/dr-input/dr-input.component.mjs +17 -17
- package/esm2022/lib/dr-inputs/dr-inputs.module.mjs +2 -2
- package/esm2022/lib/dr-inputs/dr-link/dr-link.component.mjs +3 -3
- package/esm2022/lib/dr-inputs/dr-model-debounce-change.directive.mjs +5 -3
- package/esm2022/lib/dr-inputs/dr-select/dr-select.component.mjs +17 -20
- package/esm2022/lib/dr-inputs/dr-select-add-item/dr-select-add-item.component.mjs +4 -4
- package/esm2022/lib/dr-inputs/dr-slider/dr-slider.component.mjs +5 -11
- package/esm2022/lib/dr-inputs/dr-toggle/dr-toggle.component.mjs +6 -12
- package/esm2022/lib/dr-inputs/dr-toggle-button/dr-toggle-button.component.mjs +6 -12
- package/esm2022/lib/dr-inputs/radio-button/radio-button.component.mjs +10 -12
- package/esm2022/lib/dr-inputs/radio-button/radio-group.component.mjs +16 -14
- package/esm2022/lib/dr-layout/dr-layout-body.component.mjs +2 -3
- package/esm2022/lib/dr-layout/dr-layout-header.component.mjs +2 -3
- package/esm2022/lib/dr-layout/dr-layout.component.mjs +2 -3
- package/esm2022/lib/dr-layout/dr-layout.module.mjs +3 -11
- package/esm2022/lib/dr-popover/dr-popover-ref.mjs +1 -1
- package/esm2022/lib/dr-popover/dr-popover.component.mjs +11 -15
- package/esm2022/lib/dr-popover/dr-popover.directive.mjs +6 -6
- package/esm2022/lib/dr-popover/dr-popover.module.mjs +5 -15
- package/esm2022/lib/dr-popover/dr-popover.service.mjs +6 -8
- package/esm2022/lib/dr-scenario/components/dr-scenario-configuration/dr-scenario-configuration.component.mjs +3 -3
- package/esm2022/lib/dr-scenario/components/dr-scenario-tag-configuration/dr-scenario-tag-configuration.component.mjs +3 -3
- package/esm2022/lib/dr-scenario/consts/scenario-tags-config.mjs +2 -2
- package/esm2022/lib/dr-scenario/dr-scenario.module.mjs +5 -24
- package/esm2022/lib/dr-scenario/services/scenario.service.mjs +16 -12
- package/esm2022/lib/dr-spinner/dr-spinner.component.mjs +1 -1
- package/esm2022/lib/dr-spinner/dr-spinner.directive.mjs +9 -4
- package/esm2022/lib/dr-spinner/dr-spinner.module.mjs +3 -5
- package/esm2022/lib/dr-tabs/dr-tab.component.mjs +4 -6
- package/esm2022/lib/dr-tabs/dr-tabs.component.mjs +4 -5
- package/esm2022/lib/dr-tabs/dr-tabs.module.mjs +6 -31
- package/esm2022/lib/dr-tags/dr-tag.component.mjs +9 -10
- package/esm2022/lib/dr-tags/dr-tag.module.mjs +5 -18
- package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.component.mjs +10 -10
- package/esm2022/lib/dr-tags-constructor/dr-tags-constructor.module.mjs +1 -1
- package/esm2022/lib/dr-tags-constructor/tags-constructor.service.mjs +3 -2
- package/esm2022/lib/dr-toastr/default-toastr/default-toastr.component.mjs +4 -4
- package/esm2022/lib/dr-toastr/dr-toastr.module.mjs +5 -7
- package/esm2022/lib/dr-toastr/dr-toastr.service.mjs +3 -3
- package/esm2022/lib/dr-tooltip/components/tooltip-default/tooltip-default.component.mjs +1 -1
- package/esm2022/lib/dr-tooltip/components/tooltip-info/tooltip-info.component.mjs +4 -5
- package/esm2022/lib/dr-tooltip/components/tooltip-info-simple/tooltip-info-simple.component.mjs +4 -5
- package/esm2022/lib/dr-tooltip/components/tooltip-no-body/tooltip-no-body.component.mjs +5 -7
- package/esm2022/lib/dr-tooltip/components/tooltip-process-default/tooltip-process-default.component.mjs +4 -9
- package/esm2022/lib/dr-tooltip/dr-tooltip.component.mjs +3 -7
- package/esm2022/lib/dr-tooltip/dr-tooltip.directive.mjs +8 -4
- package/esm2022/lib/dr-tooltip/dr-tooltip.module.mjs +7 -19
- package/esm2022/lib/dr-treeview/components/treeview/treeview.component.mjs +11 -11
- package/esm2022/lib/dr-treeview/components/treeview-item/treeview-item.component.mjs +4 -4
- package/esm2022/lib/dr-treeview/dr-tree-view.module.mjs +7 -25
- package/esm2022/lib/dr-treeview/helpers/treeview-event-parser.mjs +11 -9
- package/esm2022/lib/dr-treeview/helpers/treeview-helper.mjs +3 -3
- package/esm2022/lib/dr-treeview/models/treeview-config.mjs +1 -1
- package/esm2022/lib/dr-treeview/models/treeview-header-template-context.mjs +1 -1
- package/esm2022/lib/dr-treeview/models/treeview-i18n.mjs +1 -1
- package/esm2022/lib/dr-treeview/models/treeview-item-template-context.mjs +1 -1
- package/esm2022/lib/dr-treeview/models/treeview-item.mjs +7 -7
- package/esm2022/lib/dr-treeview/pipes/treeview.pipe.mjs +3 -3
- package/esm2022/lib/image-cropper/dr-image-cropper-canvas.service.mjs +2 -2
- package/esm2022/lib/image-cropper/dr-image-cropper.component.mjs +3 -3
- package/esm2022/lib/list-tags/list-tag.component.mjs +4 -4
- package/esm2022/lib/list-tags/list-tag.module.mjs +5 -18
- package/esm2022/lib/models/chat.mjs +6 -4
- package/esm2022/lib/models/constants.mjs +17 -22
- package/esm2022/lib/models/datePicker.mjs +2 -2
- package/esm2022/lib/models/dropdown.mjs +1 -1
- package/esm2022/lib/models/feedback.mjs +1 -2
- package/esm2022/lib/models/serverTags.mjs +1 -1
- package/esm2022/lib/models/toastr.mjs +1 -1
- package/esm2022/lib/stepper/stepper.component.mjs +4 -4
- package/esm2022/lib/stepper/stepper.module.mjs +5 -10
- package/esm2022/lib/utils/dr-shared-utils.mjs +1 -1
- package/esm2022/public-api.mjs +2 -2
- package/fesm2022/datarailsshared-datarailsshared.mjs +538 -849
- package/fesm2022/datarailsshared-datarailsshared.mjs.map +1 -1
- package/lib/dr-inputs/date-pickers/dr-date-picker-with-timeframe/dr-date-picker-with-timeframe.component.d.ts +4 -4
- package/lib/dr-inputs/date-pickers/dr-date-picker_custom-header/dr-date-picker_custom-header.component.d.ts +1 -1
- package/lib/models/chat.d.ts +1 -1
- package/package.json +1 -1
- package/public-api.d.ts +2 -2
- package/datarailsshared-datarailsshared-1.5.313.tgz +0 -0
|
@@ -64,11 +64,11 @@ export class DrImageCropperComponent {
|
|
|
64
64
|
return decoder.decode(reader.result);
|
|
65
65
|
}
|
|
66
66
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DrImageCropperComponent, deps: [{ token: i1.DrImageCropperCanvasService }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
67
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DrImageCropperComponent, isStandalone: true, selector: "dr-image-cropper", inputs: { cropperSize: "cropperSize", imageFile: "imageFile", maxZoom: "maxZoom", minZoom: "minZoom", zoomStep: "zoomStep", zoomLevel: "zoomLevel" }, outputs: { cropChanged: "cropChanged", clearClicked: "clearClicked" }, providers: [DrImageCropperCanvasService], viewQueries: [{ propertyName: "canvasElement", first: true, predicate: ["imageCanvas"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"crop-mode-btns-container\">\n <dr-button
|
|
67
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: DrImageCropperComponent, isStandalone: true, selector: "dr-image-cropper", inputs: { cropperSize: "cropperSize", imageFile: "imageFile", maxZoom: "maxZoom", minZoom: "minZoom", zoomStep: "zoomStep", zoomLevel: "zoomLevel" }, outputs: { cropChanged: "cropChanged", clearClicked: "clearClicked" }, providers: [DrImageCropperCanvasService], viewQueries: [{ propertyName: "canvasElement", first: true, predicate: ["imageCanvas"], descendants: true, static: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"crop-mode-btns-container\">\n <dr-button\n theme=\"ghost\"\n [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.SQUARE\"\n (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.SQUARE)\">\n <div class=\"mode-btn\">\n <div class=\"mode-btn__square-icon\"></div>\n Square\n </div>\n </dr-button>\n <dr-button\n theme=\"ghost\"\n [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.RECTANGLE\"\n (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.RECTANGLE)\">\n <div class=\"mode-btn\">\n <div class=\"mode-btn__rectangle-icon\"></div>\n Rectangle\n </div>\n </dr-button>\n</div>\n\n<div class=\"image-cropper\">\n <canvas #imageCanvas></canvas>\n</div>\n<dr-slider\n [(ngModel)]=\"zoomLevel\"\n [max]=\"maxZoom\"\n [min]=\"minZoom\"\n [step]=\"zoomStep\"\n [style.width]=\"cropperSize + 'px'\"\n class=\"image-crop-slider\"\n (input)=\"drawImage($event)\">\n</dr-slider>\n<dr-button [theme]=\"'ghost'\" (click)=\"clearClicked.emit()\" class=\"try-another-btn\"> Try another image </dr-button>\n", styles: [":host{display:flex;flex-direction:column}:host .crop-mode-btns-container{display:flex;justify-content:center;margin-bottom:16px}:host .crop-mode-btns-container ::ng-deep dr-button.active-mode>button{background:#eaeaff}:host .crop-mode-btns-container ::ng-deep dr-button>button{height:56px;width:80px}:host .crop-mode-btns-container dr-button:not(:first-child){margin-left:8px}:host .crop-mode-btns-container .mode-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#333;height:56px;width:80px}:host .crop-mode-btns-container .mode-btn__rectangle-icon{height:8px;width:24px;margin-top:4px;margin-bottom:4px}:host .crop-mode-btns-container .mode-btn__square-icon{width:16px;height:16px}:host .crop-mode-btns-container .mode-btn__rectangle-icon,:host .crop-mode-btns-container .mode-btn__square-icon{border:1px solid #333333}:host .image-cropper{overflow:hidden;position:relative}:host .image-cropper__shadow{position:absolute}:host .image-crop-slider{margin-top:8px}:host .try-another-btn{display:flex;justify-content:center;margin-top:8px}\n"], dependencies: [{ kind: "ngmodule", type: FormsModule }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: DrSliderComponent, selector: "dr-slider", inputs: ["disabled", "max", "min", "step", "rangeValue"] }, { kind: "ngmodule", type: DrInputsModule }, { kind: "component", type: i3.DrButtonComponent, selector: "dr-button", inputs: ["theme", "icon", "iconColor", "iconSize", "iconAfter", "iconAfterColor", "iconAfterSize", "disabled", "isLoading", "isActive"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
|
|
68
68
|
}
|
|
69
69
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: DrImageCropperComponent, decorators: [{
|
|
70
70
|
type: Component,
|
|
71
|
-
args: [{ selector: 'dr-image-cropper', changeDetection: ChangeDetectionStrategy.OnPush, imports: [FormsModule, DrSliderComponent, DrInputsModule], standalone: true, providers: [DrImageCropperCanvasService], template: "<div class=\"crop-mode-btns-container\">\n <dr-button
|
|
71
|
+
args: [{ selector: 'dr-image-cropper', changeDetection: ChangeDetectionStrategy.OnPush, imports: [FormsModule, DrSliderComponent, DrInputsModule], standalone: true, providers: [DrImageCropperCanvasService], template: "<div class=\"crop-mode-btns-container\">\n <dr-button\n theme=\"ghost\"\n [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.SQUARE\"\n (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.SQUARE)\">\n <div class=\"mode-btn\">\n <div class=\"mode-btn__square-icon\"></div>\n Square\n </div>\n </dr-button>\n <dr-button\n theme=\"ghost\"\n [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.RECTANGLE\"\n (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.RECTANGLE)\">\n <div class=\"mode-btn\">\n <div class=\"mode-btn__rectangle-icon\"></div>\n Rectangle\n </div>\n </dr-button>\n</div>\n\n<div class=\"image-cropper\">\n <canvas #imageCanvas></canvas>\n</div>\n<dr-slider\n [(ngModel)]=\"zoomLevel\"\n [max]=\"maxZoom\"\n [min]=\"minZoom\"\n [step]=\"zoomStep\"\n [style.width]=\"cropperSize + 'px'\"\n class=\"image-crop-slider\"\n (input)=\"drawImage($event)\">\n</dr-slider>\n<dr-button [theme]=\"'ghost'\" (click)=\"clearClicked.emit()\" class=\"try-another-btn\"> Try another image </dr-button>\n", styles: [":host{display:flex;flex-direction:column}:host .crop-mode-btns-container{display:flex;justify-content:center;margin-bottom:16px}:host .crop-mode-btns-container ::ng-deep dr-button.active-mode>button{background:#eaeaff}:host .crop-mode-btns-container ::ng-deep dr-button>button{height:56px;width:80px}:host .crop-mode-btns-container dr-button:not(:first-child){margin-left:8px}:host .crop-mode-btns-container .mode-btn{display:flex;flex-direction:column;align-items:center;justify-content:center;color:#333;height:56px;width:80px}:host .crop-mode-btns-container .mode-btn__rectangle-icon{height:8px;width:24px;margin-top:4px;margin-bottom:4px}:host .crop-mode-btns-container .mode-btn__square-icon{width:16px;height:16px}:host .crop-mode-btns-container .mode-btn__rectangle-icon,:host .crop-mode-btns-container .mode-btn__square-icon{border:1px solid #333333}:host .image-cropper{overflow:hidden;position:relative}:host .image-cropper__shadow{position:absolute}:host .image-crop-slider{margin-top:8px}:host .try-another-btn{display:flex;justify-content:center;margin-top:8px}\n"] }]
|
|
72
72
|
}], ctorParameters: function () { return [{ type: i1.DrImageCropperCanvasService }]; }, propDecorators: { cropperSize: [{
|
|
73
73
|
type: Input,
|
|
74
74
|
args: [{ required: true }]
|
|
@@ -91,4 +91,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
91
91
|
type: ViewChild,
|
|
92
92
|
args: ['imageCanvas', { static: true }]
|
|
93
93
|
}] } });
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-image-cropper.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/image-cropper/dr-image-cropper.component.ts","../../../../../projects/datarailsshared/src/lib/image-cropper/dr-image-cropper.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEH,uBAAuB,EACvB,SAAS,EACT,UAAU,EACV,YAAY,EACZ,KAAK,EAEL,MAAM,EAEN,SAAS,GACZ,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,MAAM,gBAAgB,CAAC;AAC7C,OAAO,EAAE,iBAAiB,EAAE,MAAM,4CAA4C,CAAC;AAC/E,OAAO,EAAE,gBAAgB,EAAkB,MAAM,0BAA0B,CAAC;AAC5E,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,2BAA2B,EAAE,MAAM,mCAAmC,CAAC;;;;;AAWhF,MAAM,OAAO,uBAAuB;IAiBhC,YAA6B,aAA0C;QAA1C,kBAAa,GAAb,aAAa,CAA6B;QAd9D,YAAO,GAAW,EAAE,CAAC;QACrB,YAAO,GAAW,GAAG,CAAC;QACtB,aAAQ,GAAW,GAAG,CAAC;QACvB,cAAS,GAAW,CAAC,CAAC;QAErB,gBAAW,GAAG,IAAI,YAAY,EAAkB,CAAC;QACjD,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QAKlD,aAAQ,GAAqB,gBAAgB,CAAC,MAAM,CAAC;QAC5C,qBAAgB,GAAG,gBAAgB,CAAC;IAG7C,CAAC;IAED,WAAW,CAAC,OAAsB;QAC9B,IAAI,OAAO,CAAC,SAAS,IAAI,IAAI,CAAC,SAAS,EAAE;YACrC,IAAI,CAAC,aAAa,EAAE,CAAC;SACxB;IACL,CAAC;IAED,eAAe;QACX,IAAI,CAAC,aAAa,CAAC,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;IAC/E,CAAC;IAED,SAAS,CAAC,YAAa;QACnB,IAAI,YAAY,KAAK,SAAS,EAAE;YAC5B,IAAI,CAAC,SAAS,GAAG,YAAY,CAAC,MAAM,CAAC,KAAK,CAAC;SAC9C;QACD,IAAI,CAAC,iBAAiB,EAAE,CAAC;IAC7B,CAAC;IAED,iBAAiB,CAAC,QAA2B;QACzC,IAAI,QAAQ,EAAE;YACV,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC;SAC5B;QAED,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACrG,MAAM,WAAW,GAAG,IAAI,CAAC,aAAa,CAAC,cAAc,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;QACvF,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE;YAC7C,MAAM,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,IAAI,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,IAAI,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,YAAY,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;YAC5G,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,WAAW,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC;QAC1E,CAAC,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;IAC5B,CAAC;IAEO,aAAa;QACjB,MAAM,MAAM,GAAG,IAAI,UAAU,EAAE,CAAC;QAChC,MAAM,CAAC,MAAM,GAAG,GAAG,EAAE;YACjB,IAAI,CAAC,gBAAgB,GAAG,IAAI,KAAK,EAAE,CAAC;YACpC,IAAI,CAAC,gBAAgB,CAAC,GAAG,GAAG,IAAI,CAAC,kBAAkB,CAAC,MAAM,CAAC,CAAC;YAC5D,IAAI,CAAC,gBAAgB,CAAC,MAAM,GAAG,GAAG,EAAE;gBAChC,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,MAAM,GAAG,IAAI,CAAC,WAAW,CAAC;gBACpG,IAAI,CAAC,SAAS,EAAE,CAAC;YACrB,CAAC,CAAC;QACN,CAAC,CAAC;QACF,MAAM,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IACzC,CAAC;IAEO,kBAAkB,CAAC,MAAkB;QACzC,IAAI,OAAO,MAAM,CAAC,MAAM,KAAK,QAAQ;YAAE,OAAO,MAAM,CAAC,MAAM,CAAC;QAE5D,MAAM,OAAO,GAAG,IAAI,WAAW,EAAE,CAAC;QAClC,OAAO,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,CAAC;IACzC,CAAC;kIApEQ,uBAAuB;sHAAvB,uBAAuB,4RAFrB,CAAC,2BAA2B,CAAC,2KCzB5C,oqCAkCA,6mCDXc,WAAW,+VAAE,iBAAiB,+GAAE,cAAc;;4FAI/C,uBAAuB;kBATnC,SAAS;+BACI,kBAAkB,mBAGX,uBAAuB,CAAC,MAAM,WACtC,CAAC,WAAW,EAAE,iBAAiB,EAAE,cAAc,CAAC,cAC7C,IAAI,aACL,CAAC,2BAA2B,CAAC;kHAGb,WAAW;sBAArC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBACE,SAAS;sBAAnC,KAAK;uBAAC,EAAE,QAAQ,EAAE,IAAI,EAAE;gBAChB,OAAO;sBAAf,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEI,WAAW;sBAApB,MAAM;gBACG,YAAY;sBAArB,MAAM;gBAEqC,aAAa;sBAAxD,SAAS;uBAAC,aAAa,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DrSliderComponent } from '../dr-inputs/dr-slider/dr-slider.component';\nimport { CROP_IMAGE_MODES, ICropImageData } from './dr-image-cropper.types';\nimport { DrInputsModule } from '../dr-inputs/dr-inputs.module';\nimport { DrImageCropperCanvasService } from './dr-image-cropper-canvas.service';\n\n@Component({\n    selector: 'dr-image-cropper',\n    templateUrl: './dr-image-cropper.component.html',\n    styleUrls: ['./dr-image-cropper.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [FormsModule, DrSliderComponent, DrInputsModule],\n    standalone: true,\n    providers: [DrImageCropperCanvasService]\n})\nexport class DrImageCropperComponent implements OnChanges, AfterViewInit {\n    @Input({ required: true }) cropperSize: number;\n    @Input({ required: true }) imageFile: File;\n    @Input() maxZoom: number = 10;\n    @Input() minZoom: number = 0.5;\n    @Input() zoomStep: number = 0.1;\n    @Input() zoomLevel: number = 1;\n\n    @Output() cropChanged = new EventEmitter<ICropImageData>();\n    @Output() clearClicked = new EventEmitter<void>();\n\n    @ViewChild('imageCanvas', { static: true }) canvasElement: ElementRef<HTMLCanvasElement>;\n\n    htmlImageElement: HTMLImageElement;\n    cropMode: CROP_IMAGE_MODES = CROP_IMAGE_MODES.SQUARE;\n    readonly CROP_IMAGE_MODES = CROP_IMAGE_MODES;\n\n    constructor(private readonly canvasService: DrImageCropperCanvasService) {\n    }\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.imageFile && this.imageFile) {\n            this.readImageFile();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.canvasService.ctx = this.canvasElement.nativeElement.getContext('2d');\n    }\n\n    drawImage(newZoomEvent?): void {\n        if (newZoomEvent !== undefined) {\n            this.zoomLevel = newZoomEvent.target.value;\n        }\n        this.onCropModeUpdated();\n    }\n\n    onCropModeUpdated(cropMode?: CROP_IMAGE_MODES): void {\n        if (cropMode) {\n            this.cropMode = cropMode;\n        }\n\n        this.canvasService.drawShape(this.cropperSize, this.cropMode, this.zoomLevel, this.htmlImageElement);\n        const coordinates = this.canvasService.getCoordinates(this.cropMode, this.cropperSize);\n        this.canvasElement.nativeElement.toBlob((blob) => {\n            const file = new File([blob], this.imageFile.name, { type: this.imageFile.type, lastModified: Date.now() });\n            this.cropChanged.emit({ file, coordinates, cropMode: this.cropMode });\n        }, this.imageFile.type);\n    }\n\n    private readImageFile(): void {\n        const reader = new FileReader();\n        reader.onload = () => {\n            this.htmlImageElement = new Image();\n            this.htmlImageElement.src = this.getImagesStringSrc(reader);\n            this.htmlImageElement.onload = () => {\n                this.canvasElement.nativeElement.width = this.canvasElement.nativeElement.height = this.cropperSize;\n                this.drawImage();\n            };\n        };\n        reader.readAsDataURL(this.imageFile);\n    }\n\n    private getImagesStringSrc(reader: FileReader): string {\n        if (typeof reader.result === 'string') return reader.result;\n\n        const decoder = new TextDecoder();\n        return decoder.decode(reader.result);\n    }\n}\n","<div class=\"crop-mode-btns-container\">\n    <dr-button theme=\"ghost\"\n               [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.SQUARE\"\n               (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.SQUARE)\">\n        <div class=\"mode-btn\">\n            <div class=\"mode-btn__square-icon\"></div>\n            Square\n        </div>\n    </dr-button>\n    <dr-button theme=\"ghost\"\n               [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.RECTANGLE\"\n               (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.RECTANGLE)\">\n        <div class=\"mode-btn\">\n            <div class=\"mode-btn__rectangle-icon\"></div>\n            Rectangle\n        </div>\n    </dr-button>\n</div>\n\n<div class=\"image-cropper\">\n    <canvas #imageCanvas></canvas>\n</div>\n<dr-slider\n        [(ngModel)]=\"zoomLevel\"\n        [max]=\"maxZoom\"\n        [min]=\"minZoom\"\n        [step]=\"zoomStep\"\n        [style.width]=\"cropperSize + 'px'\"\n        class=\"image-crop-slider\"\n        (input)=\"drawImage($event)\">\n</dr-slider>\n<dr-button [theme]=\"'ghost'\" (click)=\"clearClicked.emit()\" class=\"try-another-btn\">\n    Try another image\n</dr-button>\n"]}
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dr-image-cropper.component.js","sourceRoot":"","sources":["../../../../../projects/datarailsshared/src/lib/image-cropper/dr-image-cropper.component.ts","../../../../../projects/datarailsshared/src/lib/image-cropper/dr-image-cropper.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n    AfterViewInit,\n    ChangeDetectionStrategy,\n    Component,\n    ElementRef,\n    EventEmitter,\n    Input,\n    OnChanges,\n    Output,\n    SimpleChanges,\n    ViewChild,\n} from '@angular/core';\nimport { FormsModule } from '@angular/forms';\nimport { DrSliderComponent } from '../dr-inputs/dr-slider/dr-slider.component';\nimport { CROP_IMAGE_MODES, ICropImageData } from './dr-image-cropper.types';\nimport { DrInputsModule } from '../dr-inputs/dr-inputs.module';\nimport { DrImageCropperCanvasService } from './dr-image-cropper-canvas.service';\n\n@Component({\n    selector: 'dr-image-cropper',\n    templateUrl: './dr-image-cropper.component.html',\n    styleUrls: ['./dr-image-cropper.component.scss'],\n    changeDetection: ChangeDetectionStrategy.OnPush,\n    imports: [FormsModule, DrSliderComponent, DrInputsModule],\n    standalone: true,\n    providers: [DrImageCropperCanvasService],\n})\nexport class DrImageCropperComponent implements OnChanges, AfterViewInit {\n    @Input({ required: true }) cropperSize: number;\n    @Input({ required: true }) imageFile: File;\n    @Input() maxZoom: number = 10;\n    @Input() minZoom: number = 0.5;\n    @Input() zoomStep: number = 0.1;\n    @Input() zoomLevel: number = 1;\n\n    @Output() cropChanged = new EventEmitter<ICropImageData>();\n    @Output() clearClicked = new EventEmitter<void>();\n\n    @ViewChild('imageCanvas', { static: true }) canvasElement: ElementRef<HTMLCanvasElement>;\n\n    htmlImageElement: HTMLImageElement;\n    cropMode: CROP_IMAGE_MODES = CROP_IMAGE_MODES.SQUARE;\n    readonly CROP_IMAGE_MODES = CROP_IMAGE_MODES;\n\n    constructor(private readonly canvasService: DrImageCropperCanvasService) {}\n\n    ngOnChanges(changes: SimpleChanges): void {\n        if (changes.imageFile && this.imageFile) {\n            this.readImageFile();\n        }\n    }\n\n    ngAfterViewInit(): void {\n        this.canvasService.ctx = this.canvasElement.nativeElement.getContext('2d');\n    }\n\n    drawImage(newZoomEvent?): void {\n        if (newZoomEvent !== undefined) {\n            this.zoomLevel = newZoomEvent.target.value;\n        }\n        this.onCropModeUpdated();\n    }\n\n    onCropModeUpdated(cropMode?: CROP_IMAGE_MODES): void {\n        if (cropMode) {\n            this.cropMode = cropMode;\n        }\n\n        this.canvasService.drawShape(this.cropperSize, this.cropMode, this.zoomLevel, this.htmlImageElement);\n        const coordinates = this.canvasService.getCoordinates(this.cropMode, this.cropperSize);\n        this.canvasElement.nativeElement.toBlob((blob) => {\n            const file = new File([blob], this.imageFile.name, { type: this.imageFile.type, lastModified: Date.now() });\n            this.cropChanged.emit({ file, coordinates, cropMode: this.cropMode });\n        }, this.imageFile.type);\n    }\n\n    private readImageFile(): void {\n        const reader = new FileReader();\n        reader.onload = () => {\n            this.htmlImageElement = new Image();\n            this.htmlImageElement.src = this.getImagesStringSrc(reader);\n            this.htmlImageElement.onload = () => {\n                this.canvasElement.nativeElement.width = this.canvasElement.nativeElement.height = this.cropperSize;\n                this.drawImage();\n            };\n        };\n        reader.readAsDataURL(this.imageFile);\n    }\n\n    private getImagesStringSrc(reader: FileReader): string {\n        if (typeof reader.result === 'string') return reader.result;\n\n        const decoder = new TextDecoder();\n        return decoder.decode(reader.result);\n    }\n}\n","<div class=\"crop-mode-btns-container\">\n    <dr-button\n        theme=\"ghost\"\n        [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.SQUARE\"\n        (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.SQUARE)\">\n        <div class=\"mode-btn\">\n            <div class=\"mode-btn__square-icon\"></div>\n            Square\n        </div>\n    </dr-button>\n    <dr-button\n        theme=\"ghost\"\n        [class.active-mode]=\"cropMode === CROP_IMAGE_MODES.RECTANGLE\"\n        (click)=\"onCropModeUpdated(CROP_IMAGE_MODES.RECTANGLE)\">\n        <div class=\"mode-btn\">\n            <div class=\"mode-btn__rectangle-icon\"></div>\n            Rectangle\n        </div>\n    </dr-button>\n</div>\n\n<div class=\"image-cropper\">\n    <canvas #imageCanvas></canvas>\n</div>\n<dr-slider\n    [(ngModel)]=\"zoomLevel\"\n    [max]=\"maxZoom\"\n    [min]=\"minZoom\"\n    [step]=\"zoomStep\"\n    [style.width]=\"cropperSize + 'px'\"\n    class=\"image-crop-slider\"\n    (input)=\"drawImage($event)\">\n</dr-slider>\n<dr-button [theme]=\"'ghost'\" (click)=\"clearClicked.emit()\" class=\"try-another-btn\"> Try another image </dr-button>\n"]}
|