In the previous part of this tutorial series, we implemented the edit and delete post functionality in the welcome page. In this part of the tutorial, we'll add a Ladda loading indicator into our application. Adding a loading indicator is quite essential as it makes the application more interactive. We'll also fix a couple of minor issues as the tutorial progresses.
Getting Started
Let's start by cloning the previous part of the tutorial from GitHub.
git clone https://github.com/jay3dec/AngularJS_Firebase_Part6.git
After cloning the source code, navigate to the project directory and install the required dependencies.
cd AngularJS_Firebase_Part6 npm install
Once the dependencies are installed, start the server.
npm start
Point your browser to http://localhost:8000/app/#/home and you should have the application running.
Adding a Ladda Loading Indicator
Ladda is a UI concept which merges a loading indicator into buttons, making it interactive and user-friendly. From the official Ladda site,
A UI concept which merges loading indicators into the action that invoked them. Primarily intended for use with forms where it gives users immediate feedback upon submit rather than leaving them wondering while the browser does its thing.
Creating a Directive for Ladda
In order to use Ladda in our application, we'll create an AngularJS directive for the Ladda loading indicator. Directives are one of the core features of AngularJS, and they control the rendering of HTML inside the application.
Open up app/home/home.js and create a simple directive as shown below:
.directive('laddaLoading', [
function() {
return {
link: function(scope, element, attrs) {
}
};
}
]);
We'll start and stop the Ladda loading indicator based on a $scope variable called login.loading. When login.loading is true, we'll show the loading indicator, and when it's false we'll stop the loading indicator. So, in HomeCtrl, define a variable called login and assign it to the $scope.login variable.
var login = {};
$scope.login = login;
Next include the CSS and JavaScript files from ladda dist in home/home.html as shown below:
<script type="text/javascript" src="spin.min.js"></script> <script type="text/javascript" src="ladda.min.js"></script> <link href="ladda-themeless.min.css" rel="stylesheet">
After adding the above script and style references, modify the Sign In button in home.html as shown:
<button ladda-loading="login.loading" data-style="expand-right" ng-disabled="!user.email || !user.password" type="button" ng-click="SignIn($event)" class="btn btn-lg segoe-ui-light ladda-button btn-primary btn-block"><span class="ladda-label">Sign In</span></button>
As you can see in the above code, we have added the directive laddaLoading to the button and have passed login.loading. We'll set and reset the passed in login.loading to toggle the loading indicator display. We have also added certain styles, segoe-ui-light and ladda-button, to style the Ladda loading indicators.
Now inside the directive link function, add the following code to keep a watch on the login.loading scope variable and start and stop the indicator accordingly.
.directive('laddaLoading', [
function() {
return {
link: function(scope, element, attrs) {
var Ladda = window.Ladda;
var ladda = Ladda.create(element[0]);
// Watching login.loading for change
scope.$watch(attrs.laddaLoading, function(newVal, oldVal) {
// Based on the value start and stop the indicator
if (newVal) {
ladda.start();
} else {
ladda.stop();
}
});
}
};
}
]);
Next, when the user clicks the Sign In button we need to set the loading indicator. So, in HomeCtrl inside the SignIn function, set login.loading to true to start the loading indicator.
login.loading = true;
Similarly when the sign-in success or failure callback is called, we need to set the login.loading to false to stop the loading indicator.
login.loading = false;
Save all the changes and restart the server. Enter a valid email address and password and you should be able to see the loading indicator in action.

Similarly, we can add the ladda loading indicator for the Register button in register/register.html. Include the required references in register/register.html as shown:
<script type="text/javascript" src="spin.min.js"></script> <script type="text/javascript" src="ladda.min.js"></script> <link href="ladda-themeless.min.css" rel="stylesheet">
Modify the Register button to include the directive as shown:
<button type="button" ladda-loading="login.loading" data-style="expand-right" ng-click="signUp();" ng-disabled="!user.email || !user.password" class="btn btn-lg segoe-ui-light ladda-button btn-primary btn-block">Register</button>
Inside the RegisterCtrl add the login variable to set and reset the Ladda loading indicator.
var login={};
$scope.login=login;
Now, to enable the loading indicator when the user clicks the Register button, add the following code to the signUp function.
login.loading = true;
To disable the loading indicator, on success or failure callback add the following code.
login.loading = false;
Save all the changes and try to register for a new account. On clicking the Register button you should be able to see the loading indicator.

Similarly, we can add the loading indicator to the Add post page too. It's exactly the same so I won't be repeating it again. If you get stuck, do have a look at the source code at the end of this tutorial.
Filter Articles in the Welcome Page
At this point any logged-in user can add, edit and delete all the posts in the application. But it's not really fair to allow a user to modify any other user's post. So we'll filter the posts displayed on the welcome page and show only those posts which were created by the particular user.
To query a data from Firebase we can use the startAt and endAt API. Using startAt and endAt we can fetch results with the specified starting point and ending point. But the data that we would be passing with startAt should be a priority. So first we'll need to set the email address as a priority while pushing the data to Firebase.
So, open up addPost/addPost.js and have a look at portion where we push the data to Firebase.
fb.$push({ title: title,post: post,emailId: CommonProp.getUser() }).then(function(ref) {
console.log(ref);
$location.path('/welcome');
}, function(error) {
console.log("Error:", error);
});
Modify the above code to set the email address as a priority while pushing the data.
var user = CommonProp.getUser();
fb.$push({
title: title,
post: post,
emailId: user,
'.priority': user
}).then(function(ref) {
console.log(ref);
$location.path('/welcome');
}, function(error) {
console.log("Error:", error);
});
So now if we add a post in our application it's added with a priority for email address. Next, open up welcome/welcome.js and have a look at the portion where we are creating the $firebase object in WelcomeCtrl.
var sync = $firebase(firebaseObj);
Modify the above code by adding the startAt and endAt methods to the firebaseObj.
var sync = $firebase(firebaseObj.startAt($scope.username).endAt($scope.username));
Now, it will return only the posts added by a particular logged-in user.
Save the above changes and restart the server. Remove all the old posts from Firebase. Now try to add posts after logging in with a valid email address and password. Once a few posts are created, try to log in as another user and you won't be able to see the posts created by the previous user.
Conclusion
In this tutorial, we saw how to add the Ladda loading indicator into our application to make our app more interactive. We also saw how to filter the data result while fetching data from Firebase. In the next part of this series, we'll implement the logout functionality and also fix a couple of existing issues.
Source code from this tutorial is available on GitHub. Do let us know your thoughts, corrections and suggestions in the comments below!
Comments