X-Git-Url: https://delta.frontaccounting.com/gitweb/?a=blobdiff_plain;f=reporting%2Fincludes%2Fpdf_report.inc;h=e3d84a1914e94c8dfda83a6cb954534bab8cfc0f;hb=7d9150f4f6ba547f19c789abb7a506bbd4c2bdf4;hp=9b0c9d4584029006a684ecf0535e5d7a4373767a;hpb=9967d9b22e1200e516aadf98ffcbcc65ac1c35bb;p=fa-stable.git
diff --git a/reporting/includes/pdf_report.inc b/reporting/includes/pdf_report.inc
index 9b0c9d45..e3d84a19 100644
--- a/reporting/includes/pdf_report.inc
+++ b/reporting/includes/pdf_report.inc
@@ -3,7 +3,9 @@
$page_security = 8;
//include_once($path_to_root . "reporting/includes/class.pdf.inc");
include_once(dirname(__FILE__)."/class.pdf.inc");
+include_once(dirname(__FILE__)."/printer_class.inc");
include_once($path_to_root . "admin/db/company_db.inc");
+include_once($path_to_root . "admin/db/printers_db.inc");
include_once($path_to_root . "config.php");
class FrontReport extends Cpdf
{
@@ -278,12 +280,12 @@ class FrontReport extends Cpdf
function SetDrawColor($r, $g, $b)
{
- $this->setStrokeColor($r / 255, $g / 255, $b / 255);
+ $this->setStrokeColor($r, $g, $b);
}
function SetTextColor($r, $g, $b)
{
- TCPDF::SetTextColor($r / 255, $g / 255, $b / 255);
+ TCPDF::SetTextColor($r, $g, $b);
}
function Text($c, $txt, $n=0, $corr=0, $r=0)
@@ -314,7 +316,13 @@ class FrontReport extends Cpdf
return $this->TextWrap($this->cols2[$c], $this->row - $r, $this->cols2[$n] - $this->cols2[$c] + $corr, $txt, $this->aligns2[$c]);
}
- function TextColLines($c, $n, $txt, $corr=0)
+ function TextColLines($c, $n, $txt, $corr=0, $r=0)
+ {
+ $this->row -= $r;
+ $this->TextWrapLines($this->cols[$c], $this->cols[$n] - $this->cols[$c] + $corr, $txt, $this->aligns[$c]);
+ }
+
+ function TextWrapLines($c, $width, $txt, $align='left')
{
$str = Explode("\n", $txt);
for ($i = 0; $i < count($str); $i++)
@@ -322,7 +330,7 @@ class FrontReport extends Cpdf
$l = $str[$i];
do
{
- $l = $this->TextCol($c, $n, $l, $corr);
+ $l = $this->TextWrap($c, $this->row , $width, $l, $align);
$this->NewLine();
}
while ($l != '');
@@ -349,13 +357,11 @@ class FrontReport extends Cpdf
function End($email=0, $subject=null, $myrow=null, $doctype = 0)
{
- global $go_debug, $path_to_root, $comp_path;
+ global $pdf_debug, $path_to_root, $comp_path;
- if ($go_debug == 1)
+ if ($pdf_debug == 1)
{
- $buf = $this->Output();
- $len = strlen($buf);
- $pdfcode = $buf;
+ $pdfcode = $this->Output();
$pdfcode = str_replace("\n", "\n
", htmlspecialchars($pdfcode));
echo '
';
echo trim($pdfcode);
@@ -370,6 +376,7 @@ class FrontReport extends Cpdf
}
else
{
+
$buf = $this->Output();
$len = strlen($buf);
$dir = $comp_path.'/'.user_company(). '/pdf_files';
@@ -378,7 +385,12 @@ class FrontReport extends Cpdf
{
mkdir ($dir,0777);
}
- $fname = $dir . '/' . $this->filename;
+ // do not use standard filenames or your sensitive company data
+ // are world readable
+// $fname = $dir . '/' . $this->filename;
+ $fname = tempnam($dir, 'xx');
+ rename($fname, $fname.'.pdf');
+ $fname .= '.pdf';
$fp = fopen($fname,'w');
fwrite($fp,$buf);
fclose($fp);
@@ -442,36 +454,70 @@ class FrontReport extends Cpdf
}
else
{
- //echo '
- //
- //
- //
- //
- // click here if you are not re-directed.
- //
- // ';
- header('Content-type: application/pdf');
- header("Content-Disposition: inline; filename=$this->filename");
- header('Expires: 0');
- header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
- header('Pragma: public');
- $this->Stream();
-
+ $printer = get_report_printer(user_print_profile(), $_POST['REP_ID']);
+ if ($printer == false) {
+ if(in_Ajax()) {
+ global $Ajax;
+ // in case of ajax call non-ajax page reload is forced.
+ // the alternative is to differ browser support from
+ // call to remote printing by some attribute of print links,
+ // but in this case we should check related printer target
+ // for any link on the page, even if never used.
+
+ // display in popup window ...
+// $Ajax->popup($_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING']);
+ // ... or fire browser download popup
+ // $Ajax->redirect($_SERVER['PHP_SELF'].'?'.$_SERVER['QUERY_STRING']);
+// strip document root from file path
+ $fname = substr(realpath($fname), strlen($_SERVER['DOCUMENT_ROOT']));
+ if (substr($fname,0,1) != '/') $fname = '/'.$fname;
+
+ if (user_rep_popup())
+ $Ajax->popup($fname);
+ else
+ $Ajax->redirect($fname);
+ } else {
+ //echo '
+ //
+ //
+ //
+ //
+ // click here if you are not re-directed.
+ //
+ // ';
+ header('Content-type: application/pdf');
+ header("Content-Disposition: inline; filename=$this->filename");
+ header('Expires: 0');
+ header('Cache-Control: must-revalidate, post-check=0, pre-check=0');
+ header('Pragma: public');
+ $this->Stream();
+ }
+ } else { // send report to network printer
+ $prn = new remote_printer($printer['queue'],$printer['host'],
+ $printer['port'], $printer['timeout']);
+ $error = $prn->print_file($fname);
+ if ($error)
+ display_error($error);
+ else
+ display_notification(_('Report has been sent to network printer ').$printer['name']);
+ }
}
- // also have a look through the directory, and remove the files that are older than a week
- // rather want to save 'em
- /*if ($d = @opendir($dir)) {
+ // first have a look through the directory,
+ // and remove old temporary pdfs
+ if ($d = @opendir($dir)) {
while (($file = readdir($d)) !== false) {
- // then check to see if this one is too old
+ if (!is_file($dir.'/'.$file) || $file == 'index.php') continue;
+ // then check to see if this one is too old
$ftime = filemtime($dir.'/'.$file);
- if (time()-$ftime > 3600*24*7){
+ // seems 3 min is enough for any report download, isn't it?
+ if (time()-$ftime > 180){
unlink($dir.'/'.$file);
}
}
closedir($d);
- }*/
+ }
}
}
}