Следующий код показывает средство выбора даты и времени в форме, и я использую плагин angular-moment-picker в качестве средства выбора. Когда я выбираю определенную дату/время, в поле ввода средства выбора отображается правильное время, но после отправки формы время, введенное в БД, отстает. Поэтому я использовал директиву часового пояса из ответа stackoverflow. Но он выдает viewValue.getMinutes не является ошибкой функции
<div moment-picker="startTime" class="form-control" name="startTime"
ng-model="shiftTimings.startTime" format="YYYY-MM-DD HH:mm:ss" datepicker-localdate >
{{ startTime }} </div>
Директива
app.directive('datepickerLocaldate', ['$parse', function ($parse) {
var directive = {
restrict: 'A',
require: ['ngModel'],
link: link
};
return directive;
function link(scope, element, attr, ctrls) {
var ngModelController = ctrls[0];
ngModelController.$parsers.push(function (viewValue) {
viewValue.setMinutes(viewValue.getMinutes() - viewValue.getTimezoneOffset());
return viewValue.toISOString().substring(0, 10);
});
ngModelController.$formatters.push(function (modelValue) {
if (!modelValue) {
return undefined;
}
var dt = new Date(modelValue);
dt.setMinutes(dt.getMinutes() + dt.getTimezoneOffset());
return dt;
});
}
}]);