Facebook
From Marcelo, 1 Year ago, written in HTML5.
Embed
Download Paste or View Raw
Hits: 126
  1.  #_form_33_ { font-size:14px; line-height:1.6; font-family:arial, helvetica, sans-serif; margin:0; }
  2.  #_form_33_ * { outline:0; }
  3.  ._form_hide { display:none; visibility:hidden; }
  4.  ._form_show { display:block; visibility:visible; }
  5.  #_form_33_._form-top { top:0; }
  6.  #_form_33_._form-bottom { bottom:0; }
  7.  #_form_33_._form-left { left:0; }
  8.  #_form_33_._form-right { right:0; }
  9.  #_form_33_ input[type="text"],#_form_33_ input[type="tel"],#_form_33_ input[type="date"],#_form_33_ textarea { padding:6px; height:auto; border:#979797 1px solid; border-radius:4px; color:#000 !important; font-size:14px; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; }
  10.  #_form_33_ textarea { resize:none; }
  11.  #_form_33_ ._submit { -webkit-appearance:none; cursor:pointer; font-family:arial, sans-serif; font-size:14px; text-align:center; background:#333 !important; border:0 !important; -moz-border-radius:4px !important; -webkit-border-radius:4px !important; border-radius:4px !important; color:#fff !important; padding:10px !important; }
  12.  #_form_33_ ._close-icon { cursor:pointer; background-image:url('https://d226aj4ao1t61q.cloudfront.net/esfkyjh1u_forms-close-dark.png'); background-repeat:no-repeat; background-size:14.2px 14.2px; position:absolute; display:block; top:11px; right:9px; overflow:hidden; width:16.2px; height:16.2px; }
  13.  #_form_33_ ._close-icon:before { position:relative; }
  14.  #_form_33_ ._form-body { margin-bottom:30px; }
  15.  #_form_33_ ._form-image-left { width:150px; float:left; }
  16.  #_form_33_ ._form-content-right { margin-left:164px; }
  17.  #_form_33_ ._form-branding { color:#fff; font-size:10px; clear:both; text-align:left; margin-top:30px; font-weight:100; }
  18.  #_form_33_ ._form-branding ._logo { display:block; width:130px; height:14px; margin-top:6px; background-image:url('https://d226aj4ao1t61q.cloudfront.net/hh9ujqgv5_aclogo_li.png'); background-size:130px auto; background-repeat:no-repeat; }
  19.  #_form_33_ .form-sr-only { position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0, 0, 0, 0); border:0; }
  20.  #_form_33_ ._form-label,#_form_33_ ._form_element ._form-label { font-weight:bold; margin-bottom:5px; display:block; }
  21.  #_form_33_._dark ._form-branding { color:#333; }
  22.  #_form_33_._dark ._form-branding ._logo { background-image:url('https://d226aj4ao1t61q.cloudfront.net/jftq2c8s_aclogo_dk.png'); }
  23.  #_form_33_ ._form_element { position:relative; margin-bottom:10px; font-size:0; max-width:100%; }
  24.  #_form_33_ ._form_element * { font-size:14px; }
  25.  #_form_33_ ._form_element._clear { clear:both; width:100%; float:none; }
  26.  #_form_33_ ._form_element._clear:after { clear:left; }
  27.  #_form_33_ ._form_element input[type="text"],#_form_33_ ._form_element input[type="date"],#_form_33_ ._form_element select,#_form_33_ ._form_element textarea:not(.g-recaptcha-response) { display:block; width:100%; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; font-family:inherit; }
  28.  #_form_33_ ._field-wrapper { position:relative; }
  29.  #_form_33_ ._inline-style { float:left; }
  30.  #_form_33_ ._inline-style input[type="text"] { width:150px; }
  31.  #_form_33_ ._inline-style:not(._clear) + ._inline-style:not(._clear) { margin-left:20px; }
  32.  #_form_33_ ._form_element img._form-image { max-width:100%; }
  33.  #_form_33_ ._form_element ._form-fieldset { border:0; padding:0.01em 0 0 0; margin:0; min-width:0; }
  34.  #_form_33_ ._clear-element { clear:left; }
  35.  #_form_33_ ._full_width { width:100%; }
  36.  #_form_33_ ._form_full_field { display:block; width:100%; margin-bottom:10px; }
  37.  #_form_33_ input[type="text"]._has_error,#_form_33_ textarea._has_error { border:#f37c7b 1px solid; }
  38.  #_form_33_ input[type="checkbox"]._has_error { outline:#f37c7b 1px solid; }
  39.  #_form_33_ ._error { display:block; position:absolute; font-size:14px; z-index:10000001; }
  40.  #_form_33_ ._error._above { padding-bottom:4px; bottom:39px; right:0; }
  41.  #_form_33_ ._error._below { padding-top:4px; top:100%; right:0; }
  42.  #_form_33_ ._error._above ._error-arrow { bottom:0; right:15px; border-left:5px solid transparent; border-right:5px solid transparent; border-top:5px solid #f37c7b; }
  43.  #_form_33_ ._error._below ._error-arrow { top:0; right:15px; border-left:5px solid transparent; border-right:5px solid transparent; border-bottom:5px solid #f37c7b; }
  44.  #_form_33_ ._error-inner { padding:8px 12px; background-color:#f37c7b; font-size:14px; font-family:arial, sans-serif; color:#fff; text-align:center; text-decoration:none; -webkit-border-radius:4px; -moz-border-radius:4px; border-radius:4px; }
  45.  #_form_33_ ._error-inner._form_error { margin-bottom:5px; text-align:left; }
  46.  #_form_33_ ._button-wrapper ._error-inner._form_error { position:static; }
  47.  #_form_33_ ._error-inner._no_arrow { margin-bottom:10px; }
  48.  #_form_33_ ._error-arrow { position:absolute; width:0; height:0; }
  49.  #_form_33_ ._error-html { margin-bottom:10px; }
  50.  .pika-single { z-index:10000001 !important; }
  51.  #_form_33_ input[type="text"].datetime_date { width:69%; display:inline; }
  52.  #_form_33_ select.datetime_time { width:29%; display:inline; height:32px; }
  53.  #_form_33_ input[type="date"].datetime_date { width:69%; display:inline-flex; }
  54.  #_form_33_ input[type="time"].datetime_time { width:29%; display:inline-flex; }
  55.  @media all and (min-width:320px) and (max-width:667px) { ::-webkit-scrollbar { display:none; }
  56.  #_form_33_ { margin:0; width:100%; min-width:100%; max-width:100%; box-sizing:border-box; }
  57.  #_form_33_ * { -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; font-size:1em; }
  58.  #_form_33_ ._form-content { margin:0; width:100%; }
  59.  #_form_33_ ._form-inner { display:block; min-width:100%; }
  60.  #_form_33_ ._form-title,#_form_33_ ._inline-style { margin-top:0; margin-right:0; margin-left:0; }
  61.  #_form_33_ ._form-title { font-size:1.2em; }
  62.  #_form_33_ ._form_element { margin:0 0 20px; padding:0; width:100%; }
  63.  #_form_33_ ._form-element,#_form_33_ ._inline-style,#_form_33_ input[type="text"],#_form_33_ label,#_form_33_ p,#_form_33_ textarea:not(.g-recaptcha-response) { float:none; display:block; width:100%; }
  64.  #_form_33_ ._row._checkbox-radio label { display:inline; }
  65.  #_form_33_ ._row,#_form_33_ p,#_form_33_ label { margin-bottom:0.7em; width:100%; }
  66.  #_form_33_ ._row input[type="checkbox"],#_form_33_ ._row input[type="radio"] { margin:0 !important; vertical-align:middle !important; }
  67.  #_form_33_ ._row input[type="checkbox"] + span label { display:inline; }
  68.  #_form_33_ ._row span label { margin:0 !important; width:initial !important; vertical-align:middle !important; }
  69.  #_form_33_ ._form-image { max-width:100%; height:auto !important; }
  70.  #_form_33_ input[type="text"] { padding-left:10px; padding-right:10px; font-size:16px; line-height:1.3em; -webkit-appearance:none; }
  71.  #_form_33_ input[type="radio"],#_form_33_ input[type="checkbox"] { display:inline-block; width:1.3em; height:1.3em; font-size:1em; margin:0 0.3em 0 0; vertical-align:baseline; }
  72.  #_form_33_ button[type="submit"] { padding:20px; font-size:1.5em; }
  73.  #_form_33_ ._inline-style { margin:20px 0 0 !important; }
  74.  }
  75.  #_form_33_ { position:relative; text-align:left; margin:25px auto 0; padding:20px; -webkit-box-sizing:border-box; -moz-box-sizing:border-box; box-sizing:border-box; *zoom:1; background:#fff !important; border:0px solid #b0b0b0 !important; max-width:500px; -moz-border-radius:0px !important; -webkit-border-radius:0px !important; border-radius:0px !important; color:#000 !important; }
  76.  #_form_33_._inline-form,#_form_33_._inline-form ._form-content,#_form_33_._inline-form input,#_form_33_._inline-form ._submit { font-family:"IBM Plex Sans", Helvetica, sans-serif; }
  77.  #_form_33_ ._form-title { font-size:22px; line-height:22px; font-weight:600; margin-bottom:0; }
  78.  #_form_33_:before,#_form_33_:after { content:" "; display:table; }
  79.  #_form_33_:after { clear:both; }
  80.  #_form_33_._inline-style { width:auto; display:inline-block; }
  81.  #_form_33_._inline-style input[type="text"],#_form_33_._inline-style input[type="date"] { padding:10px 12px; }
  82.  #_form_33_._inline-style button._inline-style { position:relative; top:27px; }
  83.  #_form_33_._inline-style p { margin:0; }
  84.  #_form_33_._inline-style ._button-wrapper { position:relative; margin:27px 12.5px 0 20px; }
  85.  #_form_33_ ._form-thank-you { position:relative; left:0; right:0; text-align:center; font-size:18px; }
  86.  @media all and (min-width:320px) and (max-width:667px) { #_form_33_._inline-form._inline-style ._inline-style._button-wrapper { margin-top:20px !important; margin-left:0 !important; }
  87.  }
  88.  #_form_33_ .iti.iti--allow-dropdown.iti--separate-dial-code { width:100%; }
  89.  #_form_33_ .iti input { width:100%; height:32px; border:#979797 1px solid; border-radius:4px; }
  90.  #_form_33_ .iti--separate-dial-code .iti__selected-flag { background-color:#fff; border-radius:4px; }
  91.  #_form_33_ .iti--separate-dial-code .iti__selected-flag:hover { background-color:rgba(0, 0, 0, 0.05); }
  92.  #_form_33_ .iti__country-list { border-radius:4px; margin-top:4px; min-width:460px; }
  93.  #_form_33_ .iti__country-list--dropup { margin-bottom:4px; }
  94.  #_form_33_ .phone-error-hidden { display:none; }
  95.  #_form_33_ .phone-error { color:#e40e49; }
  96.  #_form_33_ .phone-input-error { border:1px solid #e40e49 !important; }
  97. <link href="https://fonts.googleapis.com/css2?family=Lato&family=Montserrat&family=Roboto&family=IBM+Plex+Sans:wght@400;600&display=swap" rel="stylesheet">
  98.   <link rel="stylesheet" type="text/css" href="https://unpkg.com/[email protected]/build/css/intlTelInput.min.css"/>
  99.     <form method="POST" action="https://iagorgs92246.activehosted.com/proc.php" id="_form_33_" class="_form _form_33 _inline-form  _dark" novalidate>
  100.       <input type="hidden" name="u" value="33" />
  101.       <input type="hidden" name="f" value="33" />
  102.       <input type="hidden" name="s" />
  103.       <input type="hidden" name="c" value="0" />
  104.       <input type="hidden" name="m" value="0" />
  105.       <input type="hidden" name="act" value="sub" />
  106.       <input type="hidden" name="v" value="2" />
  107.       <input type="hidden" name="or" value="6473121f291b9128f3c0d14dc7311f95" />
  108.       <div class="_form-content">
  109.         <div class="_form_element _x76713865 _full_width " >
  110.           <label for="fullname" class="_form-label">
  111.             Nome*
  112.           </label>
  113.           <div class="_field-wrapper">
  114.             <input type="text" id="fullname" name="fullname" placeholder="Digite seu nome" required/>
  115.           </div>
  116.         </div>
  117.         <div class="_form_element _x99442640 _full_width " >
  118.           <label for="email" class="_form-label">
  119.             E-mail*
  120.           </label>
  121.           <div class="_field-wrapper">
  122.             <input type="text" id="email" name="email" placeholder="Digite seu e-mail" required/>
  123.           </div>
  124.         </div>
  125.         <div class="_form_element _x44189214 _full_width " >
  126.           <input type="hidden" name="field[8]" value="" />
  127.         </div>
  128.         <div class="_form_element _x81823848 _full_width " >
  129.           <input type="hidden" name="field[9]" value="" />
  130.         </div>
  131.         <div class="_form_element _x85070230 _full_width " >
  132.           <input type="hidden" name="field[10]" value="" />
  133.         </div>
  134.         <div class="_form_element _x16019386 _full_width " >
  135.           <input type="hidden" name="field[11]" value="" />
  136.         </div>
  137.         <div class="_button-wrapper _full_width">
  138.           <button id="_form_33_submit" class="_submit" type="submit">
  139.             Enviar
  140.           </button>
  141.         </div>
  142.         <div class="_clear-element">
  143.         </div>
  144.       </div>
  145.       <div class="_form-thank-you" style="display:none;">
  146.       </div>
  147.     </form><script type="text/javascript">
  148. window.cfields = {"8":"utm_source","9":"utm_campaign","10":"utm_medium","11":"utm_content"};
  149. window._show_thank_you = function(id, message, trackcmp_url, email) {
  150.   var form = document.getElementById('_form_' + id + '_'), thank_you = form.querySelector('._form-thank-you');
  151.   form.querySelector('._form-content').style.display = 'none';
  152.   thank_you.innerHTML = message;
  153.   thank_you.style.display = 'block';
  154.   const vgoAlias = typeof visitorGlobalObjectAlias === 'undefined' ? 'vgo' : visitorGlobalObjectAlias;
  155.   var visitorObject = window[vgoAlias];
  156.   if (email && typeof visitorObject !== 'undefined') {
  157.    visitorObject('setEmail', email);
  158.     visitorObject('update');
  159.   } else if (typeof(trackcmp_url) != 'undefined' && trackcmp_url) {
  160.    // Site tracking URL to use after inline form submission.
  161.    _load_script(trackcmp_url);
  162.   }
  163.   if (typeof window._form_callback !== 'undefined') window._form_callback(id);
  164. };
  165. window._show_error = function(id, message, html) {
  166.   var form = document.getElementById('_form_' + id + '_'), err = document.createElement('div'), button = form.querySelector('button'), old_error = form.querySelector('._form_error');
  167.   if (old_error) old_error.parentNode.removeChild(old_error);
  168.   err.innerHTML = message;
  169.   err.className = '_error-inner _form_error _no_arrow';
  170.   var wrapper = document.createElement('div');
  171.   wrapper.className = '_form-inner';
  172.   wrapper.appendChild(err);
  173.   button.parentNode.insertBefore(wrapper, button);
  174.   document.querySelector('[id^="_form"][id$="_submit"]').disabled = false;
  175.   if (html) {
  176.     var div = document.createElement('div');
  177.     div.className = '_error-html';
  178.     div.innerHTML = html;
  179.     err.appendChild(div);
  180.   }
  181. };
  182. window._load_script = function(url, callback) {
  183.   var head = document.querySelector('head'), script = document.createElement('script'), r = false;
  184.   script.type = 'text/javascript';
  185.   script.charset = 'utf-8';
  186.   script.src = url;
  187.   if (callback) {
  188.     script.onload = script.onreadystatechange = function() {
  189.       if (!r && (!this.readyState || this.readyState == 'complete')) {
  190.        r = true;
  191.         callback();
  192.       }
  193.     };
  194.   }
  195.   head.appendChild(script);
  196. };
  197. (function() {
  198.   if (window.location.search.search("excludeform") !== -1) return false;
  199.   var getCookie = function(name) {
  200.     var match = document.cookie.match(new RegExp('(^|; )' + name + '=([^;]+)'));
  201.     return match ? match[2] : null;
  202.   }
  203.   var setCookie = function(name, value) {
  204.     var now = new Date();
  205.     var time = now.getTime();
  206.     var expireTime = time + 1000 * 60 * 60 * 24 * 365;
  207.     now.setTime(expireTime);
  208.     document.cookie = name + '=' + value + '; expires=' + now + ';path=/; Secure; SameSite=Lax;';// cannot be HttpOnly
  209.   }
  210.       var addEvent = function(element, event, func) {
  211.     if (element.addEventListener) {
  212.       element.addEventListener(event, func);
  213.     } else {
  214.       var oldFunc = element['on' + event];
  215.       element['on' + event] = function() {
  216.         oldFunc.apply(this, arguments);
  217.         func.apply(this, arguments);
  218.       };
  219.     }
  220.   }
  221.   var _removed = false;
  222.   var form_to_submit = document.getElementById('_form_33_');
  223.   var allInputs = form_to_submit.querySelectorAll('input, select, textarea'), tooltips = [], submitted = false;
  224.  
  225.   var getUrlParam = function(name) {
  226.     var params = new URLSearchParams(window.location.search);
  227.     return params.get(name) || false;
  228.   };
  229.  
  230.   for (var i = 0; i < allInputs.length; i++) {
  231.    var regexStr = "field\\[(\\d+)\\]";
  232.    var results = new RegExp(regexStr).exec(allInputs[i].name);
  233.    if (results != undefined) {
  234.      allInputs[i].dataset.name = window.cfields[results[1]];
  235.    } else {
  236.      allInputs[i].dataset.name = allInputs[i].name;
  237.    }
  238.    var fieldVal = getUrlParam(allInputs[i].dataset.name);
  239.  
  240.    if (fieldVal) {
  241.      if (allInputs[i].dataset.autofill === "false") {
  242.        continue;
  243.      }
  244.      if (allInputs[i].type == "radio" || allInputs[i].type == "checkbox") {
  245.        if (allInputs[i].value == fieldVal) {
  246.          allInputs[i].checked = true;
  247.        }
  248.      } else {
  249.        allInputs[i].value = fieldVal;
  250.      }
  251.    }
  252.  }
  253.  
  254.  var remove_tooltips = function() {
  255.    for (var i = 0; i < tooltips.length; i++) {
  256.      tooltips[i].tip.parentNode.removeChild(tooltips[i].tip);
  257.    }
  258.    tooltips = [];
  259.  };
  260.  var remove_tooltip = function(elem) {
  261.    for (var i = 0; i < tooltips.length; i++) {
  262.      if (tooltips[i].elem === elem) {
  263.        tooltips[i].tip.parentNode.removeChild(tooltips[i].tip);
  264.        tooltips.splice(i, 1);
  265.        return;
  266.      }
  267.    }
  268.  };
  269.  var create_tooltip = function(elem, text) {
  270.    var tooltip = document.createElement('div'), arrow = document.createElement('div'), inner = document.createElement('div'), new_tooltip = {};
  271.    if (elem.type != 'radio' && elem.type != 'checkbox') {
  272.      tooltip.className = '_error';
  273.      arrow.className = '_error-arrow';
  274.      inner.className = '_error-inner';
  275.      inner.innerHTML = text;
  276.      tooltip.appendChild(arrow);
  277.      tooltip.appendChild(inner);
  278.      elem.parentNode.appendChild(tooltip);
  279.    } else {
  280.      tooltip.className = '_error-inner _no_arrow';
  281.      tooltip.innerHTML = text;
  282.      elem.parentNode.insertBefore(tooltip, elem);
  283.      new_tooltip.no_arrow = true;
  284.    }
  285.    new_tooltip.tip = tooltip;
  286.    new_tooltip.elem = elem;
  287.    tooltips.push(new_tooltip);
  288.    return new_tooltip;
  289.  };
  290.  var resize_tooltip = function(tooltip) {
  291.    var rect = tooltip.elem.getBoundingClientRect();
  292.    var doc = document.documentElement, scrollPosition = rect.top - ((window.pageYOffset || doc.scrollTop)  - (doc.clientTop || 0));
  293.    if (scrollPosition < 40) {
  294.      tooltip.tip.className = tooltip.tip.className.replace(/ ?(_above|_below) ?/g, '') + ' _below';
  295.    } else {
  296.      tooltip.tip.className = tooltip.tip.className.replace(/ ?(_above|_below) ?/g, '') + ' _above';
  297.    }
  298.  };
  299.  var resize_tooltips = function() {
  300.    if (_removed) return;
  301.    for (var i = 0; i < tooltips.length; i++) {
  302.      if (!tooltips[i].no_arrow) resize_tooltip(tooltips[i]);
  303.    }
  304.  };
  305.  var validate_field = function(elem, remove) {
  306.    var tooltip = null, value = elem.value, no_error = true;
  307.    remove ? remove_tooltip(elem) : false;
  308.    if (elem.type != 'checkbox') elem.className = elem.className.replace(/ ?_has_error ?/g, '');
  309.    if (elem.getAttribute('required') !== null) {
  310.      if (elem.type == 'radio' || (elem.type == 'checkbox' && /any/.test(elem.className))) {
  311.        var elems = form_to_submit.elements[elem.name];
  312.        if (!(elems instanceof NodeList || elems instanceof HTMLCollection) || elems.length <= 1) {
  313.          no_error = elem.checked;
  314.        }
  315.        else {
  316.          no_error = false;
  317.          for (var i = 0; i < elems.length; i++) {
  318.            if (elems[i].checked) no_error = true;
  319.          }
  320.        }
  321.        if (!no_error) {
  322.          tooltip = create_tooltip(elem, "Por favor, selecione uma opção.");
  323.        }
  324.      } else if (elem.type =='checkbox') {
  325.        var elems = form_to_submit.elements[elem.name], found = false, err = [];
  326.        no_error = true;
  327.        for (var i = 0; i < elems.length; i++) {
  328.          if (elems[i].getAttribute('required') === null) continue;
  329.          if (!found && elems[i] !== elem) return true;
  330.          found = true;
  331.          elems[i].className = elems[i].className.replace(/ ?_has_error ?/g, '');
  332.          if (!elems[i].checked) {
  333.            no_error = false;
  334.            elems[i].className = elems[i].className + ' _has_error';
  335.            err.push("Marcar %s é necessário".replace("%s", elems[i].value));
  336.          }
  337.        }
  338.        if (!no_error) {
  339.          tooltip = create_tooltip(elem, err.join('<br/>'));
  340.         }
  341.       } else if (elem.tagName == 'SELECT') {
  342.         var selected = true;
  343.         if (elem.multiple) {
  344.           selected = false;
  345.           for (var i = 0; i < elem.options.length; i++) {
  346.            if (elem.options[i].selected) {
  347.              selected = true;
  348.              break;
  349.            }
  350.          }
  351.        } else {
  352.          for (var i = 0; i < elem.options.length; i++) {
  353.            if (elem.options[i].selected && (!elem.options[i].value || (elem.options[i].value.match(/\n/g)))) {
  354.              selected = false;
  355.            }
  356.          }
  357.        }
  358.        if (!selected) {
  359.          elem.className = elem.className + ' _has_error';
  360.          no_error = false;
  361.          tooltip = create_tooltip(elem, "Por favor, selecione uma opção.");
  362.        }
  363.      } else if (value === undefined || value === null || value === '') {
  364.        elem.className = elem.className + ' _has_error';
  365.        no_error = false;
  366.        tooltip = create_tooltip(elem, "Este campo é necessário.");
  367.      }
  368.    }
  369.    if (no_error && (elem.id == 'field[]' || elem.id == 'ca[11][v]')) {
  370.      if (elem.className.includes('phone-input-error')) {
  371.        elem.className = elem.className + ' _has_error';
  372.        no_error = false;
  373.      }
  374.    }
  375.    if (no_error && elem.name == 'email') {
  376.      if (!value.match(/^[\+_a-z0-9-'&=]+(\.[\+_a-z0-9-']+)*@[a-z0-9-]+(\.[a-z0-9-]+)*(\.[a-z]{2,})$/i)) {
  377.        elem.className = elem.className + ' _has_error';
  378.        no_error = false;
  379.        tooltip = create_tooltip(elem, "Digite um e-mail válido");
  380.      }
  381.    }
  382.    if (no_error && /date_field/.test(elem.className)) {
  383.      if (!value.match(/^\d\d\d\d-\d\d-\d\d$/)) {
  384.        elem.className = elem.className + ' _has_error';
  385.        no_error = false;
  386.        tooltip = create_tooltip(elem, "Digite uma data válida.");
  387.      }
  388.    }
  389.    tooltip ? resize_tooltip(tooltip) : false;
  390.    return no_error;
  391.  };
  392.  var needs_validate = function(el) {
  393.        if(el.getAttribute('required') !== null){
  394.            return true
  395.        }
  396.        if(el.name === 'email' && el.value !== ""){
  397.            return true
  398.        }
  399.  
  400.    if((el.id == 'field[]' || el.id == 'ca[11][v]') && el.className.includes('phone-input-error')){
  401.            return true
  402.        }
  403.  
  404.        return false
  405.  };
  406.  var validate_form = function(e) {
  407.    var err = form_to_submit.querySelector('._form_error'), no_error = true;
  408.    if (!submitted) {
  409.      submitted = true;
  410.      for (var i = 0, len = allInputs.length; i < len; i++) {
  411.        var input = allInputs[i];
  412.        if (needs_validate(input)) {
  413.          if (input.type == 'tel') {
  414.            addEvent(input, 'blur', function() {
  415.              this.value = this.value.trim();
  416.              validate_field(this, true);
  417.            });
  418.          }
  419.          if (input.type == 'text' || input.type == 'number' || input.type == 'time') {
  420.            addEvent(input, 'blur', function() {
  421.              this.value = this.value.trim();
  422.              validate_field(this, true);
  423.            });
  424.            addEvent(input, 'input', function() {
  425.              validate_field(this, true);
  426.            });
  427.          } else if (input.type == 'radio' || input.type == 'checkbox') {
  428.            (function(el) {
  429.              var radios = form_to_submit.elements[el.name];
  430.              for (var i = 0; i < radios.length; i++) {
  431.                addEvent(radios[i], 'click', function() {
  432.                  validate_field(el, true);
  433.                });
  434.              }
  435.            })(input);
  436.          } else if (input.tagName == 'SELECT') {
  437.            addEvent(input, 'change', function() {
  438.              validate_field(this, true);
  439.            });
  440.          } else if (input.type == 'textarea'){
  441.            addEvent(input, 'input', function() {
  442.              validate_field(this, true);
  443.            });
  444.          }
  445.        }
  446.      }
  447.    }
  448.    remove_tooltips();
  449.    for (var i = 0, len = allInputs.length; i < len; i++) {
  450.      var elem = allInputs[i];
  451.      if (needs_validate(elem)) {
  452.        if (elem.tagName.toLowerCase() !== "select") {
  453.          elem.value = elem.value.trim();
  454.        }
  455.        validate_field(elem) ? true : no_error = false;
  456.      }
  457.    }
  458.    if (!no_error && e) {
  459.      e.preventDefault();
  460.    }
  461.    resize_tooltips();
  462.    return no_error;
  463.  };
  464.  addEvent(window, 'resize', resize_tooltips);
  465.  addEvent(window, 'scroll', resize_tooltips);
  466.  
  467.  var hidePhoneInputError = function(inputId) {
  468.    var errorMessage =  document.getElementById("error-msg-" + inputId);
  469.    var input = document.getElementById(inputId);
  470.    errorMessage.classList.remove("phone-error");
  471.    errorMessage.classList.add("phone-error-hidden");
  472.    input.classList.remove("phone-input-error");
  473.  };
  474.  
  475.  var initializePhoneInput = function(input, defaultCountry) {
  476.    return window.intlTelInput(input, {
  477.      utilsScript: "https://unpkg.com/[email protected]/build/js/utils.js",
  478.      autoHideDialCode: false,
  479.      separateDialCode: true,
  480.      initialCountry: defaultCountry,
  481.      preferredCountries: []
  482.    });
  483.  }
  484.  
  485.  var setPhoneInputEventListeners = function(inputId, input, iti) {
  486.    input.addEventListener('blur', function() {
  487.      var errorMessage = document.getElementById("error-msg-" + inputId);
  488.      if (input.value.trim()) {
  489.        if (iti.isValidNumber()) {
  490.          iti.setNumber(iti.getNumber());
  491.          if (errorMessage.classList.contains("phone-error")){
  492.            hidePhoneInputError(inputId);
  493.          }
  494.        } else {
  495.          showPhoneInputError(inputId)
  496.        }
  497.      } else {
  498.        if (errorMessage.classList.contains("phone-error")){
  499.          hidePhoneInputError(inputId);
  500.        }
  501.      }
  502.    });
  503.  
  504.    input.addEventListener("countrychange", function() {
  505.      iti.setNumber('');
  506.    });
  507.  
  508.    input.addEventListener("keydown", function(e) {
  509.        var charCode = (e.which) ? e.which : e.keyCode;
  510.        if (charCode > 31 && (charCode < 48 || charCode > 57) && charCode !== 8) {
  511.               e.preventDefault();
  512.       }
  513.      });
  514.   };
  515.  
  516.   var showPhoneInputError = function(inputId) {
  517.     var errorMessage =  document.getElementById("error-msg-" + inputId);
  518.     var input = document.getElementById(inputId);
  519.     errorMessage.classList.add("phone-error");
  520.     errorMessage.classList.remove("phone-error-hidden");
  521.     input.classList.add("phone-input-error");
  522.   };
  523.  
  524.  
  525.     var _form_serialize = function(form){if(!form||form.nodeName!=="FORM"){return }var i,j,q=[];for(i=0;i<form.elements.length;i++){if(form.elements[i].name===""){continue}switch(form.elements[i].nodeName){case"INPUT":switch(form.elements[i].type){case"tel":q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].previousSibling.querySelector('div.iti__selected-dial-code').innerText)+encodeURIComponent(" ")+encodeURIComponent(form.elements[i].value));break;case"text":case"number":case"date":case"time":case"hidden":case"password":case"button":case"reset":case"submit":q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].value));break;case"checkbox":case"radio":if(form.elements[i].checked){q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].value))}break;case"file":break}break;case"TEXTAREA":q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].value));break;case"SELECT":switch(form.elements[i].type){case"select-one":q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].value));break;case"select-multiple":for(j=0;j<form.elements[i].options.length;j++){if(form.elements[i].options[j].selected){q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].options[j].value))}}break}break;case"BUTTON":switch(form.elements[i].type){case"reset":case"submit":case"button":q.push(form.elements[i].name+"="+encodeURIComponent(form.elements[i].value));break}break}}return q.join("&")};
  526.  var form_submit = function(e) {
  527.    e.preventDefault();
  528.    if (validate_form()) {
  529.      // use this trick to get the submit button & disable it using plain javascript
  530.      document.querySelector('#_form_33_submit').disabled = true;
  531.            var serialized = _form_serialize(document.getElementById('_form_33_')).replace(/%0A/g, '\\n');
  532.      var err = form_to_submit.querySelector('._form_error');
  533.      err ? err.parentNode.removeChild(err) : false;
  534.      _load_script('https://iagorgs92246.activehosted.com/proc.php?' + serialized + '&jsonp=true');
  535.    }
  536.    return false;
  537.  };
  538.  addEvent(form_to_submit, 'submit', form_submit);
  539. })();
  540.