Public release from ruodoo-project: 19.0 - 2026-05-31 21:19:12 UTC

This commit is contained in:
CI Publish Bot
2026-05-31 21:19:21 +00:00
commit aa4214c195
1213 changed files with 183945 additions and 0 deletions

View File

@ -0,0 +1,7 @@
from . import ir_actions_report
from . import res_company
from . import res_partner
from . import res_users
from . import uom_uom
from . import account_move
from . import account_move_line

View File

@ -0,0 +1,207 @@
from odoo import api, fields, models, _
import hashlib
from odoo.exceptions import UserError
class AccountMove(models.Model):
_inherit = 'account.move'
edi = fields.Char(string=_('ID EDI'), compute='_compute_sh1_edi')
kpp = fields.Char(string=_('КПП'), compute='_compute_get_kpp')
def _compute_get_kpp(self):
for s in self:
pid = self.partner_id.parent_id or self.partner_id
s.kpp = pid.kpp if (s.partner_id == s.partner_shipping_id or not s.partner_shipping_id) else s.partner_shipping_id.kpp
@api.depends('name')
def _compute_sh1_edi(self):
hash_object = hashlib.sha1((self.name).encode('utf-8'))
pid = self.partner_id.parent_id or self.partner_id
self.edi = 'ON_NSCHFDOPPR_2BM-' + str(pid.edi) + '_' + str(self.company_id.edi) + '_' + hash_object.hexdigest()
def print_upd(self):
for s in self:
mes = str(s.check_correct_upd()).strip()
if mes != "":
raise UserError(_(u"Не удалось сформировать УПД. Выявлены следующие ошибки:\n{}".format(mes)))
else:
return self.env.ref('l10n_ru_upd_xml.upd_xml_report').sudo().report_action(s.id) # render_qweb_xml(s.id)
def check_correct_upd(self, manually=True):
for s in self:
mes = ""
company = s.company_id
if s.name == '/':
mes += u"Отсутствует наименование документа. Проверидите документ, чтобы назваие сформировалось автоматически.\n"
if not s.only_service and s.get_delivery_doc_name() == '0':
mes += u"Отсутствуют связанные отгрузки.\n"
if not company:
company = self.env.company
if not company:
mes += u"Не указана компания.\n"
else:
if not company.edi:
mes += u"Не указан идентификатор компании для Diadoc.\n"
if not company.name:
mes += u"Не указано наименование компании.\n"
if not company.okpo:
mes += u"Не указано ОКПО компании.\n"
if not company.inn:
mes += u"Не указан ИНН компании.\n"
else:
if len(company.inn) == 12:
if not company.partner_id.last_name_IP:
mes += u"Не указана фамилия ИП для вашей компании.\n"
if not company.partner_id.first_name_IP:
mes += u"Не указано имя ИП для вашей компании.\n"
if not company.partner_id.middle_name_IP:
mes += u"Не указано отчество ИП для вашей компании.\n"
elif len(company.inn) == 10:
if not company.kpp:
mes += u"Не указан КПП компании.\n"
else:
mes += u"Некорректный ИНН компании.\n"
if not company.city:
mes += u"Не указан город компании.\n"
if not company.street:
mes += u"Не указан адрес компании.\n"
if not company.chief_id:
mes += u"Не указан руководитель компании.\n"
else:
if not company.chief_id.function:
mes += u"Не указана должность руководителя компании.\n"
if not company.chief_id.last_name:
mes += u"Не указана фамилия руководителя компании.\n"
if not company.chief_id.first_name:
mes += u"Не указано имя руководителя компании.\n"
if not company.chief_id.second_name:
mes += u"Не указано отчество руководителя компании.\n"
pid = s.partner_id.parent_id
if not pid:
pid = s.partner_id
if not pid:
mes += u"Не указан контрагент.\n"
else:
if not pid.edi:
mes += u"Не указан идентификатор контрагента для Diadoc.\n"
if not pid.name:
mes += u"Не указано наименование контрагента.\n"
if not pid.okpo:
mes += u"Не указано ОКПО контрагента.\n"
if not pid.inn:
mes += u"Не указан ИНН контрагента.\n"
else:
if len(pid.inn) == 12:
if not pid.last_name_IP:
mes += u"Не указана фамилия ИП для контрагента.\n"
if not pid.first_name_IP:
mes += u"Не указано имя ИП для контрагента.\n"
if not pid.middle_name_IP:
mes += u"Не указано отчество ИП для контрагента.\n"
elif len(pid.inn) == 10:
if not pid.kpp:
mes += u"Не указан КПП контрагента.\n"
else:
mes += u"Некорректный ИНН контрагента.\n"
if not pid.city:
mes += u"Не указан город контрагента.\n"
if not pid.street:
mes += u"Не указан адрес контрагента.\n"
if manually:
if not s.edi:
mes += u"Не указан идентификатор документа для Diadoc.\n"
if not s.name:
mes += u"Не указано наименование документа\n"
if not s.invoice_date:
mes += u"Не указана дата документа\n"
if not s.only_service:
gruzootpr = s.gruzootpr
if not gruzootpr:
gruzootpr = pid
if gruzootpr.parent_id:
gruzootpr = gruzootpr.parent_id
if not gruzootpr:
mes += u"Не указан грузоотправитель.\n"
else:
if not gruzootpr.name:
mes += u"Не указано наименование грузоотправителя.\n"
if not gruzootpr.okpo:
mes += u"Не указано ОКПО грузоотправителя.\n"
if not gruzootpr.inn:
mes += u"Не указан ИНН грузоотправителя.\n"
else:
if len(gruzootpr.inn) == 12:
if not gruzootpr.last_name_IP:
mes += u"Не указана фамилия ИП для грузоотправителя.\n"
if not gruzootpr.first_name_IP:
mes += u"Не указано имя ИП для грузоотправителя.\n"
if not gruzootpr.middle_name_IP:
mes += u"Не указано отчество ИП для грузоотправителя.\n"
elif len(gruzootpr.inn) == 10:
if not gruzootpr.kpp:
mes += u"Не указан КПП грузоотправителя.\n"
else:
mes += u"Некорректный ИНН грузоотправителя.\n"
if not gruzootpr.city:
mes += u"Не указан город грузоотправителя.\n"
if not gruzootpr.street:
mes += u"Не указан адрес грузоотправителя.\n"
gruzopol = s.gruzopol
if not gruzopol:
gruzopol = pid
if gruzopol.parent_id:
gruzopol = gruzopol.parent_id
if not gruzopol:
mes += u"Не указан грузополучатель.\n"
else:
if not gruzopol.name:
mes += u"Не указано наименование грузополучателя.\n"
if not gruzopol.okpo:
mes += u"Не указано ОКПО грузополучателя.\n"
if not gruzopol.inn:
mes += u"Не указан ИНН грузополучателя.\n"
else:
if len(gruzopol.inn) == 12:
if not gruzopol.last_name_IP:
mes += u"Не указана фамилия ИП для грузополучателя.\n"
if not gruzopol.first_name_IP:
mes += u"Не указано имя ИП для грузополучателя.\n"
if not gruzopol.middle_name_IP:
mes += u"Не указано отчество ИП для грузополучателя.\n"
elif len(gruzopol.inn) == 10:
if not gruzopol.kpp:
mes += u"Не указан КПП грузополучателя.\n"
else:
mes += u"Некорректный ИНН грузополучателя.\n"
if not gruzopol.city:
mes += u"Не указан город грузополучателя.\n"
if not gruzopol.street:
mes += u"Не указан адрес грузополучателя.\n"
if s.payment_num:
if not s.payment_date:
mes += u"Не указана дата платежки в УПД.\n"
if not s.invoice_line_ids:
mes += u"Отсутствуют строки заказа.\n"
else:
for line in s.invoice_line_ids:
if not line.price_unit:
mes += u"Не указана цена за единицу для товара {}.\n".format(line.name)
if not line.quantity:
mes += u"Не указано количество для товара {}.\n".format(line.name)
if not line.product_uom_id.okei:
mes += u"Не указан код ОКЕИ для единицы измерения {}.\n".format(line.product_uom_id.name)
if not s.mt_contract_id:
mes += u"Не указан договор.\n"
else:
if not s.mt_contract_id.name:
mes += u"Не указано наименование договора.\n"
if not s.mt_contract_id.date_start:
mes += u"Не указана дата договора.\n"
if not s.kladov:
mes += u"Не указано лицо, ответственное за передачу товаров/услуг.\n"
else:
if not s.kladov.partner_id.function:
mes += u"Не указана должность лица, ответственного за передачу товаров/услуг.\n"
return str(mes)

View File

@ -0,0 +1,7 @@
from odoo import models, fields, api, _
class AccountMoveLine(models.Model):
_inherit = "account.move.line"
uom_okei = fields.Char(string=_('Код ОКЕИ'), related='product_uom_id.okei')

View File

@ -0,0 +1,62 @@
from odoo import fields, models, api
class IrActionsReport(models.Model):
_inherit = "ir.actions.report"
report_type = fields.Selection(
selection_add=[("qweb-xml", "XML")], ondelete={"qweb-xml": "set default"}
)
xsd_schema = fields.Binary(
string="XSD Validation Schema",
attachment=True,
help="File with XSD Schema for checking content of result report. Can be empty "
"if validation is not required.",
)
xml_encoding = fields.Selection(
selection=[
("WINDOWS-1251", "WINDOWS-1251") # will be used as default even if nothing is selected
],
string="XML Encoding",
help=(
"Encoding for XML reports. If nothing is selected, "
"then UTF-8 will be applied."
),
)
xml_declaration = fields.Boolean(
string="XML Declaration",
help=(
"""Add `<?xml encoding="..." version="..."?>` at the start """
"""of final report file."""
),
default=True,
)
xml_extension = fields.Char(
default="xml",
help="Extension for XML Reports, by default is `xml`",
)
@api.model
def _render_qweb_xml(self, report_ref, res_ids, data=None):
"""
Call `generate_report` method of report abstract class
`report.<report technical name>` or of standard class for XML report
rendering - `report.report_xml.abstract`
Args:
* docids(list) - IDs of instances for those report will be generated
* data(dict, None) - variables for report rendering
Returns:
* str - result content of report
* str - type of result content
"""
report = self._get_report(report_ref)
report_model = self.env.get(
f"report.{report.report_name}", self.env["report.upd_xml.abstract"]
)
return report_model.generate_report(
ir_report=report, # will be used to get settings of report
docids=res_ids,
data=data or {},
)

View File

@ -0,0 +1,11 @@
from odoo import fields, models, _
class ResCompany(models.Model):
_inherit = 'res.company'
inn = fields.Char(related='partner_id.inn', readonly=False, string=_('ИНН'))
kpp = fields.Char(related='partner_id.kpp', readonly=False, string=_('КПП'))
okpo = fields.Char(related='partner_id.okpo', readonly=False, string=_('ОКПО'))
edi = fields.Char(string='ID EDI', readonly=False)
chief_id = fields.Many2one('res.users', string=_('Управляющий'))

View File

@ -0,0 +1,36 @@
from odoo import api, fields, models, _
class ResPartner(models.Model):
_inherit = 'res.partner'
inn = fields.Char(_('ИНН'), size=12)
kpp = fields.Char(_('КПП'), size=9)
okpo = fields.Char(_('ОКПО'), size=14)
edi = fields.Char(_('ID EDI'))
house = fields.Char(_('Дом'))
office = fields.Char(_('Квартира, офис'))
fias_id = fields.Char(_('Код ФИАС'))
last_name_IP = fields.Char(_('Фамилия ИП'), compute='_compute_get_fio', readonly=False)
first_name_IP = fields.Char(_('Имя ИП'), compute='_compute_get_fio', readonly=False)
middle_name_IP = fields.Char(_('Отчество ИП'), compute='_compute_get_fio', readonly=False)
@api.depends('name')
def _compute_get_fio(self):
for s in self:
if s.name:
name = s.name
if name.find('ИП ') != -1:
name = name[name.find(' ') + 1:]
s.last_name_IP = name[:name.find(' ')]
name = name[name.find(' ') + 1:]
s.first_name_IP = name[:name.find(' ')]
name = name[name.find(' ') + 1:]
s.middle_name_IP = name
else:
s.last_name_IP = ""
s.first_name_IP = ""
s.middle_name_IP = ""
else:
s.last_name_IP = ""
s.first_name_IP = ""
s.middle_name_IP = ""

View File

@ -0,0 +1,25 @@
from odoo import api, fields, models, _
class ResUsers(models.Model):
_inherit = 'res.users'
last_name = fields.Char(string=_('Фамилия'), compute='_compute_update_name')
first_name = fields.Char(string=_('Имя'), compute='_compute_update_name')
second_name = fields.Char(string=_('Отчество'), compute='_compute_update_name')
@api.depends('name')
def _compute_update_name(self):
for s in self:
s.last_name = ''
s.first_name = ''
s.second_name = ''
if s.name:
s.last_name = s.name
s.first_name = ''
s.second_name = ''
if len(s.name.split(' ')) == 3:
s.last_name, s.first_name, s.second_name = s.name.split(' ')
if len(s.name.split(' ')) == 4:
s.last_name, s.first_name, second_name1, second_name2 = s.name.split(' ')
s.second_name = second_name1 + ' ' + second_name2

View File

@ -0,0 +1,7 @@
from odoo import fields, models, _
class UomUom(models.Model):
_inherit = "uom.uom"
okei = fields.Char(string="Код ОКЕИ")