Formularz 2 pola nie obowiązkowe

0

Witam,
Posiadam formularz (nie robiłem go samemu) w którym wszystkie pola są obowiązkowe, ale potrzebuję zrobić żeby imię i nazwisko oraz email były nieobowiązkowe. Oto strona http://hacjendadziwnow.pl/kontakt.php
Mógłby ktoś pomóc?

Tutaj jest kod .js

//forms
;(function($){
	$.fn.forms=function(o){
		return this.each(function(){
			var th=$(this)
				,_=th.data('forms')||{
					errorCl:'error',
					emptyCl:'empty',
					invalidCl:'invalid',
					notRequiredCl:'notRequired',
					successCl:'success',
					successShow:'4000',
					mailHandlerURL:'wyslij.php',					
					stripHTML:true,
					smtpMailServer:'localhost',
					targets:'input,textarea',
					controls:'a[data-type=reset],a[data-type=submit]',
					validate:true,
					rx:{
						".state":{rx:/^[a-zA-Z'][a-zA-Z-' ]+[a-zA-Z']?$/,target:'input'},
						".email":{rx:/^(("[\w-\s]+")|([\w-]+(?:\.[\w-]+)*)|("[\w-\s]+")([\w-]+(?:\.[\w-]+)*))(@((?:[\w-]+\.)*\w[\w-]{0,66})\.([a-z]{2,6}(?:\.[a-z]{2})?)$)|(@\[?((25[0-5]\.|2[0-4][0-9]\.|1[0-9]{2}\.|[0-9]{1,2}\.))((25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\.){2}(25[0-5]|2[0-4][0-9]|1[0-9]{2}|[0-9]{1,2})\]?$)/i,target:'input'},
						".phone":{rx:/^\+?(\d[\d\-\+\(\) ]{5,}\d$)/,target:'input'},
						".fax":{rx:/^\+?(\d[\d\-\+\(\) ]{5,}\d$)/,target:'input'},
						".message":{rx:/.{20}/,target:'textarea'}
					},
					preFu:function(){
						_.labels.each(function(){
							var label=$(this),
								inp=$(_.targets,this),
								defVal=inp.val(),
								trueVal=(function(){
											var tmp=inp.is('input')?(tmp=label.html().match(/value=['"](.+?)['"].+/),!!tmp&&!!tmp[1]&&tmp[1]):inp.html()
											return defVal==''?defVal:tmp
										})()
							trueVal!=defVal
								&&inp.val(defVal=trueVal||defVal)
							label.data({defVal:defVal})								
							inp
								.bind('focus',function(){
									inp.val()==defVal
										&&(inp.val(''),_.hideEmptyFu(label),label.removeClass(_.invalidCl))
								})
								.bind('blur',function(){
									_.validateFu(label)
									if(_.isEmpty(label))
										inp.val(defVal)
										,_.hideErrorFu(label.removeClass(_.invalidCl))											
								})
								.bind('keyup',function(){
									label.hasClass(_.invalidCl)
										&&_.validateFu(label)
								})
							label.find('.'+_.errorCl+',.'+_.emptyCl).css({display:'block'}).hide()
						})
						_.success=$('.'+_.successCl,_.form).hide()
					},
					isRequired:function(el){							
						return !el.hasClass(_.notRequiredCl)
					},
					isValid:function(el){							
						var ret=true
						$.each(_.rx,function(k,d){
							if(el.is(k))
								ret=d.rx.test(el.find(d.target).val())										
						})
						return ret							
					},
					isEmpty:function(el){
						var tmp
						return (tmp=el.find(_.targets).val())==''||tmp==el.data('defVal')
					},
					validateFu:function(el){							
						el.each(function(){
							var th=$(this)
								,req=_.isRequired(th)
								,empty=_.isEmpty(th)
								,valid=_.isValid(th)								
							
							if(empty&&req)
								_.showEmptyFu(th.addClass(_.invalidCl))
							else
								_.hideEmptyFu(th.removeClass(_.invalidCl))
							
							if(!empty)
								if(valid)
									_.hideErrorFu(th.removeClass(_.invalidCl))
								else
									_.showErrorFu(th.addClass(_.invalidCl))								
						})
					},
					getValFromLabel:function(label){
						var val=$('input,textarea',label).val()
							,defVal=label.data('defVal')								
						return label.length?val==defVal?'nope':val:'nope'
					}
					,submitFu:function(){
						_.validateFu(_.labels)							
						if(!_.form.has('.'+_.invalidCl).length)
							$.ajax({
								type: "POST",
								url:_.mailHandlerURL,
								data:{
									name:_.getValFromLabel($('.name',_.form)),
									email:_.getValFromLabel($('.email',_.form)),
									phone:_.getValFromLabel($('.phone',_.form)),
									fax:_.getValFromLabel($('.fax',_.form)),
									state:_.getValFromLabel($('.state',_.form)),
									message:_.getValFromLabel($('.message',_.form)),
									owner_email:_.ownerEmail,
									stripHTML:_.stripHTML
								},
								success: function(){
									_.showFu()
								}
							})			
					},
					showFu:function(){
						_.success.slideDown(function(){
							setTimeout(function(){
								_.success.slideUp()
								_.form.trigger('reset')
							},_.successShow)
						})
					},
					controlsFu:function(){
						$(_.controls,_.form).each(function(){
							var th=$(this)
							th
								.bind('click',function(){
									_.form.trigger(th.data('type'))
									return false
								})
						})
					},
					showErrorFu:function(label){
						label.find('.'+_.errorCl).slideDown()
					},
					hideErrorFu:function(label){
						label.find('.'+_.errorCl).slideUp()
					},
					showEmptyFu:function(label){
						label.find('.'+_.emptyCl).slideDown()
						_.hideErrorFu(label)
					},
					hideEmptyFu:function(label){
						label.find('.'+_.emptyCl).slideUp()
					},
					init:function(){
						_.form=_.me						
						_.labels=$('label',_.form)

						_.preFu()
						
						_.controlsFu()
														
						_.form
							.bind('submit',function(){
								if(_.validate)
									_.submitFu()
								else
									_.form[0].submit()
								return false
							})
							.bind('reset',function(){
								_.labels.removeClass(_.invalidCl)									
								_.labels.each(function(){
									var th=$(this)
									_.hideErrorFu(th)
									_.hideEmptyFu(th)
								})
							})
						_.form.trigger('reset')
					}
				}
			_.me||_.init(_.me=th.data({forms:_}))
			typeof o=='object'
				&&$.extend(_,o)
		})
	}
})(jQuery)
$(window).load(function(){
	$('#contact-form').forms({
		ownerEmail:'#'
	})
})

a tutaj html jakby był potrzebny

<form id="contact-form">
												<div class="success">Wiadomość wysłana<br>
															<strong>Wkrótce na nią odpowiemy.</strong>
													</div>
												<fieldset>
													<label class="name">
														<input type="text" value="Imię i nazwisko:">
															<span class="error">*Wpisz poprawne imię oraz nazwisko.</span> <span class="empty">*To pole jest wymagane.</span>
													</label><br/>
													<label class="email">
														<input type="text" value="E-mail:">
															<span class="error">*Wpisz poprawny adres e-mail.</span> <span class="empty">*To pole jest wymagane.</span>
													</label><br/>
													<label class="phone">
														<input type="text" value="Telefon:">
															<span class="error">*Wpisz poprawny numer telefonu kontaktowego.</span> <span class="empty">*To pole jest wymagane.</span>
													</label><br/>
													<label class="message">
														<textarea>Treść wiadomości:</textarea>
															<span class="error"><br/><br/>*Wiadomość jest zbyt krótka.</span> <span class="empty">*To pole jest wymagane.</span>
													</label><br/>
													<div class="buttons2">
															<a href="#" data-type="reset" class="link2" style="margin-right:20px;">Wyczyść</a>
															<a href="#" data-type="submit" class="link2">Wyślij</a>
													</div>
												</fieldset>
											</form>
0

Po co ci tak rozbudowana funkcja?
Tutaj masz kawałek kodu odpowiadający za sprawdzanie czy wszystkie pola zostały wypełnione:

                                        validateFu:function(el){                                                        
                                                el.each(function(){
                                                        var th=$(this)
                                                                ,req=_.isRequired(th)
                                                                ,empty=_.isEmpty(th)
                                                                ,valid=_.isValid(th)                                                                
 
                                                        if(empty&&req)
                                                                _.showEmptyFu(th.addClass(_.invalidCl))
                                                        else
                                                                _.hideEmptyFu(th.removeClass(_.invalidCl))
 
                                                        if(!empty)
                                                                if(valid)
                                                                        _.hideErrorFu(th.removeClass(_.invalidCl))
                                                                else
                                                                        _.showErrorFu(th.addClass(_.invalidCl))                                                                
                                                })
                                        },

Nie powiem jak, ale musisz sobie dopisać, że jak label class == email lub name to nic nie robi.

Druga opcja to usuń w class="email" i class="name" to może nie będzie brać tego pod uwagę.

1 użytkowników online, w tym zalogowanych: 0, gości: 1