.
National Convention Registration Sample
This demo codes allow the developer to set multiple number of persons for a single registration.
HTML
<!-- minified via http://minifycode.com/html-minifier/-->
<head><base target='_blank'><meta name='viewport' content='width=device-width, initial-scale=1.0' /><title>Registration</title><link href='https://fonts.googleapis.com/icon?family=Material+Icons' rel='stylesheet'><link rel='stylesheet' href='https://cdnjs.cloudflare.com/ajax/libs/materialize/0.98.0/css/materialize.min.css'></head><body>
<div class="waves-light headerBanner"></div>
<div id="DivForm" class="main" style="max-width: 480px;margin: 40px auto;padding:10px;">
<div id="DivInfo" class="row" style="background-color:LemonChiffon;">
<div class="col s12">
<h3 class="center-align teal-text">Registration</h3>
<a name="test"></a>
<p>1)Download <a href="#test" target="_self" onclick="window.location.assign('https://drive.google.com/uc?export=download&id=<FILE_ID>');">Hard Copy</a>.</p>
<p>2)Fill out the following form.</p>
</div>
</div>
<!--Begin Form Section -->
<form id="FormPerson" >
<div id="FormHeader">
<div class="input-field col s12">
<i class="material-icons prefix">group_work</i>
<select id="state" name="state"></select>
</div>
<div class="input-field col s12">
<i class="material-icons prefix">group_work</i>
<select id="division" name="division"></select>
</div>
</div>
<div id="FormBody"></div>
<div id="FormFooter" align="right" >
<input type="button" value="Send" class="btn"
onclick="sendForm()" />
</div>
</form>
<!--End Form Section -->
</div>
<div id="DivProgress" class="center-align" style="display: none;max-width: 480px;margin: 40px auto;padding:10px;">
<p class="imageUploading"></p>
<p>Uploading. Please wait...</p>
</div>
<div id="DivDone" class="center-align" style="display: none;max-width: 480px;margin: 40px auto;padding:10px;">
<p class="imageDone"></p>
<p>Done</p>
<input type="button" value="New Registration" class="btn"
onclick="newForm()" />
</div>
<script type='text/javascript' src='https://code.jquery.com/jquery-2.1.1.min.js'></script> <script src='https://cdnjs.cloudflare.com/ajax/libs/materialize/0.98.0/js/materialize.min.js'></script> </body>
|
CSS
.headerBanner{height:50px;
background:url('');
}
.imageUploading {margin:auto;width:200px;height:128px;
background:url('') no-repeat;}
.imageDone {margin:auto;width:128px;height:128px;
background: url() no-repeat;}
|
JS
$(document).ready(function () {
setSelectState();
setFormBody();
$('#state').change(function() {
//alert ($('#state').val());
setSelectDivision();
});
});
function setSelectDivision(){
var request;
$('#division').empty();
$('#division').append("<option value='' disabled selected>Wait...</option>")
$('#division').material_select();
request = $.ajax({
url: "https://script.google.com/macros/s/AKfycbygVbZJEaZEEaKGAYPLiFgNDgZ0dSaqgmnfFKUMXCtsCmNhoHEe/exec?action=finddivisions&statecode="+ $('#state').val(),
type: "get"
});
request.done(function(response, textStatus, jqXHR) {
// log a message to the console
//console.log(response);
//console.log(textStatus);
//console.log(jqXHR);
$('#division').empty();
$('#division').append("<option value='' disabled selected>Select Division</option>")
$.each(response.values, function(key, item) {
//console.log(item);
$('#division').append("<option value="+item.District_Code+">" + item.District_Name + "</option>");
$('#division').material_select();
});
});
// callback handler that will be called on failure
request.fail(function(jqXHR, textStatus, errorThrown) {
// log the error to the console
console.error(
"The following error occured: " +
textStatus, errorThrown
);
});
// callback handler that will be called regardless
// if the request failed or succeeded
request.always(function() {
// reenable the inputs
//$inputs.prop("disabled", false);
});
}
function setSelectState(){
var request;
$('#state').empty();
$('#state').append("<option value='' disabled selected>Wait...</option>")
$('#state').material_select();
$('#division').empty();
$('#division').material_select();
request = $.ajax({
url: "https://script.google.com/macros/s/AKfycbygVbZJEaZEEaKGAYPLiFgNDgZ0dSaqgmnfFKUMXCtsCmNhoHEe/exec?action=getstates",
type: "get"
});
request.done(function(response, textStatus, jqXHR) {
// log a message to the console
//console.log(response);
//console.log(textStatus);
//console.log(jqXHR);
$('#state').empty();
$('#state').append("<option value='' disabled selected>Select State</option>")
$.each(response.values, function(key, item) {
//console.log(item);
$('#state').append("<option value="+item.State_Code+">" + item.State_Name + "</option>");
$('select').material_select();
});
});
// callback handler that will be called on failure
request.fail(function(jqXHR, textStatus, errorThrown) {
// log the error to the console
console.error(
"The following error occured: " +
textStatus, errorThrown
);
});
// callback handler that will be called regardless
// if the request failed or succeeded
request.always(function() {
// reenable the inputs
//$inputs.prop("disabled", false);
});
}
function setFormBody(){
var labelPerson = "Delegate";
var htmlFormSection = "<div id='FormSection{Person}'><h5 class='left-align teal-text' style='padding-top:20px;'> <span id='Label{Person}'>{labelPerson}</span></h5><div class='input-field col s12'> <i class='material-icons prefix'>account_circle</i> <input id='{Person}_Name' type='text' name='{Person}_Name' class='validate' required='' aria-required='true'> <label for='{Person}_Name'>Name</label></div><div class='input-field col s12'> <i class='material-icons prefix'>picture_in_picture</i> <input id='{Person}_Pid' type='text' name='{Person}_Pid' class='validate' required='' aria-required='true'> <label for='{Person}_Pid'>Personal ID</label></div><div class='input-field col s12'> <i class='material-icons prefix'>assignment_ind</i> <input id='{Person}_Oid' type='text' name='{Person}_Oid' class='validate' required='' aria-required='true'> <label for='{Person}_Oid'>Organization ID</label></div><div class='input-field col s12'> <i class='material-icons prefix'>work</i> <select id='{Person}_Position' name='{Person}_Position'><option value='' disabled selected>Position</option><option value='Head'>Head</option><option value='Vice'>Vice</option><option value='Deputy'>Deputy</option><option value='Secretary'>Secretary</option><option value='Others'>Others</option> </select></div><div class='file-field input-field col s12'><div class='btn yellow accent-4'> <span>Picture</span> <input id='{Person}_File' name='{Person}_File' type='file'></div><div class='file-path-wrapper'> <input class='file-path validate' type='text' placeholder='Select Picture'></div></div></div>";
var totalPerson = 1;
for (i = 1; i < totalPerson + 1; i++) { /*create a unique label*/
var newLabelPerson = labelPerson.concat(" ", i); /*create unique id */
var newIdPerson = "Person" + i; /*replace id placeholders */
var regex = new RegExp('{Person}', 'g');
var newHtmlFormSection = htmlFormSection;
newHtmlFormSection = newHtmlFormSection.replace('{labelPerson}', newLabelPerson);
newHtmlFormSection = newHtmlFormSection.replace(regex, newIdPerson);
$('#FormBody').append(newHtmlFormSection);
}
$('select').material_select();
}
function isEmpty($inputs) {
var check = false;
$.each($inputs, function (key, item) {
if (item.value == "") {
check = true
}
});
return check;
}
function newForm(){
$('#DivDone').hide();
$('#DivForm').show();
$('#FormPerson')[0].reset();
setSelectState();
setFormBody();
}
function sendDone(){
$('#DivProgress').hide();
$('#DivDone').show();
}
function sendForm(){
var $inputs = $('#FormPerson').find("input, select");
if (isEmpty($inputs)) {
alert("Please fill all the fields.")
} else {
alert("Sending now...");
$('#DivForm').hide();
$('#DivProgress').show();
setTimeout(sendDone, 3000);
}
/*
google.script.run
.withSuccessHandler(updateOutput)
.processForm(this.parentNode)
*/
}
|
CODEPEN
Demo:
.
See the Pen National Convention Registration Sample by notarazi (@notarazi) on CodePen.
No comments:
Post a Comment