123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421 |
- /**
- *
- * DWSurvey 3.0 中关于问卷设计Javascript
- *
- * @desc: design survey
- * @author: keyuan(@keyuan, keyuan258@gmail.com)
- * @github: https://github.com/wkeyuan/DWSurvey
- *
- * Copyright 2012, 2017 调问问卷(DWSurvey,http://dwsurvey.net)
- *
- */
- $(document).ready(function(){
- var ctx=$("#ctx").val();
- var sid = $.getUrlParam("sid");
- var surveyId = $.getUrlParam("surveyId");
- var tag = $.getUrlParam("tag");
- var ruleCode = $.getUrlParam("ruleCode");
- var wxCode = $.getUrlParam("code");
- $("#sid").val(sid);
- $("#id").val(surveyId);
- $("#tag").val(tag);
- $("#ruleCode").val(ruleCode);
- $("#wxCode").val(wxCode);
- if(tag!="" && (tag==="p" || tag==="s")){
- $("#preview_head_top").show();
- }else{
- $("#preview_head_top").remove();
- }
- querySurveyAll(function(){
- sww();
- if(!$("#preview_head_top")[0]){
- checkAnswerSurvey(sid);
- }
- });
- });
- function sww(){
- $(".nextPage_a").click(function(){
- if(validateForms()){
- var thParent=$(this).parent();
- var nextPageNo=thParent.find("input[name='nextPageNo']").val();
- $(".li_surveyQuItemBody").hide();
- $(".surveyQu_"+nextPageNo).fadeIn("slow");
- $("html,body").animate({scrollTop:10},500);
- }
- return false;
- });
- $(".prevPage_a").click(function(){
- var thParent=$(this).parent();
- var prevPageNo=thParent.find("input[name='prevPageNo']").val();
- $(".li_surveyQuItemBody").hide();
- $(".surveyQu_"+prevPageNo).fadeIn("slow");
- $(window).scrollTop(10);
- return false;
- });
- $(".m_clickQuOrderItem").click(function(){
- var visibleOrderbyNum=$(this).parents().find(".m_orderby_num:visible");
- var thOrderbyNum=$(this).find(".m_orderby_num");
- if(!$(this).find(".m_orderby_num:visible")[0]){
- var thNum=0;
- $(this).append("<select class='m_orderby_sel' > </select>");
- var mOrderbySel=$(this).find(".m_orderby_sel");
- var quOrderItems=$(this).parents().find(".m_clickQuOrderItem");
- $.each(quOrderItems,function(i,item){
- mOrderbySel.append("<option value='"+(i+1)+"'>移至排序"+(i+1)+"</option>");
- var targetHid=$(this).parents(".ui-controlgroup-controls ").find(".quOrderItemHidInput[value='"+(i+1)+"']");
- if(!targetHid[0] && thNum===0){
- thNum=(i+1);
- }
- });
- thOrderbyNum.text(thNum);
- thOrderbyNum.show();
- mOrderbySel.val(thNum)
- $(this).find(".quOrderItemHidInput").val(thNum);
- }
- bindEvent();
- lgcommon($(this));
- validateCheck($(this).parents(".li_surveyQuItemBody"),false);
- return false;
- });
- function bindEvent(){
- $(".m_orderby_sel").unbind();
- $(".m_orderby_sel").change(function(){
- var thOrderbyItem=$(this).parents(".m_clickQuOrderItem");
- var thOrderByNum=thOrderbyItem.find(".quOrderItemHidInput").val();
- var thChangeNum=$(this).val();
- var targetHid=$(this).parents(".ui-controlgroup-controls ").find(".quOrderItemHidInput[value='"+thChangeNum+"']");
- if(targetHid[0]){
- var targetOrderbyItem=targetHid.parents(".m_clickQuOrderItem");
- targetOrderbyItem.find(".m_orderby_num").text(thOrderByNum);
- targetOrderbyItem.find(".quOrderItemHidInput").val(thOrderByNum);
- targetOrderbyItem.find(".m_orderby_sel").val(thOrderByNum);
- }
- thOrderbyItem.find(".m_orderby_num").text(thChangeNum);
- thOrderbyItem.find(".quOrderItemHidInput").val(thChangeNum);
- thOrderbyItem.find(".m_orderby_sel").val(thChangeNum);
- });
- }
- /**评分题*/
- $(".starRating .fa").hover(function(){
- var prevAll=$(this).prevAll();
- prevAll.removeClass("fa-star-o");
- prevAll.addClass("fa-star");
- $(this).removeClass("fa-star-o");
- $(this).addClass("fa-star");
- },function(){
- var scoreRow=$(this).parents(".scoreRow");
- var starNum=scoreRow.find(".scoreNumInput").val();
- if(starNum==""&&starNum<=0){
- var thParent=$(this).parent();
- var fas=thParent.find(".fa");
- fas.removeClass("fa-star");
- fas.addClass("fa-star-o");
- }
- });
- $(".starRating .fa").click(function(){
- var thParent=$(this).parent();
- var fas=thParent.find(".fa");
- fas.removeClass("fa-star");
- fas.addClass("fa-star-o");
- var prevAll=$(this).prevAll();
- prevAll.removeClass("fa-star-o");
- prevAll.addClass("fa-star");
- $(this).removeClass("fa-star-o");
- $(this).addClass("fa-star");
- var scoreRow=$(this).parents(".scoreRow");
- var starNum=0;
- if(prevAll[0]){
- starNum=prevAll.size();
- }
- scoreRow.find(".scoreNumInput").val(starNum+1);
- validateCheck($(this).parents(".li_surveyQuItemBody"),false);
- return false;
- });
- //表单验证
- /**初始化表单骓证配置**/
- function validateForms(){
- var result=true;
- var surveyQuItemBodys=$(".li_surveyQuItemBody");
- var firstError=null;
- $.each(surveyQuItemBodys,function(){
- var quItemBody=$(this);
- if(!validateCheck(quItemBody,true)){
- //定位到这题
- if(firstError==null){
- firstError=quItemBody;
- }
- result=false;
- }
- });
- if(firstError!=null){
- $(window).scrollTop(firstError.offset().top);
- }
- if($("#jcaptchaImgBody").is(":visible")){
- var jcaptchaInput = $("input[name='jcaptchaInput']").val();
- if(jcaptchaInput===""){
- $("#jcaptchaImgBody .errorItem").show();
- result = false;
- }else{
- $("#jcaptchaImgBody .errorItem").hide();
- }
- }
- return result;
- }
- function validateCheck(quItemBody,isSubForm){
- if(quItemBody.is(":visible")){
- var quId=quItemBody.find(".quId").val();
- var quType=quItemBody.find(".quType").val();
- var isRequired=quItemBody.find(".isRequired").val();
- var validateStatus=false;
- var checkType = "";
- if(isRequired==="0"){
- validateStatus = true;
- return true;
- }
- if(quType==="RADIO"){
- var hv = quItemBody.find(".hv").val();
- if(hv=="4"){
- var radioSelectVal = quItemBody.find(".radioSelect").val();
- if(radioSelectVal!="" && radioSelectVal!="0"){
- validateStatus = true;
- }else{
- validateStatus = false;
- }
- }else{
- validateStatus=quItemBody.find("input[type='radio']:checked")[0];
- }
- }else if(quType==="CHECKBOX"){
- validateStatus=quItemBody.find("input[type='checkbox']:checked")[0];
- }else if(quType==="FILLBLANK"){
- var value = quItemBody.find(".fillblankInput").val();
- validateStatus=value!="";
- checkType = quItemBody.find(".checkType").val();
- if(validateStatus){
- validateStatus = checkoutData(checkType, value);
- }
- }else if(quType==="ORDERQU"){
- //quItemBody.find(".quOrderByLeftUl label");
- validateStatus=!quItemBody.find(".quOrderItemHidInput[value=0]")[0];
- }else if(quType==="MULTIFILLBLANK"){
- validateStatus=true;
- var quScoreOptionTrs=quItemBody.find(".mFillblankTableTr");
- var paramInt01=quItemBody.find(".paramInt01");
- var anNum = 0;
- $.each(quScoreOptionTrs,function(){
- var scoreNumInput=$(this).find(".dwMFillblankInput");
- if(scoreNumInput.val()!=""){
- anNum++;
- }
- });
- if(paramInt01[0]){
- if(paramInt01.val()=='0'){
- if(anNum!=quScoreOptionTrs.size()) {
- validateStatus = false;
- }
- }else{
- if(anNum<parseInt(paramInt01.val())) {
- validateStatus = false;
- }
- }
- }else{
- if(anNum!=quScoreOptionTrs.size()) {
- validateStatus = false;
- }
- }
- }else if(quType==="SCORE"){
- validateStatus=true;
- var quScoreOptionTrs=quItemBody.find(".quScoreOptionTr");
- $.each(quScoreOptionTrs,function(){
- var scoreNumInput=$(this).find(".scoreNumInput");
- if(scoreNumInput.val()===""){
- validateStatus=false;
- return false;
- }
- });
- }else if(quType==="submitSurveyBtn" || quType==="PARAGRAPH" || quType==="PAGETAG"){
- return true;
- }
- }else{
- validateStatus=true;
- }
- if(validateStatus){
- quItemBody.find(".errorItem").remove();
- }else{
- if(isSubForm){
- if(quItemBody.find(".errorItem")[0]){
- quItemBody.find(".errorItem").remove();
- }
- var errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请检查题目答案,为必答项!</label></div>";
- if(checkType=="EMAIL"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入Email,为必答项!</label></div>";
- }else if(checkType=="UNSTRCN"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入非中文字符,为必答项!</label></div>";
- }else if(checkType=="STRCN"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入中文字符,为必答项!</label></div>";
- }else if(checkType=="NUM"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入数字,为必答项!</label></div>";
- }else if(checkType == "DIGITS"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入整数,为必答项!</label></div>";
- }else if(checkType == "TELENUM"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入电话,为必答项!</label></div>";
- }else if(checkType == "PHONENUM"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入手机,为必答项!</label></div>";
- }else if(checkType == "TELE_PHONE_NUM"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入电话或手机,为必答项!</label></div>";
- }else if(checkType == "DATE"){
- //2014-01-01 12:00:00
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入如:2014-01-01,为必答项!</label></div>";
- }else if(checkType == "IDENTCODE"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入身份证号,为必答项!</label></div>";
- }else if(checkType == "ZIPCODE"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入邮编,为必答项!</label></div>";
- }else if(checkType == "URL"){
- errorHtml="<div class=\"errorItem\"><label for=\"\" class=\"error\">请输入URL,为必答项!</label></div>";
- }
- quItemBody.find(".surveyQuItemContent").append(errorHtml);
- }
- }
- return validateStatus;
- }
- $(".submitSurvey").click(function(){
- if(validateForms()){
- $("#surveyForm").submit();
- }
- return false;
- });
- $(".radioSelect").change(function(){
- var thVal = $(this).val();
- var thName = $(this).attr("name");
- var quCoItemUlLi = $(this).parents("li.quCoItemUlLi");
- var quItemInputCase= quCoItemUlLi.find(".quItemInputCase[itemid='"+thVal+"']");
- var isNote = quItemInputCase.find(".isNote").val();
- if(isNote=="1"){
- quCoItemUlLi.find(".dwQuOptionItemNote").hide();
- var dwQuOptionItemNote = quCoItemUlLi.find(".dwQuOptionItemNote[name='text_"+thName+"_"+thVal+"']");
- dwQuOptionItemNote.show();
- }else{
- quCoItemUlLi.find(".dwQuOptionItemNote").hide();
- }
- var thObj = $(this);
- var quItemBody = $(this).parents(".li_surveyQuItemBody");
- validateCheck(quItemBody,false);
- return false;
- });
- $("#dwSurveyQuContent .dwQuOptionItemContent").unbind();
- $("#dwSurveyQuContent .dwQuOptionItemContent").click(function(){
- clickItem($(this));
- lgcommon($(this));
- validateCheck($(this).parents(".li_surveyQuItemBody"),false);
- $(".fillblankInput,.dwMFillblankInput,.dwChenMFillblankInput").blur();
- });
- function clickItem(thObj){
- var quItemBody=thObj.parents(".li_surveyQuItemBody");
- var quType=quItemBody.find(".quType").val();
- var dwQuInputLabel=thObj.find(".dwQuInputLabel");
- if("RADIO"===quType){
- quItemBody.find(".dwQuInputLabel").removeClass("checked");
- quItemBody.find("input[type='radio']").prop("checked",false);
- thObj.find("input[type='radio']").prop("checked",true);
- dwQuInputLabel.addClass("checked");
- quItemBody.find(".dwQuOptionItemContent").removeClass("active");
- thObj.addClass("active");
- }else if("CHECKBOX"===quType){
- var thCheckbox = thObj.find("input[type='checkbox']");
- if(thCheckbox.prop("checked")){
- thObj.find("input[type='checkbox']").prop("checked",false);
- dwQuInputLabel.removeClass("checked");
- thObj.removeClass("active");
- }else{
- thObj.find("input[type='checkbox']").prop("checked",true);
- dwQuInputLabel.addClass("checked");
- thObj.addClass("active");
- }
- }else if("MULTIFILLBLANK"===quType){
- var chenRow=thObj.parents(".mFillblankTableTr");
- chenRow.find(".dwQuInputLabel").removeClass("checked");
- chenRow.find("input[type='radio']").prop("checked",false);
- thObj.find("input[type='radio']").prop("checked",true);
- dwQuInputLabel.addClass("checked");
- }
- }
- //填空题
- $(".fillblankInput,.dwMFillblankInput,.dwChenMFillblankInput").blur(function(){
- lgcommon($(this));
- validateCheck($(this).parents(".li_surveyQuItemBody"),true);
- });
- function resetQuNum(){
- var quTitleNums=$(".quTitleNum");
- $.each(quTitleNums,function(i,item){
- $(this).text((i+1)+"、")
- });
- }
- resetQuNum();
- var quTitleNums=$(".quTitleNum");
- $.each(quTitleNums,function(){
- var nextObj=$(this).next();
- if(nextObj[0]){
- var childrens=nextObj.children();
- if(childrens[0]){
- var firstChildren=childrens.first();
- if(firstChildren.is("p")){
- $(this).prependTo(firstChildren);
- }
- }
- }
- });
- var quLogics=$("#dwSurveyQuContent .quLogicItem");
- $.each(quLogics,function(){
- var loginItem=$(this);
- var cgQuItemId=loginItem.find(".cgQuItemId").val();
- var skQuId=loginItem.find(".skQuId").val();
- var logicId=loginItem.find(".logicId").val();
- var logicType=loginItem.find(".logicType").val();
- if(logicType==="2"){
- //逻辑类型为“显示”2 则初始化为隐藏
- var hidQuItemBody=$(".quId[value='"+skQuId+"']").parents(".li_surveyQuItemBody");
- hidQuItemBody.hide();
- hidQuItemBody.addClass("hidFor"+logicId);
- hidQuItemBody.find(".answerTag").attr("disabled",true);
- }
- });
- bindDateEvent();
- }
- function refreshAutoCode(codeImgId){
- var ctx = $("#ctx").val();
- $("#"+codeImgId).attr("src",ctx+"/jcaptcha.action");
- }
|