Skip to main content

Angular UI Routing (angular-ui-router) problem with '-' in the state name - model is not bound in first load.

Issue:
angular-ui-router confused with state names separated with '-' .
Ex. Sign-up vs Sign-up-user.

Though it loads the template it is not binding the model in the first load. You have to click same link again to get the form fields populated.

Angular-ui- router - almost treating it as sub url path like in " sign-up.user" the URL will be-  'sign-up/user' .

 FIX:
Avoid same prefix separated by '-'.
 Use  some thing like  'signup-user' instead of 'sign-up-user' that repeats the other route 'sign-up'.

Code:
 This below code will not populate the form fields first time.
app.js
 .state('sign-up', { 
        url: '/sign-up',
        templateUrl: 'views/sign-up-options.html'
      })
     .state('sign-up-user', {                
        url: '/sign-up-user',                    -----------------------------> This URL is compared with the previous URL and is still loading and the template and controller, but not binding. It works if changed to '/signup-user'
        templateUrl: 'views/sign-up-user.html',
        controller: 'SignUpController'
      })
 .state('sign-up-success', {
        url: '/sign-up/success',
        templateUrl: 'views/sign-up-success.html'
      });
  
Controller:
 .controller('SignUpController', ['$scope',   '$state',    
      function($scope,  $state ) {
        $scope.user = {
          email: 'user@u.com',
          password: ' password',
            repassword:null
        };
    
        $scope.register = function() {
           console.log('register called');
        };
  }]);

HTML:

<section>
  <form name="form" ng-submit="register()">
    <fieldset>
      <legend>Sign up form</legend>

      <div class="form-group">
        <label>Email</label>
        <input name="email" type="text" ng-model="user.email">
      </div>

      <div class="form-group">
        <label>Password</label>
        <input name="password" type="password" ng-model="user.password">
      </div>

      <div class="actions">
        <label></label>
        <button>Sign up</button>
      </div>
    </fieldset>
  </form>
</section>
 

Comments

Popular posts from this blog

LLM on Mobile Phone : Mini Universal data and assistant running on an android smart phone Galaxy S23

  Imagine a world where everyone has access to a mini #OpenAI's #ChatGPT on their mobile phone, answering any question on any topic, right from their local phone memory. No need for internet. This is the future of #LLMs on mobile devices, and it's happening now. #MLC-AI has created a way to install a 3 billion parameter #RedPajam #LLMModel on a #Galaxy #S23 smartphone. This is a powerful #LLM that can generate text, translate languages, write different kinds of creative content, and answer your questions in an informative way. And it's all available on your phone, without the need for an internet connection. This could have a profound impact on people all over the world. Millions of suburban students who don't have access to the internet could now have access to a universal data source that can answer most of their questions. Refugee camps around the world could also benefit from this technology, giving refugees access to information and resources that they might not ot...

Ohmni robot disassembly - Parts and structure inside Ohmni Telepresence Robot - Tear down

    The tablet, speakers were disconnected and removed in different video.    Ohmni robot disassembly - Parts and structure inside Ohmni Telepresence - Design - Mechonical and Electrical components .

Setting up Rassberry Pi Zero W 1/2 with USB (not using hdmi) On MAC

Copy  Rassberry Pi zero image (pi 3 image also supported on pi zero) on a SD card https://www.raspberrypi.com/software/     From mac - Finder - open SD card . It opens the root folder We will edit or create 4 files:  config.txt cmdline.txt ssh wifi   config.txt At the bottom of the file add this line dtoverlay=dwc2 cmdline.txt add this line between rootwait  ........  quiet . Should look  like this, rootwait modules-load=dwc2,g_ether quiet   ssh create an emptyfile named ssh (no extensions)   wifi : (pi zero can connect only to 2.5gh Unless you update your firmware) create this file in root : wpa_supplicant.conf   add this lines to the file - with your own wifi credentials country=US ctrl_interface=DIR=/var/run/wpa_supplicant GROUP=netdev update_config=1 network={ ssid="*******" psk="********" }  Insert sd card in raspberry pi  zero w , and connect from pc with, ...