create model maintenance_service
This commit is contained in:
parent
8cd2cf17bf
commit
9736b1baf3
@ -15,10 +15,13 @@ def register():
|
||||
equipment.EquipmentMaintenance,
|
||||
configuration_equipment.Configuration,
|
||||
maintenance.Maintenance,
|
||||
maintenance.MaintenanceService,
|
||||
maintenance.MaintenanceActivity,
|
||||
maintenance.MaintenanceLine,
|
||||
move.Move,
|
||||
move.ShipmentOut,
|
||||
sale.Sale,
|
||||
sale.SaleLine,
|
||||
subscription.Contract,
|
||||
subscription.Subscription,
|
||||
subscription.CreateInitialContract,
|
||||
|
@ -2,6 +2,11 @@
|
||||
<!-- This file is part of Tryton. The COPYRIGHT file at the top level of
|
||||
this repository contains the full copyright notices and license terms. -->
|
||||
<tryton>
|
||||
<record model="ir.ui.view" id="address_view_tree">
|
||||
<field name="model">party.address</field>
|
||||
<field name="inherit" ref="party.address_view_tree"/>
|
||||
<field name="name">address_tree</field>
|
||||
</record>
|
||||
<record model="ir.ui.view" id="address_view_form">
|
||||
<field name="model">party.address</field>
|
||||
<field name="inherit" ref="party.address_view_form"/>
|
||||
|
@ -392,6 +392,11 @@ msgctxt "field:sale.subscription.line,subscription_end_date:"
|
||||
msgid "Subscription End Date"
|
||||
msgstr "Fecha final del Contrato"
|
||||
|
||||
msgctxt ""
|
||||
"model:ir.action.act_window.domain,name:act_subscription_form_domain_closed"
|
||||
msgid "Closed"
|
||||
msgstr "Vencidas"
|
||||
|
||||
msgctxt "model:ir.ui.menu,name:menu_contracts"
|
||||
msgid "Contracts Management"
|
||||
msgstr "Gestión de Contratos"
|
||||
|
101
maintenance.py
101
maintenance.py
@ -4,6 +4,7 @@ from trytond.model import (
|
||||
Workflow, ModelSQL, ModelView, Unique, fields, sequence_ordered)
|
||||
from trytond.transaction import Transaction
|
||||
from trytond.pyson import Eval, If, Id
|
||||
from trytond.pool import Pool
|
||||
import math as mt
|
||||
import numpy as np
|
||||
|
||||
@ -13,6 +14,8 @@ class Maintenance(Workflow, ModelSQL, ModelView):
|
||||
__name__ = 'optical_equipment.maintenance'
|
||||
|
||||
|
||||
service_maintenance = fields.Many2One('optical_equipment.maintenance.service', "Maintenance Service",
|
||||
ondelete='CASCADE', select=True)
|
||||
code = fields.Char(
|
||||
"Code", select=True,states={'readonly': True })
|
||||
|
||||
@ -69,10 +72,9 @@ class Maintenance(Workflow, ModelSQL, ModelView):
|
||||
('in_progress', 'finished')
|
||||
})
|
||||
cls._buttons.update({
|
||||
'draft': {},
|
||||
'agended': {},
|
||||
'in_progress': {},
|
||||
'finished': {},
|
||||
'agended': {'invisible': Eval('state').in_(['agended', 'in_progress', 'finished'])},
|
||||
'in_progress': {'invisible': Eval('state').in_(['draft', 'in_progress', 'finished'])},
|
||||
'finished': {'invisible': Eval('state').in_(['draft', 'agended', 'finished'])},
|
||||
})
|
||||
|
||||
@staticmethod
|
||||
@ -91,11 +93,6 @@ class Maintenance(Workflow, ModelSQL, ModelView):
|
||||
def default_state_agended(cls):
|
||||
return 'no_agenda'
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@Workflow.transition('draft')
|
||||
def draft(cls, maintenances):
|
||||
pass
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@ -106,7 +103,7 @@ class Maintenance(Workflow, ModelSQL, ModelView):
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@Workflow.transition('in_progress')
|
||||
def inProgress(cls, maintenances):
|
||||
def in_progress(cls, maintenances):
|
||||
pass
|
||||
|
||||
@classmethod
|
||||
@ -127,6 +124,90 @@ class Maintenance(Workflow, ModelSQL, ModelView):
|
||||
]
|
||||
|
||||
|
||||
class MaintenanceService(ModelSQL, ModelView):
|
||||
'Equipment Maintenance Service'
|
||||
__name__ = 'optical_equipment.maintenance.service'
|
||||
|
||||
code = fields.Char(
|
||||
"Code", select=True,states={'readonly': True })
|
||||
reference = fields.Char(
|
||||
"Reference", select=True,
|
||||
help="The identification of an external origin.")
|
||||
description = fields.Char("Description",
|
||||
states={
|
||||
'readonly': Eval('state') != 'draft',
|
||||
})
|
||||
#sale_date = fields.Function(fields.Char("Sale Date"), 'get_sale_date')
|
||||
sale_origin = fields.Reference("Sale Origin", selection='get_origin', select=True,
|
||||
states={'readonly': True})
|
||||
company = fields.Many2One('company.company', "Company", readonly=True)
|
||||
maintenance_type = fields.Selection([('preventive', 'Preventive'),
|
||||
('corrective', 'Corrective')
|
||||
], "Maintenance Type")
|
||||
propietary = fields.Many2One('party.party', "Propietary", required=True)
|
||||
propietary_address = fields.Many2One('party.address', "Propietary Address", required=True,
|
||||
domain=[('party', '=', Eval('propietary'))]
|
||||
)
|
||||
lines = fields.One2Many('optical_equipment.maintenance', 'service_maintenance', "Lines")
|
||||
estimated_agended = fields.DateTime("Date Maintenance")
|
||||
state_agended = fields.Selection([('no_agenda', "No agenda"),
|
||||
('agended', "Agended"),
|
||||
('in_progress', "In progress"),
|
||||
('finish', "Finish"),
|
||||
('failed', "Failed")], "State Agenda")
|
||||
technical = fields.Many2One('company.employee', "Technical")
|
||||
|
||||
state = fields.Selection([('draft', "Draft"),
|
||||
('agended', "Agended"),
|
||||
('in_progress', "In Progress"),
|
||||
('failed', "Failed"),
|
||||
('finished', "Finished")
|
||||
], "State",required=True, readonly=True, sort=False)
|
||||
|
||||
|
||||
@classmethod
|
||||
def default_state(self):
|
||||
return 'draft'
|
||||
|
||||
@classmethod
|
||||
def get_sale_date(self):
|
||||
pass
|
||||
|
||||
@classmethod
|
||||
def _get_origin(cls):
|
||||
'Return list of Model names for origin Reference'
|
||||
pool = Pool()
|
||||
Sale = pool.get('sale.line')
|
||||
|
||||
return [Sale.__name__]
|
||||
|
||||
@classmethod
|
||||
def get_origin(cls):
|
||||
Model = Pool().get('ir.model')
|
||||
get_name = Model.get_name
|
||||
models = cls._get_origin()
|
||||
|
||||
return [(None, '')] + [(m, get_name(m)) for m in models]
|
||||
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@Workflow.transition('agended')
|
||||
def agended(cls, maintenances):
|
||||
pass
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@Workflow.transition('in_progress')
|
||||
def in_progress(cls, maintenances):
|
||||
pass
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@Workflow.transition('finished')
|
||||
def finished(cls, maintenances):
|
||||
pass
|
||||
|
||||
class MaintenanceActivity(ModelSQL):
|
||||
'Maintenance - Products'
|
||||
__name__ = 'optical_equipment.maintenance-product.product'
|
||||
|
125
maintenance.xml
125
maintenance.xml
@ -18,6 +18,23 @@
|
||||
<field name="type">form</field>
|
||||
<field name="name">maintenance_form</field>
|
||||
</record>
|
||||
<record model="ir.action.act_window" id="act_maintenance_service_form">
|
||||
<field name="name">Services Maintenance</field>
|
||||
<field name="res_model">optical_equipment.maintenance.service</field>
|
||||
<field name="search_value"></field>
|
||||
</record>
|
||||
<record model="ir.ui.view" id= "maintenance_service_view_tree">
|
||||
<field name="model">optical_equipment.maintenance.service</field>
|
||||
<field name="type">tree</field>
|
||||
<field name="name">maintenance_service_tree</field>
|
||||
</record>
|
||||
<record model="ir.ui.view" id="maintenance_service_view_form">
|
||||
<field name="model">optical_equipment.maintenance.service</field>
|
||||
<field name="type">form</field>
|
||||
<field name="name">maintenance_service_form</field>
|
||||
</record>
|
||||
|
||||
|
||||
<record model="ir.ui.view" id= "maintenance_equipment_view_form">
|
||||
<field name="model">optical_equipment.maintenance-optical_equipment.equipment</field>
|
||||
<field name="inherit" ref="maintenance_view_form"/>
|
||||
@ -84,30 +101,80 @@
|
||||
<field name="domain"></field>
|
||||
<field name="act_window" ref="act_maintenance_form"/>
|
||||
</record>
|
||||
<record model="ir.model.button" id="maintenance_draft_button">
|
||||
|
||||
<record model="ir.model.button" id="maintenance_service_draft_button">
|
||||
<field name="name">draft</field>
|
||||
<field name="string">Draft</field>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance')]"/>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance.service')]"/>
|
||||
</record>
|
||||
<record model="ir.model.button" id="maintenance_agended_button">
|
||||
<record model="ir.model.button" id="maintenance_service_agended_button">
|
||||
<field name="name">agended</field>
|
||||
<field name="string">Agended</field>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance')]"/>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance.service')]"/>
|
||||
</record>
|
||||
<record model="ir.model.button" id="maintenance_in_progress_button">
|
||||
<record model="ir.model.button" id="maintenance_service_in_progress_button">
|
||||
<field name="name">in_progress</field>
|
||||
<field name="string">In progress</field>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance')]"/>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance.service')]"/>
|
||||
</record>
|
||||
<record model="ir.model.button" id="maintenance_finished_button">
|
||||
<record model="ir.model.button" id="maintenance_service_finished_button">
|
||||
<field name="name">finished</field>
|
||||
<field name="string">Finished</field>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance')]"/>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.maintenance.service')]"/>
|
||||
</record>
|
||||
<menuitem parent="menu_equipment"
|
||||
action="act_maintenance_form"
|
||||
sequence="40"
|
||||
id="menu_maintenance_form"/>
|
||||
|
||||
<record model="ir.action.act_window.domain" id="act_maintenance_service_form_domain_draft">
|
||||
<field name="name">Draft</field>
|
||||
<field name="sequence" eval="10"/>
|
||||
<field name="domain"
|
||||
eval="[('state', '=', 'draft')]"
|
||||
pyson="1"/>
|
||||
<field name="count" eval="True"/>
|
||||
<field name="act_window" ref="act_maintenance_service_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain" id="act_maintenance_service_form_domain_agended">
|
||||
<field name="name">Agended</field>
|
||||
<field name="sequence" eval="20"/>
|
||||
<field name="domain"
|
||||
eval="[('state', '=', 'agended')]"
|
||||
pyson="1"/>
|
||||
<field name="count" eval="True"/>
|
||||
<field name="act_window" ref="act_maintenance_service_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain" id="act_maintenance_service_form_domain_in_progress">
|
||||
<field name="name">In progress</field>
|
||||
<field name="sequence" eval="30"/>
|
||||
<field name="domain"
|
||||
eval="[('state', '=', 'in_progress')]"
|
||||
pyson="1"/>
|
||||
<field name="count" eval="True"/>
|
||||
<field name="act_window" ref="act_maintenance_service_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain" id="act_maintenance_service_form_domain_failed">
|
||||
<field name="name">Failed</field>
|
||||
<field name="sequence" eval="30"/>
|
||||
<field name="domain"
|
||||
eval="[('state', '=', 'failed')]"
|
||||
pyson="1"/>
|
||||
<field name="count" eval="True"/>
|
||||
<field name="act_window" ref="act_maintenance_service_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain" id="act_maintenance_service_form_domain_finished">
|
||||
<field name="name">Finished</field>
|
||||
<field name="sequence" eval="40"/>
|
||||
<field name="domain"
|
||||
eval="[('state', '=', 'finished')]"
|
||||
pyson="1"/>
|
||||
<field name="count" eval="True"/>
|
||||
<field name="act_window" ref="act_maintenance_service_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain" id="act_maintenance_service_form_domain_all">
|
||||
<field name="name">All</field>
|
||||
<field name="sequence" eval="9999"/>
|
||||
<field name="domain"></field>
|
||||
<field name="act_window" ref="act_maintenance_service_form"/>
|
||||
</record>
|
||||
|
||||
<record model="ir.ui.view" id="maintenance_line_view_tree">
|
||||
<field name="model">optical_equipment.maintenance.line</field>
|
||||
<field name="type">form</field>
|
||||
@ -124,5 +191,39 @@
|
||||
<field name="priority" eval="10"/>
|
||||
<field name="name">maintenance_calibration_tree</field>
|
||||
</record>
|
||||
<record model="ir.ui.view" id="maintenance_service_view_calendar">
|
||||
<field name="model">optical_equipment.maintenance.service</field>
|
||||
<field name="type">calendar</field>
|
||||
<field name="name">maintenance_calendar</field>
|
||||
</record>
|
||||
<record model="ir.action.act_window" id="act_maintenance_service_calendar">
|
||||
<field name="name">Agenda</field>
|
||||
<field name="res_model">optical_equipment.maintenance.service</field>
|
||||
</record>
|
||||
<record model="ir.action.act_window.view"
|
||||
id="act_maintenance_calendar_view1">
|
||||
<field name="sequence" eval="10"/>
|
||||
<field name="view" ref="maintenance_service_view_calendar"/>
|
||||
<field name="act_window" ref="act_maintenance_service_calendar"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.view"
|
||||
id="act_maintenance_calendar_view2">
|
||||
<field name="sequence" eval="20"/>
|
||||
<field name="view" ref="maintenance_service_view_form"/>
|
||||
<field name="act_window" ref="act_maintenance_service_calendar"/>
|
||||
</record>
|
||||
<menuitem parent="menu_equipment"
|
||||
action="act_maintenance_service_calendar"
|
||||
sequence="10"
|
||||
id="menu_agenda_form"/>
|
||||
<menuitem parent="menu_equipment"
|
||||
action="act_maintenance_service_form"
|
||||
sequence="10"
|
||||
id="menu_maintenance_service_form"/>
|
||||
<menuitem parent="menu_maintenance_service_form"
|
||||
action="act_maintenance_form"
|
||||
sequence="40"
|
||||
id="menu_maintenance_form"/>
|
||||
|
||||
</data>
|
||||
</tryton>
|
||||
|
143
sale.py
143
sale.py
@ -18,7 +18,11 @@ class Sale(metaclass=PoolMeta):
|
||||
'Sale'
|
||||
__name__ = 'sale.sale'
|
||||
|
||||
"""
|
||||
agended = fields.Boolean("Scheduling")
|
||||
sale_type = fields.Selection([('maintenance', 'Maintenance'),
|
||||
('equipments', 'Equipos'),
|
||||
('replaces', 'Replaces')], "Sale Type", required=True)
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
@Workflow.transition('confirmed')
|
||||
@ -26,31 +30,33 @@ class Sale(metaclass=PoolMeta):
|
||||
def confirm(cls, sales):
|
||||
pool = Pool()
|
||||
Configuration = pool.get('sale.configuration')
|
||||
transaction = Transaction()
|
||||
context = transaction.context
|
||||
cls.set_sale_date(sales)
|
||||
cls.store_cache(sales)
|
||||
config = Configuration(1)
|
||||
|
||||
pool = Pool()
|
||||
Equipments = pool.get('optical_equipment.equipment')
|
||||
|
||||
MaintenanceService = pool.get('optical_equipment.maintenance.service')
|
||||
for sale in sales:
|
||||
for line in sale.lines:
|
||||
if line.equipment:
|
||||
equipment=line.equipment
|
||||
equipment.propietary=sale.party.id
|
||||
equipment.propietary_address=sale.shipment_address.id
|
||||
equipment.state="uncontrated"
|
||||
equipment.sale_destination = line
|
||||
equipment.maintenance_frequency = "6" if sale.party.client_type == "ips" else "12"
|
||||
equipment.save()
|
||||
maintenanceService = MaintenanceService(
|
||||
maintenance_type='preventive',
|
||||
state_agended='no_agenda',
|
||||
propietary=cls.party,
|
||||
propietary_address=cls.shipment_address,
|
||||
state="draft"
|
||||
)
|
||||
#raise UserError(str(dir(maintenanceService)))
|
||||
maintenanceService.save()
|
||||
cls.agended = True
|
||||
sale.save()
|
||||
|
||||
with Transaction().set_context(
|
||||
queue_name='sale',
|
||||
queue_scheduled_at=config.sale_process_after):
|
||||
with transaction.set_context(
|
||||
queue_scheduled_at=config.sale_process_after,
|
||||
queue_batch=context.get('queue_batch', True)):
|
||||
cls.__queue__.process(sales)
|
||||
|
||||
|
||||
|
||||
class SaleLine(metaclass=PoolMeta):
|
||||
'SaleLine'
|
||||
__name__ = 'sale.line'
|
||||
@ -69,10 +75,15 @@ class SaleLine(metaclass=PoolMeta):
|
||||
'on_change_with_unit_digits')
|
||||
|
||||
|
||||
|
||||
@classmethod
|
||||
def __setup__(cls):
|
||||
super(SaleLine, cls).__setup__()
|
||||
cls.quantity.states['readonly'] = If(Eval('product_equipment') == True, True)
|
||||
#raise UserError(str(Eval('_parent_sale', {}).get('sale_type')))
|
||||
if Eval('_parent_sale', {}).get('sale_type') == 'maintenance':
|
||||
cls.product.domain + [('type', '=', 'service'),
|
||||
('maintenance_activity', '=', True)]
|
||||
|
||||
@fields.depends('product_equipment','equipment')
|
||||
def get_serial_equipment(self):
|
||||
@ -239,103 +250,3 @@ class SaleLine(metaclass=PoolMeta):
|
||||
('//page[@id="equipment"]', 'states', {
|
||||
'invisible': ~Eval('product_equipment', True),
|
||||
})]
|
||||
|
||||
|
||||
|
||||
class CreateSubscriptionStart(ModelView):
|
||||
'Create Subscription Start'
|
||||
__name__ = 'sale.create.subscription.start'
|
||||
|
||||
start_date = fields.Date("Start Date", required=True)
|
||||
end_date = fields.Date("End Date", required=True)
|
||||
invoice_recurrence = fields.Many2One('sale.subscription.recurrence.rule.set',
|
||||
"Invoice Recurrence",required=True)
|
||||
invoice_start_date = fields.Date("Invoice Start Date",
|
||||
help='Billing start date')
|
||||
service = fields.Many2One('sale.subscription.service', "Service")
|
||||
quantity = fields.Float("Quantity", digits='unit')
|
||||
unit_price = Monetary("Unit Price", currency='currency',
|
||||
digits=price_digits,
|
||||
)
|
||||
|
||||
@classmethod
|
||||
def default_start_date(cls):
|
||||
pool = Pool()
|
||||
Date = pool.get('ir.date')
|
||||
return Date.today()
|
||||
|
||||
@classmethod
|
||||
@fields.depends(methods=['default_start_date'])
|
||||
def default_invoice_start_date(self):
|
||||
invoice_start_date = self.default_start_date()
|
||||
|
||||
return invoice_start_date
|
||||
|
||||
class CreateSubscription(Wizard):
|
||||
'Create Subscription'
|
||||
__name__ = 'sale.create.subscription'
|
||||
|
||||
start = StateView('sale.create.subscription.start',
|
||||
'optical_equipment.create_subscription_view_form',[
|
||||
Button('Cancel', 'end', 'tryton-cancel'),
|
||||
Button('Create', 'create_subscription', 'tryton-ok', default=True),
|
||||
])
|
||||
create_subscription = StateAction('sale_subscription.act_subscription_form')
|
||||
|
||||
done_ = StateView('sale.create.subscription.start',
|
||||
'optical_equipment.create_subscription_view_form',[
|
||||
Button('Done', 'end', 'tryton-cancel'),
|
||||
])
|
||||
@property
|
||||
def _subscription_start(self):
|
||||
return dict(start_date=self.start.start_date,
|
||||
end_date=self.start.end_date,
|
||||
invoice_recurrence=self.start.invoice_recurrence,
|
||||
invoice_start_date=self.start.invoice_start_date,
|
||||
service=self.start.service,
|
||||
quantity=self.start.quantity,
|
||||
unit_price=self.start.unit_price)
|
||||
|
||||
def _equipments_to_subscription(self):
|
||||
sale = self.records[0]
|
||||
equipments_to_subscription = []
|
||||
for line in sale.lines:
|
||||
if line.product_equipment:
|
||||
equipments_to_subscription.append(line.equipment)
|
||||
|
||||
return equipments_to_subscription
|
||||
|
||||
def do_create_subscription(self, action):
|
||||
pool = Pool()
|
||||
Subscription = pool.get('sale.subscription')
|
||||
SubscriptionLine = pool.get('sale.subscription.line')
|
||||
|
||||
sale = self.records[0]
|
||||
a = self._subscription_start
|
||||
|
||||
equipments_to_subscription=self._equipments_to_subscription()
|
||||
subscription_lines = [SubscriptionLine(
|
||||
start_date=a['start_date'],
|
||||
end_date=a['end_date'],
|
||||
consumption_recurrence=a['invoice_recurrence'],
|
||||
service=a['service'],
|
||||
unit=a['service'].product.default_uom,
|
||||
quantity=a['quantity'],
|
||||
unit_price=a['unit_price']
|
||||
)]
|
||||
|
||||
subscription = Subscription(
|
||||
start_date=a['start_date'],
|
||||
end_date=a['end_date'],
|
||||
invoice_recurrence=a['invoice_recurrence'],
|
||||
invoice_start_date=a['invoice_start_date'],
|
||||
party=sale.party.id,
|
||||
contact=sale.contact.id if sale.contact else None,
|
||||
invoice_party=sale.invoice_party.id if sale.invoice_party else None,
|
||||
invoice_address=sale.invoice_address.id,
|
||||
payment_term=sale.payment_term.id if sale.payment_term else None,
|
||||
lines=subscription_lines,
|
||||
equipments=equipments_to_subscription,
|
||||
)
|
||||
subscription.save()
|
||||
"""
|
||||
|
13
sale.xml
13
sale.xml
@ -1,7 +1,11 @@
|
||||
<?xml version="1.0"?>
|
||||
<!--This file file is part of Tryton. The COPYRIGHT file at the top level of this repository contains the full copyright notices and license terms. -->
|
||||
<tryton>
|
||||
<!--
|
||||
<record model="ir.ui.view" id="sale_view_form">
|
||||
<field name="model">sale.sale</field>
|
||||
<field name="inherit" ref="sale.sale_view_form"/>
|
||||
<field name="name">sale_form</field>
|
||||
</record>
|
||||
<record model="ir.ui.view" id="sale_line_view_form">
|
||||
<field name="model">sale.line</field>
|
||||
<field name="inherit" ref="sale.sale_line_view_form"/>
|
||||
@ -16,8 +20,8 @@
|
||||
<field name="model">sale.line</field>
|
||||
<field name="inherit" ref="sale.sale_line_view_tree_sequence"/>
|
||||
<field name="name">sale_line_tree_sequence</field>
|
||||
</record>
|
||||
|
||||
</record>
|
||||
<!--
|
||||
<record model="ir.ui.view" id="create_subscription_view_form">
|
||||
<field name="model">sale.create.subscription.start</field>
|
||||
<field name="type">form</field>
|
||||
@ -32,6 +36,5 @@
|
||||
<field name="keyword">form_action</field>
|
||||
<field name="model">sale.sale,-1</field>
|
||||
<field name="action" ref="create_subscription"/>
|
||||
</record>
|
||||
-->
|
||||
</record>-->
|
||||
</tryton>
|
||||
|
116
subscription.py
116
subscription.py
@ -75,7 +75,13 @@ class Contract(ModelSQL, ModelView):
|
||||
('state', '=', 'uncontrated')]
|
||||
])
|
||||
|
||||
|
||||
@classmethod
|
||||
def __setup__(cls):
|
||||
super(Contract, cls).__setup__()
|
||||
cls._buttons.update({
|
||||
'quotation': {'invisible': Eval('state').in_(['quotation', 'running', 'closed', 'cancelled'])},
|
||||
'run': {'invisible': Eval('state').in_(['draft', 'running', 'closed', 'cancelled'])}
|
||||
})
|
||||
|
||||
@staticmethod
|
||||
def default_company():
|
||||
@ -85,17 +91,58 @@ class Contract(ModelSQL, ModelView):
|
||||
def default_state():
|
||||
return 'draft'
|
||||
|
||||
# @classmethod
|
||||
# @ModelView.button
|
||||
# def run(cls, subscription):
|
||||
# for equipment in cls.equipments:
|
||||
# if equipment.state == "contrated":
|
||||
# #aise UserError(str("El equipo"+str(equipment.number)
|
||||
# # +"No puede pertencer a este contrato porque
|
||||
# # ya se encuentra en un contrato"))
|
||||
# else:
|
||||
# continue
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
def quotation(self, contract):
|
||||
#raise UserError(str(self))
|
||||
pool = Pool()
|
||||
Subscription = pool.get('sale.subscription')
|
||||
#raise UserError(str((subscription[0].equipments)))
|
||||
for equipment in contract[0].equipments:
|
||||
if equipment.state == "contrated":
|
||||
raise UserError(str("El equipo"+str(equipment.number) +
|
||||
"No puede pertencer a este contrato porque ya se encuentra en un contrato"))
|
||||
else:
|
||||
continue
|
||||
|
||||
#raise UserError(str((contract[0].prorogues)))
|
||||
if contract[0].contract and contract[0].prorogues == ():
|
||||
#raise UserError(str(contract[0].contract))
|
||||
Subscription.quote([contract[0].contract])
|
||||
Subscription.run([contract[0].contract])
|
||||
else:
|
||||
IdProrogues = set()
|
||||
for ide in contract[0].prorogues:
|
||||
IdProrogues.add(ide.id)
|
||||
|
||||
subscription = Subscription.search([('state', '=', 'draft'),
|
||||
('id', 'in', IdProrogues)])
|
||||
|
||||
raise UserError(str(subscription))
|
||||
#raise UserError(str(list(contract[0].prorogues)))
|
||||
raise UserError(str(list(contract[0].prorogues).find(['state', '=', 'draft'])))
|
||||
|
||||
|
||||
@classmethod
|
||||
@ModelView.button
|
||||
def run(cls, subscription):
|
||||
pool = Pool()
|
||||
Subscription = pool.get('sale.subscription')
|
||||
|
||||
if subscription.state == 'quotation':
|
||||
Subscription.run(subscription)
|
||||
elif subscription.state == 'draft':
|
||||
for equipment in cls.equipments:
|
||||
if equipment.state == "contrated":
|
||||
raise UserError(str("El equipo"+str(equipment.number) +
|
||||
"No puede pertencer a este contrato porque ya se encuentra en un contrato"))
|
||||
else:
|
||||
continue
|
||||
|
||||
Subscription.quotation(subscription)
|
||||
Subscription.run(subscription)
|
||||
|
||||
Subscription.quotation(subscription)
|
||||
|
||||
|
||||
class CreateInitialContract(ModelView):
|
||||
@ -142,7 +189,8 @@ class CreateInitialContract(ModelView):
|
||||
'equipment', "Equipments", required=True,
|
||||
domain=[['OR',
|
||||
('state', '=', 'registred'),
|
||||
('state', '=', 'uncontrated')]
|
||||
('state', '=', 'uncontrated')],
|
||||
('propietary', '=', Eval('party'))
|
||||
])
|
||||
|
||||
@staticmethod
|
||||
@ -276,10 +324,13 @@ class CreateNextProrogue(ModelView):
|
||||
__name__ = 'optical_equipment_prorogue.next'
|
||||
|
||||
party = fields.Many2One('party.party', "Party", required=True,
|
||||
domain=[('party', '=', Eval('party'))],
|
||||
help="The party who subscribes.")
|
||||
initial_contract = fields.Many2One('optical_equipment.contract', "Initial Contract")
|
||||
contact = fields.Many2One('party.contact_mechanism', "Contact")
|
||||
initial_contract = fields.Many2One('optical_equipment.contract', "Initial Contract", required=True,
|
||||
domain=[('party', '=', Eval('party')),
|
||||
('state', '=', "closed")],
|
||||
depends=['party'])
|
||||
contact = fields.Many2One('party.contact_mechanism', "Contact", required=True,
|
||||
domain=[('party', '=', Eval('party'))])
|
||||
invoice_address = fields.Many2One('party.address', 'Invoice Address',
|
||||
required=True, domain=[('party', '=', Eval('party'))])
|
||||
invoice_recurrence = fields.Many2One('sale.subscription.recurrence.rule.set', "Invoice Recurrence",
|
||||
@ -294,9 +345,11 @@ class CreateNextProrogue(ModelView):
|
||||
Eval('start_date', datetime.date.min),
|
||||
datetime.date.min)),
|
||||
('end_date', '=', None),
|
||||
])
|
||||
],
|
||||
depends=['invoice_start_date'])
|
||||
invoice_start_date = fields.Date("Invoice Start Date", required=True,
|
||||
help='Billing start date')
|
||||
help='Billing start date',
|
||||
depends=['start_date'])
|
||||
service = fields.Many2One('sale.subscription.service', "Service", required=True)
|
||||
quantity = fields.Float("Quantity", digits='unit', required=True)
|
||||
unit_price = Monetary("Unit Price", currency='currency',
|
||||
@ -306,9 +359,16 @@ class CreateNextProrogue(ModelView):
|
||||
'equipment', "Equipments", required=True,
|
||||
domain=[['OR',
|
||||
('state', '=', 'registred'),
|
||||
('state', '=', 'uncontrated')]
|
||||
('state', '=', 'uncontrated')],
|
||||
('propietary', '=', Eval('party'))
|
||||
])
|
||||
|
||||
|
||||
@fields.depends('party', 'contact')
|
||||
def on_change_party(self):
|
||||
self.contact = None
|
||||
self.initial_contract = None
|
||||
|
||||
@fields.depends('initial_contract', 'party', 'contact', 'invoice_address',
|
||||
'invoice_recurrence', 'start_date', 'end_date',
|
||||
'equipments')
|
||||
@ -318,8 +378,8 @@ class CreateNextProrogue(ModelView):
|
||||
self.party = contract.party.id
|
||||
self.contact = contract.contact.id
|
||||
self.invoice_address = contract.invoice_address.id
|
||||
self.invoice_recurrence = contract.invoice_recurrence.id
|
||||
self.start_date = contract.end_date
|
||||
self.invoice_start_date = contract.end_date
|
||||
self.equipments = contract.equipments
|
||||
else:
|
||||
self.party = None
|
||||
@ -329,6 +389,24 @@ class CreateNextProrogue(ModelView):
|
||||
self.start_date = None
|
||||
self.equipments = []
|
||||
|
||||
@fields.depends('invoice_recurrence', 'start_date')
|
||||
def on_change_invoice_recurrence(self):
|
||||
if self.invoice_recurrence and self.invoice_recurrence.rules[0].freq == "yearly":
|
||||
#pool = Pool()
|
||||
#Date = pool.get('ir.date')
|
||||
self.end_date = self.start_date + timedelta(days=365)
|
||||
#self.end_date = Date.today() + timedelta(days=365)
|
||||
elif self.invoice_recurrence == None:
|
||||
self.end_date = None
|
||||
|
||||
|
||||
@fields.depends('invoice_start_date', 'start_date')
|
||||
def on_change_start_date(self):
|
||||
self.invoice_start_date = self.start_date
|
||||
|
||||
@classmethod
|
||||
def default_quantity(self):
|
||||
return 1
|
||||
|
||||
class CreateProrogue(Wizard):
|
||||
'Create Prorogue'
|
||||
|
@ -51,6 +51,13 @@
|
||||
<field name="domain" eval="[('state', '=', 'running')]" pyson="1"/>
|
||||
<field name="act_window" ref="act_contract_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain"
|
||||
id="act_contract_form_domain_closed">
|
||||
<field name="name">Closed</field>
|
||||
<field name="sequence" eval="40"/>
|
||||
<field name="domain" eval="[('state', '=', 'closed')]" pyson="1"/>
|
||||
<field name="act_window" ref="act_contract_form"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain"
|
||||
id="act_contract_form_domain_all">
|
||||
<field name="name">All</field>
|
||||
@ -113,6 +120,19 @@
|
||||
<field name="name">run</field>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.contract')]"/>
|
||||
</record>
|
||||
<record model="ir.action.act_window.domain"
|
||||
id="act_subscription_form_domain_closed">
|
||||
<field name="name">Closed</field>
|
||||
<field name="sequence" eval="40"/>
|
||||
<field name="domain" eval="[('state', '=', 'closed')]" pyson="1"/>
|
||||
<field name="act_window" ref="sale_subscription.act_subscription_form"/>
|
||||
</record>
|
||||
<record model="ir.model.button" id="quotation_contract_button">
|
||||
<field name="name">quotation</field>
|
||||
<field name="string">Quotation</field>
|
||||
<field name="confirm">Are you sure you want to quote these subscription?</field>
|
||||
<field name="model" search="[('model', '=', 'optical_equipment.contract')]"/>
|
||||
</record>
|
||||
<menuitem
|
||||
name="Contracts Management"
|
||||
sequence="50"
|
||||
|
@ -40,4 +40,9 @@ this repository contains the full copyright notices and license terms. -->
|
||||
</notebook>
|
||||
<label name="state"/>
|
||||
<field name="state"/>
|
||||
<group col="2" colspan="2" id="button">
|
||||
<!--<button name="draft"/> -->
|
||||
<button name="quotation"/>
|
||||
<button name="run"/>
|
||||
</group>
|
||||
</form>
|
||||
|
@ -3,24 +3,27 @@
|
||||
this repository contains the full copyright notices and license terms. -->
|
||||
<form>
|
||||
<group id="create_prorogue">
|
||||
<label name="initial_contract"/>
|
||||
<field name="initial_contract" colspan="3"/>
|
||||
<label name="party"/>
|
||||
<field name="party"/>
|
||||
<label name="contact"/>
|
||||
<field name="contact"/>
|
||||
<newline/>
|
||||
<label name="initial_contract"/>
|
||||
<field name="initial_contract" colspan="3"/>
|
||||
<label name="invoice_address"/>
|
||||
<field name="invoice_address"/>
|
||||
<label name="payment_term"/>
|
||||
<field name="payment_term"/>
|
||||
<label name="contact"/>
|
||||
<field name="contact"/>
|
||||
<newline/>
|
||||
<label name="invoice_recurrence"/>
|
||||
<field name="invoice_recurrence"/>
|
||||
<newline/>
|
||||
<label name="start_date"/>
|
||||
<field name="start_date"/>
|
||||
<label name="end_date"/>
|
||||
<field name="end_date"/>
|
||||
<label name="invoice_start_date"/>
|
||||
<field name="invoice_start_date"/>
|
||||
<label name="invoice_recurrence"/>
|
||||
<field name="invoice_recurrence"/>
|
||||
<label name="service"/>
|
||||
<field name="service"/>
|
||||
<label name="quantity"/>
|
||||
|
@ -52,8 +52,7 @@
|
||||
<newline/>
|
||||
<label name="state"/>
|
||||
<field name="state"/>
|
||||
<group col="4" colspan="4" id="button">
|
||||
<button name="draft"/>
|
||||
<group id="button">
|
||||
<button name="agended"/>
|
||||
<button name="in_progress"/>
|
||||
<button name="finished"/>
|
||||
|
@ -3,7 +3,7 @@
|
||||
this repository contains the full copyright notices and license terms.-->
|
||||
<tree>
|
||||
<field name="code"/>
|
||||
<field name="company"/>
|
||||
<field name="maintenance_type" expand="0"/>
|
||||
<field name="propietary"/>
|
||||
<field name="propietary_address"/>
|
||||
<field name="equipment"/>
|
||||
|
@ -3,22 +3,10 @@
|
||||
this repository contains the full copyright notices and license terms.-->
|
||||
<tree>
|
||||
<field name="code"/>
|
||||
<field name="company"/>
|
||||
<field name="location"/>
|
||||
<field name="propietary"/>
|
||||
<field name="propietary_address"/>
|
||||
<field name="product"/>
|
||||
<field name="equipment_type"/>
|
||||
<field name="use"/>
|
||||
<field name="biomedical_class"/>
|
||||
<field name="calibration"/>
|
||||
<field name="product" expand="1"/>
|
||||
<field name="mark_category"/>
|
||||
<field name="model_category"/>
|
||||
<field name="refurbish"/>
|
||||
<field name="software_version"/>
|
||||
<field name="useful_life"/>
|
||||
<field name="warranty"/>
|
||||
<field name="serial"/>
|
||||
<field name="health_register"/>
|
||||
<field name="origin_country"/>
|
||||
</tree>
|
||||
|
@ -1,6 +1,7 @@
|
||||
<?xml version="1.0"?>
|
||||
<!--This file file is part of Tryton. The COPYRIGHT file at the top level of this repository contains the full copyright notices and license terms. -->
|
||||
<data>
|
||||
<!--
|
||||
<xpath
|
||||
expr="/form/notebook/page[@id='notes']" position="before">
|
||||
<page string="Equipment" id="equipment">
|
||||
@ -17,5 +18,5 @@
|
||||
<field name="equipment"/>
|
||||
<label name="equipment_serial"/>
|
||||
<field name="equipment_serial"/>
|
||||
</xpath>
|
||||
</xpath>-->
|
||||
</data>
|
||||
|
Loading…
Reference in New Issue
Block a user