diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 17:14:58 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 17:14:58 +0700 |
| commit | 1ca3b3df3421961caec3b747a364071c80f5c7da (patch) | |
| tree | 6778a1f0f3f9b4c6e26d6d87ccde16e24da6c9d6 /v14_indoteknik/models | |
| parent | b57188be371d36d96caac4b8d65a40745c0e972c (diff) | |
initial commit
Diffstat (limited to 'v14_indoteknik/models')
| -rw-r--r-- | v14_indoteknik/models/__init__.py | 4 | ||||
| -rw-r--r-- | v14_indoteknik/models/account_move.py | 19 | ||||
| -rw-r--r-- | v14_indoteknik/models/account_period.py | 146 | ||||
| -rw-r--r-- | v14_indoteknik/models/export_product.py | 34 | ||||
| -rw-r--r-- | v14_indoteknik/models/manufacture.py | 26 | ||||
| -rw-r--r-- | v14_indoteknik/models/sale.py | 29 |
6 files changed, 258 insertions, 0 deletions
diff --git a/v14_indoteknik/models/__init__.py b/v14_indoteknik/models/__init__.py new file mode 100644 index 0000000..faa4a1e --- /dev/null +++ b/v14_indoteknik/models/__init__.py @@ -0,0 +1,4 @@ +# -*- coding: utf-8 -*- + +from . import account_period +from . import export_product
\ No newline at end of file diff --git a/v14_indoteknik/models/account_move.py b/v14_indoteknik/models/account_move.py new file mode 100644 index 0000000..5bacec6 --- /dev/null +++ b/v14_indoteknik/models/account_move.py @@ -0,0 +1,19 @@ +# -*- coding: utf-8 -*- + +from odoo import api, fields, models, _ +from odoo.exceptions import UserError, RedirectWarning, ValidationError, except_orm, Warning +from datetime import datetime + + +class AccountMove(models.Model): + _inherit = "account.move" + + period_start_date = fields.Date(string="Period") + period_end_date = fields.Date(string="Period") + period_id = fields.Many2one(string="Period") + + def action_post(self): + if self.period_id and self.period_id.state == "Open": + super(AccountMove, self).action_post() + else: + raise ValidationError(_('Period of this Journal has been closed')) diff --git a/v14_indoteknik/models/account_period.py b/v14_indoteknik/models/account_period.py new file mode 100644 index 0000000..c3c59cc --- /dev/null +++ b/v14_indoteknik/models/account_period.py @@ -0,0 +1,146 @@ +# -*- coding: utf-8 -*- + +from odoo import api, fields, models, _ +from odoo.exceptions import UserError, RedirectWarning, ValidationError, except_orm, Warning +from datetime import datetime + + +class AccountPeriodLine(models.Model): + _name = "account.period.line" + + reference = fields.Many2one('account.period', string="Reference") + start_date = fields.Date('Start Date') + end_date = fields.Date('End Date') + state = fields.Selection([('Open','Open'),('Closed','Closed')], string="Status", default="Open") + + def action_close_period(self): + for res in self: + res.write({'state': 'Closed'}) + + def action_open_period(self): + for res in self: + res.write({'state': 'Open'}) + +class AccountPeriod(models.Model): + _name = "account.period" + + name = fields.Char('Period Name') + year = fields.Char('Year') + start_date = fields.Date('Start Date') + end_date = fields.Date('End Date') + line_ids = fields.One2many('account.period.line', 'reference', string='Lines') + state = fields.Selection([('Open','Open'),('Closed','Closed')], string="Status", default="Open") + + def action_create_period(self): + for res in self: + if res.line_ids: + for line in res.line_ids: + line.unlink() + + start_date1 = datetime(int(res.year), 1, 1) + end_date1 = datetime(int(res.year), 1, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '01/' + str(res.year), + 'start_date': start_date1, + 'end_date': end_date1 + }) + + start_date2 = datetime(int(res.year), 2, 1) + end_date2 = datetime(int(res.year), 2, 28) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '02/' + str(res.year), + 'start_date': start_date2, + 'end_date': end_date2 + }) + + start_date3 = datetime(int(res.year), 3, 1) + end_date3 = datetime(int(res.year), 3, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '03/' + str(res.year), + 'start_date': start_date3, + 'end_date': end_date3 + }) + + start_date4 = datetime(int(res.year), 4, 1) + end_date4 = datetime(int(res.year), 4, 30) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '04/' + str(res.year), + 'start_date': start_date4, + 'end_date': end_date4 + }) + + start_date5 = datetime(int(res.year), 5, 1) + end_date5 = datetime(int(res.year), 5, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '05/' + str(res.year), + 'start_date': start_date5, + 'end_date': end_date5 + }) + + start_date6 = datetime(int(res.year), 6, 1) + end_date6 = datetime(int(res.year), 6, 30) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '06/' + str(res.year), + 'start_date': start_date6, + 'end_date': end_date6 + }) + + start_date7 = datetime(int(res.year), 7, 1) + end_date7 = datetime(int(res.year), 7, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '07/' + str(res.year), + 'start_date': start_date7, + 'end_date': end_date7 + }) + + start_date8 = datetime(int(res.year), 8, 1) + end_date8 = datetime(int(res.year), 8, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'name': '08/' + str(res.year), + 'start_date': start_date8, + 'end_date': end_date8 + }) + + start_date9 = datetime(int(res.year), 9, 1) + end_date9 = datetime(int(res.year), 9, 30) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '09/' + str(res.year), + 'start_date': start_date9, + 'end_date': end_date9 + }) + + start_date10 = datetime(int(res.year), 10, 1) + end_date10 = datetime(int(res.year), 10, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '10/' + str(res.year), + 'start_date': start_date10, + 'end_date': end_date10 + }) + + start_date11 = datetime(int(res.year), 11, 1) + end_date11 = datetime(int(res.year), 11, 30) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '11/' + str(res.year), + 'start_date': start_date11, + 'end_date': end_date11 + }) + + start_date12 = datetime(int(res.year), 12, 1) + end_date12 = datetime(int(res.year), 12, 31) + self.env['account.period.line'].create({ + 'reference': res.id, + 'period_name': '12/' + str(res.year), + 'start_date': start_date12, + 'end_date': end_date12 + })
\ No newline at end of file diff --git a/v14_indoteknik/models/export_product.py b/v14_indoteknik/models/export_product.py new file mode 100644 index 0000000..540891e --- /dev/null +++ b/v14_indoteknik/models/export_product.py @@ -0,0 +1,34 @@ +# -*- coding: utf-8 -*- + +from odoo import api, fields, models, _ +from odoo.exceptions import UserError, RedirectWarning, ValidationError, except_orm, Warning +from datetime import datetime + + +class ExportProductLine(models.Model): + _name = "export.product.line" + + reference = fields.Many2one('Reference') + value = fields.Char('Value') + +class ExportProduct(models.Model): + _name = "export.product" + + product_template_id = fields.Char('Product External ID') + product_template_name = fields.Char('Product Name') + attribute_id = fields.Char('Attribute') + value_text = fields.Char(compute="_get_value_text", string="Values in Text") + line_ids = fields.One2many('export.product.line', 'reference', 'Lines') + + @api.depends('line_ids.value') + def _get_value_text(self): + for res in self: + value_text = "" + if res.line_ids: + for line in res.line_ids: + if not value_text: + value_text += line.value + elif value_text: + value_text += "," + line.value + + res.value_text = value_text diff --git a/v14_indoteknik/models/manufacture.py b/v14_indoteknik/models/manufacture.py new file mode 100644 index 0000000..55ffe6f --- /dev/null +++ b/v14_indoteknik/models/manufacture.py @@ -0,0 +1,26 @@ +# -*- coding: utf-8 -*- + +from odoo import api, fields, models, _ +from odoo.exceptions import UserError, RedirectWarning, ValidationError, except_orm, Warning +from datetime import datetime + + +class XManufacture(models.Model): + _name = "x.manufacture" + + x_name = fields.Char('Name') + x_negara_asal = fields.Char('Negara Asal') + x_short_desc = fields.Text('Short Description') + x_manufacture_category = fields.Many2one('x.manufacture.category', string="Manufacture Category") + x_manufacture_level = fields.Selection([ + ('Prioritas','Prioritas'), + ('Gold','Gold'), + ('Silver','Silver') + ], string="Manufacture Level") + x_produk_aksesoris_sparepart = fields.Selection([ + ('Produk','Produk'), + ('Aksesoris','Aksesoris'), + ('Sparepart','Sparepart') + ], string="Jenis Produk") + x_description = fields.Text('Description') + x_logo_manufacture = fields.Binary('Logo Manufacture')
\ No newline at end of file diff --git a/v14_indoteknik/models/sale.py b/v14_indoteknik/models/sale.py new file mode 100644 index 0000000..f020e23 --- /dev/null +++ b/v14_indoteknik/models/sale.py @@ -0,0 +1,29 @@ +# -*- coding: utf-8 -*- + +from odoo import api, fields, models, _ +from odoo.exceptions import UserError, RedirectWarning, ValidationError, except_orm, Warning +from datetime import datetime + + +# class SaleOrder(models.Model): +# _inherit = "sale.order" + +# @api.multi +# def action_confirm(self): +# for order in self: +# # Check Invoice Limit +# if order.partner_id.invoice_limit < order.partner_id.total_receivable: +# raise ValidationError(_("This Customer has reached the Limit of Outstanding Invoices")) +# elif order.partner_id.invoice_limit < order.amount_total: +# raise ValidationError(_("This order is more than this Customer Limit")) + +# # Check Overdue invoices +# outstanding_invoice = self.env['account.move'].search([ +# ('partner_id','=',order.partner_id.id), +# ('state','=','open'), +# ('date_due','<',fields.Date.today())]) + +# if outstanding_invoice: +# raise ValidationError(_("There are Overdue Invoices for this Customer")) + +# return super(SaleOrder, self).action_confirm()
\ No newline at end of file |
