Skip to content

Commit 9fac039

Browse files
[OU-IMP] website: fix migrated snippets
Add missing data-vcss="001" and data-vxml="001" attributes required by Odoo 18 on migrated snippets. TT63052
1 parent 6b4ed70 commit 9fac039

1 file changed

Lines changed: 65 additions & 0 deletions

File tree

Lines changed: 65 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,65 @@
1+
# Copyright 2026 Tecnativa - Pilar Vargas
2+
# License AGPL-3.0 or later (https://www.gnu.org/licenses/agpl).
3+
4+
from openupgradelib import openupgrade
5+
6+
7+
def migrate_s_carousel_snippets(env):
8+
openupgrade.logged_query(
9+
env.cr,
10+
r"""
11+
UPDATE ir_ui_view v
12+
SET arch_db = data.arch_db
13+
FROM (
14+
SELECT view.id,
15+
jsonb_object_agg(
16+
lang,
17+
regexp_replace(
18+
arch,
19+
$$<section(?=[^>]*class="[^"]*s_carousel_wrapper[^"]*")(?![^>]*data-vcss=)([^>]*)>$$,
20+
$$<section\1 data-vcss="001">$$,
21+
'g'
22+
)
23+
) AS arch_db
24+
FROM ir_ui_view view
25+
CROSS JOIN LATERAL jsonb_each_text(view.arch_db) AS value(lang, arch)
26+
WHERE view.website_id IS NOT NULL
27+
AND view.arch_db::text LIKE '%s_carousel_wrapper%'
28+
GROUP BY view.id
29+
) data
30+
WHERE v.id = data.id
31+
""",
32+
)
33+
34+
35+
def migrate_s_three_columns_snippets(env):
36+
openupgrade.logged_query(
37+
env.cr,
38+
r"""
39+
UPDATE ir_ui_view v
40+
SET arch_db = data.arch_db
41+
FROM (
42+
SELECT view.id,
43+
jsonb_object_agg(
44+
lang,
45+
regexp_replace(
46+
arch,
47+
$$<section(?=[^>]*class="[^"]*s_three_columns[^"]*")(?![^>]*data-vxml=)([^>]*)>$$,
48+
$$<section\1 data-vxml="001">$$,
49+
'g'
50+
)
51+
) AS arch_db
52+
FROM ir_ui_view view
53+
CROSS JOIN LATERAL jsonb_each_text(view.arch_db) AS value(lang, arch)
54+
WHERE view.website_id IS NOT NULL
55+
AND view.arch_db::text LIKE '%s_three_columns%'
56+
GROUP BY view.id
57+
) data
58+
WHERE v.id = data.id
59+
""",
60+
)
61+
62+
63+
@openupgrade.migrate()
64+
def migrate(env, version):
65+
migrate_s_carousel_snippets(env)

0 commit comments

Comments
 (0)