%PDF- %PDF-
Direktori : /home/bitrix/www/bitrix/modules/sale/handlers/paysystem/billby/template/ |
Current File : /home/bitrix/www/bitrix/modules/sale/handlers/paysystem/billby/template/template.php |
<? if (!defined("B_PROLOG_INCLUDED") || B_PROLOG_INCLUDED !== true) die(); use Bitrix\Main\Localization\Loc; Loc::loadMessages(__FILE__); ?> <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Transitional//EN"> <html> <head> <title><?=Loc::getMessage('SALE_HPS_BILLBY_TITLE')?></title> <meta http-equiv="Content-Type" content="text/html; charset=<?=LANG_CHARSET?>"> <style type="text/css"> table { border-collapse: collapse; } table.acc td { border: 1pt solid #000000; padding: 0 3pt; line-height: 21pt; } table.it td { border: 1pt solid #000000; padding: 0 3pt; } table.sign td { vertical-align: bottom; } table.header td { padding: 0; vertical-align: top; } </style> </head> <? if ($_REQUEST['BLANK'] == 'Y') $blank = true; $pageWidth = 595.28; $pageHeight = 841.89; $background = '#ffffff'; if ($params['BILLBY_BACKGROUND']) { $path = $params['BILLBY_BACKGROUND']; if (intval($path) > 0) { if ($arFile = CFile::GetFileArray($path)) $path = $arFile['SRC']; } $backgroundStyle = $params['BILLBY_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($params['BILLBY_MARGIN_TOP'] ?: 15) * 72/25.4, 'right' => intval($params['BILLBY_MARGIN_RIGHT'] ?: 15) * 72/25.4, 'bottom' => intval($params['BILLBY_MARGIN_BOTTOM'] ?: 15) * 72/25.4, 'left' => intval($params['BILLBY_MARGIN_LEFT'] ?: 20) * 72/25.4 ); $width = $pageWidth - $margin['left'] - $margin['right']; ?> <body style="margin: 0; padding: 0; background: <?=$background; ?>"<? if ($_REQUEST['PRINT'] == 'Y') { ?> onload="setTimeout(window.print, 0);"<? } ?>> <div style="margin: 0; padding: <?=join('pt ', $margin); ?>pt; width: <?=$width; ?>pt; background: <?=$background; ?>"> <?if ($params['BILLBY_HEADER_SHOW'] == 'Y'):?> <? // region Seller info $sellerInfo = ''; $sellerInfoRows = array(); $sellerInfoName = ''; if ($params["SELLER_COMPANY_NAME"]) { $sellerInfoName .= $params["SELLER_COMPANY_NAME"]; if (!empty($sellerInfoName)) $sellerInfoRows[] = $sellerInfoName; } unset($sellerInfoName); $sellerInfoTaxId = ''; if ($params['SELLER_COMPANY_INN']) { $sellerInfoTaxId .= Loc::getMessage('SALE_HPS_BILLBY_INN').': '.$params['SELLER_COMPANY_INN']; if (!empty($sellerInfoTaxId)) $sellerInfoRows[] = $sellerInfoTaxId; } unset($sellerInfoTaxId); $sellerInfoBank = ''; $sellerBank = ''; $sellerRs = ''; if ($params["SELLER_COMPANY_BANK_NAME"]) { $sellerBankCity = ''; if ($params["SELLER_COMPANY_BANK_CITY"]) { $sellerBankCity = $params["SELLER_COMPANY_BANK_CITY"]; if (is_array($sellerBankCity)) $sellerBankCity = implode(', ', $sellerBankCity); else $sellerBankCity = str_replace(array("\r\n", "\n", "\r"), ', ', strval($sellerBankCity)); } $sellerBank = sprintf( "%s %s", $params["SELLER_COMPANY_BANK_NAME"], $sellerBankCity ); $sellerRs = $params["SELLER_COMPANY_BANK_ACCOUNT"]; } else { $rsPattern = '/\s*\d{10,100}\s*/'; $sellerBank = trim(preg_replace($rsPattern, ' ', $params["SELLER_COMPANY_BANK_ACCOUNT"])); preg_match($rsPattern, $params["SELLER_COMPANY_BANK_ACCOUNT"], $matches); $sellerRs = trim($matches[0]); } if (!empty($sellerRs)) { $sellerRsPrefix = Loc::getMessage('SALE_HPS_BILLBY_SELLER_ACC_ABBR'); if (!empty($sellerRsPrefix)) $sellerRs = $sellerRsPrefix.' '.$sellerRs; unset($sellerRsPrefix); $sellerInfoBank .= $sellerRs; } unset($sellerRs); if (!empty($sellerBank)) { if (!empty($sellerInfoBank)) $sellerInfoBank .= ', '; $sellerInfoBank .= $sellerBank; } unset($sellerBank); if (!empty($params['SELLER_COMPANY_BANK_BIC'])) { if (!empty($sellerInfoBank)) $sellerInfoBank .= ', '; $sellerInfoBank .= Loc::getMessage('SALE_HPS_BILLBY_SELLER_BANK_BIK').' '.$params['SELLER_COMPANY_BANK_BIC']; } if (!empty($sellerInfoBank)) $sellerInfoRows[] = $sellerInfoBank; unset($sellerInfoBank); $sellerInfoAddr = ''; if ($params['SELLER_COMPANY_ADDRESS']) { $sellerAddr = $params['SELLER_COMPANY_ADDRESS']; if (is_array($sellerAddr)) $sellerAddr = implode(', ', $sellerAddr); else $sellerAddr = str_replace(array("\r\n", "\n", "\r"), ', ', strval($sellerAddr)); if (!empty($sellerAddr)) $sellerInfoAddr .= Loc::getMessage('SALE_HPS_BILLBY_ADDR_TITLE').': '.$sellerAddr; } if ($params["SELLER_COMPANY_PHONE"]) { if (!empty($sellerInfoAddr)) $sellerInfoAddr .= ', '; $phoneTitle = Loc::getMessage('SALE_HPS_BILLBY_PHONE_TITLE'); if (!empty($phoneTitle)) $sellerInfoAddr .= $phoneTitle.' '; $sellerInfoAddr .= $params["SELLER_COMPANY_PHONE"]; } if (!empty($sellerInfoAddr)) $sellerInfoRows[] = $sellerInfoAddr; unset($sellerInfoAddr); if (!empty($sellerInfoRows)) $sellerInfo = implode('<br>', $sellerInfoRows); unset($sellerInfoRows); // endregion Seller info ?> <table class="header"> <tr> <td><?= $sellerInfo ?></td> <? if ($params["BILLBY_PATH_TO_LOGO"]) { ?> <td style="padding-left: 5pt; padding-bottom: 5pt; "> <? $imgParams = CFile::_GetImgParams($params['BILLBY_PATH_TO_LOGO']); $dpi = intval($params['BILLBY_LOGO_DPI']) ?: 96; $imgWidth = $imgParams['WIDTH'] * 96 / $dpi; if ($imgWidth > $pageWidth) $imgWidth = $pageWidth * 0.6; ?> <img src="<?=$imgParams['SRC']; ?>" width="<?=$imgWidth; ?>" /> </td> <? } ?> </tr> </table> <?endif;?> <br> <br> <table width="100%"> <colgroup> <col width="50%"> <col width="0"> <col width="50%"> </colgroup> <?if ($params['BILLBY_HEADER']):?> <? $dateValue = $params["PAYMENT_DATE_INSERT"]; if ($dateValue instanceof \Bitrix\Main\Type\Date || $dateValue instanceof \Bitrix\Main\Type\DateTime) { $dateValue = ToLower(FormatDate('d F Y', $dateValue->getTimestamp())); $yearPostfix = Loc::getMessage('SALE_HPS_BILLBY_YEAR_POSTFIX'); if (!empty($yearPostfix)) $dateValue .= $yearPostfix; unset($yearPostfix); } else if (is_string($dateValue)) { $timeStampValue = MakeTimeStamp($dateValue); if ($timeStampValue !== false) $dateValue = ToLower(FormatDate('d F Y', $timeStampValue)); unset($timeStampValue); } ?> <tr> <td></td> <td style="font-size: 1.6em; font-weight: bold; text-align: center"> <nobr><?=$params['BILLBY_HEADER'];?> <?=Loc::getMessage('SALE_HPS_BILLBY_SELLER_TITLE', array('#PAYMENT_NUM#' => $params["ACCOUNT_NUMBER"], '#PAYMENT_DATE#' => $dateValue));?> </nobr> </td> <td></td> </tr> <?endif;?> <? if ($params["BILLBY_ORDER_SUBJECT"]) { ?> <tr> <td></td> <td><?=$params["BILLBY_ORDER_SUBJECT"]; ?></td> <td></td> </tr> <? } ?> <? if ($params["PAYMENT_DATE_PAY_BEFORE"]) { ?> <tr> <td></td> <td> <?=Loc::getMessage('SALE_HPS_BILLBY_SELLER_DATE_END', array('#PAYMENT_DATE_END#' => ConvertDateTime($params["PAYMENT_DATE_PAY_BEFORE"], FORMAT_DATE) ?: $params["PAYMENT_DATE_PAY_BEFORE"]));?> </td> <td></td> </tr> <? } ?> </table> <br> <? if ($params['BILLBY_PAYER_SHOW'] == 'Y') { $buyerInfo = ''; $buyerInfoRows = array(); if ($params['BUYER_PERSON_COMPANY_DOGOVOR']) { $buyerInfoRows[] = Loc::getMessage('SALE_HPS_BILLBY_BUYER_DOGOVOR').': '.$params['BUYER_PERSON_COMPANY_DOGOVOR'].'<br>'; } $buyerInfoName = Loc::getMessage('SALE_HPS_BILLBY_BUYER_TITLE').':'; if ($params["BUYER_PERSON_COMPANY_NAME"]) { if (!empty($buyerInfoName)) $buyerInfoName .= ' '; $buyerInfoName .= $params["BUYER_PERSON_COMPANY_NAME"]; } if (!empty($buyerInfoName)) $buyerInfoRows[] = $buyerInfoName; unset($buyerInfoName); $buyerInfoTaxId = ''; if ($params['BUYER_PERSON_COMPANY_INN']) { $buyerInfoTaxId .= Loc::getMessage('SALE_HPS_BILLBY_INN').': '.$params['BUYER_PERSON_COMPANY_INN']; if (!empty($buyerInfoTaxId)) $buyerInfoRows[] = $buyerInfoTaxId; } unset($buyerInfoTaxId); $buyerInfoBank = ''; $buyerBank = ''; $buyerRs = ''; if ($params["BUYER_PERSON_COMPANY_BANK_NAME"]) { $buyerBankCity = ''; if ($params["BUYER_PERSON_COMPANY_BANK_CITY"]) { $buyerBankCity = $params["BUYER_PERSON_COMPANY_BANK_CITY"]; if (is_array($buyerBankCity)) $buyerBankCity = implode(', ', $buyerBankCity); else $buyerBankCity = str_replace(array("\r\n", "\n", "\r"), ', ', strval($buyerBankCity)); } $buyerBank = sprintf( "%s %s", $params["BUYER_PERSON_COMPANY_BANK_NAME"], $buyerBankCity ); $buyerRs = $params["BUYER_PERSON_COMPANY_BANK_ACCOUNT"]; } else { $rsPattern = '/\s*\d{10,100}\s*/'; $buyerBank = trim(preg_replace($rsPattern, ' ', $params["BUYER_PERSON_COMPANY_BANK_ACCOUNT"])); preg_match($rsPattern, $params["BUYER_PERSON_COMPANY_BANK_ACCOUNT"], $matches); $buyerRs = trim($matches[0]); } if (!empty($buyerRs)) { $buyerRsPrefix = Loc::getMessage('SALE_HPS_BILLBY_SELLER_ACC_ABBR'); if (!empty($buyerRsPrefix)) $buyerRs = $buyerRsPrefix.' '.$buyerRs; unset($buyerRsPrefix); $buyerInfoBank .= $buyerRs; } unset($buyerRs); if (!empty($buyerBank)) { if (!empty($buyerInfoBank)) $buyerInfoBank .= ', '; $buyerInfoBank .= $buyerBank; } unset($buyerBank); if (!empty($params['BUYER_PERSON_COMPANY_BANK_BIC'])) { if (!empty($buyerInfoBank)) $buyerInfoBank .= ', '; $buyerInfoBank .= Loc::getMessage('SALE_HPS_BILLBY_SELLER_BANK_BIK').' '.$params['BUYER_PERSON_COMPANY_BANK_BIC']; } if (!empty($buyerInfoBank)) $buyerInfoRows[] = $buyerInfoBank; unset($buyerInfoBank); $buyerInfoAddr = ''; if ($params['BUYER_PERSON_COMPANY_ADDRESS']) { $buyerAddr = $params['BUYER_PERSON_COMPANY_ADDRESS']; if (is_array($buyerAddr)) $buyerAddr = implode(', ', $buyerAddr); else $buyerAddr = str_replace(array("\r\n", "\n", "\r"), ', ', strval($buyerAddr)); if (!empty($buyerAddr)) $buyerInfoAddr .= Loc::getMessage('SALE_HPS_BILLBY_ADDR_TITLE').': '.$buyerAddr; } if ($params["BUYER_PERSON_COMPANY_PHONE"]) { if (!empty($buyerInfoAddr)) $buyerInfoAddr .= ', '; $phoneTitle = Loc::getMessage('SALE_HPS_BILLBY_PHONE_TITLE'); if (!empty($phoneTitle)) $buyerInfoAddr .= $phoneTitle.' '; $buyerInfoAddr .= $params["BUYER_PERSON_COMPANY_PHONE"]; } if ($params["BUYER_PERSON_COMPANY_FAX"]) { if (!empty($buyerInfoAddr)) $buyerInfoAddr .= ', '; $phoneTitle = Loc::getMessage('SALE_HPS_BILLBY_FAX_TITLE'); if (!empty($phoneTitle)) $buyerInfoAddr .= $phoneTitle.' '; $buyerInfoAddr .= $params["BUYER_PERSON_COMPANY_FAX"]; } if ($params["BUYER_PERSON_COMPANY_NAME_CONTACT"]) { if (!empty($buyerInfoAddr)) $buyerInfoAddr .= ', '; $buyerInfoAddr .= $params["BUYER_PERSON_COMPANY_NAME_CONTACT"]; } if (!empty($buyerInfoAddr)) $buyerInfoRows[] = $buyerInfoAddr; unset($buyerInfoAddr); if (!empty($buyerInfoRows)) { $buyerInfo = implode('<br>', $buyerInfoRows); echo $buyerInfo; } unset($buyerInfoRows); } ?> <br> <br> <? $arCurFormat = CCurrencyLang::GetCurrencyFormat($params['CURRENCY']); $currency = preg_replace('/(^|[^&])#/', '${1}', $arCurFormat['FORMAT_STRING']); // Precision $currencyFormat = CCurrencyLang::GetFormatDescription($params['CURRENCY']); if ($currencyFormat === false) $currencyFormat = CCurrencyLang::GetDefaultValues(); $currencyPrecision = (int)$currencyFormat['DECIMALS']; if ($currencyPrecision <= 0) $currencyPrecision = 2; $salePrecision = (int)Bitrix\Main\Config\Option::get('sale', 'value_precision', 2); if ($salePrecision <= 0) $salePrecision = 2; $salePrecision = min($salePrecision, SALE_VALUE_PRECISION); $precision = min($salePrecision, $currencyPrecision); $cells = array(); $props = array(); $n = 0; $sum = 0.00; $totalSum = 0.00; $totalVatSum = 0.00; $totalSumWithVat = 0.00; $vat = 0; $cntBasketItem = 0; $columnList = array('NUMBER', 'NAME', 'QUANTITY', 'MEASURE', 'PRICE', 'SUM', 'VAT_RATE', 'VAT_SUM', 'TOTAL'); $arCols = array(); $vatRateColumn = 0; foreach ($columnList as $column) { if ($params['BILLBY_COLUMN_'.$column.'_SHOW'] == 'Y') { $caption = $params['BILLBY_COLUMN_'.$column.'_TITLE']; $arCols[$column] = array( 'NAME' => htmlspecialcharsbx($caption), 'SORT' => $params['BILLBY_COLUMN_'.$column.'_SORT'] ); } } if ($params['USER_COLUMNS']) { $columnList = array_merge($columnList, array_keys($params['USER_COLUMNS'])); foreach ($params['USER_COLUMNS'] as $id => $val) { $arCols[$id] = array( 'NAME' => htmlspecialcharsbx($val['NAME']), 'SORT' => $val['SORT'] ); } } uasort($arCols, function ($a, $b) {return ($a['SORT'] < $b['SORT']) ? -1 : 1;}); $arColumnKeys = array_keys($arCols); $columnCount = count($arColumnKeys); foreach ($params['BASKET_ITEMS'] as $basketItem) { $productName = $basketItem["NAME"]; if ($productName == "OrderDelivery") $productName = Loc::getMessage('SALE_HPS_BILLBY_DELIVERY'); else if ($productName == "OrderDiscount") $productName = Loc::getMessage('SALE_HPS_BILLBY_DISCOUNT'); if ($basketItem['IS_VAT_IN_PRICE']) { $basketItemTotal = doubleval($basketItem['PRICE'] * $basketItem['QUANTITY']); if (($basketItem['VAT_RATE'] != 0.0)) { $basketItemSum = $basketItemTotal / (1 + doubleval($basketItem['VAT_RATE'])); $basketItemVatSum = doubleval($basketItemSum * $basketItem['VAT_RATE']); } else { $basketItemSum = $basketItemTotal; $basketItemVatSum = 0.0; } } else { $basketItemSum = doubleval($basketItem['PRICE'] * $basketItem['QUANTITY']); if (($basketItem['VAT_RATE'] != 0.0)) { $basketItemTotal = doubleval($basketItemSum * (1 + doubleval($basketItem['VAT_RATE']))); $basketItemVatSum = doubleval($basketItemSum * doubleval($basketItem['VAT_RATE'])); } else { $basketItemTotal = $basketItemSum; $basketItemVatSum = 0.0; } } $cells[++$n] = array(); foreach ($arCols as $columnId => $col) { $data = null; switch ($columnId) { case 'NUMBER': $data = $n; break; case 'NAME': $data = htmlspecialcharsbx($productName); break; case 'QUANTITY': $data = roundEx($basketItem['QUANTITY'], SALE_VALUE_PRECISION); break; case 'MEASURE': $data = $basketItem["MEASURE_NAME"] ? htmlspecialcharsbx($basketItem["MEASURE_NAME"]) : Loc::getMessage('SALE_HPS_BILLBY_BASKET_MEASURE_DEFAULT'); break; case 'PRICE': $data = SaleFormatCurrency($basketItem['PRICE'], $basketItem['CURRENCY'], true); break; case 'SUM': $data = SaleFormatCurrency($basketItemSum, $basketItem['CURRENCY'], true); break; case 'VAT_RATE': if ($basketItem['VAT_RATE'] == 0.0) $data = htmlspecialcharsbx(Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT_RATE_NO')); else $data = roundEx($basketItem['VAT_RATE'] * 100, $precision)."%"; break; case 'VAT_SUM': if ($basketItem['VAT_RATE'] == 0.0) $data = htmlspecialcharsbx(Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT_SUM_NO')); else $data = SaleFormatCurrency($basketItemVatSum, $basketItem['CURRENCY'], true); break; case 'TOTAL': $data = SaleFormatCurrency($basketItemTotal, $basketItem['CURRENCY'], true); break; default : $data = ($basketItem[$columnId]) ?: ''; } if ($data !== null) $cells[$n][$columnId] = $data; } $props[$n] = array(); if ($basketItem['PROPS']) { foreach ($basketItem['PROPS'] as $basketPropertyItem) { if ($basketPropertyItem['CODE'] == 'CATALOG.XML_ID' || $basketPropertyItem['CODE'] == 'PRODUCT.XML_ID') continue; $props[$n][] = htmlspecialcharsbx(sprintf("%s: %s", $basketPropertyItem["NAME"], $basketPropertyItem["VALUE"])); } } $sum += roundEx(doubleval($basketItem['PRICE'] * $basketItem['QUANTITY']), $precision); $vat = max($vat, $basketItem['VAT_RATE']); $totalSum += roundEx($basketItemSum, $precision); $totalVatSum += roundEx($basketItemVatSum, $precision); $totalSumWithVat += roundEx($basketItemTotal, $precision); } if ($params['DELIVERY_PRICE'] > 0) { $deliveryItem = Loc::getMessage('SALE_HPS_BILLBY_DELIVERY'); if ($params['DELIVERY_NAME']) $deliveryItem .= sprintf(" (%s)", $params['DELIVERY_NAME']); $basketItemTotal = $params['DELIVERY_PRICE']; if (($vat != 0.0)) { $basketItemSum = $basketItemTotal / (1 + doubleval($vat)); $basketItemVatSum = doubleval($basketItemSum * $vat); } else { $basketItemSum = $basketItemTotal; $basketItemVatSum = 0.0; } $cells[++$n] = array(); foreach ($arCols as $columnId => $caption) { $data = null; switch ($columnId) { case 'NUMBER': $data = $n; break; case 'NAME': $data = htmlspecialcharsbx($deliveryItem); break; case 'QUANTITY': $data = 1; break; case 'MEASURE': $data = ''; break; case 'PRICE': $data = SaleFormatCurrency($params['DELIVERY_PRICE'], $params['CURRENCY'], true); break; case 'SUM': $data = SaleFormatCurrency($basketItemSum, $params['CURRENCY'], true); break; case 'VAT_RATE': if ($vat == 0.0) $data = htmlspecialcharsbx(Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT_RATE_NO')); else $data = roundEx($vat * 100, $precision)."%"; break; case 'VAT_SUM': if ($vat == 0.0) $data = htmlspecialcharsbx(Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT_SUM_NO')); else $data = SaleFormatCurrency($basketItemVatSum, $params['CURRENCY'], true); break; case 'TOTAL': $data = SaleFormatCurrency($basketItemTotal, $params['CURRENCY'], true); break; } if ($data !== null) $cells[$n][$columnId] = $data; } $sum += roundEx(doubleval($params['DELIVERY_PRICE']), $precision); $totalSum += roundEx($basketItemSum, $precision); $totalVatSum += roundEx($basketItemVatSum, $precision); $totalSumWithVat += roundEx($basketItemTotal, $precision); } $totalRowIsLast = false; $totalRowIndex = -1; if ($params['BILLBY_TOTAL_SHOW'] == 'Y') { $totalRowValues = array(); foreach ($arColumnKeys as $colNum => $colCode) { $skip = false; $value = null; switch ($colCode) { case 'SUM': $value = SaleFormatCurrency($totalSum, $params['CURRENCY'], true); break; case 'VAT_RATE': $value = Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT_RATE_X'); break; case 'VAT_SUM': if ($totalVatSum == 0.0) $value = htmlspecialcharsbx(Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT_SUM_NO')); else $value = SaleFormatCurrency($totalVatSum, $params['CURRENCY'], true); break; case 'TOTAL': $value = SaleFormatCurrency($totalSumWithVat, $params['CURRENCY'], true); break; default: $skip = true; } if (!$skip) $totalRowValues[$colNum] = $value; } unset($skip, $value); $totalTitleColIndex = (empty($totalRowValues) ? 0 : (int)min(array_keys($totalRowValues))) - 1; if ($totalTitleColIndex >= 0) $totalRowValues[$totalTitleColIndex] = Loc::getMessage('SALE_HPS_BILLBY_TOTAL_SUM'); if (!empty($totalRowValues)) { $cells[++$n] = array(); for ($i = 0; $i < $columnCount; $i++) $cells[$n][$arColumnKeys[$i]] = isset($totalRowValues[$i]) ? $totalRowValues[$i] : null; $totalRowIndex = $n; } unset($totalRowValues); $totalRowIsLast = true; $cntBasketItem = $n; if ($params['TAXES']) { foreach ($params['TAXES'] as $tax) { if (isset($tax['CODE']) && $tax['CODE'] !== 'VAT') { $totalRowIsLast = false; $cells[++$n] = array(); for ($i = 0; $i < $columnCount; $i++) $cells[$n][$arColumnKeys[$i]] = null; $cells[$n][$arColumnKeys[$columnCount-2]] = htmlspecialcharsbx(sprintf( "%s%s%s:", ($tax["IS_IN_PRICE"] == "Y") ? Loc::getMessage('SALE_HPS_BILLBY_INCLUDING') : "", $tax["TAX_NAME"], ($vat <= 0 && $tax["IS_PERCENT"] == "Y") ? sprintf(' (%s%%)', roundEx($tax["VALUE"], $precision)) : "" )); $cells[$n][$arColumnKeys[$columnCount-1]] = SaleFormatCurrency($tax["VALUE_MONEY"], $params['CURRENCY'], true); } } } if ($params['SUM_PAID'] > 0) { $totalRowIsLast = false; $cells[++$n] = array(); for ($i = 0; $i < $columnCount; $i++) $cells[$n][$arColumnKeys[$i]] = null; $cells[$n][$arColumnKeys[$columnCount-2]] = Loc::getMessage('SALE_HPS_BILLBY_TOTAL_PAID'); $cells[$n][$arColumnKeys[$columnCount-1]] = SaleFormatCurrency($params['SUM_PAID'], $params['CURRENCY'], true); } if ($params['DISCOUNT_PRICE'] > 0) { $totalRowIsLast = false; $cells[++$n] = array(); for ($i = 0; $i < $columnCount; $i++) $cells[$n][$arColumnKeys[$i]] = null; $cells[$n][$arColumnKeys[$columnCount-2]] = Loc::getMessage('SALE_HPS_BILLBY_TOTAL_DISCOUNT'); $cells[$n][$arColumnKeys[$columnCount-1]] = SaleFormatCurrency($params['DISCOUNT_PRICE'], $params['CURRENCY'], true); } if (!$totalRowIsLast) { $cells[$totalRowIndex][$arColumnKeys[$totalTitleColIndex]] = Loc::getMessage('SALE_HPS_BILLBY_SUBTOTAL'); $cells[++$n] = array(); for ($i = 0; $i < $columnCount; $i++) $cells[$n][$arColumnKeys[$i]] = null; $cells[$n][$arColumnKeys[$columnCount-2]] = Loc::getMessage('SALE_HPS_BILLBY_TOTAL_SUM'); $cells[$n][$arColumnKeys[$columnCount-1]] = SaleFormatCurrency($params['SUM'], $params['CURRENCY'], true); } } ?> <table class="it" width="100%"> <tr> <?foreach ($arCols as $columnId => $col):?> <td><?=$col['NAME'];?></td> <?endforeach;?> </tr> <? $rowsCnt = count($cells); for ($n = 1; $n <= $rowsCnt; $n++): $accumulated = 0; ?> <tr valign="top"<?=(($totalRowIsLast && $n === $totalRowIndex) ? ' style="font-weight: bold;"' : '')?>> <?foreach ($arCols as $columnId => $col):?> <? if (!is_null($cells[$n][$columnId])) { if ($columnId === 'NUMBER') {?> <td align="center"><?=$cells[$n][$columnId];?></td> <?} elseif ($columnId === 'NAME') { ?> <td align="<?=($n > $cntBasketItem) ? 'right' : 'left';?>" style="word-break: break-word; word-wrap: break-word; <? if ($accumulated) {?>border-width: 0 1pt 0 0; <? } ?>" <? if ($accumulated) { ?>colspan="<?=($accumulated+1); ?>"<? $accumulated = 0; } ?>> <?=$cells[$n][$columnId]; ?> <? if (isset($props[$n]) && is_array($props[$n])) { ?> <? foreach ($props[$n] as $property) { ?> <br> <small><?=$property; ?></small> <? } ?> <? } ?> </td> <? } else { ?> <td align="right" <? if ($accumulated) { ?> style="border-width: 0 1pt 0 0" colspan="<? echo $accumulated+1; ?>" <? $accumulated = 0; } ?>> <?if ($columnId == 'PRICE' || $columnId == 'SUM' || $columnId == 'VAT_RATE' || $columnId == 'VAT_SUM' || $columnId == 'TOTAL'):?> <nobr><?=$cells[$n][$columnId];?></nobr> <?else:?> <?=$cells[$n][$columnId]; ?> <?endif;?> </td> <? } } else { $accumulated++; } ?> <?endforeach;?> </tr> <?endfor;?> </table> <? if ($params['BILLBY_TOTAL_SHOW'] == 'Y'): ?> <div style="margin-top: 5pt; font-weight: bold; word-break: break-word; word-wrap: break-word;"><? $inWords = in_array($params['CURRENCY'], array("RUR", "RUB", "UAH", "KZT", "BYR", "BYN")); echo Loc::getMessage('SALE_HPS_BILLBY_TOTAL_VAT').': '; if ($inWords) echo Number2Word_Rus(roundEx($totalVatSum, $precision), "Y", $params['CURRENCY']); else echo SaleFormatCurrency(roundEx($totalVatSum, $precision), $params['CURRENCY'], false); unset($totalVatSum); ?><br><br><? echo Loc::getMessage('SALE_HPS_BILLBY_TOTAL_SUM_WITH_VAT').': '; if ($inWords) echo Number2Word_Rus($totalSumWithVat, "Y", $params['CURRENCY']); else echo SaleFormatCurrency($totalSumWithVat, $params['CURRENCY'], false); unset($inWords); ?></div> <? endif; ?> <br> <br> <? if ($params["BILLBY_COMMENT1"] || $params["BILLBY_COMMENT2"]) { ?> <br> <? if ($params["BILLBY_COMMENT1"]) { ?> <?=nl2br(HTMLToTxt(preg_replace( array('#</div>\s*<div[^>]*>#i', '#</?div>#i'), array('<br>', '<br>'), htmlspecialcharsback($params["BILLBY_COMMENT1"]) ), '', array(), 0)); ?> <br> <br> <? } ?> <? if ($params["BILLBY_COMMENT2"]) { ?> <?=nl2br(HTMLToTxt(preg_replace( array('#</div>\s*<div[^>]*>#i', '#</?div>#i'), array('<br>', '<br>'), htmlspecialcharsback($params["BILLBY_COMMENT2"]) ), '', array(), 0)); ?> <br> <br> <? } ?> <? } ?> <br> <br> <?if ($params['BILLBY_SIGN_SHOW'] == 'Y'):?> <? if (!$blank) { ?> <div style="position: relative; "><?=CFile::ShowImage( $params["BILLBY_PATH_TO_STAMP"], 160, 160, 'style="position: absolute; left: 40pt; "' ); ?></div> <? } ?> <div style="position: relative"> <table class="sign"> <? if ($params["SELLER_COMPANY_DIRECTOR_POSITION"]) { ?> <tr> <td style="width: 150pt; font-weight: bold;"><?= $params["SELLER_COMPANY_DIRECTOR_POSITION"] ?></td> <td style="width: 160pt; border-bottom: 1pt solid #000000; text-align: center; "> <? if (!$blank) { ?> <?=CFile::ShowImage($params["SELLER_COMPANY_DIR_SIGN"], 200, 50); ?> <? } ?> </td> <td> <? if ($params["SELLER_COMPANY_DIRECTOR_NAME"]) { ?> (<?=$params["SELLER_COMPANY_DIRECTOR_NAME"]; ?>) <? } ?> </td> </tr> <tr><td colspan="3"> </td></tr> <? } ?> <? if ($params["SELLER_COMPANY_ACCOUNTANT_POSITION"]) { ?> <tr> <td style="width: 150pt; font-weight: bold;"><?= $params["SELLER_COMPANY_ACCOUNTANT_POSITION"] ?></td> <td style="width: 160pt; border-bottom: 1pt solid #000000; text-align: center; "> <? if (!$blank) { ?> <?=CFile::ShowImage($params["SELLER_COMPANY_ACC_SIGN"], 200, 50); ?> <? } ?> </td> <td> <? if ($params["SELLER_COMPANY_ACCOUNTANT_NAME"]) { ?> (<?=$params["SELLER_COMPANY_ACCOUNTANT_NAME"]; ?>) <? } ?> </td> </tr> <? } ?> </table> </div> <?endif;?> </div> </body> </html>