|  | @@ -4,7 +4,7 @@ BlazeLayout.setRoot('body');
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  let alreadyCheck = 1;
 |  |  let alreadyCheck = 1;
 | 
											
												
													
														|  |  let isCheckDone = false;
 |  |  let isCheckDone = false;
 | 
											
												
													
														|  | -let counter = 0;
 |  | 
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  const validator = {
 |  |  const validator = {
 | 
											
												
													
														|  |    set(obj, prop, value) {
 |  |    set(obj, prop, value) {
 | 
											
												
													
														|  |      if (prop === 'state' && value !== 'signIn') {
 |  |      if (prop === 'state' && value !== 'signIn') {
 | 
											
										
											
												
													
														|  | @@ -21,7 +21,7 @@ const validator = {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  // let isSettingDatabaseFctCallDone = false;
 |  |  // let isSettingDatabaseFctCallDone = false;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -Template.userFormsLayout.onCreated(function () {
 |  | 
 | 
											
												
													
														|  | 
 |  | +Template.userFormsLayout.onCreated(function() {
 | 
											
												
													
														|  |    const templateInstance = this;
 |  |    const templateInstance = this;
 | 
											
												
													
														|  |    templateInstance.currentSetting = new ReactiveVar();
 |  |    templateInstance.currentSetting = new ReactiveVar();
 | 
											
												
													
														|  |    templateInstance.isLoading = new ReactiveVar(false);
 |  |    templateInstance.isLoading = new ReactiveVar(false);
 | 
											
										
											
												
													
														|  | @@ -37,7 +37,7 @@ Template.userFormsLayout.onCreated(function () {
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |        // isSettingDatabaseFctCallDone = true;
 |  |        // isSettingDatabaseFctCallDone = true;
 | 
											
												
													
														|  | -      if (currSetting && currSetting !== undefined && currSetting.customLoginLogoImageUrl !== undefined)
 |  | 
 | 
											
												
													
														|  | 
 |  | +      if(currSetting && currSetting !== undefined && currSetting.customLoginLogoImageUrl !== undefined)
 | 
											
												
													
														|  |          document.getElementById("isSettingDatabaseCallDone").style.display = 'none';
 |  |          document.getElementById("isSettingDatabaseCallDone").style.display = 'none';
 | 
											
												
													
														|  |        else
 |  |        else
 | 
											
												
													
														|  |          document.getElementById("isSettingDatabaseCallDone").style.display = 'block';
 |  |          document.getElementById("isSettingDatabaseCallDone").style.display = 'block';
 | 
											
										
											
												
													
														|  | @@ -50,18 +50,6 @@ Template.userFormsLayout.onCreated(function () {
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    });
 |  |    });
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  if (!Meteor.user()?.profile) {
 |  | 
 | 
											
												
													
														|  | -      Meteor.call('isOidcRedirectionEnabled', (_, result) => {
 |  | 
 | 
											
												
													
														|  | -        if (result) {
 |  | 
 | 
											
												
													
														|  | -          AccountsTemplates.options.socialLoginStyle = 'redirect';
 |  | 
 | 
											
												
													
														|  | -          options = {
 |  | 
 | 
											
												
													
														|  | -            loginStyle: AccountsTemplates.options.socialLoginStyle,
 |  | 
 | 
											
												
													
														|  | -          };
 |  | 
 | 
											
												
													
														|  | -          Meteor.loginWithOidc(options);
 |  | 
 | 
											
												
													
														|  | -        }
 |  | 
 | 
											
												
													
														|  | -        else console.log("oidc redirect not set");
 |  | 
 | 
											
												
													
														|  | -      });
 |  | 
 | 
											
												
													
														|  | -  }
 |  | 
 | 
											
												
													
														|  |    Meteor.call('isDisableRegistration', (_, result) => {
 |  |    Meteor.call('isDisableRegistration', (_, result) => {
 | 
											
												
													
														|  |      if (result) {
 |  |      if (result) {
 | 
											
												
													
														|  |        $('.at-signup-link').hide();
 |  |        $('.at-signup-link').hide();
 | 
											
										
											
												
													
														|  | @@ -93,22 +81,22 @@ Template.userFormsLayout.helpers({
 | 
											
												
													
														|  |    //   return isSettingDatabaseFctCallDone;
 |  |    //   return isSettingDatabaseFctCallDone;
 | 
											
												
													
														|  |    // },
 |  |    // },
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  isLegalNoticeLinkExist() {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  isLegalNoticeLinkExist(){
 | 
											
												
													
														|  |      const currSet = Template.instance().currentSetting.get();
 |  |      const currSet = Template.instance().currentSetting.get();
 | 
											
												
													
														|  | -    if (currSet && currSet !== undefined && currSet != null) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    if(currSet && currSet !== undefined && currSet != null){
 | 
											
												
													
														|  |        return currSet.legalNotice !== undefined && currSet.legalNotice.trim() != "";
 |  |        return currSet.legalNotice !== undefined && currSet.legalNotice.trim() != "";
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      else
 |  |      else
 | 
											
												
													
														|  |        return false;
 |  |        return false;
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -  getLegalNoticeWithWritTraduction() {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  getLegalNoticeWithWritTraduction(){
 | 
											
												
													
														|  |      let spanLegalNoticeElt = $("#legalNoticeSpan");
 |  |      let spanLegalNoticeElt = $("#legalNoticeSpan");
 | 
											
												
													
														|  | -    if (spanLegalNoticeElt != null && spanLegalNoticeElt != undefined) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    if(spanLegalNoticeElt != null && spanLegalNoticeElt != undefined){
 | 
											
												
													
														|  |        spanLegalNoticeElt.html(TAPi18n.__('acceptance_of_our_legalNotice', {}));
 |  |        spanLegalNoticeElt.html(TAPi18n.__('acceptance_of_our_legalNotice', {}));
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      let atLinkLegalNoticeElt = $("#legalNoticeAtLink");
 |  |      let atLinkLegalNoticeElt = $("#legalNoticeAtLink");
 | 
											
												
													
														|  | -    if (atLinkLegalNoticeElt != null && atLinkLegalNoticeElt != undefined) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    if(atLinkLegalNoticeElt != null && atLinkLegalNoticeElt != undefined){
 | 
											
												
													
														|  |        atLinkLegalNoticeElt.html(TAPi18n.__('legalNotice', {}));
 |  |        atLinkLegalNoticeElt.html(TAPi18n.__('legalNotice', {}));
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      return true;
 |  |      return true;
 | 
											
										
											
												
													
														|  | @@ -159,41 +147,41 @@ Template.userFormsLayout.events({
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |      isCheckDone = false;
 |  |      isCheckDone = false;
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  | -  'click #at-signUp'(event, templateInstance) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  'click #at-signUp'(event, templateInstance){
 | 
											
												
													
														|  |      isCheckDone = false;
 |  |      isCheckDone = false;
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  | -  'DOMSubtreeModified #at-oidc'(event) {
 |  | 
 | 
											
												
													
														|  | -    if (alreadyCheck <= 2) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  'DOMSubtreeModified #at-oidc'(event){
 | 
											
												
													
														|  | 
 |  | +    if(alreadyCheck <= 2){
 | 
											
												
													
														|  |        let currSetting = Settings.findOne();
 |  |        let currSetting = Settings.findOne();
 | 
											
												
													
														|  |        let oidcBtnElt = $("#at-oidc");
 |  |        let oidcBtnElt = $("#at-oidc");
 | 
											
												
													
														|  | -      if (currSetting && currSetting !== undefined && currSetting.oidcBtnText !== undefined && oidcBtnElt != null && oidcBtnElt != undefined) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +      if(currSetting && currSetting !== undefined && currSetting.oidcBtnText !== undefined && oidcBtnElt != null && oidcBtnElt != undefined){
 | 
											
												
													
														|  |          let htmlvalue = "<i class='fa fa-oidc'></i>" + currSetting.oidcBtnText;
 |  |          let htmlvalue = "<i class='fa fa-oidc'></i>" + currSetting.oidcBtnText;
 | 
											
												
													
														|  | -        if (alreadyCheck == 1) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if(alreadyCheck == 1){
 | 
											
												
													
														|  |            alreadyCheck++;
 |  |            alreadyCheck++;
 | 
											
												
													
														|  |            oidcBtnElt.html("");
 |  |            oidcBtnElt.html("");
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  | -        else {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        else{
 | 
											
												
													
														|  |            alreadyCheck++;
 |  |            alreadyCheck++;
 | 
											
												
													
														|  |            oidcBtnElt.html(htmlvalue);
 |  |            oidcBtnElt.html(htmlvalue);
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  | -    else {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    else{
 | 
											
												
													
														|  |        alreadyCheck = 1;
 |  |        alreadyCheck = 1;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
												
													
														|  | -  'DOMSubtreeModified .at-form'(event) {
 |  | 
 | 
											
												
													
														|  | -    if (alreadyCheck <= 2 && !isCheckDone) {
 |  | 
 | 
											
												
													
														|  | -      if (document.getElementById("at-oidc") != null) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +  'DOMSubtreeModified .at-form'(event){
 | 
											
												
													
														|  | 
 |  | +    if(alreadyCheck <= 2 && !isCheckDone){
 | 
											
												
													
														|  | 
 |  | +      if(document.getElementById("at-oidc") != null){
 | 
											
												
													
														|  |          let currSetting = Settings.findOne();
 |  |          let currSetting = Settings.findOne();
 | 
											
												
													
														|  |          let oidcBtnElt = $("#at-oidc");
 |  |          let oidcBtnElt = $("#at-oidc");
 | 
											
												
													
														|  | -        if (currSetting && currSetting !== undefined && currSetting.oidcBtnText !== undefined && oidcBtnElt != null && oidcBtnElt != undefined) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        if(currSetting && currSetting !== undefined && currSetting.oidcBtnText !== undefined && oidcBtnElt != null && oidcBtnElt != undefined){
 | 
											
												
													
														|  |            let htmlvalue = "<i class='fa fa-oidc'></i>" + currSetting.oidcBtnText;
 |  |            let htmlvalue = "<i class='fa fa-oidc'></i>" + currSetting.oidcBtnText;
 | 
											
												
													
														|  | -          if (alreadyCheck == 1) {
 |  | 
 | 
											
												
													
														|  | 
 |  | +          if(alreadyCheck == 1){
 | 
											
												
													
														|  |              alreadyCheck++;
 |  |              alreadyCheck++;
 | 
											
												
													
														|  |              oidcBtnElt.html("");
 |  |              oidcBtnElt.html("");
 | 
											
												
													
														|  |            }
 |  |            }
 | 
											
												
													
														|  | -          else {
 |  | 
 | 
											
												
													
														|  | 
 |  | +          else{
 | 
											
												
													
														|  |              alreadyCheck++;
 |  |              alreadyCheck++;
 | 
											
												
													
														|  |              isCheckDone = true;
 |  |              isCheckDone = true;
 | 
											
												
													
														|  |              oidcBtnElt.html(htmlvalue);
 |  |              oidcBtnElt.html(htmlvalue);
 | 
											
										
											
												
													
														|  | @@ -201,7 +189,7 @@ Template.userFormsLayout.events({
 | 
											
												
													
														|  |          }
 |  |          }
 | 
											
												
													
														|  |        }
 |  |        }
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  | -    else {
 |  | 
 | 
											
												
													
														|  | 
 |  | +    else{
 | 
											
												
													
														|  |        alreadyCheck = 1;
 |  |        alreadyCheck = 1;
 | 
											
												
													
														|  |      }
 |  |      }
 | 
											
												
													
														|  |    },
 |  |    },
 | 
											
										
											
												
													
														|  | @@ -233,7 +221,7 @@ async function authentication(event, templateInstance) {
 | 
											
												
													
														|  |    switch (result) {
 |  |    switch (result) {
 | 
											
												
													
														|  |      case 'ldap':
 |  |      case 'ldap':
 | 
											
												
													
														|  |        return new Promise(resolve => {
 |  |        return new Promise(resolve => {
 | 
											
												
													
														|  | -        Meteor.loginWithLDAP(match, password, function () {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        Meteor.loginWithLDAP(match, password, function() {
 | 
											
												
													
														|  |            resolve(FlowRouter.go('/'));
 |  |            resolve(FlowRouter.go('/'));
 | 
											
												
													
														|  |          });
 |  |          });
 | 
											
												
													
														|  |        });
 |  |        });
 | 
											
										
											
												
													
														|  | @@ -245,7 +233,7 @@ async function authentication(event, templateInstance) {
 | 
											
												
													
														|  |            {
 |  |            {
 | 
											
												
													
														|  |              provider,
 |  |              provider,
 | 
											
												
													
														|  |            },
 |  |            },
 | 
											
												
													
														|  | -          function () {
 |  | 
 | 
											
												
													
														|  | 
 |  | +          function() {
 | 
											
												
													
														|  |              resolve(FlowRouter.go('/'));
 |  |              resolve(FlowRouter.go('/'));
 | 
											
												
													
														|  |            },
 |  |            },
 | 
											
												
													
														|  |          );
 |  |          );
 | 
											
										
											
												
													
														|  | @@ -253,7 +241,7 @@ async function authentication(event, templateInstance) {
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |      case 'cas':
 |  |      case 'cas':
 | 
											
												
													
														|  |        return new Promise(resolve => {
 |  |        return new Promise(resolve => {
 | 
											
												
													
														|  | -        Meteor.loginWithCas(match, password, function () {
 |  | 
 | 
											
												
													
														|  | 
 |  | +        Meteor.loginWithCas(match, password, function() {
 | 
											
												
													
														|  |            resolve(FlowRouter.go('/'));
 |  |            resolve(FlowRouter.go('/'));
 | 
											
												
													
														|  |          });
 |  |          });
 | 
											
												
													
														|  |        });
 |  |        });
 | 
											
										
											
												
													
														|  | @@ -279,6 +267,7 @@ function getUserAuthenticationMethod(defaultAuthenticationMethod, match) {
 | 
											
												
													
														|  |        Meteor.subscribe('user-authenticationMethod', match, {
 |  |        Meteor.subscribe('user-authenticationMethod', match, {
 | 
											
												
													
														|  |          onReady() {
 |  |          onReady() {
 | 
											
												
													
														|  |            const user = Users.findOne();
 |  |            const user = Users.findOne();
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |            const authenticationMethod = user
 |  |            const authenticationMethod = user
 | 
											
												
													
														|  |              ? user.authenticationMethod
 |  |              ? user.authenticationMethod
 | 
											
												
													
														|  |              : defaultAuthenticationMethod;
 |  |              : defaultAuthenticationMethod;
 |