Merge pull request #4695 from expsa/eltayar

Final Fix: Both Gregorian and Hijri calendars auto-hide on outside click
This commit is contained in:
Mohamed Eltayar 2025-09-17 11:43:24 +03:00 committed by GitHub
commit eb2d2f3fd0
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
1 changed files with 24 additions and 8 deletions

View File

@ -92,17 +92,26 @@ odoo.define('web_hijri_datepicker.datepicker', function (require) {
var self = this;
this._outsideClickHandler = function(e) {
var $target = $(e.target);
if (!$target.closest('.calendars-popup').length &&
!$target.closest('.o_hijri').length &&
!$target.hasClass('o_hijri') &&
!$target.closest('.calendars').length) {
self._hideHijriCalendar();
var shouldIgnore = $target.closest('.calendars-popup').length ||
$target.closest('.o_hijri').length ||
$target.hasClass('o_hijri') ||
$target.closest('.calendars').length ||
$target.closest('.bootstrap-datetimepicker-widget').length ||
$target.closest('.datepicker').length ||
$target.hasClass('o_datepicker_input') ||
$target.hasClass('o_datepicker_button') ||
$target.closest('.datetimepicker').length ||
$target.closest('.datetimepicker-dropdown').length;
if (!shouldIgnore) {
self._hideAllCalendars();
}
};
this._keydownHandler = function(e) {
if (e.keyCode === 27) {
self._hideHijriCalendar();
self._hideAllCalendars();
}
};
@ -115,10 +124,17 @@ odoo.define('web_hijri_datepicker.datepicker', function (require) {
$(document).off('keydown.hijri_calendar');
},
_hideHijriCalendar: function() {
_hideAllCalendars: function() {
if (this.$input_hijri && this.$input_hijri.calendarsPicker) {
this.$input_hijri.calendarsPicker('hide');
}
if (this.$el && this.$el.data('DateTimePicker')) {
this.$el.data('DateTimePicker').hide();
} else if (this.$el && this.$el.datetimepicker) {
try {
this.$el.datetimepicker('hide');
} catch (e) {}
}
},
changeDatetime: function () {
@ -161,7 +177,7 @@ odoo.define('web_hijri_datepicker.datepicker', function (require) {
var date_value = moment(time.str_to_date(formatted_date)).add(1, 'days');
this.setValue(this._parseClient(date_value));
this.trigger("datetime_changed");
this._hideHijriCalendar();
this._hideAllCalendars();
},
_parseDate: function (v) {