mapa-library-ui 0.25.3 → 0.26.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (54) hide show
  1. package/esm2020/lib/core/js-brasil/index.mjs +16 -0
  2. package/esm2020/lib/core/js-brasil/src/create.mjs +455 -0
  3. package/esm2020/lib/core/js-brasil/src/createNumberMask.mjs +115 -0
  4. package/esm2020/lib/core/js-brasil/src/estados.mjs +34 -0
  5. package/esm2020/lib/core/js-brasil/src/index.mjs +34 -0
  6. package/esm2020/lib/core/js-brasil/src/inscricaoestadual.mjs +702 -0
  7. package/esm2020/lib/core/js-brasil/src/interfaces.mjs +2 -0
  8. package/esm2020/lib/core/js-brasil/src/iptu.mjs +25 -0
  9. package/esm2020/lib/core/js-brasil/src/iptu_create.mjs +60 -0
  10. package/esm2020/lib/core/js-brasil/src/iptu_mask.mjs +38 -0
  11. package/esm2020/lib/core/js-brasil/src/iptu_validate.mjs +67 -0
  12. package/esm2020/lib/core/js-brasil/src/mask.mjs +579 -0
  13. package/esm2020/lib/core/js-brasil/src/name.mjs +371 -0
  14. package/esm2020/lib/core/js-brasil/src/placa.mjs +162 -0
  15. package/esm2020/lib/core/js-brasil/src/rg.mjs +63 -0
  16. package/esm2020/lib/core/js-brasil/src/saude.mjs +62 -0
  17. package/esm2020/lib/core/js-brasil/src/utils.mjs +304 -0
  18. package/esm2020/lib/core/js-brasil/src/validate.mjs +627 -0
  19. package/esm2020/lib/core/pipes/cpf.mjs +17 -0
  20. package/esm2020/public-api.mjs +3 -1
  21. package/esm2020/src/lib/components/table/lib/components/table/public-api.mjs +2 -1
  22. package/esm2020/src/lib/components/table/lib/components/table/src/table.module.mjs +10 -3
  23. package/fesm2015/mapa-library-ui-src-lib-components-table.mjs +31 -24
  24. package/fesm2015/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
  25. package/fesm2015/mapa-library-ui.mjs +3675 -2
  26. package/fesm2015/mapa-library-ui.mjs.map +1 -1
  27. package/fesm2020/mapa-library-ui-src-lib-components-table.mjs +31 -24
  28. package/fesm2020/mapa-library-ui-src-lib-components-table.mjs.map +1 -1
  29. package/fesm2020/mapa-library-ui.mjs +3682 -2
  30. package/fesm2020/mapa-library-ui.mjs.map +1 -1
  31. package/lib/core/js-brasil/index.d.ts +15 -0
  32. package/lib/core/js-brasil/src/create.d.ts +37 -0
  33. package/lib/core/js-brasil/src/createNumberMask.d.ts +13 -0
  34. package/lib/core/js-brasil/src/estados.d.ts +7 -0
  35. package/lib/core/js-brasil/src/index.d.ts +34 -0
  36. package/lib/core/js-brasil/src/inscricaoestadual.d.ts +7 -0
  37. package/lib/core/js-brasil/src/interfaces.d.ts +51 -0
  38. package/lib/core/js-brasil/src/iptu.d.ts +3 -0
  39. package/lib/core/js-brasil/src/iptu_create.d.ts +5 -0
  40. package/lib/core/js-brasil/src/iptu_mask.d.ts +2 -0
  41. package/lib/core/js-brasil/src/iptu_validate.d.ts +10 -0
  42. package/lib/core/js-brasil/src/mask.d.ts +53 -0
  43. package/lib/core/js-brasil/src/name.d.ts +9 -0
  44. package/lib/core/js-brasil/src/placa.d.ts +6 -0
  45. package/lib/core/js-brasil/src/rg.d.ts +5 -0
  46. package/lib/core/js-brasil/src/saude.d.ts +84 -0
  47. package/lib/core/js-brasil/src/utils.d.ts +71 -0
  48. package/lib/core/js-brasil/src/validate.d.ts +90 -0
  49. package/lib/core/pipes/cpf.d.ts +7 -0
  50. package/mapa-library-ui-0.26.0.tgz +0 -0
  51. package/package.json +1 -1
  52. package/public-api.d.ts +2 -0
  53. package/src/lib/components/table/lib/components/table/public-api.d.ts +1 -0
  54. package/mapa-library-ui-0.25.3.tgz +0 -0
@@ -0,0 +1,16 @@
1
+ export * from './src';
2
+ export * from './src/create';
3
+ export * from './src/estados';
4
+ export * from './src/inscricaoestadual';
5
+ export * from './src/interfaces';
6
+ export * from './src/iptu_create';
7
+ export * from './src/iptu_mask';
8
+ export * from './src/iptu_validate';
9
+ export * from './src/iptu';
10
+ export * from './src/name';
11
+ export * from './src/placa';
12
+ export * from './src/rg';
13
+ export * from './src/saude';
14
+ export * from './src/utils';
15
+ export * from './src/validate';
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tYXBhLWxpYnJhcnktdWkvc3JjL2xpYi9jb3JlL2pzLWJyYXNpbC9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLE9BQU8sQ0FBQztBQUN0QixjQUFjLGNBQWMsQ0FBQztBQUM3QixjQUFjLGVBQWUsQ0FBQztBQUM5QixjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxtQkFBbUIsQ0FBQztBQUNsQyxjQUFjLGlCQUFpQixDQUFDO0FBQ2hDLGNBQWMscUJBQXFCLENBQUM7QUFDcEMsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxZQUFZLENBQUM7QUFDM0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxVQUFVLENBQUM7QUFDekIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vc3JjJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2NyZWF0ZSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9lc3RhZG9zJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2luc2NyaWNhb2VzdGFkdWFsJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvaXB0dV9jcmVhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvaXB0dV9tYXNrJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL2lwdHVfdmFsaWRhdGUnO1xuZXhwb3J0ICogZnJvbSAnLi9zcmMvaXB0dSc7XG5leHBvcnQgKiBmcm9tICcuL3NyYy9uYW1lJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3BsYWNhJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3JnJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3NhdWRlJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3V0aWxzJztcbmV4cG9ydCAqIGZyb20gJy4vc3JjL3ZhbGlkYXRlJzsiXX0=
@@ -0,0 +1,455 @@
1
+ import { ESTADOS_SIGLA } from './estados';
2
+ import { getAllDigits, fillString, modulo11Custom } from './utils';
3
+ /**
4
+ *
5
+ * @param uf - UF do número da guia. Ex: 35(SP), 81(PE)
6
+ * @param ano - ANO do número da guia. Ex: 2018, 2019
7
+ * @param tipo - TIPO da guia. Aih = 1, APAC = 2
8
+ */
9
+ export function create_aih(value) {
10
+ value = getAllDigits(value.toString());
11
+ if (value.length > 12) {
12
+ value = value.toString().substr(0, value.length - 1);
13
+ }
14
+ const cod = parseInt(value);
15
+ const calc = Math.ceil(cod - (cod / 11));
16
+ const digito = calc.toString().substr(-1);
17
+ return digito;
18
+ }
19
+ export function create_certidao(value) {
20
+ if (value.length > 30) {
21
+ value = value.substring(0, value.length - 2);
22
+ }
23
+ let b1 = parseInt(value.slice(29));
24
+ let b2 = parseInt(value.slice(28, 29));
25
+ let b3 = parseInt(value.slice(27, 28));
26
+ let b4 = parseInt(value.slice(26, 27));
27
+ let b5 = parseInt(value.slice(25, 26));
28
+ let b6 = parseInt(value.slice(24, 25));
29
+ let b7 = parseInt(value.slice(23, 24));
30
+ let b8 = parseInt(value.slice(22, 23));
31
+ let b9 = parseInt(value.slice(21, 22));
32
+ let b10 = parseInt(value.slice(20, 21));
33
+ let b11 = parseInt(value.slice(19, 20));
34
+ let b12 = parseInt(value.slice(18, 19));
35
+ let b13 = parseInt(value.slice(17, 18));
36
+ let b14 = parseInt(value.slice(16, 17));
37
+ let b15 = parseInt(value.slice(15, 16));
38
+ let b16 = parseInt(value.slice(14, 15));
39
+ let b17 = parseInt(value.slice(13, 14));
40
+ let b18 = parseInt(value.slice(12, 13));
41
+ let b19 = parseInt(value.slice(11, 12));
42
+ let b20 = parseInt(value.slice(10, 11));
43
+ let b21 = parseInt(value.slice(9, 10));
44
+ let b22 = parseInt(value.slice(8, 9));
45
+ let b23 = parseInt(value.slice(7, 8));
46
+ let b24 = parseInt(value.slice(6, 7));
47
+ let b25 = parseInt(value.slice(5, 6));
48
+ let b26 = parseInt(value.slice(4, 5));
49
+ let b27 = parseInt(value.slice(3, 4));
50
+ let b28 = parseInt(value.slice(2, 3));
51
+ let b29 = parseInt(value.slice(1, 2));
52
+ let b30 = parseInt(value.slice(0, 1));
53
+ let certPriDig = (b1 * 9 + b2 * 8 + b3 * 7 + b4 * 6 + b5 * 5 + b6 * 4 + b7 * 3 + b8 * 2 + b9 * 1 + b10 * 0 + b11 * 10 + b12 * 9 + b13 * 8 + b14 * 7 + b15 * 6 + b16 * 5 + b17 * 4 + b18 * 3 + b19 * 2 + b20 * 1 + b21 * 0 + b22 * 10 + b23 * 9 + b24 * 8 + b25 * 7 + b26 * 6 + b27 * 5 + b28 * 4 + b29 * 3 + b30 * 2) % 11;
54
+ if (certPriDig == 10) {
55
+ certPriDig = 1;
56
+ }
57
+ let certSegDig = (certPriDig * 9 + b1 * 8 + b2 * 7 + b3 * 6 + b4 * 5 + b5 * 4 + b6 * 3 + b7 * 2 + b8 * 1 + b9 * 0 + b10 * 10 + b11 * 9 + b12 * 8 + b13 * 7 + b14 * 6 + b15 * 5 + b16 * 4 + b17 * 3 + b18 * 2 + b19 * 1 + b20 * 0 + b21 * 10 + b22 * 9 + b23 * 8 + b24 * 7 + b25 * 6 + b26 * 5 + b27 * 4 + b28 * 3 + b29 * 2 + b30 * 1) % 11;
58
+ if (certSegDig == 10) {
59
+ certSegDig = 1;
60
+ }
61
+ let certDV = certPriDig * 10 + certSegDig;
62
+ if (certDV == 0) {
63
+ certDV = "00";
64
+ }
65
+ if (certDV > 0 && certDV < 10) {
66
+ certDV = "0" + certDV;
67
+ }
68
+ return certDV.toString();
69
+ }
70
+ export function create_cnhespelho(value) {
71
+ let v1 = modulo11Custom(value.substr(0, value.length - 1), 1, 8, false);
72
+ return v1;
73
+ }
74
+ export function create_renachestadual(value) {
75
+ const state = value.substr(0, 2).toLowerCase();
76
+ if (!ESTADOS_SIGLA.includes(state)) {
77
+ return false;
78
+ }
79
+ let digits = value.substr(2);
80
+ digits = digits.replace(/[^\d]/g, '');
81
+ if (digits.length !== 9) {
82
+ return false;
83
+ }
84
+ let v1 = modulo11Custom(digits.substr(0, digits.length - 1), 1, 11);
85
+ return '' + v1;
86
+ }
87
+ /**
88
+ *
89
+ * @param value
90
+ * @returns
91
+ */
92
+ export function create_renachseguranca(value) {
93
+ value = value.replace(/[^\d]+/g, '');
94
+ if (value.length !== 11) {
95
+ return false;
96
+ }
97
+ let v1 = modulo11Custom(value.substr(0, value.length - 1), 1, 11);
98
+ return "" + v1;
99
+ }
100
+ /**
101
+ * Dígito verificador da CNH não é mais o módulo 11 conforme últimas resoluções
102
+ * @param value
103
+ * @returns
104
+ */
105
+ export function create_cnh(value) {
106
+ value = value.replace(/[^\d]+/g, '');
107
+ if (value.length != 11 || value === '0') {
108
+ return false;
109
+ }
110
+ // let v1 = modulo11Custom(value.substr(0, value.length - 2), 2);
111
+ // if (v1 === '10') v1 = '00'
112
+ let v1 = value.substr(-2);
113
+ return v1;
114
+ }
115
+ export function create_cnpj(cnpj) {
116
+ cnpj = cnpj.replace(/[^\d]+/g, '');
117
+ if (cnpj === '') {
118
+ return false;
119
+ }
120
+ if (cnpj.length !== 14) {
121
+ return false;
122
+ }
123
+ // Elimina CNPJs invalidos conhecidos
124
+ if (cnpj === '00000000000000' ||
125
+ cnpj === '11111111111111' ||
126
+ cnpj === '22222222222222' ||
127
+ cnpj === '33333333333333' ||
128
+ cnpj === '44444444444444' ||
129
+ cnpj === '55555555555555' ||
130
+ cnpj === '66666666666666' ||
131
+ cnpj === '77777777777777' ||
132
+ cnpj === '88888888888888' ||
133
+ cnpj === '99999999999999') {
134
+ return false;
135
+ }
136
+ // Valida DVs
137
+ let tamanho = cnpj.length - 2;
138
+ let numeros = cnpj.substring(0, tamanho);
139
+ let soma = 0;
140
+ let pos = tamanho - 7;
141
+ for (let i = tamanho; i >= 1; i--) {
142
+ soma += numeros.charAt(tamanho - i) * pos--;
143
+ if (pos < 2) {
144
+ pos = 9;
145
+ }
146
+ }
147
+ const resultados = [0, 0];
148
+ resultados[0] = soma % 11 < 2 ? 0 : 11 - soma % 11;
149
+ tamanho = tamanho + 1;
150
+ numeros = cnpj.substring(0, tamanho);
151
+ soma = 0;
152
+ pos = tamanho - 7;
153
+ for (let i = tamanho; i >= 1; i--) {
154
+ soma += numeros.charAt(tamanho - i) * pos--;
155
+ if (pos < 2) {
156
+ pos = 9;
157
+ }
158
+ }
159
+ resultados[1] = soma % 11 < 2 ? 0 : 11 - soma % 11;
160
+ return resultados;
161
+ }
162
+ export function create_cns(number) {
163
+ number = getAllDigits(number);
164
+ let somaInicial = 0;
165
+ for (let i = 0; i < number.length - 1; i++) {
166
+ somaInicial += parseInt(number[i]) * (15 - i);
167
+ }
168
+ let soma = somaInicial;
169
+ let rest = 0;
170
+ while (soma % 11 !== 0) {
171
+ rest++;
172
+ soma = somaInicial + (rest * 1);
173
+ }
174
+ return number.substr(-2, 1) + rest;
175
+ }
176
+ export function create_cpf(strCPF) {
177
+ strCPF = strCPF.replace(/[^\d]+/g, '');
178
+ if (strCPF === '00000000000') {
179
+ return false;
180
+ }
181
+ // const r1 = modulo11(strCPF.substr(0, strCPF.length - 2))
182
+ // const r2 = modulo11(strCPF.substr(0, strCPF.length - 2) + '' + r1)
183
+ // const restos = [
184
+ // r1, r2
185
+ // ];
186
+ const restoscustom = modulo11Custom(strCPF.substr(0, strCPF.length - 2), 2, 12);
187
+ return restoscustom;
188
+ }
189
+ export function create_cartaocredito(number) {
190
+ // if (number.length > 18) { alert("Erro. A rotina não abrange cartões\ncom mais de 18 dígitos (fora o DV).\nIntroduza 18 dígitos, no máximo."); }
191
+ number = "00000000000000000" + number;
192
+ number = number.slice(number.length - 18);
193
+ let b1 = parseInt(number.slice(17));
194
+ let b2 = parseInt(number.slice(16, 17));
195
+ let b3 = parseInt(number.slice(15, 16));
196
+ let b4 = parseInt(number.slice(14, 15));
197
+ let b5 = parseInt(number.slice(13, 14));
198
+ let b6 = parseInt(number.slice(12, 13));
199
+ let b7 = parseInt(number.slice(11, 12));
200
+ let b8 = parseInt(number.slice(10, 11));
201
+ let b9 = parseInt(number.slice(9, 10));
202
+ let b10 = parseInt(number.slice(8, 9));
203
+ let b11 = parseInt(number.slice(7, 8));
204
+ let b12 = parseInt(number.slice(6, 7));
205
+ let b13 = parseInt(number.slice(5, 6));
206
+ let b14 = parseInt(number.slice(4, 5));
207
+ let b15 = parseInt(number.slice(3, 4));
208
+ let b16 = parseInt(number.slice(2, 3));
209
+ let b17 = parseInt(number.slice(1, 2));
210
+ let b18 = parseInt(number.slice(0, 1));
211
+ let ci17 = b1 * 2;
212
+ if (ci17 > 9) {
213
+ ci17 = ci17 - 9;
214
+ }
215
+ let ci1516 = b3 * 2;
216
+ if (ci1516 > 9) {
217
+ ci1516 = ci1516 - 9;
218
+ }
219
+ let ci1314 = b5 * 2;
220
+ if (ci1314 > 9) {
221
+ ci1314 = ci1314 - 9;
222
+ }
223
+ let ci1112 = b7 * 2;
224
+ if (ci1112 > 9) {
225
+ ci1112 = ci1112 - 9;
226
+ }
227
+ let ci910 = b9 * 2;
228
+ if (ci910 > 9) {
229
+ ci910 = ci910 - 9;
230
+ }
231
+ let ci78 = b11 * 2;
232
+ if (ci78 > 9) {
233
+ ci78 = ci78 - 9;
234
+ }
235
+ let ci56 = b13 * 2;
236
+ if (ci56 > 9) {
237
+ ci56 = ci56 - 9;
238
+ }
239
+ let ci34 = b15 * 2;
240
+ if (ci34 > 9) {
241
+ ci34 = ci34 - 9;
242
+ }
243
+ let ci12 = b17 * 2;
244
+ if (ci12 > 9) {
245
+ ci12 = ci12 - 9;
246
+ }
247
+ let ci1617 = b2;
248
+ let ci1415 = b4;
249
+ let ci1213 = b6;
250
+ let ci1011 = b8;
251
+ let ci89 = b10;
252
+ let ci67 = b12;
253
+ let ci45 = b14;
254
+ let ci23 = b16;
255
+ let ci01 = b18;
256
+ let ccredDig = (ci1617 + ci1415 + ci1213 + ci1011 + ci89 + ci67 + ci45 + ci23 + ci01 + ci17 + ci1516 + ci1314 + ci1112 + ci910 + ci78 + ci56 + ci34 + ci12) % 10;
257
+ ccredDig = 10 - ccredDig;
258
+ if (ccredDig == 10) {
259
+ ccredDig = 0;
260
+ }
261
+ return ccredDig;
262
+ }
263
+ export function create_ect(number) {
264
+ number = getAllDigits(number);
265
+ number = "0000000" + number;
266
+ number = number.slice(number.length - 8);
267
+ let b1 = parseInt(number.slice(7));
268
+ let b2 = parseInt(number.slice(6, 7));
269
+ let b3 = parseInt(number.slice(5, 6));
270
+ let b4 = parseInt(number.slice(4, 5));
271
+ let b5 = parseInt(number.slice(3, 4));
272
+ let b6 = parseInt(number.slice(2, 3));
273
+ let b7 = parseInt(number.slice(1, 2));
274
+ let b8 = parseInt(number.slice(0, 1));
275
+ let regEctDig = (b1 * 7 + b2 * 9 + b3 * 5 + b4 * 3 + b5 * 2 + b6 * 4 + b7 * 6 + b8 * 8) % 11;
276
+ regEctDig = 11 - regEctDig;
277
+ if (regEctDig == 11) {
278
+ regEctDig = 5;
279
+ }
280
+ if (regEctDig == 10) {
281
+ regEctDig = 0;
282
+ }
283
+ return regEctDig;
284
+ }
285
+ export function create_pispasep(number) {
286
+ number = getAllDigits(number);
287
+ let nis = fillString(number, 11, '0');
288
+ let d;
289
+ let p = 2, c = 9;
290
+ for (d = 0; c >= 0; c--, (p < 9) ? p++ : p = 2) {
291
+ d += parseInt(nis[c]) * p;
292
+ }
293
+ const digit = (((10 * d) % 11) % 10);
294
+ return digit;
295
+ }
296
+ export function create_renavam(renavam) {
297
+ let dig1 = 0;
298
+ while (renavam.length < 11) {
299
+ renavam = '0' + renavam;
300
+ }
301
+ dig1 = (renavam.charCodeAt(0) - 48) * 3 + (renavam.charCodeAt(1) - 48) * 2 + (renavam.charCodeAt(2) - 48) * 9 + (renavam.charCodeAt(3) - 48) * 8 +
302
+ (renavam.charCodeAt(4) - 48) * 7 + (renavam.charCodeAt(5) - 48) * 6 + (renavam.charCodeAt(6) - 48) * 5 +
303
+ (renavam.charCodeAt(7) - 48) * 4 + (renavam.charCodeAt(8) - 48) * 3 + (renavam.charCodeAt(9) - 48) * 2;
304
+ dig1 = dig1 * 10;
305
+ let resto = (dig1 % 11);
306
+ if (resto === 10) {
307
+ return 0;
308
+ }
309
+ else {
310
+ return resto;
311
+ }
312
+ }
313
+ /**
314
+ *
315
+ * Font: http://ghiorzi.org/index.htm
316
+ * @param number
317
+ */
318
+ export function create_processo(number) {
319
+ number = getAllDigits(number);
320
+ number = "00000000000000000" + number;
321
+ number = number.slice(number.length - 18);
322
+ let b1 = parseInt(number.slice(0, 1)) * 10000000000;
323
+ let b2 = parseInt(number.slice(1, 2)) * 1000000000;
324
+ let b3 = parseInt(number.slice(2, 3)) * 100000000;
325
+ let b4 = parseInt(number.slice(3, 4)) * 10000000;
326
+ let b5 = parseInt(number.slice(4, 5)) * 1000000;
327
+ let b6 = parseInt(number.slice(5, 6)) * 100000;
328
+ let b7 = parseInt(number.slice(6, 7)) * 10000;
329
+ let b8 = parseInt(number.slice(7, 8)) * 1000;
330
+ let b9 = parseInt(number.slice(8, 9)) * 100;
331
+ let b10 = parseInt(number.slice(9, 10)) * 10;
332
+ let b11 = parseInt(number.slice(10, 11));
333
+ const proc1a11 = b1 + b2 + b3 + b4 + b5 + b6 + b7 + b8 + b9 + b10 + b11;
334
+ const resto1 = proc1a11 % 97;
335
+ let b12 = parseInt(number.slice(11, 12)) * 1000000;
336
+ let b13 = parseInt(number.slice(12, 13)) * 100000;
337
+ let b14 = parseInt(number.slice(13, 14)) * 10000;
338
+ let b15 = parseInt(number.slice(14, 15)) * 1000;
339
+ let b16 = parseInt(number.slice(15, 16)) * 100;
340
+ let b17 = parseInt(number.slice(16, 17)) * 10;
341
+ let b18 = parseInt(number.slice(17));
342
+ const proc12a18 = b12 + b13 + b14 + b15 + b16 + b17 + b18;
343
+ const resto2 = (resto1 * 10000000 * 100 + proc12a18 * 100) % 97;
344
+ let procJudDV = 98 - resto2;
345
+ if (procJudDV < 10) {
346
+ procJudDV = "0" + procJudDV;
347
+ }
348
+ let procJudCompl = b1 / 10000 + b2 / 10000 + b3 / 10000 + b4 / 10000 + b5 / 10000 + b6 / 10000 + b7 / 10000 + "-" + procJudDV + "." + b8 / 1000 + b9 / 100 + b10 / 10 + b11 + "." + b12 / 1000000 + "." + b13 / 100000 + b14 / 10000 + "." + b15 / 1000 + b16 / 100 + b17 / 10 + b18;
349
+ procJudCompl = "000000" + procJudCompl;
350
+ const result = procJudCompl.slice(procJudCompl.length - 25);
351
+ return result;
352
+ }
353
+ export function create_titulo_atual(titulo) {
354
+ const tit = titulo;
355
+ let dig1 = 0;
356
+ let dig2 = 0;
357
+ const tam = tit.length;
358
+ const estado = tit.substr(tam - 4, 2);
359
+ titulo = tit.substr(0, tam - 2);
360
+ titulo = '000000000000' + titulo;
361
+ titulo = titulo.substr(titulo.length - 11, titulo.length - 1);
362
+ const exce = (estado === '01') || (estado === '02');
363
+ dig1 = (titulo.charCodeAt(0) - 48) * 2 + (titulo.charCodeAt(1) - 48) * 9 + (titulo.charCodeAt(2) - 48) * 8 +
364
+ (titulo.charCodeAt(3) - 48) * 7 + (titulo.charCodeAt(4) - 48) * 6 + (titulo.charCodeAt(5) - 48) * 5 +
365
+ (titulo.charCodeAt(6) - 48) * 4 + (titulo.charCodeAt(7) - 48) * 3 + (titulo.charCodeAt(8) - 48) * 2;
366
+ let resto = (dig1 % 11);
367
+ if (resto === 0) {
368
+ if (exce) {
369
+ dig1 = 1;
370
+ }
371
+ else {
372
+ dig1 = 0;
373
+ }
374
+ }
375
+ else {
376
+ if (resto === 1) {
377
+ dig1 = 0;
378
+ }
379
+ else {
380
+ dig1 = 11 - resto;
381
+ }
382
+ }
383
+ dig2 = (titulo.charCodeAt(9) - 48) * 4 + (titulo.charCodeAt(10) - 48) * 3 + dig1 * 2;
384
+ resto = (dig2 % 11);
385
+ if (resto === 0) {
386
+ if (exce) {
387
+ dig2 = 1;
388
+ }
389
+ else {
390
+ dig2 = 0;
391
+ }
392
+ }
393
+ else {
394
+ if (resto === 1) {
395
+ dig2 = 0;
396
+ }
397
+ else {
398
+ dig2 = 11 - resto;
399
+ }
400
+ }
401
+ return dig1.toString() + dig2.toString();
402
+ }
403
+ export function create_titulo(titNum) {
404
+ titNum = getAllDigits(titNum);
405
+ if (titNum.length > 11) {
406
+ titNum = titNum.substr(0, 11);
407
+ }
408
+ titNum = "00000000" + titNum;
409
+ titNum = titNum.slice(titNum.length - 11);
410
+ let a1 = parseInt(titNum.slice(10));
411
+ let a2 = parseInt(titNum.slice(9, 10));
412
+ let a3 = parseInt(titNum.slice(8, 9));
413
+ let a4 = parseInt(titNum.slice(7, 8));
414
+ let a5 = parseInt(titNum.slice(6, 7));
415
+ let a6 = parseInt(titNum.slice(5, 6));
416
+ let a7 = parseInt(titNum.slice(4, 5));
417
+ let a8 = parseInt(titNum.slice(3, 4));
418
+ let a9 = parseInt(titNum.slice(2, 3));
419
+ let a10 = parseInt(titNum.slice(1, 2));
420
+ let a11 = parseInt(titNum.slice(0, 1));
421
+ if (a2 * 10 + a1 == 0 || a2 * 10 + a1 > 28) {
422
+ throw new Error("Esse nº é suspeito, porque a identificação da \nUF (últimos 2 dígitos) deve estar entre 01 e 28.");
423
+ }
424
+ let titExcecao1 = 0;
425
+ let titExcecao2 = 0;
426
+ let titPriDig = (a3 * 9 + a4 * 8 + a5 * 7 + a6 * 6 + a7 * 5 + a8 * 4 + a9 * 3 + a10 * 2 + a11 * 9) % 11;
427
+ if (titPriDig == 0) {
428
+ titExcecao1 = 1;
429
+ }
430
+ if (titPriDig == 10) {
431
+ titPriDig = 0;
432
+ }
433
+ if ((a2 * 10 + a1 == 1 || a2 * 10 + a1 == 2) && (titExcecao1 == 1)) {
434
+ titPriDig = 1;
435
+ }
436
+ let titSegDig = (titPriDig * 9 + a1 * 8 + a2 * 7) % 11;
437
+ if (titSegDig == 0) {
438
+ titExcecao2 = 1;
439
+ }
440
+ if (titSegDig == 10) {
441
+ titSegDig = 0;
442
+ }
443
+ if ((a2 * 10 + a1 == 1 || a2 * 10 + a1 == 2) && (titExcecao2 == 1)) {
444
+ titSegDig = 1;
445
+ }
446
+ let titDV = titPriDig * 10 + titSegDig;
447
+ if (titDV == 0) {
448
+ titDV = "00";
449
+ }
450
+ if (titDV > 0 && titDV < 10) {
451
+ titDV = "0" + titDV;
452
+ }
453
+ return titDV.toString();
454
+ }
455
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"create.js","sourceRoot":"","sources":["../../../../../../../projects/mapa-library-ui/src/lib/core/js-brasil/src/create.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,UAAU,EAAE,cAAc,EAAE,MAAM,SAAS,CAAC;AAEnE;;;;;GAKG;AACH,MAAM,UAAU,UAAU,CAAC,KAA8B;IACvD,KAAK,GAAG,YAAY,CAAC,KAAK,CAAC,QAAQ,EAAE,CAAC,CAAC;IACvC,IAAI,KAAK,CAAC,MAAM,GAAG,EAAE,EAAE;QACrB,KAAK,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;KACtD;IACD,MAAM,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAC5B,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,GAAG,CAAC,GAAG,GAAG,EAAE,CAAC,CAAC,CAAC;IACzC,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAC1C,OAAO,MAAM,CAAC;AAChB,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,KAAa;IAE3C,IAAI,KAAK,CAAC,MAAM,GAAG,EAAE,EAAE;QACrB,KAAK,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,EAAE,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;KAC9C;IACD,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;IACnC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACvC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC;IACxC,IAAI,GAAG,GAAG,QAAQ,CAAC,KAAK,CAAC,KAAK,CA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","sourcesContent":["import { ESTADOS_SIGLA } from './estados';\nimport { getAllDigits, fillString, modulo11Custom } from './utils';\n\n/**\n * \n * @param uf - UF do número da guia. Ex: 35(SP), 81(PE)\n * @param ano - ANO do número da guia. Ex: 2018, 2019\n * @param tipo - TIPO da guia. Aih = 1, APAC = 2\n */\nexport function create_aih(value: string | number | any[]) {\n  value = getAllDigits(value.toString());\n  if (value.length > 12) {\n    value = value.toString().substr(0, value.length - 1);\n  }\n  const cod = parseInt(value);\n  const calc = Math.ceil(cod - (cod / 11));\n  const digito = calc.toString().substr(-1);\n  return digito;\n}\n\nexport function create_certidao(value: string) {\n\n  if (value.length > 30) {\n    value = value.substring(0, value.length - 2);\n  }\n  let b1 = parseInt(value.slice(29));\n  let b2 = parseInt(value.slice(28, 29));\n  let b3 = parseInt(value.slice(27, 28));\n  let b4 = parseInt(value.slice(26, 27));\n  let b5 = parseInt(value.slice(25, 26));\n  let b6 = parseInt(value.slice(24, 25));\n  let b7 = parseInt(value.slice(23, 24));\n  let b8 = parseInt(value.slice(22, 23));\n  let b9 = parseInt(value.slice(21, 22));\n  let b10 = parseInt(value.slice(20, 21));\n  let b11 = parseInt(value.slice(19, 20));\n  let b12 = parseInt(value.slice(18, 19));\n  let b13 = parseInt(value.slice(17, 18));\n  let b14 = parseInt(value.slice(16, 17));\n  let b15 = parseInt(value.slice(15, 16));\n  let b16 = parseInt(value.slice(14, 15));\n  let b17 = parseInt(value.slice(13, 14));\n  let b18 = parseInt(value.slice(12, 13));\n  let b19 = parseInt(value.slice(11, 12));\n  let b20 = parseInt(value.slice(10, 11));\n  let b21 = parseInt(value.slice(9, 10));\n  let b22 = parseInt(value.slice(8, 9));\n  let b23 = parseInt(value.slice(7, 8));\n  let b24 = parseInt(value.slice(6, 7));\n  let b25 = parseInt(value.slice(5, 6));\n  let b26 = parseInt(value.slice(4, 5));\n  let b27 = parseInt(value.slice(3, 4));\n  let b28 = parseInt(value.slice(2, 3));\n  let b29 = parseInt(value.slice(1, 2));\n  let b30 = parseInt(value.slice(0, 1));\n\n  let certPriDig = (b1 * 9 + b2 * 8 + b3 * 7 + b4 * 6 + b5 * 5 + b6 * 4 + b7 * 3 + b8 * 2 + b9 * 1 + b10 * 0 + b11 * 10 + b12 * 9 + b13 * 8 + b14 * 7 + b15 * 6 + b16 * 5 + b17 * 4 + b18 * 3 + b19 * 2 + b20 * 1 + b21 * 0 + b22 * 10 + b23 * 9 + b24 * 8 + b25 * 7 + b26 * 6 + b27 * 5 + b28 * 4 + b29 * 3 + b30 * 2) % 11;\n  if (certPriDig == 10) { certPriDig = 1; }\n  let certSegDig = (certPriDig * 9 + b1 * 8 + b2 * 7 + b3 * 6 + b4 * 5 + b5 * 4 + b6 * 3 + b7 * 2 + b8 * 1 + b9 * 0 + b10 * 10 + b11 * 9 + b12 * 8 + b13 * 7 + b14 * 6 + b15 * 5 + b16 * 4 + b17 * 3 + b18 * 2 + b19 * 1 + b20 * 0 + b21 * 10 + b22 * 9 + b23 * 8 + b24 * 7 + b25 * 6 + b26 * 5 + b27 * 4 + b28 * 3 + b29 * 2 + b30 * 1) % 11;\n  if (certSegDig == 10) { certSegDig = 1; }\n  let certDV: any = certPriDig * 10 + certSegDig;\n  if (certDV == 0) { certDV = \"00\"; }\n  if (certDV > 0 && certDV < 10) { certDV = \"0\" + certDV; }\n\n  return certDV.toString();\n}\n\nexport function create_cnhespelho(value: string) {\n  let v1 = modulo11Custom(value.substr(0, value.length - 1), 1, 8, false);\n  return v1\n}\n\nexport function create_renachestadual(value: string) {\n\n  const state = value.substr(0, 2).toLowerCase()\n  if (!ESTADOS_SIGLA.includes(state)) {\n    return false\n  }\n\n  let digits = value.substr(2)\n  digits = digits.replace(/[^\\d]/g, '');\n  if (digits.length !== 9) {\n    return false;\n  }\n\n  let v1 = modulo11Custom(digits.substr(0, digits.length - 1), 1, 11);\n  return '' + v1\n}\n\n/**\n * \n * @param value \n * @returns \n */\nexport function create_renachseguranca(value: string) {\n  value = value.replace(/[^\\d]+/g, '');\n  if (value.length !== 11) {\n    return false;\n  }\n\n  let v1 = modulo11Custom(value.substr(0, value.length - 1), 1, 11);\n  return \"\" + v1;\n}\n\n/**\n * Dígito verificador da CNH não é mais o módulo 11 conforme últimas resoluções\n * @param value \n * @returns \n */\nexport function create_cnh(value: string) {\n  value = value.replace(/[^\\d]+/g, '');\n\n  if (value.length != 11 || value === '0') {\n    return false;\n  }\n  // let v1 = modulo11Custom(value.substr(0, value.length - 2), 2);\n  // if (v1 === '10') v1 = '00'\n  let v1 = value.substr(-2)\n  return v1;\n}\n\nexport function create_cnpj(cnpj: string) {\n  cnpj = cnpj.replace(/[^\\d]+/g, '');\n\n  if (cnpj === '') {\n    return false;\n  }\n\n  if (cnpj.length !== 14) {\n    return false;\n  }\n\n  // Elimina CNPJs invalidos conhecidos\n  if (cnpj === '00000000000000' ||\n    cnpj === '11111111111111' ||\n    cnpj === '22222222222222' ||\n    cnpj === '33333333333333' ||\n    cnpj === '44444444444444' ||\n    cnpj === '55555555555555' ||\n    cnpj === '66666666666666' ||\n    cnpj === '77777777777777' ||\n    cnpj === '88888888888888' ||\n    cnpj === '99999999999999') {\n    return false;\n  }\n\n  // Valida DVs\n  let tamanho: number = cnpj.length - 2\n  let numeros: any = cnpj.substring(0, tamanho);\n  let soma: any = 0;\n  let pos = tamanho - 7;\n  for (let i = tamanho; i >= 1; i--) {\n    soma += numeros.charAt(tamanho - i) * pos--;\n    if (pos < 2) {\n      pos = 9;\n    }\n\n  }\n  const resultados = [0, 0];\n  resultados[0] = soma % 11 < 2 ? 0 : 11 - soma % 11;\n\n  tamanho = tamanho + 1;\n  numeros = cnpj.substring(0, tamanho);\n  soma = 0;\n  pos = tamanho - 7;\n  for (let i = tamanho; i >= 1; i--) {\n    soma += numeros.charAt(tamanho - i) * pos--;\n    if (pos < 2) {\n      pos = 9;\n    }\n  }\n  resultados[1] = soma % 11 < 2 ? 0 : 11 - soma % 11;\n  return resultados;\n}\n\nexport function create_cns(number: string) {\n  number = getAllDigits(number);\n  let somaInicial = 0;\n  for (let i = 0; i < number.length - 1; i++) {\n    somaInicial += parseInt(number[i]) * (15 - i);\n  }\n  let soma = somaInicial;\n  let rest = 0;\n  while (soma % 11 !== 0) {\n    rest++;\n    soma = somaInicial + (rest * 1)\n  }\n  return number.substr(-2, 1) + rest;\n}\n\nexport function create_cpf(strCPF: string) {\n  strCPF = strCPF.replace(/[^\\d]+/g, '');\n  if (strCPF === '00000000000') {\n    return false;\n  }\n\n  // const r1 = modulo11(strCPF.substr(0, strCPF.length - 2))\n  // const r2 = modulo11(strCPF.substr(0, strCPF.length - 2) + '' + r1)\n  // const restos = [\n  //   r1, r2\n  // ];\n\n  const restoscustom = modulo11Custom(strCPF.substr(0, strCPF.length - 2), 2, 12);\n  return restoscustom\n}\n\nexport function create_cartaocredito(number: string) {\n\n  // if (number.length > 18) { alert(\"Erro. A rotina não abrange cartões\\ncom mais de 18 dígitos (fora o DV).\\nIntroduza 18 dígitos, no máximo.\"); }\n\n  number = \"00000000000000000\" + number;\n  number = number.slice(number.length - 18);\n\n  let b1 = parseInt(number.slice(17));\n  let b2 = parseInt(number.slice(16, 17));\n  let b3 = parseInt(number.slice(15, 16));\n  let b4 = parseInt(number.slice(14, 15));\n  let b5 = parseInt(number.slice(13, 14));\n  let b6 = parseInt(number.slice(12, 13));\n  let b7 = parseInt(number.slice(11, 12));\n  let b8 = parseInt(number.slice(10, 11));\n  let b9 = parseInt(number.slice(9, 10));\n  let b10 = parseInt(number.slice(8, 9));\n  let b11 = parseInt(number.slice(7, 8));\n  let b12 = parseInt(number.slice(6, 7));\n  let b13 = parseInt(number.slice(5, 6));\n  let b14 = parseInt(number.slice(4, 5));\n  let b15 = parseInt(number.slice(3, 4));\n  let b16 = parseInt(number.slice(2, 3));\n  let b17 = parseInt(number.slice(1, 2));\n  let b18 = parseInt(number.slice(0, 1));\n\n\n  let ci17 = b1 * 2; if (ci17 > 9) { ci17 = ci17 - 9; }\n  let ci1516 = b3 * 2; if (ci1516 > 9) { ci1516 = ci1516 - 9; }\n  let ci1314 = b5 * 2; if (ci1314 > 9) { ci1314 = ci1314 - 9; }\n  let ci1112 = b7 * 2; if (ci1112 > 9) { ci1112 = ci1112 - 9; }\n  let ci910 = b9 * 2; if (ci910 > 9) { ci910 = ci910 - 9; }\n  let ci78 = b11 * 2; if (ci78 > 9) { ci78 = ci78 - 9; }\n  let ci56 = b13 * 2; if (ci56 > 9) { ci56 = ci56 - 9; }\n  let ci34 = b15 * 2; if (ci34 > 9) { ci34 = ci34 - 9; }\n  let ci12 = b17 * 2; if (ci12 > 9) { ci12 = ci12 - 9; }\n  let ci1617 = b2;\n  let ci1415 = b4;\n  let ci1213 = b6;\n  let ci1011 = b8;\n  let ci89 = b10;\n  let ci67 = b12;\n  let ci45 = b14;\n  let ci23 = b16;\n  let ci01 = b18;\n\n  let ccredDig = (ci1617 + ci1415 + ci1213 + ci1011 + ci89 + ci67 + ci45 + ci23 + ci01 + ci17 + ci1516 + ci1314 + ci1112 + ci910 + ci78 + ci56 + ci34 + ci12) % 10;\n  ccredDig = 10 - ccredDig; if (ccredDig == 10) { ccredDig = 0; }\n\n  return ccredDig;\n}\n\nexport function create_ect(number: string) {\n  number = getAllDigits(number);\n  number = \"0000000\" + number;\n  number = number.slice(number.length - 8);\n\n  let b1 = parseInt(number.slice(7));\n  let b2 = parseInt(number.slice(6, 7));\n  let b3 = parseInt(number.slice(5, 6));\n  let b4 = parseInt(number.slice(4, 5));\n  let b5 = parseInt(number.slice(3, 4));\n  let b6 = parseInt(number.slice(2, 3));\n  let b7 = parseInt(number.slice(1, 2));\n  let b8 = parseInt(number.slice(0, 1));\n\n  let regEctDig = (b1 * 7 + b2 * 9 + b3 * 5 + b4 * 3 + b5 * 2 + b6 * 4 + b7 * 6 + b8 * 8) % 11;\n  regEctDig = 11 - regEctDig;\n  if (regEctDig == 11) { regEctDig = 5; }\n  if (regEctDig == 10) { regEctDig = 0; }\n  return regEctDig;\n}\n\nexport function create_pispasep(number: string) {\n\n  number = getAllDigits(number);\n  let nis = fillString(number, 11, '0');\n\n  let d;\n  let p = 2, c = 9;\n  for (d = 0; c >= 0; c--, (p < 9) ? p++ : p = 2) {\n    d += parseInt(nis[c]) * p;\n  }\n\n  const digit = (((10 * d) % 11) % 10);\n  return digit;\n}\n\nexport function create_renavam(renavam: string) {\n  let dig1 = 0;\n  while (renavam.length < 11) {\n    renavam = '0' + renavam;\n  }\n\n  dig1 = (renavam.charCodeAt(0) - 48) * 3 + (renavam.charCodeAt(1) - 48) * 2 + (renavam.charCodeAt(2) - 48) * 9 + (renavam.charCodeAt(3) - 48) * 8 +\n    (renavam.charCodeAt(4) - 48) * 7 + (renavam.charCodeAt(5) - 48) * 6 + (renavam.charCodeAt(6) - 48) * 5 +\n    (renavam.charCodeAt(7) - 48) * 4 + (renavam.charCodeAt(8) - 48) * 3 + (renavam.charCodeAt(9) - 48) * 2;\n  dig1 = dig1 * 10;\n  let resto = (dig1 % 11);\n  if (resto === 10) {\n    return 0;\n  } else {\n    return resto;\n  }\n}\n\n\n\n/**\n * \n * Font: http://ghiorzi.org/index.htm\n * @param number \n */\nexport function create_processo(number: string) {\n  number = getAllDigits(number);\n  number = \"00000000000000000\" + number;\n  number = number.slice(number.length - 18);\n\n  let b1 = parseInt(number.slice(0, 1)) * 10000000000;\n  let b2 = parseInt(number.slice(1, 2)) * 1000000000;\n  let b3 = parseInt(number.slice(2, 3)) * 100000000;\n  let b4 = parseInt(number.slice(3, 4)) * 10000000;\n  let b5 = parseInt(number.slice(4, 5)) * 1000000;\n  let b6 = parseInt(number.slice(5, 6)) * 100000;\n  let b7 = parseInt(number.slice(6, 7)) * 10000;\n  let b8 = parseInt(number.slice(7, 8)) * 1000;\n  let b9 = parseInt(number.slice(8, 9)) * 100;\n  let b10 = parseInt(number.slice(9, 10)) * 10;\n  let b11 = parseInt(number.slice(10, 11));\n\n  const proc1a11 = b1 + b2 + b3 + b4 + b5 + b6 + b7 + b8 + b9 + b10 + b11;\n  const resto1 = proc1a11 % 97;\n\n  let b12 = parseInt(number.slice(11, 12)) * 1000000;\n  let b13 = parseInt(number.slice(12, 13)) * 100000;\n  let b14 = parseInt(number.slice(13, 14)) * 10000;\n  let b15 = parseInt(number.slice(14, 15)) * 1000;\n  let b16 = parseInt(number.slice(15, 16)) * 100;\n  let b17 = parseInt(number.slice(16, 17)) * 10;\n  let b18 = parseInt(number.slice(17));\n\n  const proc12a18 = b12 + b13 + b14 + b15 + b16 + b17 + b18;\n  const resto2 = (resto1 * 10000000 * 100 + proc12a18 * 100) % 97;\n\n  let procJudDV: any = 98 - resto2;\n\n  if (procJudDV < 10) {\n    procJudDV = \"0\" + procJudDV;\n  }\n\n  let procJudCompl = b1 / 10000 + b2 / 10000 + b3 / 10000 + b4 / 10000 + b5 / 10000 + b6 / 10000 + b7 / 10000 + \"-\" + procJudDV + \".\" + b8 / 1000 + b9 / 100 + b10 / 10 + b11 + \".\" + b12 / 1000000 + \".\" + b13 / 100000 + b14 / 10000 + \".\" + b15 / 1000 + b16 / 100 + b17 / 10 + b18;\n\n  procJudCompl = \"000000\" + procJudCompl;\n  const result = procJudCompl.slice(procJudCompl.length - 25);\n  return result;\n}\n\n\nexport function create_titulo_atual(titulo: string) {\n  const tit = titulo;\n  let dig1 = 0;\n  let dig2 = 0;\n  const tam = tit.length;\n  const estado = tit.substr(tam - 4, 2);\n  titulo = tit.substr(0, tam - 2);\n  titulo = '000000000000' + titulo;\n  titulo = titulo.substr(titulo.length - 11, titulo.length - 1);\n  const exce = (estado === '01') || (estado === '02');\n  dig1 = (titulo.charCodeAt(0) - 48) * 2 + (titulo.charCodeAt(1) - 48) * 9 + (titulo.charCodeAt(2) - 48) * 8 +\n    (titulo.charCodeAt(3) - 48) * 7 + (titulo.charCodeAt(4) - 48) * 6 + (titulo.charCodeAt(5) - 48) * 5 +\n    (titulo.charCodeAt(6) - 48) * 4 + (titulo.charCodeAt(7) - 48) * 3 + (titulo.charCodeAt(8) - 48) * 2;\n  let resto = (dig1 % 11);\n  if (resto === 0) {\n    if (exce) {\n      dig1 = 1;\n    } else {\n      dig1 = 0;\n    }\n  } else {\n    if (resto === 1) {\n      dig1 = 0;\n    } else {\n      dig1 = 11 - resto;\n    }\n  }\n  dig2 = (titulo.charCodeAt(9) - 48) * 4 + (titulo.charCodeAt(10) - 48) * 3 + dig1 * 2;\n  resto = (dig2 % 11);\n  if (resto === 0) {\n    if (exce) {\n      dig2 = 1;\n    } else {\n      dig2 = 0;\n    }\n  } else {\n    if (resto === 1) {\n      dig2 = 0;\n    } else {\n      dig2 = 11 - resto;\n    }\n  }\n  return dig1.toString() + dig2.toString();\n}\n\nexport function create_titulo(titNum: string) {\n  titNum = getAllDigits(titNum);\n\n  if (titNum.length > 11) {\n    titNum = titNum.substr(0, 11);\n  }\n\n  titNum = \"00000000\" + titNum;\n  titNum = titNum.slice(titNum.length - 11);\n\n  let a1 = parseInt(titNum.slice(10));\n  let a2 = parseInt(titNum.slice(9, 10));\n  let a3 = parseInt(titNum.slice(8, 9));\n  let a4 = parseInt(titNum.slice(7, 8));\n  let a5 = parseInt(titNum.slice(6, 7));\n  let a6 = parseInt(titNum.slice(5, 6));\n  let a7 = parseInt(titNum.slice(4, 5));\n  let a8 = parseInt(titNum.slice(3, 4));\n  let a9 = parseInt(titNum.slice(2, 3));\n  let a10 = parseInt(titNum.slice(1, 2));\n  let a11 = parseInt(titNum.slice(0, 1));\n\n  if (a2 * 10 + a1 == 0 || a2 * 10 + a1 > 28) {\n    throw new Error(\"Esse nº é suspeito, porque a identificação da \\nUF (últimos 2 dígitos) deve estar entre 01 e 28.\");\n  }\n\n  let titExcecao1 = 0;\n  let titExcecao2 = 0;\n\n  let titPriDig = (a3 * 9 + a4 * 8 + a5 * 7 + a6 * 6 + a7 * 5 + a8 * 4 + a9 * 3 + a10 * 2 + a11 * 9) % 11;\n  if (titPriDig == 0) { titExcecao1 = 1; }\n  if (titPriDig == 10) { titPriDig = 0; }\n  if ((a2 * 10 + a1 == 1 || a2 * 10 + a1 == 2) && (titExcecao1 == 1)) { titPriDig = 1; }\n\n  let titSegDig = (titPriDig * 9 + a1 * 8 + a2 * 7) % 11;\n  if (titSegDig == 0) { titExcecao2 = 1; }\n  if (titSegDig == 10) { titSegDig = 0; }\n  if ((a2 * 10 + a1 == 1 || a2 * 10 + a1 == 2) && (titExcecao2 == 1)) { titSegDig = 1; }\n\n  let titDV: any = titPriDig * 10 + titSegDig;\n  if (titDV == 0) { titDV = \"00\"; }\n  if (titDV > 0 && titDV < 10) { titDV = \"0\" + titDV; }\n\n  return titDV.toString();\n}"]}