;(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

Não está no último lote? Saiba o que fazer se caiu na malha fina do IR

Do UOL, em São Paulo

08/12/2017 09h30

A Receita Federal liberou nesta sexta-feira (8) a consulta ao sétimo e último lote do Imposto de Renda. Se você ainda não recebeu a restituição e não está neste lote, significa que caiu na malha fina.

Se informou um dado errado ou omitiu informações, como não incluir rendimentos de dependentes, automaticamente a declaração fica presa na malha fina. Veja abaixo como corrigir sua situação.

Leia também:


Como checar sua situação

Para conferir sua situação, basta ar o Centro Virtual de Atendimento da Receita Federal (e-CAC), disponível neste linke informar seu F, código de o e senha.

Veja neste link como fazer o seu código de o. 

Caso constate que, de fato, está com problemas na declaração de IR e caiu na malha fina, há duas maneiras de resolver as pendências. 


1) Se a declaração tiver erro ou informações incompletas

Se a declaração apresenta informações incorretas ou incompletas, o contribuinte deve, o quanto antes, providenciar a retificação do documento, enviando uma nova versão com os dados corrigidos.

Mas é preciso ficar atento, pois não é possível retificar a declaração depois que a Receita convocou a pessoa para prestar esclarecimentos. Portanto, quanto antes providenciar as correções, melhor.

Retificação só pelo computador

Se a declaração foi feita pelo celular ou tablet, não poderá retificar a declaração por esse sistema. Terá de baixar o programa para o envio da declaração (disponível para neste link) em um computador e fazer a retificação por esse meio. Veja como:

  • envie o arquivo da declaração do dispositivo móvel para um computador (salve em uma pasta de sua preferência);
  • instale o programa no seu computador;
  • dentro do programa da declaração, no menu "Ferramentas", vá em "Cópia de Segurança" e "Restaurar" (a declaração será importada para o programa);
  • Faça as modificações necessárias, grave e transmita a declaração pelo próprio programa da declaração.

Para apresentar uma declaração retificadora, será necessário informar o número do recibo da declaração original. Localize esse número no "Recibo da Declaração", armazenado em seu dispositivo móvel em formato PDF.


2) Documento gerou dúvida, mas não há erro

Por outro lado, se a declaração foi retida na malha fina, mas o contribuinte está com tudo em dia e o documento foi preenchido corretamente, deve aguardar o Termo de Intimação ou a Notificação de Lançamento da Receita Federal, ou agendar atendimento para a entrega da documentação que comprova o acerto das informações declaradas.

Agendar atendimento: só a partir de janeiro

Para as declarações do IR 2017, só é possível agendar atendimento a partir de janeiro de 2018.

Veja mais informações sobre agendamento neste link.


Declaração processada pode voltar a ser analisada

Mesmo uma declaração que já foi processada pode voltar a ser alvo de análise da Receita.

O limite de prazo para verificar cada declaração é de cinco anos. ado esse período, nem a Receita pode cobrar débitos em atraso nem o contribuinte pode exigir o pagamento de restituição que ficou para trás.

Se não sabe responder a estas 5 questões, será muito difícil ficar rico

UOL Notícias