Перейти к содержимому
Odoo Меню
  • Войти
  • Попробовать бесплатно
  • Модули
    Финансы
    • Бухгалтерия
    • Выставление счетов
    • Расходы
    • Таблицы
    • Документооборот
    • Подпись
    Продажи
    • CRM
    • Продажи
    • POS Магазин
    • POS Ресторан
    • Подписки
    • Аренда
    Вебсайты
    • Конструктор вебсайтов
    • eCommerce
    • Блог
    • Форум
    • Онлайн-чат
    • Электронное обучение
    Логистика
    • Склад
    • Производство
    • PLM
    • Закупки
    • Обслуживание
    • Качество
    Отдел кадров
    • Сотрудники
    • Подбор персонала
    • Отпуска
    • Оценка персонала
    • Реферальная программа
    • Автопарк
    Маркетинг
    • SMM
    • E-mail рассылки
    • СМС рассылки
    • Мероприятия
    • Автоматизация маркетинга
    • Опросы
    Услуги
    • Проекты
    • Табели
    • Выездной сервис
    • Поддержка
    • Планирование
    • Встречи
    Продуктивность
    • Обсуждения
    • Согласование
    • IoT
    • VoIP-телефония
    • Knowledge
    • WhatsApp
    Сторонние приложения Модуль Студия Odoo Платформа Odoo Cloud
  • Индустрии
    Розничная торговля
    • Книжный магазин
    • Магазин одежды
    • Мебельный магазин
    • Продуктовый магазин
    • Строительный магазин
    • Магазин игрушек
    Гостинично-ресторанный бизнес
    • Бар и паб
    • Ресторан
    • Фастфуд
    • Гостевой дом
    • Дистрибьютор напитков
    • Отель
    Недвижимость
    • Агентство недвижимости
    • Архитектурное бюро
    • Строительство
    • Управление недвижимостью
    • Ландшафтный дизайн
    • Товарищество собственников жилья
    Консалтинг
    • Бухгалтерская фирма
    • Партнер Odoo
    • Маркетинговое агентство
    • Юридическая фирма
    • Подбор персонала
    • Аудиторское бюро
    Производство
    • Текстиль
    • Металл
    • Мебель
    • Продукты питания
    • Пивоварня
    • Корпоративные сувениры
    Здоровье и фитнес
    • Спортивный комплекс
    • Магазин оптики
    • Фитнес-клуб
    • Велнес-центр
    • Аптека
    • Салон красоты
    Услуги
    • Специалист по бытовым услугам
    • Продажа и обслуживание IT-оборудования
    • Солнечные энергосистемы
    • Производство обуви
    • Клининг
    • Системы ОВКВ
    Прочее
    • Некоммерческая организация
    • Консалтинг в сфере устойчивого развития
    • Аренда рекламных щитов
    • Бизнес по фотосъемке
    • Прокат велосипедов
    • Реселлер программного обеспечения
    Все индустрии
  • Community
    Обучение
    • Видео уроки
    • Документация
    • Сертификация
    • Тренинг
    • Блог
    • Подкаст
    Образование и развитие
    • Образовательная программа
    • Деловая игра Scale Up!
    • Экскурсия в офис Odoo
    ПО
    • Скачать
    • Сравнить версии
    • Релизы
    Сотрудничество
    • Github
    • Форум
    • Мероприятия
    • Перевод
    • Стать партнером
    • Услуги для партнеров
    • Зарегистрировать бухгалтерскую фирму
    Услуги
    • Найти партнера
    • Найти бухгалтера
    • Встреча с экспертом
    • Услуги по внедрению
    • Отзывы клиентов
    • Поддержка
    • Обновления
    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
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Помощь

Issue with understanding how Owl template integrate in odoo 14

Подписаться

Получайте уведомления о появлении активности в этом посте

Этот вопрос был отмечен
javascriptdevelopmentowlodooV14
1 Ответить
1593 Представления
Аватар
Daniel Palumbo

Hello,

I am fairly new to developing on odoo with owl. I am currently working on a project that use odoo 14 and owl 1.4


I am trying to implement a component that will render in a page renderer by the backend controller. I have this timeline.js file


odoo.define('my_module.My2ChildTimeline', ['web.ajax'], function (require) {
"use strict";

const { Component } = owl;
const { useState, onWillStart, onMounted } = owl.hooks;
const ajax = require("web.ajax");

/**
* ChildTimeline component for displaying a timeline of records related to a specific child.
*/
class ChildTimeline extends Component {

setup() {
...

onWillStart(async () => {
try {
console.info("Loading initial records for ChildTimeline"); // Debug
await this.loadMore();
} catch (error) {
console.error("Error loading initial records:", error);
this.state.loading = false;
}
});

onMounted(() => {
window.addEventListener('scroll', this.onScroll.bind(this));
});
}

onScroll() {
const nearBottom = window.innerHeight + window.scrollY >= document.body.offsetHeight - 100;
if (!this.state.loading && this.state.hasMoreRecords && nearBottom) {
this.loadMore();
}
}

async loadMore() {
this.state.loading = true;

const res = await ajax.jsonRpc(`/somewhere`, "call", {
offset: this.state.offset,
limit: this.state.limit,
});
console.info("Loaded more records:", res); // Debug

const tempDiv = document.createElement('div');
tempDiv.innerHTML = res.html;

const newItems = [...tempDiv.children];
const container = this.el.querySelector('.timeline-list');

if (container) {
newItems.forEach(el => container.appendChild(el));
}

this.state.offset += this.state.limit;
this.state.hasMoreRecords = res.has_more_records;
this.state.loading = false;
}
};

ChildTimeline.template = "my_module.My2ChildTimelineComponent";

// Mount immediately when DOM is ready
if (document.getElementById("timeline-root")) {
const dataScript = document.getElementById("timeline-data");
const props = JSON.parse(dataScript.textContent);

owl.mount(ChildTimeline, {
target: document.getElementById("timeline-root"),
props,
});
}

return ChildTimeline;
});

and an xml component

<templates xml:space="preserve">
<t t-name="my_module.My2ChildTimelineComponent" owl="1">
<div class="timeline-list">
<t t-foreach="state.records" t-as="record" t-key="record.id">
<div class="timeline-card d-flex">
<t t-if="record.model == 'sponsorship_gift'">
<My2ChildTimelineRecordGiftComponent record="record"/>
</t>
<t t-elif="record.model == 'correspondence'">
<My2ChildTimelineRecordCorrespondenceComponent record="record"/>
</t>
<t t-else="">
<div>This record type is not supported in the timeline.</div>
</t>
</div>
</t>

<t t-if="state.loading">
<div class="text-center py-2">Loading more...</div>
</t>
</div>
</t>
</templates>


The script will be called in a my2_child_timeline.xml page

...
<div class="mb-3">
<div id="timeline-root">
<script type="application/json" id="timeline-data">
<t t-raw="json.dumps({
'child_id': child.id,
'records': records,
'pageable': pageable,
})"/>
</script>
<script type="module" src="/my_module/static/src/components/timeline/My2ChildTimeline.js"></script>
</div>
</div>
...


The issue is that it does not find the My2ChildTimelineComponent and I cannot figure it out what is the issue. Is there somebody who could help me?



0
Аватар
Отменить
Daniel Palumbo
Автор

Thanks for sharing! It got better but I had to change a few things like 

odoo.__ready.then

does not exist in odoo 14. But I got over it and unfortunately the template is recognized but not used by the system. There is another underlying problem. After so many hours spend on it, I talked to my senior and we decided to go vanilla js for our use case and maybe later go back to owl as we will upgrade to odoo 17 probably

Thanks anyway!

Аватар
D Enterprise
Лучший ответ

Hii,


Here is updated code 


my_module/views/timeline_templates.xml


<odoo>

  <!-- Register the template -->

  <template id="My2ChildTimelineComponent">

    <t t-name="my_module.My2ChildTimelineComponent" owl="1">

      <div class="timeline-list">

        <t t-if="state.loading">

          <div class="text-center py-2">Loading more...</div>

        </t>

      </div>

    </t>

  </template>

</odoo>


Update __manifest__.py

Make sure this is included:


'qweb': [

    'views/timeline_templates.xml',

],


JavaScript Component


odoo.define('my_module.My2ChildTimeline', function (require) {

    "use strict";


    const { Component } = owl;

    const { useState, onWillStart, onMounted } = owl.hooks;

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


    class ChildTimeline extends Component {

        setup() {

            this.state = useState({

                loading: false,

                offset: 0,

                limit: 10,

                hasMoreRecords: true,

            });


            onWillStart(() => this.loadMore());

            onMounted(() => window.addEventListener('scroll', this.onScroll.bind(this)));

        }


        async loadMore() {

            this.state.loading = true;

            const res = await ajax.jsonRpc(`/somewhere`, "call", {

                offset: this.state.offset,

                limit: this.state.limit,

            });


            const container = this.el.querySelector('.timeline-list');

            const tempDiv = document.createElement('div');

            tempDiv.innerHTML = res.html;

            [...tempDiv.children].forEach(el => container.appendChild(el));


            this.state.offset += this.state.limit;

            this.state.hasMoreRecords = res.has_more_records;

            this.state.loading = false;

        }


        onScroll() {

            const nearBottom = window.innerHeight + window.scrollY >= document.body.offsetHeight - 100;

            if (!this.state.loading && this.state.hasMoreRecords && nearBottom) {

                this.loadMore();

            }

        }

    }


    ChildTimeline.template = "my_module.My2ChildTimelineComponent";


    odoo.__ready.then(() => {

        const target = document.getElementById("timeline-root");

        const script = document.getElementById("timeline-data");


        if (target && script) {

            const props = JSON.parse(script.textContent);

            owl.mount(ChildTimeline, { target, props });

        }

    });


    return ChildTimeline;

});


In views/assets.xml:

<odoo>

  <template id="assets_frontend" inherit_id="web.assets_frontend" name="Timeline Assets">

    <xpath expr="." position="inside">

      <script type="module" src="/my_module/static/src/components/timeline/My2ChildTimeline.js"/>

    </xpath>

  </template>

</odoo>

And include assets.xml in __manifest__.py under data.


i hope it is use full

0
Аватар
Отменить
Не оставайтесь в стороне – присоединяйтесь к обсуждению!

Создайте аккаунт сегодня, чтобы получить доступ к эксклюзивным функциям и стать частью нашего замечательного сообщества!

Регистрация
Похожие посты Ответы Просмотры Активность
How can I use my only web url domain using odoo?
javascript development
Аватар
Аватар
1
сент. 25
1388
How to Load Related Many2Many Data (pos.ticket.type) into the Frontend?
javascript development
Аватар
0
июн. 25
1743
Odoo 18 POS - Discount Button Group Permissions Not Working
javascript development
Аватар
Аватар
2
июн. 25
1928
¿Cómo puedo crear un Dashboard con KPIs y gráficos con Chart.js?
javascript development
Аватар
0
апр. 25
1915
Odoo icon change Решено
javascript development
Аватар
Аватар
2
янв. 25
2452
Сообщество
  • Видео уроки
  • Документация
  • Форум
Открытый исходный код
  • Скачать
  • Github
  • Runbot
  • Перевод
Услуги
  • Хостинг Odoo.sh
  • Поддержка
  • Обновление
  • Индивидуальные решения по доработке
  • Образование
  • Найти бухгалтера
  • Найти партнера
  • Стать партнером
О нас
  • Наша компания
  • Активы бренда
  • Cвяжитесь с нами
  • Вакансии
  • Мероприятия
  • Подкаст
  • Блог
  • Клиенты
  • Правовые документы • Конфиденциальность
  • Безопасность
الْعَرَبيّة 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, E-commerce, Бухгалтерия, Склад, POS, управление проектами и др.

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