/*
NAME: 
DESCRIPTION: 钻孔添加辅助孔,短槽孔,导引孔;
PARAMETER:
    [
		{
			name : 'step',
			title : 'step',
			type : 'LineEdit',
			property : {tool_tip : '目标step,默认是orig'},
		},
		{
            name : 'auto_save',
			title : '自动保存',
            type : 'RadioBox',
            property : {
				item_list:[
					{name:'yes',text:'YES'},
					{name:'no',text:'NO'},
				],
				tool_tip:'是否自动保存料号开关'
			}
        }
	]
	
 VERSION_HISTORY:
	V1.00 2020-09-01 Scott Sun
	    1.新版本
		
 HELP:
 	<html><body bgcolor="#DDECFE">
		<font size="3" color="#003DB2"><p>功能简介</p></font>
		<p> 钻孔添加辅助孔,短槽孔,导引孔 </p>
		<br>
		<font size="3" color="#003DB2"><p>参数配置</p></font>
		<p> step信息 </p>
		<br>
		<font size="3" color="#003DB2"><p>注意事项</p></font>
		<p> 无 </p>
		<br>
	</body></html>	
*/
//////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////
console.log("==============================>template");
// 引入模块 包
var $ = require('topcam.scriptfunc').argv();
var fs = require('fs');
var _ = require('lodash');
var mode = $.ikm ? "topcam" : "aimdfm";
var IKM = $.ikm; 
if (IKM==undefined ) { IKM = require('topcam.ikm6')($) }
var GEN = $.gen;
var GUI = $.gui || {};
var Job = $.job || $.job_name;
var JobId = $.job_id;
var db = $.db || IKM.db
var PAR = {}
if ($.par) { PAR = $.par } else if ($.hasOwnProperty('script_parameter')){ PAR = JSON.parse($.script_parameter); }
if (mode === "aimdfm") {
	var database = require("topsin.database");
	database.addConnection($.conf.database_conf, "DFM");
	var QDfm = database.query("DFM");
	$.QDfm = QDfm;
	if ($.conf.product_type == "aimdfm") {
		QDfm.updateRow({ table: "pdm_aimdfm_task", data: { current_process_title: $.process_title }, where: { id: $.task_id } });
	}
}
var Status = 'ok';
var resultData = [];
var par = PAR;
var default_par = {
	step:"edit",
	auto_save: "No",
	units:"mm"
}
for(var key in default_par){ if (!par.hasOwnProperty(key) || par[key] == ""){ par[key] = default_par[key] }}
var job = Job;
try {
	if(_.isEmpty(job)){throw "参数job不存在"} else { job = job.toLowerCase() }
	if(!GEN.isJobExists({job:job})){throw "料号"+job+"不存在"}
	if(!GEN.isJobOpen({job:job})){ GEN.openJob({job:job}) }
    if(mode == "aimdfm"){ if(GEN.checkInout({job:job,mode:"test"}) != 0){ throw "the job check" } else { GEN.checkInout({job:job,mode:"out"}) } }
	var stepList = GEN.getStepList({job:job})
	stepList = stepList.filter(function(step){
		var reg = new RegExp(par.step,"ig")
		return reg.test(step)
	})

	var drl_slot_tmp = "drl_slot_tmp";
	var drl_pre1 = "drl_pre1";
	var drl_pre2 = "drl_pre2";
	var drl_pre3 = "drl_pre3";
	var drl_pre4 = "drl_pre4";

	var layers_tmp = [drl_slot_tmp,drl_pre1,drl_pre2,drl_pre3,drl_pre4]	

	var matrix = GEN.getMatrix({job:job})

	var drls = Object.keys(matrix).filter(function(key){
		var info = matrix[key];
		return /^drl\d*/.test(info.name) && info.context == "board" 
	})

	var units = par.units;
	stepList.forEach(function(step){
        GEN.openStep({job:job,name:step})
		GEN.clearLayers();  //清除层显示
		GEN.affectedLayer({ mode: 'all', affected: 'no' });  //设置影响层全部不影响
		GEN.COM("sel_options,clear_mode=clear_after,display_mode=all_layers,area_inout=inside,area_select=select,select_mode=standard,area_touching_mode=exclude");
		GEN.units({ type: par.units }); 
		GEN.zoomHome(); 

		drls.forEach(function(drl){
			delIfExist(layers_tmp)
		// 1. 钻孔分离到辅助层   槽长槽宽比 <= 1.8  拷贝到 drl_slot_tmp
		// 2. 4050 <= r <= 5050  拷贝到 drl_pre1
		// 3. 5100 <= r <= 6000  drl_pre2
		// 4. 6050 <= r <= 9000  drl_pre3
		// 5. 9050 <= r <= 12000  drl_pre4
        GEN.workLayer({name:drl,display_number:2,clear_before:'yes'})
		GEN.selectByFilter({attribute:[{attribute:".string", text:"_pre_drl"}]})
        if(GEN.getSelectCount() > 0) {
            IKM.msg("已经存在预钻孔,是否删除重新制作")
            GEN.PAUSE("check")
            GEN.workLayer({name:drl,display_number:2,clear_before:'yes'})
            GEN.selectByFilter({attribute:[{attribute:".string", text:"_pre_drl"}]})
            if(GEN.getSelectCount() > 0) { GEN.selDelete() }
        }
		GEN.selectByFilter({feat_types:"line"})
		if(GEN.getSelectCount() > 0) { GEN.selMoveOther({target_layer:drl_slot_tmp,invert:'no',dx:0,dy:0,size:0}) }
		var syms = GEN.getLayerSymsHist({job:job,step:step,layer:drl,units:units})
		var drl_pre1s = [];
		var drl_pre2s = [];
		var drl_pre3s = [];
		var drl_pre4s = [];
		var slots = [];
		for (var key in syms) {
			if (/r\d/.test(key)) {
				var size = parseFloat(key.slice(1)) 
				if( size >= 4050 && size <= 5050 ) {
					drl_pre1s.push(key)
				} else if ( size >= 5100 && size <= 6000 ) {
					drl_pre2s.push(key)
				} else if ( size >= 6050 && size <= 9000 ) {
					drl_pre3s.push(key)
				} else if ( size >= 9050 && size <= 12000 ) {
					drl_pre4s.push(key)
				}
			} else {
				slots.push(key)
			}
		}
		if (slots.length) {
			GEN.selectByFilter({include_syms:slots.join(";")})
			if(GEN.getSelectCount() > 0) {
				GEN.selMoveOther({target_layer:drl_slot_tmp,invert:'no',dx:0,dy:0,size:0})
			}
		}

		// 1. 槽孔处理  1、槽孔:槽长和槽宽的比≤1.8时需按以下要求添加,添加位置,预钻孔边与槽端相切,预钻孔圆心在槽孔中心线上;取值大小,d=L/2,选刀方式最大化,进位取整 ;分刀,加0.001结尾用于区分普通孔;
		if (GEN.isLayerExists({job:job, layer:drl_slot_tmp})) {
			GEN.workLayer({name:drl_slot_tmp,display_number:2,clear_before:'yes'})
			// 计算每个孔的槽长槽宽比
			var feats = GEN.getFeatures({job:job,step:step,layer:drl_slot_tmp,units:units})
			feats.forEach(function(feat) {
				GEN.selClearFeature()
				if(feat.type == "line"){
					GEN.COM("sel_net_feat,operation=select,x="+feat.xs+",y="+feat.ys+",use_ffilter=no")
				} else if (feat.type == "pad") {
					GEN.COM("sel_net_feat,operation=select,x="+feat.x+",y="+feat.y+",use_ffilter=no")
				}
				if(GEN.getSelectCount() == 1) {
					GEN.selClearFeature()
					if( feat.type == "line") {
						var width = parseFloat(feat.symbol.slice(1));
						var d = Math.sqrt( (feat.xe - feat.xs)*(feat.xe - feat.xs) + (feat.ye - feat.ys)*(feat.ye - feat.ys) )*1000 + width;
						var k = d/width;
						if ( k <= 1.8) {
							// 1. 计算预钻孔 直径
							var r =  Math.ceil((width / 2)/ 50 ) * 50 + 1;
							// 2. 计算槽孔两个端点坐标  计算两个槽孔向内缩短 r/2 后的坐标   // 算法  已知 线段两个端点 一个函数 输入 正负数 算出线段两端加上或者减去输入的值后的端点
							var ret = changeLine(feat, (width-r)/2000)
							// 3. 以算出的坐标为中心 r 为symbol 画预钻孔
							GEN.addPad({x:ret.xe,y:ret.ye,symbol:'r' + r,attributes:[{attribute:".string", text:"_pre_drl"}]})
							GEN.addPad({x:ret.xs,y:ret.ys,symbol:'r' + r,attributes:[{attribute:".string", text:"_pre_drl"}]})
						}
					}
				}
				GEN.selClearFeature()
			})
			GEN.selMoveOther({target_layer:drl,invert:'no',dx:0,dy:0,size:0})
		}

		// 2. drl_pre1s
		if(drl_pre1s.length) {
			GEN.workLayer({name:drl,display_number:2,clear_before:'yes'})
			GEN.selectByFilter({include_syms:drl_pre1s.join(";")})
			if(GEN.getSelectCount() > 0) { 
				GEN.selMoveOther({target_layer:drl_pre1,invert:'no',dx:0,dy:0,size:0}) 
				GEN.workLayer({name:drl_pre1,display_number:2,clear_before:'yes'})
				var feats = GEN.getFeatures({job:job,step:step,layer:drl_pre1,units:units})
				feats.forEach(function(feat) {
					GEN.selClearFeature()
					if(feat.type == "line"){
						GEN.COM("sel_net_feat,operation=select,x="+feat.xs+",y="+feat.ys+",use_ffilter=no")
					} else if (feat.type == "pad") {
						GEN.COM("sel_net_feat,operation=select,x="+feat.x+",y="+feat.y+",use_ffilter=no")
					}
					if(GEN.getSelectCount() == 1) {
						GEN.selClearFeature()
						var x = Number(feat.x)
						var y = Number(feat.y)
						GEN.addPad({x:x,y:y,symbol:'r1001',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x + 1.301,y:y,symbol:'r1001',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x - 1.301,y:y,symbol:'r1001',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y + 1.301,symbol:'r1001',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y - 1.301,symbol:'r1001',attributes:[{attribute:".string", text:"_pre_drl"}]})
					}
					GEN.selClearFeature()
				})
			}
			GEN.selMoveOther({target_layer:drl,invert:'no',dx:0,dy:0,size:0})
		}

		// 2. drl_pre2s
		if(drl_pre2s.length) {
			GEN.workLayer({name:drl,display_number:2,clear_before:'yes'})
			GEN.selectByFilter({include_syms:drl_pre2s.join(";")})
			if(GEN.getSelectCount() > 0) { 
				GEN.selMoveOther({target_layer:drl_pre2,invert:'no',dx:0,dy:0,size:0}) 
				GEN.workLayer({name:drl_pre2,display_number:2,clear_before:'yes'})
				var feats = GEN.getFeatures({job:job,step:step,layer:drl_pre2,units:units})
				feats.forEach(function(feat) {
					GEN.selClearFeature()
					if(feat.type == "line"){
						GEN.COM("sel_net_feat,operation=select,x="+feat.xs+",y="+feat.ys+",use_ffilter=no")
					} else if (feat.type == "pad") {
						GEN.COM("sel_net_feat,operation=select,x="+feat.x+",y="+feat.y+",use_ffilter=no")
					}
					if(GEN.getSelectCount() == 1) {
						GEN.selClearFeature()
						var x = Number(feat.x)
						var y = Number(feat.y)
						GEN.addPad({x:x,y:y,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x + 1.601,y:y,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x - 1.601,y:y,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y + 1.601,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y - 1.601,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
					}
					GEN.selClearFeature()
				})
			}
			GEN.selMoveOther({target_layer:drl,invert:'no',dx:0,dy:0,size:0})
		}

		// 3. drl_pre3s
		if(drl_pre3s.length) {
			GEN.workLayer({name:drl,display_number:2,clear_before:'yes'})
			GEN.selectByFilter({include_syms:drl_pre3s.join(";")})
			if(GEN.getSelectCount() > 0) { 
				GEN.selMoveOther({target_layer:drl_pre3,invert:'no',dx:0,dy:0,size:0}) 
				GEN.workLayer({name:drl_pre3,display_number:2,clear_before:'yes'})
				var feats = GEN.getFeatures({job:job,step:step,layer:drl_pre3,units:units})
				feats.forEach(function(feat) {
					GEN.selClearFeature()
					if(feat.type == "line"){
						GEN.COM("sel_net_feat,operation=select,x="+feat.xs+",y="+feat.ys+",use_ffilter=no")
					} else if (feat.type == "pad") {
						GEN.COM("sel_net_feat,operation=select,x="+feat.x+",y="+feat.y+",use_ffilter=no")
					}
					if(GEN.getSelectCount() == 1) {
						GEN.selClearFeature()
						var x = Number(feat.x)
						var y = Number(feat.y)
						GEN.addPad({x:x,y:y,symbol:'r3001',attributes:[{attribute:".string", text:"_pre_drl"}]})
					}
					GEN.selClearFeature()
				})
			}
			GEN.selMoveOther({target_layer:drl,invert:'no',dx:0,dy:0,size:0})
		}

		// 4. drl_pre4s
		if(drl_pre4s.length) {
			GEN.workLayer({name:drl,display_number:2,clear_before:'yes'})
			GEN.selectByFilter({include_syms:drl_pre4s.join(";")})
			if(GEN.getSelectCount() > 0) { 
				GEN.selMoveOther({target_layer:drl_pre4,invert:'no',dx:0,dy:0,size:0}) 
				GEN.workLayer({name:drl_pre4,display_number:2,clear_before:'yes'})
				var feats = GEN.getFeatures({job:job,step:step,layer:drl_pre4,units:units})
				feats.forEach(function(feat) {
					GEN.selClearFeature()
					if(feat.type == "line"){
						GEN.COM("sel_net_feat,operation=select,x="+feat.xs+",y="+feat.ys+",use_ffilter=no")
					} else if (feat.type == "pad") {
						GEN.COM("sel_net_feat,operation=select,x="+feat.x+",y="+feat.y+",use_ffilter=no")
					}
					if(GEN.getSelectCount() == 1) {
						GEN.selClearFeature()
						var x = Number(feat.x)
						var y = Number(feat.y)
						GEN.addPad({x:x,y:y,symbol:'r6001',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x + 1.601,y:y,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x - 1.601,y:y,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y + 1.601,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
						GEN.addPad({x:x,y:y - 1.601,symbol:'r1301',attributes:[{attribute:".string", text:"_pre_drl"}]})
					}
					GEN.selClearFeature()
				})
			}
			GEN.selMoveOther({target_layer:drl,invert:'no',dx:0,dy:0,size:0})
		}


		delIfExist(layers_tmp)
		})
		
	})




	// 保存 
	if(/yes/ig.test(par.auto_save)){GEN.checkInout({job:job,mode:"out"}); GEN.saveJob({ job: job });GEN.checkInout({job:job,mode:"in"});GEN.closeJob({job:job});} else {GEN.checkInout({job:job,mode:"in"})}
	if (mode === "aimdfm") {
		$.QDfm.updateRow({table: "pdm_aimdfm_task",data: {progress: 33.33},where: { id: $.task_id }});
		if (GEN.hasError()) { Status = 'error';resultData.push({ type: "error", title: "GEN错误!", detail: [{ desc: _.join(GEN.STATUS, "\n") }] });
			return {status: Status,result_data: resultData};
		} else { resultData.push({ type: "info", title: "操作完成, 请注意检查!" }); return {status: Status,result_data: resultData}; }
	}else { return "Done" }
} catch (e) {
	IKM.msg(_.join(GEN.STATUS, "\n"));IKM.msg(e);Status = 'error';
    resultData.push({type: "error", title: "脚本执行出错!", detail: [{desc: _.toString(e)}]});
    return (mode === "aimdfm") ? {status: Status, result_data: resultData} : "Error";
}

function delIfExist(layer) {
	if(!Array.isArray(layer)){
		layer = [layer];
	}
	layer.forEach(function(l){
		if(GEN.isLayerExists({job:job, layer:l})){
			GEN.deleteLayer({job:job, layer:[l]})
		}
	})
}

function changeLine(line, length) {
    line.xs = Number(line.xs)
    line.ys = Number(line.ys)
    line.xe = Number(line.xe)
    line.ye = Number(line.ye)
    if (line.xe - line.xs == 0 || line.ye - line.ys == 0) {
        if (line.xe - line.xs == 0 ) {
            return {
                xs: line.xs,
                ys: line.ys + (line.ye - line.ys > 0 ? -length : length),
                xe: line.xe,
                ye: line.ye + (line.ye - line.ys > 0 ? length : -length)
            }
        } else {
            return {
                xs: line.xs - (line.xe - line.xs > 0 ? length : -length),
                ys: line.ys,
                xe: line.xe - (line.xe - line.xs > 0 ? -length : length),
                ye: line.ye
            }
        }
    }
    var width =  Math.sqrt( (line.xe - line.xs)*(line.xe - line.xs) + (line.ye - line.ys)*(line.ye - line.ys) )
    var k = length / width;
    var x = line.xe - line.xs;
    var y = line.ye - line.ys;
    return {
        xs: line.xs - k * x,
        ys: line.ys - k * y,
        xe: line.xe + k * x,
        ye: line.ye + k * y
    }
}