diff --git a/mail/inc/class.mail_compose.inc.php b/mail/inc/class.mail_compose.inc.php index d212e9c615..b88e21ddc4 100644 --- a/mail/inc/class.mail_compose.inc.php +++ b/mail/inc/class.mail_compose.inc.php @@ -448,6 +448,10 @@ class mail_compose $response = egw_json_response::get(); if (isset($previouslyDrafted) && $previouslyDrafted!=$draft_id) $response->call('opener.egw_refresh',lang('Message saved successfully.'),'mail',$previouslyDrafted,'delete'); $response->call('opener.egw_refresh',lang('Message saved successfully.'),'mail',$draft_id,'add'); + if ($_content['button']['saveAsDraftAndPrint']) + { + $response->call('app.mail.mail_compose_print',"mail::" .$draft_id); + } } } if ($activeProfile != $composeProfile) $this->changeProfile($activeProfile); @@ -2376,7 +2380,7 @@ class mail_compose } $mail_bo->closeConnection(); } - + function saveAsDraft($_formData, &$savingDestination='') { $mail_bo = $this->mail_bo; diff --git a/mail/inc/class.mail_ui.inc.php b/mail/inc/class.mail_ui.inc.php index 0e098a0435..dac4404c61 100644 --- a/mail/inc/class.mail_ui.inc.php +++ b/mail/inc/class.mail_ui.inc.php @@ -1951,27 +1951,30 @@ class mail_ui /** * display messages - * @param array $_requesteddata + * @param array $_requesteddata etemplate content * all params are passed as GET Parameters, but can be passed via ExecMethod2 as array too */ function displayMessage($_requesteddata = null) { - if (!is_null($_requesteddata) && isset($_requesteddata['id'])) - { - $rowID = $_requesteddata['id']; - } + if (is_null($_requesteddata)) $_requesteddata = $_GET; + $preventRedirect=false; - if(isset($_GET['id'])) $rowID = $_GET['id']; - if(isset($_GET['part'])) $partID = $_GET['part']; - if(isset($_GET['mode'])) $preventRedirect = ($_GET['mode']=='display'?true:false); + if(isset($_requesteddata['id'])) $rowID = $_requesteddata['id']; + if(isset($_requesteddata['part'])) $partID = $_requesteddata['part']; + if(isset($_requesteddata['mode'])) $preventRedirect = (($_requesteddata['mode']=='display' || $_requesteddata['mode'] == 'print')?true:false); $htmlOptions = $this->mail_bo->htmlOptions; - if (!empty($_GET['tryastext'])) $htmlOptions = "only_if_no_text"; - if (!empty($_GET['tryashtml'])) $htmlOptions = "always_display"; + if (!empty($_requesteddata['tryastext'])) $htmlOptions = "only_if_no_text"; + if (!empty($_requesteddata['tryashtml'])) $htmlOptions = "always_display"; $hA = self::splitRowID($rowID); $uid = $hA['msgUID']; $mailbox = $hA['folder']; //error_log(__METHOD__.__LINE__.array2string($hA)); + if (($this->mail_bo->isDraftFolder($mailbox)) && $_requesteddata['mode'] == 'print') + { + $response = egw_json_response::get(); + $response->call('app.mail.print_for_compose', $rowID); + } if (!$preventRedirect && ($this->mail_bo->isDraftFolder($mailbox) || $this->mail_bo->isTemplateFolder($mailbox))) { egw::redirect_link('/index.php',array('menuaction'=>'mail.mail_compose.compose','id'=>$rowID,'from'=>'composefromdraft')); diff --git a/mail/js/app.js b/mail/js/app.js index 96e16f0c3c..4e0ac35d66 100644 --- a/mail/js/app.js +++ b/mail/js/app.js @@ -390,7 +390,7 @@ app.classes.mail = AppJS.extend( var dataElem = egw.dataGetUIDdata(_id); var subject = dataElem.data.subject; //alert('Open Message:'+_id+' '+subject); - var h = egw().open( _id,'mail','view',_mode+'='+_id.replace(/=/g,"_") ); + var h = egw().open( _id,'mail','view',_mode+'='+_id.replace(/=/g,"_")+'&mode='+_mode); egw(h).ready(function() { h.document.title = subject; }); @@ -3163,7 +3163,7 @@ app.classes.mail = AppJS.extend( { this.et2_obj.submit(); }, - + /** * Focus handler for folder, address, reject textbox/taglist to automatic check associated radio button * @@ -3537,7 +3537,7 @@ app.classes.mail = AppJS.extend( var textArea = this.et2.getWidgetById('mail_plaintext'); var toolbar = jQuery('.mailSignature'); - if (typeof textArea != 'undefined') + if (typeof textArea != 'undefined' && textArea != null) { var textAreaH = textArea.node.clientHeight; if (textArea.getParent().disabled) @@ -3712,14 +3712,43 @@ app.classes.mail = AppJS.extend( switch (currentTemp) { case 'mail.index': - this.mail_prev_print(); + this.mail_prev_print(_action, _senders); break; case 'mail.display': this.mail_display_print(); } }, - + + /** + * Print a mail from compose + * @param {stirng} _id id of new draft + */ + mail_compose_print:function (_id) + { + this.egw.open(_id,'mail','view','&print='+_id+'&mode=print'); + }, + + /** + * Bind special handler on print media. + * -FF and IE have onafterprint event, and as Chrome does not have that event we bind afterprint function to onFocus + */ + print_for_compose: function() + { + var afterprint = function (){ + window.close(); + }; + + if (!window.onafterprint) + { + window.onfocus = afterprint; + } + else + { + window.onafterprint = afterprint; + } + }, + /** * Print a mail from Display *