%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/modules/sale/ru/payment/bill_en/ |
Current File : //home/bitrix/www/bitrix/modules/sale/ru/payment/bill_en/html.php |
<?if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED !== true) die();?><? $ORDER_ID = IntVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["ID"]); if (!is_array($arOrder)) $arOrder = CSaleOrder::GetByID($ORDER_ID); ?> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title>Счет</title> <meta http-equiv="Content-Type" content="text/html; charset=<?=LANG_CHARSET?>"> <style> table { border-collapse: collapse; } table.it td { border: 1pt solid #000000; padding: 0pt 3pt; } table.inv td, table.sign td { padding: 0pt; } table.sign td { vertical-align: top; } </style> </head> <? $pageWidth = 595.28; $pageHeight = 841.89; $background = '#ffffff'; if (CSalePaySystemAction::GetParamValue('BACKGROUND')) { $path = CSalePaySystemAction::GetParamValue('BACKGROUND'); if (intval($path) > 0) { if ($arFile = CFile::GetFileArray($path)) $path = $arFile['SRC']; } $backgroundStyle = CSalePaySystemAction::GetParamValue('BACKGROUND_STYLE'); if (!in_array($backgroundStyle, array('none', 'tile', 'stretch'))) $backgroundStyle = 'none'; if ($path) { switch ($backgroundStyle) { case 'none': $background = "url('" . $path . "') 0 0 no-repeat"; break; case 'tile': $background = "url('" . $path . "') 0 0 repeat"; break; case 'stretch': $background = sprintf( "url('%s') 0 0 repeat-y; background-size: %.02fpt %.02fpt", $path, $pageWidth, $pageHeight ); break; } } } $margin = array( 'top' => intval(CSalePaySystemAction::GetParamValue('MARGIN_TOP') ?: 15) * 72/25.4, 'right' => intval(CSalePaySystemAction::GetParamValue('MARGIN_RIGHT') ?: 15) * 72/25.4, 'bottom' => intval(CSalePaySystemAction::GetParamValue('MARGIN_BOTTOM') ?: 15) * 72/25.4, 'left' => intval(CSalePaySystemAction::GetParamValue('MARGIN_LEFT') ?: 20) * 72/25.4 ); $width = $pageWidth - $margin['left'] - $margin['right']; ?> <body style="margin: 0pt; padding: <?=join('pt ', $margin); ?>pt; width: <?=$width; ?>pt; background: <?=$background; ?>" <? if ($_REQUEST['PRINT'] == 'Y') { ?> onload="setTimeout(window.print, 0);" <? } ?> > <?=CFile::ShowImage( CSalePaySystemAction::GetParamValue("PATH_TO_LOGO"), 0, 0, 'style="float: left; padding-right: 5pt; "' ); ?> <div style="float: left; "> <b><?=CSalePaySystemAction::GetParamValue("SELLER_NAME"); ?></b><br> <? if (CSalePaySystemAction::GetParamValue("SELLER_ADDRESS")) { ?> <b><?=CSalePaySystemAction::GetParamValue("SELLER_ADDRESS"); ?></b><br> <? } ?> <? if (CSalePaySystemAction::GetParamValue("SELLER_PHONE")) { ?> <b><?=sprintf("Tel.: %s", CSalePaySystemAction::GetParamValue("SELLER_PHONE")); ?></b><br> <? } ?> <br> </div> <div style="clear: both; height: 5pt; "></div> <br> <div style="text-align: center; font-size: 2em"><b>Invoice</b></div> <br> <br> <table width="100%"> <tr> <? if (CSalePaySystemAction::GetParamValue("BUYER_NAME")) { ?> <td> <b>To</b><br> <?=CSalePaySystemAction::GetParamValue("BUYER_NAME"); ?><br> <? if (CSalePaySystemAction::GetParamValue("BUYER_ADDRESS")) { ?> <?=CSalePaySystemAction::GetParamValue("BUYER_ADDRESS"); ?> <? } ?> </td> <? } ?> <td align="right"> <table class="inv"> <tr align="right"> <td><b>Invoice # </b></td> <td><?=htmlspecialcharsbx($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["ACCOUNT_NUMBER"]); ?></td> </tr> <tr align="right"> <td><b>Issue Date: </b></td> <td><?=CSalePaySystemAction::GetParamValue("DATE_INSERT"); ?></td> </tr> <? if (CSalePaySystemAction::GetParamValue("DATE_PAY_BEFORE")) { ?> <tr align="right"> <td><b>Due Date: </b></td> <td><?=ConvertDateTime(CSalePaySystemAction::GetParamValue("DATE_PAY_BEFORE"), FORMAT_DATE); ?></td> </tr> <? } ?> </table> </td> </tr> </table> <br> <br> <br> <? $dbBasket = CSaleBasket::GetList( array("NAME" => "ASC"), array("ORDER_ID" => $ORDER_ID) ); if ($arBasket = $dbBasket->Fetch()) { $arCells = array(); $arProps = array(); $n = 0; $sum = 0.00; $vat = 0; $vats = array(); do { // props in busket product $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; // @TODO: replace with real vatless price $arBasket["VATLESS_PRICE"] = roundEx($arBasket["PRICE"] / (1 + $arBasket["VAT_RATE"]), SALE_VALUE_PRECISION); $arCells[++$n] = array( 1 => $n, htmlspecialcharsbx($arBasket["NAME"]), roundEx($arBasket["QUANTITY"], SALE_VALUE_PRECISION), 'pcs', SaleFormatCurrency($arBasket["VATLESS_PRICE"], $arBasket["CURRENCY"], true), roundEx($arBasket["VAT_RATE"]*100, SALE_VALUE_PRECISION) . "%", SaleFormatCurrency( $arBasket["VATLESS_PRICE"] * $arBasket["QUANTITY"], $arBasket["CURRENCY"], true ) ); $arProps[$n] = array(); foreach ($arBasket["PROPS"] as $vv) $arProps[$n][] = htmlspecialcharsbx(sprintf("%s: %s", $vv["NAME"], $vv["VALUE"])); $sum += doubleval($arBasket["VATLESS_PRICE"] * $arBasket["QUANTITY"]); $vat = max($vat, $arBasket["VAT_RATE"]); if ($arBasket["VAT_RATE"] > 0) { if (!isset($vats[$arBasket["VAT_RATE"]])) $vats[$arBasket["VAT_RATE"]] = 0; $vats[$arBasket["VAT_RATE"]] += ($arBasket["PRICE"] - $arBasket["VATLESS_PRICE"]) * $arBasket["QUANTITY"]; } } 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 = "Shipping"; if (strlen($arDelivery_tmp["NAME"]) > 0) $sDeliveryItem .= sprintf(" (%s)", $arDelivery_tmp["NAME"]); $arCells[++$n] = array( 1 => $n, htmlspecialcharsbx($sDeliveryItem), 1, '', SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"] / (1 + $vat), $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ), roundEx($vat*100, SALE_VALUE_PRECISION) . "%", SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"] / (1 + $vat), $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ) ); $sum += roundEx( doubleval($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"] / (1 + $vat)), SALE_VALUE_PRECISION ); if ($vat > 0) $vats[$vat] += roundEx( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE_DELIVERY"] * $vat / (1 + $vat), SALE_VALUE_PRECISION ); } $items = $n; if ($sum < $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE"]) { $arCells[++$n] = array( 1 => null, null, null, null, null, "Subtotal:", SaleFormatCurrency($sum, $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true) ); } if (!empty($vats)) { // @TODO: remove on real vatless price implemented $delta = intval(roundEx( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["PRICE"] - $sum - array_sum($vats), SALE_VALUE_PRECISION ) * pow(10, SALE_VALUE_PRECISION)); if ($delta) { $vatRates = array_keys($vats); rsort($vatRates); while (abs($delta) > 0) { foreach ($vatRates as $vatRate) { $vats[$vatRate] += abs($delta)/$delta / pow(10, SALE_VALUE_PRECISION); $delta -= abs($delta)/$delta; if ($delta == 0) break 2; } } } foreach ($vats as $vatRate => $vatSum) { $arCells[++$n] = array( 1 => null, null, null, null, null, sprintf( "Sales Tax (%s%%):", roundEx($vatRate * 100, SALE_VALUE_PRECISION) ), SaleFormatCurrency( $vatSum, $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ) ); } } else { $dbTaxList = CSaleOrderTax::GetList( array("APPLY_ORDER" => "ASC"), array("ORDER_ID" => $ORDER_ID) ); while ($arTaxList = $dbTaxList->Fetch()) { $arCells[++$n] = array( 1 => null, null, null, null, null, htmlspecialcharsbx(sprintf( "%s%s%s:", ($arTaxList["IS_IN_PRICE"] == "Y") ? "Included " : "", $arTaxList["TAX_NAME"], sprintf(' (%s%%)', roundEx($arTaxList["VALUE"],SALE_VALUE_PRECISION)) )), SaleFormatCurrency( $arTaxList["VALUE_MONEY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ) ); } } if (DoubleVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SUM_PAID"]) > 0) { $arCells[++$n] = array( 1 => null, null, null, null, null, "Payment made:", SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SUM_PAID"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ) ); } if (DoubleVal($GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["DISCOUNT_VALUE"]) > 0) { $arCells[++$n] = array( 1 => null, null, null, null, null, "Discount:", SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["DISCOUNT_VALUE"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ) ); } $arCells[++$n] = array( 1 => null, null, null, null, null, "Total:", SaleFormatCurrency( $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["SHOULD_PAY"], $GLOBALS["SALE_INPUT_PARAMS"]["ORDER"]["CURRENCY"], true ) ); } ?> <table class="it" width="100%"> <tr> <td><nobr>#</nobr></td> <td><nobr>Item / Description</nobr></td> <td><nobr>Qty</nobr></td> <td><nobr>Units</nobr></td> <td><nobr>Unit Price</nobr></td> <? if ($vat > 0) { ?> <td><nobr>Tax</nobr></td> <? } ?> <td><nobr>Total</nobr></td> </tr> <? $rowsCnt = count($arCells); for ($n = 1; $n <= $rowsCnt; $n++) { $accumulated = 0; ?> <tr valign="top"> <? if (!is_null($arCells[$n][1])) { ?> <td align="center"><?=$arCells[$n][1]; ?></td> <? } else { $accumulated++; } ?> <? if (!is_null($arCells[$n][2])) { ?> <td align="left" <? if ($accumulated) { ?> style="border-width: 0pt 1pt 0pt 0pt" colspan="<?=($accumulated+1); ?>"<? $accumulated = 0; } ?>> <?=$arCells[$n][2]; ?> <? if (isset($arProps[$n]) && is_array($arProps[$n])) { ?> <? foreach ($arProps[$n] as $property) { ?> <br> <small><?=$property; ?></small> <? } ?> <? } ?> </td> <? } else { $accumulated++; } ?> <? for ($i = 3; $i <= 7; $i++) { ?> <? if (!is_null($arCells[$n][$i])) { ?> <? if ($i != 6 || $vat > 0 || is_null($arCells[$n][2])) { ?> <td align="right" <? if ($accumulated) { ?> style="border-width: 0pt 1pt 0pt 0pt" colspan="<?=(($i == 6 && $vat <= 0) ? $accumulated : $accumulated+1); ?>" <? $accumulated = 0; } ?>> <nobr><?=$arCells[$n][$i]; ?></nobr> </td> <? } } else { $accumulated++; } } ?> </tr> <? } ?> </table> <br> <br> <br> <br> <? if (CSalePaySystemAction::GetParamValue("COMMENT1") || CSalePaySystemAction::GetParamValue("COMMENT2")) { ?> <b>Terms & Conditions</b> <br> <? if (CSalePaySystemAction::GetParamValue("COMMENT1")) { ?> <?=nl2br(HTMLToTxt(preg_replace( array('#</div>\s*<div[^>]*>#i', '#</?div>#i'), array('<br>', '<br>'), htmlspecialcharsback(CSalePaySystemAction::GetParamValue("COMMENT1")) ), '', array(), 0)); ?> <br> <br> <? } ?> <? if (CSalePaySystemAction::GetParamValue("COMMENT2")) { ?> <?=nl2br(HTMLToTxt(preg_replace( array('#</div>\s*<div[^>]*>#i', '#</?div>#i'), array('<br>', '<br>'), htmlspecialcharsback(CSalePaySystemAction::GetParamValue("COMMENT2")) ), '', array(), 0)); ?> <br> <br> <? } ?> <? } ?> <br> <br> <br> <? $bankAccNo = CSalePaySystemAction::GetParamValue("SELLER_BANK_ACCNO"); ?> <? $bankRouteNo = CSalePaySystemAction::GetParamValue("SELLER_BANK_ROUTENO"); ?> <? $bankSwift = CSalePaySystemAction::GetParamValue("SELLER_BANK_SWIFT"); ?> <table class="sign" style="width: 100%; "> <tr> <td style="width: 50%; "> <? if ($bankAccNo && $bankRouteNo && $bankSwift) { ?> <b>Bank Details</b> <br> <? if (CSalePaySystemAction::GetParamValue("SELLER_NAME")) { ?> Account Name: <?=CSalePaySystemAction::GetParamValue("SELLER_NAME"); ?> <br> <? } ?> Account #: <?=$bankAccNo; ?> <br> <? $bank = CSalePaySystemAction::GetParamValue("SELLER_BANK"); ?> <? $bankAddr = CSalePaySystemAction::GetParamValue("SELLER_BANK_ADDR"); ?> <? $bankPhone = CSalePaySystemAction::GetParamValue("SELLER_BANK_PHONE"); ?> <? if ($bank || $bankAddr || $bankPhone) { ?> Bank Name and Address: <? if ($bank) { ?><?=$bank; ?><? } ?> <br> <? if ($bankAddr) { ?> <?=$bankAddr; ?> <br> <? } ?> <? if ($bankPhone) { ?> <?=$bankPhone; ?> <br> <? } ?> <? } ?> Bank's routing number: <?=$bankRouteNo; ?> <br> Bank SWIFT: <?=$bankSwift; ?> <br> <? } ?> </td> <td style="width: 50%; "> <div style="position: relative; "><?=CFile::ShowImage( CSalePaySystemAction::GetParamValue("PATH_TO_STAMP"), 0, 0, 'style="position: absolute; left: 30pt; "' ); ?></div> <table style="width: 100%; position: relative; "> <colgroup> <col width="0"> <col width="100%"> </colgroup> <? if (CSalePaySystemAction::GetParamValue("SELLER_DIR") || CSalePaySystemAction::GetParamValue("SELLER_DIR_SIGN")) { ?> <? if (CSalePaySystemAction::GetParamValue("SELLER_DIR")) { ?> <tr><td> </td></tr> <tr> <td colspan="2"><?=CSalePaySystemAction::GetParamValue("SELLER_DIR"); ?></td> </tr> <? } ?> <? if (CSalePaySystemAction::GetParamValue("SELLER_DIR_SIGN")) { ?> <tr><td> </td></tr> <tr> <td><nobr>The Director</nobr></td> <td style="border-bottom: 1pt solid #000000; text-align: center; "> <span style="position: relative; "> <?=CFile::ShowImage( CSalePaySystemAction::GetParamValue("SELLER_DIR_SIGN"), 200, 50, 'style="position: absolute; margin-left: -75pt; bottom: 0pt; "' ); ?></span> </td> </tr> <? } ?> <? } ?> <? if (CSalePaySystemAction::GetParamValue("SELLER_ACC") || CSalePaySystemAction::GetParamValue("SELLER_ACC_SIGN")) { ?> <? if (CSalePaySystemAction::GetParamValue("SELLER_ACC")) { ?> <tr><td> </td></tr> <tr> <td colspan="2"><?=CSalePaySystemAction::GetParamValue("SELLER_ACC"); ?></td> </tr> <? } ?> <? if (CSalePaySystemAction::GetParamValue("SELLER_ACC_SIGN")) { ?> <tr><td> </td></tr> <tr> <td><nobr>The Accountant</nobr></td> <td style="border-bottom: 1pt solid #000000; text-align: center; "> <span style="position: relative; "> <?=CFile::ShowImage( CSalePaySystemAction::GetParamValue("SELLER_ACC_SIGN"), 200, 50, 'style="position: absolute; margin-left: -75pt; bottom: 0pt; "' ); ?></span> </td> </tr> <? } ?> <? } ?> </table> </td> </tr> </table> </body> </html>