Accept Merge Request #2125: (feature/6694 -> develop)
Merge Request: 回退工艺外协代码 Created By: @胡尧 Accepted By: @胡尧 URL: https://jikimo-hn.coding.net/p/jikimo_sfs/d/jikimo_sf/git/merge/2125?initial=true
This commit is contained in:
@@ -13,7 +13,11 @@ class ProductTemplate(models.Model):
|
|||||||
template_id.purchase_request = product_id.purchase_request
|
template_id.purchase_request = product_id.purchase_request
|
||||||
return template_id
|
return template_id
|
||||||
|
|
||||||
|
|
||||||
|
class ProdcutProduct(models.Model):
|
||||||
|
_inherit = 'product.product'
|
||||||
|
|
||||||
def copy_template(self, product_template_id):
|
def copy_template(self, product_template_id):
|
||||||
""" 复制成品模板时,复制采购申请 """
|
""" 复制成品模板时,复制采购申请 """
|
||||||
super(ProductTemplate, self).copy_template(product_template_id)
|
super(ProdcutProduct, self).copy_template(product_template_id)
|
||||||
self.purchase_request = product_template_id.purchase_request
|
self.purchase_request = product_template_id.purchase_request
|
||||||
|
|||||||
@@ -114,7 +114,10 @@ class PurchaseRequestLine(models.Model):
|
|||||||
|
|
||||||
def _compute_qty_to_buy(self):
|
def _compute_qty_to_buy(self):
|
||||||
for pr in self:
|
for pr in self:
|
||||||
qty_to_buy = sum(pr.mapped("product_qty")) - sum(pr.mapped("qty_done")) - sum(pr.mapped("qty_in_progress"))
|
qty_to_buy = sum(pr.mapped("product_qty"))
|
||||||
|
if pr.purchase_count > 0:
|
||||||
|
qty_to_buy -= sum(pr.mapped("purchase_lines").filtered(lambda po: po.state != 'cancel').mapped(
|
||||||
|
"product_qty"))
|
||||||
pr.qty_to_buy = qty_to_buy > 0.0
|
pr.qty_to_buy = qty_to_buy > 0.0
|
||||||
pr.pending_qty_to_receive = qty_to_buy
|
pr.pending_qty_to_receive = qty_to_buy
|
||||||
|
|
||||||
|
|||||||
@@ -6,6 +6,10 @@ class ProductTemplate(models.Model):
|
|||||||
is_manual_processing = fields.Boolean(string='人工线下加工')
|
is_manual_processing = fields.Boolean(string='人工线下加工')
|
||||||
is_customer_provided = fields.Boolean(string='客供料')
|
is_customer_provided = fields.Boolean(string='客供料')
|
||||||
|
|
||||||
|
|
||||||
|
class ProductProduct(models.Model):
|
||||||
|
_inherit = 'product.product'
|
||||||
|
|
||||||
def copy_template(self, product_template_id):
|
def copy_template(self, product_template_id):
|
||||||
if not isinstance(product_template_id, ProductTemplate):
|
if not isinstance(product_template_id, ProductTemplate):
|
||||||
raise ValueError('%s必须是ProductTemplate类型' % product_template_id)
|
raise ValueError('%s必须是ProductTemplate类型' % product_template_id)
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import json
|
|||||||
import logging
|
import logging
|
||||||
from odoo.addons.sf_mrs_connect.controllers.controllers import Sf_Mrs_Connect
|
from odoo.addons.sf_mrs_connect.controllers.controllers import Sf_Mrs_Connect
|
||||||
from odoo.addons.sf_manufacturing.controllers.controllers import Manufacturing_Connect
|
from odoo.addons.sf_manufacturing.controllers.controllers import Manufacturing_Connect
|
||||||
|
from odoo.addons.sf_base.decorators.api_log import api_log
|
||||||
from datetime import datetime
|
from datetime import datetime
|
||||||
|
|
||||||
_logger = logging.getLogger(__name__)
|
_logger = logging.getLogger(__name__)
|
||||||
@@ -12,6 +13,7 @@ class WorkorderExceptionConroller(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/BillError', type='json', auth='public', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/BillError', type='json', auth='public', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('工单对接错误', requester='中控系统')
|
||||||
def workder_exception(self, **kw):
|
def workder_exception(self, **kw):
|
||||||
"""
|
"""
|
||||||
记录工单异常
|
记录工单异常
|
||||||
|
|||||||
@@ -103,12 +103,19 @@ class PrintingUtils(models.AbstractModel):
|
|||||||
self.send_to_printer(host, port, zpl_code)
|
self.send_to_printer(host, port, zpl_code)
|
||||||
|
|
||||||
|
|
||||||
def add_qr_code_to_pdf(self, pdf_path:str, content:str, buttom_text:Optional[str]=False):
|
def add_qr_code_to_pdf(
|
||||||
|
self,
|
||||||
|
pdf_path:str,
|
||||||
|
content:str,
|
||||||
|
qr_code_buttom_text:Optional[str]=False,
|
||||||
|
buttom_text:Optional[str]=False,
|
||||||
|
):
|
||||||
"""
|
"""
|
||||||
在PDF文件中添加二维码
|
在PDF文件中添加二维码
|
||||||
:param pdf_path: PDF文件路径
|
:param pdf_path: PDF文件路径
|
||||||
:param content: 二维码内容
|
:param content: 二维码内容
|
||||||
:param buttom_text: 二维码下方文字
|
:param qr_code_buttom_text: 二维码下方文字
|
||||||
|
:param buttom_text: 正文下方文字
|
||||||
:return: 是否成功
|
:return: 是否成功
|
||||||
"""
|
"""
|
||||||
if not os.path.exists(pdf_path):
|
if not os.path.exists(pdf_path):
|
||||||
@@ -156,8 +163,9 @@ class PrintingUtils(models.AbstractModel):
|
|||||||
existing_pdf = PdfFileReader(original_file)
|
existing_pdf = PdfFileReader(original_file)
|
||||||
output = PdfFileWriter()
|
output = PdfFileWriter()
|
||||||
|
|
||||||
# 处理第一页
|
# 处理最后一页
|
||||||
page = existing_pdf.getPage(0)
|
last_page = existing_pdf.getNumPages() - 1
|
||||||
|
page = existing_pdf.getPage(last_page)
|
||||||
# 获取页面尺寸
|
# 获取页面尺寸
|
||||||
page_width = float(page.mediaBox.getWidth())
|
page_width = float(page.mediaBox.getWidth())
|
||||||
page_height = float(page.mediaBox.getHeight())
|
page_height = float(page.mediaBox.getHeight())
|
||||||
@@ -179,14 +187,22 @@ class PrintingUtils(models.AbstractModel):
|
|||||||
qr_y = margin + 20 # 将二维码向上移动一点,为文字留出空间
|
qr_y = margin + 20 # 将二维码向上移动一点,为文字留出空间
|
||||||
c.drawImage(qr_temp_path, page_width - qr_size - margin, qr_y, width=qr_size, height=qr_size)
|
c.drawImage(qr_temp_path, page_width - qr_size - margin, qr_y, width=qr_size, height=qr_size)
|
||||||
|
|
||||||
if buttom_text:
|
if qr_code_buttom_text:
|
||||||
# 在二维码下方绘制文字
|
# 在二维码下方绘制文字
|
||||||
text = buttom_text
|
text = qr_code_buttom_text
|
||||||
text_width = c.stringWidth(text, "SimSun" if font_found else "Helvetica", 10) # 准确计算文字宽度
|
text_width = c.stringWidth(text, "SimSun" if font_found else "Helvetica", 10) # 准确计算文字宽度
|
||||||
text_x = page_width - qr_size - margin + (qr_size - text_width) / 2 # 文字居中对齐
|
text_x = page_width - qr_size - margin + (qr_size - text_width) / 2 # 文字居中对齐
|
||||||
text_y = margin + 20 # 文字位置靠近底部
|
text_y = margin + 20 # 文字位置靠近底部
|
||||||
c.drawString(text_x, text_y, text)
|
c.drawString(text_x, text_y, text)
|
||||||
|
|
||||||
|
if buttom_text:
|
||||||
|
# 在下方中间添加文字
|
||||||
|
text = button_text
|
||||||
|
text_width = c.stringWidth(text, "SimSun" if font_found else "Helvetica", 10) # 准确计算文字宽度
|
||||||
|
text_x = (page_width - text_width) / 2 # 文字居中对齐
|
||||||
|
text_y = margin + 20 # 文字位置靠近底部
|
||||||
|
c.drawString(text_x, text_y, text)
|
||||||
|
|
||||||
c.save()
|
c.save()
|
||||||
|
|
||||||
# 读取带有二维码的临时PDF
|
# 读取带有二维码的临时PDF
|
||||||
@@ -196,12 +212,13 @@ class PrintingUtils(models.AbstractModel):
|
|||||||
|
|
||||||
# 合并原始页面和二维码页面
|
# 合并原始页面和二维码页面
|
||||||
page.mergePage(qr_page)
|
page.mergePage(qr_page)
|
||||||
output.addPage(page)
|
|
||||||
|
|
||||||
# 添加剩余的页面
|
# 添加剩余的页面
|
||||||
for i in range(1, existing_pdf.getNumPages()):
|
for i in range(0, last_page):
|
||||||
output.addPage(existing_pdf.getPage(i))
|
output.addPage(existing_pdf.getPage(i))
|
||||||
|
|
||||||
|
output.addPage(page)
|
||||||
|
|
||||||
# 保存最终的PDF到一个临时文件
|
# 保存最终的PDF到一个临时文件
|
||||||
final_temp_path = pdf_path + '.tmp'
|
final_temp_path = pdf_path + '.tmp'
|
||||||
with open(final_temp_path, "wb") as output_file:
|
with open(final_temp_path, "wb") as output_file:
|
||||||
|
|||||||
@@ -4,6 +4,7 @@ import json
|
|||||||
import logging
|
import logging
|
||||||
from odoo import http
|
from odoo import http
|
||||||
from odoo.http import request
|
from odoo.http import request
|
||||||
|
from odoo.addons.sf_base.decorators.api_log import api_log
|
||||||
|
|
||||||
_logger = logging.getLogger(__name__)
|
_logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
@@ -11,6 +12,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/MachineToolGroup', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/MachineToolGroup', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('机床刀具组', requester='中控系统')
|
||||||
def get_maintenance_tool_groups_Info(self, **kw):
|
def get_maintenance_tool_groups_Info(self, **kw):
|
||||||
"""
|
"""
|
||||||
机床刀具组接口
|
机床刀具组接口
|
||||||
|
|||||||
@@ -27,6 +27,9 @@ def api_log(name=None, requester=None):
|
|||||||
|
|
||||||
# 执行原始函数
|
# 执行原始函数
|
||||||
result = func(*args, **kwargs)
|
result = func(*args, **kwargs)
|
||||||
|
origin_result = result
|
||||||
|
if isinstance(result, str):
|
||||||
|
result = json.loads(result)
|
||||||
|
|
||||||
# 计算响应时间
|
# 计算响应时间
|
||||||
end_time = datetime.now()
|
end_time = datetime.now()
|
||||||
@@ -41,7 +44,7 @@ def api_log(name=None, requester=None):
|
|||||||
'response_data': json.dumps(result, ensure_ascii=False),
|
'response_data': json.dumps(result, ensure_ascii=False),
|
||||||
'remote_addr': remote_addr,
|
'remote_addr': remote_addr,
|
||||||
'response_time': response_time,
|
'response_time': response_time,
|
||||||
'status': result.get('code', 500),
|
'status': result.get('code') or result.get('ErrorCode') or 500,
|
||||||
'requester': requester,
|
'requester': requester,
|
||||||
'responser': '智能工厂'
|
'responser': '智能工厂'
|
||||||
}
|
}
|
||||||
@@ -49,7 +52,7 @@ def api_log(name=None, requester=None):
|
|||||||
# 异步创建日志记录
|
# 异步创建日志记录
|
||||||
request.env['api.request.log'].sudo().with_context(tracking_disable=True).create(log_vals)
|
request.env['api.request.log'].sudo().with_context(tracking_disable=True).create(log_vals)
|
||||||
|
|
||||||
return result
|
return origin_result
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
_logger.error(f"API日志记录失败: {str(e)}")
|
_logger.error(f"API日志记录失败: {str(e)}")
|
||||||
|
|||||||
@@ -1,4 +1,9 @@
|
|||||||
from odoo import models, fields, api
|
from odoo import models, fields, api
|
||||||
|
import json, ast
|
||||||
|
import logging
|
||||||
|
import requests
|
||||||
|
|
||||||
|
_logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
class ApiRequestLog(models.Model):
|
class ApiRequestLog(models.Model):
|
||||||
@@ -16,3 +21,52 @@ class ApiRequestLog(models.Model):
|
|||||||
status = fields.Integer('状态码')
|
status = fields.Integer('状态码')
|
||||||
requester = fields.Char('请求方')
|
requester = fields.Char('请求方')
|
||||||
responser = fields.Char('响应方')
|
responser = fields.Char('响应方')
|
||||||
|
|
||||||
|
@api.model
|
||||||
|
def log_request(self, method, url, name=None, responser=None, **kwargs):
|
||||||
|
# Log the request
|
||||||
|
request_headers = kwargs.get('headers', {})
|
||||||
|
request_body = kwargs.get('json') or kwargs.get('params') or {}
|
||||||
|
|
||||||
|
_logger.info(f"Request: {method} {url} Headers: {request_headers} Body: {request_body}")
|
||||||
|
|
||||||
|
# Make the actual request
|
||||||
|
response = requests.request(method, url, **kwargs)
|
||||||
|
|
||||||
|
# Log the response
|
||||||
|
response_status = response.status_code
|
||||||
|
response_headers = response.headers
|
||||||
|
response_body = response.text
|
||||||
|
response_time = response.elapsed.total_seconds()
|
||||||
|
|
||||||
|
_logger.info(f"Response: Status: {response_status} Headers: {response_headers} Body: {response_body}")
|
||||||
|
|
||||||
|
try:
|
||||||
|
# 如果是字符串,先尝试用 ast.literal_eval 安全地转换成 Python 对象
|
||||||
|
if isinstance(response_body, str):
|
||||||
|
|
||||||
|
response_body_obj = json.loads(response_body)
|
||||||
|
else:
|
||||||
|
response_body_obj = response_body
|
||||||
|
|
||||||
|
# 再使用 json.dumps 转换成标准的 JSON 字符串
|
||||||
|
response_body = json.dumps(response_body_obj, ensure_ascii=False)
|
||||||
|
except Exception as e:
|
||||||
|
_logger.warning(f"转换 response_body 到标准 JSON 失败: {str(e)}")
|
||||||
|
# 如果转换失败,保持原样
|
||||||
|
|
||||||
|
# Save to database
|
||||||
|
self.sudo().create({
|
||||||
|
'name': name,
|
||||||
|
'path': url,
|
||||||
|
'method': method,
|
||||||
|
'request_data': request_body,
|
||||||
|
'response_data': response_body,
|
||||||
|
'remote_addr': None,
|
||||||
|
'response_time': response_time,
|
||||||
|
'status': response_status,
|
||||||
|
'requester': '智能工厂',
|
||||||
|
'responser': responser
|
||||||
|
})
|
||||||
|
|
||||||
|
return response
|
||||||
@@ -2,8 +2,8 @@
|
|||||||
# from odoo import fields, models, api
|
# from odoo import fields, models, api
|
||||||
# from odoo.exceptions import UserError
|
# from odoo.exceptions import UserError
|
||||||
# from odoo.tools import str2bool
|
# from odoo.tools import str2bool
|
||||||
#
|
|
||||||
#
|
|
||||||
# class ResMrpRoutingWorkcenter(models.Model):
|
# class ResMrpRoutingWorkcenter(models.Model):
|
||||||
# _inherit = 'mrp.routing.workcenter'
|
# _inherit = 'mrp.routing.workcenter'
|
||||||
# def init(self):
|
# def init(self):
|
||||||
|
|||||||
@@ -3,12 +3,12 @@
|
|||||||
# from odoo import fields, models, api
|
# from odoo import fields, models, api
|
||||||
# from odoo.exceptions import UserError
|
# from odoo.exceptions import UserError
|
||||||
# from odoo.tools import str2bool
|
# from odoo.tools import str2bool
|
||||||
#
|
|
||||||
#
|
|
||||||
# class SfProductionProcessParameter(models.Model):
|
# class SfProductionProcessParameter(models.Model):
|
||||||
# _inherit = 'sf.production.process.parameter'
|
# _inherit = 'sf.production.process.parameter'
|
||||||
#
|
|
||||||
#
|
|
||||||
# @api.model
|
# @api.model
|
||||||
# def create(self, vals):
|
# def create(self, vals):
|
||||||
# # if vals.get('code', '/') == '/' or vals.get('code', '/') is False:
|
# # if vals.get('code', '/') == '/' or vals.get('code', '/') is False:
|
||||||
@@ -26,7 +26,7 @@
|
|||||||
# def create_service_product(self):
|
# def create_service_product(self):
|
||||||
# service_categ = self.env.ref(
|
# service_categ = self.env.ref(
|
||||||
# 'sf_dlm.product_category_surface_technics_sf').sudo()
|
# 'sf_dlm.product_category_surface_technics_sf').sudo()
|
||||||
#
|
|
||||||
# product_name = f"{self.process_id.name}_{self.name}"
|
# product_name = f"{self.process_id.name}_{self.name}"
|
||||||
# product_id = self.env['product.template'].search(
|
# product_id = self.env['product.template'].search(
|
||||||
# [("name", '=', product_name)])
|
# [("name", '=', product_name)])
|
||||||
@@ -48,7 +48,7 @@
|
|||||||
# 'partner_id': res_partner.id,
|
# 'partner_id': res_partner.id,
|
||||||
# 'price': 1, })],
|
# 'price': 1, })],
|
||||||
# })
|
# })
|
||||||
#
|
|
||||||
# def create_work_center(self):
|
# def create_work_center(self):
|
||||||
# production_process_parameter = self
|
# production_process_parameter = self
|
||||||
# if not production_process_parameter.process_id:
|
# if not production_process_parameter.process_id:
|
||||||
@@ -70,7 +70,7 @@
|
|||||||
# production_process_parameter.routing_id = routing_id.id
|
# production_process_parameter.routing_id = routing_id.id
|
||||||
# else:
|
# else:
|
||||||
# production_process_parameter.routing_id = workcenter_id.id
|
# production_process_parameter.routing_id = workcenter_id.id
|
||||||
#
|
|
||||||
# def init(self):
|
# def init(self):
|
||||||
# super(SfProductionProcessParameter, self).init()
|
# super(SfProductionProcessParameter, self).init()
|
||||||
# # 在模块初始化时触发计算字段的更新
|
# # 在模块初始化时触发计算字段的更新
|
||||||
|
|||||||
@@ -48,6 +48,7 @@
|
|||||||
'views/mrp_workorder_batch_replan.xml',
|
'views/mrp_workorder_batch_replan.xml',
|
||||||
'views/purchase_order_view.xml',
|
'views/purchase_order_view.xml',
|
||||||
'views/product_template_views.xml',
|
'views/product_template_views.xml',
|
||||||
|
# 'views/stock_warehouse_orderpoint.xml',
|
||||||
],
|
],
|
||||||
'assets': {
|
'assets': {
|
||||||
|
|
||||||
|
|||||||
@@ -6,12 +6,14 @@ from datetime import datetime
|
|||||||
from odoo.addons.sf_manufacturing.models.agv_scheduling import RepeatTaskException
|
from odoo.addons.sf_manufacturing.models.agv_scheduling import RepeatTaskException
|
||||||
from odoo import http
|
from odoo import http
|
||||||
from odoo.http import request
|
from odoo.http import request
|
||||||
|
from odoo.addons.sf_base.decorators.api_log import api_log
|
||||||
|
|
||||||
|
|
||||||
class Manufacturing_Connect(http.Controller):
|
class Manufacturing_Connect(http.Controller):
|
||||||
|
|
||||||
@http.route('/AutoDeviceApi/GetWoInfo', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/GetWoInfo', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('获取工单', requester='中控系统')
|
||||||
def get_Work_Info(self, **kw):
|
def get_Work_Info(self, **kw):
|
||||||
"""
|
"""
|
||||||
自动化传递工单号获取工单信息
|
自动化传递工单号获取工单信息
|
||||||
@@ -54,6 +56,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/GetShiftPlan', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/GetShiftPlan', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('获取日计划', requester='中控系统')
|
||||||
def get_ShiftPlan(self, **kw):
|
def get_ShiftPlan(self, **kw):
|
||||||
"""
|
"""
|
||||||
自动化每天获取机台日计划
|
自动化每天获取机台日计划
|
||||||
@@ -107,6 +110,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/QcCheck', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/QcCheck', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('工件预调(前置三元检测)', requester='中控系统')
|
||||||
def get_qcCheck(self, **kw):
|
def get_qcCheck(self, **kw):
|
||||||
"""
|
"""
|
||||||
工件预调(前置三元检测)
|
工件预调(前置三元检测)
|
||||||
@@ -149,6 +153,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/FeedBackStart', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/FeedBackStart', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('工单开始', requester='中控系统')
|
||||||
def button_Work_START(self, **kw):
|
def button_Work_START(self, **kw):
|
||||||
"""
|
"""
|
||||||
工单任务开始
|
工单任务开始
|
||||||
@@ -198,6 +203,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/FeedBackEnd', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/FeedBackEnd', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('工单结束', requester='中控系统')
|
||||||
def button_Work_End(self, **kw):
|
def button_Work_End(self, **kw):
|
||||||
"""
|
"""
|
||||||
工单任务结束
|
工单任务结束
|
||||||
@@ -249,6 +255,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/PartQualityInspect', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/PartQualityInspect', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('零件检测(后置三元检测)', requester='中控系统')
|
||||||
def PartQualityInspect(self, **kw):
|
def PartQualityInspect(self, **kw):
|
||||||
"""
|
"""
|
||||||
零件质检
|
零件质检
|
||||||
@@ -295,6 +302,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/CMMProgDolod', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/CMMProgDolod', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('CMM测量程序下载', requester='中控系统')
|
||||||
def CMMProgDolod(self, **kw):
|
def CMMProgDolod(self, **kw):
|
||||||
"""
|
"""
|
||||||
中控系统传递RFID编号给MES,获取测量程序文件。Ftp下载文件
|
中控系统传递RFID编号给MES,获取测量程序文件。Ftp下载文件
|
||||||
@@ -335,6 +343,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/NCProgDolod', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/NCProgDolod', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('CAM加工程序下载', requester='中控系统')
|
||||||
def NCProgDolod(self, **kw):
|
def NCProgDolod(self, **kw):
|
||||||
"""
|
"""
|
||||||
中控系统传递RFID编号给MES,获取程序单及程序文件。Ftp下载文件
|
中控系统传递RFID编号给MES,获取程序单及程序文件。Ftp下载文件
|
||||||
@@ -376,6 +385,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/LocationChange', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/LocationChange', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('库位变更', requester='中控系统')
|
||||||
def LocationChange(self, **kw):
|
def LocationChange(self, **kw):
|
||||||
"""
|
"""
|
||||||
库位变更
|
库位变更
|
||||||
@@ -480,6 +490,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/AGVToProduct', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/AGVToProduct', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('AGV运送上产线', requester='中控系统')
|
||||||
def AGVToProduct(self, **kw):
|
def AGVToProduct(self, **kw):
|
||||||
"""
|
"""
|
||||||
AGV运送上产线(完成)
|
AGV运送上产线(完成)
|
||||||
@@ -552,6 +563,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/AGVDownProduct', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/AGVDownProduct', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('AGV运送下产线', requester='中控系统')
|
||||||
def AGVDownProduct(self, **kw):
|
def AGVDownProduct(self, **kw):
|
||||||
"""
|
"""
|
||||||
MES调度AGV,搬运零件AGV托盘到产线接驳站。
|
MES调度AGV,搬运零件AGV托盘到产线接驳站。
|
||||||
|
|||||||
@@ -18,3 +18,4 @@ from . import quick_easy_order
|
|||||||
from . import purchase_order
|
from . import purchase_order
|
||||||
from . import quality_check
|
from . import quality_check
|
||||||
from . import purchase_request_line
|
from . import purchase_request_line
|
||||||
|
# from . import stock_warehouse_orderpoint
|
||||||
@@ -928,12 +928,13 @@ class MrpProduction(models.Model):
|
|||||||
# 'sf_stock.stock_route_process_outsourcing').id)]
|
# 'sf_stock.stock_route_process_outsourcing').id)]
|
||||||
# for product_id, request_line_list in grouped_purchase_request_line_sorted_list.items():
|
# for product_id, request_line_list in grouped_purchase_request_line_sorted_list.items():
|
||||||
# cur_request_line = request_line_list[0]
|
# cur_request_line = request_line_list[0]
|
||||||
# cur_request_line['product_qty'] = len(request_line_list)
|
# # cur_request_line['product_qty'] = cur_request_line['product_qty']
|
||||||
# cur_request_line['request_id'] = pr.id
|
# cur_request_line['request_id'] = pr.id
|
||||||
# cur_request_line['origin'] = ", ".join({item['production_name'] for item in request_line_list if item.get('production_name')})
|
# cur_request_line['origin'] = ", ".join({item['production_name'] for item in request_line_list if item.get('production_name')})
|
||||||
# cur_request_line.pop('group_id', None)
|
# cur_request_line.pop('group_id', None)
|
||||||
# cur_request_line.pop('production_name', None)
|
# cur_request_line.pop('production_name', None)
|
||||||
# self.env["purchase.request.line"].create(cur_request_line)
|
# self.env["purchase.request.line"].create(cur_request_line)
|
||||||
|
# pr.button_approved()
|
||||||
|
|
||||||
# 外协出入库单处理
|
# 外协出入库单处理
|
||||||
def get_subcontract_pick_purchase(self):
|
def get_subcontract_pick_purchase(self):
|
||||||
|
|||||||
@@ -71,7 +71,7 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
tracking=True)
|
tracking=True)
|
||||||
back_button_display = fields.Boolean(default=False, compute='_compute_back_button_display', store=True)
|
back_button_display = fields.Boolean(default=False, compute='_compute_back_button_display', store=True)
|
||||||
# pr_mp_count = fields.Integer('采购申请单数量', compute='_compute_pr_mp_count', store=True)
|
# pr_mp_count = fields.Integer('采购申请单数量', compute='_compute_pr_mp_count', store=True)
|
||||||
#
|
|
||||||
# @api.depends('state')
|
# @api.depends('state')
|
||||||
# def _compute_pr_mp_count(self):
|
# def _compute_pr_mp_count(self):
|
||||||
# for item in self:
|
# for item in self:
|
||||||
@@ -85,6 +85,7 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
# item.pr_mp_count = len(pr_ids)
|
# item.pr_mp_count = len(pr_ids)
|
||||||
# else:
|
# else:
|
||||||
# item.pr_mp_count = 0
|
# item.pr_mp_count = 0
|
||||||
|
|
||||||
@api.depends('state')
|
@api.depends('state')
|
||||||
def _compute_back_button_display(self):
|
def _compute_back_button_display(self):
|
||||||
for record in self:
|
for record in self:
|
||||||
@@ -443,9 +444,8 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
def _compute_surface_technics_purchase_ids(self):
|
def _compute_surface_technics_purchase_ids(self):
|
||||||
for order in self:
|
for order in self:
|
||||||
if order.routing_type == '表面工艺' and order.state not in ['cancel']:
|
if order.routing_type == '表面工艺' and order.state not in ['cancel']:
|
||||||
domain = [('purchase_type', '=', 'consignment'),
|
domain = [('group_id', '=', self.production_id.procurement_group_id.id),
|
||||||
('origin', 'like', '%' + self.production_id.name + '%'),
|
('purchase_type', '=', 'consignment'), ('state', '!=', 'cancel')]
|
||||||
('state', '!=', 'cancel')]
|
|
||||||
# domain = [('purchase_type', '=', 'consignment'),
|
# domain = [('purchase_type', '=', 'consignment'),
|
||||||
# ('origin', 'like', '%' + self.production_id.name + '%'),
|
# ('origin', 'like', '%' + self.production_id.name + '%'),
|
||||||
# ('state', '!=', 'cancel')]
|
# ('state', '!=', 'cancel')]
|
||||||
@@ -485,6 +485,7 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
# 'view_mode': 'tree,form',
|
# 'view_mode': 'tree,form',
|
||||||
# })
|
# })
|
||||||
# return action
|
# return action
|
||||||
|
|
||||||
def action_view_surface_technics_purchase(self):
|
def action_view_surface_technics_purchase(self):
|
||||||
self.ensure_one()
|
self.ensure_one()
|
||||||
# if self.routing_type == '表面工艺':
|
# if self.routing_type == '表面工艺':
|
||||||
@@ -513,7 +514,8 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
return result
|
return result
|
||||||
|
|
||||||
def _get_surface_technics_purchase_ids(self):
|
def _get_surface_technics_purchase_ids(self):
|
||||||
domain = [('origin', 'like', '%' + self.production_id.name + '%'), ('purchase_type', '=', 'consignment'), ('state', '!=', 'cancel')]
|
domain = [('origin', 'like', '%' + self.production_id.name + '%'), ('purchase_type', '=', 'consignment'),
|
||||||
|
('state', '!=', 'cancel')]
|
||||||
# domain = [('origin', 'like', '%' + self.production_id.name + '%'), ('purchase_type', '=', 'consignment')]
|
# domain = [('origin', 'like', '%' + self.production_id.name + '%'), ('purchase_type', '=', 'consignment')]
|
||||||
# domain = [('group_id', '=', self.production_id.procurement_group_id.id), ('purchase_type', '=', 'consignment')]
|
# domain = [('group_id', '=', self.production_id.procurement_group_id.id), ('purchase_type', '=', 'consignment')]
|
||||||
purchase_orders = self.env['purchase.order'].search(domain, order='id desc')
|
purchase_orders = self.env['purchase.order'].search(domain, order='id desc')
|
||||||
@@ -1243,6 +1245,13 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
}]
|
}]
|
||||||
return workorders_values_str
|
return workorders_values_str
|
||||||
|
|
||||||
|
# def check_lot_exists(self, picking_id, lot_id):
|
||||||
|
# return bool(
|
||||||
|
# picking_id.move_ids.move_line_ids.filtered(
|
||||||
|
# lambda line: line.lot_id.id == lot_id
|
||||||
|
# )
|
||||||
|
# )
|
||||||
|
|
||||||
def _process_compute_state(self):
|
def _process_compute_state(self):
|
||||||
sorted_workorders = sorted(self, key=lambda x: x.sequence)
|
sorted_workorders = sorted(self, key=lambda x: x.sequence)
|
||||||
for workorder in sorted_workorders:
|
for workorder in sorted_workorders:
|
||||||
@@ -1264,10 +1273,17 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
workorder.state = 'pending'
|
workorder.state = 'pending'
|
||||||
continue
|
continue
|
||||||
# ================= 如果制造订单制造类型为【人工线下加工】==========================
|
# ================= 如果制造订单制造类型为【人工线下加工】==========================
|
||||||
|
# lot_id = workorder.production_id.move_raw_ids.move_line_ids.lot_id
|
||||||
|
# picking_ids = workorder.production_id.picking_ids.filtered(
|
||||||
|
# lambda wk: wk.location_id.name == '外协收料区' and wk.location_dest_id.name == '制造前')
|
||||||
|
# exists = any(
|
||||||
|
# move_line.lot_id == lot_id
|
||||||
|
# for picking in picking_ids
|
||||||
|
# for move in picking.move_ids
|
||||||
|
# for move_line in move.move_line_ids
|
||||||
|
# )
|
||||||
if (workorder.production_id.production_type == '人工线下加工'
|
if (workorder.production_id.production_type == '人工线下加工'
|
||||||
and workorder.production_id.schedule_state == '已排'
|
and workorder.production_id.schedule_state == '已排'):
|
||||||
and len(workorder.production_id.picking_ids.filtered(
|
|
||||||
lambda w: w.state not in ['done', 'cancel'])) == 0):
|
|
||||||
# and workorder.production_id.programming_state == '已编程'
|
# and workorder.production_id.programming_state == '已编程'
|
||||||
if workorder.is_subcontract is True:
|
if workorder.is_subcontract is True:
|
||||||
if workorder.production_id.state == 'rework':
|
if workorder.production_id.state == 'rework':
|
||||||
@@ -1276,6 +1292,9 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
purchase_orders_id = self._get_surface_technics_purchase_ids()
|
purchase_orders_id = self._get_surface_technics_purchase_ids()
|
||||||
if purchase_orders_id.state == 'purchase':
|
if purchase_orders_id.state == 'purchase':
|
||||||
workorder.state = 'ready'
|
workorder.state = 'ready'
|
||||||
|
# picking_id = workorder.production_id.picking_ids.filtered(
|
||||||
|
# lambda wk: wk.location_id.name == '制造前' and wk.location_dest_id.name == '外协加工区')
|
||||||
|
# move_out = picking_id.move_ids
|
||||||
move_out = workorder.move_subcontract_workorder_ids[1]
|
move_out = workorder.move_subcontract_workorder_ids[1]
|
||||||
for mo in move_out:
|
for mo in move_out:
|
||||||
if mo.state != 'done':
|
if mo.state != 'done':
|
||||||
@@ -1316,6 +1335,10 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
if purchase_orders_id.state == 'purchase':
|
if purchase_orders_id.state == 'purchase':
|
||||||
workorder.state = 'ready'
|
workorder.state = 'ready'
|
||||||
move_out = workorder.move_subcontract_workorder_ids[1]
|
move_out = workorder.move_subcontract_workorder_ids[1]
|
||||||
|
# picking_id = workorder.production_id.picking_ids.filtered(
|
||||||
|
# lambda
|
||||||
|
# wk: wk.location_id.name == '制造前' and wk.location_dest_id.name == '外协加工区')
|
||||||
|
# move_out = picking_id.move_ids
|
||||||
for mo in move_out:
|
for mo in move_out:
|
||||||
if mo.state != 'done':
|
if mo.state != 'done':
|
||||||
mo.write({'state': 'assigned', 'production_id': False})
|
mo.write({'state': 'assigned', 'production_id': False})
|
||||||
@@ -1325,7 +1348,6 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
else:
|
else:
|
||||||
workorder.state = 'waiting'
|
workorder.state = 'waiting'
|
||||||
|
|
||||||
|
|
||||||
@api.depends('production_availability', 'blocked_by_workorder_ids', 'blocked_by_workorder_ids.state',
|
@api.depends('production_availability', 'blocked_by_workorder_ids', 'blocked_by_workorder_ids.state',
|
||||||
'production_id.tool_state', 'production_id.schedule_state', 'sequence',
|
'production_id.tool_state', 'production_id.schedule_state', 'sequence',
|
||||||
'production_id.programming_state')
|
'production_id.programming_state')
|
||||||
@@ -1357,7 +1379,8 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
# 判断是否有坯料的序列号信息
|
# 判断是否有坯料的序列号信息
|
||||||
boolean = False
|
boolean = False
|
||||||
if self.production_id.move_raw_ids:
|
if self.production_id.move_raw_ids:
|
||||||
if self.production_id.move_raw_ids[0].product_id.categ_type == '坯料' and self.production_id.move_raw_ids[0].product_id.tracking == 'serial':
|
if self.production_id.move_raw_ids[0].product_id.categ_type == '坯料' and \
|
||||||
|
self.production_id.move_raw_ids[0].product_id.tracking == 'serial':
|
||||||
if self.production_id.move_raw_ids[0].move_line_ids:
|
if self.production_id.move_raw_ids[0].move_line_ids:
|
||||||
if self.production_id.move_raw_ids[0].move_line_ids[0].lot_id.name:
|
if self.production_id.move_raw_ids[0].move_line_ids[0].lot_id.name:
|
||||||
boolean = True
|
boolean = True
|
||||||
@@ -1390,6 +1413,10 @@ class ResMrpWorkOrder(models.Model):
|
|||||||
if self.routing_type == '表面工艺':
|
if self.routing_type == '表面工艺':
|
||||||
if self.is_subcontract is True:
|
if self.is_subcontract is True:
|
||||||
move_out = self.move_subcontract_workorder_ids[1]
|
move_out = self.move_subcontract_workorder_ids[1]
|
||||||
|
# picking_id = self.production_id.picking_ids.filtered(
|
||||||
|
# lambda wk: wk.location_id.name == '制造前' and wk.location_dest_id.name == '外协加工区')
|
||||||
|
# move_out = picking_id.move_ids
|
||||||
|
# move_out = self.move_subcontract_workorder_ids[1]
|
||||||
# move_out = self.env['stock.move'].search(
|
# move_out = self.env['stock.move'].search(
|
||||||
# [('location_id', '=', self.env['stock.location'].search(
|
# [('location_id', '=', self.env['stock.location'].search(
|
||||||
# [('barcode', 'ilike', 'WH-PREPRODUCTION')]).id),
|
# [('barcode', 'ilike', 'WH-PREPRODUCTION')]).id),
|
||||||
|
|||||||
@@ -59,15 +59,9 @@ class PurchaseOrder(models.Model):
|
|||||||
production_id = self.env['mrp.production'].search([('origin', 'in', origins)])
|
production_id = self.env['mrp.production'].search([('origin', 'in', origins)])
|
||||||
purchase.production_count = len(production_id)
|
purchase.production_count = len(production_id)
|
||||||
|
|
||||||
def button_confirm(self):
|
# def process_replenish(self,production,total_qty):
|
||||||
for record in self:
|
# record = self
|
||||||
for line in record.order_line:
|
# bom_line_id = production.bom_id.bom_line_ids
|
||||||
if line.product_qty <= 0:
|
|
||||||
raise UserError('请对【产品】中的【数量】进行输入')
|
|
||||||
if line.price_unit <= 0:
|
|
||||||
raise UserError('请对【产品】中的【单价】进行输入')
|
|
||||||
# if record.purchase_type == 'consignment':
|
|
||||||
# bom_line_id = record.order_line[0].purchase_request_lines.request_id.bom_id.bom_line_ids
|
|
||||||
# replenish = self.env['stock.warehouse.orderpoint'].search([
|
# replenish = self.env['stock.warehouse.orderpoint'].search([
|
||||||
# ('product_id', '=', bom_line_id.product_id.id),
|
# ('product_id', '=', bom_line_id.product_id.id),
|
||||||
# (
|
# (
|
||||||
@@ -82,7 +76,7 @@ class PurchaseOrder(models.Model):
|
|||||||
# 'sf_stock.stock_location_outsourcing_material_receiving_area').id,
|
# 'sf_stock.stock_location_outsourcing_material_receiving_area').id,
|
||||||
# 'route_id': self.env.ref('sf_stock.stock_route_process_outsourcing').id,
|
# 'route_id': self.env.ref('sf_stock.stock_route_process_outsourcing').id,
|
||||||
# 'group_id': record.group_id.id,
|
# 'group_id': record.group_id.id,
|
||||||
# 'qty_to_order': 1,
|
# 'qty_to_order': total_qty,
|
||||||
# 'origin': record.name,
|
# 'origin': record.name,
|
||||||
# })
|
# })
|
||||||
# else:
|
# else:
|
||||||
@@ -92,11 +86,70 @@ class PurchaseOrder(models.Model):
|
|||||||
# 'sf_stock.stock_location_outsourcing_material_receiving_area').id,
|
# 'sf_stock.stock_location_outsourcing_material_receiving_area').id,
|
||||||
# 'route_id': self.env.ref('sf_stock.stock_route_process_outsourcing').id,
|
# 'route_id': self.env.ref('sf_stock.stock_route_process_outsourcing').id,
|
||||||
# 'group_id': record.group_id.id,
|
# 'group_id': record.group_id.id,
|
||||||
# 'qty_to_order': 1 + replenish.qty_to_order,
|
# 'qty_to_order': total_qty + replenish.qty_to_order,
|
||||||
# 'origin': record.name + ',' + replenish.origin,
|
# 'origin': record.name + ',' + replenish.origin,
|
||||||
# })
|
# })
|
||||||
# replenish.action_replenish()
|
# replenish.action_replenish()
|
||||||
|
|
||||||
|
# def outsourcing_service_replenishment(self):
|
||||||
|
# record = self
|
||||||
|
# if record.purchase_type != 'consignment':
|
||||||
|
# return
|
||||||
|
# grouped_lines = {}
|
||||||
|
# for line in record.order_line:
|
||||||
|
# if line.related_product.id not in grouped_lines:
|
||||||
|
# grouped_lines[line.related_product.id] = []
|
||||||
|
# grouped_lines[line.related_product.id].append(line)
|
||||||
|
# for product_id,lines in grouped_lines.items():
|
||||||
|
# production = self.env['mrp.production'].search([('product_id', '=', product_id)], limit=1)
|
||||||
|
# if not production:
|
||||||
|
# continue
|
||||||
|
# total_qty = sum(line.product_qty for line in lines)
|
||||||
|
# record.process_replenish(production,total_qty)
|
||||||
|
# for product_id,lines in grouped_lines.items():
|
||||||
|
# productions = self.env['mrp.production'].search([('product_id', '=', product_id)], limit=1)
|
||||||
|
# if not productions:
|
||||||
|
# continue
|
||||||
|
# # production.bom_id.bom_line_ids.product_id
|
||||||
|
# location_id = self.env['stock.location'].search([('name', '=', '制造前')])
|
||||||
|
# quants = self.env['stock.quant'].search([
|
||||||
|
# ('product_id', '=', productions.bom_id.bom_line_ids.product_id.id),
|
||||||
|
# ('location_id', '=', location_id.id)
|
||||||
|
# ])
|
||||||
|
# total_qty = sum(quants.mapped('quantity')) # 计算该位置的总库存量
|
||||||
|
# is_available = total_qty > 0
|
||||||
|
# if not is_available:
|
||||||
|
# raise UserError('请先完成坯料入库')
|
||||||
|
# for production_id in productions:
|
||||||
|
# work_ids = production_id.workorder_ids.filtered(
|
||||||
|
# lambda wk: wk.state not in ['done', 'rework', 'cancel'])
|
||||||
|
# if not work_ids:
|
||||||
|
# continue
|
||||||
|
# min_sequence_wk = min(work_ids, key=lambda wk: wk.sequence)
|
||||||
|
# if min_sequence_wk.is_subcontract:
|
||||||
|
# picking_id = production_id.picking_ids.filtered(
|
||||||
|
# lambda wk: wk.location_id.name == '制造前' and wk.location_dest_id.name == '外协加工区')
|
||||||
|
# move_out = picking_id.move_ids
|
||||||
|
# for mo in move_out:
|
||||||
|
# if mo.state != 'done':
|
||||||
|
# mo.write({'state': 'assigned', 'production_id': False})
|
||||||
|
# if not mo.move_line_ids:
|
||||||
|
# self.env['stock.move.line'].create(
|
||||||
|
# mo.get_move_line(production_id, min_sequence_wk))
|
||||||
|
# product = self.env['mrp.production'].search([('product_id', '=', product_id)], limit=1)
|
||||||
|
# match = re.search(r'(S\d{5}-\d)',product.name)
|
||||||
|
# pass
|
||||||
|
def button_confirm(self):
|
||||||
|
for record in self:
|
||||||
|
for line in record.order_line:
|
||||||
|
if line.product_qty <= 0:
|
||||||
|
raise UserError('请对【产品】中的【数量】进行输入')
|
||||||
|
if line.price_unit <= 0:
|
||||||
|
raise UserError('请对【产品】中的【单价】进行输入')
|
||||||
|
# record.outsourcing_service_replenishment()
|
||||||
|
|
||||||
res = super(PurchaseOrder, self).button_confirm()
|
res = super(PurchaseOrder, self).button_confirm()
|
||||||
|
|
||||||
for line in self.order_line:
|
for line in self.order_line:
|
||||||
# 将产品不追踪序列号的行项目设置qty_done
|
# 将产品不追踪序列号的行项目设置qty_done
|
||||||
if line.move_ids and line.move_ids[0].product_id.tracking == 'none':
|
if line.move_ids and line.move_ids[0].product_id.tracking == 'none':
|
||||||
|
|||||||
@@ -1,4 +1,4 @@
|
|||||||
# # -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
# import base64
|
# import base64
|
||||||
# import datetime
|
# import datetime
|
||||||
# import logging
|
# import logging
|
||||||
@@ -7,24 +7,24 @@
|
|||||||
# import re
|
# import re
|
||||||
# import traceback
|
# import traceback
|
||||||
# from operator import itemgetter
|
# from operator import itemgetter
|
||||||
#
|
|
||||||
# import requests
|
# import requests
|
||||||
# from itertools import groupby
|
# from itertools import groupby
|
||||||
# from collections import defaultdict, namedtuple
|
# from collections import defaultdict, namedtuple
|
||||||
#
|
|
||||||
# from odoo import api, fields, models, SUPERUSER_ID, _
|
# from odoo import api, fields, models, SUPERUSER_ID, _
|
||||||
# from odoo.exceptions import UserError, ValidationError
|
# from odoo.exceptions import UserError, ValidationError
|
||||||
# from odoo.tools import float_compare, float_round, float_is_zero, format_datetime
|
# from odoo.tools import float_compare, float_round, float_is_zero, format_datetime
|
||||||
#
|
|
||||||
#
|
|
||||||
# class PurchaseRequestLine(models.Model):
|
# class PurchaseRequestLine(models.Model):
|
||||||
# _inherit = 'purchase.request'
|
# _inherit = 'purchase.request'
|
||||||
# is_subcontract = fields.Boolean(string='是否外协',default=False)
|
# is_subcontract = fields.Boolean(string='是否外协',default=False)
|
||||||
# class PurchaseRequestLine(models.Model):
|
# class PurchaseRequestLine(models.Model):
|
||||||
# _inherit = 'purchase.request.line'
|
# _inherit = 'purchase.request.line'
|
||||||
# is_subcontract = fields.Boolean(string='是否外协')
|
# is_subcontract = fields.Boolean(string='是否外协')
|
||||||
#
|
|
||||||
#
|
|
||||||
# class PurchaseRequest(models.Model):
|
# class PurchaseRequest(models.Model):
|
||||||
# _inherit = 'purchase.request'
|
# _inherit = 'purchase.request'
|
||||||
# bom_id = fields.Many2one('mrp.bom')
|
# bom_id = fields.Many2one('mrp.bom')
|
||||||
|
|||||||
@@ -56,10 +56,10 @@ class SaleOrder(models.Model):
|
|||||||
'jikimo_sale_multiple_supply_methods.product_template_manual_processing').sudo()
|
'jikimo_sale_multiple_supply_methods.product_template_manual_processing').sudo()
|
||||||
|
|
||||||
# 复制成品模板上的属性
|
# 复制成品模板上的属性
|
||||||
line.product_id.product_tmpl_id.copy_template(product_template_id)
|
line.product_id.copy_template(product_template_id)
|
||||||
# 将模板上的single_manufacturing属性复制到成品上
|
# 将模板上的single_manufacturing属性复制到成品上
|
||||||
line.product_id.single_manufacturing = product_template_id.single_manufacturing
|
# line.product_id.single_manufacturing = product_template_id.single_manufacturing
|
||||||
line.product_id.tracking = product_template_id.tracking
|
# line.product_id.tracking = product_template_id.tracking
|
||||||
|
|
||||||
order_id = self
|
order_id = self
|
||||||
product = line.product_id
|
product = line.product_id
|
||||||
@@ -76,7 +76,7 @@ class SaleOrder(models.Model):
|
|||||||
'embryo_redundancy_id': line.embryo_redundancy_id,
|
'embryo_redundancy_id': line.embryo_redundancy_id,
|
||||||
}
|
}
|
||||||
product_name = ''
|
product_name = ''
|
||||||
match = re.search(r'(S\d{5}-\d)', product.name)
|
match = re.search(r'(S\d{5}-\d*)', product.name)
|
||||||
# 如果匹配成功,提取结果
|
# 如果匹配成功,提取结果
|
||||||
if match:
|
if match:
|
||||||
product_name = match.group(0)
|
product_name = match.group(0)
|
||||||
|
|||||||
@@ -20,13 +20,13 @@ class SfProductionProcessParameter(models.Model):
|
|||||||
# is_product_button = fields.Boolean(compute='_compute_is_product_button',default=False)
|
# is_product_button = fields.Boolean(compute='_compute_is_product_button',default=False)
|
||||||
# is_delete_button = fields.Boolean(compute='_compute_is_delete_button', default=False)
|
# is_delete_button = fields.Boolean(compute='_compute_is_delete_button', default=False)
|
||||||
# routing_id = fields.Many2one('mrp.routing.workcenter', string="工序")
|
# routing_id = fields.Many2one('mrp.routing.workcenter', string="工序")
|
||||||
#
|
|
||||||
# @api.depends('outsourced_service_products')
|
# @api.depends('outsourced_service_products')
|
||||||
# def _compute_service_products(self):
|
# def _compute_service_products(self):
|
||||||
# for record in self:
|
# for record in self:
|
||||||
# # 假设取第一条作为主明细
|
# # 假设取第一条作为主明细
|
||||||
# record.service_products = record.outsourced_service_products.id if record.outsourced_service_products else False
|
# record.service_products = record.outsourced_service_products.ids if record.outsourced_service_products else False
|
||||||
#
|
|
||||||
# def _inverse_service_products(self):
|
# def _inverse_service_products(self):
|
||||||
# for record in self:
|
# for record in self:
|
||||||
# if record.service_products:
|
# if record.service_products:
|
||||||
@@ -45,7 +45,7 @@ class SfProductionProcessParameter(models.Model):
|
|||||||
# for record in self:
|
# for record in self:
|
||||||
# if len(record.outsourced_service_products) > 1:
|
# if len(record.outsourced_service_products) > 1:
|
||||||
# raise ValidationError("工艺参数不能与多个产品关联")
|
# raise ValidationError("工艺参数不能与多个产品关联")
|
||||||
#
|
|
||||||
# @api.onchange('outsourced_service_products')
|
# @api.onchange('outsourced_service_products')
|
||||||
# def _onchange_validate_partner_limit(self):
|
# def _onchange_validate_partner_limit(self):
|
||||||
# for record in self:
|
# for record in self:
|
||||||
@@ -58,7 +58,7 @@ class SfProductionProcessParameter(models.Model):
|
|||||||
# record.is_product_button = True
|
# record.is_product_button = True
|
||||||
# else:
|
# else:
|
||||||
# record.is_product_button = False
|
# record.is_product_button = False
|
||||||
#
|
|
||||||
# def has_wksp_prefix(self):
|
# def has_wksp_prefix(self):
|
||||||
# """
|
# """
|
||||||
# 判断字符串是否以WKSP开头(不区分大小写)
|
# 判断字符串是否以WKSP开头(不区分大小写)
|
||||||
|
|||||||
@@ -631,6 +631,62 @@ class StockPicking(models.Model):
|
|||||||
move.action_clear_lines_show_details()
|
move.action_clear_lines_show_details()
|
||||||
move.action_show_details()
|
move.action_show_details()
|
||||||
res = super().button_validate()
|
res = super().button_validate()
|
||||||
|
# lot_ids = None
|
||||||
|
# product_ids = self.move_ids.mapped('product_id')
|
||||||
|
# if not self.move_ids[0].product_id.single_manufacturing and self.move_ids[0].product_id.tracking == 'none':
|
||||||
|
# lot_ids = self.move_ids.move_line_ids.mapped('lot_id')
|
||||||
|
# production_ids = self.sale_order_id.mrp_production_ids if self.sale_order_id else self.env['mrp.production']
|
||||||
|
# if res and self.location_id.name == '外协收料区' and self.location_dest_id.name == '制造前':
|
||||||
|
# # 如果是最后一张外协入库单,则设置库存位置的预留数量
|
||||||
|
# for production_id in production_ids:
|
||||||
|
# if lot_ids:
|
||||||
|
# lot_id = production_id.move_raw_ids.move_line_ids.lot_id
|
||||||
|
# # picking_ids = production_id.picking_ids.filtered(
|
||||||
|
# # lambda wk: wk.location_id.name == '外协收料区' and wk.location_dest_id.name == '制造前')
|
||||||
|
# if lot_id in lot_ids:
|
||||||
|
# workorder_id = production_id.workorder_ids.filtered(
|
||||||
|
# lambda a: a.state == 'progress' and a.is_subcontract)
|
||||||
|
# if not workorder_id:
|
||||||
|
# continue
|
||||||
|
# workorder_id.button_finish()
|
||||||
|
# else:
|
||||||
|
# workorder_id = production_id.workorder_ids.filtered(lambda a: a.state == 'progress' and a.is_subcontract)
|
||||||
|
# if not workorder_id:
|
||||||
|
# continue
|
||||||
|
# workorder_id.button_finish()
|
||||||
|
# # lot_id = workorder.production_id.move_raw_ids.move_line_ids.lot_id
|
||||||
|
# # picking_ids = workorder.production_id.picking_ids.filtered(
|
||||||
|
# # lambda wk: wk.location_id.name == '外协收料区' and wk.location_dest_id.name == '制造前')
|
||||||
|
|
||||||
|
# # if move_in:
|
||||||
|
# # workorder = move_in.subcontract_workorder_id
|
||||||
|
# # workorders = workorder.production_id.workorder_ids
|
||||||
|
# # subcontract_workorders = workorders.filtered(
|
||||||
|
# # lambda wo: wo.is_subcontract == True and wo.state != 'cancel').sorted('sequence')
|
||||||
|
# # # if workorder == subcontract_workorders[-1]:
|
||||||
|
# # # self.env['stock.quant']._update_reserved_quantity(
|
||||||
|
# # # move_in.product_id, move_in.location_dest_id, move_in.product_uom_qty,
|
||||||
|
# # # lot_id=move_in.move_line_ids.lot_id,
|
||||||
|
# # # package_id=False, owner_id=False, strict=False
|
||||||
|
# # # )
|
||||||
|
# # workorder.button_finish()
|
||||||
|
# if res and self.location_id.name == '制造前' and self.location_dest_id.name == '外协加工区':
|
||||||
|
# for production_id in production_ids:
|
||||||
|
# if lot_ids:
|
||||||
|
# lot_id = production_id.move_raw_ids.move_line_ids.lot_id
|
||||||
|
# # picking_ids = production_id.picking_ids.filtered(
|
||||||
|
# # lambda wk: wk.location_id.name == '外协收料区' and wk.location_dest_id.name == '制造前')
|
||||||
|
# if lot_id in lot_ids:
|
||||||
|
# workorder_id = production_id.workorder_ids.filtered(
|
||||||
|
# lambda a: a.state == 'progress' and a.is_subcontract)
|
||||||
|
# if not workorder_id:
|
||||||
|
# continue
|
||||||
|
# workorder_id.button_finish()
|
||||||
|
# else:
|
||||||
|
# workorder_id = production_id.workorder_ids.filtered(lambda a: a.state == 'ready' and a.is_subcontract)
|
||||||
|
# if not workorder_id:
|
||||||
|
# continue
|
||||||
|
# workorder_id.button_start()
|
||||||
picking_type_in = self.env.ref('sf_manufacturing.outcontract_picking_in').id
|
picking_type_in = self.env.ref('sf_manufacturing.outcontract_picking_in').id
|
||||||
if res is True and self.picking_type_id.id == picking_type_in:
|
if res is True and self.picking_type_id.id == picking_type_in:
|
||||||
# 如果是最后一张外协入库单,则设置库存位置的预留数量
|
# 如果是最后一张外协入库单,则设置库存位置的预留数量
|
||||||
|
|||||||
11
sf_manufacturing/models/stock_warehouse_orderpoint.py
Normal file
11
sf_manufacturing/models/stock_warehouse_orderpoint.py
Normal file
@@ -0,0 +1,11 @@
|
|||||||
|
# -*- coding: utf-8 -*-
|
||||||
|
# Part of SmartGo. See LICENSE file for full copyright and licensing details.
|
||||||
|
import base64
|
||||||
|
from io import BytesIO
|
||||||
|
from odoo import api, fields, models, SUPERUSER_ID, _
|
||||||
|
|
||||||
|
|
||||||
|
class StockWarehouseOrderpoint(models.Model):
|
||||||
|
_inherit = 'stock.warehouse.orderpoint'
|
||||||
|
origin = fields.Char(string='来源')
|
||||||
|
_order = 'create_date DESC'
|
||||||
@@ -22,26 +22,26 @@
|
|||||||
<field name="is_repeat"/>
|
<field name="is_repeat"/>
|
||||||
<field name="reserved_duration"/>
|
<field name="reserved_duration"/>
|
||||||
</field>
|
</field>
|
||||||
<!-- <xpath expr="//notebook/page[1]" position="before">-->
|
<!-- <xpath expr="//notebook/page[1]" position="before">
|
||||||
<!-- <page string="可选工艺参数">-->
|
<page string="可选工艺参数">
|
||||||
<!-- <field name="optional_process_parameters">-->
|
<field name="optional_process_parameters">
|
||||||
<!-- <tree editable="bottom">-->
|
<tree editable="bottom">
|
||||||
<!-- <field name="is_product_button" invisible="1"/>-->
|
<field name="is_product_button" invisible="1"/>
|
||||||
<!-- <field name="is_delete_button" invisible="1"/>-->
|
<field name="is_delete_button" invisible="1"/>
|
||||||
<!-- <field name="code" attrs="{'readonly': True}"/>-->
|
<field name="code" attrs="{'readonly': True}"/>
|
||||||
<!-- <field name="name" required="1"/>-->
|
<field name="name" required="1"/>
|
||||||
<!-- <field name="service_products" domain="[('detailed_type', '=', 'service'),('server_product_process_parameters_id', '=', False)]"/>-->
|
<field name="service_products" domain="[('detailed_type', '=', 'service'),('server_product_process_parameters_id', '=', False)]"/> -->
|
||||||
<!-- <!– 按钮列 –>-->
|
<!-- 按钮列 -->
|
||||||
<!-- <button name="action_create_service_product" string="创建服务产品" type="object"-->
|
<!-- <button name="action_create_service_product" string="创建服务产品" type="object"
|
||||||
<!-- class="btn-primary"-->
|
class="btn-primary"
|
||||||
<!-- attrs="{'invisible': [('is_product_button', '=', True)]}" context="{'default_process_parameter_id':id}"/>-->
|
attrs="{'invisible': [('is_product_button', '=', True)]}" context="{'default_process_parameter_id':id}"/>
|
||||||
<!-- <button name="action_hide_service_products" string="删除" type="object"-->
|
<button name="action_hide_service_products" string="删除" type="object"
|
||||||
<!-- class="oe_highlight"-->
|
class="oe_highlight"
|
||||||
<!-- attrs="{'invisible': [('is_delete_button', '=', True)]}"/>-->
|
attrs="{'invisible': [('is_delete_button', '=', True)]}"/>
|
||||||
<!-- </tree>-->
|
</tree>
|
||||||
<!-- </field>-->
|
</field>
|
||||||
<!-- </page>-->
|
</page>
|
||||||
<!-- </xpath>-->
|
</xpath> -->
|
||||||
</field>
|
</field>
|
||||||
</record>
|
</record>
|
||||||
</data>
|
</data>
|
||||||
|
|||||||
@@ -144,17 +144,17 @@
|
|||||||
statusbar_visible="pending,waiting,ready,progress,to be detected,done,rework"/>
|
statusbar_visible="pending,waiting,ready,progress,to be detected,done,rework"/>
|
||||||
</xpath>
|
</xpath>
|
||||||
<xpath expr="//div[@name='button_box']" position="inside">
|
<xpath expr="//div[@name='button_box']" position="inside">
|
||||||
<!-- <button type="object" name="action_view_pr_mrp_workorder" class="oe_stat_button"-->
|
<!-- <button type="object" name="action_view_pr_mrp_workorder" class="oe_stat_button"
|
||||||
<!-- icon="fa-credit-card"-->
|
icon="fa-credit-card"
|
||||||
<!-- groups="base.group_user,sf_base.group_sf_order_user"-->
|
groups="base.group_user,sf_base.group_sf_order_user"
|
||||||
<!-- attrs="{'invisible': [('pr_mp_count', '=', 0)]}">-->
|
attrs="{'invisible': [('pr_mp_count', '=', 0)]}">
|
||||||
<!-- <div class="o_field_widget o_stat_info">-->
|
<div class="o_field_widget o_stat_info">
|
||||||
<!-- <span class="o_stat_value">-->
|
<span class="o_stat_value">
|
||||||
<!-- <field name="pr_mp_count"/>-->
|
<field name="pr_mp_count"/>
|
||||||
<!-- </span>-->
|
</span>
|
||||||
<!-- <span class="o_stat_text">采购申请</span>-->
|
<span class="o_stat_text">采购申请</span>
|
||||||
<!-- </div>-->
|
</div>
|
||||||
<!-- </button>-->
|
</button> -->
|
||||||
<button type="object" name="action_view_surface_technics_purchase" class="oe_stat_button"
|
<button type="object" name="action_view_surface_technics_purchase" class="oe_stat_button"
|
||||||
icon="fa-credit-card"
|
icon="fa-credit-card"
|
||||||
groups="base.group_user,sf_base.group_sf_order_user"
|
groups="base.group_user,sf_base.group_sf_order_user"
|
||||||
|
|||||||
16
sf_manufacturing/views/stock_warehouse_orderpoint.xml
Normal file
16
sf_manufacturing/views/stock_warehouse_orderpoint.xml
Normal file
@@ -0,0 +1,16 @@
|
|||||||
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
|
<odoo>
|
||||||
|
<data>
|
||||||
|
<record id="view_warehouse_orderpoint_tree_editable_inherit" model="ir.ui.view">
|
||||||
|
<field name="name">补货</field>
|
||||||
|
<field name="model">stock.warehouse.orderpoint</field>
|
||||||
|
<field name="inherit_id" ref="stock.view_warehouse_orderpoint_tree_editable"/>
|
||||||
|
<field name="arch" type="xml">
|
||||||
|
<xpath expr="//field[@name='qty_to_order']" position="after">
|
||||||
|
<field name="origin"/>
|
||||||
|
</xpath>
|
||||||
|
</field>
|
||||||
|
</record>
|
||||||
|
<!-- 继承补货单的搜索视图 -->
|
||||||
|
</data>
|
||||||
|
</odoo>
|
||||||
@@ -126,7 +126,15 @@ class QualityCheck(models.Model):
|
|||||||
# todo 需修改
|
# todo 需修改
|
||||||
val = ['0037818516']
|
val = ['0037818516']
|
||||||
logging.info('获取到的工单信息%s' % val)
|
logging.info('获取到的工单信息%s' % val)
|
||||||
r = requests.post(crea_url, json=val, headers=headers)
|
# r = requests.post(crea_url, json=val, headers=headers)
|
||||||
|
r = self.env['api.request.log'].log_request(
|
||||||
|
'get',
|
||||||
|
crea_url,
|
||||||
|
name='零件特采',
|
||||||
|
responser='中控系统',
|
||||||
|
json=val,
|
||||||
|
headers=headers
|
||||||
|
)
|
||||||
ret = r.json()
|
ret = r.json()
|
||||||
logging.info('_register_quality_check:%s' % ret)
|
logging.info('_register_quality_check:%s' % ret)
|
||||||
if ret['Succeed']:
|
if ret['Succeed']:
|
||||||
|
|||||||
@@ -393,10 +393,11 @@ class RePurchaseOrder(models.Model):
|
|||||||
# # route_ids
|
# # route_ids
|
||||||
# result.append({
|
# result.append({
|
||||||
# "product_id": server_template.product_variant_id.id,
|
# "product_id": server_template.product_variant_id.id,
|
||||||
|
# 'related_product': production.product_id.id,
|
||||||
# "name": production.procurement_group_id.name,
|
# "name": production.procurement_group_id.name,
|
||||||
# "date_required": fields.Datetime.now(),
|
# "date_required": fields.Datetime.now(),
|
||||||
# "product_uom_id":server_template.uom_id.id,
|
# "product_uom_id":server_template.uom_id.id,
|
||||||
# "product_qty": 1,
|
# "product_qty": production.product_qty,
|
||||||
# "request_id": False,
|
# "request_id": False,
|
||||||
# "move_dest_ids": False,
|
# "move_dest_ids": False,
|
||||||
# "orderpoint_id": False,
|
# "orderpoint_id": False,
|
||||||
|
|||||||
@@ -4,12 +4,14 @@ import json
|
|||||||
import base64
|
import base64
|
||||||
from odoo import http
|
from odoo import http
|
||||||
from odoo.http import request
|
from odoo.http import request
|
||||||
|
from odoo.addons.sf_base.decorators.api_log import api_log
|
||||||
|
|
||||||
|
|
||||||
class Manufacturing_Connect(http.Controller):
|
class Manufacturing_Connect(http.Controller):
|
||||||
|
|
||||||
@http.route('/AutoDeviceApi/ToolGroup', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/ToolGroup', type='json', auth='sf_token', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('刀具组', requester='中控系统')
|
||||||
def get_functional_tool_groups_Info(self, **kw):
|
def get_functional_tool_groups_Info(self, **kw):
|
||||||
"""
|
"""
|
||||||
刀具组接口
|
刀具组接口
|
||||||
@@ -39,6 +41,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/ToolInventory', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/ToolInventory', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('功能刀具清单', requester='中控系统')
|
||||||
def get_functional_tool_inventory_Info(self, **kw):
|
def get_functional_tool_inventory_Info(self, **kw):
|
||||||
"""
|
"""
|
||||||
功能刀具清单接口
|
功能刀具清单接口
|
||||||
@@ -68,6 +71,7 @@ class Manufacturing_Connect(http.Controller):
|
|||||||
|
|
||||||
@http.route('/AutoDeviceApi/ToolEntity', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
@http.route('/AutoDeviceApi/ToolEntity', type='json', auth='none', methods=['GET', 'POST'], csrf=False,
|
||||||
cors="*")
|
cors="*")
|
||||||
|
@api_log('功能刀具', requester='中控系统')
|
||||||
def get_functional_tool_entity_Info(self, **kw):
|
def get_functional_tool_entity_Info(self, **kw):
|
||||||
"""
|
"""
|
||||||
功能刀具列表接口
|
功能刀具列表接口
|
||||||
|
|||||||
@@ -51,7 +51,15 @@ class SfMaintenanceEquipment(models.Model):
|
|||||||
headers = {'Authorization': config['center_control_Authorization']}
|
headers = {'Authorization': config['center_control_Authorization']}
|
||||||
crea_url = config['center_control_url'] + "/AutoDeviceApi/GetToolInfos"
|
crea_url = config['center_control_url'] + "/AutoDeviceApi/GetToolInfos"
|
||||||
params = {"DeviceId": self.name}
|
params = {"DeviceId": self.name}
|
||||||
r = requests.get(crea_url, params=params, headers=headers)
|
# r = requests.get(crea_url, params=params, headers=headers)
|
||||||
|
r = self.env['api.request.log'].log_request(
|
||||||
|
'get',
|
||||||
|
crea_url,
|
||||||
|
name='机床刀库',
|
||||||
|
responser='中控系统',
|
||||||
|
params=params,
|
||||||
|
headers=headers
|
||||||
|
)
|
||||||
ret = r.json()
|
ret = r.json()
|
||||||
logging.info('机床刀库register_equipment_tool():%s' % ret)
|
logging.info('机床刀库register_equipment_tool():%s' % ret)
|
||||||
datas = ret['Datas']
|
datas = ret['Datas']
|
||||||
|
|||||||
@@ -514,7 +514,15 @@ class ShelfLocation(models.Model):
|
|||||||
crea_url = config['center_control_url'] + "/AutoDeviceApi/GetLocationInfos"
|
crea_url = config['center_control_url'] + "/AutoDeviceApi/GetLocationInfos"
|
||||||
|
|
||||||
params = {'DeviceId': device_id}
|
params = {'DeviceId': device_id}
|
||||||
r = requests.get(crea_url, params=params, headers=headers)
|
# r = requests.get(crea_url, params=params, headers=headers)
|
||||||
|
r = self.env['api.request.log'].log_request(
|
||||||
|
'get',
|
||||||
|
crea_url,
|
||||||
|
name='库位信息',
|
||||||
|
responser='中控系统',
|
||||||
|
params=params,
|
||||||
|
headers=headers
|
||||||
|
)
|
||||||
|
|
||||||
ret = r.json()
|
ret = r.json()
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user