Skip to content

Commit

Permalink
[MIG] bi_view_editor: Migration to 18.0
Browse files Browse the repository at this point in the history
  • Loading branch information
cormaza committed Jan 7, 2025
1 parent 4c00443 commit ec73ccf
Show file tree
Hide file tree
Showing 7 changed files with 68 additions and 72 deletions.
7 changes: 3 additions & 4 deletions bi_view_editor/__manifest__.py
Original file line number Diff line number Diff line change
Expand Up @@ -9,14 +9,13 @@
"license": "AGPL-3",
"website": "https://github.com/OCA/reporting-engine",
"category": "Productivity",
"version": "16.0.1.1.0",
"version": "18.0.1.1.0",
"development_status": "Beta",
"depends": [
"spreadsheet_dashboard",
"web",
],
"external_dependencies": {
"deb": ["graphviz"],
},
"external_dependencies": {"deb": ["graphviz"], "python": ["pydot"]},
"data": [
"security/res_groups.xml",
"security/ir.model.access.csv",
Expand Down
43 changes: 19 additions & 24 deletions bi_view_editor/models/bve_view.py
Original file line number Diff line number Diff line change
Expand Up @@ -100,7 +100,6 @@ def _inverse_serialized_data(self):
)
query = fields.Text(compute="_compute_sql_query")
over_condition = fields.Text(
states={"draft": [("readonly", False)]},
readonly=True,
help="Condition to be inserted in the OVER part "
"of the ID's row_number function.\n"
Expand Down Expand Up @@ -190,7 +189,7 @@ def _get_field_attrs(line):
res = attr and f'{attr}="{line.description}"' or ""
return f'<field name="{line.name}" {res} />'

bve_field_lines = self.field_ids.filtered(lambda l: l.in_list)
bve_field_lines = self.field_ids.filtered(lambda line: line.in_list)
return list(map(_get_field_attrs, bve_field_lines.sorted("sequence")))

def _create_bve_view(self):
Expand Down Expand Up @@ -244,18 +243,16 @@ def _create_bve_view(self):
tree_view = View.create(
{
"name": "Tree Analysis",
"type": "tree",
"type": "list",
"model": self.model_name,
"priority": 16,
"arch": """<?xml version="1.0"?>
<tree create="false">
{}
</tree>
"arch": """<?xml version="1.0"?> <list create="false">
{}</list>
""".format("".join(self._create_tree_view_arch())),
}
)

# set the Tree view as the default one
# set the List view as the default one
action = (
self.env["ir.actions.act_window"]
.sudo()
Expand All @@ -264,9 +261,9 @@ def _create_bve_view(self):
"name": self.name,
"res_model": self.model_name,
"type": "ir.actions.act_window",
"view_mode": "tree,graph,pivot",
"view_mode": "list,graph,pivot",
"view_id": tree_view.id,
"context": "{'service_name': '%s'}" % self.name,
"context": "{'service_name': '" + self.name + "'}",
}
)
)
Expand Down Expand Up @@ -357,17 +354,13 @@ def _compute_sql_query(self):
seen.add(line.table_alias)
from_str += "\n"
from_str += " LEFT" if line.left_join else ""
from_str += f" JOIN {table_format} ON {line.join_node}.id = {line.table_alias}.{line.field_id.name}"
from_str += f" JOIN {table_format} ON {line.join_node}.id = {line.table_alias}.{line.field_id.name}" # noqa: E501
if line.join_node not in seen:
from_str += "\n"
seen.add(line.join_node)
from_str += " LEFT" if line.left_join else ""
from_str += f" JOIN {tables_map[line.join_node]} AS {line.join_node} ON {line.table_alias}.{line.field_id.name} = {line.join_node}.id"
bve_view.query = """SELECT %s\n\nFROM %s
""" % (
AsIs(select_str),
AsIs(from_str),
)
from_str += f" JOIN {tables_map[line.join_node]} AS {line.join_node} ON {line.table_alias}.{line.field_id.name} = {line.join_node}.id" # noqa: E501
bve_view.query = f"""SELECT {AsIs(select_str)}\n\nFROM {AsIs(from_str)}"""

def action_create(self):
self.ensure_one()
Expand All @@ -383,7 +376,7 @@ def action_create(self):
self._create_sql_view()

# create model and fields
bve_fields = self.line_ids.filtered(lambda l: not l.join_node)
bve_fields = self.line_ids.filtered(lambda line: not line.join_node)
model = (
self.env["ir.model"]
.sudo()
Expand Down Expand Up @@ -440,7 +433,8 @@ def _check_groups_consistency(self):
for group in access_records.mapped("group_id"):
group_list += f" * {group.full_name}\n"
msg_title = _(
'The model "%s" cannot be accessed by users with the selected groups only.'
'The model "%s" cannot be accessed '
"by users with the selected groups only."
) % (line_model.name,)
msg_details = _("At least one of the following groups must be added:")
raise UserError(
Expand All @@ -457,16 +451,17 @@ def _check_invalid_lines(self):
if not self.line_ids:
raise ValidationError(_("No data to process."))

invalid_lines = self.line_ids.filtered(lambda l: not l.model_id)
invalid_lines = self.line_ids.filtered(lambda line: not line.model_id)
if invalid_lines:
missing_models = ", ".join(set(invalid_lines.mapped("model_name")))
raise ValidationError(
_(
"Following models are missing: %s.\nProbably some modules were uninstalled."
"Following models are missing: %(missing_models)s.\n"
"Probably some modules were uninstalled."
)
% (missing_models,)
% {"missing_models": missing_models}
)
invalid_lines = self.line_ids.filtered(lambda l: not l.field_id)
invalid_lines = self.line_ids.filtered(lambda line: not line.field_id)
if invalid_lines:
missing_fields = ", ".join(set(invalid_lines.mapped("field_name")))
raise ValidationError(
Expand Down Expand Up @@ -584,7 +579,7 @@ def _constraint_line_ids(self):
@api.model
def get_clean_list(self, data_dict):
serialized_data = data_dict
if type(data_dict) == str:
if isinstance(data_dict, str):
serialized_data = json.loads(data_dict)
table_alias_list = set()
for item in serialized_data:
Expand Down
4 changes: 2 additions & 2 deletions bi_view_editor/models/bve_view_line.py
Original file line number Diff line number Diff line change
Expand Up @@ -44,11 +44,11 @@ def _compute_view_field_type(self):
@api.constrains("row", "column", "measure")
def _constrains_options_check(self):
measure_types = ["float", "integer", "monetary"]
for line in self.filtered(lambda l: l.row or l.column):
for line in self.filtered(lambda x: x.row or x.column):
if line.join_model_id or line.ttype in measure_types:
err_msg = _("This field cannot be a row or a column.")
raise ValidationError(err_msg)
for line in self.filtered(lambda l: l.measure):
for line in self.filtered(lambda x: x.measure):
if line.join_model_id or line.ttype not in measure_types:
err_msg = _("This field cannot be a measure.")
raise ValidationError(err_msg)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,17 @@ import {JoinNodeDialog} from "./join_node_dialog.esm";
import {registry} from "@web/core/registry";
import {standardFieldProps} from "@web/views/fields/standard_field_props";
import {useService} from "@web/core/utils/hooks";
import {uniqueId} from "@web/core/utils/functions";

export class BiViewEditor extends Component {
static components = {
ModelList,
FieldList,
};
static template = "bi_view_editor.Frame";
static props = {
...standardFieldProps,
};
setup() {
this.state = useState({
models: [],
Expand Down Expand Up @@ -55,7 +64,7 @@ export class BiViewEditor extends Component {
field.column = typeof field.column === "undefined" ? false : field.column;
field.measure = typeof field.measure === "undefined" ? false : field.measure;
field.list = typeof field.list === "undefined" ? true : field.list;
field._id = typeof field._id === "undefined" ? _.uniqueId("node_") : field._id;
field._id = typeof field._id === "undefined" ? uniqueId("node_") : field._id;
if (field.join_node) {
field.join_left =
typeof field.join_left === "undefined" ? false : field.join_left;
Expand Down Expand Up @@ -155,7 +164,7 @@ export class BiViewEditor extends Component {
this.updateValue();
}
addField(field) {
const data = _.extend({}, field);
const data = {...field};
const field_data = this.state.fields;
this.orm
.call("ir.model", "get_join_nodes", [field_data, data])
Expand Down Expand Up @@ -201,17 +210,13 @@ export class BiViewEditor extends Component {
}
}
updateValue() {
this.props.update(JSON.stringify(this.state.fields));
// This.props.update(JSON.stringify(this.state.fields));
this.updateModels();
}
}
BiViewEditor.template = "bi_view_editor.Frame";
BiViewEditor.components = {
ModelList,
FieldList,
};
BiViewEditor.props = {
...standardFieldProps,

export const BiViewEditorField = {
component: BiViewEditor,
};

registry.category("fields").add("BVEEditor", BiViewEditor);
registry.category("fields").add("BVEEditor", BiViewEditorField);
2 changes: 1 addition & 1 deletion bi_view_editor/tests/test_bi_view.py
Original file line number Diff line number Diff line change
Expand Up @@ -367,7 +367,7 @@ def test_19_field_selection(self):
.search(
[
("model", "=", self.company_model_name),
("name", "=", "base_onboarding_company_state"),
("name", "=", "font"),
],
limit=1,
)
Expand Down
56 changes: 26 additions & 30 deletions bi_view_editor/views/bve_view.xml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
<record id="action_bi_view_editor_view_form" model="ir.actions.act_window">
<field name="name">Custom BI Views</field>
<field name="res_model">bve.view</field>
<field name="view_mode">tree,form</field>
<field name="view_mode">list,form</field>
<field name="help" type="html">
<p class="oe_view_nocontent_create">
Click to create a Custom Query Object.
Expand All @@ -20,23 +20,23 @@
-->
<menuitem
id="menu_bi_view_editor_view"
parent="base.menu_reporting_config"
parent="spreadsheet_dashboard.spreadsheet_dashboard_menu_configuration"
action="action_bi_view_editor_view_form"
sequence="50"
/>
<!-- Menu that will contain all the BI views generated by this module -->
<menuitem
id="menu_bi_view_editor_custom_reports"
name="Custom BI Views"
parent="base.menu_board_root"
parent="spreadsheet_dashboard.spreadsheet_dashboard_menu_root"
sequence="120"
/>
<record id="view_bi_view_editor_view_tree" model="ir.ui.view">
<field name="model">bve.view</field>
<field name="arch" type="xml">
<tree>
<list>
<field name="name" />
</tree>
</list>
</field>
</record>
<record id="view_bi_view_editor_view_form" model="ir.ui.view">
Expand All @@ -47,30 +47,30 @@
<button
name="action_reset"
type="object"
states="created"
invisible="state != 'created'"
string="Reset to Draft"
groups="bi_view_editor.group_bve_manager"
/>
<button
name="action_create"
type="object"
states="draft"
invisible="state != 'draft'"
string="Generate BI View"
class="oe_highlight"
groups="bi_view_editor.group_bve_manager"
/>
<button
name="open_view"
type="object"
states="created"
invisible="state != 'created'"
string="Open BI View"
class="oe_highlight"
groups="bi_view_editor.group_bve_manager"
/>
<button
name="%(base.act_menu_create)d"
type="action"
states="created"
invisible="state != 'created'"
groups="bi_view_editor.group_bve_manager"
icon="fa-align-justify"
string="Create a Menu"
Expand All @@ -86,35 +86,28 @@
</header>
<sheet>
<h1>
<field
name="name"
attrs="{'readonly': [('state','=','created')]}"
colspan="4"
/>
<field name="name" readonly="state == 'created'" colspan="4" />
</h1>
<notebook>
<page string="Query Builder">
<field
name="data"
widget="BVEEditor"
nolabel="1"
attrs="{'readonly': [('state','=','created')]}"
readonly="state == 'created'"
/>
</page>
<page
string="ER Diagram"
attrs="{'invisible': [('er_diagram_image','=',False)]}"
>
<page string="ER Diagram" invisible="not er_diagram_image">
<field nolabel="1" name="er_diagram_image" widget="image" />
</page>
<page string="Details">
<separator string="Fields" />
<field
name="field_ids"
nolabel="1"
attrs="{'readonly': [('state','=','created')]}"
readonly="state == 'created'"
>
<tree
<list
editable="bottom"
decoration-muted="in_list == False"
create="false"
Expand All @@ -126,44 +119,47 @@
<field name="ttype" invisible="1" />
<field
name="row"
attrs="{'invisible': [('ttype','in',('float', 'integer', 'monetary'))]}"
invisible="ttype in ('float', 'integer', 'monetary')"
/>
<field
name="column"
attrs="{'invisible': [('ttype','in',('float', 'integer', 'monetary'))]}"
invisible="ttype in ('float', 'integer', 'monetary')"
/>
<field
name="measure"
attrs="{'invisible': [('ttype','not in',('float', 'integer', 'monetary'))]}"
invisible="ttype in ('float', 'integer', 'monetary')"
/>
<field name="in_list" widget="boolean_toggle" />
<field
name="list_attr"
attrs="{'invisible': ['|',('in_list','=',False),('ttype','not in',('float', 'integer'))]}"
invisible="not in_list or ttype not in ('float', 'integer')"
/>
</tree>
</list>
</field>
<separator string="Relations" />
<field
name="relation_ids"
nolabel="1"
attrs="{'readonly': [('state','=','created')]}"
readonly="state == 'created'"
>
<tree editable="bottom" create="false">
<list editable="bottom" create="false">
<field name="sequence" widget="handle" />
<field name="description" string="Field" />
<field name="model_id" readonly="1" />
<field name="table_alias" />
<field name="join_model_id" readonly="1" />
<field name="join_node" />
<field name="left_join" />
</tree>
</list>
</field>
</page>
<page string="SQL" groups="base.group_no_one">
<field name="query" />
<group>
<field name="over_condition" />
<field
name="over_condition"
readonly="state == 'draft'"
/>
</group>
</page>
<page string="Security">
Expand Down
1 change: 1 addition & 0 deletions requirements.txt
Original file line number Diff line number Diff line change
@@ -1,3 +1,4 @@
# generated from manifests external_dependencies
pydot
xlrd
xlsxwriter

0 comments on commit ec73ccf

Please sign in to comment.