@openmrs/ngx-formentry 3.0.1-pre.8
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/abstract-controls-extension/afe-control-type.d.ts +6 -0
- package/abstract-controls-extension/afe-form-array.d.ts +43 -0
- package/abstract-controls-extension/afe-form-control.d.ts +46 -0
- package/abstract-controls-extension/afe-form-group.d.ts +38 -0
- package/abstract-controls-extension/control-extensions.d.ts +4 -0
- package/abstract-controls-extension/index.d.ts +4 -0
- package/abstract-controls-extension/value-change.listener.d.ts +4 -0
- package/bundles/openmrs-ngx-formentry.umd.js +15020 -0
- package/bundles/openmrs-ngx-formentry.umd.js.map +1 -0
- package/bundles/openmrs-ngx-formentry.umd.min.js +2 -0
- package/bundles/openmrs-ngx-formentry.umd.min.js.map +1 -0
- package/change-tracking/control-relation.d.ts +12 -0
- package/change-tracking/control-relations.d.ts +12 -0
- package/components/afe-ng-select.component.d.ts +26 -0
- package/components/appointments-overview/appointments-overview.component.d.ts +15 -0
- package/components/check-box/checkbox.component.d.ts +16 -0
- package/components/check-box/checkbox.module.d.ts +2 -0
- package/components/custom-component-wrapper/custom-component-wrapper..module.d.ts +2 -0
- package/components/custom-component-wrapper/custom-component-wrapper.component.d.ts +11 -0
- package/components/custom-control-wrapper/custom-control-wrapper..module.d.ts +2 -0
- package/components/custom-control-wrapper/custom-control-wrapper.component.d.ts +25 -0
- package/components/date-time-picker/date-picker/date-picker.component.d.ts +42 -0
- package/components/date-time-picker/date-time-picker.component.d.ts +26 -0
- package/components/date-time-picker/date-time-picker.module.d.ts +5 -0
- package/components/date-time-picker/picker-modal/modal.component.d.ts +10 -0
- package/components/date-time-picker/pipes/moment.pipe.d.ts +8 -0
- package/components/date-time-picker/time-picker/time-picker.component.d.ts +29 -0
- package/components/file-upload/file-upload.component.d.ts +26 -0
- package/components/file-upload/file-upload.module.d.ts +2 -0
- package/components/file-upload/secure.pipe.d.ts +23 -0
- package/components/input/input.directive.d.ts +28 -0
- package/components/input/input.module.d.ts +2 -0
- package/components/input/label.component.d.ts +87 -0
- package/components/input/text-area.directive.d.ts +21 -0
- package/components/ngx-datetime-picker/ngx-datetime-picker.component.d.ts +17 -0
- package/components/ngx-datetime-picker/ngx-datetime-picker.module.d.ts +5 -0
- package/components/ngx-pick-datetime/lib/date-time/adapter/date-time-adapter.class.d.ts +189 -0
- package/components/ngx-pick-datetime/lib/date-time/adapter/date-time-format.class.d.ts +15 -0
- package/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-adapter.class.d.ts +73 -0
- package/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-format.class.d.ts +5 -0
- package/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time.module.d.ts +7 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-body.component.d.ts +77 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-month-view.component.d.ts +139 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-multi-year-view.component.d.ts +109 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.d.ts +120 -0
- package/components/ngx-pick-datetime/lib/date-time/calendar.component.d.ts +141 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-inline.component.d.ts +90 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-container.component.d.ts +122 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-input.directive.d.ts +152 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-intl.service.d.ts +51 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker-trigger.directive.d.ts +21 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker.animations.d.ts +8 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time-picker.component.d.ts +157 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time.class.d.ts +86 -0
- package/components/ngx-pick-datetime/lib/date-time/date-time.module.d.ts +5 -0
- package/components/ngx-pick-datetime/lib/date-time/numberedFixLen.pipe.d.ts +7 -0
- package/components/ngx-pick-datetime/lib/date-time/timer-box.component.d.ts +35 -0
- package/components/ngx-pick-datetime/lib/date-time/timer.component.d.ts +129 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog-config.class.d.ts +93 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog-container.component.d.ts +56 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog-ref.class.d.ts +49 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog.module.d.ts +5 -0
- package/components/ngx-pick-datetime/lib/dialog/dialog.service.d.ts +70 -0
- package/components/ngx-pick-datetime/lib/utils/index.d.ts +4 -0
- package/components/ngx-pick-datetime/lib/utils/object.utils.d.ts +11 -0
- package/components/ngx-remote-select/ngx-remote-select.component.d.ts +37 -0
- package/components/ngx-remote-select/ngx-remote-select.module.d.ts +2 -0
- package/components/ngx-tabset/components/tab-set.d.ts +16 -0
- package/components/ngx-tabset/components/tab.d.ts +10 -0
- package/components/ngx-tabset/directives/hover-class.directive.d.ts +8 -0
- package/components/ngx-tabset/modules/ngx-tabset.module.d.ts +11 -0
- package/components/number-input/number-input.component.d.ts +148 -0
- package/components/number-input/number-input.module.d.ts +2 -0
- package/components/select/optgroup.directive.d.ts +3 -0
- package/components/select/option.directive.d.ts +3 -0
- package/components/select/select.component.d.ts +112 -0
- package/components/select/select.module.d.ts +2 -0
- package/esm2015/abstract-controls-extension/afe-control-type.js +8 -0
- package/esm2015/abstract-controls-extension/afe-form-array.js +85 -0
- package/esm2015/abstract-controls-extension/afe-form-control.js +88 -0
- package/esm2015/abstract-controls-extension/afe-form-group.js +61 -0
- package/esm2015/abstract-controls-extension/control-extensions.js +5 -0
- package/esm2015/abstract-controls-extension/index.js +5 -0
- package/esm2015/abstract-controls-extension/value-change.listener.js +2 -0
- package/esm2015/change-tracking/control-relation.js +44 -0
- package/esm2015/change-tracking/control-relations.js +32 -0
- package/esm2015/components/afe-ng-select.component.js +87 -0
- package/esm2015/components/appointments-overview/appointments-overview.component.js +119 -0
- package/esm2015/components/check-box/checkbox.component.js +77 -0
- package/esm2015/components/check-box/checkbox.module.js +14 -0
- package/esm2015/components/custom-component-wrapper/custom-component-wrapper..module.js +16 -0
- package/esm2015/components/custom-component-wrapper/custom-component-wrapper.component.js +18 -0
- package/esm2015/components/custom-control-wrapper/custom-control-wrapper..module.js +17 -0
- package/esm2015/components/custom-control-wrapper/custom-control-wrapper.component.js +63 -0
- package/esm2015/components/date-time-picker/date-picker/date-picker.component.js +182 -0
- package/esm2015/components/date-time-picker/date-time-picker.component.js +104 -0
- package/esm2015/components/date-time-picker/date-time-picker.module.js +34 -0
- package/esm2015/components/date-time-picker/picker-modal/modal.component.js +30 -0
- package/esm2015/components/date-time-picker/pipes/moment.pipe.js +13 -0
- package/esm2015/components/date-time-picker/time-picker/time-picker.component.js +114 -0
- package/esm2015/components/file-upload/file-upload.component.js +110 -0
- package/esm2015/components/file-upload/file-upload.module.js +24 -0
- package/esm2015/components/file-upload/secure.pipe.js +102 -0
- package/esm2015/components/input/input.directive.js +55 -0
- package/esm2015/components/input/input.module.js +18 -0
- package/esm2015/components/input/label.component.js +177 -0
- package/esm2015/components/input/text-area.directive.js +40 -0
- package/esm2015/components/ngx-datetime-picker/ngx-datetime-picker.component.js +60 -0
- package/esm2015/components/ngx-datetime-picker/ngx-datetime-picker.module.js +26 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/date-time-adapter.class.js +114 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/date-time-format.class.js +7 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-adapter.class.js +344 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time-format.class.js +16 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/adapter/native-date-time.module.js +30 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-body.component.js +149 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-month-view.component.js +429 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-multi-year-view.component.js +367 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar-year-view.component.js +359 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/calendar.component.js +334 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-inline.component.js +251 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-container.component.js +380 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-input.directive.js +590 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-intl.service.js +60 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker-trigger.directive.js +71 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker.animations.js +21 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time-picker.component.js +512 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time.class.js +153 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/date-time.module.js +58 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/numberedFixLen.pipe.js +24 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/timer-box.component.js +85 -0
- package/esm2015/components/ngx-pick-datetime/lib/date-time/timer.component.js +292 -0
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog-config.class.js +56 -0
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog-container.component.js +208 -0
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog-ref.class.js +119 -0
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog.module.js +22 -0
- package/esm2015/components/ngx-pick-datetime/lib/dialog/dialog.service.js +222 -0
- package/esm2015/components/ngx-pick-datetime/lib/utils/index.js +5 -0
- package/esm2015/components/ngx-pick-datetime/lib/utils/object.utils.js +26 -0
- package/esm2015/components/ngx-remote-select/ngx-remote-select.component.js +121 -0
- package/esm2015/components/ngx-remote-select/ngx-remote-select.module.js +16 -0
- package/esm2015/components/ngx-tabset/components/tab-set.js +67 -0
- package/esm2015/components/ngx-tabset/components/tab.js +35 -0
- package/esm2015/components/ngx-tabset/directives/hover-class.directive.js +26 -0
- package/esm2015/components/ngx-tabset/modules/ngx-tabset.module.js +33 -0
- package/esm2015/components/number-input/number-input.component.js +203 -0
- package/esm2015/components/number-input/number-input.module.js +15 -0
- package/esm2015/components/select/optgroup.directive.js +17 -0
- package/esm2015/components/select/option.directive.js +17 -0
- package/esm2015/components/select/select.component.js +293 -0
- package/esm2015/components/select/select.module.js +18 -0
- package/esm2015/form-entry/control-alerts/alert-helpers.js +40 -0
- package/esm2015/form-entry/control-alerts/can-generate-alert.js +2 -0
- package/esm2015/form-entry/control-calculators/can-calculate.js +2 -0
- package/esm2015/form-entry/control-hiders-disablers/can-disable.js +2 -0
- package/esm2015/form-entry/control-hiders-disablers/can-hide.js +2 -0
- package/esm2015/form-entry/control-hiders-disablers/disabler-helper.js +33 -0
- package/esm2015/form-entry/control-hiders-disablers/hider-helpers.js +40 -0
- package/esm2015/form-entry/data-sources/data-sources.js +30 -0
- package/esm2015/form-entry/data-sources/dummy-data-source.js +104 -0
- package/esm2015/form-entry/directives/collapse-animations.js +11 -0
- package/esm2015/form-entry/directives/collapse.directive.js +157 -0
- package/esm2015/form-entry/directives/historical-value-directive.js +66 -0
- package/esm2015/form-entry/error-renderer/error-renderer.component.js +55 -0
- package/esm2015/form-entry/expression-runner/expression-runner.js +168 -0
- package/esm2015/form-entry/form-entry.module.js +107 -0
- package/esm2015/form-entry/form-factory/control-relations.factory.js +236 -0
- package/esm2015/form-entry/form-factory/form-control.service.js +118 -0
- package/esm2015/form-entry/form-factory/form-node.js +81 -0
- package/esm2015/form-entry/form-factory/form.factory.js +132 -0
- package/esm2015/form-entry/form-factory/form.js +193 -0
- package/esm2015/form-entry/form-factory/hiders-disablers.factory.js +66 -0
- package/esm2015/form-entry/form-factory/question.factory.js +864 -0
- package/esm2015/form-entry/form-factory/show-messages.factory.js +30 -0
- package/esm2015/form-entry/form-factory/validation.factory.js +145 -0
- package/esm2015/form-entry/form-renderer/form-renderer.component.css.js +179 -0
- package/esm2015/form-entry/form-renderer/form-renderer.component.js +231 -0
- package/esm2015/form-entry/helpers/historical-expression-helper-service.js +38 -0
- package/esm2015/form-entry/helpers/historical-field-helper-service.js +36 -0
- package/esm2015/form-entry/helpers/js-expression-helper.js +238 -0
- package/esm2015/form-entry/pipes/time-ago.pipe.js +107 -0
- package/esm2015/form-entry/question-models/checkbox.model.js +11 -0
- package/esm2015/form-entry/question-models/conditional-validation.model.js +9 -0
- package/esm2015/form-entry/question-models/custom-control-question.model.js +10 -0
- package/esm2015/form-entry/question-models/date-question.js +12 -0
- package/esm2015/form-entry/question-models/date-validation.model.js +10 -0
- package/esm2015/form-entry/question-models/file-upload-question.js +13 -0
- package/esm2015/form-entry/question-models/group-question.js +12 -0
- package/esm2015/form-entry/question-models/interfaces/base-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/checkbox-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/data-source.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/date-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/file-upload-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/group-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/multi-select-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/nested-questions.js +7 -0
- package/esm2015/form-entry/question-models/interfaces/repeating-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/select-option.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/select-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/test-order-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/text-area-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/text-question-options.js +2 -0
- package/esm2015/form-entry/question-models/interfaces/ui-select-question-options.js +2 -0
- package/esm2015/form-entry/question-models/js-expression-validation.model.js +8 -0
- package/esm2015/form-entry/question-models/max-validation.model.js +9 -0
- package/esm2015/form-entry/question-models/min-validation.model.js +9 -0
- package/esm2015/form-entry/question-models/models.js +12 -0
- package/esm2015/form-entry/question-models/multi-select-question.js +11 -0
- package/esm2015/form-entry/question-models/pair.model.js +7 -0
- package/esm2015/form-entry/question-models/question-base.js +25 -0
- package/esm2015/form-entry/question-models/rendering-type.js +9 -0
- package/esm2015/form-entry/question-models/repeating-question.js +11 -0
- package/esm2015/form-entry/question-models/select-option.js +7 -0
- package/esm2015/form-entry/question-models/select-question.js +12 -0
- package/esm2015/form-entry/question-models/test-order-question.js +15 -0
- package/esm2015/form-entry/question-models/text-area-input-question.js +13 -0
- package/esm2015/form-entry/question-models/text-input-question.js +10 -0
- package/esm2015/form-entry/question-models/ui-select-question.js +11 -0
- package/esm2015/form-entry/question-models/validation.model.js +7 -0
- package/esm2015/form-entry/services/debug-mode.service.js +22 -0
- package/esm2015/form-entry/services/form-errors.service.js +18 -0
- package/esm2015/form-entry/services/form-schema-compiler.service.js +246 -0
- package/esm2015/form-entry/services/historical-encounter-data.service.js +170 -0
- package/esm2015/form-entry/utils/messages.js +12 -0
- package/esm2015/form-entry/validators/conditional-answered.validator.js +46 -0
- package/esm2015/form-entry/validators/conditional-required.validator.js +40 -0
- package/esm2015/form-entry/validators/date.validator.js +18 -0
- package/esm2015/form-entry/validators/future-date-restriction.validator.js +21 -0
- package/esm2015/form-entry/validators/js-expression.validator.js +26 -0
- package/esm2015/form-entry/validators/max-date.validator.js +23 -0
- package/esm2015/form-entry/validators/max.validator.js +17 -0
- package/esm2015/form-entry/validators/min-date.validator.js +23 -0
- package/esm2015/form-entry/validators/min.validator.js +17 -0
- package/esm2015/form-entry/validators/required.validator.js +11 -0
- package/esm2015/form-entry/validators/validations.js +5 -0
- package/esm2015/form-entry/value-adapters/encounter.adapter.js +172 -0
- package/esm2015/form-entry/value-adapters/obs-adapter-helper.js +496 -0
- package/esm2015/form-entry/value-adapters/obs.adapter.js +545 -0
- package/esm2015/form-entry/value-adapters/order.adapter.js +186 -0
- package/esm2015/form-entry/value-adapters/person-attribute.adapter.js +87 -0
- package/esm2015/form-entry/value-adapters/value.adapter.js +2 -0
- package/esm2015/lib/index.js +49 -0
- package/esm2015/openmrs-ngx-formentry.js +76 -0
- package/esm2015/public_api.js +2 -0
- package/esm2015/shared.module.js +15 -0
- package/fesm2015/openmrs-ngx-formentry.js +13458 -0
- package/fesm2015/openmrs-ngx-formentry.js.map +1 -0
- package/form-entry/control-alerts/alert-helpers.d.ts +9 -0
- package/form-entry/control-alerts/can-generate-alert.d.ts +18 -0
- package/form-entry/control-calculators/can-calculate.d.ts +5 -0
- package/form-entry/control-hiders-disablers/can-disable.d.ts +19 -0
- package/form-entry/control-hiders-disablers/can-hide.d.ts +20 -0
- package/form-entry/control-hiders-disablers/disabler-helper.d.ts +7 -0
- package/form-entry/control-hiders-disablers/hider-helpers.d.ts +9 -0
- package/form-entry/data-sources/data-sources.d.ts +7 -0
- package/form-entry/data-sources/dummy-data-source.d.ts +18 -0
- package/form-entry/directives/collapse-animations.d.ts +4 -0
- package/form-entry/directives/collapse.directive.d.ts +42 -0
- package/form-entry/directives/historical-value-directive.d.ts +13 -0
- package/form-entry/error-renderer/error-renderer.component.d.ts +17 -0
- package/form-entry/expression-runner/expression-runner.d.ts +15 -0
- package/form-entry/form-entry.module.d.ts +2 -0
- package/form-entry/form-factory/control-relations.factory.d.ts +15 -0
- package/form-entry/form-factory/form-control.service.d.ts +22 -0
- package/form-entry/form-factory/form-node.d.ts +51 -0
- package/form-entry/form-factory/form.d.ts +28 -0
- package/form-entry/form-factory/form.factory.d.ts +23 -0
- package/form-entry/form-factory/hiders-disablers.factory.d.ts +17 -0
- package/form-entry/form-factory/question.factory.d.ts +56 -0
- package/form-entry/form-factory/show-messages.factory.d.ts +12 -0
- package/form-entry/form-factory/validation.factory.d.ts +22 -0
- package/form-entry/form-renderer/form-renderer.component.css.d.ts +1 -0
- package/form-entry/form-renderer/form-renderer.component.d.ts +52 -0
- package/form-entry/helpers/historical-expression-helper-service.d.ts +5 -0
- package/form-entry/helpers/historical-field-helper-service.d.ts +4 -0
- package/form-entry/helpers/js-expression-helper.d.ts +22 -0
- package/form-entry/pipes/time-ago.pipe.d.ts +11 -0
- package/form-entry/question-models/checkbox.model.d.ts +9 -0
- package/form-entry/question-models/conditional-validation.model.d.ts +6 -0
- package/form-entry/question-models/custom-control-question.model.d.ts +6 -0
- package/form-entry/question-models/date-question.d.ts +7 -0
- package/form-entry/question-models/date-validation.model.d.ts +5 -0
- package/form-entry/question-models/file-upload-question.d.ts +8 -0
- package/form-entry/question-models/group-question.d.ts +8 -0
- package/form-entry/question-models/interfaces/base-options.d.ts +28 -0
- package/form-entry/question-models/interfaces/checkbox-options.d.ts +7 -0
- package/form-entry/question-models/interfaces/data-source.d.ts +10 -0
- package/form-entry/question-models/interfaces/date-question-options.d.ts +3 -0
- package/form-entry/question-models/interfaces/file-upload-question-options.d.ts +5 -0
- package/form-entry/question-models/interfaces/group-question-options.d.ts +5 -0
- package/form-entry/question-models/interfaces/multi-select-options.d.ts +4 -0
- package/form-entry/question-models/interfaces/nested-questions.d.ts +6 -0
- package/form-entry/question-models/interfaces/repeating-question-options.d.ts +5 -0
- package/form-entry/question-models/interfaces/select-option.d.ts +4 -0
- package/form-entry/question-models/interfaces/select-question-options.d.ts +9 -0
- package/form-entry/question-models/interfaces/test-order-question-options.d.ts +14 -0
- package/form-entry/question-models/interfaces/text-area-question-options.d.ts +5 -0
- package/form-entry/question-models/interfaces/text-question-options.d.ts +4 -0
- package/form-entry/question-models/interfaces/ui-select-question-options.d.ts +9 -0
- package/form-entry/question-models/js-expression-validation.model.d.ts +5 -0
- package/form-entry/question-models/max-validation.model.d.ts +5 -0
- package/form-entry/question-models/min-validation.model.d.ts +5 -0
- package/form-entry/question-models/models.d.ts +15 -0
- package/form-entry/question-models/multi-select-question.d.ts +9 -0
- package/form-entry/question-models/pair.model.d.ts +5 -0
- package/form-entry/question-models/question-base.d.ts +40 -0
- package/form-entry/question-models/rendering-type.d.ts +7 -0
- package/form-entry/question-models/repeating-question.d.ts +7 -0
- package/form-entry/question-models/select-option.d.ts +6 -0
- package/form-entry/question-models/select-question.d.ts +10 -0
- package/form-entry/question-models/test-order-question.d.ts +13 -0
- package/form-entry/question-models/text-area-input-question.d.ts +7 -0
- package/form-entry/question-models/text-input-question.d.ts +6 -0
- package/form-entry/question-models/ui-select-question.d.ts +11 -0
- package/form-entry/question-models/validation.model.d.ts +5 -0
- package/form-entry/services/debug-mode.service.d.ts +5 -0
- package/form-entry/services/form-errors.service.d.ts +10 -0
- package/form-entry/services/form-schema-compiler.service.d.ts +20 -0
- package/form-entry/services/historical-encounter-data.service.d.ts +12 -0
- package/form-entry/utils/messages.d.ts +11 -0
- package/form-entry/validators/conditional-answered.validator.d.ts +8 -0
- package/form-entry/validators/conditional-required.validator.d.ts +8 -0
- package/form-entry/validators/date.validator.d.ts +7 -0
- package/form-entry/validators/future-date-restriction.validator.d.ts +7 -0
- package/form-entry/validators/js-expression.validator.d.ts +8 -0
- package/form-entry/validators/max-date.validator.d.ts +6 -0
- package/form-entry/validators/max.validator.d.ts +6 -0
- package/form-entry/validators/min-date.validator.d.ts +6 -0
- package/form-entry/validators/min.validator.d.ts +6 -0
- package/form-entry/validators/required.validator.d.ts +6 -0
- package/form-entry/validators/validations.d.ts +4 -0
- package/form-entry/value-adapters/encounter.adapter.d.ts +23 -0
- package/form-entry/value-adapters/obs-adapter-helper.d.ts +27 -0
- package/form-entry/value-adapters/obs.adapter.d.ts +35 -0
- package/form-entry/value-adapters/order.adapter.d.ts +17 -0
- package/form-entry/value-adapters/person-attribute.adapter.d.ts +12 -0
- package/form-entry/value-adapters/value.adapter.d.ts +5 -0
- package/lib/index.d.ts +49 -0
- package/openmrs-ngx-formentry.d.ts +85 -0
- package/openmrs-ngx-formentry.metadata.json +1 -0
- package/package.json +35 -0
- package/public_api.d.ts +1 -0
- package/shared.module.d.ts +2 -0
- package/styles/ngx-formentry.css +374 -0
- package/styles/picker.min.css +770 -0
|
@@ -0,0 +1,292 @@
|
|
|
1
|
+
/* eslint-disable @angular-eslint/no-host-metadata-property */
|
|
2
|
+
/**
|
|
3
|
+
* timer.component
|
|
4
|
+
*/
|
|
5
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, Input, NgZone, Optional, Output } from '@angular/core';
|
|
6
|
+
import { OwlDateTimeIntl } from './date-time-picker-intl.service';
|
|
7
|
+
import { DateTimeAdapter } from './adapter/date-time-adapter.class';
|
|
8
|
+
import { take } from 'rxjs/operators';
|
|
9
|
+
export class OwlTimerComponent {
|
|
10
|
+
constructor(ngZone, elmRef, pickerIntl, cdRef, dateTimeAdapter) {
|
|
11
|
+
this.ngZone = ngZone;
|
|
12
|
+
this.elmRef = elmRef;
|
|
13
|
+
this.pickerIntl = pickerIntl;
|
|
14
|
+
this.cdRef = cdRef;
|
|
15
|
+
this.dateTimeAdapter = dateTimeAdapter;
|
|
16
|
+
this.isPM = false; // a flag indicates the current timer moment is in PM or AM
|
|
17
|
+
/**
|
|
18
|
+
* Hours to change per step
|
|
19
|
+
*/
|
|
20
|
+
this.stepHour = 1;
|
|
21
|
+
/**
|
|
22
|
+
* Minutes to change per step
|
|
23
|
+
*/
|
|
24
|
+
this.stepMinute = 1;
|
|
25
|
+
/**
|
|
26
|
+
* Seconds to change per step
|
|
27
|
+
*/
|
|
28
|
+
this.stepSecond = 1;
|
|
29
|
+
this.selectedChange = new EventEmitter();
|
|
30
|
+
}
|
|
31
|
+
get pickerMoment() {
|
|
32
|
+
return this._pickerMoment;
|
|
33
|
+
}
|
|
34
|
+
set pickerMoment(value) {
|
|
35
|
+
value = this.dateTimeAdapter.deserialize(value);
|
|
36
|
+
this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();
|
|
37
|
+
}
|
|
38
|
+
get minDateTime() {
|
|
39
|
+
return this._minDateTime;
|
|
40
|
+
}
|
|
41
|
+
set minDateTime(value) {
|
|
42
|
+
value = this.dateTimeAdapter.deserialize(value);
|
|
43
|
+
this._minDateTime = this.getValidDate(value);
|
|
44
|
+
}
|
|
45
|
+
get maxDateTime() {
|
|
46
|
+
return this._maxDateTime;
|
|
47
|
+
}
|
|
48
|
+
set maxDateTime(value) {
|
|
49
|
+
value = this.dateTimeAdapter.deserialize(value);
|
|
50
|
+
this._maxDateTime = this.getValidDate(value);
|
|
51
|
+
}
|
|
52
|
+
get hourValue() {
|
|
53
|
+
return this.dateTimeAdapter.getHours(this.pickerMoment);
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* The value would be displayed in hourBox.
|
|
57
|
+
* We need this because the value displayed in hourBox it not
|
|
58
|
+
* the same as the hourValue when the timer is in hour12Timer mode.
|
|
59
|
+
* */
|
|
60
|
+
get hourBoxValue() {
|
|
61
|
+
let hours = this.hourValue;
|
|
62
|
+
if (!this.hour12Timer) {
|
|
63
|
+
return hours;
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
if (hours === 0) {
|
|
67
|
+
hours = 12;
|
|
68
|
+
this.isPM = false;
|
|
69
|
+
}
|
|
70
|
+
else if (hours > 0 && hours < 12) {
|
|
71
|
+
this.isPM = false;
|
|
72
|
+
}
|
|
73
|
+
else if (hours === 12) {
|
|
74
|
+
this.isPM = true;
|
|
75
|
+
}
|
|
76
|
+
else if (hours > 12 && hours < 24) {
|
|
77
|
+
hours = hours - 12;
|
|
78
|
+
this.isPM = true;
|
|
79
|
+
}
|
|
80
|
+
return hours;
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
get minuteValue() {
|
|
84
|
+
return this.dateTimeAdapter.getMinutes(this.pickerMoment);
|
|
85
|
+
}
|
|
86
|
+
get secondValue() {
|
|
87
|
+
return this.dateTimeAdapter.getSeconds(this.pickerMoment);
|
|
88
|
+
}
|
|
89
|
+
get upHourButtonLabel() {
|
|
90
|
+
return this.pickerIntl.upHourLabel;
|
|
91
|
+
}
|
|
92
|
+
get downHourButtonLabel() {
|
|
93
|
+
return this.pickerIntl.downHourLabel;
|
|
94
|
+
}
|
|
95
|
+
get upMinuteButtonLabel() {
|
|
96
|
+
return this.pickerIntl.upMinuteLabel;
|
|
97
|
+
}
|
|
98
|
+
get downMinuteButtonLabel() {
|
|
99
|
+
return this.pickerIntl.downMinuteLabel;
|
|
100
|
+
}
|
|
101
|
+
get upSecondButtonLabel() {
|
|
102
|
+
return this.pickerIntl.upSecondLabel;
|
|
103
|
+
}
|
|
104
|
+
get downSecondButtonLabel() {
|
|
105
|
+
return this.pickerIntl.downSecondLabel;
|
|
106
|
+
}
|
|
107
|
+
get hour12ButtonLabel() {
|
|
108
|
+
return this.isPM
|
|
109
|
+
? this.pickerIntl.hour12PMLabel
|
|
110
|
+
: this.pickerIntl.hour12AMLabel;
|
|
111
|
+
}
|
|
112
|
+
get owlDTTimerClass() {
|
|
113
|
+
return true;
|
|
114
|
+
}
|
|
115
|
+
get owlDTTimeTabIndex() {
|
|
116
|
+
return -1;
|
|
117
|
+
}
|
|
118
|
+
ngOnInit() { }
|
|
119
|
+
/**
|
|
120
|
+
* Focus to the host element
|
|
121
|
+
* */
|
|
122
|
+
focus() {
|
|
123
|
+
this.ngZone.runOutsideAngular(() => {
|
|
124
|
+
this.ngZone.onStable
|
|
125
|
+
.asObservable()
|
|
126
|
+
.pipe(take(1))
|
|
127
|
+
.subscribe(() => {
|
|
128
|
+
this.elmRef.nativeElement.focus();
|
|
129
|
+
});
|
|
130
|
+
});
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Set the hour value via typing into timer box input
|
|
134
|
+
* We need this to handle the hour value when the timer is in hour12 mode
|
|
135
|
+
* */
|
|
136
|
+
setHourValueViaInput(hours) {
|
|
137
|
+
if (this.hour12Timer && this.isPM && hours >= 1 && hours <= 11) {
|
|
138
|
+
hours = hours + 12;
|
|
139
|
+
}
|
|
140
|
+
else if (this.hour12Timer && !this.isPM && hours === 12) {
|
|
141
|
+
hours = 0;
|
|
142
|
+
}
|
|
143
|
+
this.setHourValue(hours);
|
|
144
|
+
}
|
|
145
|
+
setHourValue(hours) {
|
|
146
|
+
const m = this.dateTimeAdapter.setHours(this.pickerMoment, hours);
|
|
147
|
+
this.selectedChange.emit(m);
|
|
148
|
+
this.cdRef.markForCheck();
|
|
149
|
+
}
|
|
150
|
+
setMinuteValue(minutes) {
|
|
151
|
+
const m = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);
|
|
152
|
+
this.selectedChange.emit(m);
|
|
153
|
+
this.cdRef.markForCheck();
|
|
154
|
+
}
|
|
155
|
+
setSecondValue(seconds) {
|
|
156
|
+
const m = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);
|
|
157
|
+
this.selectedChange.emit(m);
|
|
158
|
+
this.cdRef.markForCheck();
|
|
159
|
+
}
|
|
160
|
+
setMeridiem(event) {
|
|
161
|
+
this.isPM = !this.isPM;
|
|
162
|
+
let hours = this.hourValue;
|
|
163
|
+
if (this.isPM) {
|
|
164
|
+
hours = hours + 12;
|
|
165
|
+
}
|
|
166
|
+
else {
|
|
167
|
+
hours = hours - 12;
|
|
168
|
+
}
|
|
169
|
+
if (hours >= 0 && hours <= 23) {
|
|
170
|
+
this.setHourValue(hours);
|
|
171
|
+
}
|
|
172
|
+
this.cdRef.markForCheck();
|
|
173
|
+
event.preventDefault();
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Check if the up hour button is enabled
|
|
177
|
+
*/
|
|
178
|
+
upHourEnabled() {
|
|
179
|
+
return (!this.maxDateTime ||
|
|
180
|
+
this.compareHours(this.stepHour, this.maxDateTime) < 1);
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Check if the down hour button is enabled
|
|
184
|
+
*/
|
|
185
|
+
downHourEnabled() {
|
|
186
|
+
return (!this.minDateTime ||
|
|
187
|
+
this.compareHours(-this.stepHour, this.minDateTime) > -1);
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Check if the up minute button is enabled
|
|
191
|
+
*/
|
|
192
|
+
upMinuteEnabled() {
|
|
193
|
+
return (!this.maxDateTime ||
|
|
194
|
+
this.compareMinutes(this.stepMinute, this.maxDateTime) < 1);
|
|
195
|
+
}
|
|
196
|
+
/**
|
|
197
|
+
* Check if the down minute button is enabled
|
|
198
|
+
*/
|
|
199
|
+
downMinuteEnabled() {
|
|
200
|
+
return (!this.minDateTime ||
|
|
201
|
+
this.compareMinutes(-this.stepMinute, this.minDateTime) > -1);
|
|
202
|
+
}
|
|
203
|
+
/**
|
|
204
|
+
* Check if the up second button is enabled
|
|
205
|
+
*/
|
|
206
|
+
upSecondEnabled() {
|
|
207
|
+
return (!this.maxDateTime ||
|
|
208
|
+
this.compareSeconds(this.stepSecond, this.maxDateTime) < 1);
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Check if the down second button is enabled
|
|
212
|
+
*/
|
|
213
|
+
downSecondEnabled() {
|
|
214
|
+
return (!this.minDateTime ||
|
|
215
|
+
this.compareSeconds(-this.stepSecond, this.minDateTime) > -1);
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* PickerMoment's hour value +/- certain amount and compare it to the give date
|
|
219
|
+
* 1 is after the comparedDate
|
|
220
|
+
* -1 is before the comparedDate
|
|
221
|
+
* 0 is equal the comparedDate
|
|
222
|
+
* */
|
|
223
|
+
compareHours(amount, comparedDate) {
|
|
224
|
+
const hours = this.dateTimeAdapter.getHours(this.pickerMoment) + amount;
|
|
225
|
+
const result = this.dateTimeAdapter.setHours(this.pickerMoment, hours);
|
|
226
|
+
return this.dateTimeAdapter.compare(result, comparedDate);
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* PickerMoment's minute value +/- certain amount and compare it to the give date
|
|
230
|
+
* 1 is after the comparedDate
|
|
231
|
+
* -1 is before the comparedDate
|
|
232
|
+
* 0 is equal the comparedDate
|
|
233
|
+
* */
|
|
234
|
+
compareMinutes(amount, comparedDate) {
|
|
235
|
+
const minutes = this.dateTimeAdapter.getMinutes(this.pickerMoment) + amount;
|
|
236
|
+
const result = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);
|
|
237
|
+
return this.dateTimeAdapter.compare(result, comparedDate);
|
|
238
|
+
}
|
|
239
|
+
/**
|
|
240
|
+
* PickerMoment's second value +/- certain amount and compare it to the give date
|
|
241
|
+
* 1 is after the comparedDate
|
|
242
|
+
* -1 is before the comparedDate
|
|
243
|
+
* 0 is equal the comparedDate
|
|
244
|
+
* */
|
|
245
|
+
compareSeconds(amount, comparedDate) {
|
|
246
|
+
const seconds = this.dateTimeAdapter.getSeconds(this.pickerMoment) + amount;
|
|
247
|
+
const result = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);
|
|
248
|
+
return this.dateTimeAdapter.compare(result, comparedDate);
|
|
249
|
+
}
|
|
250
|
+
/**
|
|
251
|
+
* Get a valid date object
|
|
252
|
+
*/
|
|
253
|
+
getValidDate(obj) {
|
|
254
|
+
return this.dateTimeAdapter.isDateInstance(obj) &&
|
|
255
|
+
this.dateTimeAdapter.isValid(obj)
|
|
256
|
+
? obj
|
|
257
|
+
: null;
|
|
258
|
+
}
|
|
259
|
+
}
|
|
260
|
+
OwlTimerComponent.decorators = [
|
|
261
|
+
{ type: Component, args: [{
|
|
262
|
+
exportAs: 'owlDateTimeTimer',
|
|
263
|
+
selector: 'owl-date-time-timer',
|
|
264
|
+
template: "<owl-date-time-timer-box\n [upBtnAriaLabel]=\"upHourButtonLabel\"\n [downBtnAriaLabel]=\"downHourButtonLabel\"\n [upBtnDisabled]=\"!upHourEnabled()\"\n [downBtnDisabled]=\"!downHourEnabled()\"\n [boxValue]=\"hourBoxValue\"\n [value]=\"hourValue\" [min]=\"0\" [max]=\"23\"\n [step]=\"stepHour\" [inputLabel]=\"'Hour'\"\n (inputChange)=\"setHourValueViaInput($event)\"\n (valueChange)=\"setHourValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n [showDivider]=\"true\"\n [upBtnAriaLabel]=\"upMinuteButtonLabel\"\n [downBtnAriaLabel]=\"downMinuteButtonLabel\"\n [upBtnDisabled]=\"!upMinuteEnabled()\"\n [downBtnDisabled]=\"!downMinuteEnabled()\"\n [value]=\"minuteValue\" [min]=\"0\" [max]=\"59\"\n [step]=\"stepMinute\" [inputLabel]=\"'Minute'\"\n (inputChange)=\"setMinuteValue($event)\"\n (valueChange)=\"setMinuteValue($event)\"></owl-date-time-timer-box>\n<owl-date-time-timer-box\n *ngIf=\"showSecondsTimer\"\n [showDivider]=\"true\"\n [upBtnAriaLabel]=\"upSecondButtonLabel\"\n [downBtnAriaLabel]=\"downSecondButtonLabel\"\n [upBtnDisabled]=\"!upSecondEnabled()\"\n [downBtnDisabled]=\"!downSecondEnabled()\"\n [value]=\"secondValue\" [min]=\"0\" [max]=\"59\"\n [step]=\"stepSecond\" [inputLabel]=\"'Second'\"\n (inputChange)=\"setSecondValue($event)\"\n (valueChange)=\"setSecondValue($event)\"></owl-date-time-timer-box>\n\n<div *ngIf=\"hour12Timer\" class=\"owl-dt-timer-hour12\">\n <button class=\"owl-dt-control-button owl-dt-timer-hour12-box\"\n type=\"button\" tabindex=\"0\"\n (click)=\"setMeridiem($event)\">\n <span class=\"owl-dt-control-button-content\" tabindex=\"-1\">\n {{hour12ButtonLabel}}\n </span>\n </button>\n</div>\n",
|
|
265
|
+
preserveWhitespaces: false,
|
|
266
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
267
|
+
host: {
|
|
268
|
+
'[class.owl-dt-timer]': 'owlDTTimerClass',
|
|
269
|
+
'[attr.tabindex]': 'owlDTTimeTabIndex'
|
|
270
|
+
},
|
|
271
|
+
styles: [""]
|
|
272
|
+
},] }
|
|
273
|
+
];
|
|
274
|
+
OwlTimerComponent.ctorParameters = () => [
|
|
275
|
+
{ type: NgZone },
|
|
276
|
+
{ type: ElementRef },
|
|
277
|
+
{ type: OwlDateTimeIntl },
|
|
278
|
+
{ type: ChangeDetectorRef },
|
|
279
|
+
{ type: DateTimeAdapter, decorators: [{ type: Optional }] }
|
|
280
|
+
];
|
|
281
|
+
OwlTimerComponent.propDecorators = {
|
|
282
|
+
pickerMoment: [{ type: Input }],
|
|
283
|
+
minDateTime: [{ type: Input }],
|
|
284
|
+
maxDateTime: [{ type: Input }],
|
|
285
|
+
showSecondsTimer: [{ type: Input }],
|
|
286
|
+
hour12Timer: [{ type: Input }],
|
|
287
|
+
stepHour: [{ type: Input }],
|
|
288
|
+
stepMinute: [{ type: Input }],
|
|
289
|
+
stepSecond: [{ type: Input }],
|
|
290
|
+
selectedChange: [{ type: Output }]
|
|
291
|
+
};
|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timer.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/date-time/timer.component.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @angular-eslint/no-host-metadata-property */\n/**\n * timer.component\n */\n\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  EventEmitter,\n  Input,\n  NgZone,\n  OnInit,\n  Optional,\n  Output\n} from '@angular/core';\nimport { OwlDateTimeIntl } from './date-time-picker-intl.service';\nimport { DateTimeAdapter } from './adapter/date-time-adapter.class';\nimport { take } from 'rxjs/operators';\n\n@Component({\n  exportAs: 'owlDateTimeTimer',\n  selector: 'owl-date-time-timer',\n  templateUrl: './timer.component.html',\n  styleUrls: ['./timer.component.scss'],\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.owl-dt-timer]': 'owlDTTimerClass',\n    '[attr.tabindex]': 'owlDTTimeTabIndex'\n  }\n})\nexport class OwlTimerComponent<T> implements OnInit {\n  /** The current picker moment */\n  private _pickerMoment: T;\n  @Input()\n  get pickerMoment() {\n    return this._pickerMoment;\n  }\n\n  set pickerMoment(value: T) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._pickerMoment = this.getValidDate(value) || this.dateTimeAdapter.now();\n  }\n\n  /** The minimum selectable date time. */\n  private _minDateTime: T | null;\n  @Input()\n  get minDateTime(): T | null {\n    return this._minDateTime;\n  }\n\n  set minDateTime(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._minDateTime = this.getValidDate(value);\n  }\n\n  /** The maximum selectable date time. */\n  private _maxDateTime: T | null;\n  @Input()\n  get maxDateTime(): T | null {\n    return this._maxDateTime;\n  }\n\n  set maxDateTime(value: T | null) {\n    value = this.dateTimeAdapter.deserialize(value);\n    this._maxDateTime = this.getValidDate(value);\n  }\n\n  private isPM = false; // a flag indicates the current timer moment is in PM or AM\n\n  /**\n   * Whether to show the second's timer\n   */\n  @Input()\n  showSecondsTimer: boolean;\n\n  /**\n   * Whether the timer is in hour12 format\n   */\n  @Input()\n  hour12Timer: boolean;\n\n  /**\n   * Hours to change per step\n   */\n  @Input()\n  stepHour = 1;\n\n  /**\n   * Minutes to change per step\n   */\n  @Input()\n  stepMinute = 1;\n\n  /**\n   * Seconds to change per step\n   */\n  @Input()\n  stepSecond = 1;\n\n  get hourValue(): number {\n    return this.dateTimeAdapter.getHours(this.pickerMoment);\n  }\n\n  /**\n   * The value would be displayed in hourBox.\n   * We need this because the value displayed in hourBox it not\n   * the same as the hourValue when the timer is in hour12Timer mode.\n   * */\n  get hourBoxValue(): number {\n    let hours = this.hourValue;\n\n    if (!this.hour12Timer) {\n      return hours;\n    } else {\n      if (hours === 0) {\n        hours = 12;\n        this.isPM = false;\n      } else if (hours > 0 && hours < 12) {\n        this.isPM = false;\n      } else if (hours === 12) {\n        this.isPM = true;\n      } else if (hours > 12 && hours < 24) {\n        hours = hours - 12;\n        this.isPM = true;\n      }\n\n      return hours;\n    }\n  }\n\n  get minuteValue(): number {\n    return this.dateTimeAdapter.getMinutes(this.pickerMoment);\n  }\n\n  get secondValue(): number {\n    return this.dateTimeAdapter.getSeconds(this.pickerMoment);\n  }\n\n  get upHourButtonLabel(): string {\n    return this.pickerIntl.upHourLabel;\n  }\n\n  get downHourButtonLabel(): string {\n    return this.pickerIntl.downHourLabel;\n  }\n\n  get upMinuteButtonLabel(): string {\n    return this.pickerIntl.upMinuteLabel;\n  }\n\n  get downMinuteButtonLabel(): string {\n    return this.pickerIntl.downMinuteLabel;\n  }\n\n  get upSecondButtonLabel(): string {\n    return this.pickerIntl.upSecondLabel;\n  }\n\n  get downSecondButtonLabel(): string {\n    return this.pickerIntl.downSecondLabel;\n  }\n\n  get hour12ButtonLabel(): string {\n    return this.isPM\n      ? this.pickerIntl.hour12PMLabel\n      : this.pickerIntl.hour12AMLabel;\n  }\n\n  @Output()\n  selectedChange = new EventEmitter<T>();\n\n  get owlDTTimerClass(): boolean {\n    return true;\n  }\n\n  get owlDTTimeTabIndex(): number {\n    return -1;\n  }\n\n  constructor(\n    private ngZone: NgZone,\n    private elmRef: ElementRef,\n    private pickerIntl: OwlDateTimeIntl,\n    private cdRef: ChangeDetectorRef,\n    @Optional() private dateTimeAdapter: DateTimeAdapter<T>\n  ) {}\n\n  public ngOnInit() {}\n\n  /**\n   * Focus to the host element\n   * */\n  public focus() {\n    this.ngZone.runOutsideAngular(() => {\n      this.ngZone.onStable\n        .asObservable()\n        .pipe(take(1))\n        .subscribe(() => {\n          this.elmRef.nativeElement.focus();\n        });\n    });\n  }\n\n  /**\n   * Set the hour value via typing into timer box input\n   * We need this to handle the hour value when the timer is in hour12 mode\n   * */\n  public setHourValueViaInput(hours: number): void {\n    if (this.hour12Timer && this.isPM && hours >= 1 && hours <= 11) {\n      hours = hours + 12;\n    } else if (this.hour12Timer && !this.isPM && hours === 12) {\n      hours = 0;\n    }\n\n    this.setHourValue(hours);\n  }\n\n  public setHourValue(hours: number): void {\n    const m = this.dateTimeAdapter.setHours(this.pickerMoment, hours);\n    this.selectedChange.emit(m);\n    this.cdRef.markForCheck();\n  }\n\n  public setMinuteValue(minutes: number): void {\n    const m = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);\n    this.selectedChange.emit(m);\n    this.cdRef.markForCheck();\n  }\n\n  public setSecondValue(seconds: number): void {\n    const m = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);\n    this.selectedChange.emit(m);\n    this.cdRef.markForCheck();\n  }\n\n  public setMeridiem(event: any): void {\n    this.isPM = !this.isPM;\n\n    let hours = this.hourValue;\n    if (this.isPM) {\n      hours = hours + 12;\n    } else {\n      hours = hours - 12;\n    }\n\n    if (hours >= 0 && hours <= 23) {\n      this.setHourValue(hours);\n    }\n\n    this.cdRef.markForCheck();\n    event.preventDefault();\n  }\n\n  /**\n   * Check if the up hour button is enabled\n   */\n  public upHourEnabled(): boolean {\n    return (\n      !this.maxDateTime ||\n      this.compareHours(this.stepHour, this.maxDateTime) < 1\n    );\n  }\n\n  /**\n   * Check if the down hour button is enabled\n   */\n  public downHourEnabled(): boolean {\n    return (\n      !this.minDateTime ||\n      this.compareHours(-this.stepHour, this.minDateTime) > -1\n    );\n  }\n\n  /**\n   * Check if the up minute button is enabled\n   */\n  public upMinuteEnabled(): boolean {\n    return (\n      !this.maxDateTime ||\n      this.compareMinutes(this.stepMinute, this.maxDateTime) < 1\n    );\n  }\n\n  /**\n   * Check if the down minute button is enabled\n   */\n  public downMinuteEnabled(): boolean {\n    return (\n      !this.minDateTime ||\n      this.compareMinutes(-this.stepMinute, this.minDateTime) > -1\n    );\n  }\n\n  /**\n   * Check if the up second button is enabled\n   */\n  public upSecondEnabled(): boolean {\n    return (\n      !this.maxDateTime ||\n      this.compareSeconds(this.stepSecond, this.maxDateTime) < 1\n    );\n  }\n\n  /**\n   * Check if the down second button is enabled\n   */\n  public downSecondEnabled(): boolean {\n    return (\n      !this.minDateTime ||\n      this.compareSeconds(-this.stepSecond, this.minDateTime) > -1\n    );\n  }\n\n  /**\n   * PickerMoment's hour value +/- certain amount and compare it to the give date\n   * 1 is after the comparedDate\n   * -1 is before the comparedDate\n   * 0 is equal the comparedDate\n   * */\n  private compareHours(amount: number, comparedDate: T): number {\n    const hours = this.dateTimeAdapter.getHours(this.pickerMoment) + amount;\n    const result = this.dateTimeAdapter.setHours(this.pickerMoment, hours);\n    return this.dateTimeAdapter.compare(result, comparedDate);\n  }\n\n  /**\n   * PickerMoment's minute value +/- certain amount and compare it to the give date\n   * 1 is after the comparedDate\n   * -1 is before the comparedDate\n   * 0 is equal the comparedDate\n   * */\n  private compareMinutes(amount: number, comparedDate: T): number {\n    const minutes = this.dateTimeAdapter.getMinutes(this.pickerMoment) + amount;\n    const result = this.dateTimeAdapter.setMinutes(this.pickerMoment, minutes);\n    return this.dateTimeAdapter.compare(result, comparedDate);\n  }\n\n  /**\n   * PickerMoment's second value +/- certain amount and compare it to the give date\n   * 1 is after the comparedDate\n   * -1 is before the comparedDate\n   * 0 is equal the comparedDate\n   * */\n  private compareSeconds(amount: number, comparedDate: T): number {\n    const seconds = this.dateTimeAdapter.getSeconds(this.pickerMoment) + amount;\n    const result = this.dateTimeAdapter.setSeconds(this.pickerMoment, seconds);\n    return this.dateTimeAdapter.compare(result, comparedDate);\n  }\n\n  /**\n   * Get a valid date object\n   */\n  private getValidDate(obj: any): T | null {\n    return this.dateTimeAdapter.isDateInstance(obj) &&\n      this.dateTimeAdapter.isValid(obj)\n      ? obj\n      : null;\n  }\n}\n"]}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { NoopScrollStrategy } from '@angular/cdk/overlay';
|
|
2
|
+
let uniqueId = 0;
|
|
3
|
+
export class OwlDialogConfig {
|
|
4
|
+
constructor() {
|
|
5
|
+
/**
|
|
6
|
+
* ID of the element that describes the dialog.
|
|
7
|
+
*/
|
|
8
|
+
this.ariaDescribedBy = null;
|
|
9
|
+
/**
|
|
10
|
+
* Whether to focus the dialog when the dialog is opened
|
|
11
|
+
*/
|
|
12
|
+
this.autoFocus = true;
|
|
13
|
+
/** Whether the dialog has a backdrop. */
|
|
14
|
+
this.hasBackdrop = true;
|
|
15
|
+
/** Data being injected into the child component. */
|
|
16
|
+
this.data = null;
|
|
17
|
+
/** Whether the user can use escape or clicking outside to close a modal. */
|
|
18
|
+
this.disableClose = false;
|
|
19
|
+
/**
|
|
20
|
+
* The ARIA role of the dialog element.
|
|
21
|
+
*/
|
|
22
|
+
this.role = 'dialog';
|
|
23
|
+
/**
|
|
24
|
+
* Custom class for the pane
|
|
25
|
+
* */
|
|
26
|
+
this.paneClass = '';
|
|
27
|
+
/**
|
|
28
|
+
* Mouse Event
|
|
29
|
+
* */
|
|
30
|
+
this.event = null;
|
|
31
|
+
/**
|
|
32
|
+
* Custom class for the backdrop
|
|
33
|
+
* */
|
|
34
|
+
this.backdropClass = '';
|
|
35
|
+
/**
|
|
36
|
+
* Whether the dialog should close when the user goes backwards/forwards in history.
|
|
37
|
+
* */
|
|
38
|
+
this.closeOnNavigation = true;
|
|
39
|
+
/** Width of the dialog. */
|
|
40
|
+
this.width = '';
|
|
41
|
+
/** Height of the dialog. */
|
|
42
|
+
this.height = '';
|
|
43
|
+
/**
|
|
44
|
+
* The max-width of the overlay panel.
|
|
45
|
+
* If a number is provided, pixel units are assumed.
|
|
46
|
+
* */
|
|
47
|
+
this.maxWidth = '85vw';
|
|
48
|
+
/**
|
|
49
|
+
* The scroll strategy when the dialog is open
|
|
50
|
+
* Learn more this from https://material.angular.io/cdk/overlay/overview#scroll-strategies
|
|
51
|
+
* */
|
|
52
|
+
this.scrollStrategy = new NoopScrollStrategy();
|
|
53
|
+
this.id = `owl-dialog-${uniqueId++}`;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWNvbmZpZy5jbGFzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1mb3JtZW50cnkvc3JjL2NvbXBvbmVudHMvbmd4LXBpY2stZGF0ZXRpbWUvbGliL2RpYWxvZy9kaWFsb2ctY29uZmlnLmNsYXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUlBLE9BQU8sRUFBRSxrQkFBa0IsRUFBa0IsTUFBTSxzQkFBc0IsQ0FBQztBQUUxRSxJQUFJLFFBQVEsR0FBRyxDQUFDLENBQUM7QUFpQmpCLE1BQU0sT0FBTyxlQUFlO0lBZ0cxQjtRQS9GQTs7V0FFRztRQUNJLG9CQUFlLEdBQW1CLElBQUksQ0FBQztRQUU5Qzs7V0FFRztRQUNJLGNBQVMsR0FBSSxJQUFJLENBQUM7UUFFekIseUNBQXlDO1FBQ2xDLGdCQUFXLEdBQUksSUFBSSxDQUFDO1FBTzNCLG9EQUFvRDtRQUM3QyxTQUFJLEdBQVMsSUFBSSxDQUFDO1FBRXpCLDRFQUE0RTtRQUNyRSxpQkFBWSxHQUFJLEtBQUssQ0FBQztRQU83Qjs7V0FFRztRQUNJLFNBQUksR0FBOEIsUUFBUSxDQUFDO1FBRWxEOzthQUVLO1FBQ0UsY0FBUyxHQUF1QixFQUFFLENBQUM7UUFFMUM7O2FBRUs7UUFDRSxVQUFLLEdBQWdCLElBQUksQ0FBQztRQUVqQzs7YUFFSztRQUNFLGtCQUFhLEdBQXVCLEVBQUUsQ0FBQztRQUU5Qzs7YUFFSztRQUNFLHNCQUFpQixHQUFHLElBQUksQ0FBQztRQUVoQywyQkFBMkI7UUFDcEIsVUFBSyxHQUFHLEVBQUUsQ0FBQztRQUVsQiw0QkFBNEI7UUFDckIsV0FBTSxHQUFHLEVBQUUsQ0FBQztRQWNuQjs7O2FBR0s7UUFDRSxhQUFRLEdBQXFCLE1BQU0sQ0FBQztRQVczQzs7O2FBR0s7UUFDRSxtQkFBYyxHQUFvQixJQUFJLGtCQUFrQixFQUFFLENBQUM7UUFLaEUsSUFBSSxDQUFDLEVBQUUsR0FBRyxjQUFjLFFBQVEsRUFBRSxFQUFFLENBQUM7SUFDdkMsQ0FBQztDQUNGIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBkaWFsb2ctY29uZmlnLmNsYXNzXG4gKi9cbmltcG9ydCB7IFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE5vb3BTY3JvbGxTdHJhdGVneSwgU2Nyb2xsU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5cbmxldCB1bmlxdWVJZCA9IDA7XG5cbi8qKiBQb3NzaWJsZSBvdmVycmlkZXMgZm9yIGEgZGlhbG9nJ3MgcG9zaXRpb24uICovXG5leHBvcnQgaW50ZXJmYWNlIERpYWxvZ1Bvc2l0aW9uIHtcbiAgLyoqIE92ZXJyaWRlIGZvciB0aGUgZGlhbG9nJ3MgdG9wIHBvc2l0aW9uLiAqL1xuICB0b3A/OiBzdHJpbmc7XG5cbiAgLyoqIE92ZXJyaWRlIGZvciB0aGUgZGlhbG9nJ3MgYm90dG9tIHBvc2l0aW9uLiAqL1xuICBib3R0b20/OiBzdHJpbmc7XG5cbiAgLyoqIE92ZXJyaWRlIGZvciB0aGUgZGlhbG9nJ3MgbGVmdCBwb3NpdGlvbi4gKi9cbiAgbGVmdD86IHN0cmluZztcblxuICAvKiogT3ZlcnJpZGUgZm9yIHRoZSBkaWFsb2cncyByaWdodCBwb3NpdGlvbi4gKi9cbiAgcmlnaHQ/OiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjbGFzcyBPd2xEaWFsb2dDb25maWcge1xuICAvKipcbiAgICogSUQgb2YgdGhlIGVsZW1lbnQgdGhhdCBkZXNjcmliZXMgdGhlIGRpYWxvZy5cbiAgICovXG4gIHB1YmxpYyBhcmlhRGVzY3JpYmVkQnk/OiBzdHJpbmcgfCBudWxsID0gbnVsbDtcblxuICAvKipcbiAgICogV2hldGhlciB0byBmb2N1cyB0aGUgZGlhbG9nIHdoZW4gdGhlIGRpYWxvZyBpcyBvcGVuZWRcbiAgICovXG4gIHB1YmxpYyBhdXRvRm9jdXM/ID0gdHJ1ZTtcblxuICAvKiogV2hldGhlciB0aGUgZGlhbG9nIGhhcyBhIGJhY2tkcm9wLiAqL1xuICBwdWJsaWMgaGFzQmFja2Ryb3A/ID0gdHJ1ZTtcblxuICAvKipcbiAgICogQ3VzdG9tIHN0eWxlIGZvciB0aGUgYmFja2Ryb3BcbiAgICogKi9cbiAgcHVibGljIGJhY2tkcm9wU3R5bGU/OiBhbnk7XG5cbiAgLyoqIERhdGEgYmVpbmcgaW5qZWN0ZWQgaW50byB0aGUgY2hpbGQgY29tcG9uZW50LiAqL1xuICBwdWJsaWMgZGF0YT86IGFueSA9IG51bGw7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIHVzZXIgY2FuIHVzZSBlc2NhcGUgb3IgY2xpY2tpbmcgb3V0c2lkZSB0byBjbG9zZSBhIG1vZGFsLiAqL1xuICBwdWJsaWMgZGlzYWJsZUNsb3NlPyA9IGZhbHNlO1xuXG4gIC8qKlxuICAgKiBJRCBmb3IgdGhlIG1vZGFsLiBJZiBvbWl0dGVkLCBhIHVuaXF1ZSBvbmUgd2lsbCBiZSBnZW5lcmF0ZWQuXG4gICAqL1xuICBwdWJsaWMgaWQ/OiBzdHJpbmc7XG5cbiAgLyoqXG4gICAqIFRoZSBBUklBIHJvbGUgb2YgdGhlIGRpYWxvZyBlbGVtZW50LlxuICAgKi9cbiAgcHVibGljIHJvbGU/OiAnZGlhbG9nJyB8ICdhbGVydGRpYWxvZycgPSAnZGlhbG9nJztcblxuICAvKipcbiAgICogQ3VzdG9tIGNsYXNzIGZvciB0aGUgcGFuZVxuICAgKiAqL1xuICBwdWJsaWMgcGFuZUNsYXNzPzogc3RyaW5nIHwgc3RyaW5nW10gPSAnJztcblxuICAvKipcbiAgICogTW91c2UgRXZlbnRcbiAgICogKi9cbiAgcHVibGljIGV2ZW50PzogTW91c2VFdmVudCA9IG51bGw7XG5cbiAgLyoqXG4gICAqIEN1c3RvbSBjbGFzcyBmb3IgdGhlIGJhY2tkcm9wXG4gICAqICovXG4gIHB1YmxpYyBiYWNrZHJvcENsYXNzPzogc3RyaW5nIHwgc3RyaW5nW10gPSAnJztcblxuICAvKipcbiAgICogV2hldGhlciB0aGUgZGlhbG9nIHNob3VsZCBjbG9zZSB3aGVuIHRoZSB1c2VyIGdvZXMgYmFja3dhcmRzL2ZvcndhcmRzIGluIGhpc3RvcnkuXG4gICAqICovXG4gIHB1YmxpYyBjbG9zZU9uTmF2aWdhdGlvbiA9IHRydWU7XG5cbiAgLyoqIFdpZHRoIG9mIHRoZSBkaWFsb2cuICovXG4gIHB1YmxpYyB3aWR0aCA9ICcnO1xuXG4gIC8qKiBIZWlnaHQgb2YgdGhlIGRpYWxvZy4gKi9cbiAgcHVibGljIGhlaWdodCA9ICcnO1xuXG4gIC8qKlxuICAgKiBUaGUgbWluLXdpZHRoIG9mIHRoZSBvdmVybGF5IHBhbmVsLlxuICAgKiBJZiBhIG51bWJlciBpcyBwcm92aWRlZCwgcGl4ZWwgdW5pdHMgYXJlIGFzc3VtZWQuXG4gICAqICovXG4gIHB1YmxpYyBtaW5XaWR0aD86IG51bWJlciB8IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIG1pbi1oZWlnaHQgb2YgdGhlIG92ZXJsYXkgcGFuZWwuXG4gICAqIElmIGEgbnVtYmVyIGlzIHByb3ZpZGVkLCBwaXhlbCB1bml0cyBhcmUgYXNzdW1lZC5cbiAgICogKi9cbiAgcHVibGljIG1pbkhlaWdodD86IG51bWJlciB8IHN0cmluZztcblxuICAvKipcbiAgICogVGhlIG1heC13aWR0aCBvZiB0aGUgb3ZlcmxheSBwYW5lbC5cbiAgICogSWYgYSBudW1iZXIgaXMgcHJvdmlkZWQsIHBpeGVsIHVuaXRzIGFyZSBhc3N1bWVkLlxuICAgKiAqL1xuICBwdWJsaWMgbWF4V2lkdGg/OiBudW1iZXIgfCBzdHJpbmcgPSAnODV2dyc7XG5cbiAgLyoqXG4gICAqIFRoZSBtYXgtaGVpZ2h0IG9mIHRoZSBvdmVybGF5IHBhbmVsLlxuICAgKiBJZiBhIG51bWJlciBpcyBwcm92aWRlZCwgcGl4ZWwgdW5pdHMgYXJlIGFzc3VtZWQuXG4gICAqICovXG4gIHB1YmxpYyBtYXhIZWlnaHQ/OiBudW1iZXIgfCBzdHJpbmc7XG5cbiAgLyoqIFBvc2l0aW9uIG92ZXJyaWRlcy4gKi9cbiAgcHVibGljIHBvc2l0aW9uPzogRGlhbG9nUG9zaXRpb247XG5cbiAgLyoqXG4gICAqIFRoZSBzY3JvbGwgc3RyYXRlZ3kgd2hlbiB0aGUgZGlhbG9nIGlzIG9wZW5cbiAgICogTGVhcm4gbW9yZSB0aGlzIGZyb20gaHR0cHM6Ly9tYXRlcmlhbC5hbmd1bGFyLmlvL2Nkay9vdmVybGF5L292ZXJ2aWV3I3Njcm9sbC1zdHJhdGVnaWVzXG4gICAqICovXG4gIHB1YmxpYyBzY3JvbGxTdHJhdGVneT86IFNjcm9sbFN0cmF0ZWd5ID0gbmV3IE5vb3BTY3JvbGxTdHJhdGVneSgpO1xuXG4gIHB1YmxpYyB2aWV3Q29udGFpbmVyUmVmPzogVmlld0NvbnRhaW5lclJlZjtcblxuICBjb25zdHJ1Y3RvcigpIHtcbiAgICB0aGlzLmlkID0gYG93bC1kaWFsb2ctJHt1bmlxdWVJZCsrfWA7XG4gIH1cbn1cbiJdfQ==
|
|
@@ -0,0 +1,208 @@
|
|
|
1
|
+
/* eslint-disable @angular-eslint/no-host-metadata-property */
|
|
2
|
+
/**
|
|
3
|
+
* dialog-container.component
|
|
4
|
+
*/
|
|
5
|
+
import { ChangeDetectorRef, Component, ElementRef, EventEmitter, Inject, Optional, ViewChild } from '@angular/core';
|
|
6
|
+
import { animate, animateChild, keyframes, style, transition, trigger } from '@angular/animations';
|
|
7
|
+
import { DOCUMENT } from '@angular/common';
|
|
8
|
+
import { FocusTrapFactory } from '@angular/cdk/a11y';
|
|
9
|
+
import { BasePortalOutlet, CdkPortalOutlet } from '@angular/cdk/portal';
|
|
10
|
+
const zoomFadeIn = {
|
|
11
|
+
opacity: 0,
|
|
12
|
+
transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})'
|
|
13
|
+
};
|
|
14
|
+
const zoomFadeInFrom = {
|
|
15
|
+
opacity: 0,
|
|
16
|
+
transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})',
|
|
17
|
+
transformOrigin: '{{ ox }} {{ oy }}'
|
|
18
|
+
};
|
|
19
|
+
export class OwlDialogContainerComponent extends BasePortalOutlet {
|
|
20
|
+
constructor(changeDetector, elementRef, focusTrapFactory, document) {
|
|
21
|
+
super();
|
|
22
|
+
this.changeDetector = changeDetector;
|
|
23
|
+
this.elementRef = elementRef;
|
|
24
|
+
this.focusTrapFactory = focusTrapFactory;
|
|
25
|
+
this.document = document;
|
|
26
|
+
/** ID of the element that should be considered as the dialog's label. */
|
|
27
|
+
this.ariaLabelledBy = null;
|
|
28
|
+
/** Emits when an animation state changes. */
|
|
29
|
+
this.animationStateChanged = new EventEmitter();
|
|
30
|
+
this.isAnimating = false;
|
|
31
|
+
this.state = 'enter';
|
|
32
|
+
// for animation purpose
|
|
33
|
+
this.params = {
|
|
34
|
+
x: '0px',
|
|
35
|
+
y: '0px',
|
|
36
|
+
ox: '50%',
|
|
37
|
+
oy: '50%',
|
|
38
|
+
scale: 0
|
|
39
|
+
};
|
|
40
|
+
// A variable to hold the focused element before the dialog was open.
|
|
41
|
+
// This would help us to refocus back to element when the dialog was closed.
|
|
42
|
+
this.elementFocusedBeforeDialogWasOpened = null;
|
|
43
|
+
}
|
|
44
|
+
get config() {
|
|
45
|
+
return this._config;
|
|
46
|
+
}
|
|
47
|
+
get owlDialogContainerClass() {
|
|
48
|
+
return true;
|
|
49
|
+
}
|
|
50
|
+
get owlDialogContainerTabIndex() {
|
|
51
|
+
return -1;
|
|
52
|
+
}
|
|
53
|
+
get owlDialogContainerId() {
|
|
54
|
+
return this._config.id;
|
|
55
|
+
}
|
|
56
|
+
get owlDialogContainerRole() {
|
|
57
|
+
return this._config.role || null;
|
|
58
|
+
}
|
|
59
|
+
get owlDialogContainerAriaLabelledby() {
|
|
60
|
+
return this.ariaLabelledBy;
|
|
61
|
+
}
|
|
62
|
+
get owlDialogContainerAriaDescribedby() {
|
|
63
|
+
return this._config.ariaDescribedBy || null;
|
|
64
|
+
}
|
|
65
|
+
get owlDialogContainerAnimation() {
|
|
66
|
+
return { value: this.state, params: this.params };
|
|
67
|
+
}
|
|
68
|
+
ngOnInit() { }
|
|
69
|
+
/**
|
|
70
|
+
* Attach a ComponentPortal as content to this dialog container.
|
|
71
|
+
*/
|
|
72
|
+
attachComponentPortal(portal) {
|
|
73
|
+
if (this.portalOutlet.hasAttached()) {
|
|
74
|
+
throw Error('Attempting to attach dialog content after content is already attached');
|
|
75
|
+
}
|
|
76
|
+
this.savePreviouslyFocusedElement();
|
|
77
|
+
return this.portalOutlet.attachComponentPortal(portal);
|
|
78
|
+
}
|
|
79
|
+
attachTemplatePortal(portal) {
|
|
80
|
+
throw new Error('Method not implemented.');
|
|
81
|
+
}
|
|
82
|
+
setConfig(config) {
|
|
83
|
+
this._config = config;
|
|
84
|
+
if (config.event) {
|
|
85
|
+
this.calculateZoomOrigin(event);
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
onAnimationStart(event) {
|
|
89
|
+
this.isAnimating = true;
|
|
90
|
+
this.animationStateChanged.emit(event);
|
|
91
|
+
}
|
|
92
|
+
onAnimationDone(event) {
|
|
93
|
+
if (event.toState === 'enter') {
|
|
94
|
+
this.trapFocus();
|
|
95
|
+
}
|
|
96
|
+
else if (event.toState === 'exit') {
|
|
97
|
+
this.restoreFocus();
|
|
98
|
+
}
|
|
99
|
+
this.animationStateChanged.emit(event);
|
|
100
|
+
this.isAnimating = false;
|
|
101
|
+
}
|
|
102
|
+
startExitAnimation() {
|
|
103
|
+
this.state = 'exit';
|
|
104
|
+
this.changeDetector.markForCheck();
|
|
105
|
+
}
|
|
106
|
+
/**
|
|
107
|
+
* Calculate origin used in the `zoomFadeInFrom()`
|
|
108
|
+
* for animation purpose
|
|
109
|
+
*/
|
|
110
|
+
calculateZoomOrigin(event) {
|
|
111
|
+
if (!event) {
|
|
112
|
+
return;
|
|
113
|
+
}
|
|
114
|
+
const clientX = event.clientX;
|
|
115
|
+
const clientY = event.clientY;
|
|
116
|
+
const wh = window.innerWidth / 2;
|
|
117
|
+
const hh = window.innerHeight / 2;
|
|
118
|
+
const x = clientX - wh;
|
|
119
|
+
const y = clientY - hh;
|
|
120
|
+
const ox = clientX / window.innerWidth;
|
|
121
|
+
const oy = clientY / window.innerHeight;
|
|
122
|
+
this.params.x = `${x}px`;
|
|
123
|
+
this.params.y = `${y}px`;
|
|
124
|
+
this.params.ox = `${ox * 100}%`;
|
|
125
|
+
this.params.oy = `${oy * 100}%`;
|
|
126
|
+
this.params.scale = 0;
|
|
127
|
+
return;
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Save the focused element before dialog was open
|
|
131
|
+
*/
|
|
132
|
+
savePreviouslyFocusedElement() {
|
|
133
|
+
if (this.document) {
|
|
134
|
+
this.elementFocusedBeforeDialogWasOpened = this.document
|
|
135
|
+
.activeElement;
|
|
136
|
+
Promise.resolve().then(() => this.elementRef.nativeElement.focus());
|
|
137
|
+
}
|
|
138
|
+
}
|
|
139
|
+
trapFocus() {
|
|
140
|
+
if (!this.focusTrap) {
|
|
141
|
+
this.focusTrap = this.focusTrapFactory.create(this.elementRef.nativeElement);
|
|
142
|
+
}
|
|
143
|
+
if (this._config.autoFocus) {
|
|
144
|
+
this.focusTrap.focusInitialElementWhenReady();
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
restoreFocus() {
|
|
148
|
+
const toFocus = this.elementFocusedBeforeDialogWasOpened;
|
|
149
|
+
// We need the extra check, because IE can set the `activeElement` to null in some cases.
|
|
150
|
+
if (toFocus && typeof toFocus.focus === 'function') {
|
|
151
|
+
toFocus.focus();
|
|
152
|
+
}
|
|
153
|
+
if (this.focusTrap) {
|
|
154
|
+
this.focusTrap.destroy();
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
OwlDialogContainerComponent.decorators = [
|
|
159
|
+
{ type: Component, args: [{
|
|
160
|
+
selector: 'owl-dialog-container',
|
|
161
|
+
template: "<ng-template cdkPortalOutlet></ng-template>\n",
|
|
162
|
+
animations: [
|
|
163
|
+
trigger('slideModal', [
|
|
164
|
+
transition('void => enter', [
|
|
165
|
+
style(zoomFadeInFrom),
|
|
166
|
+
animate('300ms cubic-bezier(0.35, 0, 0.25, 1)', style('*')),
|
|
167
|
+
animate('150ms', keyframes([
|
|
168
|
+
style({ transform: 'scale(1)', offset: 0 }),
|
|
169
|
+
style({ transform: 'scale(1.05)', offset: 0.3 }),
|
|
170
|
+
style({ transform: 'scale(.95)', offset: 0.8 }),
|
|
171
|
+
style({ transform: 'scale(1)', offset: 1.0 })
|
|
172
|
+
])),
|
|
173
|
+
animateChild()
|
|
174
|
+
], {
|
|
175
|
+
params: {
|
|
176
|
+
x: '0px',
|
|
177
|
+
y: '0px',
|
|
178
|
+
ox: '50%',
|
|
179
|
+
oy: '50%',
|
|
180
|
+
scale: 1
|
|
181
|
+
}
|
|
182
|
+
}),
|
|
183
|
+
transition('enter => exit', [animateChild(), animate(200, style(zoomFadeIn))], { params: { x: '0px', y: '0px', ox: '50%', oy: '50%' } })
|
|
184
|
+
])
|
|
185
|
+
],
|
|
186
|
+
host: {
|
|
187
|
+
'(@slideModal.start)': 'onAnimationStart($event)',
|
|
188
|
+
'(@slideModal.done)': 'onAnimationDone($event)',
|
|
189
|
+
'[class.owl-dialog-container]': 'owlDialogContainerClass',
|
|
190
|
+
'[attr.tabindex]': 'owlDialogContainerTabIndex',
|
|
191
|
+
'[attr.id]': 'owlDialogContainerId',
|
|
192
|
+
'[attr.role]': 'owlDialogContainerRole',
|
|
193
|
+
'[attr.aria-labelledby]': 'owlDialogContainerAriaLabelledby',
|
|
194
|
+
'[attr.aria-describedby]': 'owlDialogContainerAriaDescribedby',
|
|
195
|
+
'[@slideModal]': 'owlDialogContainerAnimation'
|
|
196
|
+
}
|
|
197
|
+
},] }
|
|
198
|
+
];
|
|
199
|
+
OwlDialogContainerComponent.ctorParameters = () => [
|
|
200
|
+
{ type: ChangeDetectorRef },
|
|
201
|
+
{ type: ElementRef },
|
|
202
|
+
{ type: FocusTrapFactory },
|
|
203
|
+
{ type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [DOCUMENT,] }] }
|
|
204
|
+
];
|
|
205
|
+
OwlDialogContainerComponent.propDecorators = {
|
|
206
|
+
portalOutlet: [{ type: ViewChild, args: [CdkPortalOutlet, { static: true },] }]
|
|
207
|
+
};
|
|
208
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dialog-container.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-formentry/src/components/ngx-pick-datetime/lib/dialog/dialog-container.component.ts"],"names":[],"mappings":"AAAA,8DAA8D;AAC9D;;GAEG;AAEH,OAAO,EACL,iBAAiB,EACjB,SAAS,EAET,UAAU,EAEV,YAAY,EACZ,MAAM,EAEN,QAAQ,EACR,SAAS,EACV,MAAM,eAAe,CAAC;AACvB,OAAO,EACL,OAAO,EACP,YAAY,EAEZ,SAAS,EACT,KAAK,EACL,UAAU,EACV,OAAO,EACR,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAa,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAChE,OAAO,EACL,gBAAgB,EAChB,eAAe,EAGhB,MAAM,qBAAqB,CAAC;AAG7B,MAAM,UAAU,GAAG;IACjB,OAAO,EAAE,CAAC;IACV,SAAS,EAAE,0DAA0D;CACtE,CAAC;AACF,MAAM,cAAc,GAAG;IACrB,OAAO,EAAE,CAAC;IACV,SAAS,EAAE,0DAA0D;IACrE,eAAe,EAAE,mBAAmB;CACrC,CAAC;AAoDF,MAAM,OAAO,2BACX,SAAQ,gBAAgB;IAgExB,YACU,cAAiC,EACjC,UAAsB,EACtB,gBAAkC,EAGlC,QAAa;QAErB,KAAK,EAAE,CAAC;QAPA,mBAAc,GAAd,cAAc,CAAmB;QACjC,eAAU,GAAV,UAAU,CAAY;QACtB,qBAAgB,GAAhB,gBAAgB,CAAkB;QAGlC,aAAQ,GAAR,QAAQ,CAAK;QA9DvB,yEAAyE;QAClE,mBAAc,GAAkB,IAAI,CAAC;QAE5C,6CAA6C;QACtC,0BAAqB,GAAG,IAAI,YAAY,EAAkB,CAAC;QAE3D,gBAAW,GAAG,KAAK,CAAC;QAOnB,UAAK,GAA8B,OAAO,CAAC;QAEnD,wBAAwB;QAChB,WAAM,GAAQ;YACpB,CAAC,EAAE,KAAK;YACR,CAAC,EAAE,KAAK;YACR,EAAE,EAAE,KAAK;YACT,EAAE,EAAE,KAAK;YACT,KAAK,EAAE,CAAC;SACT,CAAC;QAEF,qEAAqE;QACrE,4EAA4E;QACpE,wCAAmC,GAAuB,IAAI,CAAC;IAuCvE,CAAC;IAxDD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;IAiBD,IAAI,uBAAuB;QACzB,OAAO,IAAI,CAAC;IACd,CAAC;IAED,IAAI,0BAA0B;QAC5B,OAAO,CAAC,CAAC,CAAC;IACZ,CAAC;IAED,IAAI,oBAAoB;QACtB,OAAO,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC;IACzB,CAAC;IAED,IAAI,sBAAsB;QACxB,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,IAAI,IAAI,CAAC;IACnC,CAAC;IAED,IAAI,gCAAgC;QAClC,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAED,IAAI,iCAAiC;QACnC,OAAO,IAAI,CAAC,OAAO,CAAC,eAAe,IAAI,IAAI,CAAC;IAC9C,CAAC;IAED,IAAI,2BAA2B;QAC7B,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,CAAC;IACpD,CAAC;IAaM,QAAQ,KAAI,CAAC;IAEpB;;OAEG;IACI,qBAAqB,CAAI,MAA0B;QACxD,IAAI,IAAI,CAAC,YAAY,CAAC,WAAW,EAAE,EAAE;YACnC,MAAM,KAAK,CACT,uEAAuE,CACxE,CAAC;SACH;QAED,IAAI,CAAC,4BAA4B,EAAE,CAAC;QACpC,OAAO,IAAI,CAAC,YAAY,CAAC,qBAAqB,CAAC,MAAM,CAAC,CAAC;IACzD,CAAC;IAEM,oBAAoB,CACzB,MAAyB;QAEzB,MAAM,IAAI,KAAK,CAAC,yBAAyB,CAAC,CAAC;IAC7C,CAAC;IAEM,SAAS,CAAC,MAAuB;QACtC,IAAI,CAAC,OAAO,GAAG,MAAM,CAAC;QAEtB,IAAI,MAAM,CAAC,KAAK,EAAE;YAChB,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,CAAC;SACjC;IACH,CAAC;IAEM,gBAAgB,CAAC,KAAqB;QAC3C,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;QACxB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAEM,eAAe,CAAC,KAAqB;QAC1C,IAAI,KAAK,CAAC,OAAO,KAAK,OAAO,EAAE;YAC7B,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;aAAM,IAAI,KAAK,CAAC,OAAO,KAAK,MAAM,EAAE;YACnC,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;QAED,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACvC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;IAC3B,CAAC;IAEM,kBAAkB;QACvB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC;QACpB,IAAI,CAAC,cAAc,CAAC,YAAY,EAAE,CAAC;IACrC,CAAC;IAED;;;OAGG;IACK,mBAAmB,CAAC,KAAU;QACpC,IAAI,CAAC,KAAK,EAAE;YACV,OAAO;SACR;QAED,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAC9B,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;QAE9B,MAAM,EAAE,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,CAAC;QACjC,MAAM,EAAE,GAAG,MAAM,CAAC,WAAW,GAAG,CAAC,CAAC;QAClC,MAAM,CAAC,GAAG,OAAO,GAAG,EAAE,CAAC;QACvB,MAAM,CAAC,GAAG,OAAO,GAAG,EAAE,CAAC;QACvB,MAAM,EAAE,GAAG,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC;QACvC,MAAM,EAAE,GAAG,OAAO,GAAG,MAAM,CAAC,WAAW,CAAC;QAExC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,GAAG,CAAC,IAAI,CAAC;QACzB,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,GAAG,EAAE,GAAG,GAAG,GAAG,CAAC;QAChC,IAAI,CAAC,MAAM,CAAC,KAAK,GAAG,CAAC,CAAC;QAEtB,OAAO;IACT,CAAC;IAED;;OAEG;IACK,4BAA4B;QAClC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,mCAAmC,GAAG,IAAI,CAAC,QAAQ;iBACrD,aAA4B,CAAC;YAEhC,OAAO,CAAC,OAAO,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC,CAAC;SACrE;IACH,CAAC;IAEO,SAAS;QACf,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAC3C,IAAI,CAAC,UAAU,CAAC,aAAa,CAC9B,CAAC;SACH;QAED,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,EAAE;YAC1B,IAAI,CAAC,SAAS,CAAC,4BAA4B,EAAE,CAAC;SAC/C;IACH,CAAC;IAEO,YAAY;QAClB,MAAM,OAAO,GAAG,IAAI,CAAC,mCAAmC,CAAC;QAEzD,yFAAyF;QACzF,IAAI,OAAO,IAAI,OAAO,OAAO,CAAC,KAAK,KAAK,UAAU,EAAE;YAClD,OAAO,CAAC,KAAK,EAAE,CAAC;SACjB;QAED,IAAI,IAAI,CAAC,SAAS,EAAE;YAClB,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;SAC1B;IACH,CAAC;;;YAhPF,SAAS,SAAC;gBACT,QAAQ,EAAE,sBAAsB;gBAChC,yDAAgD;gBAChD,UAAU,EAAE;oBACV,OAAO,CAAC,YAAY,EAAE;wBACpB,UAAU,CACR,eAAe,EACf;4BACE,KAAK,CAAC,cAAc,CAAC;4BACrB,OAAO,CAAC,sCAAsC,EAAE,KAAK,CAAC,GAAG,CAAC,CAAC;4BAC3D,OAAO,CACL,OAAO,EACP,SAAS,CAAC;gCACR,KAAK,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC;gCAC3C,KAAK,CAAC,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;gCAChD,KAAK,CAAC,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;gCAC/C,KAAK,CAAC,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,EAAE,GAAG,EAAE,CAAC;6BAC9C,CAAC,CACH;4BACD,YAAY,EAAE;yBACf,EACD;4BACE,MAAM,EAAE;gCACN,CAAC,EAAE,KAAK;gCACR,CAAC,EAAE,KAAK;gCACR,EAAE,EAAE,KAAK;gCACT,EAAE,EAAE,KAAK;gCACT,KAAK,EAAE,CAAC;6BACT;yBACF,CACF;wBACD,UAAU,CACR,eAAe,EACf,CAAC,YAAY,EAAE,EAAE,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,UAAU,CAAC,CAAC,CAAC,EACjD,EAAE,MAAM,EAAE,EAAE,CAAC,EAAE,KAAK,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,EAAE,KAAK,EAAE,EAAE,CACzD;qBACF,CAAC;iBACH;gBACD,IAAI,EAAE;oBACJ,qBAAqB,EAAE,0BAA0B;oBACjD,oBAAoB,EAAE,yBAAyB;oBAC/C,8BAA8B,EAAE,yBAAyB;oBACzD,iBAAiB,EAAE,4BAA4B;oBAC/C,WAAW,EAAE,sBAAsB;oBACnC,aAAa,EAAE,wBAAwB;oBACvC,wBAAwB,EAAE,kCAAkC;oBAC5D,yBAAyB,EAAE,mCAAmC;oBAC9D,eAAe,EAAE,6BAA6B;iBAC/C;aACF;;;YAzFC,iBAAiB;YAGjB,UAAU;YAkBQ,gBAAgB;4CA0I/B,QAAQ,YACR,MAAM,SAAC,QAAQ;;;2BAnEjB,SAAS,SAAC,eAAe,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE","sourcesContent":["/* eslint-disable @angular-eslint/no-host-metadata-property */\n/**\n * dialog-container.component\n */\n\nimport {\n  ChangeDetectorRef,\n  Component,\n  ComponentRef,\n  ElementRef,\n  EmbeddedViewRef,\n  EventEmitter,\n  Inject,\n  OnInit,\n  Optional,\n  ViewChild\n} from '@angular/core';\nimport {\n  animate,\n  animateChild,\n  AnimationEvent,\n  keyframes,\n  style,\n  transition,\n  trigger\n} from '@angular/animations';\nimport { DOCUMENT } from '@angular/common';\nimport { FocusTrap, FocusTrapFactory } from '@angular/cdk/a11y';\nimport {\n  BasePortalOutlet,\n  CdkPortalOutlet,\n  ComponentPortal,\n  TemplatePortal\n} from '@angular/cdk/portal';\nimport { OwlDialogConfig } from './dialog-config.class';\n\nconst zoomFadeIn = {\n  opacity: 0,\n  transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})'\n};\nconst zoomFadeInFrom = {\n  opacity: 0,\n  transform: 'translateX({{ x }}) translateY({{ y }}) scale({{scale}})',\n  transformOrigin: '{{ ox }} {{ oy }}'\n};\n\n@Component({\n  selector: 'owl-dialog-container',\n  templateUrl: './dialog-container.component.html',\n  animations: [\n    trigger('slideModal', [\n      transition(\n        'void => enter',\n        [\n          style(zoomFadeInFrom),\n          animate('300ms cubic-bezier(0.35, 0, 0.25, 1)', style('*')),\n          animate(\n            '150ms',\n            keyframes([\n              style({ transform: 'scale(1)', offset: 0 }),\n              style({ transform: 'scale(1.05)', offset: 0.3 }),\n              style({ transform: 'scale(.95)', offset: 0.8 }),\n              style({ transform: 'scale(1)', offset: 1.0 })\n            ])\n          ),\n          animateChild()\n        ],\n        {\n          params: {\n            x: '0px',\n            y: '0px',\n            ox: '50%',\n            oy: '50%',\n            scale: 1\n          }\n        }\n      ),\n      transition(\n        'enter => exit',\n        [animateChild(), animate(200, style(zoomFadeIn))],\n        { params: { x: '0px', y: '0px', ox: '50%', oy: '50%' } }\n      )\n    ])\n  ],\n  host: {\n    '(@slideModal.start)': 'onAnimationStart($event)',\n    '(@slideModal.done)': 'onAnimationDone($event)',\n    '[class.owl-dialog-container]': 'owlDialogContainerClass',\n    '[attr.tabindex]': 'owlDialogContainerTabIndex',\n    '[attr.id]': 'owlDialogContainerId',\n    '[attr.role]': 'owlDialogContainerRole',\n    '[attr.aria-labelledby]': 'owlDialogContainerAriaLabelledby',\n    '[attr.aria-describedby]': 'owlDialogContainerAriaDescribedby',\n    '[@slideModal]': 'owlDialogContainerAnimation'\n  }\n})\nexport class OwlDialogContainerComponent\n  extends BasePortalOutlet\n  implements OnInit {\n  @ViewChild(CdkPortalOutlet, { static: true })\n  portalOutlet: CdkPortalOutlet;\n\n  /** The class that traps and manages focus within the dialog. */\n  private focusTrap: FocusTrap;\n\n  /** ID of the element that should be considered as the dialog's label. */\n  public ariaLabelledBy: string | null = null;\n\n  /** Emits when an animation state changes. */\n  public animationStateChanged = new EventEmitter<AnimationEvent>();\n\n  public isAnimating = false;\n\n  private _config: OwlDialogConfig;\n  get config(): OwlDialogConfig {\n    return this._config;\n  }\n\n  private state: 'void' | 'enter' | 'exit' = 'enter';\n\n  // for animation purpose\n  private params: any = {\n    x: '0px',\n    y: '0px',\n    ox: '50%',\n    oy: '50%',\n    scale: 0\n  };\n\n  // A variable to hold the focused element before the dialog was open.\n  // This would help us to refocus back to element when the dialog was closed.\n  private elementFocusedBeforeDialogWasOpened: HTMLElement | null = null;\n\n  get owlDialogContainerClass(): boolean {\n    return true;\n  }\n\n  get owlDialogContainerTabIndex(): number {\n    return -1;\n  }\n\n  get owlDialogContainerId(): string {\n    return this._config.id;\n  }\n\n  get owlDialogContainerRole(): string {\n    return this._config.role || null;\n  }\n\n  get owlDialogContainerAriaLabelledby(): string {\n    return this.ariaLabelledBy;\n  }\n\n  get owlDialogContainerAriaDescribedby(): string {\n    return this._config.ariaDescribedBy || null;\n  }\n\n  get owlDialogContainerAnimation(): any {\n    return { value: this.state, params: this.params };\n  }\n\n  constructor(\n    private changeDetector: ChangeDetectorRef,\n    private elementRef: ElementRef,\n    private focusTrapFactory: FocusTrapFactory,\n    @Optional()\n    @Inject(DOCUMENT)\n    private document: any\n  ) {\n    super();\n  }\n\n  public ngOnInit() {}\n\n  /**\n   * Attach a ComponentPortal as content to this dialog container.\n   */\n  public attachComponentPortal<T>(portal: ComponentPortal<T>): ComponentRef<T> {\n    if (this.portalOutlet.hasAttached()) {\n      throw Error(\n        'Attempting to attach dialog content after content is already attached'\n      );\n    }\n\n    this.savePreviouslyFocusedElement();\n    return this.portalOutlet.attachComponentPortal(portal);\n  }\n\n  public attachTemplatePortal<C>(\n    portal: TemplatePortal<C>\n  ): EmbeddedViewRef<C> {\n    throw new Error('Method not implemented.');\n  }\n\n  public setConfig(config: OwlDialogConfig): void {\n    this._config = config;\n\n    if (config.event) {\n      this.calculateZoomOrigin(event);\n    }\n  }\n\n  public onAnimationStart(event: AnimationEvent): void {\n    this.isAnimating = true;\n    this.animationStateChanged.emit(event);\n  }\n\n  public onAnimationDone(event: AnimationEvent): void {\n    if (event.toState === 'enter') {\n      this.trapFocus();\n    } else if (event.toState === 'exit') {\n      this.restoreFocus();\n    }\n\n    this.animationStateChanged.emit(event);\n    this.isAnimating = false;\n  }\n\n  public startExitAnimation() {\n    this.state = 'exit';\n    this.changeDetector.markForCheck();\n  }\n\n  /**\n   * Calculate origin used in the `zoomFadeInFrom()`\n   * for animation purpose\n   */\n  private calculateZoomOrigin(event: any): void {\n    if (!event) {\n      return;\n    }\n\n    const clientX = event.clientX;\n    const clientY = event.clientY;\n\n    const wh = window.innerWidth / 2;\n    const hh = window.innerHeight / 2;\n    const x = clientX - wh;\n    const y = clientY - hh;\n    const ox = clientX / window.innerWidth;\n    const oy = clientY / window.innerHeight;\n\n    this.params.x = `${x}px`;\n    this.params.y = `${y}px`;\n    this.params.ox = `${ox * 100}%`;\n    this.params.oy = `${oy * 100}%`;\n    this.params.scale = 0;\n\n    return;\n  }\n\n  /**\n   * Save the focused element before dialog was open\n   */\n  private savePreviouslyFocusedElement(): void {\n    if (this.document) {\n      this.elementFocusedBeforeDialogWasOpened = this.document\n        .activeElement as HTMLElement;\n\n      Promise.resolve().then(() => this.elementRef.nativeElement.focus());\n    }\n  }\n\n  private trapFocus(): void {\n    if (!this.focusTrap) {\n      this.focusTrap = this.focusTrapFactory.create(\n        this.elementRef.nativeElement\n      );\n    }\n\n    if (this._config.autoFocus) {\n      this.focusTrap.focusInitialElementWhenReady();\n    }\n  }\n\n  private restoreFocus(): void {\n    const toFocus = this.elementFocusedBeforeDialogWasOpened;\n\n    // We need the extra check, because IE can set the `activeElement` to null in some cases.\n    if (toFocus && typeof toFocus.focus === 'function') {\n      toFocus.focus();\n    }\n\n    if (this.focusTrap) {\n      this.focusTrap.destroy();\n    }\n  }\n}\n"]}
|