Merge branch 'develop' of https://e.coding.net/jikimo-hn/jikimo_sfs/jikimo_sf into feature/刀具产品模板优化
# Conflicts: # sf_mrs_connect/models/res_config_setting.py
This commit is contained in:
@@ -27,6 +27,9 @@
|
||||
|
||||
'web.assets_qweb': [
|
||||
],
|
||||
'web.assets_backend':[
|
||||
'sf_tool_management/static/src/change.scss'
|
||||
]
|
||||
|
||||
|
||||
},
|
||||
|
||||
@@ -8,7 +8,7 @@ class FunctionalCuttingToolEntity(models.Model):
|
||||
_description = '功能刀具管理'
|
||||
|
||||
order = fields.Char(string='序')
|
||||
functional_cutting_tool_id = fields.Many2one('sf.functional.cutting.tool', string='功能刀具', invisible=True)
|
||||
functional_cutting_tool_id = fields.Char(string='功能刀具', invisible=True)
|
||||
# 功能刀具预警 特有字段
|
||||
install_tool_time = fields.Char("装刀时间")
|
||||
outbound_time = fields.Char('出库时间')
|
||||
@@ -104,11 +104,11 @@ class MachineTableToolChangingApply(models.Model):
|
||||
_name = 'sf.machine.table.tool.changing.apply'
|
||||
_description = '机床换刀申请'
|
||||
|
||||
apply_to_tool_change_ids = fields.One2many(
|
||||
'sf.tool.change.requirement.information',
|
||||
'tool_change_to_apply_id',
|
||||
string='换刀需求信息',
|
||||
attrs="{'invisible': 1}")
|
||||
# apply_to_tool_change_ids = fields.One2many(
|
||||
# 'sf.tool.change.requirement.information',
|
||||
# 'tool_change_to_apply_id',
|
||||
# string='换刀需求信息',
|
||||
# attrs="{'invisible': 1}")
|
||||
|
||||
CNC_machine_table = fields.Char(string='CNC机床')
|
||||
# todo 机床类型和刀位号 为 Many2one
|
||||
@@ -260,7 +260,7 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
|
||||
def automation_apply_for_tooling(self):
|
||||
"""
|
||||
todo 自动申请装刀
|
||||
自动申请装刀
|
||||
:return:
|
||||
"""
|
||||
self.env['sf.functional.tool.assembly'].create({
|
||||
@@ -303,6 +303,7 @@ class CAMWorkOrderProgramKnifePlan(models.Model):
|
||||
class FunctionalToolAssembly(models.Model):
|
||||
_name = 'sf.functional.tool.assembly'
|
||||
_description = '功能刀具组装'
|
||||
_order = 'use_tool_time asc'
|
||||
|
||||
functional_tool_code = fields.Char(string='功能刀具编码')
|
||||
functional_tool_name = fields.Char(string='功能刀具名称')
|
||||
@@ -317,7 +318,6 @@ class FunctionalToolAssembly(models.Model):
|
||||
knife_handle_name = fields.Char(string='刀柄名称')
|
||||
knife_handle_brand = fields.Char(string='品牌')
|
||||
knife_handle_type = fields.Char(string='型号')
|
||||
|
||||
coarse_middle_thin = fields.Selection([("1", "粗"), ('2', '中'), ('3', '精')], string='粗/中/精')
|
||||
tool_loading_length = fields.Char(string='装刀长')
|
||||
new_former = fields.Selection([('0', '新'), ('1', '旧')], string='新/旧')
|
||||
@@ -330,7 +330,6 @@ class FunctionalToolAssembly(models.Model):
|
||||
applicant = fields.Char(string='申请人')
|
||||
reason_for_applying = fields.Char(string='申请原因')
|
||||
apply_time = fields.Datetime(string='申请时间', default=fields.Datetime.now())
|
||||
|
||||
assemble_status = fields.Selection([('0', '待组装'), ('1', '已组装'), ('2', '已出库')],string='组装状态', default='0')
|
||||
use_tool_time = fields.Datetime(string='用刀时间')
|
||||
production_line_name = fields.Char(string='产线名称')
|
||||
@@ -343,6 +342,8 @@ class FunctionalToolAssembly(models.Model):
|
||||
receive_time = fields.Datetime(string='领用出库时间')
|
||||
remark = fields.Char(string='备注说明')
|
||||
|
||||
check_box = fields.Boolean(string='复选框', default=False, attrs="{'readonly': [('assemble_status', '!=', '1')]}")
|
||||
|
||||
def cancel_functional_tool_assembly(self):
|
||||
"""
|
||||
取消功能刀具组装
|
||||
@@ -367,3 +368,62 @@ class FunctionalToolAssembly(models.Model):
|
||||
'cut_number': None,
|
||||
'assemble_status': '0'
|
||||
})
|
||||
|
||||
|
||||
def show_popup(self):
|
||||
"""
|
||||
单个功能刀具出库
|
||||
:return:
|
||||
"""
|
||||
self.env['sf.delivery.of.cargo.from.storage'].search([]).unlink()
|
||||
|
||||
vals = self.env['sf.functional.tool.assembly'].search([('check_box', '=', True),('assemble_status', '=', '1')])
|
||||
|
||||
if vals:
|
||||
for val in vals:
|
||||
self.env['sf.delivery.of.cargo.from.storage'].create({
|
||||
'functional_tool_code': val.functional_tool_code,
|
||||
'functional_tool_name': val.functional_tool_name,
|
||||
'functional_tool_type': val.functional_tool_type,
|
||||
'production_line_name': val.production_line_name,
|
||||
'machine_tool_code': val.machine_tool_code,
|
||||
'receive_person': val.receive_person,
|
||||
'receive_time': val.receive_time
|
||||
})
|
||||
else:
|
||||
self.env['sf.delivery.of.cargo.from.storage'].create({
|
||||
'functional_tool_code': self.functional_tool_code,
|
||||
'functional_tool_name': self.functional_tool_name,
|
||||
'functional_tool_type': self.functional_tool_type,
|
||||
'production_line_name': self.production_line_name,
|
||||
'machine_tool_code': self.machine_tool_code,
|
||||
'receive_person': self.receive_person,
|
||||
'receive_time': self.receive_time
|
||||
})
|
||||
|
||||
return {
|
||||
'type': 'ir.actions.act_window',
|
||||
'name': '功能刀具出库',
|
||||
'res_model': 'sf.delivery.of.cargo.from.storage',
|
||||
'view_mode': 'tree',
|
||||
'view_type': 'tree',
|
||||
'target': 'new'
|
||||
}
|
||||
|
||||
def automated_assembly(self):
|
||||
"""
|
||||
todo 自动组装
|
||||
:return:
|
||||
"""
|
||||
|
||||
def automatic_printing_of_QR_code(self):
|
||||
"""
|
||||
todo 自动打印二维码
|
||||
:return:
|
||||
"""
|
||||
|
||||
def assemble_single_print(self):
|
||||
"""
|
||||
todo 组装单打印
|
||||
:return:
|
||||
"""
|
||||
11
sf_tool_management/static/src/change.scss
Normal file
11
sf_tool_management/static/src/change.scss
Normal file
@@ -0,0 +1,11 @@
|
||||
.modal-content .o_cp_buttons {
|
||||
display:none
|
||||
}
|
||||
|
||||
.modal-content .o_control_panel {
|
||||
display:none
|
||||
}
|
||||
|
||||
.modal-content .o_list_button {
|
||||
|
||||
}
|
||||
@@ -417,31 +417,20 @@
|
||||
class="btn-primary"/>
|
||||
<button string="组装" name="" attrs="{'invisible': [('assemble_status', '=', '0')]}" class="btn-primary"/>
|
||||
|
||||
<button string="取消组装" name="cancel_functional_tool_assembly" type="object" attrs="{'invisible': [('assemble_status', '=', '0')]}" class="btn-primary"/>
|
||||
<button string="取消组装" name="" attrs="{'invisible': [('assemble_status', '!=', '0')]}" class="btn-primary"/>
|
||||
<button string="取消组装" name="cancel_functional_tool_assembly" type="object" attrs="{'invisible': [('assemble_status', '!=', '1')]}" class="btn-primary"/>
|
||||
<button string="取消组装" name="" attrs="{'invisible': [('assemble_status', '=', '1')]}" class="btn-primary"/>
|
||||
|
||||
<button string="自动打印二维码" name="" class="btn-primary"/>
|
||||
<button string="自动打印二维码" name="automatic_printing_of_QR_code" type="object" class="btn-primary"/>
|
||||
|
||||
<button string="出库"
|
||||
name="%(sf_tool_management.sf_delivery_of_cargo_from_storager_act)d"
|
||||
type="action"
|
||||
context="{
|
||||
'default_functional_tool_code': functional_tool_code,
|
||||
'default_machine_tool_name': machine_tool_name,
|
||||
'default_functional_tool_type': functional_tool_type,
|
||||
'default_production_line_name': production_line_name,
|
||||
'default_machine_tool_code': machine_tool_code,
|
||||
'default_receive_person': receive_person,
|
||||
'default_receive_time': receive_time
|
||||
}"
|
||||
attrs="{'invisible': [('assemble_status', '!=', '1')]}" class="btn-primary"/>
|
||||
<button string="出库" name="show_popup" type="object" attrs="{'invisible': [('assemble_status', '!=', '1')]}" class="btn-primary"/>
|
||||
<button string="出库" name="" attrs="{'invisible': [('assemble_status', '=', '1')]}" class="btn-primary"/>
|
||||
|
||||
<button string="组装单打印" name="" class="btn-primary"/>
|
||||
<button string="组装单打印" name="assemble_single_print" type="object" class="btn-primary"/>
|
||||
|
||||
<field name="check_box"/>
|
||||
|
||||
<field name="assemble_status"/>
|
||||
<field name="use_tool_time"/>
|
||||
<field name="use_tool_time" />
|
||||
<field name="production_line_name"/>
|
||||
<field name="machine_tool_name"/>
|
||||
<field name="machine_tool_code"/>
|
||||
|
||||
@@ -1,11 +1,11 @@
|
||||
from odoo import fields, models, api
|
||||
from odoo import fields, models
|
||||
|
||||
|
||||
class ToolChangeRequirementInformation(models.TransientModel):
|
||||
_name = 'sf.tool.change.requirement.information'
|
||||
_description = '换刀需求信息'
|
||||
|
||||
tool_change_to_apply_id = fields.Many2one('sf.machine.table.tool.changing.apply', string='机床换刀申请')
|
||||
# tool_change_to_apply_id = fields.Many2one('sf.machine.table.tool.changing.apply', string='机床换刀申请')
|
||||
|
||||
CNC_machine_table = fields.Char(string='CNC机床', readonly=True)
|
||||
machine_tool_code = fields.Char(string='机台号', readonly=True)
|
||||
@@ -224,6 +224,7 @@ class DeliveryOfCargoFromStorage(models.TransientModel):
|
||||
_name = 'sf.delivery.of.cargo.from.storage'
|
||||
_description = '出库'
|
||||
|
||||
order = fields.Integer(string='序')
|
||||
functional_tool_code = fields.Char(string='功能刀具编码')
|
||||
functional_tool_name = fields.Char(string='功能刀具名称')
|
||||
functional_tool_type = fields.Char(string='功能刀具类型')
|
||||
@@ -236,4 +237,13 @@ class DeliveryOfCargoFromStorage(models.TransientModel):
|
||||
"""
|
||||
出库
|
||||
:return:
|
||||
"""
|
||||
"""
|
||||
vals = self.env['sf.delivery.of.cargo.from.storage'].search([])
|
||||
if vals:
|
||||
for val in vals:
|
||||
self.env['sf.functional.tool.assembly'].search([
|
||||
('functional_tool_code', '=', val.functional_tool_code),
|
||||
('functional_tool_name', '=', val.functional_tool_name)
|
||||
]).write({
|
||||
'assemble_status': '2'
|
||||
})
|
||||
|
||||
@@ -273,14 +273,19 @@
|
||||
<field name="model">sf.delivery.of.cargo.from.storage</field>
|
||||
<field name="arch" type="xml">
|
||||
<tree>
|
||||
<field name="functional_tool_code" string="编码"/>
|
||||
<field name="functional_tool_name" string="名称"/>
|
||||
<field name="functional_tool_type" string="类型"/>
|
||||
<field name="production_line_name" string="生产线"/>
|
||||
<field name="machine_tool_code" string="机台"/>
|
||||
<field name="order"/>
|
||||
<field name="functional_tool_code"/>
|
||||
<field name="functional_tool_name"/>
|
||||
<field name="functional_tool_type"/>
|
||||
<field name="production_line_name"/>
|
||||
<field name="machine_tool_code"/>
|
||||
<field name="receive_person"/>
|
||||
<field name="receive_time" string="出库时间"/>
|
||||
<field name="receive_time"/>
|
||||
</tree>
|
||||
<footer>
|
||||
<button string="确定" name="stock_removal" type="object" class="btn-primary" />
|
||||
<button string="取消" class="btn-secondary" special="cancel"/>
|
||||
</footer>
|
||||
</field>
|
||||
</record>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user