Solved

Implement wizard step UI navigation with jquery slider in MVC view

Posted on 2010-09-09
10
2,119 Views
Last Modified: 2013-11-08
I have asp.net MVC2 app and have implemented wizard navigation to complete a customer survey.

Customers can fill out different surveys and each survey has a different number of questions.

A survey is loaded and each question is displayed one at a time with a NEXT button to proceed onto next question.

I need to implement something like a jquery slider/progress bar plugin or something experts can recommend

http://jqueryui.com/demos/slider/#rangemax
or something like
http://jqueryui.com/demos/progressbar/

so as a user progresses through survey by clicking the next button the slider progresses as well.
In the view I can get the total number of questions to use this as the range max.
How can I implement this?  
0
Comment
Question by:ToString1
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 6
  • 4
10 Comments
 
LVL 40

Expert Comment

by:gurvinder372
ID: 33634676
0
 

Author Comment

by:ToString1
ID: 33634776
Ideally I want something from the jquery core like this

http://jqueryui.com/demos/slider/#rangemax

I need a code snippet of how to pass the number of questions to the slider so it progresses correctly.

0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 33634921
If i have understood the requirement correctly, you are looking for
Number of steps in the wizard
http://jqueryui.com/demos/slider/#option-step

<<I need a code snippet of how to pass the number of questions to the slider so it progresses correctly.>>
How would you like to distribute the questions among screens?
0
Salesforce Has Never Been Easier

Improve and reinforce salesforce training & adoption using WalkMe's digital adoption platform. Start saving on costly employee training by creating fast intuitive Walk-Thrus for Salesforce. Claim your Free Account Now

 

Author Comment

by:ToString1
ID: 33635181
What I do is have an MVC ActionResult that returns one question at a time.

My view inherits from a viewmodel that passes in the total number of questions and the current question.
0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 33636612
If you give min as '1' and max as 'number of questions', doesn't that give you what you are looking for?
$("#slider-range-max").slider({
                  range: "max",
                  min: 1, \\starting point
                  max: 10, \\number of questions
                  value: 2,
                  slide: function(event, ui) {
                        $("#amount").val(ui.value);
                  }
            });
0
 

Author Comment

by:ToString1
ID: 33636740
Hi Yes

It does but I am unsure of how to pass this to the jquery function from hidden fields in my view

So in my view I have

 <input name="currentQuestionNo" type="hidden" value="<%Model.customer.qustID%>" />
<input name="totalQuestions" type="hidden" value="<%Model.customer.qustID%>" />


How can I pass  questionNo to the jquery

$("#slider-range-max").slider({
                  range: "max",
                  min: 1, \\starting point
                  max: 10,                          // totalQuestions from hidden field
                  value: 2,                                 //currentQuestionNo  from hidden field
                  slide: function(event, ui) {
                        $("#amount").val(ui.value);
                  }
            });

0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 33637053
Make it

$("#slider-range-max").slider({
                  range: "max",
                  min: 1,
                  max: $(input[name='totalQuestions']).value,
                  value: 2,                                
                  slide: function(event, ui) {
                        $("#amount").val(ui.value);
                  }
            });

0
 

Author Comment

by:ToString1
ID: 33637454
Thanks but if I try that I get "input undefined"

Its on the
 max: $(input[name='totalQuestions']).value,
0
 
LVL 40

Accepted Solution

by:
gurvinder372 earned 500 total points
ID: 33637484
are you not calling this function at the document.ready (body onload event)?

If not, then this input element will not be available to the slider unless the document is ready to be processed
0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 33637628
thanks for the points
0

Featured Post

MS Dynamics Made Instantly Simpler

Make Your Microsoft Dynamics Investment Count  & Drastically Decrease Training Time by Providing Intuitive Step-By-Step WalkThru Tutorials.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Introduction Chart.js, used properly, can visually add a difference to your charting applications. It engages your visitors and allows them to interact with data they otherwise wouldn't be able to without expensive and complicated systems. For this…
Introduction Knockoutjs (Knockout) is a JavaScript framework (Model View ViewModel or MVVM framework).   The main ideology behind Knockout is to control from JavaScript how a page looks whilst creating an engaging user experience in the least …
The purpose of this video is to demonstrate how to set up the WordPress backend so that each page automatically generates a Mailchimp signup form in the sidebar. This will be demonstrated using a Windows 8 PC. Tools Used are Photoshop, Awesome…
The viewer will learn the basics of jQuery including how to code hide show and toggles. Reference your jQuery libraries: (CODE) Include your new external js/jQuery file: (CODE) Write your first lines of code to setup your site for jQuery…

730 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question