Initial commit: OCA Technical packages (595 packages)

This commit is contained in:
Ernad Husremovic 2025-08-29 15:43:03 +02:00
commit 2cc02aac6e
24950 changed files with 2318079 additions and 0 deletions

View file

@ -0,0 +1,172 @@
# Copyright 2011-2012 Nicolas Bessi (Camptocamp SA)
# Copyright 2016 Yannick Payot (Camptocamp SA)
# Copyright 2023 ACSONE SA/NV
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
import logging
from odoo import _, api, models
from odoo.exceptions import MissingError, UserError
from odoo.osv.expression import AND
from .. import fields as geo_fields
DEFAULT_EXTENT = (
"-123164.85222423, 5574694.9538936, " "1578017.6490538, 6186191.1800898"
)
_logger = logging.getLogger(__name__)
class Base(models.AbstractModel):
"""Extend Base class for to allow definition of geo fields."""
_inherit = "base"
# Array of ash that define layer and data to use
_georepr = []
@api.model
def fields_get(self, allfields=None, attributes=None):
"""Add geo_type definition for geo fields"""
res = super().fields_get(allfields=allfields, attributes=attributes)
for f_name in res:
field = self._fields.get(f_name)
if field and field.type.startswith("geo_"):
geo_type = {
"type": field.type,
"dim": int(field.dim),
"srid": field.srid,
"geo_type": field.geo_type,
}
# TODO
if field.compute or field.related:
if not field.dim:
geo_type["dim"] = 2
if not field.srid:
geo_type["srid"] = 3857
res[f_name]["geo_type"] = geo_type
return res
@api.model
def _get_geo_view(self):
IrView = self.env["ir.ui.view"]
geo_view = IrView.sudo().search(
[("model", "=", self._name), ("type", "=", "geoengine")],
limit=1,
)
if not geo_view:
raise UserError(
_("No GeoEngine view defined for the model %s") % self._name,
_("Please create a view or modify view mode"),
)
return geo_view
@api.model
def set_field_real_name(self, in_tuple):
field_obj = self.env["ir.model.fields"]
if not in_tuple:
return in_tuple
name = field_obj.browse(in_tuple[0]).name
out = (in_tuple[0], name, in_tuple[1])
return out
@api.model
def get_geoengine_layers(self, view_id=None, view_type="geoengine", **options):
view_obj = self.env["ir.ui.view"]
if not view_id:
view = self._get_geo_view()
else:
view = view_obj.browse(view_id)
geoengine_layers = {
"backgrounds": [],
"actives": [],
"projection": view.projection,
"restricted_extent": view.restricted_extent,
"default_extent": view.default_extent or DEFAULT_EXTENT,
"default_zoom": view.default_zoom,
}
for layer in view.raster_layer_ids:
layer_dict = layer.read()[0]
geoengine_layers["backgrounds"].append(layer_dict)
for layer in view.vector_layer_ids:
layer_dict = layer.read()[0]
layer_dict["attribute_field_id"] = self.set_field_real_name(
layer_dict.get("attribute_field_id", False)
)
layer_dict["geo_field_id"] = self.set_field_real_name(
layer_dict.get("geo_field_id", False)
)
layer_dict["resModel"] = layer._name
layer_dict["model"] = layer.model_id.model
layer_dict["model_domain"] = layer.model_domain
geoengine_layers["actives"].append(layer_dict)
return geoengine_layers
@api.model
def get_edit_info_for_geo_column(self, column):
raster_obj = self.env["geoengine.raster.layer"]
field = self._fields.get(column)
if not field or not isinstance(field, geo_fields.GeoField):
raise ValueError(
_("%s column does not exists or is not a geo field") % column
)
view = self._get_geo_view()
raster = raster_obj.search(
[("view_id", "=", view.id), ("use_to_edit", "=", True)], limit=1
)
if not raster:
raster = raster_obj.search([("view_id", "=", view.id)], limit=1)
if not raster:
raise MissingError(_("No raster layer for view %s") % (view.name,))
return {
"edit_raster": raster.read()[0],
"srid": field.srid,
"projection": view.projection,
"restricted_extent": view.restricted_extent,
"default_extent": view.default_extent or DEFAULT_EXTENT,
"default_zoom": view.default_zoom,
}
@api.model
def geo_search(
self, domain=None, geo_domain=None, offset=0, limit=None, order=None
):
"""Perform a geo search it allows direct domain:
geo_search(
domain=[('name', 'ilike', 'toto']),
geo_domain=[('the_point', 'geo_intersect',
myshaply_obj or mywkt or mygeojson)])
We can also support indirect geo_domain (
geom, geo_operator, {res.zip.poly: [id, in, [1,2,3]] })
The supported operators are :
* geo_greater
* geo_lesser
* geo_equal
* geo_touch
* geo_within
* geo_contains
* geo_intersect"""
# First we do a standard search in order to apply security rules
# and do a search on standard attributes
# Limit and offset are managed after, we may loose a lot of performance
# here
_logger.debug(
_("geo_search is deprecated: uses search method defined on base model")
)
domain = domain or []
geo_domain = geo_domain or []
search_domain = domain or []
if domain and geo_domain:
search_domain = AND([domain, geo_domain])
elif geo_domain:
search_domain = geo_domain
if not search_domain:
raise ValueError(_("You must at least provide one of domain or geo_domain"))
return self.search(search_domain, limit=limit, offset=offset, order=order)