diff options
| author | Azka Nathan <darizkyfaz@gmail.com> | 2024-07-04 11:54:41 +0700 |
|---|---|---|
| committer | Azka Nathan <darizkyfaz@gmail.com> | 2024-07-04 11:54:41 +0700 |
| commit | 17e4deaaa9b274069e2ee01c2cdba7630532b68b (patch) | |
| tree | 70bddc3d5b52fe9b527fde25d50e07f582c2ee0f | |
| parent | dee0f12ed114837636d34824f86e5bfa2e055eb0 (diff) | |
shipment group
| -rwxr-xr-x | indoteknik_custom/__manifest__.py | 1 | ||||
| -rwxr-xr-x | indoteknik_custom/models/__init__.py | 1 | ||||
| -rw-r--r-- | indoteknik_custom/models/shipment_group.py | 58 | ||||
| -rwxr-xr-x | indoteknik_custom/security/ir.model.access.csv | 2 | ||||
| -rw-r--r-- | indoteknik_custom/views/ir_sequence.xml | 10 | ||||
| -rw-r--r-- | indoteknik_custom/views/shipment_group.xml | 65 |
6 files changed, 137 insertions, 0 deletions
diff --git a/indoteknik_custom/__manifest__.py b/indoteknik_custom/__manifest__.py index 67f16800..4a37414f 100755 --- a/indoteknik_custom/__manifest__.py +++ b/indoteknik_custom/__manifest__.py @@ -135,6 +135,7 @@ 'views/logbook_bill.xml', 'views/report_logbook_bill.xml', 'views/sale_order_multi_uangmuka_penjualan.xml', + 'views/shipment_group.xml', 'report/report.xml', 'report/report_banner_banner.xml', 'report/report_banner_banner2.xml', diff --git a/indoteknik_custom/models/__init__.py b/indoteknik_custom/models/__init__.py index ffd1b645..10f4acee 100755 --- a/indoteknik_custom/models/__init__.py +++ b/indoteknik_custom/models/__init__.py @@ -120,3 +120,4 @@ from . import purchase_order_multi_uangmuka2 from . import logbook_bill from . import report_logbook_bill from . import sale_order_multi_uangmuka_penjualan +from . import shipment_group diff --git a/indoteknik_custom/models/shipment_group.py b/indoteknik_custom/models/shipment_group.py new file mode 100644 index 00000000..bc593437 --- /dev/null +++ b/indoteknik_custom/models/shipment_group.py @@ -0,0 +1,58 @@ +from odoo import models, api, fields +from odoo.exceptions import AccessError, UserError, ValidationError +from datetime import timedelta, date +import logging + +_logger = logging.getLogger(__name__) + +class ShipmentGroup(models.Model): + _name = "shipment.group" + _description = "Shipment Group" + _inherit = ['mail.thread'] + _rec_name = 'number' + + number = fields.Char(string='Document No', index=True, copy=False, readonly=True, tracking=True) + shipment_line = fields.One2many('shipment.group.line', 'shipment_id', string='Shipment Group Lines', auto_join=True) + + @api.model + def create(self, vals): + vals['number'] = self.env['ir.sequence'].next_by_code('shipment.group') or '0' + result = super(ShipmentGroup, self).create(vals) + return result + +class ShipmentGroupLine(models.Model): + _name = 'shipment.group.line' + _description = 'Shipment Group Line' + _order = 'shipment_id, id' + + shipment_id = fields.Many2one('shipment.group', string='Shipment Ref', required=True, ondelete='cascade', index=True, copy=False) + partner_id = fields.Many2one('res.partner', string='Customer') + picking_id = fields.Many2one('stock.picking', string='Picking') + sale_id = fields.Many2one('sale.order', string='Sale Order') + state = fields.Char(string='Status', readonly=True, compute='_get_state') + + def _get_state(self): + for rec in self: + if rec.picking_id.state == 'assigned': + rec.state = 'Ready' + elif rec.picking_id.state == 'done': + rec.state = 'Done' + elif rec.picking_id.state == 'cancel': + rec.state = 'Cancelled' + elif rec.picking_id.state == 'confirmed': + rec.state = 'Waiting' + elif rec.picking_id.state == 'waiting': + rec.state = 'Waiting Another Operation' + else: + rec.state = 'draft' + + @api.onchange('picking_id') + def onchange_picking_id(self): + picking = self.env['stock.picking'].search([('id', '=', self.picking_id.id)], limit=1) + + self.partner_id = picking.partner_id + + self.state = picking.state + + self.sale_id = picking.sale_id + diff --git a/indoteknik_custom/security/ir.model.access.csv b/indoteknik_custom/security/ir.model.access.csv index 30bc7d06..d33ec5e3 100755 --- a/indoteknik_custom/security/ir.model.access.csv +++ b/indoteknik_custom/security/ir.model.access.csv @@ -128,3 +128,5 @@ access_report_logbook_bill,access.report.logbook.sj,model_report_logbook_bill,,1 access_report_logbook_bill_line,access.report.logbook.sj.line,model_report_logbook_bill_line,,1,1,1,1 access_report_logbook_bill_line,access.report.logbook.sj.line,model_report_logbook_bill_line,,1,1,1,1 access_sale_order_multi_uangmuka_penjualan,access.sale.order.multi_uangmuka_penjualan,model_sale_order_multi_uangmuka_penjualan,,1,1,1,1 +access_shipment_group,access.shipment.group,model_shipment_group,,1,1,1,1 +access_shipment_group_line,access.shipment.group.line,model_shipment_group_line,,1,1,1,1 diff --git a/indoteknik_custom/views/ir_sequence.xml b/indoteknik_custom/views/ir_sequence.xml index 40ce135c..b4fb5c0c 100644 --- a/indoteknik_custom/views/ir_sequence.xml +++ b/indoteknik_custom/views/ir_sequence.xml @@ -21,6 +21,16 @@ <field name="number_increment">1</field> </record> + <record id="sequence_shipment_group" model="ir.sequence"> + <field name="name">Shipment Group</field> + <field name="code">shipment.group</field> + <field name="active">TRUE</field> + <field name="prefix">SG/%(year)s/</field> + <field name="padding">5</field> + <field name="number_next">1</field> + <field name="number_increment">1</field> + </record> + <record id="sequence_logbook_bill" model="ir.sequence"> <field name="name">Logbook Bill</field> <field name="code">report.logbook.bill</field> diff --git a/indoteknik_custom/views/shipment_group.xml b/indoteknik_custom/views/shipment_group.xml new file mode 100644 index 00000000..33d08920 --- /dev/null +++ b/indoteknik_custom/views/shipment_group.xml @@ -0,0 +1,65 @@ +<?xml version="1.0" encoding="UTF-8"?> +<odoo> + <record id="shipment_group_tree" model="ir.ui.view"> + <field name="name">shipment.group.tree</field> + <field name="model">shipment.group</field> + <field name="arch" type="xml"> + <tree default_order="create_date desc"> + <field name="number"/> + </tree> + </field> + </record> + + <record id="shipment_group_line_tree" model="ir.ui.view"> + <field name="name">shipment.group.line.tree</field> + <field name="model">shipment.group.line</field> + <field name="arch" type="xml"> + <tree editable="bottom"> + <field name="picking_id" required="1"/> + <field name="partner_id" readonly="1"/> + <field name="sale_id" readonly="1"/> + <field name="state" readonly="1"/> + </tree> + </field> + </record> + + <record id="shipment_group_form" model="ir.ui.view"> + <field name="name">shipment.group.form</field> + <field name="model">shipment.group</field> + <field name="arch" type="xml"> + <form> + <sheet> + <group> + <group> + <field name="number" readonly="1"/> + </group> + </group> + <notebook> + <page string="Line"> + <field name="shipment_line"/> + </page> + </notebook> + </sheet> + <div class="oe_chatter"> + <field name="message_follower_ids" widget="mail_followers"/> + <field name="message_ids" widget="mail_thread"/> + </div> + </form> + </field> + </record> + + <record id="shipment_group_action" model="ir.actions.act_window"> + <field name="name">Shipment Group</field> + <field name="type">ir.actions.act_window</field> + <field name="res_model">shipment.group</field> + <field name="view_mode">tree,form</field> + </record> + + <menuitem + action="shipment_group_action" + id="shipment_group" + parent="stock.menu_stock_warehouse_mgmt" + name="Shipment Group" + sequence="1" + /> +</odoo> |
