Skip to Content
Odoo Меню
  • Увійти
  • Спробуйте це безкоштовно
  • Додатки
    Фінанси
    • Бухоблік
    • Виставлення рахунку
    • Витрати
    • Електронні таблиці (BI)
    • Документи
    • Підпис
    Продажі
    • CRM
    • Продажі
    • POS Магазин
    • POS Ресторан
    • Підписки
    • Оренда
    Веб-сайти
    • Конструктор веб-сайту
    • Електронна комерція
    • Блог
    • Форум
    • Живий чат
    • Електронне навчання
    Ланцюг поставок
    • Склад
    • Виробництво
    • PLM
    • Купівлі
    • Технічне обслуговування
    • Якість
    Кадри
    • Співробітники
    • Рекрутинг
    • Відпустки
    • Оцінювання
    • Рекомендації
    • Автотранспорт
    Маркетинг
    • Маркетинг соцмереж
    • Email-маркетинг
    • SMS-маркетинг
    • Події
    • Автом. маркетингу
    • Опитування
    Послуги
    • Проект
    • Табелі
    • Виїзне обслуговування
    • Служба підтримки
    • Планування
    • Призначення
    Продуктивність
    • Обговорення
    • Схвалення
    • IoT
    • IP-телефонія
    • База знань
    • WhatsApp
    Сторонні модулі Odoo Studio Платформа Odoo Cloud
  • Сфери
    Роздрібна торгівля
    • Книжковий магазин
    • Магазин одягу
    • Магазин меблів
    • Продуктовий магазин
    • Магазин будівельних матеріалів
    • Магазин іграшок
    Food & Hospitality
    • Бар та паб
    • Ресторан
    • Фастфуд
    • Guest House
    • Дистриб'ютор напоїв
    • Hotel
    Нерухомість
    • Real Estate Agency
    • Архітектурна фірма
    • Будівництво
    • Управління нерухомістю
    • Садівництво
    • Асоціація власників нерухомості
    Консалтинг
    • Бухгалтерська компанія
    • Партнер Odoo
    • Агенція маркетингу
    • Юридична фірма
    • Придбання Талантів
    • Аудит та сертифікація
    Виробництво
    • Textile
    • Metal
    • Меблі
    • Їжа
    • Brewery
    • Корпоративні подарунки
    Здоров'я & Фітнес
    • Спортивний клуб
    • Оптика
    • Фітнес-центр
    • Практики здоров'я
    • Аптека
    • Салон краси
    Trades
    • Ремонтник
    • IT-обладнання та Підтримка
    • Системи сонячної енергії
    • Shoe Maker
    • Cleaning Services
    • HVAC Services
    Інші
    • Nonprofit Organization
    • Екологічна агенція
    • Оренда білбордів
    • Фотографія
    • Лізинг велосипедів
    • Реселлер програмного забезпечення
    Browse all Industries
  • Спільнота
    Навчання
    • Навчальний посібник
    • Документація
    • Сертифікації
    • Тренування
    • Блог
    • Подкаст
    Сприяйте Освіті
    • Програма навчання
    • Бізнес гра Scale Up!
    • Відвідайте Odoo
    Отримайте програмне забезпечення
    • Завантаження
    • Порівняйте версії
    • Релізи
    Співпрацюйте
    • Github
    • Форум
    • Події
    • Переклади
    • Стати партнером
    • Services for Partners
    • Зареєструйте вашу бухгалтерську фірму
    Отримайте послуги
    • Знайдіть партнера
    • Знайдіть бухгалтера
    • Зустріньтеся з консультантом
    • Послуги з впровадження
    • Референси клієнтів
    • Підтримка
    • Оновлення
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Отримати демо
  • Ціни
  • Допомога

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

  • CRM
  • e-Commerce
  • Бухоблік
  • Склад
  • PoS
  • Проект
  • MRP
All apps
Вам необхідно зареєструватися, щоб взаємодіяти зі спільнотою.
All Posts Люди Значки
Мітки (View all)
odoo accounting v14 pos v15
Про цей форум
Вам необхідно зареєструватися, щоб взаємодіяти зі спільнотою.
All Posts Люди Значки
Мітки (View all)
odoo accounting v14 pos v15
Про цей форум
Допомога

Client Action using Owl Component - how do I get the control panel to show?

Підписатися

Отримуйте сповіщення про активність щодо цієї публікації

Це запитання позначене
owlv14
9832 Переглядів
Аватар
kevin lall

Hi there, I am currently using Odoo 14 to try out the Owl framework, I am able to get my component to work via the client action with the ComponentWrapper.

my question is how do I get the control panel to show (breadcrumbs, search view)

I spend a few days trying to figure this out, I went over example code in Odoo I am pretty much stuck


here is my code 


odoo.define("todo", function (require) {

  "use strict";


  const AbstractAction = require("web.AbstractAction");

  const {

    ComponentWrapper,

    WidgetAdapterMixin,

  } = require("web.OwlCompatibility");

  const core = require("web.core");


  const { Component, tags } = owl;

  const { useRef, useState } = owl.hooks;


  class Task extends Component {

    toggleTask() {

      this.trigger("toggle-task", { id: this.props.task.id }); 

    }


    deleteTask() {

      this.trigger("delete-task", { id: this.props.task.id });

    }

  }

  Task.template = tags.xml`

  <div class="task" t-att-class="props.task.isCompleted ? 'done' : ''">

    <input type="checkbox" t-att-checked="props.task.isCompleted" t-on-click="toggleTask"/>

    <span><t t-esc="props.task.title"/></span>

    <span class="delete" t-on-click="deleteTask">🗑</span>

  </div>

  `;

  Task.props = ["task"];


  class Todo extends Component {

    constructor() {


      super(...arguments);

    }


    tasks = useState([]);

    inputRef = useRef("add-input");


    mounted() {

      this.inputRef.el.focus();

    }


    async willStart() {

      const fields = ["id", "name", "completed"];

      const tasks = await this.env.services.rpc({

        model: "todo",

        method: "search_read",

        kwargs: {

          fields,

        },

      });

      tasks.map((task) =>

        this.tasks.push({

          id: task.id,

          title: task.name,

          isCompleted: task.completed,

        })

      );

    }


    async addTask(ev) {

      // 13 is keycode for ENTER

      if (ev.keyCode === 13) {

        const title = ev.target.value.trim();

        ev.target.value = "";

        if (title) {

          const newTask = await this.env.services.rpc({

            model: "todo",

            method: "create",

            args: [

              {

                name: title,

                completed: false,

              },

            ],

          });

          this.tasks.push({

            id: newTask,

            title: title,

            isCompleted: false,

          });

        }

      }

    }


    async toggleTask(ev) {

      const task = this.tasks.find((t) => t.id === ev.detail.id);

      task.isCompleted = !task.isCompleted;

      await this.env.services.rpc({

        model: "todo",

        method: "write",

        args: [

          [task.id],

          {

            completed: task.isCompleted,

          },

        ],

      });

    }


    async deleteTask(ev) {

      const index = this.tasks.findIndex((t) => t.id === ev.detail.id);

      this.tasks.splice(index, 1);

      await this.env.services.rpc({

        model: "todo",

        method: "unlink",

        args: [[ev.detail.id]],

      });

    }

  }


  Todo.components = { Task };


  Todo.template = tags.xml`

    <div>

      <div class="o_form_view">

        <div class="o_form_sheet_bg">

          <div class="o_form_sheet">

            <div class="todo-app">

              <input placeholder="Enter a new task" t-on-keyup="addTask" t-ref="add-input"/>

              <div class="task-list" t-on-toggle-task="toggleTask" t-on-delete-task="deleteTask">

                <t t-foreach="tasks" t-as="task" t-key="task.id">

                  <Task task="task"/>

                </t>

              </div>

            </div>

          </div>

        </div>

      </div>

    </div>

  `;


  const ClientAction = AbstractAction.extend(WidgetAdapterMixin, {

    start() {

      const component = new ComponentWrapper(this, Todo);

      return component.mount(this.el.querySelector(".o_content"));

    },

  });


  core.action_registry.add("todo_client_action", ClientAction);

  return ClientAction;

});


I am calling the action from a button 

def open_client_action(self):
print('open action called')
return {
'res_model': 'todo',
'type': 'ir.actions.client',
'tag': 'todo_client_action',
}




0
Аватар
Відмінити
Enjoying the discussion? Don't just read, join in!

Create an account today to enjoy exclusive features and engage with our awesome community!

Реєстрація
Related Posts Відповіді Переглядів Дія
How can i extend constructor of a class in odoo14?
javascript owl v14
Аватар
0
жовт. 22
571
Inherit OWL JS
js owl v14
Аватар
Аватар
1
серп. 21
5314
How to define a qweb template in owl (Odoo14)
qweb template view owl v14
Аватар
0
трав. 21
4863
How to replace JS class in Odoo 14?
JS owl v14
Аватар
0
груд. 20
4621
Odoo14 alternative for Automated Translations through Gengo API module
v14
Аватар
Аватар
Аватар
Аватар
3
вер. 25
3586
Спільнота
  • Навчальний посібник
  • Документація
  • Форум
Open Source
  • Завантаження
  • Github
  • Runbot
  • Переклади
Послуги
  • Хостинг Odoo.sh
  • Підтримка
  • Оновлення
  • Кастомні доробки
  • Навчання
  • Знайдіть бухгалтера
  • Знайдіть партнера
  • Стати партнером
Про нас
  • Наша компанія
  • Торгові активи
  • Зв'яжіться з нами
  • Вакансії
  • Події
  • Подкаст
  • Блог
  • Клієнти
  • Юридичні документи • Конфіденційність
  • Безпека
الْعَرَبيّة 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 - це набір програм для роботи з відкритим кодом, які охоплюють всі ваші потреби компанії: CRM, електронна комерція, бухгалтерський облік, склад, точка продажу, управління проектами тощо.

Унікальна пропозиція Odoo - це одночасно дуже проста у використанні та повністю інтегрована.

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