mirror of
https://github.com/bringout/oca-ocb-core.git
synced 2026-04-21 19:52:08 +02:00
19.0 vanilla
This commit is contained in:
parent
d1963a3c3a
commit
2d3ee4855a
7430 changed files with 2687981 additions and 2965473 deletions
|
|
@ -1,4 +1,3 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# Part of Odoo. See LICENSE file for full copyright and licensing details.
|
||||
|
||||
import base64
|
||||
|
|
@ -8,7 +7,7 @@ from datetime import datetime
|
|||
from odoo import http
|
||||
from odoo.exceptions import AccessError, MissingError
|
||||
from odoo.http import request, Response
|
||||
from odoo.tools import image_process
|
||||
from odoo.tools.image import image_process
|
||||
from odoo.tools.translate import _
|
||||
from odoo.addons.portal.controllers import portal
|
||||
from odoo.addons.portal.controllers.portal import pager as portal_pager
|
||||
|
|
@ -22,11 +21,11 @@ class CustomerPortal(portal.CustomerPortal):
|
|||
if 'rfq_count' in counters:
|
||||
values['rfq_count'] = PurchaseOrder.search_count([
|
||||
('state', 'in', ['sent'])
|
||||
]) if PurchaseOrder.check_access_rights('read', raise_exception=False) else 0
|
||||
]) if PurchaseOrder.has_access('read') else 0
|
||||
if 'purchase_count' in counters:
|
||||
values['purchase_count'] = PurchaseOrder.search_count([
|
||||
('state', 'in', ['purchase', 'done', 'cancel'])
|
||||
]) if PurchaseOrder.check_access_rights('read', raise_exception=False) else 0
|
||||
('state', 'in', ['purchase', 'cancel'])
|
||||
]) if PurchaseOrder.has_access('read') else 0
|
||||
return values
|
||||
|
||||
def _get_purchase_searchbar_sortings(self):
|
||||
|
|
@ -130,10 +129,9 @@ class CustomerPortal(portal.CustomerPortal):
|
|||
page, date_begin, date_end, sortby, filterby,
|
||||
[],
|
||||
{
|
||||
'all': {'label': _('All'), 'domain': [('state', 'in', ['purchase', 'done', 'cancel'])]},
|
||||
'all': {'label': _('All'), 'domain': [('state', 'in', ['purchase', 'cancel'])]},
|
||||
'purchase': {'label': _('Purchase Order'), 'domain': [('state', '=', 'purchase')]},
|
||||
'cancel': {'label': _('Cancelled'), 'domain': [('state', '=', 'cancel')]},
|
||||
'done': {'label': _('Locked'), 'domain': [('state', '=', 'done')]},
|
||||
},
|
||||
'all',
|
||||
"/my/purchase",
|
||||
|
|
@ -151,13 +149,11 @@ class CustomerPortal(portal.CustomerPortal):
|
|||
|
||||
report_type = kw.get('report_type')
|
||||
if report_type in ('html', 'pdf', 'text'):
|
||||
return self._show_report(model=order_sudo, report_type=report_type, report_ref='purchase.action_report_purchase_order', download=kw.get('download'))
|
||||
report_ref = 'purchase.report_purchase_quotation' if order_sudo.state in ['rfq','sent'] else 'purchase.action_report_purchase_order'
|
||||
return self._show_report(model=order_sudo, report_type=report_type, report_ref=report_ref, download=kw.get('download'))
|
||||
|
||||
confirm_type = kw.get('confirm')
|
||||
if confirm_type == 'reminder':
|
||||
order_sudo.confirm_reminder_mail(kw.get('confirmed_date'))
|
||||
if confirm_type == 'reception':
|
||||
order_sudo._confirm_reception_mail()
|
||||
if kw.get('acknowledge'):
|
||||
order_sudo.action_acknowledge()
|
||||
|
||||
values = self._purchase_order_get_page_view_values(order_sudo, access_token, **kw)
|
||||
update_date = kw.get('update')
|
||||
|
|
@ -167,7 +163,7 @@ class CustomerPortal(portal.CustomerPortal):
|
|||
return request.render("purchase.portal_my_purchase_order_update_date", values)
|
||||
return request.render("purchase.portal_my_purchase_order", values)
|
||||
|
||||
@http.route(['/my/purchase/<int:order_id>/update'], type='http', methods=['POST'], auth="public", website=True)
|
||||
@http.route(['/my/purchase/<int:order_id>/update'], type='jsonrpc', auth="public", website=True)
|
||||
def portal_my_purchase_order_update_dates(self, order_id=None, access_token=None, **kw):
|
||||
"""User update scheduled date on purchase order line.
|
||||
"""
|
||||
|
|
@ -196,3 +192,31 @@ class CustomerPortal(portal.CustomerPortal):
|
|||
if updated_dates:
|
||||
order_sudo._update_date_planned_for_lines(updated_dates)
|
||||
return Response(status=204)
|
||||
|
||||
@http.route(['/my/purchase/<int:order_id>/download_edi'], auth="public", website=True)
|
||||
def portal_my_purchase_order_download_edi(self, order_id=None, access_token=None, **kw):
|
||||
"""An endpoint to download EDI file representation.
|
||||
"""
|
||||
try:
|
||||
order_sudo = self._document_check_access('purchase.order', order_id, access_token=access_token)
|
||||
except (AccessError, MissingError):
|
||||
return request.redirect('/my')
|
||||
|
||||
builders = order_sudo._get_edi_builders()
|
||||
|
||||
# This handles only one builder for now, more can be added in the future
|
||||
# TODO: add builder choice on modal
|
||||
if len(builders) == 0:
|
||||
return request.redirect('/my')
|
||||
builder = builders[0]
|
||||
|
||||
xml_content = builder._export_order(order_sudo)
|
||||
|
||||
download_name = builder._export_invoice_filename(order_sudo) # works even if it's a SO or PO
|
||||
|
||||
http_headers = [
|
||||
('Content-Type', 'text/xml'),
|
||||
('Content-Length', len(xml_content)),
|
||||
('Content-Disposition', f'attachment; filename={download_name}')
|
||||
]
|
||||
return request.make_response(xml_content, headers=http_headers)
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue