script.js 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148
  1. 'use strict';
  2. window.onload = () => {
  3. if ('serviceWorker' in navigator) {
  4. navigator.serviceWorker.register('./sw.js');
  5. console.info('serviceWorker loaded!');
  6. }
  7. }
  8. var formulario = {};
  9. (function(formulario){
  10. formulario.cpf = document.getElementById('cpf');
  11. formulario.bairro = document.getElementById('bairro');
  12. formulario.endereco = document.getElementById('endereco')
  13. formulario.cidade = document.getElementById('cidade');
  14. formulario.estado = document.getElementById('estado');
  15. formulario.celular = document.getElementById('celular');
  16. formulario.required = document.querySelectorAll(".required");
  17. formulario.invalidElement = document.querySelector("span");
  18. })(formulario);
  19. function validatecpf(cpf) {
  20. if (cpf.length != 11) return false;
  21. let numbers = cpf.substring(0, 9)
  22. let entry = cpf.substring(9)
  23. let sum = 0;
  24. for (let i = 10; i > 1; i--) {
  25. sum += numbers.charAt(10 - i) * i;
  26. }
  27. var result = (sum % 11) < 2 ? 0 : 11 - (sum % 11);
  28. if (result != entry.charAt(0)) {
  29. return false;
  30. }
  31. sum = 0;
  32. numbers = cpf.substring(0, 10);
  33. for (let k = 11; k > 1; k--) {
  34. sum += numbers.charAt(11 - k) * k;
  35. }
  36. result = sum % 11 < 2 ? 0 : 11 - (sum % 11);
  37. return result != entry.charAt(1) ? false : true
  38. }
  39. function validate() {
  40. const cpf = formulario.cpf.value.replace(/[^a-z0-9 ]/g, "")
  41. const requiredInputs = formulario.required;
  42. let inputIsValid = false;
  43. const cpfIsValid = validatecpf(cpf);
  44. for (let i = 0; i < requiredInputs.length; i++) {
  45. if (requiredInputs[i].value === "") {
  46. requiredInputs[i].style["border"] = "1px solid red"
  47. inputIsValid = false;
  48. } else {
  49. inputIsValid = true
  50. requiredInputs[1].style["border"] = "none"
  51. formulario.invalidElement.style["display"] = "none"
  52. requiredInputs[i].style["border"] = "none"
  53. }
  54. }
  55. if (!inputIsValid || !cpfIsValid) {
  56. window.alert("Opss! Aconteceu um erro no seu cadastro, verifique se você preencheu todos espaços necessários")
  57. cpfIsValid ? (
  58. requiredInputs[1].style["border"] = "none",
  59. formulario.invalidElement.style["display"] = "none"
  60. ) : (
  61. requiredInputs[1].style["border"] = "1px solid red",
  62. formulario.invalidElement.style["display"] = "inline"
  63. );
  64. return false
  65. }
  66. else if (cpfIsValid && inputIsValid) window.alert("Parabéns!! você foi cadastrado com sucesso")
  67. return true
  68. }
  69. function clearCepInputs() {
  70. formulario.endereco.value = ("");
  71. formulario.bairro.value = ("");
  72. formulario.cidade.value = ("");
  73. dformulario.estado.value = ("");
  74. }
  75. function retrievingCepInputs(cepInputs) {
  76. if ('erro' in cepInputs) {
  77. clearCepInputs();
  78. alert("CEP não encontrado.");
  79. return;
  80. }
  81. formulario.endereco.value = (cepInputs.logradouro);
  82. formulario.bairro.value = (cepInputs.bairro);
  83. formulario.cidade.value = (cepInputs.localidade);
  84. formulario.estado.value = (cepInputs.uf);
  85. }
  86. function searchCep(valor) {
  87. const cep = valor.replace(/\D/g, '');
  88. if (cep === "") {
  89. clearCepInputs();
  90. return;
  91. }
  92. const validateCep = /^[0-9]{8}$/;
  93. if (! validateCep.test(cep)) {
  94. clearCepInputs();
  95. alert("Formato de CEP inválido.");
  96. return;
  97. }
  98. const script = document.createElement('script');
  99. script.src = 'https://viacep.com.br/ws/' + cep + '/json/?callback=retrievingCepInputs';
  100. document.body.appendChild(script);
  101. };
  102. function cpfMask() {
  103. const length = formulario.cpf.value.length;
  104. if (length === 3 || length === 7)
  105. formulario.cpf.value = formulario.cpf.value + ".";
  106. else if (length === 11)
  107. formulario.cpf.value = formulario.cpf.value + "-";
  108. else if (length===14) length = 0
  109. }
  110. function phoneMask() {
  111. const length = formulario.celular.value.length;
  112. switch (length) {
  113. case 0:
  114. formulario.celular.value = '('
  115. break
  116. case 3:
  117. formulario.celular.value += ')'
  118. break
  119. case 5:
  120. formulario.celular.value += ' ';
  121. break
  122. case 10:
  123. formulario.celular.value += '-'
  124. break
  125. case 15:
  126. i = 0
  127. }
  128. }