mirror of
https://github.com/e107inc/e107.git
synced 2025-10-11 21:15:09 +02:00
84 lines
3.2 KiB
JavaScript
84 lines
3.2 KiB
JavaScript
// If you don't insert this line into your JS, you may see the error: e107 is not defined.
|
|
var e107 = e107 || {'settings': {}, 'behaviors': {}};
|
|
|
|
(function ($) {
|
|
|
|
/**
|
|
* Behavior to initialize date-time-picker on elements.
|
|
*
|
|
* @type {{attach: e107.behaviors.bootstrapDatetimepickerInit.attach}}
|
|
*/
|
|
e107.behaviors.bootstrapDatetimepickerInit = {
|
|
attach: function (context, settings) {
|
|
$(context).find('input.e-date,input.e-datetime').once('datetimepicker-onchange-init').each(function () {
|
|
var $item = $(this);
|
|
|
|
// Fix for changeDate() not being fired when value manually altered.
|
|
$item.on("change keyup", function () {
|
|
var $this = $(this);
|
|
var useUnix = $this.attr("data-date-unix");
|
|
|
|
if (useUnix !== "true") {
|
|
var id = $this.attr("id");
|
|
var newTarget = "#" + id.replace("e-datepicker-", "");
|
|
var newValue = $this.val();
|
|
$(newTarget).val(newValue);
|
|
}
|
|
});
|
|
});
|
|
|
|
$(context).find('input.e-date').once('datetimepicker-init').each(function () {
|
|
var $item = $(this);
|
|
|
|
$item.datetimepicker({
|
|
minView: "month",
|
|
maxView: "decade",
|
|
autoclose: true,
|
|
format: $item.attr("data-date-format"),
|
|
weekStart: $item.attr("data-date-firstday"),
|
|
language: $item.attr("data-date-language")
|
|
}).on("changeDate", function (ev) {
|
|
var useUnix = $(this).attr("data-date-unix");
|
|
var newValue = "";
|
|
var newTarget = "#" + ev.target.id.replace("e-datepicker-", "");
|
|
|
|
if (useUnix === "true") {
|
|
newValue = parseInt(ev.date.getTime() / 1000);
|
|
}
|
|
else {
|
|
newValue = $("#" + ev.target.id).val();
|
|
}
|
|
|
|
$(newTarget).val(newValue);
|
|
});
|
|
});
|
|
|
|
$(context).find('input.e-datetime').once('datetimepicker-init').each(function () {
|
|
var $item = $(this);
|
|
|
|
$item.datetimepicker({
|
|
autoclose: true,
|
|
format: $item.attr("data-date-format"),
|
|
weekStart: $item.attr("data-date-firstday"),
|
|
showMeridian: $item.attr("data-date-ampm"),
|
|
language: $item.attr("data-date-language")
|
|
}).on("changeDate", function (ev) {
|
|
var useUnix = $(this).attr("data-date-unix");
|
|
var newValue = "";
|
|
var newTarget = "#" + ev.target.id.replace("e-datepicker-", "");
|
|
|
|
if (useUnix === "true") {
|
|
newValue = parseInt(ev.date.getTime() / 1000);
|
|
}
|
|
else {
|
|
newValue = $("#" + ev.target.id).val();
|
|
}
|
|
|
|
$(newTarget).val(newValue);
|
|
})
|
|
});
|
|
}
|
|
};
|
|
|
|
})(jQuery);
|