lu
昨天 5e376d06404a16cb3c82a93cff351c5315bbcfe3
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
using Gs.DevApp.DevFrm.Rpt;
using Gs.DevApp.Entity;
using Gs.DevApp.ToolBox;
using Newtonsoft.Json;
using System;
using System.Data;
using System.Drawing;
using System.Windows.Forms;
 
 
namespace Gs.DevApp.UserControl
{
    public partial class UcBtnPrint : DevExpress.XtraEditors.XtraUserControl
    {
        public UcBtnPrint()
        {
            InitializeComponent();
            this.btnPrint.Click += (s, e) =>
            {
                if (btnPrintClick != null)
                    btnPrintClick(this, e);
                else
                    return;
                if (rptParameter == "return false")
                    return;
                if (string.IsNullOrEmpty(rptParameter))
                {
                    MsgHelper.ShowError("没有指定报表参数,请联系技术开发人员!");
                    return;
                }
                #region 如果是客户的
                if (rptParameter.Contains("rpt_hgm"))
                {
                    var _obj = new
                    {
                        keyType = "客户模板"
                    };
                    var json = JsonConvert.SerializeObject(_obj);
                    try
                    {
                        var strReturn =
                            UtilityHelper.HttpPost("", "Report/GetTemplateList", json);
                        ReturnModel<DataTable> dd = UtilityHelper.ReturnToList(strReturn);
                        DataTable dt = dd.rtnData;
                        if (dd.rtnCode > 0)
                        {
                            // 创建或获取一个ContextMenu对象(例如使用ContextMenuStrip)
                            ContextMenu contextMenu = new ContextMenu();
                            foreach (DataRow dr in dt.Rows)
                            {
                                MenuItem menuItem1 = new MenuItem(dr["reportType"].ToString() + "【" + dr["reportName"].ToString() + "】");
                                menuItem1.Click += (ss, ee) =>
                                {
                                    rptParameter = rptParameter.Replace("rpt_hgm", dr["reportType"].ToString());
                                    _print();
                                };
                                contextMenu.MenuItems.Add(menuItem1);
                            }
                            // 显示菜单在按钮的位置
                            contextMenu.Show(btnPrint, new Point(0, btnPrint.Height)); // 调整第二个参数以调整菜单的显示位置
                            return;
                        }
                    }
                    catch (Exception ex)
                    { }
                }
                #endregion
 
                _print();
 
            };
            this.btnAll.Click += (s, e) =>
            {
                if (btnAllClick != null)
                    btnAllClick(this, e);
                else
                    return;
            };
        }
        /// <summary>
        ///     关键字,一般是主键
        /// </summary>
        public string guidKey { get; set; }
 
 
        /// <summary>
        /// 批量操作时的关键字:托板码
        /// </summary>
        public string allClickKey { get; set; }
 
 
        /// <summary>
        ///     报表,在数据库中要唯一,如:存储过程名{入参1名|入参值,入参2名|入参值}
        /// </summary>
        public string rptParameter { get; set; }
 
        /// <summary>
        /// 打印
        /// </summary>
        public event EventHandler btnPrintClick;
 
        /// <summary>
        /// 批量操作
        /// </summary>
        public event EventHandler btnAllClick;
 
        private bool _ckRptService()
        {
            try
            {
                var _obj = new
                {
                    guid = guidKey,
                    rptParameter,
                    isDesign = 1
                };
                var strJson = UtilityHelper.HttpPost("", "Report/GetRptData",
                    JsonConvert.SerializeObject(_obj));
                var _rtn = UtilityHelper.ReturnToDynamic(strJson);
                if (_rtn.rtnCode > 0) return true;
                return false;
            }
            catch (Exception ex)
            {
                MsgHelper.Warning("提示:" + ex.Message);
                return true;
            }
            return false;
        }
 
        public void SetPlButton(bool blPiLiang)
        {
            if (blPiLiang == true)
                this.lay3.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Always;
            else
                this.lay3.Visibility = DevExpress.XtraLayout.Utils.LayoutVisibility.Never;
        }
 
        /// <summary>
        /// 
        /// </summary>
        private void _print() {
            var _bl = false;
            _bl = _ckRptService();
            if (_bl)
            {
                try
                {
                    using (Form frm = new RptPreview(guidKey, rptParameter))
                    {
                        frm.ShowDialog();
                    }
                }
                catch (Exception)
                {
                }
                return;
            }
            MsgHelper.ShowError("没有设计模板,请先设计模板!");
        }
    }
}