You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							112 lines
						
					
					
						
							4.4 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							112 lines
						
					
					
						
							4.4 KiB
						
					
					
				| from odoo import models, fields, api | |
| from datetime import datetime | |
| 
 | |
| 
 | |
| class Washing(models.Model): | |
|     """washing activity generating model""" | |
|     _name = 'washing.washing' | |
|     _description = 'Washing Washing' | |
| 
 | |
|     def start_wash(self): | |
|         """ | |
|             Function for initiating the activity of washing. | |
|         """ | |
|         if not self.laundry_works: | |
|             self.laundry_obj.state = 'wash' | |
|             self.laundry_obj.laundry_obj.state = 'process' | |
|         for each in self: | |
|             for obj in each.product_line: | |
|                 self.env['sale.order.line'].create( | |
|                     {'product_id': obj.product_id.id, | |
|                      'name': obj.name, | |
|                      'price_unit': obj.price_unit, | |
|                      'order_id': each.laundry_obj.laundry_obj.sale_obj.id, | |
|                      'product_uom_qty': obj.quantity, | |
|                      'product_uom': obj.uom_id.id, | |
|                      }) | |
|         self.state = 'process' | |
| 
 | |
|     def set_to_done(self): | |
|         self.state = 'done' | |
| 
 | |
|         f = 0 | |
|         if not self.laundry_works: | |
|             if self.laundry_obj.extra_work: | |
|                 for each in self.laundry_obj.extra_work: | |
|                     self.create({'name': each.name, | |
|                                  'user_id': each.assigned_person.id, | |
|                                  'description': self.laundry_obj.description, | |
|                                  'laundry_obj': self.laundry_obj.id, | |
|                                  'state': 'draft', | |
|                                  'laundry_works': True, | |
|                                  'washing_date': datetime.now().strftime( | |
|                                      '%Y-%m-%d %H:%M:%S')}) | |
|                 self.laundry_obj.state = 'extra_work' | |
|         laundry_obj = self.search([('laundry_obj.laundry_obj', '=', | |
|                                     self.laundry_obj.laundry_obj.id)]) | |
|         for each in laundry_obj: | |
|             if each.state != 'done' or each.state == 'cancel': | |
|                 f = 1 | |
|                 break | |
|         if f == 0: | |
|             self.laundry_obj.laundry_obj.state = 'done' | |
|         laundry_obj1 = self.search([('laundry_obj', '=', self.laundry_obj.id)]) | |
|         f1 = 0 | |
|         for each in laundry_obj1: | |
|             if each.state != 'done' or each.state == 'cancel': | |
|                 f1 = 1 | |
|                 break | |
|         if f1 == 0: | |
|             self.laundry_obj.state = 'done' | |
| 
 | |
|     @api.depends('product_line') | |
|     def get_total(self): | |
|         total = 0 | |
|         for obj in self: | |
|             for each in obj.product_line: | |
|                 total += each.subtotal | |
|             obj.total_amount = total | |
| 
 | |
|     name = fields.Char(string='Work') | |
|     laundry_works = fields.Boolean(default=False, invisible=1) | |
|     user_id = fields.Many2one('res.users', | |
|                               string='Assigned Person', | |
|                               help="name of assigned person") | |
|     washing_date = fields.Datetime(string='Date', help="date of washing") | |
|     description = fields.Text(string='Description') | |
|     state = fields.Selection([ | |
|         ('draft', 'Draft'), | |
|         ('process', 'Process'), | |
|         ('done', 'Done'), | |
|         ('cancel', 'Cancelled'), | |
|     ], string='Status', readonly=True, copy=False, index=True, default='draft') | |
|     laundry_obj = fields.Many2one('laundry.order.line', invisible=1) | |
|     product_line = fields.One2many('wash.order.line', 'wash_obj', | |
|                                    string='Products', ondelete='cascade') | |
|     total_amount = fields.Float(compute='get_total', string='Grand Total') | |
| 
 | |
| 
 | |
| class SaleOrderInherit(models.Model): | |
|     """ | |
|         for creating orderlines in washing. | |
|     """ | |
|     _name = 'wash.order.line' | |
|     _description = 'Washing Order LINE' | |
| 
 | |
|     @api.depends('price_unit', 'quantity') | |
|     def compute_amount(self): | |
|         total = 0 | |
|         for obj in self: | |
|             total += obj.price_unit * obj.quantity | |
|         obj.subtotal = total | |
| 
 | |
|     wash_obj = fields.Many2one('washing.washing', string='Order Reference', | |
|                                ondelete='cascade') | |
|     name = fields.Text(string='Description', required=True) | |
|     uom_id = fields.Many2one('uom.uom', 'Unit of Measure ', required=True) | |
|     quantity = fields.Integer(string='Quantity') | |
|     product_id = fields.Many2one('product.product', string='Product') | |
|     price_unit = fields.Float('Unit Price', default=0.0, | |
|                               related='product_id.list_price') | |
|     subtotal = fields.Float(compute='compute_amount', string='Subtotal', | |
|                             readonly=True, store=True)
 | |
| 
 |