;(function() { window.createMeasureObserver = (measureName) => { var markPrefix = `_uol-measure-${measureName}-${new Date().getTime()}`; performance.mark(`${markPrefix}-start`); return { end: function() { performance.mark(`${markPrefix}-end`); performance.measure(`uol-measure-${measureName}`, `${markPrefix}-start`, `${markPrefix}-end`); performance.clearMarks(`${markPrefix}-start`); performance.clearMarks(`${markPrefix}-end`); } } }; /** * Gerenciador de eventos */ window.gevent = { stack: [], RUN_ONCE: true, on: function(name, callback, once) { this.stack.push([name, callback, !!once]); }, emit: function(name, args) { for (var i = this.stack.length, item; i--;) { item = this.stack[i]; if (item[0] === name) { item[1](args); if (item[2]) { this.stack.splice(i, 1); } } } } }; var runningSearch = false; var hadAnEvent = true; var elementsToWatch = window.elementsToWatch = new Map(); var innerHeight = window.innerHeight; // timestamp da última rodada do requestAnimationFrame // É usado para limitar a procura por elementos visíveis. var lastAnimationTS = 0; // verifica se elemento está no viewport do usuário var isElementInViewport = function(el) { var rect = el.getBoundingClientRect(); var clientHeight = window.innerHeight || document.documentElement.clientHeight; // renderizando antes, evitando troca de conteúdo visível no chartbeat-related-content if(el.className.includes('related-content-front')) return true; // garante que usa ao mínimo 280px de margem para fazer o lazyload var margin = clientHeight + Math.max(280, clientHeight * 0.2); // se a base do componente está acima da altura da tela do usuário, está oculto if(rect.bottom < 0 && rect.bottom > margin * -1) { return false; } // se o topo do elemento está abaixo da altura da tela do usuário, está oculto if(rect.top > margin) { return false; } // se a posição do topo é negativa, verifica se a altura dele ainda // compensa o que já foi scrollado if(rect.top < 0 && rect.height + rect.top < 0) { return false; } return true; }; var asynxNextFreeTime = () => { return new Promise((resolve) => { if(window.requestIdleCallback) { window.requestIdleCallback(resolve, { timeout: 5000, }); } else { window.requestAnimationFrame(resolve); } }); }; var asyncValidateIfElIsInViewPort = function(promise, el) { return promise.then(() => { if(el) { if(isElementInViewport(el) == true) { const cb = elementsToWatch.get(el); // remove da lista para não ser disparado novamente elementsToWatch.delete(el); cb(); } } }).then(asynxNextFreeTime); }; // inicia o fluxo de procura de elementos procurados var look = function() { if(window.requestIdleCallback) { window.requestIdleCallback(findByVisibleElements, { timeout: 5000, }); } else { window.requestAnimationFrame(findByVisibleElements); } }; var findByVisibleElements = function(ts) { var elapsedSinceLast = ts - lastAnimationTS; // se não teve nenhum evento que possa alterar a página if(hadAnEvent == false) { return look(); } if(elementsToWatch.size == 0) { return look(); } if(runningSearch == true) { return look(); } // procura por elementos visíveis apenas 5x/seg if(elapsedSinceLast < 1000/5) { return look(); } // atualiza o último ts lastAnimationTS = ts; // reseta status de scroll para não entrar novamente aqui hadAnEvent = false; // indica que está rodando a procura por elementos no viewport runningSearch = true; const done = Array.from(elementsToWatch.keys()).reduce(asyncValidateIfElIsInViewPort, Promise.resolve()); // obtém todos os elementos que podem ter view contabilizados //elementsToWatch.forEach(function(cb, el) { // if(isElementInViewport(el) == true) { // // remove da lista para não ser disparado novamente // elementsToWatch.delete(el); // cb(el); // } //}); done.then(function() { runningSearch = false; }); // reinicia o fluxo de procura look(); }; /** * Quando o elemento `el` entrar no viewport (-20%), cb será disparado. */ window.lazyload = function(el, cb) { if(el.nodeType != Node.ELEMENT_NODE) { throw new Error("element parameter should be a Element Node"); } if(typeof cb !== 'function') { throw new Error("callback parameter should be a Function"); } elementsToWatch.set(el, cb); } var setEvent = function() { hadAnEvent = true; }; window.addEventListener('scroll', setEvent, { capture: true, ive: true }); window.addEventListener('click', setEvent, { ive: true }); window.addEventListener('resize', setEvent, { ive: true }); window.addEventListener('load', setEvent, { once: true, ive: true }); window.addEventListener('DOMContentLoaded', setEvent, { once: true, ive: true }); window.gevent.on('allJSLoadedAndCreated', setEvent, window.gevent.RUN_ONCE); // inicia a validação look(); })();
  • AssineUOL
Logo Pagbenk Seu dinheiro rende mais
Topo

Imposto de Renda 2022: Veja uma forma simples de achar erros na declaração

Colaboração para o UOL, de São Paulo

01/04/2022 04h00Atualizada em 10/05/2022 14h01

O programa da declaração de Imposto de Renda 2022 possui uma ferramenta que verifica possíveis problemas no documento, como campos não preenchidos ou com algum tipo de inconsistência nas informações prestadas.

A ferramenta "Verificar Pendências" pode ser ada na barra de menu do lado esquerdo da tela do programa, ou por meio do botão "F5" do teclado. Ela faz uma busca de possíveis erros na declaração e avisa o contribuinte quais fichas apresentam problemas.

A ferramenta pode ser utilizada a qualquer momento durante o preenchimento da declaração. Mas, é fundamental que você faça a verificação antes do envio do IR 2022 para a Receita.

IR pendencias - Reprodução - Reprodução
Imagem: Reprodução

As inconsistências encontradas são classificadas em "erros" (sinalizados por triângulos vermelhos) e "avisos" (triângulos amarelos).

Segundo a Receita Federal, "erros" são inconsistências graves, que impedem o envio da declaração, como a falta do número do F de algum dependente ou do CNPJ de alguma empresa declarada.

Se houver "erro", o programa emitirá uma mensagem, informando que não é possível entregar a declaração. Você terá que corrigir o problema para conseguir enviar o documento.

Já os "avisos" são inconsistências menos significativas, que não impedem o envio da declaração. Um exemplo é deixar de informar o título de eleitor na ficha de identificação do contribuinte.

Outra situação de "aviso" é colocar valor zero nos campos "situação em 31/12/2020" e "situação em 31/12/2021" na ficha de "Bens e direitos". Você deve declarar desta forma um bem (veículo, imóvel) que foi comprado e vendido no mesmo ano.

O programa emitirá o alerta por entender que você pode ter esquecido de informar o valor. Apesar do alerta, é possível enviar a declaração com os dois campos zerados. E, neste caso, de compra e venda do bem no mesmo ano, o correto é mandar desta forma.

Para corrigir os erros ou eliminar os avisos apontados pela ferramenta "verificar pendências", basta clicar em cima do texto que o programa informa a inconsistência encontrada.

O programa irá abrir automaticamente uma janela com a ficha que precisa ser corrigida. Faça as alterações necessárias e dê "ok" antes de sair da ficha para salvá-las.