summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAzka Nathan <darizkyfaz@gmail.com>2023-07-14 16:40:27 +0700
committerAzka Nathan <darizkyfaz@gmail.com>2023-07-14 16:40:27 +0700
commit855f63e1c39ba1ff4d84360845949bc260462c83 (patch)
tree863e5c637ea589771859072c350f3c63b3faefed
parent94ff2a962740492614b5f1f09e690ef8dd0b2874 (diff)
bill receipt
-rwxr-xr-xindoteknik_custom/__manifest__.py1
-rwxr-xr-xindoteknik_custom/models/__init__.py3
-rw-r--r--indoteknik_custom/models/bill_receipt.py70
-rwxr-xr-xindoteknik_custom/security/ir.model.access.csv2
-rw-r--r--indoteknik_custom/views/bill_receipt.xml76
-rw-r--r--indoteknik_custom/views/ir_sequence.xml10
6 files changed, 161 insertions, 1 deletions
diff --git a/indoteknik_custom/__manifest__.py b/indoteknik_custom/__manifest__.py
index 4fa736f6..f91b33d7 100755
--- a/indoteknik_custom/__manifest__.py
+++ b/indoteknik_custom/__manifest__.py
@@ -79,6 +79,7 @@
'views/landedcost.xml',
'views/product_sla.xml',
'views/voucher.xml',
+ 'views/bill_receipt.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 9e4d2cf9..8b3296a5 100755
--- a/indoteknik_custom/models/__init__.py
+++ b/indoteknik_custom/models/__init__.py
@@ -66,4 +66,5 @@ from . import requisition
from . import token_storage
from . import product_sla
from . import account_move_due_extension
-from . import voucher \ No newline at end of file
+from . import voucher
+from . import bill_receipt \ No newline at end of file
diff --git a/indoteknik_custom/models/bill_receipt.py b/indoteknik_custom/models/bill_receipt.py
new file mode 100644
index 00000000..31c09b33
--- /dev/null
+++ b/indoteknik_custom/models/bill_receipt.py
@@ -0,0 +1,70 @@
+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 BillReceipt(models.Model):
+ _name = "bill.receipt"
+ _description = "Bill Receipt"
+ _rec_name = 'number'
+
+ number = fields.Char(string='Document No', index=True, copy=False, readonly=True, tracking=True)
+ vendor_id = fields.Many2one('res.partner', string="Vendor")
+ document_date = fields.Date(string="Document Date")
+ description = fields.Text(string='Description')
+ validated = fields.Boolean(string="Validated", readonly=True)
+ bill_line = fields.One2many('bill.receipt.line', 'bill_id', string='Bill Receipt Lines')
+
+ @api.model
+ def create(self, vals):
+ vals['number'] = self.env['ir.sequence'].next_by_code('due.extension') or '0'
+ result = super(BillReceipt, self).create(vals)
+ return result
+
+ def validate_button(self):
+ if not self.bill_line:
+ raise UserError('Bill receipt line masih kosong')
+
+ self.validated = True
+
+ def cancel_button(self):
+ if not self.bill_line:
+ raise UserError('Bill receipt line masih kosong')
+
+ if self.validated != True:
+ raise UserError('Document ini belum di validate')
+
+ self.validated = False
+
+class BillReceiptLine(models.Model):
+ _name = 'bill.receipt.line'
+ _description = 'Bill Receipt Line'
+ _order = 'bill_id, id'
+
+ bill_id = fields.Many2one('bill.receipt', string='Bill Receipt')
+ po_id = fields.Many2one('purchase.order', string='PO')
+ sale_order_id = fields.Many2one('sale.order', string='Sale Order')
+ user_id = fields.Many2one('res.users', string='Purchase Rep')
+ payment_term_id = fields.Many2one('account.payment.term', string='Payment Terms')
+ amount_total = fields.Float(string='Total')
+ reference = fields.Char(string='Reference')
+
+ @api.onchange('po_id')
+ def onchange_user_id(self):
+ self.user_id = self.po_id.user_id
+
+ @api.onchange('po_id')
+ def onchange_sale_order_id(self):
+ self.sale_order_id = self.po_id.sale_order_id
+
+ @api.onchange('po_id')
+ def onchange_payment_term_id(self):
+ self.payment_term_id = self.po_id.payment_term_id
+
+ @api.onchange('po_id')
+ def onchange_amount_total(self):
+ self.amount_total = self.po_id.amount_total
+
+
diff --git a/indoteknik_custom/security/ir.model.access.csv b/indoteknik_custom/security/ir.model.access.csv
index 2b269417..379c4c8e 100755
--- a/indoteknik_custom/security/ir.model.access.csv
+++ b/indoteknik_custom/security/ir.model.access.csv
@@ -57,3 +57,5 @@ access_requisition_purchase_match,access.requisition.purchase.match,model_requis
access_token_storage,access.token_storage,model_token_storage,,1,1,1,1
access_product_sla,access.product_sla,model_product_sla,,1,1,1,1
access_voucher,access.voucher,model_voucher,,1,1,1,1
+access_bill_receipt,access.bill.receipt,model_bill_receipt,,1,1,1,1
+access_bill_receipt_line,access.bill.receipt.line,model_bill_receipt_line,,1,1,1,1
diff --git a/indoteknik_custom/views/bill_receipt.xml b/indoteknik_custom/views/bill_receipt.xml
new file mode 100644
index 00000000..6e27ee12
--- /dev/null
+++ b/indoteknik_custom/views/bill_receipt.xml
@@ -0,0 +1,76 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<odoo>
+ <record id="bill_receipt_tree" model="ir.ui.view">
+ <field name="name">bill.receipt.tree</field>
+ <field name="model">bill.receipt</field>
+ <field name="arch" type="xml">
+ <tree>
+ <field name="number"/>
+ <field name="vendor_id"/>
+ <field name="document_date"/>
+ <field name="description"/>
+ <field name="validated"/>
+ </tree>
+ </field>
+ </record>
+
+ <record id="bill_receipt_form" model="ir.ui.view">
+ <field name="name">bill.receipt.form</field>
+ <field name="model">bill.receipt</field>
+ <field name="arch" type="xml">
+ <form>
+ <header>
+ <button name="validate_button"
+ string="Validate"
+ type="object"
+ />
+ <button name="cancel_button"
+ string="Cancel"
+ type="object"
+ />
+ </header>
+ <sheet>
+ <group>
+ <group>
+ <field name="vendor_id" attrs="{'readonly': [('validated', '=', True)]}"/>
+ <field name="document_date" attrs="{'readonly': [('validated', '=', True)]}"/>
+ <field name="description" attrs="{'readonly': [('validated', '=', True)]}"/>
+ </group>
+ <group>
+ <field name="validated" readonly="1"/>
+ </group>
+ </group>
+ <notebook>
+ <page string="Bill Line" name="bill_line">
+ <field name="bill_line" attrs="{'readonly': [('validated', '=', True)]}">
+ <tree editable="bottom">
+ <field name="po_id"/>
+ <field name="sale_order_id"/>
+ <field name="user_id"/>
+ <field name="payment_term_id"/>
+ <field name="amount_total"/>
+ <field name="reference"/>
+ </tree>
+ </field>
+ </page>
+ </notebook>
+ </sheet>
+ </form>
+ </field>
+ </record>
+
+ <record id="bill_receipt_action" model="ir.actions.act_window">
+ <field name="name">Bill Line</field>
+ <field name="type">ir.actions.act_window</field>
+ <field name="res_model">bill.receipt</field>
+ <field name="view_mode">tree,form</field>
+ </record>
+
+ <menuitem
+ id="menu_bill_receipt"
+ name="Bill Line"
+ parent="sale.product_menu_catalog"
+ sequence="4"
+ action="bill_receipt_action"
+ />
+</odoo>
diff --git a/indoteknik_custom/views/ir_sequence.xml b/indoteknik_custom/views/ir_sequence.xml
index a8348772..6798e5b4 100644
--- a/indoteknik_custom/views/ir_sequence.xml
+++ b/indoteknik_custom/views/ir_sequence.xml
@@ -41,6 +41,16 @@
<field name="number_increment">1</field>
</record>
+ <record id="sequence_bill_receipt" model="ir.sequence">
+ <field name="name">Bill Receipt</field>
+ <field name="code">bill.receipt</field>
+ <field name="active">TRUE</field>
+ <field name="prefix">BR/%(year)s/</field>
+ <field name="padding">5</field>
+ <field name="number_next">1</field>
+ <field name="number_increment">1</field>
+ </record>
+
<record id="sequence_requisition" model="ir.sequence">
<field name="name">Requisition</field>
<field name="code">requisition</field>