Pular para o conteúdo
Odoo Menu
  • Entrar
  • Experimente grátis
  • Aplicativos
    Finanças
    • Financeiro
    • Faturamento
    • Despesas
    • Planilhas (BI)
    • Documentos
    • Assinar Documentos
    Vendas
    • CRM
    • Vendas
    • PDV Loja
    • PDV Restaurantes
    • Assinaturas
    • Locação
    Websites
    • Criador de Sites
    • e-Commerce
    • Blog
    • Fórum
    • Chat ao Vivo
    • e-Learning
    Cadeia de mantimentos
    • Inventário
    • Fabricação
    • PLM - Ciclo de Vida do Produto
    • Compras
    • Manutenção
    • Qualidade
    Recursos Humanos
    • Funcionários
    • Recrutamento
    • Folgas
    • Avaliações
    • Indicações
    • Frota
    Marketing
    • Redes Sociais
    • Marketing por E-mail
    • Marketing por SMS
    • Eventos
    • Automação de Marketing
    • Pesquisas
    Serviços
    • Projeto
    • Planilhas de Horas
    • Serviço de Campo
    • Central de Ajuda
    • Planejamento
    • Compromissos
    Produtividade
    • Mensagens
    • Aprovações
    • Internet das Coisas
    • VoIP
    • Conhecimento
    • WhatsApp
    Aplicativos de terceiros Odoo Studio Plataforma Odoo Cloud
  • Setores
    Varejo
    • Loja de livros
    • Loja de roupas
    • Loja de móveis
    • Mercearia
    • Loja de ferramentas
    • Loja de brinquedos
    Comida e hospitalidade
    • Bar e Pub
    • Restaurante
    • Fast Food
    • Hospedagem
    • Distribuidor de bebidas
    • Hotel
    Imóveis
    • Imobiliária
    • Escritório de arquitetura
    • Construção
    • Administração de propriedades
    • Jardinagem
    • Associação de proprietários de imóveis
    Consultoria
    • Escritório de Contabilidade
    • Parceiro Odoo
    • Agência de marketing
    • Escritório de advocacia
    • Aquisição de talentos
    • Auditoria e Certificação
    Fabricação
    • Têxtil
    • Metal
    • Móveis
    • Alimentação
    • Cervejaria
    • Presentes corporativos
    Saúde e Boa forma
    • Clube esportivo
    • Loja de óculos
    • Academia
    • Profissionais de bem-estar
    • Farmácia
    • Salão de cabeleireiro
    Comércio
    • Handyman
    • Hardware e Suporte de TI
    • Sistemas de energia solar
    • Sapataria
    • Serviços de limpeza
    • Serviços de climatização
    Outros
    • Organização sem fins lucrativos
    • Agência Ambiental
    • Aluguel de outdoors
    • Fotografia
    • Aluguel de bicicletas
    • Revendedor de software
    Navegar por todos os setores
  • Comunidade
    Aprenda
    • Tutoriais
    • Documentação
    • Certificações
    • Treinamento
    • Blog
    • Podcast
    Empodere a Educação
    • Programa de educação
    • Scale Up! Jogo de Negócios
    • Visite a Odoo
    Obtenha o Software
    • Baixar
    • Comparar edições
    • Releases
    Colaborar
    • Github
    • Fórum
    • Eventos
    • Traduções
    • Torne-se um parceiro
    • Serviços para parceiros
    • Cadastre seu escritório contábil
    Obtenha os serviços
    • Encontre um parceiro
    • Encontre um Contador
    • Conheça um consultor
    • Serviços de Implementação
    • Referências de Clientes
    • Suporte
    • Upgrades
    Github YouTube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Faça uma demonstração
  • Preços
  • Ajuda

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Financeiro
  • Inventário
  • PoS
  • Projeto
  • MRP
All apps
É necessário estar registrado para interagir com a comunidade.
Todas as publicações Pessoas Emblemas
Marcadores (Ver tudo)
odoo accounting v14 pos v15
Sobre este fórum
É necessário estar registrado para interagir com a comunidade.
Todas as publicações Pessoas Emblemas
Marcadores (Ver tudo)
odoo accounting v14 pos v15
Sobre este fórum
Ajuda

print purview came empty when I use windows.print()

Inscrever

Seja notificado quando houver atividade nesta publicação

Esta pergunta foi sinalizada
javascriptodoo16
1 Responder
2191 Visualizações
Avatar
ahmed mohamady

I try to add button in POS screen to print a simple HTML code 
And I use this code for this, 

        async _printWeb(receipt) {

            try {

                const receiptContainer = $(this.el).find('.pos-cash-rpt-container');

                receiptContainer.empty();

                receiptContainer.html(receipt);

                await new Promise((resolve) => setTimeout(resolve, 100));

                window.print();

            } catch (_err) {

                await this.showPopup('ErrorPopup', {

                    title: this.env._t('Printing is not supported on some browsers'),

                    body: this.env._t(

                        'Printing is not supported on some browsers due to no default printing protocol ' +

                            'is available. It is possible to print your tickets by making use of an IoT Box.'

                    ),

                });

            }

I check every thing and it's ok but the print preview every time came empty 
can any one help me in this 

0
Avatar
Cancelar
Avatar
S.A. Methsiri Madusanka Sooriyaarachchi
Melhor resposta

The issue you're encountering with the print preview coming up empty might be due to the timing of the window.print() function. The DOM might not be fully rendered or updated when the print command is triggered. Here are a few steps you can take to ensure the HTML content is properly rendered before the print preview is triggered:

Possible Solutions

  1. Ensure the DOM is Fully Updated:
    • Instead of using a simple setTimeout, you can use requestAnimationFrame to ensure that the DOM update has been fully rendered before triggering the print.
    javascriptCopy codeasync _printWeb(receipt) {
        try {
            const receiptContainer = $(this.el).find('.pos-cash-rpt-container');
    
            receiptContainer.empty();
            receiptContainer.html(receipt);
    
            // Wait for the next frame to ensure the DOM is updated
            await new Promise(resolve => requestAnimationFrame(resolve));
    
            window.print();
        } catch (_err) {
            await this.showPopup('ErrorPopup', {
                title: this.env._t('Printing is not supported on some browsers'),
                body: this.env._t(
                    'Printing is not supported on some browsers due to no default printing protocol ' +
                    'is available. It is possible to print your tickets by making use of an IoT Box.'
                ),
            });
        }
    }
    
  2. Force a Reflow Before Printing:
    • Sometimes, forcing a reflow of the document can help ensure that all changes are rendered before printing. You can do this by accessing certain properties (like offsetHeight) that trigger a reflow.
    javascriptCopy codeasync _printWeb(receipt) {
        try {
            const receiptContainer = $(this.el).find('.pos-cash-rpt-container');
    
            receiptContainer.empty();
            receiptContainer.html(receipt);
    
            // Force reflow
            receiptContainer[0].offsetHeight;
    
            await new Promise((resolve) => setTimeout(resolve, 100));
    
            window.print();
        } catch (_err) {
            await this.showPopup('ErrorPopup', {
                title: this.env._t('Printing is not supported on some browsers'),
                body: this.env._t(
                    'Printing is not supported on some browsers due to no default printing protocol ' +
                    'is available. It is possible to print your tickets by making use of an IoT Box.'
                ),
            });
        }
    }
    
  3. Check for Browser Compatibility:
    • Make sure that the browser you're using supports the window.print() function as expected. Sometimes, certain browsers might have issues with printing, especially in a POS environment. Testing on different browsers can help identify if the problem is browser-specific.
  4. Debugging the Receipt Container:
    • Add some logging or debugging to ensure that the receiptContainer.html(receipt) is indeed populating the container with the correct content before printing.
    javascriptCopy codeconsole.log(receipt); // Check if the receipt content is correct
    console.log(receiptContainer.html()); // Check if the container is populated with the content
    

If the print preview continues to show up empty after trying these solutions, you may need to explore alternative approaches to printing, such as using the Odoo IoT Box for more reliable printing in POS environments.

2
Avatar
Cancelar
ahmed mohamady
Autor

thank you it's working

Está gostando da discussão? Não fique apenas lendo, participe!

Crie uma conta hoje mesmo para aproveitar os recursos exclusivos e interagir com nossa incrível comunidade!

Inscreva-se
Publicações relacionadas Respostas Visualizações Atividade
How to add special JavaScript code to a from view
javascript odoo16
Avatar
Avatar
1
set. 24
2184
How to hide "section-financials" from the ProductInfoPopup in POS Screen Resolvido
javascript xml odoo16
Avatar
Avatar
2
jul. 24
2068
how to inherit the BarcodeModel in odoo 16 Resolvido
javascript owl odoo16
Avatar
Avatar
1
set. 24
3559
override method in javascript class class in odoo 16 Resolvido
javascript inheritance odoo16
Avatar
Avatar
Avatar
3
mai. 24
4468
Error While Installing Accounting Module in Odoo 19 Enterprise (Works on Another PC)
javascript
Avatar
0
nov. 25
195
Comunidade
  • Tutoriais
  • Documentação
  • Fórum
Open Source
  • Baixar
  • Github
  • Runbot
  • Traduções
Serviços
  • Odoo.sh Hosting
  • Suporte
  • Upgrade
  • Desenvolvimentos personalizados
  • Educação
  • Encontre um Contador
  • Encontre um parceiro
  • Torne-se um parceiro
Sobre nós
  • Nossa empresa
  • Ativos da marca
  • Contato
  • Empregos
  • Eventos
  • Podcast
  • Blog
  • Clientes
  • Legal • Privacidade
  • Segurança
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo é um conjunto de aplicativos de negócios em código aberto que cobre todas as necessidades de sua empresa: CRM, comércio eletrônico, contabilidade, estoque, ponto de venda, gerenciamento de projetos, etc.

A proposta de valor exclusiva Odoo é ser, ao mesmo tempo, muito fácil de usar e totalmente integrado.

Site feito com

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now