description | tags | prev | |
---|---|---|---|
Odoo mühelos anpassen und erweitern. |
|
./ |
{{ $frontmatter.description }}
Bereich | Beschreibung |
---|---|
Entwicklung Aktionen | Eigene Odoo Aktionen erstellen. |
Entwicklung Ansichten | Odoo Ansichten anpassen. |
Entwicklung QWeb-Berichte | Eigene Berichte mit QWeb erstellen. |
Entwicklung Snippets | Einfache Anpassungen mit den Mint System Snippets umsetzen. |
Erweiterung | Beschreibung |
---|---|
BI SQL Editor | Ganz einfach SQL-basierte Berichte erstellen. |
Mass Editing | Mühelos mehrere Einträge auf einmal bearbeiten. |
Mass Operation Abstract | Bietet Werkzeuge zur Massenbearbeitung. |
Onchange Helper | Vereinfacht den Aufruf von Onchange-Methoden im Python Code. |
Project timeline | Timeline-Ansicht für Projektaufgaben. |
Prometheus Exporter | Odoo-Metriken mit Prometheus monitoren. |
Report XLSX | Klasse zur Enwicklung von XLSX-Berichten. |
Server Environment Ir Config Parameter | Systemparameter aus Umgebungsvariablen laden. |
Server Environment | Systemkonfigurationen aus Umgebungsvariablen laden. |
Web Domain Field | Dynamische Definitionen für Domain-Attribute auf Felder generieren. |
Web Environment Ribbon | Odoo Umgebung mit Banner markieren. |
Web Timeline | Die Timeline-Ansicht für alle Objekte. |
Öffnen Sie Einstellungen > Technisch > Parameter > Systemparameter und erstellen einen Eintrag mit Schlüssel und Wert.
Damit Software von Dritten Zugriff auf die Daten von Odoo hat, ohne dass dabei das Passwort eines Benutzers geteilt werden muss, kann man einen Zugriffsschlüssel bereitstellen.
Öffenen Sie die Sicherheitseinstellungen des eingeloggten Benutzers Menu > Mein Profil > Tab Acccount Security und klicken auf New API Key.
Wird Odoo im Browser angezeigt, werden sog. Assets im Hintergrund geladen (JavaScript-, SCSS- und CSS-Dateien). Diese Assets können nach einem Odoo-Update veraltet sein und müss neu generiert werden. Wählen Sie Entwicklertool > Bündel von Assets regenerieren.
Navigieren Sie nach Einstellungen > Entwicklertools und klicken Sie auf Demo Daten laden um die Daten in die aktuelle Datenbank zu laden.
Rufen Sie die Einstellungen auf und scrollen Sie auf der Ansicht nach ganz unten. Beim Abschnitt Über finden Sie Angaben zur Odoo Revision.
Im Entwicklermodus navigieren Sie nach Einstellungen > Technisch > Benutzer-Interface > Menüeinträge. Erstellen Sie einen Filter Obermenü mit dem Wert ist nicht gesetzt. Nun können Sie die Menüeinträge mit dem Handler in der Liste anordnen.
Im Entwicklermodus können Sie ganz einfach Menüeinträge umbennen. Angenommen Sie möchten diesen Punkt umbennen:
Gehen Sie wie folgt vor. Navigieren Sie nach Einstellungen > Technisch > Benutzer-Interface > Menüeinträge und suchen Sie nach Alle Angestellte. Bearbeiten Sie den Eintrag und setzen Sie für das Feld Menü einen neuen Wert.
Nachdem Sie den Browser-Tab aktualisiert haben, ist der Menüeintrag umbenannt.
Öffnen Sie Einstellungen > Technisch > Benutzer-Interface > Menüeinträge und wählen Sie Anlegen.
Öffnen Sie Einstellungen > Technisch > Benutzer-Interface > Menüeinträge und wählen Sie ein bestehenden Menüeintrag aus. Bearbeiten Sie die Sichtbarkeit des Menüs im Tab Zugriffsrechte oder steuern Sie die Reihenfolge der Untermenüs im Tab Untermenüs.
::: Bei einer Aktualisierung der Odoo App, werden die verlinkten Menüeinträge zurückgesetzt. :::
Öffnen Sie Einstellungen > Technisch > Benutzer-Interface > Menüeinträge und suchen Sie den entsprechende Menüeintrag. Markieren Sie diesen und wählen Sie Aktion > Löschen oder Aktion > Archiv.
::: warning Diese Vorgang kann die Integrität und Verüfgbarkeit des Systems beeiträchitgen. Führen Sie die Aktion nur aus, wenn Sie sich den möglichen Auswirkungen bewusst sind. :::
Öffnen Sie Einstellungen > Technisch > Datenbankstruktur > Datenmodelle und suchen Sie das entsprechende Datenmodell. Markieren Sie diesen und wählen Sie Aktion > Löschen.
::: warning Diese Vorgang kann die Integrität und Verüfgbarkeit des Systems beeiträchitgen. Führen Sie die Aktion nur aus, wenn Sie sich den möglichen Auswirkungen bewusst sind. :::
Für jedes Geschäftsobjekt können Sie in der Einzelansicht die Metadaten anzeigen. Rufen Sie ein Odoo-Objekt im Entwicklermodus auf, beispielsweise einen Benutzer und klicken Sie auf Entwicklertools > Metadaten anzeigen.
Odoo speichert alle externen IDs in einer Tabelle. Öffnen Sie Einstellungen > Technisch > Sequenzen- und Identifizierungsmerkmale > Externe Identifikationen.
Zeigen Sie einen beliebigen Datensatz in der Formularansicht an. Als Beispiel verwenden wir eine Ansicht. Entnehmen Sie anhand der Url die ID und das Datenmodell.
/web#id=1639&action=28&model=ir.ui.view&view_type=form&cids=1&menu_id=4
Navigieren Sie nun nach Einstellungen > Technisch > Sequenzen- und Identifizierungsmerkmale > Externe Identifikationen und legen Sie einen Eintrag an:
- Modul: Technischer Name des Odoo-Moduls
- Externe Identifikation: Eindeutiger Bezeichner
- Modellname: Angabe Gemäss Url
- Datensatz-ID: Angabe Gemäss Url
Dazu die Angaben aus dem Beispiel:
Ist die Externe Identifikation gespeichert, wird Sie auf Datensatz angezeigt.
An jedem Objekt kann an einfach ein Feld hinzugefügt werden. Öffnen Sie eine Ansicht im Entwicklermodus und wählen Sie Entwicklertools > Felder anzeigen. Wählen Sie + Anlegen und geben Sie folgende Informationen ein:
- Feldname: Beginnt mit
x_
und darf keine Leerschläge enthalten und sollte kleingeschrieben und auf Englisch sein. - Feldbezeichnung: Passender Name in der angezeigten Sprache.
- Typfeld-Text: Auswahls den Felddatentyps.
Dazu ein Beispiel mit Abwesenheit:
Wir nehmen an, dass Sie auf der Lagerbechnung ein berechnetes Feld benötigen. Dieses Feld soll die Anzahl Kisten berechnen, die es braucht um das Produkt zu verpacken. Immer wenn die Erledigte Menge ändert, soll das Feld berechnet werden.
Erstellen Sie ein neues Feld unter Einstellungen > Technisch > Datenbankstruktur > Felder mit diesen Attributen:
- Feldname:
x_count_boxes
- Feldbezeichnung: Anzahl Kisten
- Modell: Lagerbuchung (technischer Name ist
stock.move
) - Typfeld-Text: Ganzzahl
- Basiseigenschaften:
- Nur Lesen
- Gespeichert
- Abhängigkeiten:
quantity_done
- Berechnen:
for rec in self:
if rec.product_packaging:
if rec.product_packaging.name == "Schale":
rec['x_count_boxes'] = (rec.quantity_done + 2.4)/2.5
if rec.product_packaging.name == "Kiste":
rec['x_count_boxes'] = (rec.quantity_done + 9)/10
Dieser Code berechnet abhängig von der gewählten Verpackung und deren Füllmenge die Anzahl Kisten. Mit Python-Code können Sie natürlich jegliche Logik für die Berechnung entwickeln.
Wir nehmen an, dass Sie auf der Auftragsposition ein Beziehungs-Feld benötigen. Dieses Feld soll die Kundenreferenz auf dem zugehörigen Verkaufsauftrag anzeigen.
Erstellen Sie ein neues Feld unter Einstellungen > Technisch > Datenbankstruktur > Felder mit diesen Attributen:
- Feldname:
x_client_order_ref
- Feldbezeichnung: Kundenreferenz
- Modell: Auftragsposition (technischer Name ist
sale.order.line
) - Typfeld-Text: Text
- Basiseigenschaften:
- Nur Lesen
- Gespeichert
- Beziehungs-Feld:
order_id.client_order_ref
Dieses Feld können Sie nun in Berichten oder Listenansichten anzeigen.
Sie können den Zugriff für benutzerdefinierte Felder einschränken. Dazu müssen Sie ein Snippet hinzufügen, welches auf der ausgewählten Ansicht auf dem Feld das Attribut groups
festlegt. Als Wert geben Sie die externe ID der Benutzergruppe an, welche Zugriff haben soll. Dazu ein Beispiel:
<?xml version="1.0"?>
<data inherit_id="hr_holidays.hr_leave_view_tree">
<xpath expr="//field[@name='state']" position="after">
<field name="x_synced" widget="toggle_button" groups="hr.group_hr_user"/>
</xpath>
</data>