As I was working on my new web project, I decided to use Twitter Bootstrap as the foundation for my styling and components. One common feature that all web usually have is showing some kind of “Please Wait” dialog to let the user know that application is processing something in the background. Typically in web applications we show this screen during server communications.
There are many components in the bootstrap package. I am going to use two to put my “Please Wait” screen together – modal dialog and progress bar. I am going to use animated striped progress bar and set its value to 100%. This will look very similar to Silverlight infinite progress bar. I also have to make sure the user cannot dismiss my dialog manually, so I have to block keyboard. So, here is how my html for dialog looks like.
<div class="modal hide" id="pleaseWaitDialog" data-backdrop="static" data-keyboard="false"> <div class="modal-header"> <h1>Processing...</h1> </div> <div class="modal-body"> <div class="progress progress-striped active"> <div class="bar" style="width: 100%;"></div> </div> </div> </div>
I also added a header. So, here is how the whole thing will look.
The black background is the default for modal dialogs in Bootstrap.
Next step is to wrap up this dialog in a reusable JavaScript component.
var myApp; myApp = myApp || (function () { var pleaseWaitDiv = $('<div class="modal hide" id="pleaseWaitDialog" data-backdrop="static" data-keyboard="false"><div class="modal-header"><h1>Processing...</h1></div><div class="modal-body"><div class="progress progress-striped active"><div class="bar" style="width: 100%;"></div></div></div></div>'); return { showPleaseWait: function() { pleaseWaitDiv.modal(); }, hidePleaseWait: function () { pleaseWaitDiv.modal('hide'); }, }; })();
All I did above is mote the html into the JavaScript variable and used jQuery to call Bootstrap’s modal function. I added two functions to my component – show and hide the please wait. So, if you are calling the server, call the function to show dialog and when the call complete call the one to hide it. For example:
myApp.showPleaseWait();
Thanks.
Enjoy.
Thanks for the post Sergey! I am also looking in to using Twitter Bootstrap for my project as well, so this is nice to know.
I do have one question though… Did you use jQuery to create the “pleaseWaitDialog” div because of portability, or is there another reason?
A couple of reasons really. One is to keep all the code together, js and html. The other one is that I found that my _Layout.cshtml continued to grow with system wide reusable html, and I wanted to cut down on that.
Cheers for this – a very useful bit of jquery. I separated my HTML and jQuery out and also had a confirm as part of it. So I had the following jquery function:
(function ($) {
$.confirmProcessingDialog = function(question, dialogId) {
if (confirm(question)) {
$(dialogId).modal();
return true;
} else {
return false;
}
};
})(jQuery);
So then you have to include the modal html in the pages you want to use, but then you can put the following:
It doesn’t like me putting in html so here it the last bit:
Doesn’t like that either. So I just put the following in the onclick event of the submit button:
$.confirmProcessDialog('Are you sure?', '#pleaseWaitDialog');
I am not sure what your question is exactly, Any dialogs are asynchronous, so typically you cannot do something like if(confirn()).
Thanks bro.inded thats awasome idea
Pingback: Building Message Dialog with Angular, Bootstrap and TypeScript | Sergey Barskiy's Blog
this is not working , please help
Pingback: Clever use of Bootstrap to Show “Please Wait…” | DevBlog
This is Not Working, only backdrop is visible but modal not handled, can you please view
@Deepan,
I am not sure why your code is not working for you without seeing your code.
It did not work for me too. I am calling showPleaseWait on ajax beforeSend and hidePleaseWait on always (aka complete). Like Deepan mentioned, I am also not seeing progress bar. Entire screen becomes black.
Yeah, could be bootstrap 2 vs 3 issue or many other reasons. No way to tell without code. If you post something on jsfiddle I could take a look.
First, you have done a great job. Is the better wait screen I had saw. But, I have the same problem. The backdrop is showing but the modal himself not.
Can you help us?
Sure, I can help, but I need something to look at. Could you post your repro somewhere, like jsfiddle or email it to me?
thank a lot man
Sergey,
I am new to angular & bootstrap. I am trying to create a modal window as a confirmation message box. Basically, customers enter their information and click on a button, which brings up the modal window. This window has some messages displayed and when they click on the close button on modal, it should take them to home page.
Everything is working except when the home page comes in, backdrop is still active and everything on home page is greyed out and non-editable. I have to manually refresh this page to get it working.
How can I remove the back drop when I close the modal window?
2)I am also not able to run any plain javascript statements. If I just call – alert(“test”); inside tags, it doesn’t work. Is there anything extra I need to do to incorporate javascripts or jQuery?
Any help would be great as I am kind of stuck with this for couple days now.
Thanks in advance.
-Suma
@Suma,
I think maybe your dialog HTML is incorrect that is why backdrop does not work. Just compare your HTML with an example in the bootstratp web site api pages. I think you will find a problem. I always recommend to create a very simple demo for these types of problem, that will help you pinpoint the issue. Alert should always work, maybe your code is not hit? Use browser tools to debug your JS code to make sure your code is hit. Hard to provide more help without looking at the code….
Hi Sergey,
1. I have written the below script in head section of the page
var myApp;
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘Processing…’);
return {
showPleaseWait: function() {
pleaseWaitDiv.modal();
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
2. and on click of this button i wants to open the modal window Open
But the page is refreshing on click of the submit button. This submit button is inside another modal window. Where as when i give hyperlink to an text like below the modal window is opening perfect.
Please Wait Dialog in this #pleasewaitDialog i have kept it in the document itself not in script.
But i wants to call somehow this modal dialog on click of a button or input submit button
Thanks for your quick response Sergey.
I did post a code sample to your response..but I don’t see it here.
Anyway, I was able to resolve my issue. I was calling jQuery.js in the wrong spot and hence was not being referenced. Since that got resolved, I used a jQuery snippet to redirect the button click to homepage. I am using MEAN stack with bootstrap for my coding efforts.
Thanks
Suma
Sorry, I am late in my response. You are right, I am using bootstrap v 3.0, c# mvc 5.0.
Here’s the code:
///
///
///
function ProcessDataController() {
var self = this;
this.OnBeforeAjaxRequest = function () {
alert(‘in beforeSend’);
myApp.showPleaseWait();
};
this.ProcessLongData = function() {
$.ajax({
beforeSend: self.OnBeforeAjaxRequest,
type: “GET”,
url: “/Home/SomeLongRunningProcessForDemo”,
cache: false,
contentType: “application/json; charset=utf-8”
})
.always(function () {
alert(‘in always’);
myApp.hidePleaseWait();
})
.done(function () {
alert(‘Viola!!!’);
});
};
}
And c# MVC controller:
public class HomeController : Controller
{
public ActionResult Index()
{
return View();
}
public JsonResult SomeLongRunningProcessForDemo()
{
try
{
Thread.Sleep(new TimeSpan(0,0,2,0));
return Json(new {DidSucceed = true}, JsonRequestBehavior.AllowGet);
}
catch (Exception ex)
{
return Json(new { DidSucceed = false}, JsonRequestBehavior.AllowGet);
}
}
}
And on ViewsHomeIndex.cshtml, I created a button as follows:
!!!Click Me!!!
@section scripts
{
$(document).ready(function () {
$(‘#btnDemo’).on(‘click’, function () {
var controller = new ProcessDataController();
controller.ProcessLongData();
});
});
}
I want to email the mvc test project code, could you share your email address?
Thank you in advance for your time.
My email address is listed in Contact Me page (above).
Done!!! please check your email
Not there, man.
I am sorry, I tried second time also to send email with attachment but it seems something went wrong.
But I am figure it out why its not working for me. Like you said, its the difference between Bootstrap v2 and v3.
I am posting the reasons here if they might help others.
1) Remove hide from tag.
2) It seems, bootstrap v3 modal HTML template requires, “” and which needs to around model-header and model-body divs.
Bootstrap v3 modal template is
var pleaseWaitDiv3 = $("" + // 1) There is no hide in class here
"" + // 2) We need this for Bootstrap v3
"" + // 2) We need this for Bootstrap v3
"" +
"Processing..." +
"" +
"" +
"" +
"" +
"" +
"" +
"" +
"" +
"");
I don’t know how to post the Bootstrap v3 compatible pleaseWaitDiv here.
@san,
Take a look at the post itself above. The original post is Bootstrap 3 compatible, Did you have to change something?
Hello Sergey, I am sorry that I could not find about Bootstrap version information in the post. Anyways, to answer your question, yes I had to change little bit.
First thing, I did was removing hide class from the first div.
And then I added a div with class modal-dialog as a child to the first div (for which class is set to modal). And then another div with class modal-content as a child to the div with class modal-dialog.
So, the hierarchy that helped me to fix this issue is: modal => modal-dialog => modal-content => modal-header and modal-body as children to modal-content.
Hope this might help others who are also seeing backdrop like me.
Thank you sergey for your time and the post. It really is very helpful and a smart thought.
Pingback: Modal Approach | DiscVentionsTech
Hi, I copied javascript into my jsp and calling the myApp.showPleaseWait(); before ajaxCall. My screen geting dark (not clickable) but cannot see progress bar. Can you please help ? Thanks!
You have to make sure that dialog markup matches your version of Bootstrap.
It doesn’t work for me :-(. Actually, I use boostrap v.3, i did with the same thing as you mention above, but it just showed black colour as the background on my screen.
If you post a sample project, I could take a look. But every time I see this now working is because the HTML syntax is not correct for Bootstrap version you are using.
this works for me on bootstrap 3
Processing…
previous comment -> https://gist.github.com/saten/11168003
All I see is the black background, no actual model with:
Load
Then:
var myApp;
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘Processing…’);
return {
showPleaseWait: function() {
pleaseWaitDiv.modal();
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
This is loaded after my bootstrap v3 js and jquery files. Any ideas why?
@James
Your message cannot be just “Processing”. You have to follow proper syntax for modal dialog for Twitter Bootstrap.
Can’t I just trigger the modal and processing message when clicking submit on a form if the second page isn’t so fast at loading? This would be ideal..
You can, you just have to have HTML for the dialog that is valid from bootstrap perspective $(“Processing”) is not a valid html for a dialog.
Same thing happened to me, grey background and no text or progress.
Using bootstrap 3.1.1 and MVC.NET
Fixed the following –
added modal-dialog and modal-content div containers
removed the ‘hide’ from the outer ‘modal hide’ div class
replaced the ‘bar’ with ‘progress-bar’
So the new line should be:
var pleaseWaitDiv = $(‘Processing…’);
I use it on a form so i added to my button the following onclick attribute
onclick=”myApp.showPleaseWait(); return true;”
WP messed up my replaced line so here it is again:
var pleaseWaitDiv = $(‘Processing…’);
Hope it works now…
Ok… sorry i dont know how to put code in WP reply.
I put it in pastebin here:
http://pastebin.com/0yFEXp9N
$(document).ready(function(){
var myApp;
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘Processing…’);
return {
showPleaseWait: function() {
pleaseWaitDiv.modal();
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
myApp.showPleaseWait();
};
sorry it is not working as expected: the bar and the label Processing is not visible. I tried to see the dom …
Processing….
This part is hidden … i tried to remove manually in the dom “hide” but anyway is not correct
@Cristian. You cannot use just ‘Processing’. You have to use html that is compatible with bootstrap. Look up what dialog needs to look like on bootstrap site.
For those of you running MVC 5 and bootstrap 3 here is the updated code.
var myApp;
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘Processing…60% Complete’);
return {
showPleaseWait: function () {
pleaseWaitDiv.modal();
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
my mistake. Here is a paste bucket that shows the full jquery code along with the HTML
http://goo.gl/8dE49u
So, I assume this worked for you. Cool.
Looks great! Thanks.
Ok. it worked when i use @thedrs2 code. var pleaseWaitDiv = $(‘Processing…’);
Thanks
For those who are not able to see model.
Solution Is:
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘Please Wait…’);
return {
showPleaseWait: function() {
pleaseWaitDiv.modal(‘show’);
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
Pingback: Find out the Front-end framework resouces | Pixelsgrid
Thanx for your code Sergey,
But I have an issue.
Every time I call it before AJAX request, the modal will show right after the AJAX call finish.
myApp.showPleaseWait();
//AJAX Request Here
myApp.hidePleaseWait();
can it actually called like that ?
If your request is async, then your code cannot look like this. You have to call hide inside the ajax callback.
This is what worked for me. The original post will not work with Bootstrap 3+.
var pleaseWaitDiv = $(‘Processing…’);
Pingback: twitter bootstrap xaml - Search Yours
Thanks!
Thank you! Its awesome!
Was a very good example, but no modal popup was happening to me. Finaly get it to work with latest bootstrap & jquery.
var myApp;
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘ Please Wait <!– –> Processing ‘);
return {
showPleaseWait: function() {
pleaseWaitDiv.modal();
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
function showLoading(){
myApp.showPleaseWait();
}
function removeLoading(){
myApp.hidePleaseWait();
}
Hi There, , I am also not able to see the processing dialog. How do we install the modal.js . is it included in bootstrap.min file
modal is a function inside bootstrap.
This is my working code.
var loadingPannel;
loadingPannel = loadingPannel || (function () {
var lpDialog = $(“” +
“” +
“” +
“Processing…” +
“” +
“” +
” “+
“Please Wait…”+
“”+
“”+
“” +
“” +
“” +
“”);
return {
show: function () {
lpDialog.modal(‘show’);
},
hide: function () {
lpDialog.modal(‘hide’);
},
};
})();
Codes are gone after posting..
var loadingPannel;
loadingPannel = loadingPannel || (function () {
var lpDialog = $(”
Processing…
“Please Wait…
“);
return {
show: function () {
lpDialog.modal(‘show’);
},
hide: function () {
lpDialog.modal(‘hide’);
},
};
})();
Here my code.
http://codepen.io/anon/pen/qdjqoO
Hello,
Not working with me.I am using bootstrap 3. modal box is not showing.
@bhumishah You need to make sure you follow BS3 layout for dialog. You can see similar problem above
This will work with Bootstrap 3
var myApp;
myApp = myApp || (function () {
var pleaseWaitDiv = $(‘Processing…’);
return {
showPleaseWait: function () {
pleaseWaitDiv.modal();
},
hidePleaseWait: function () {
pleaseWaitDiv.modal(‘hide’);
},
};
})();
Ignore the above, it removes all the HTML when you post.
You can find it here instead – jsfiddle.net/terryr2015/qzzxuuj7/
@Sergey Barskiy .What do you mean by “Layout.cshtml continued to grow with system wide reusable htlm” . Is this something i should worry about in my project ?
Layout.cshtml continued to grow with system wide reusable html, and I wanted to cut down on that.
You can always break it up into chunks / partial views.
This is code written entirely in JavaScript, works with Bootstrap 3.
Two functions: showPleaseWait and hidePleaseWait.
https://gist.github.com/Ravaelles/0507c53597c8a82168eb
Hello everybody, I need a help in ajax update progress in asp.net c#. I am developing a web application in which on button click a job executed in SQL server in through job s stored procedure execute where different queries and condition applied for long running data upload insertion process.
Basically i need a loader which should shown on button click and it will be displayed until job executed completely because here page post-back logic not applied i have that’s why create a job.
Please help in this if anybody knows to do that in simplest way, it will be very grateful.
Best Regards,
Imtiaz Malik
The comment from san @ March 30, 2014 at 3:55 pm fixed the “black screen” issue for me on Bootstrap v3
Just dropped in to say thanks for this Sergey! Also thanks to @Adrian for his pastebin as I’m running MVC 5 and bootstrap 3 here too and I needed this fix to make it work.
Ah, so it turns out this doesn’t work at all on Safari (either on a Mac or an iPad) – any suggestions??
Yet strangely it DOES work on Safari on Windows 7. So it seems to be Safari on iOS it doesn’t work.
Its working fine on chrome but not working on IE.
I am using this like below.
$(function () {
$(“#upload”).bind(“click”, function () {
myApp.showPleaseWait();
//Long operation include multiple ajax calls.
myApp.hidePleaseWait()
});
});
If you are making ajax calls, this will not work. You need to put hide call into last ajax call back. Since ajax calls are asynchronous, this will show and immediately hide your please wait window.
Pingback: How to show loading indicator in web page | AndyCnZh Blog
Thanks, it’s amazing solution for my project. Thank you for sharing.
After 1 day, its working from codebehind just onclientclickevent
OnClientClick=”loadingPannel.show();”
thanks a lot, it was pretty much what I was looking for
Pingback: twitter-bootstrap - Twitter Bootstrap - Centro De Diálogo Modal
Pingback: asp.net-mvc - Bootstrap Barra de Progreso para MVC de Carga de Archivos
Pingback: asp.net-mvc - Bootstrap Barra di Avanzamento per MVC Upload di File
Pingback: modal-dialog - Twitter Bootstrap - Centro Della Finestra Di Dialogo Modale
Pingback: Load mask plugin for twitter bootstrap – inneka.com