summaryrefslogtreecommitdiff
path: root/v14_indoteknik/models
diff options
context:
space:
mode:
authorstephanchrst <stephanchrst@gmail.com>2022-05-10 17:14:58 +0700
committerstephanchrst <stephanchrst@gmail.com>2022-05-10 17:14:58 +0700
commit1ca3b3df3421961caec3b747a364071c80f5c7da (patch)
tree6778a1f0f3f9b4c6e26d6d87ccde16e24da6c9d6 /v14_indoteknik/models
parentb57188be371d36d96caac4b8d65a40745c0e972c (diff)
initial commit
Diffstat (limited to 'v14_indoteknik/models')
-rw-r--r--v14_indoteknik/models/__init__.py4
-rw-r--r--v14_indoteknik/models/account_move.py19
-rw-r--r--v14_indoteknik/models/account_period.py146
-rw-r--r--v14_indoteknik/models/export_product.py34
-rw-r--r--v14_indoteknik/models/manufacture.py26
-rw-r--r--v14_indoteknik/models/sale.py29
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