summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAzka Nathan <darizkyfaz@gmail.com>2024-07-04 11:54:41 +0700
committerAzka Nathan <darizkyfaz@gmail.com>2024-07-04 11:54:41 +0700
commit17e4deaaa9b274069e2ee01c2cdba7630532b68b (patch)
tree70bddc3d5b52fe9b527fde25d50e07f582c2ee0f
parentdee0f12ed114837636d34824f86e5bfa2e055eb0 (diff)
shipment group
-rwxr-xr-xindoteknik_custom/__manifest__.py1
-rwxr-xr-xindoteknik_custom/models/__init__.py1
-rw-r--r--indoteknik_custom/models/shipment_group.py58
-rwxr-xr-xindoteknik_custom/security/ir.model.access.csv2
-rw-r--r--indoteknik_custom/views/ir_sequence.xml10
-rw-r--r--indoteknik_custom/views/shipment_group.xml65
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>