%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/modules/sale/ru/payment/bill/ |
Current File : //home/bitrix/www/bitrix/modules/sale/ru/payment/bill/pdf.php |
<?if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED !== true) die();?><? $arPaySysAction["ENCODING"] = ""; $ORDER_ID = IntVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["ID"]); if (!is_array($arOrder)) $arOrder = CSaleOrder::GetByID($ORDER_ID); if (!CSalePdf::isPdfAvailable()) die(); if ($_REQUEST['BLANK'] == 'Y') $blank = true; $pdf = new CSalePdf('P', 'pt', 'A4'); if (CSalePaySystemAction::GetParamValue('BACKGROUND', false)) { $pdf->SetBackground( CSalePaySystemAction::GetParamValue('BACKGROUND', false), CSalePaySystemAction::GetParamValue('BACKGROUND_STYLE', false) ); } $pageWidth = $pdf->GetPageWidth(); $pageHeight = $pdf->GetPageHeight(); $pdf->AddFont('Font', '', 'pt_sans-regular.ttf', true); $pdf->AddFont('Font', 'B', 'pt_sans-bold.ttf', true); $fontFamily = 'Font'; $fontSize = 10.5; $margin = array( 'top' => intval(CSalePaySystemAction::GetParamValue('MARGIN_TOP', false) ?: 15) * 72/25.4, 'right' => intval(CSalePaySystemAction::GetParamValue('MARGIN_RIGHT', false) ?: 15) * 72/25.4, 'bottom' => intval(CSalePaySystemAction::GetParamValue('MARGIN_BOTTOM', false) ?: 15) * 72/25.4, 'left' => intval(CSalePaySystemAction::GetParamValue('MARGIN_LEFT', false) ?: 20) * 72/25.4 ); $width = $pageWidth - $margin['left'] - $margin['right']; $pdf->SetDisplayMode(100, 'continuous'); $pdf->SetMargins($margin['left'], $margin['top'], $margin['right']); $pdf->SetAutoPageBreak(true, $margin['bottom']); $pdf->AddPage(); $y0 = $pdf->GetY(); $logoHeight = 0; $logoWidth = 0; if (CSalePaySystemAction::GetParamValue('PATH_TO_LOGO', false)) { list($imageHeight, $imageWidth) = $pdf->GetImageSize(CSalePaySystemAction::GetParamValue('PATH_TO_LOGO', false)); $imgDpi = intval(CSalePaySystemAction::GetParamValue('LOGO_DPI', false)) ?: 96; $imgZoom = 96 / $imgDpi; $logoHeight = $imageHeight * $imgZoom + 5; $logoWidth = $imageWidth * $imgZoom + 5; $pdf->Image(CSalePaySystemAction::GetParamValue('PATH_TO_LOGO', false), $pdf->GetX(), $pdf->GetY(), -$imgDpi, -$imgDpi); } $pdf->SetFont($fontFamily, 'B', $fontSize); $pdf->SetX($pdf->GetX() + $logoWidth); $pdf->Write(15, CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("SELLER_NAME", false))); $pdf->Ln(); if (CSalePaySystemAction::GetParamValue("SELLER_ADDRESS", false)) { $pdf->SetX($pdf->GetX() + $logoWidth); $pdf->MultiCell(0, 15, CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("SELLER_ADDRESS", false)), 0, 'L'); } if (CSalePaySystemAction::GetParamValue("SELLER_PHONE", false)) { $pdf->SetX($pdf->GetX() + $logoWidth); $pdf->Write(15, CSalePdf::prepareToPdf(sprintf("Тел.: %s", CSalePaySystemAction::GetParamValue("SELLER_PHONE", false)))); $pdf->Ln(); } $pdf->Ln(); $pdf->SetY(max($y0 + $logoHeight, $pdf->GetY())); if (CSalePaySystemAction::GetParamValue("SELLER_BANK", false)) { $sellerBank = sprintf( "%s %s", CSalePaySystemAction::GetParamValue("SELLER_BANK", false), CSalePaySystemAction::GetParamValue("SELLER_BCITY", false) ); $sellerRs = CSalePaySystemAction::GetParamValue("SELLER_RS", false); } else { $rsPattern = '/\s*\d{10,100}\s*/'; $sellerBank = trim(preg_replace($rsPattern, ' ', CSalePaySystemAction::GetParamValue("SELLER_RS", false))); preg_match($rsPattern, CSalePaySystemAction::GetParamValue("SELLER_RS", false), $matches); $sellerRs = trim($matches[0]); } $pdf->SetFont($fontFamily, '', $fontSize); $x0 = $pdf->GetX(); $y0 = $pdf->GetY(); $pdf->Cell( 150, 18, (CSalePaySystemAction::GetParamValue("SELLER_INN", false)) ? CSalePdf::prepareToPdf(sprintf("ИНН %s", CSalePaySystemAction::GetParamValue("SELLER_INN", false))) : '' ); $x1 = $pdf->GetX(); $pdf->Cell( 150, 18, (CSalePaySystemAction::GetParamValue("SELLER_KPP", false)) ? CSalePdf::prepareToPdf(sprintf("КПП %s", CSalePaySystemAction::GetParamValue("SELLER_KPP", false))) : '' ); $x2 = $pdf->GetX(); $pdf->Cell(50, 18); $x3 = $pdf->GetX(); $pdf->Cell(0, 18); $x4 = $pdf->GetX(); $pdf->Line($x0, $y0, $x4, $y0); $pdf->Ln(); $y1 = $pdf->GetY(); $pdf->Line($x1, $y0, $x1, $y1); $pdf->Cell(300, 18, CSalePdf::prepareToPdf('Получатель')); $pdf->Cell(50, 18); $pdf->Cell(0, 18); $pdf->Line($x0, $y1, $x2, $y1); $pdf->Ln(); $y2 = $pdf->GetY(); $text = CSalePaySystemAction::GetParamValue("SELLER_NAME", false); while ($pdf->GetStringWidth($text) > 0) { list($string, $text) = $pdf->splitString($text, 300-5); $pdf->Cell(300, 18, CSalePdf::prepareToPdf($string)); if ($text) $pdf->Ln(); } $pdf->Cell(50, 18, CSalePdf::prepareToPdf('Сч. №')); $pdf->Cell(0, 18, CSalePdf::prepareToPdf($sellerRs)); $pdf->Ln(); $y3 = $pdf->GetY(); $pdf->Cell(300, 18, CSalePdf::prepareToPdf('Банк получателя')); $pdf->Cell(50, 18, CSalePdf::prepareToPdf('БИК')); $pdf->Cell(0, 18, CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("SELLER_BIK", false))); $pdf->Line($x0, $y3, $x4, $y3); $pdf->Ln(); $y4 = $pdf->GetY(); $text = $sellerBank; while ($pdf->GetStringWidth($text) > 0) { list($string, $text) = $pdf->splitString($text, 300-5); $pdf->Cell(300, 18, CSalePdf::prepareToPdf($string)); if ($text) $pdf->Ln(); } $pdf->Cell(50, 18, CSalePdf::prepareToPdf('Сч. №')); $pdf->Cell(0, 18, CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("SELLER_KS", false))); $pdf->Ln(); $y5 = $pdf->GetY(); $pdf->Line($x0, $y5, $x4, $y5); $pdf->Line($x0, $y0, $x0, $y5); $pdf->Line($x2, $y0, $x2, $y5); $pdf->Line($x3, $y0, $x3, $y5); $pdf->Line($x4, $y0, $x4, $y5); $pdf->Ln(); $pdf->Ln(); $pdf->SetFont($fontFamily, 'B', $fontSize*2); $billNo_tmp = CSalePdf::prepareToPdf(sprintf( "СЧЕТ № %s от %s", $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["ACCOUNT_NUMBER"], CSalePaySystemAction::GetParamValue("DATE_INSERT", false) )); $billNo_width = $pdf->GetStringWidth($billNo_tmp); $pdf->Cell(0, 20, $billNo_tmp, 0, 0, 'C'); $pdf->Ln(); $pdf->SetFont($fontFamily, '', $fontSize); if (CSalePaySystemAction::GetParamValue("ORDER_SUBJECT", false)) { $pdf->Cell($width/2-$billNo_width/2-2, 15, ''); $pdf->MultiCell(0, 15, CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("ORDER_SUBJECT", false)), 0, 'L'); } if (CSalePaySystemAction::GetParamValue("DATE_PAY_BEFORE", false)) { $pdf->Cell($width/2-$billNo_width/2-2, 15, ''); $pdf->MultiCell(0, 15, CSalePdf::prepareToPdf(sprintf( "Срок оплаты %s", ConvertDateTime(CSalePaySystemAction::GetParamValue("DATE_PAY_BEFORE", false), FORMAT_DATE) ?: CSalePaySystemAction::GetParamValue("DATE_PAY_BEFORE", false) )), 0, 'L'); } $pdf->Ln(); if (CSalePaySystemAction::GetParamValue("BUYER_NAME", false)) { $pdf->Write(15, CSalePdf::prepareToPdf(sprintf( "Плательщик: %s", CSalePaySystemAction::GetParamValue("BUYER_NAME", false) ))); if (CSalePaySystemAction::GetParamValue("BUYER_INN", false)) $pdf->Write(15, CSalePdf::prepareToPdf(sprintf(" ИНН %s", CSalePaySystemAction::GetParamValue("BUYER_INN", false)))); if (CSalePaySystemAction::GetParamValue("BUYER_ADDRESS", false)) $pdf->Write(15, CSalePdf::prepareToPdf(sprintf(", %s", CSalePaySystemAction::GetParamValue("BUYER_ADDRESS", false)))); if (CSalePaySystemAction::GetParamValue("BUYER_PHONE", false)) $pdf->Write(15, CSalePdf::prepareToPdf(sprintf(", %s", CSalePaySystemAction::GetParamValue("BUYER_PHONE", false)))); if (CSalePaySystemAction::GetParamValue("BUYER_FAX", false)) $pdf->Write(15, CSalePdf::prepareToPdf(sprintf(", %s", CSalePaySystemAction::GetParamValue("BUYER_FAX", false)))); if (CSalePaySystemAction::GetParamValue("BUYER_PAYER_NAME", false)) $pdf->Write(15, CSalePdf::prepareToPdf(sprintf(", %s", CSalePaySystemAction::GetParamValue("BUYER_PAYER_NAME", false)))); $pdf->Ln(); } /* $pdf->Write(15, CSalePdf::prepareToPdf(sprintf( "Грузополучатель: %s ИНН %s, %s", CSalePaySystemAction::GetParamValue("BUYER_NAME", false), CSalePaySystemAction::GetParamValue("BUYER_INN", false), CSalePaySystemAction::GetParamValue("BUYER_ADDRESS", false) ))); $pdf->Ln(); */ // Список товаров $dbBasket = CSaleBasket::GetList( array("DATE_INSERT" => "ASC", "NAME" => "ASC"), array("ORDER_ID" => $ORDER_ID), false, false, array("ID", "PRICE", "CURRENCY", "QUANTITY", "NAME", "VAT_RATE", "MEASURE_NAME") ); if ($arBasket = $dbBasket->Fetch()) { $arCurFormat = CCurrencyLang::GetCurrencyFormat($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"]); $currency = trim(str_replace('#', '', $arCurFormat['FORMAT_STRING'])); $arColsCaption = array( 1 => CSalePdf::prepareToPdf('№'), CSalePdf::prepareToPdf('Наименование товара'), CSalePdf::prepareToPdf('Кол-во'), CSalePdf::prepareToPdf('Ед.'), CSalePdf::prepareToPdf('Цена, '.$currency), CSalePdf::prepareToPdf('Ставка НДС'), CSalePdf::prepareToPdf('Сумма, '.$currency) ); $arCells = array(); $arProps = array(); $arRowsWidth = array(1 => 0, 0, 0, 0, 0, 0, 0); for ($i = 1; $i <= 7; $i++) $arRowsWidth[$i] = max($arRowsWidth[$i], $pdf->GetStringWidth($arColsCaption[$i])); $n = 0; $sum = 0.00; $vat = 0; do { // props in product basket $arProdProps = array(); $dbBasketProps = CSaleBasket::GetPropsList( array("SORT" => "ASC", "ID" => "DESC"), array( "BASKET_ID" => $arBasket["ID"], "!CODE" => array("CATALOG.XML_ID", "PRODUCT.XML_ID") ), false, false, array("ID", "BASKET_ID", "NAME", "VALUE", "CODE", "SORT") ); while ($arBasketProps = $dbBasketProps->GetNext()) { if (!empty($arBasketProps) && $arBasketProps["VALUE"] != "") $arProdProps[] = $arBasketProps; } $arBasket["PROPS"] = $arProdProps; $productName = $arBasket["NAME"]; if ($productName == "OrderDelivery") $productName = "Доставка"; else if ($productName == "OrderDiscount") $productName = "Скидка"; $arCells[++$n] = array( 1 => CSalePdf::prepareToPdf($n), CSalePdf::prepareToPdf($productName), CSalePdf::prepareToPdf(roundEx($arBasket["QUANTITY"], SALE_VALUE_PRECISION)), CSalePdf::prepareToPdf($arBasket["MEASURE_NAME"] ? $arBasket["MEASURE_NAME"] : 'шт.'), CSalePdf::prepareToPdf(SaleFormatCurrency($arBasket["PRICE"], $arBasket["CURRENCY"], true)), CSalePdf::prepareToPdf(roundEx($arBasket["VAT_RATE"]*100, SALE_VALUE_PRECISION)."%"), CSalePdf::prepareToPdf(SaleFormatCurrency( $arBasket["PRICE"] * $arBasket["QUANTITY"], $arBasket["CURRENCY"], true )) ); $arProps[$n] = array(); foreach ($arBasket["PROPS"] as $vv) $arProps[$n][] = CSalePdf::prepareToPdf(sprintf("%s: %s", $vv["NAME"], $vv["VALUE"])); for ($i = 1; $i <= 7; $i++) $arRowsWidth[$i] = max($arRowsWidth[$i], $pdf->GetStringWidth($arCells[$n][$i])); $sum += doubleval($arBasket["PRICE"] * $arBasket["QUANTITY"]); $vat = max($vat, $arBasket["VAT_RATE"]); } while ($arBasket = $dbBasket->Fetch()); if (DoubleVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"]) > 0) { $arDelivery_tmp = CSaleDelivery::GetByID($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["DELIVERY_ID"]); $sDeliveryItem = "Доставка"; if (strlen($arDelivery_tmp["NAME"]) > 0) $sDeliveryItem .= sprintf(" (%s)", $arDelivery_tmp["NAME"]); $arCells[++$n] = array( 1 => CSalePdf::prepareToPdf($n), CSalePdf::prepareToPdf($sDeliveryItem), CSalePdf::prepareToPdf(1), CSalePdf::prepareToPdf(''), CSalePdf::prepareToPdf(SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true )), CSalePdf::prepareToPdf(roundEx($vat*100, SALE_VALUE_PRECISION)."%"), CSalePdf::prepareToPdf(SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true )) ); for ($i = 1; $i <= 7; $i++) $arRowsWidth[$i] = max($arRowsWidth[$i], $pdf->GetStringWidth($arCells[$n][$i])); $sum += doubleval($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"]); } $items = $n; if ($sum < $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE"]) { $arCells[++$n] = array( 1 => null, null, null, null, null, CSalePdf::prepareToPdf("Подытог:"), CSalePdf::prepareToPdf(SaleFormatCurrency($sum, $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true)) ); $arRowsWidth[7] = max($arRowsWidth[7], $pdf->GetStringWidth($arCells[$n][7])); } $taxes = false; $dbTaxList = CSaleOrderTax::GetList( array("APPLY_ORDER" => "ASC"), array("ORDER_ID" => $ORDER_ID) ); while ($arTaxList = $dbTaxList->Fetch()) { $taxes = true; $arCells[++$n] = array( 1 => null, null, null, null, null, CSalePdf::prepareToPdf(sprintf( "%s%s%s:", ($arTaxList["IS_IN_PRICE"] == "Y") ? "В том числе " : "", $arTaxList["TAX_NAME"], ($vat <= 0 && $arTaxList["IS_PERCENT"] == "Y") ? sprintf(' (%s%%)', roundEx($arTaxList["VALUE"],SALE_VALUE_PRECISION)) : "" )), CSalePdf::prepareToPdf(SaleFormatCurrency( $arTaxList["VALUE_MONEY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true )) ); $arRowsWidth[7] = max($arRowsWidth[7], $pdf->GetStringWidth($arCells[$n][7])); } if (!$taxes) { $arCells[++$n] = array( 1 => null, null, null, null, null, CSalePdf::prepareToPdf("НДС:"), CSalePdf::prepareToPdf("Без НДС") ); $arRowsWidth[7] = max($arRowsWidth[7], $pdf->GetStringWidth($arCells[$n][7])); } if (DoubleVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SUM_PAID"]) > 0) { $arCells[++$n] = array( 1 => null, null, null, null, null, CSalePdf::prepareToPdf("Уже оплачено:"), CSalePdf::prepareToPdf(SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SUM_PAID"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true )) ); $arRowsWidth[7] = max($arRowsWidth[7], $pdf->GetStringWidth($arCells[$n][7])); } if (DoubleVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["DISCOUNT_VALUE"]) > 0) { $arCells[++$n] = array( 1 => null, null, null, null, null, CSalePdf::prepareToPdf("Скидка:"), CSalePdf::prepareToPdf(SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["DISCOUNT_VALUE"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true )) ); $arRowsWidth[7] = max($arRowsWidth[7], $pdf->GetStringWidth($arCells[$n][7])); } $arCells[++$n] = array( 1 => null, null, null, null, null, CSalePdf::prepareToPdf("Итого:"), CSalePdf::prepareToPdf(SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SHOULD_PAY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true )) ); $arRowsWidth[7] = max($arRowsWidth[7], $pdf->GetStringWidth($arCells[$n][7])); for ($i = 1; $i <= 7; $i++) $arRowsWidth[$i] += 10; if ($vat <= 0) $arRowsWidth[6] = 0; $arRowsWidth[2] = $width - (array_sum($arRowsWidth)-$arRowsWidth[2]); } $pdf->Ln(); $x0 = $pdf->GetX(); $y0 = $pdf->GetY(); for ($i = 1; $i <= 7; $i++) { if ($vat > 0 || $i != 6) $pdf->Cell($arRowsWidth[$i], 20, $arColsCaption[$i], 0, 0, 'C'); ${"x$i"} = $pdf->GetX(); } $pdf->Ln(); $y5 = $pdf->GetY(); $pdf->Line($x0, $y0, $x7, $y0); for ($i = 0; $i <= 7; $i++) { if ($vat > 0 || $i != 6) $pdf->Line(${"x$i"}, $y0, ${"x$i"}, $y5); } $pdf->Line($x0, $y5, $x7, $y5); $rowsCnt = count($arCells); for ($n = 1; $n <= $rowsCnt; $n++) { $arRowsWidth_tmp = $arRowsWidth; $accumulated = 0; for ($j = 1; $j <= 7; $j++) { if (is_null($arCells[$n][$j])) { $accumulated += $arRowsWidth_tmp[$j]; $arRowsWidth_tmp[$j] = null; } else { $arRowsWidth_tmp[$j] += $accumulated; $accumulated = 0; } } $x0 = $pdf->GetX(); $y0 = $pdf->GetY(); $pdf->SetFont($fontFamily, '', $fontSize); if (!is_null($arCells[$n][2])) { $text = $arCells[$n][2]; $cellWidth = $arRowsWidth_tmp[2]; } else { $text = $arCells[$n][6]; $cellWidth = $arRowsWidth_tmp[6]; } for ($l = 0; $pdf->GetStringWidth($text) > 0; $l++) { list($string, $text) = $pdf->splitString($text, $cellWidth-5); if (!is_null($arCells[$n][1])) $pdf->Cell($arRowsWidth_tmp[1], 15, ($l == 0) ? $arCells[$n][1] : '', 0, 0, 'C'); if ($l == 0) $x1 = $pdf->GetX(); if (!is_null($arCells[$n][2])) $pdf->Cell($arRowsWidth_tmp[2], 15, $string); if ($l == 0) $x2 = $pdf->GetX(); if (!is_null($arCells[$n][3])) $pdf->Cell($arRowsWidth_tmp[3], 15, ($l == 0) ? $arCells[$n][3] : '', 0, 0, 'R'); if ($l == 0) $x3 = $pdf->GetX(); if (!is_null($arCells[$n][4])) $pdf->Cell($arRowsWidth_tmp[4], 15, ($l == 0) ? $arCells[$n][4] : '', 0, 0, 'R'); if ($l == 0) $x4 = $pdf->GetX(); if (!is_null($arCells[$n][5])) $pdf->Cell($arRowsWidth_tmp[5], 15, ($l == 0) ? $arCells[$n][5] : '', 0, 0, 'R'); if ($l == 0) $x5 = $pdf->GetX(); if (!is_null($arCells[$n][6])) { if (is_null($arCells[$n][2])) $pdf->Cell($arRowsWidth_tmp[6], 15, $string, 0, 0, 'R'); else if ($vat > 0) $pdf->Cell($arRowsWidth_tmp[6], 15, ($l == 0) ? $arCells[$n][6] : '', 0, 0, 'R'); } if ($l == 0) $x6 = $pdf->GetX(); if (!is_null($arCells[$n][7])) $pdf->Cell($arRowsWidth_tmp[7], 15, ($l == 0) ? $arCells[$n][7] : '', 0, 0, 'R'); if ($l == 0) $x7 = $pdf->GetX(); $pdf->Ln(); } if (isset($arProps[$n]) && is_array($arProps[$n])) { $pdf->SetFont($fontFamily, '', $fontSize-2); foreach ($arProps[$n] as $property) { $pdf->Cell($arRowsWidth_tmp[1], 12, ''); $pdf->Cell($arRowsWidth_tmp[2], 12, $property); $pdf->Cell($arRowsWidth_tmp[3], 12, ''); $pdf->Cell($arRowsWidth_tmp[4], 12, ''); $pdf->Cell($arRowsWidth_tmp[5], 12, ''); if ($vat > 0) $pdf->Cell($arRowsWidth_tmp[6], 12, ''); $pdf->Cell($arRowsWidth_tmp[7], 12, '', 0, 1); } } $y5 = $pdf->GetY(); if ($y0 > $y5) $y0 = $margin['top']; for ($i = (is_null($arCells[$n][1])) ? 6 : 0; $i <= 7; $i++) { if ($vat > 0 || $i != 5) $pdf->Line(${"x$i"}, $y0, ${"x$i"}, $y5); } $pdf->Line((!is_null($arCells[$n][1])) ? $x0 : $x6, $y5, $x7, $y5); } $pdf->Ln(); $pdf->SetFont($fontFamily, '', $fontSize); $pdf->Write(15, CSalePdf::prepareToPdf(sprintf( "Всего наименований %s, на сумму %s", $items, SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SHOULD_PAY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], false ) ))); $pdf->Ln(); $pdf->SetFont($fontFamily, 'B', $fontSize); if (in_array($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], array("RUR", "RUB"))) { $pdf->Write(15, CSalePdf::prepareToPdf(Number2Word_Rus($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SHOULD_PAY"]))); } else { $pdf->Write(15, CSalePdf::prepareToPdf(SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SHOULD_PAY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], false ))); } $pdf->Ln(); $pdf->Ln(); if (CSalePaySystemAction::GetParamValue("COMMENT1", false) || CSalePaySystemAction::GetParamValue("COMMENT2", false)) { $pdf->Write(15, CSalePdf::prepareToPdf('Условия и комментарии')); $pdf->Ln(); $pdf->SetFont($fontFamily, '', $fontSize); if (CSalePaySystemAction::GetParamValue("COMMENT1", false)) { $pdf->Write(15, HTMLToTxt(preg_replace( array('#</div>\s*<div[^>]*>#i', '#</?div>#i'), array('<br>', '<br>'), CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("COMMENT1", false)) ), '', array(), 0)); $pdf->Ln(); $pdf->Ln(); } if (CSalePaySystemAction::GetParamValue("COMMENT2", false)) { $pdf->Write(15, HTMLToTxt(preg_replace( array('#</div>\s*<div[^>]*>#i', '#</?div>#i'), array('<br>', '<br>'), CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("COMMENT2", false)) ), '', array(), 0)); $pdf->Ln(); $pdf->Ln(); } } $pdf->Ln(); $pdf->Ln(); if (!$blank && CSalePaySystemAction::GetParamValue('PATH_TO_STAMP', false)) { list($stampHeight, $stampWidth) = $pdf->GetImageSize(CSalePaySystemAction::GetParamValue('PATH_TO_STAMP', false)); if ($stampHeight && $stampWidth) { if ($stampHeight > 120 || $stampWidth > 120) { $ratio = 120 / max($stampHeight, $stampWidth); $stampHeight = $ratio * $stampHeight; $stampWidth = $ratio * $stampWidth; } $pdf->Image( CSalePaySystemAction::GetParamValue('PATH_TO_STAMP', false), $margin['left']+40, $pdf->GetY(), $stampWidth, $stampHeight ); } } $pdf->SetFont($fontFamily, 'B', $fontSize); if (CSalePaySystemAction::GetParamValue("SELLER_DIR_POS", false)) { $isDirSign = false; if (!$blank && CSalePaySystemAction::GetParamValue('SELLER_DIR_SIGN', false)) { list($signHeight, $signWidth) = $pdf->GetImageSize(CSalePaySystemAction::GetParamValue('SELLER_DIR_SIGN', false)); if ($signHeight && $signWidth) { $ratio = min(37.5/$signHeight, 150/$signWidth); $signHeight = $ratio * $signHeight; $signWidth = $ratio * $signWidth; $isDirSign = true; } } $sellerDirPos = CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("SELLER_DIR_POS", false)); if ($isDirSign && $pdf->GetStringWidth($sellerDirPos) <= 160) $pdf->SetY($pdf->GetY() + min($signHeight, 30) - 15); $pdf->MultiCell(150, 15, $sellerDirPos, 0, 'L'); $pdf->SetXY($margin['left'] + 150, $pdf->GetY() - 15); if ($isDirSign) { $pdf->Image( CSalePaySystemAction::GetParamValue('SELLER_DIR_SIGN', false), $pdf->GetX() + 80 - $signWidth/2, $pdf->GetY() - $signHeight + 15, $signWidth, $signHeight ); } $x1 = $pdf->GetX(); $pdf->Cell(160, 15, ''); $x2 = $pdf->GetX(); if (CSalePaySystemAction::GetParamValue("SELLER_DIR", false)) $pdf->Write(15, CSalePdf::prepareToPdf('('.CSalePaySystemAction::GetParamValue("SELLER_DIR", false).')')); $pdf->Ln(); $y2 = $pdf->GetY(); $pdf->Line($x1, $y2, $x2, $y2); $pdf->Ln(); } if (CSalePaySystemAction::GetParamValue("SELLER_ACC_POS", false)) { $isAccSign = false; if (!$blank && CSalePaySystemAction::GetParamValue('SELLER_ACC_SIGN', false)) { list($signHeight, $signWidth) = $pdf->GetImageSize(CSalePaySystemAction::GetParamValue('SELLER_ACC_SIGN', false)); if ($signHeight && $signWidth) { $ratio = min(37.5/$signHeight, 150/$signWidth); $signHeight = $ratio * $signHeight; $signWidth = $ratio * $signWidth; $isAccSign = true; } } $sellerAccPos = CSalePdf::prepareToPdf(CSalePaySystemAction::GetParamValue("SELLER_ACC_POS", false)); if ($isAccSign && $pdf->GetStringWidth($sellerAccPos) <= 160) $pdf->SetY($pdf->GetY() + min($signHeight, 30) - 15); $pdf->MultiCell(150, 15, $sellerAccPos, 0, 'L'); $pdf->SetXY($margin['left'] + 150, $pdf->GetY() - 15); if ($isAccSign) { $pdf->Image( CSalePaySystemAction::GetParamValue('SELLER_ACC_SIGN', false), $pdf->GetX() + 80 - $signWidth/2, $pdf->GetY() - $signHeight + 15, $signWidth, $signHeight ); } $x1 = $pdf->GetX(); $pdf->Cell((CSalePaySystemAction::GetParamValue("SELLER_DIR", false)) ? $x2-$x1 : 160, 15, ''); $x2 = $pdf->GetX(); if (CSalePaySystemAction::GetParamValue("SELLER_ACC", false)) $pdf->Write(15, CSalePdf::prepareToPdf('('.CSalePaySystemAction::GetParamValue("SELLER_ACC", false).')')); $pdf->Ln(); $y2 = $pdf->GetY(); $pdf->Line($x1, $y2, $x2, $y2); } $dest = 'I'; if ($_REQUEST['GET_CONTENT'] == 'Y') $dest = 'S'; else if ($_REQUEST['DOWNLOAD'] == 'Y') $dest = 'D'; return $pdf->Output( sprintf( 'Schet No %s ot %s.pdf', $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["ACCOUNT_NUMBER"], ConvertDateTime($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["DATE_INSERT"], 'YYYY-MM-DD') ), $dest ); ?>