source: sandbox/2.3-MailArchiver/calendar/js/dhtmlx/client/dhtmlxscheduler_pdf.js @ 6779

Revision 6779, 7.0 KB checked in by rafaelraymundo, 12 years ago (diff)

Ticket #2946 - Liberado Expresso(branch 2.3) integrado ao MailArchiver?.

Line 
1/*
2Copyright DHTMLX LTD. http://www.dhtmlx.com
3*/
4scheduler.toPDF=function(url,mode,header,footer){
5        var dx = 0;
6        var dy = 0;
7        mode = mode||"color";
8       
9        function x_norm(x) {
10            x = parseFloat(x);
11            if (isNaN(x)) return "auto";
12            return 100 * x / dx;
13        }
14        function y_norm(y) {
15            y = parseFloat(y);
16            if (isNaN(y)) return "auto";
17            return 100 * y / dy;
18        }
19        function xml_month_scale(xh){
20                var xml="";
21                for (var i = 0; i < xh.length; i++)
22                        xml += "\n<column><![CDATA[" + xh[i].innerHTML + "]]></column>";
23                dx = xh[0].offsetWidth;
24                return xml;
25        }
26        function de_day(node,n){
27                var x = parseInt(node.style.left);
28               
29                for (var dx=0; dx < scheduler._cols.length; dx++){
30                        x-=scheduler._cols[dx];
31                        if (x<0) return dx;
32                }
33                return n;
34        }
35        function de_week(node,n){
36                var y = parseInt(node.style.top);
37                for (var dy=0; dy < scheduler._colsS.heights.length; dy++)
38                        if (scheduler._colsS.heights[dy]>y) return dy;
39                return n;
40        }
41        function xml_month(yh){
42                var xml="";
43        var r = yh.firstChild.rows;
44        for (var i = 0; i < r.length; i++) {
45            var days = [];
46            for (var j = 0; j < r[i].cells.length; j++){
47            /*  var dd = r[i].cells[j];
48                var css = dd.className;
49               
50                if (css!=" " && css!="dhx_now ")
51                        days.push("");
52                else*/
53                        days.push(r[i].cells[j].firstChild.innerHTML);
54            }
55
56            xml += "\n<row height='"+yh.firstChild.rows[i].cells[0].offsetHeight+"'>" + days.join("|") + "</row>";
57            dy = yh.firstChild.rows[0].cells[0].offsetHeight;
58        }
59        return xml;
60        }
61        function xml_top(profile) {
62            var xml = "<data profile='"+profile+"'";
63               if (header)
64                  xml+=" header='"+header+"'";
65               if (footer)
66                  xml+=" footer='"+footer+"'";
67            xml+=">";
68            xml += "<scale mode='" + scheduler._mode + "' today='" + scheduler._els.dhx_cal_date[0].innerHTML + "'>";
69           
70            if (scheduler._mode == "agenda"){
71                var xh = scheduler._els.dhx_cal_header[0].childNodes[0].childNodes;
72               
73                xml+="<column>"+xh[0].innerHTML+"</column><column>"+xh[1].innerHTML+"</column>"
74            } else if (scheduler._mode == "year"){
75                var xh = scheduler._els.dhx_cal_data[0].childNodes;
76                for (var i=0; i < xh.length; i++) {
77                        xml+="<month label='"+xh[i].childNodes[0].innerHTML+"'>";
78                                xml+=xml_month_scale(xh[i].childNodes[1].childNodes);
79                                xml+=xml_month(xh[i].childNodes[2]);
80                        xml+="</month>";
81                };
82            } else {
83                    xml += "<x>";
84                    var xh = scheduler._els.dhx_cal_header[0].childNodes;
85                        xml+=xml_month_scale(xh);
86                    xml += "</x>";
87               
88                    var yh = scheduler._els.dhx_cal_data[0];
89                    if (yh.firstChild.tagName == "TABLE") {
90                                xml += xml_month(yh);
91                    } else {
92                                yh = yh.childNodes[yh.childNodes.length - 1];
93                        if (yh.className.indexOf("dhx_cal_event") != -1)
94                            yh = yh.previousSibling;
95                        yh = yh.childNodes;
96               
97                        xml += "<y>";
98                        for (var i = 0; i < yh.length; i++)
99                            xml += "\n<row><![CDATA[" + yh[i].innerHTML + "]]></row>";
100                        xml += "</y>";
101                        dy = yh[0].offsetHeight;
102                    }
103                }
104               
105            xml += "</scale>";
106            return xml;
107        }
108        function xml_body() {
109            var xml = "";
110            var evs = scheduler._rendered;
111           
112            if (scheduler._mode == "agenda"){
113                for (var i=0; i < evs.length; i++)
114                        xml+="<event><head>"+evs[i].childNodes[0].innerHTML+"</head><body>"+evs[i].childNodes[2].innerHTML+"</body></event>";
115            } else if (scheduler._mode == "year"){
116                var evs = scheduler.get_visible_events();
117                for (var i=0; i < evs.length; i++) {
118                        var d = evs[i].start_date;
119                                if (d.valueOf()<scheduler._min_date.valueOf())
120                                d = scheduler._min_date;
121                                while (d<evs[i].end_date){
122                                        var m = d.getMonth()+12*(d.getFullYear()-scheduler._min_date.getFullYear())-scheduler.week_starts._month;
123                                        var day  = scheduler.week_starts[m]+d.getDate()-1;
124
125                                        xml+="<event day='"+(day%7)+"' week='"+Math.floor(day/7)+"' month='"+m+"'></event>";
126                                scheduler._mark_year_date(d);
127                                d = scheduler.date.add(d,1,"day");
128                                if (d.valueOf()>=scheduler._max_date.valueOf())
129                                        break;
130                        }
131                        }   
132            } else {
133                    for (var i = 0; i < evs.length; i++) {
134                        var zx = x_norm(evs[i].style.left);
135                        var zy = y_norm(evs[i].style.top);
136                        var zdx = x_norm(evs[i].style.width);
137                        var zdy = y_norm(evs[i].style.height);
138                        var e_type = evs[i].className.split(" ")[0].replace("dhx_cal_", "");
139                        var dets = scheduler.getEvent(evs[i].getAttribute("event_id"))
140                        var day = dets._sday;
141                        var week = dets._sweek;
142                        if (scheduler._mode != "month") {
143                           if (parseInt(evs[i].style.left) <= 26) {
144                              zx = 2;
145                              zdx += x_norm(evs[i].style.left)-1;
146                           }                   
147                            if (evs[i].parentNode == scheduler._els.dhx_cal_data[0]) continue;
148                            zx += x_norm(evs[i].parentNode.style.left);
149                            zx -= x_norm(51);
150                        } else {
151                            zdy = parseInt(evs[i].offsetHeight);
152                            zy = parseInt(evs[i].style.top) - 22;
153                           
154                            day = de_day(evs[i],day);
155                            week = de_week(evs[i],week);
156                        }
157                       
158                        xml += "\n<event week='"+week+"' day='"+day+"' type='" + e_type + "' x='" + zx + "' y='" + zy + "' width='" + zdx + "' height='" + zdy + "'>";
159                        if (e_type == "event") {
160                            xml += "<header><![CDATA[" + evs[i].childNodes[1].innerHTML + "]]></header>";
161                            var color = window.getComputedStyle ? (window.getComputedStyle(evs[i].childNodes[2], null)["backgroundColor"]) : (evs[i].childNodes[2].currentStyle["backgroundColor"]);
162                            xml += "<body color='" + color + "'><![CDATA[" + evs[i].childNodes[2].innerHTML + "]]></body>";
163                        } else {
164                            var color = window.getComputedStyle ? (window.getComputedStyle(evs[i], null)["backgroundColor"]) : (evs[i].currentStyle["backgroundColor"]);
165                            xml += "<body color='" + color + "'><![CDATA[" + evs[i].innerHTML + "]]></body>";
166                        }
167                        xml += "</event>";
168                    }
169            }
170            return xml;
171        }
172        function xml_end(){
173            var xml = "</data>";
174            return xml;
175        }
176       
177        var win = window.open("", "_blank");
178        win.document.open();
179        win.document.write("<html><body>");
180        win.document.write('<form id="mycollformname" method="post"  accept-charset="utf-8" enctype="multipart/form-data"  action="'+url+'"><input type="hidden" name="mycoolxmlbody" id="mycoolxmlbody"/> </form>');
181        // as long dash in post converts to some special symbols we need to convert it to simple dash by replacing using unicode \u2013
182        win.document.getElementById("mycoolxmlbody").value = xml_top(mode).replace("\u2013", "-") + xml_body() + xml_end();
183        win.document.write("</body></html>");
184        win.document.getElementById("mycollformname").submit();
185        win.document.close();
186}   
Note: See TracBrowser for help on using the repository browser.