Scroll Only |
---|
Autor do artigo: atualizado por Joao.Fonseca (Não remova esse quadro) |
Quando a falha ocorre?
Ao solicitar a exclusão de eventos no painel de monitoramento do Reinf é evidenciada a falha:
A1424-Descrição: Invalid use of Null <-LFSREINFMONIT.clsNPainel.RetornarArquivoCompleto. Referência/Erro: 79600000 / 94 ao excluir evento do monitoramento Reinf
Sumário
Sistema: Gerenciador de Aplicativos Prosoft
...
Descrição: Invalid use of Null
Rastreio:
<-LFSREINFMONIT.clsNPainel.RetornarArquivoCompleto.
Referência/Erro: 79600000 / 94
...
Como Corrigir?
Aviso |
---|
Antes de executar o procedimento efetue backup da base Prosoft |
Informações Adicionais: Não se aplica
...
1 - Execute o script para buscar os evento gerados sem competência ativa
...
SELECT [evg_id]
,[evg_tag_id]
,[evg_status]
,[evg_comp_ativa]
FROM [prosoft].[dbo].[esoc_evento_gerado] where evg_comp_ativa is null
2 - Execute o script para inserir uma competência para o evento, neste exemplo foi usada a data 202010, mas verifique com o cliente qual é a correta.
...
UPDATE [prosoft].[dbo].[esoc_evento_gerado]
SET evg_comp_ativa = 202010
WHERE evg_tag_id = 'ID1401145340001632021011217194200001'
...
Scroll Only |
---|
(Não remova esse quadro) |
HTML |
---|
<div id="text-end"></div>
<!-- Global site tag (gtag.js) - Google Analytics -->
<script async src="https://www.googletagmanager.com/gtag/js?id=UA-193974933-1"></script>
<script>
window.dataLayer = window.dataLayer || [];
function gtag2(){dataLayer.push(arguments);}
gtag2('js', new Date());
gtag2('config', 'UA-193974933-1');
function gtagevents (action,category) {
console.log(category + ':' + action);
gtag2('event',action,{event_category:category,event_label: document.title});
};
</script>
<script src="https://player.vimeo.com/api/player.js"></script>
<script>
(function(){
// RASTREIO DE USO DO VÍDEO
function gtagvideo(action){
gtagevents(action,'Video')
}
var iframe = document.querySelector('iframe');
var player = new Vimeo.Player(iframe);
var seeking = false;
var priorTime = 0;
var currentTime = 0;
var reportouFinalDoConteudo = false;
// se pausar o play é acionado também.
player.on('play', function(data) {
if(data.seconds == 0){
gtagvideo('video-iniciado');
}
priorTime = data.seconds;
});
player.on('ended', function() {
gtagvideo('video-finalizado');
});
//seeking e timeupdate são disparados juntos, logo o tempo dos 2 é atualizado também. Preciso garantir que a variavel starttime seja atualizada ordenadamente (sempre antes ou após o seeking).
// pra isso preciso setar uma variavel no timeupdate e ler no seeking para garantir a ordem. Se ela estiver false será alterada na próxima iteração.
player.on('seeking', function(data) {
seeking = true;
});
player.on('pause',function(data){
gtagvideo('video-pausado');
});
player.on('timeupdate', function(data) {
if(seeking){
if(currentTime < priorTime){
gtagvideo('video-voltando');
}
if(currentTime > priorTime){
gtagvideo('video-avancando')
}
seeking = false;
}
priorTime = currentTime;
currentTime = data.seconds;
var finalDoConteudo = (data.duration - data.seconds) < 5;
if(finalDoConteudo && !reportouFinalDoConteudo){
gtagvideo('conteudo-finalizado')
reportouFinalDoConteudo = true;
}
});
player.on('fullscreenchange', function() {
gtagvideo('video-fullscreen');
});
})();
</script>
<script>
// RASTREIO DO USO DE AUDIO
(function(){
function gtagaudio(action){
gtagevents(action,'Audio')
}
var audio = document.querySelector("audio");
var seeking = false;
var priorTime = 0;
var currentTime = 0;
audio.addEventListener('play',function(){
if(audio.currentTime == 0){
gtagaudio('audio-iniciado');
}
priorTime = audio.currentTime;
});
audio.addEventListener('ended',function(){
gtagaudio('audio-finalizado');
});
audio.addEventListener('pause',function(){
gtagaudio('audio-pausado');
});
audio.addEventListener('seeking', function(data) {
seeking = true;
});
audio.addEventListener('timeupdate', function(data) {
if(seeking){
if(currentTime < priorTime){
gtagaudio('audio-voltando');
}
if(currentTime > priorTime){
gtagaudio('audio-avancando')
}
seeking = false;
}
priorTime = currentTime;
currentTime = audio.currentTime;
});
})();
</script>
<script>
(function(){
var terminou = false;
//RASTREIO DE LEITURA ATÉ O FINAL DA PÁGINA
document.addEventListener('scroll',() => {
if(document.getElementById('text-end').getBoundingClientRect().top < window.innerHeight){
if(!terminou){
terminou = true;
gtagevents('artigo-lido','Pagina')
}
}else{
terminou = false;
}
});
})();
</script>
|
...