Overslaan naar inhoud
Odoo Menu
  • Aanmelden
  • Probeer het gratis
  • Apps
    Financiën
    • Boekhouding
    • Facturatie
    • Onkosten
    • Spreadsheet (BI)
    • Documenten
    • Ondertekenen
    Verkoop
    • CRM
    • Verkoop
    • Kassasysteem winkel
    • Kassasysteem Restaurant
    • Abonnementen
    • Verhuur
    Websites
    • Websitebouwer
    • E-commerce
    • Blog
    • Forum
    • Live Chat
    • eLearning
    Bevoorradingsketen
    • Voorraad
    • Productie
    • PLM
    • Inkoop
    • Onderhoud
    • Kwaliteit
    Personeelsbeheer
    • Werknemers
    • Werving & Selectie
    • Verlof
    • Evaluaties
    • Aanbevelingen
    • Wagenpark
    Marketing
    • Social media Marketing
    • E-mailmarketing
    • SMS Marketing
    • Evenementen
    • Marketingautomatisering
    • Enquêtes
    Diensten
    • Project
    • Urenstaten
    • Buitendienst
    • Helpdesk
    • Planning
    • Afspraken
    Productiviteit
    • Chat
    • Goedkeuringen
    • IoT
    • VoIP
    • Kennis
    • WhatsApp
    Apps van derden Odoo Studio Odoo Cloud Platform
  • Bedrijfstakken
    Detailhandel
    • Boekhandel
    • kledingwinkel
    • Meubelzaak
    • Supermarkt
    • Bouwmarkt
    • Speelgoedwinkel
    Food & Hospitality
    • Bar en Pub
    • Restaurant
    • Fastfood
    • Gastenverblijf
    • Drankenhandelaar
    • Hotel
    Vastgoed
    • Makelaarskantoor
    • Architectenbureau
    • Bouw
    • Vastgoedbeheer
    • Tuinieren
    • Vereniging van eigenaren
    Consulting
    • Accountantskantoor
    • Odoo Partner
    • Marketingbureau
    • Advocatenkantoor
    • Talentenwerving
    • Audit & Certificering
    Productie
    • Textiel
    • Metaal
    • Meubels
    • Eten
    • Brewery
    • Relatiegeschenken
    Gezondheid & Fitness
    • Sportclub
    • Opticien
    • Fitnesscentrum
    • Wellness-medewerkers
    • Apotheek
    • Kapper
    Trades
    • Klusjesman
    • IT-hardware & support
    • Zonne-energiesystemen
    • Schoenmaker
    • Schoonmaakdiensten
    • HVAC-diensten
    Andere
    • Non-profitorganisatie
    • Milieuagentschap
    • Verhuur van Billboards
    • Fotograaf
    • Fietsleasing
    • Softwareverkoper
    Browse all Industries
  • Community
    Leren
    • Tutorials
    • Documentatie
    • Certificeringen
    • Training
    • Blog
    • Podcast
    Versterk het onderwijs
    • Onderwijs- programma
    • Scale Up! Business Game
    • Bezoek Odoo
    Download de Software
    • Downloaden
    • Vergelijk edities
    • Releases
    Werk samen
    • Github
    • Forum
    • Evenementen
    • Vertalingen
    • Word een Partner
    • Services for Partners
    • Registreer je accountantskantoor
    Diensten
    • Vind een partner
    • Vind een boekhouder
    • Een adviseur ontmoeten
    • Implementatiediensten
    • Klantreferenties
    • Ondersteuning
    • Upgrades
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Vraag een demo aan
  • Prijzen
  • Help

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

  • CRM
  • e-Commerce
  • Boekhouding
  • Voorraad
  • PoS
  • Project
  • MRP
All apps
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Je moet geregistreerd zijn om te kunnen communiceren met de community.
Alle posts Personen Badges
Labels (Bekijk alle)
odoo accounting v14 pos v15
Over dit forum
Help

How to create a new module and iframe inside each menu?

Inschrijven

Ontvang een bericht wanneer er activiteit is op deze post

Deze vraag is gerapporteerd
newmoduleiframeodoo16features
1 Beantwoorden
48776 Weergaven
Avatar
Jeffrey

Hi Guys,

I am trying to create a new module, which will have different menus, inside different menus, different iframe will be appeared.

This is my code which is not working, can anybody tell me the correct way to get what I want? Thank you!

PS: wasn't able to paste my current code here properly, command/image/link are not working, please help.

update 1:

I successfully added the iframe under the menu now, but every time I select to another module and then go back to the iframe under the menu, it will refresh, how to make iframe remember the status during switching modules? Thanks.

​​
​​​ ​

0
Avatar
Annuleer
Avatar
LandLogic IT s.n.c.
Beste antwoord

To create a new Odoo module with different menus containing iframes, follow these steps. Additionally, we'll address how to maintain the iframe state during module switches.

1. Module Creation Basics

a. Folder Structure

Create the following directory structure for your custom module:

custom_module/
├── __init__.py
├── __manifest__.py
├── models/
│   ├── __init__.py
├── views/
│   ├── custom_module_views.xml
│   ├── custom_module_menus.xml

2. Define __manifest__.py

This file specifies the metadata for your module:

{
    'name': 'Custom Iframe Module',
    'version': '16.0.1.0',
    'summary': 'A module to add menus with iframes',
    'description': 'This module adds menus that display specific iframes.',
    'author': 'Your Name',
    'website': 'https://yourwebsite.com',
    'category': 'Custom',
    'depends': ['base'],
    'data': [
        'views/custom_module_menus.xml',
        'views/custom_module_views.xml',
    ],
    'installable': True,
    'application': True,
    'license': 'LGPL-3',
}

3. Add Menus in custom_module_menus.xml

Define menus and link them to actions for the iframe views:

<odoo>
    <menuitem id="menu_custom_module" name="Custom Module" sequence="10" />
    <menuitem id="menu_iframe_1" name="Iframe 1" parent="menu_custom_module" action="action_iframe_1" sequence="20" />
    <menuitem id="menu_iframe_2" name="Iframe 2" parent="menu_custom_module" action="action_iframe_2" sequence="30" />
</odoo>

4. Define Views with Iframes in custom_module_views.xml

Here’s an example of how to embed iframes:

<odoo>
    <!-- Action for Iframe 1 -->
    <record id="action_iframe_1" model="ir.actions.act_window">
        <field name="name">Iframe 1</field>
        <field name="res_model">custom.module.iframe</field>
        <field name="view_mode">form</field>
        <field name="target">inline</field>
        <field name="context">{'iframe_url': 'https://example.com/page1'}</field>
    </record>

    <!-- Action for Iframe 2 -->
    <record id="action_iframe_2" model="ir.actions.act_window">
        <field name="name">Iframe 2</field>
        <field name="res_model">custom.module.iframe</field>
        <field name="view_mode">form</field>
        <field name="target">inline</field>
        <field name="context">{'iframe_url': 'https://example.com/page2'}</field>
    </record>

    <!-- Form View to Display the Iframe -->
    <record id="view_custom_module_form" model="ir.ui.view">
        <field name="name">custom.module.form</field>
        <field name="model">custom.module.iframe</field>
        <field name="arch" type="xml">
            <form>
                <sheet>
                    <iframe style="width: 100%; height: 800px;" src="javascript:void(0);" t-att-src="context.get('iframe_url')"/>
                </sheet>
            </form>
        </field>
    </record>
</odoo>

5. Define the Model in models/__init__.py

For a simple iframe display, you don’t need a complex model, but you can define a dummy model:

from . import models

6. Handle State Persistence

By default, the iframe will refresh when navigating back to its menu. To preserve its state:

  1. Use Local Storage in JavaScript: Extend the web client to save and restore the iframe state.
    Create a file static/src/js/custom_iframe.js:
    odoo.define('custom_module.iframe_state', function (require) {
        "use strict";
    
        const AbstractAction = require('web.AbstractAction');
    
        const CustomIframe = AbstractAction.extend({
            start: function () {
                const iframeElement = this.$('iframe');
                const urlKey = this.context.iframe_url;
    
                // Restore saved state
                const savedState = localStorage.getItem(urlKey);
                if (savedState) {
                    iframeElement.attr('src', savedState);
                }
    
                // Save state on navigation
                iframeElement.on('load', function () {
                    localStorage.setItem(urlKey, iframeElement.attr('src'));
                });
    
                return this._super.apply(this, arguments);
            }
        });
    
        return CustomIframe;
    });
    
  2. Include the Script in the Manifest: Add this JavaScript file to the module’s assets:
    'assets': {
        'web.assets_backend': [
            'custom_module/static/src/js/custom_iframe.js',
        ],
    },
    

7. Restart and Install the Module

  1. Restart your Odoo server:
    sudo service odoo restart
    
  2. Go to Apps, update the app list, and install the module.

8. Test and Debug

  • Navigate to the custom menus and confirm the iframes display the correct content.
  • Switch between modules and ensure the iframe remembers its state.

With this implementation, you have a scalable and stateful iframe module in Odoo 16.

0
Avatar
Annuleer
Geniet je van het gesprek? Blijf niet alleen lezen, doe ook mee!

Maak vandaag nog een account aan om te profiteren van exclusieve functies en deel uit te maken van onze geweldige community!

Aanmelden
Gerelateerde posts Antwoorden Weergaven Activiteit
How to write Token into cookie in <iframe>
token iframe OWL odoo16features
Avatar
0
mrt. 23
2694
Issue of new module now showing
development newmodule windows11 odoo16features
Avatar
Avatar
2
jan. 24
4093
DeprecationWarning: The longpolling-port is a deprecated alias to the gevent-port option, please use the latter Opgelost
odoo16features
Avatar
Avatar
Avatar
Avatar
Avatar
5
sep. 25
24416
How to Add wizard under print button inside the form view.
odoo16features
Avatar
Avatar
Avatar
Avatar
3
aug. 25
3730
How to add @api.onchange in _get_view() method odoo 16
odoo16features
Avatar
Avatar
1
mei 25
3623
Community
  • Tutorials
  • Documentatie
  • Forum
Open Source
  • Downloaden
  • Github
  • Runbot
  • Vertalingen
Diensten
  • Odoo.sh Hosting
  • Ondersteuning
  • Upgrade
  • Gepersonaliseerde ontwikkelingen
  • Onderwijs
  • Vind een boekhouder
  • Vind een partner
  • Word een Partner
Over ons
  • Ons bedrijf
  • Merkelementen
  • Neem contact met ons op
  • Vacatures
  • Evenementen
  • Podcast
  • Blog
  • Klanten
  • Juridisch • Privacy
  • Beveiliging
الْعَرَبيّة 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 is een suite van open source zakelijke apps die aan al je bedrijfsbehoeften voldoet: CRM, E-commerce, boekhouding, inventaris, kassasysteem, projectbeheer, enz.

Odoo's unieke waardepropositie is om tegelijkertijd zeer gebruiksvriendelijk en volledig geïntegreerd te zijn.

Website made with

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