Labels

Learn the powerful enterprise adaptable database:

Getting Started With ADABAS & Natural

Saturday, February 25, 2017

Google Firebase Quickstarts for Javascript


.
Google Firebase Quickstarts for Javascript

1) Goto Firebase Github

Firebase Quickstarts for Javascript: https://github.com/firebase/quickstart-js

2) Download ZIP

3) Unzip and Find Scripts

For this exercise, we will be using Auth scripts.

4) Add Firebase Init Scripts

Let’s say we want to try the google-popup auth, copy the script to google-popup.html .
Your script initially is like below.
Replace the commented codes with the actual Firebase Init Scripts.

5) Start the localhost server

Error?

If you encounter the following error, go to Firebase Console and enable sign-in provider

Message
:
"The given sign-in provider is disabled for this Firebase project. Enable it in the Firebase console, under the sign-in method tab of the Auth section."
__proto__
:
Error

In this exercise, we are going to enable Google Sign-in providers.
This time, sign-in popup window should be available.

Google Authentication with Popup is successful.

.

Google Firebase: Getting Started


.
Google Firebase: Getting Started

1) Create Firebase Project

  1. Create a Firebase project in the Firebase console, if you don't already have one.
  • If you already have an existing Google project associated with your app, click Import Google Project. Otherwise, click Create New Project.
  • If you already have a Firebase project, click Add App from the project overview page.
  1. Click Add Firebase to your web app.
  1. Note the initialization code snippet, which you will use in a minute.

    authDomain: "notarazicom.firebaseapp.com",
   databaseURL: "https://notarazicom.firebaseio.com",
   storageBucket: "notarazicom.appspot.com",

2) Run a Local Web Server for Development

If you are building a web app, you will find that some parts of the Firebase JavaScript SDK require that your web app be served from a server rather than from the local filesystem. You can use the Firebase CLI to run a local server like this:

$ npm install -g firebase-tools
$ firebase init    # Generate a firebase.json (REQUIRED)
$ firebase serve   # Start development server
firebase login
firebase init
Associate Local Project Directory to Firebase Project
Database Setup
Functions Setup
Hosting Setup
Web Page Setup

firebase serve
CTRL+C to shutdown localhost server
firebase logout
Firebase Command Summary

(go into new local project directory)
firebase login
firebase init
firebase serve
firebase logout
.

Saturday, February 4, 2017

Google Sheet Auto Sort Data

1) Fill in Sheet1 with data

2) Enter Formula in Sheet2 Cell A2 =SORT(Sheet1!A2:C, 2, 1)

3) Google Sheet automatically populate Sheet 2 with sorted data

REFERENCE:
https://vcfvct.wordpress.com/2014/05/27/add-auto-sort-to-google-spreadsheet/

Friday, February 3, 2017

Google Sheet Data CRUD + App Script + jQuery + objDB


Google Sheet Data CRUD + App Script +  jQuery + objDB

Follow the steps at:
.
Learn powerful non-relational database at:
.

Google Sheet Data CRUD + App Script + jQuery



.

Google Sheet Data CRUD + App Script +  jQuery

Follow the steps at:
.

Google Sheet Data Insert with Google Apps Script

.

Google Sheet Data Insert with Google Apps Script

Follow the steps at
http://programming-steps.blogspot.com/2016/10/google-sheet-data-insert-with-google.html
.

National Convention Registration Sample


.
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.