SystemSetting_LabelMaintain.cs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487
  1. using LabelManager2;
  2. using System;
  3. using System.Collections.Generic;
  4. using System.Data;
  5. using System.Drawing;
  6. using System.Text;
  7. using System.Threading;
  8. using System.Windows.Forms;
  9. using UAS_MES.CustomControl.TextBoxWithIcon;
  10. using UAS_MES.DataOperate;
  11. using UAS_MES.Properties;
  12. using UAS_MES.PublicMethod;
  13. namespace UAS_MES.SystemSetting
  14. {
  15. public partial class SystemSetting_LabelMaintain : Form
  16. {
  17. DataHelper dh;
  18. DataTable dt;
  19. //设置Grid中Combox的静态数据,这个格式是必须的,#前面是展示值,#后面是实际值
  20. string[] labeltype = { "机身标#机身标", "彩盒标#彩盒标", "卡通箱标#卡通箱标", "大箱标#大箱标", "栈板标#栈板标" };
  21. string[] defaultype = { "是#1", "否#0" };
  22. Dictionary<string, string> dic = new Dictionary<string, string>();
  23. //用于拼接条件查询
  24. StringBuilder condition = new StringBuilder();
  25. LogStringBuilder sql = new LogStringBuilder();
  26. /*CodeSoft新建打印机引擎*/
  27. ApplicationClass lbl;
  28. Document doc;
  29. /*BarTender新建打印机引擎*/
  30. //private Engine engine = null;
  31. //private LabelFormatDocument format ;
  32. //点击行的LabelCode
  33. string LabelCode = "";
  34. //模板的路径
  35. string LabelPath = "";
  36. //参数个数
  37. int ParamNum;
  38. //标签参数的数组
  39. string[] ParamName;
  40. //模板编号的ID
  41. string pl_id1;
  42. //用于保存更新的模板ID
  43. string pl_id2 = "";
  44. //Label表的主键,用于弹窗的传参
  45. string La_id1;
  46. //添加在grid末列的操作列
  47. DataGridViewImageColumn PerviewColumn = new DataGridViewImageColumn
  48. {
  49. Image = Resources.preview_16px_25980_easyicon_net,
  50. Width = 40,
  51. Name = "预览",
  52. ToolTipText = "预览模板参数",
  53. Tag = "Read",
  54. AutoSizeMode = DataGridViewAutoSizeColumnMode.None
  55. };
  56. DataGridViewImageColumn OperateColumn = new DataGridViewImageColumn
  57. {
  58. Image = Resources.write_15_893687707641px_1181413_easyicon_net,
  59. Width = 40,
  60. Name = "编辑",
  61. ToolTipText = "编辑模板",
  62. Tag = "Read",
  63. AutoSizeMode = DataGridViewAutoSizeColumnMode.None
  64. };
  65. Thread thread;
  66. AutoSizeFormClass asc = new AutoSizeFormClass();
  67. public SystemSetting_LabelMaintain()
  68. {
  69. InitializeComponent();
  70. }
  71. //创建打印进程
  72. private void NewPrint()
  73. {
  74. lbl = new ApplicationClass();
  75. }
  76. private void 条码维护_Load(object sender, EventArgs e)
  77. {
  78. thread = new Thread(NewPrint);
  79. thread.Start();
  80. asc.controllInitializeSize(this);
  81. dh = new DataHelper();
  82. condition.Append(" ");
  83. LoadData();
  84. pr_code.FormName = Name;
  85. pr_code.SetValueField = new string[] { "pr_code" };
  86. pr_code.TableName = "product";
  87. pr_code.SelectField = "pr_code # 物料编号,pr_detail # 物料名称,pr_kind # 物料种类,pr_spec # 物料规格";
  88. la_code.FormName = Name;
  89. la_code.SetValueField = new string[] { "la_code" };
  90. la_code.TableName = "label";
  91. la_code.SelectField = "la_code # 标签编号,la_name # 标签名称";
  92. //加载下拉框的静态值
  93. BaseUtil.SetDgvColumnComboxData((DataGridViewComboBoxColumn)LabelDataGridView.Columns["pl_labeltype"], "pl_labeltype", "display", "value", labeltype);
  94. BaseUtil.SetDgvColumnComboxData((DataGridViewComboBoxColumn)LabelDataGridView.Columns["pl_isdefault"], "pl_isdefault", "display", "value", defaultype);
  95. ChooseAll.ChooseAll(LabelDataGridView);
  96. pr_code2.KeyDown += ScreenEvent;
  97. pr_detail.KeyDown += ScreenEvent;
  98. pr_spec.KeyDown += ScreenEvent;
  99. }
  100. private void LabelDataGridView_CellContentClick(object sender, DataGridViewCellEventArgs e)
  101. {
  102. if (LabelDataGridView.Columns[e.ColumnIndex].HeaderText == "预览")
  103. {
  104. //获取路径和标签名称
  105. LabelPath = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelurl"].Value.ToString();
  106. LabelCode = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelcode"].Value.ToString();
  107. pl_id1 = LabelDataGridView.Rows[e.RowIndex].Cells["pl_id"].Value.ToString();
  108. La_id1 = LabelDataGridView.Rows[e.RowIndex].Cells["la_id"].Value.ToString();
  109. if (CodeSoft.Checked)
  110. {
  111. string LabelName = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelname"].Value.ToString();
  112. doc = lbl.Documents.Open(BaseUtil.GetLabelUrl(LabelPath, LabelName));
  113. if (doc == null)
  114. {
  115. MessageBox.Show("指定位置文件不存在");
  116. return;
  117. }
  118. ParamNum = doc.Variables.FreeVariables.Count;
  119. //去除之前添加的控件
  120. for (int i = 0; i < (ParamName == null ? 0 : ParamName.Length); i++)
  121. {
  122. if (this.Controls["LabelParam"].Controls[ParamName[i] + "_label"] != null)
  123. {
  124. this.Controls["LabelParam"].Controls.Remove(this.Controls["LabelParam"].Controls[ParamName[i] + "_label"]);
  125. this.Controls["LabelParam"].Controls.Remove(this.Controls["LabelParam"].Controls[ParamName[i]]);
  126. }
  127. }
  128. ParamName = new string[ParamNum];
  129. for (int i = 0; i < ParamNum; i++)
  130. {
  131. ParamName[i] = doc.Variables.FreeVariables.Item(i + 1).Name;
  132. }
  133. int y = 20;
  134. for (int i = 0; i < ParamName.Length; i++)
  135. {
  136. //变量的名称Label
  137. Label Param = new Label();
  138. Param.Text = ParamName[i];
  139. Param.Name = ParamName[i] + "_label";
  140. Param.AutoSize = true;
  141. Param.Anchor = AnchorStyles.Left;
  142. Param.Anchor = AnchorStyles.Top;
  143. Param.Location = new Point(30, y + 5);
  144. this.Controls["LabelParam"].Controls.Add(Param);
  145. //维护变量的打印测试参数
  146. EnterTextBox TempParam = new EnterTextBox();
  147. TempParam.Anchor = AnchorStyles.Left;
  148. TempParam.Anchor = AnchorStyles.Top;
  149. TempParam.Name = ParamName[i];
  150. TempParam.Location = new Point(110, y);
  151. y = y + 30;
  152. TempParam.Size = new Size(170, 22);
  153. this.Controls["LabelParam"].Controls.Add(TempParam);
  154. y = y + 30;
  155. }
  156. doc.Close();
  157. }
  158. }
  159. if (LabelDataGridView.Columns[e.ColumnIndex].HeaderText == "编辑")
  160. {
  161. if (e.RowIndex >= 0 && e.ColumnIndex >= 0)
  162. {
  163. LabelPath = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelurl"].Value.ToString();
  164. string LabelName = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelname"].Value.ToString();
  165. pr_code.Text = LabelDataGridView.Rows[e.RowIndex].Cells["pr_code1"].Value.ToString();
  166. la_code.Text = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelcode"].Value.ToString();
  167. la_name.Text = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labelname"].Value.ToString();
  168. la_type.Text = LabelDataGridView.Rows[e.RowIndex].Cells["pl_labeltype"].Value.ToString();
  169. FolderPath.Text = ftpOperater.DownLoadTo;
  170. pl_id2 = LabelDataGridView.Rows[e.RowIndex].Cells["pl_id"].Value.ToString();
  171. System.Diagnostics.Process.Start(BaseUtil.GetLabelUrl(LabelPath, LabelName));
  172. }
  173. }
  174. }
  175. private void Screen_Click(object sender, EventArgs e)
  176. {
  177. sql.Clear();
  178. condition.Clear();
  179. //如果条件全部为空的时候
  180. if (pr_code2.Text == "" && pr_detail.Text == "" && pr_spec.Text == "")
  181. {
  182. LoadData();
  183. }
  184. else
  185. {
  186. sql.Append("select pl_labelurl,pl_labeltype,pl_isdefault,pl_prodcode,pl_id,pl_labelcode,pl_detno,pl_labelsoft,pr_detail,pr_spec,pr_code from productlabel left join product on pl_prodcode=pr_code");
  187. //设置筛选的条件
  188. condition.Append(BaseUtil.GetScreenSqlCondition(pr_code2, pr_detail, pr_spec));
  189. //最终刷选条件拼接成的sql
  190. LoadData();
  191. }
  192. }
  193. private void Update_Click(object sender, EventArgs e)
  194. {
  195. string LabelSoft = "";
  196. //需要处理新增的行和原有数据然后更新的行
  197. if (CodeSoft.Checked)
  198. {
  199. LabelSoft = "CodeSoft";
  200. }
  201. DataTable dt = (DataTable)LabelDataGridView.DataSource;
  202. //如果有改变的行才传递到后台
  203. if (dt.GetChanges() != null)
  204. {
  205. for (int i = 0; i < LabelDataGridView.Rows.Count; i++)
  206. {
  207. //如果是新增的默认加上Radio当前选中的打印软件
  208. if (LabelDataGridView.Rows[i].Cells["pl_labelsoft"].Value.ToString() == "")
  209. {
  210. LabelDataGridView.Rows[i].Cells["pl_labelsoft"].Value = LabelSoft;
  211. }
  212. //从表格判断一个产品以及对应的打印模板是否存在默认选项
  213. if (!dic.ContainsKey(LabelDataGridView.Rows[i].Cells["pl_prodcode"].Value.ToString() + LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString()))
  214. {
  215. dic.Add(LabelDataGridView.Rows[i].Cells["pl_prodcode"].Value.ToString() + LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString(), LabelDataGridView.Rows[i].Cells["pl_isdefault"].Value.ToString());
  216. }
  217. else
  218. {
  219. string outvalue = dic[LabelDataGridView.Rows[i].Cells["pl_prodcode"].Value.ToString() + LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString()];
  220. if (outvalue == "0")
  221. {
  222. dic[LabelDataGridView.Rows[i].Cells["pl_prodcode"].Value.ToString() + LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString()] = LabelDataGridView.Rows[i].Cells["pl_isdefault"].Value.ToString();
  223. }
  224. else if (LabelDataGridView.Rows[i].Cells["pl_isdefault"].Value.ToString() == "1" && (LabelDataGridView.Rows[i].Cells["pl_prodcode"].Value.ToString() == LabelDataGridView.Rows[i - 1].Cells["pl_prodcode"].Value.ToString()) && (LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString() == LabelDataGridView.Rows[i - 1].Cells["pl_labeltype"].Value.ToString()))
  225. {
  226. MessageBox.Show("产品"+LabelDataGridView.Rows[i].Cells["pr_detail1"].Value.ToString() +" "+ LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString()+ " 保存的模板之前具有默认模板");
  227. LabelDataGridView.Rows[i].Cells["pl_isdefault"].Value = "0";
  228. }
  229. }
  230. //从数据库核对是否同时存在一个产品以及对应打印模板是否存在默认选项
  231. DataTable table = (DataTable)dh.ExecuteSql("select pl_isdefault from productlabel where pl_id = '" + LabelDataGridView.Rows[i].Cells["pl_id"].Value.ToString() + " '", "select");
  232. if (LabelDataGridView.Rows[i].Cells["pl_isdefault"].Value.ToString() == "1" && table.Rows[0][0].ToString() == "0")
  233. {
  234. int is_defualt = isdefault(LabelDataGridView.Rows[i].Cells["pl_prodcode"].Value.ToString(), LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString());
  235. if (is_defualt == 0)
  236. {
  237. MessageBox.Show("产品" + LabelDataGridView.Rows[i].Cells["pr_detail1"].Value.ToString()+" "+ LabelDataGridView.Rows[i].Cells["pl_labeltype"].Value.ToString()+ " 保存的模板之前具有默认模板");
  238. LabelDataGridView.Rows[i].Cells["pl_isdefault"].Value = is_defualt;
  239. }
  240. }
  241. }
  242. string sql = "Insert into productlabel (PL_ID,PL_PRODCODE,PL_LABELTYPE,PL_LABELCODE,PL_LABELURL,PL_DETNO,PL_LABELSOFT,PL_ISDEFAULT) values( ProductLabel_seq.nextval,'" + pr_code.Text + "',:PL_LABELTYPE,:PL_LABELCODE,:PL_LABELURL,:PL_DETNO,:PL_LABELSOFT,:PL_ISDEFAULT )";
  243. dh.SaveDataTable(dt.GetChanges(), "productlabel", "pl_id", sql.ToLower());
  244. LoadData();
  245. dic.Clear();
  246. }
  247. }
  248. private void DeleteDetail_Click(object sender, EventArgs e)
  249. {
  250. string[] deleteid = new string[LabelDataGridView.RowCount];
  251. for (int i = 0; i < LabelDataGridView.RowCount; i++)
  252. {
  253. deleteid[i] = LabelDataGridView.Rows[i].Cells["pl_id"].Value.ToString();
  254. }
  255. dh.DeleteDataByID("productlabel", "pl_id", deleteid);
  256. LoadData();
  257. }
  258. private void OpenFolder_Click(object sender, EventArgs e)
  259. {
  260. //根据勾选的不同设置不同的文件后缀过滤
  261. if (CodeSoft.Checked)
  262. {
  263. openFileDialog1.Filter = "(*.lab)|*.lab";
  264. }
  265. DialogResult result = openFileDialog1.ShowDialog();
  266. if (result == DialogResult.OK)
  267. {
  268. string FullPath = openFileDialog1.FileName;
  269. FolderPath.Text = FullPath.Substring(0, FullPath.LastIndexOf("\\"));
  270. la_name.Text = FullPath.Substring(FullPath.LastIndexOf("\\") + 1);
  271. for (int i = 0; i < LabelDataGridView.Rows.Count; i++)
  272. {
  273. if (LabelDataGridView.Rows[i].Cells["Choose"].Value != null)
  274. {
  275. if ((bool)LabelDataGridView.Rows[i].Cells["Choose"].Value == true)
  276. {
  277. LabelDataGridView.Rows[i].Cells["pl_labelurl"].Value = FolderPath.Text;
  278. }
  279. }
  280. }
  281. }
  282. }
  283. private void LabelDataGridView_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e)
  284. {
  285. if (LabelDataGridView.Columns[e.ColumnIndex].Name == "pl_isdefault")
  286. {
  287. if (e.Value != null)
  288. {
  289. switch (e.Value.ToString())
  290. {
  291. case "0":
  292. e.Value = "否";
  293. break;
  294. case "1":
  295. e.Value = "是";
  296. break;
  297. default:
  298. break;
  299. }
  300. }
  301. }
  302. }
  303. private void LabelDataGridView_DataError(object sender, DataGridViewDataErrorEventArgs e)
  304. {
  305. //覆盖参数错误的事件,使得不会报错
  306. }
  307. //判断与维护标签相同ID是否具有默认模板
  308. private int isdefault(string pl_prodcode, string pl_labeltype)
  309. {
  310. LogStringBuilder sql2 = new LogStringBuilder();
  311. sql2.Append("select la_id,pl_labelname,pl_labelurl,pl_labeltype,pl_isdefault,pl_prodcode,pl_id,pl_labelcode,pl_detno,pl_labelsoft,pr_detail,pr_spec,");
  312. sql2.Append("pr_code from productlabel left join product on pl_prodcode=pr_code left join label on pl_labelcode=la_code");
  313. sql2.Append(" where pl_isdefault = '1' and pl_prodcode = '" + pl_prodcode + "' and pl_labeltype = '" + pl_labeltype + "'");
  314. dt = (DataTable)dh.ExecuteSql(sql2.GetString(), "select");
  315. if (dt.Rows.Count > 0)
  316. {
  317. sql2.Clear();
  318. return 0;
  319. }
  320. else
  321. {
  322. sql2.Clear();
  323. return 1;
  324. }
  325. }
  326. //判断与标签保存时是否已经有同类型标签存在
  327. private Boolean isSameLabel(string pl_prodcode, string pl_labeltype, string pl_labelname)
  328. {
  329. LogStringBuilder sql2 = new LogStringBuilder();
  330. sql2.Append("select la_id,pl_labelname,pl_labelurl,pl_labeltype,pl_isdefault,pl_prodcode,pl_id,pl_labelcode,pl_detno,pl_labelsoft,pr_detail,pr_spec,");
  331. sql2.Append("pr_code from productlabel left join product on pl_prodcode=pr_code left join label on pl_labelcode=la_code");
  332. sql2.Append(" where pl_prodcode = '" + pl_prodcode + "' and pl_labeltype = '" + pl_labeltype + "' and pl_labelname = '" + pl_labelname + "'");
  333. dt = (DataTable)dh.ExecuteSql(sql2.GetString(), "select");
  334. if (dt.Rows.Count > 0)
  335. {
  336. sql2.Clear();
  337. return true;
  338. }
  339. else
  340. {
  341. sql2.Clear();
  342. return false;
  343. }
  344. }
  345. private void LoadData()
  346. {
  347. //如果没有任何筛选条件直接选取productlabel的数据
  348. if (sql.GetString().Length == 0)
  349. {
  350. sql.Clear();
  351. sql.Append("select la_id,pl_labelname,pl_labelurl,pl_labeltype,pl_isdefault,pl_prodcode,pl_id,pl_labelcode,pl_detno,pl_labelsoft,pr_detail,pr_spec,");
  352. sql.Append("pr_code from productlabel left join product on pl_prodcode=pr_code left join label on pl_labelcode=la_code");
  353. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  354. }
  355. else
  356. {
  357. dt = (DataTable)dh.ExecuteSql(sql.GetString(), "select");
  358. }
  359. BaseUtil.FillDgvWithDataTable(LabelDataGridView, dt, PerviewColumn, OperateColumn);
  360. string Field = BaseUtil.GetGridViewSelectContent(LabelDataGridView);
  361. pagination1.BindDataToNavigator(LabelDataGridView, "productlabel left join product on pl_prodcode=pr_code left join label on pl_labelcode=la_code", Field, "pl_id", "", condition.Replace("where", "").ToString(), PerviewColumn, OperateColumn);
  362. }
  363. private void PrintTest_Click(object sender, EventArgs e)
  364. {
  365. if (LabelCode != "")
  366. {
  367. doc.Save();
  368. doc.PrintDocument();
  369. doc.Close();
  370. }
  371. }
  372. private void 产品标签维护_FormClosing(object sender, FormClosingEventArgs e)
  373. {
  374. //关闭所有的打印文件
  375. if (lbl.Documents != null)
  376. lbl.Documents.CloseAll();
  377. }
  378. private void Save_Click(object sender, EventArgs e)
  379. {
  380. if (la_code.Text != "" && la_type.Text != "" && FolderPath.Text != "" && pr_code.Text != "")
  381. {
  382. if (FTPShare.Checked)
  383. {
  384. string SoftWare = "CodeSoft";
  385. ftpOperater ftp = new ftpOperater();
  386. ftp.UpLoadFile(FolderPath.Text, la_name.Text);
  387. if (pl_id2 != "")
  388. {
  389. if (!isSameLabel(pr_code.Text, la_type.Text, la_name.Text))
  390. {
  391. sql.Clear();
  392. sql.Append("update productlabel set pl_labelcode=:pl_labelcode,pl_labeltype=:pl_labeltype,pl_labelname=:pl_labelname,");
  393. sql.Append("pl_prodcode=:pl_prodcode,pl_indate=sysdate where pl_id='" + pl_id2 + "'");
  394. dh.ExecuteSql(sql.GetString(), "update", la_code.Text, la_type.Text, la_name.Text, pr_code.Text);
  395. }
  396. else
  397. {
  398. MessageBox.Show("编号" + pr_code.Text + "商品已有相同标签");
  399. sql.Clear();
  400. LoadData();
  401. return;
  402. }
  403. }
  404. else
  405. {
  406. if (!isSameLabel(pr_code.Text, la_type.Text, la_name.Text))
  407. {
  408. sql.Clear();
  409. sql.Append("insert into productlabel (pl_id,pl_labelcode,pl_labeltype,pl_isdefault,pl_labelurl,pl_labelsoft,pl_labelname,pl_prodcode,pl_indate) values( productlabel_seq.nextval, ");
  410. sql.Append("'" + la_code.Text + "','" + la_type.Text + "','" + isdefault(pr_code.Text, la_type.Text) + "','" + ftpOperater.FTPAddress + la_name.Text + "','" + SoftWare + "','" + la_name.Text + "','" + pr_code.Text + "',sysdate)");
  411. dh.ExecuteSql(sql.GetString(), "insert");
  412. }
  413. else
  414. {
  415. MessageBox.Show("编号" + pr_code.Text + "商品已有相同标签");
  416. sql.Clear();
  417. LoadData();
  418. return;
  419. }
  420. }
  421. pl_id2 = "";
  422. MessageBox.Show("保存成功!");
  423. sql.Clear();
  424. LoadData();
  425. }
  426. }
  427. else
  428. MessageBox.Show("所有参数必须填写");
  429. }
  430. private void 产品标签维护_SizeChanged(object sender, EventArgs e)
  431. {
  432. asc.controlAutoSize(this);
  433. }
  434. private void ScreenEvent(object sender, KeyEventArgs e)
  435. {
  436. if (e.KeyCode == Keys.Enter)
  437. Screen.PerformClick();
  438. }
  439. private void Delete_Click(object sender, EventArgs e)
  440. {
  441. string[] deleteid = new string[LabelDataGridView.RowCount];
  442. for (int i = 0; i < LabelDataGridView.RowCount; i++)
  443. {
  444. if (LabelDataGridView.Rows[i].Cells["Choose"].Value != null)
  445. {
  446. if ((bool)LabelDataGridView.Rows[i].Cells["Choose"].Value == true)
  447. {
  448. deleteid[i] = LabelDataGridView.Rows[i].Cells["pl_id"].Value.ToString();
  449. }
  450. }
  451. }
  452. dh.DeleteDataByID("productlabel", "pl_id", deleteid);
  453. LoadData();
  454. }
  455. }
  456. }