From 71a7b48978d041725d9a93e6d9c937117b6e890d Mon Sep 17 00:00:00 2001 From: Bizz <56281168+dr-bizz@users.noreply.github.com> Date: Fri, 8 Sep 2023 17:08:04 -0400 Subject: [PATCH] Reimplementing the reverted PR #842/#843 but not included changes were localModel is set. I'm confused to why we need to format scope.localModel differently. (#844) --- app/scripts/controllers/registration.js | 15 +++++++++++++-- app/scripts/directives/datepicker.js | 4 ++-- test/spec/directives/datepicker.spec.js | 2 +- 3 files changed, 16 insertions(+), 5 deletions(-) diff --git a/app/scripts/controllers/registration.js b/app/scripts/controllers/registration.js index 5c3ea210a..8ef325741 100644 --- a/app/scripts/controllers/registration.js +++ b/app/scripts/controllers/registration.js @@ -367,6 +367,16 @@ angular var currentRegistrant = _.find($scope.currentRegistration.registrants, { id: $scope.currentRegistrant, }); + const invalidBlocks = _.find(currentRegistration.registrants, { + id: currentRegistrant.id, + }) + ? validateRegistrant.validate( + conference, + _.find(currentRegistration.registrants, { + id: currentRegistrant.id, + }), + ) + : []; var answersToSave = []; angular.forEach( @@ -376,8 +386,9 @@ angular id: a.id, }); if ( - angular.isUndefined(savedAnswer) || - !angular.equals(savedAnswer.value, a.value) + (angular.isUndefined(savedAnswer) || + !angular.equals(savedAnswer.value, a.value)) && + !invalidBlocks.includes(a.blockId) ) { if ($scope.registerMode !== 'preview') { answersToSave.push($http.put('answers/' + a.id, a)); diff --git a/app/scripts/directives/datepicker.js b/app/scripts/directives/datepicker.js index c60f50ef5..58ba6c96a 100644 --- a/app/scripts/directives/datepicker.js +++ b/app/scripts/directives/datepicker.js @@ -14,9 +14,9 @@ angular }, controller: function ($timeout, $scope) { $scope.updateTimeStamp = function (timestamp) { - //For Graduation date question, set the day to 1. The API needs the day but that could change in the future. + //For the Graduation date question, set the day to 10. The API needs the day but that could change in the future. timestamp = $scope.monthYearOnly - ? moment(new Date(timestamp)).set('date', 1) + ? moment(new Date(timestamp)).set('date', 10) : timestamp; $scope.$apply(function () { let dateSaveFormat = $scope.monthYearOnly diff --git a/test/spec/directives/datepicker.spec.js b/test/spec/directives/datepicker.spec.js index 03e200fc5..76066216b 100644 --- a/test/spec/directives/datepicker.spec.js +++ b/test/spec/directives/datepicker.spec.js @@ -21,7 +21,7 @@ describe('Directive: datepicker', function () { it('Sets the date to the correct format based on the type of date question', function () { scope.updateTimeStamp(new Date('02/05/1994')); - expect(scope.localModel).toBe('1994-02-01'); + expect(scope.localModel).toBe('1994-02-10'); scope.monthYearOnly = false;