diff --git a/.phive/phars.xml b/.phive/phars.xml index 5bfa092bfad10dad9d23240281a5a2041acb815b..cccdab55e6792f5161b502854bef53c1667a4add 100644 --- a/.phive/phars.xml +++ b/.phive/phars.xml @@ -1,6 +1,6 @@ <?xml version="1.0" encoding="UTF-8"?> <phive xmlns="https://phar.io/phive"> - <phar name="phpstan" version="1.11.8" installed="1.11.8" location="./tools/phpstan" copy="false"/> + <phar name="phpstan" version="1.*" installed="1.12.13" location="./tools/phpstan" copy="false"/> <phar name="phpunit" version="^10.5.20" installed="10.5.20" location="./tools/phpunit" copy="false"/> <phar name="phpcs" version="^3.10.1" installed="3.10.1" location="./tools/phpcs" copy="false"/> <phar name="phpcbf" version="^3.10.1" installed="3.10.1" location="./tools/phpcbf" copy="false"/> diff --git a/phpstan-baseline.neon b/phpstan-baseline.neon index 2f8fdeb646618252a4ab8099991d71bec9926215..3fdf065df0dcf143e0a8527c1d4ffa6fd0565faa 100644 --- a/phpstan-baseline.neon +++ b/phpstan-baseline.neon @@ -1,25 +1,10 @@ parameters: ignoreErrors: - - - message: "#^Parameter \\#6 \\$User of static method QUI\\\\ERP\\\\Accounting\\\\Payments\\\\Transactions\\\\Factory\\:\\:createPaymentTransaction\\(\\) expects null, QUI\\\\Interfaces\\\\Users\\\\User given\\.$#" - count: 1 - path: ajax/invoices/addPayment.php - - message: "#^Call to static method getInstance\\(\\) on an unknown class QUI\\\\ERP\\\\Order\\\\Handler\\.$#" count: 1 path: src/QUI/ERP/Accounting/Invoice/EventHandler.php - - - message: "#^PHPDoc tag @throws has invalid value \\(\\)\\: Unexpected token \"\\\\n \", expected type at offset 212$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Factory.php - - - - message: "#^Class QUI\\\\Database\\\\Exception referenced with incorrect case\\: QUI\\\\DataBase\\\\Exception\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Invoice.php - - message: "#^Method QUI\\\\ERP\\\\Accounting\\\\Invoice\\\\Invoice\\:\\:getShipping\\(\\) has invalid return type QUI\\\\ERP\\\\Shipping\\\\Types\\\\ShippingUnique\\.$#" count: 2 @@ -30,21 +15,6 @@ parameters: count: 2 path: src/QUI/ERP/Accounting/Invoice/Invoice.php - - - message: "#^PHPDoc tag @param references unknown parameter\\: \\$globalProcessId$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Invoice.php - - - - message: "#^PHPDoc tag @throws has invalid value \\(\\)\\: Unexpected token \"\\\\n \", expected type at offset 174$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Invoice.php - - - - message: "#^PHPDoc tag @throws has invalid value \\(\\)\\: Unexpected token \"\\\\n \", expected type at offset 86$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Invoice.php - - message: "#^Property QUI\\\\ERP\\\\Accounting\\\\Invoice\\\\Invoice\\:\\:\\$Shipping \\(QUI\\\\ERP\\\\Shipping\\\\Api\\\\ShippingInterface\\|null\\) does not accept QUI\\\\ERP\\\\Shipping\\\\Types\\\\ShippingUnique\\.$#" count: 2 @@ -80,87 +50,17 @@ parameters: count: 2 path: src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php - - - message: "#^PHPDoc tag @throws has invalid value \\(\\)\\: Unexpected token \"\\\\n \", expected type at offset 86$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php - - message: "#^Parameter \\$Shipping of method QUI\\\\ERP\\\\Accounting\\\\Invoice\\\\InvoiceTemporary\\:\\:setShipping\\(\\) has invalid type QUI\\\\ERP\\\\Shipping\\\\Api\\\\ShippingInterface\\.$#" count: 2 path: src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php - - - message: "#^Else branch is unreachable because previous condition is always true\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/InvoiceView.php - - - - message: "#^Unreachable statement \\- code above always terminates\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/InvoiceView.php - - - - message: "#^Call to an undefined method QUI\\\\ERP\\\\Accounting\\\\ArticleListUnique\\:\\:setUser\\(\\)\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php - - - - message: "#^Call to an undefined method QUI\\\\ERP\\\\Accounting\\\\ArticleListUnique\\:\\:toUniqueList\\(\\)\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php - - message: "#^Call to static method getInstance\\(\\) on an unknown class QUI\\\\ERP\\\\Order\\\\Handler\\.$#" count: 1 path: src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php - - - message: "#^Parameter \\#2 \\$key of method QUI\\\\Config\\:\\:setValue\\(\\) expects string\\|null, int given\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Factory.php - - - - message: "#^Parameter \\#2 \\$key of method QUI\\\\Config\\:\\:del\\(\\) expects string\\|null, int given\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Handler.php - - - - message: "#^Parameter \\#2 \\$key of method QUI\\\\Config\\:\\:setValue\\(\\) expects string\\|null, int given\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Handler.php - - message: "#^Call to static method getInstance\\(\\) on an unknown class QUI\\\\ERP\\\\Order\\\\Handler\\.$#" count: 1 path: src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php - - - - message: "#^Expression on left side of \\?\\? is not nullable\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php - - - - message: "#^Parameter \\#1 \\$haystack of function str_starts_with expects string, int given\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php - - - - message: "#^Parameter \\#1 \\$string of function strlen expects string, int given\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php - - - - message: "#^Parameter \\#1 \\$string of function substr_replace expects array\\|string, int given\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php - - - - message: "#^Result of && is always false\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Utils/Invoice.php - - - - message: "#^Result of \\|\\| is always true\\.$#" - count: 1 - path: src/QUI/ERP/Accounting/Invoice/Utils/Invoice.php diff --git a/src/QUI/ERP/Accounting/Invoice/Factory.php b/src/QUI/ERP/Accounting/Invoice/Factory.php index 0fbc282b65b7404c641ece2416767c77a833ea65..336682bc83eb88ad93a4e451d3fbe1d8a2214096 100644 --- a/src/QUI/ERP/Accounting/Invoice/Factory.php +++ b/src/QUI/ERP/Accounting/Invoice/Factory.php @@ -7,6 +7,7 @@ namespace QUI\ERP\Accounting\Invoice; use QUI; +use QUI\Database\Exception; use function json_encode; @@ -23,14 +24,13 @@ class Factory extends QUI\Utils\Singleton /** * Creates a new temporary invoice * - * @param QUI\Interfaces\Users\User|null $User - * @param bool|string $globalProcessId - hash of the process - * @return InvoiceTemporary - * @throws + * @throws QUI\Exception + * @throws QUI\Lock\Exception + * @throws Exception */ public function createInvoice( - QUI\Interfaces\Users\User $User = null, - bool|string $globalProcessId = false + null | QUI\Interfaces\Users\User $User = null, + bool | string $globalProcessId = false ): InvoiceTemporary { if ($User === null) { $User = QUI::getUserBySession(); diff --git a/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.css b/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.css index 22c1df142886f6321f111610d21c9042d7b9eaef..42e91d870606af09ab9b5498e9093429029af91d 100644 --- a/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.css +++ b/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.css @@ -1,24 +1,18 @@ -.quiqqer-invoice-profile-invoices { - float: left; +:where(.quiqqer-invoice-profile-invoices-table) { width: 100%; } -.quiqqer-invoice-profile-invoices-table { - float: left; - width: 100%; -} - -.quiqqer-invoice-profile-invoices-table th { +:where(.quiqqer-invoice-profile-invoices-table th) { padding: 5px; text-align: left; } -.quiqqer-invoice-profile-invoices-table td { +:where(.quiqqer-invoice-profile-invoices-table td) { padding: 5px; } -.quiqqer-invoice-profile-invoices-table th:last-child, -.quiqqer-invoice-profile-invoices-table td:last-child { +.quiqqer-invoice-profile-invoices-table-th-invoice-dl, +.quiqqer-invoice-profile-invoices-table-invoice-dl { text-align: center; width: 100px; } @@ -27,6 +21,6 @@ width: 140px; } -.quiqqer-invoice-profile-invoices-table tbody tr:nth-child(odd) { +:where(.quiqqer-invoice-profile-invoices-table tbody tr:nth-child(even)) { background: #f8f8f8; } \ No newline at end of file diff --git a/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.html b/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.html index 07a7c79d293017900c01021c00d02c5404f26504..2d8173f11c53ad68270eab907497d3c6bddcc8d8 100644 --- a/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.html +++ b/src/QUI/ERP/Accounting/Invoice/FrontendUsers/UserInvoices.html @@ -1,46 +1,48 @@ -<h1> - {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.title"} -</h1> +<section class="quiqqer-frontendUsers-profile-section quiqqer-frontendUsers-section--userInvoices"> + <h2> + {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.title"} + </h2> -<table class="quiqqer-invoice-profile-invoices-table"> - {if count($invoices)} - <thead> - <tr> - <th> - {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.id"} - </th> - <th> - {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.date"} - </th> - <th> - {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.download"} - </th> - </tr> - </thead> - {/if} - <tbody> - {foreach $invoices as $Invoice} - <tr class="quiqqer-invoice-profile-invoices-table-invoice"> - <td class="quiqqer-invoice-profile-invoices-table-invoice-id"> - {$Invoice->getId()} - </td> - <td class="quiqqer-invoice-profile-invoices-table-invoice-date"> - {$Invoice->getDate()} - </td> - <td class="quiqqer-invoice-profile-invoices-table-invoice-dl"> - <a href="{$Invoice->getDownloadLink()}" target="_blank"> - <span class="fa fa-file-pdf-o fa-file-pdf"></span> - </a> - </td> - </tr> - {foreachelse} - <tr> - <td colspan="3"> - <div class="invoice-message-empty-invoices"> - {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.empty.message"} - </div> - </td> - </tr> - {/foreach} - </tbody> -</table> + <table class="quiqqer-invoice-profile-invoices-table"> + {if count($invoices)} + <thead> + <tr> + <th> + {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.id"} + </th> + <th> + {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.date"} + </th> + <th class="quiqqer-invoice-profile-invoices-table-th-invoice-dl"> + {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.download"} + </th> + </tr> + </thead> + {/if} + <tbody> + {foreach $invoices as $Invoice} + <tr class="quiqqer-invoice-profile-invoices-table-invoice"> + <td class="quiqqer-invoice-profile-invoices-table-invoice-id"> + {$Invoice->getId()} + </td> + <td class="quiqqer-invoice-profile-invoices-table-invoice-date"> + {$Invoice->getDate()} + </td> + <td class="quiqqer-invoice-profile-invoices-table-invoice-dl"> + <a href="{$Invoice->getDownloadLink()}" target="_blank"> + <span class="fa fa-file-pdf-o fa-file-pdf"></span> + </a> + </td> + </tr> + {foreachelse} + <tr> + <td colspan="3"> + <div class="invoice-message-empty-invoices"> + {locale group="quiqqer/invoice" var="control.frontendUsers.invoices.table.empty.message"} + </div> + </td> + </tr> + {/foreach} + </tbody> + </table> +</section> \ No newline at end of file diff --git a/src/QUI/ERP/Accounting/Invoice/Handler.php b/src/QUI/ERP/Accounting/Invoice/Handler.php index 06e4281374c7ed172db5cbc64db4c8b4fb3b8d5c..f4c008469e531208b3e4a5f23105aed7007b7882 100644 --- a/src/QUI/ERP/Accounting/Invoice/Handler.php +++ b/src/QUI/ERP/Accounting/Invoice/Handler.php @@ -97,7 +97,7 @@ public function getInvoicesByUser(QUI\Users\User $User): array * @throws QUI\Lock\Exception * @throws QUI\Exception */ - public function delete(string|int $invoiceId, QUI\Interfaces\Users\User $User = null): void + public function delete(string | int $invoiceId, null | QUI\Interfaces\Users\User $User = null): void { $Invoice = QUI\ERP\Accounting\Invoice\Utils\Invoice::getInvoiceByString($invoiceId); @@ -269,7 +269,7 @@ public function countTemporaryInvoices(array $queryParams = []): int * * @throws QUI\Exception */ - public function get(int|string $id): Invoice|InvoiceTemporary + public function get(int | string $id): Invoice | InvoiceTemporary { try { return $this->getInvoice($id); @@ -288,7 +288,7 @@ public function get(int|string $id): Invoice|InvoiceTemporary * @throws Exception * @throws QUI\Exception */ - public function getInvoice(int|string $id): Invoice + public function getInvoice(int | string $id): Invoice { return new Invoice($id, $this); } @@ -302,7 +302,7 @@ public function getInvoice(int|string $id): Invoice * @throws Exception * @throws QUI\Exception */ - public function getInvoiceByHash(string $hash): Invoice|InvoiceTemporary + public function getInvoiceByHash(string $hash): Invoice | InvoiceTemporary { $hash = QUI\Utils\Security\Orthos::clear($hash); @@ -347,7 +347,7 @@ public function getInvoiceByHash(string $hash): Invoice|InvoiceTemporary * @throws Exception * @throws QUI\Exception */ - public function getInvoiceData(int|string $id): array + public function getInvoiceData(int | string $id): array { // check invoice via hash $result = QUI::getDataBase()->fetch([ @@ -434,7 +434,7 @@ public function temporaryInvoiceTable(): string * @throws Exception * @throws QUI\Exception */ - public function getTemporaryInvoice(int|string $id): InvoiceTemporary + public function getTemporaryInvoice(int | string $id): InvoiceTemporary { return new InvoiceTemporary($id, $this); } @@ -480,7 +480,7 @@ public function getTemporaryInvoiceByHash(string $hash): InvoiceTemporary * @throws Exception * @throws QUI\Exception */ - public function getTemporaryInvoiceData(int|string $id): array + public function getTemporaryInvoiceData(int | string $id): array { $result = QUI::getDataBase()->fetch([ 'from' => self::temporaryInvoiceTable(), diff --git a/src/QUI/ERP/Accounting/Invoice/Invoice.php b/src/QUI/ERP/Accounting/Invoice/Invoice.php index 4c673dd859bd4476a32f44bd09c95dc75e227aed..13269f58d6121a71a82d512febe321b5325b04f9 100644 --- a/src/QUI/ERP/Accounting/Invoice/Invoice.php +++ b/src/QUI/ERP/Accounting/Invoice/Invoice.php @@ -101,7 +101,7 @@ class Invoice extends QUI\QDOM implements ErpEntityInterface, ErpTransactionsInt /** * @var null|ShippingInterface */ - protected ShippingInterface|null $Shipping = null; + protected ShippingInterface | null $Shipping = null; /** * Invoice constructor. @@ -430,8 +430,8 @@ public function getEditor(): QUI\ERP\User * - How many must be paid * * @return array - * - * @throws + * @throws Exception + * @throws QUI\Exception */ public function getPaidStatusInformation(): array { @@ -549,7 +549,7 @@ public function getPayment(): Payment * * @return int|QUI\ERP\Shipping\Types\ShippingUnique|null */ - public function getShipping(): int|QUI\ERP\Shipping\Types\ShippingUnique|null + public function getShipping(): int | QUI\ERP\Shipping\Types\ShippingUnique | null { return $this->Shipping; } @@ -583,7 +583,7 @@ public function getInvoiceType(): int */ public function reversal( string $reason = '', - QUI\Interfaces\Users\User $PermissionUser = null + null | QUI\Interfaces\Users\User $PermissionUser = null ): ?QUI\ERP\ErpEntityInterface { // is canceled / reversal possible? if (!Settings::getInstance()->get('invoice', 'storno')) { @@ -743,7 +743,7 @@ public function reversal( * @throws QUI\Exception * @throws QUI\Permissions\Exception */ - public function cancellation(string $reason, QUI\Interfaces\Users\User $PermissionUser = null): int|string + public function cancellation(string $reason, null | QUI\Interfaces\Users\User $PermissionUser = null): int | string { return $this->reversal($reason, $PermissionUser)->getUUID(); } @@ -759,7 +759,7 @@ public function cancellation(string $reason, QUI\Interfaces\Users\User $Permissi * @throws QUI\Exception * @throws QUI\Permissions\Exception */ - public function storno(string $reason, QUI\Interfaces\Users\User $PermissionUser = null): int|string + public function storno(string $reason, null | QUI\Interfaces\Users\User $PermissionUser = null): int | string { return $this->reversal($reason, $PermissionUser)->getUUID(); } @@ -776,8 +776,8 @@ public function storno(string $reason, QUI\Interfaces\Users\User $PermissionUser * @throws QUI\Permissions\Exception */ public function copy( - QUI\Interfaces\Users\User $PermissionUser = null, - bool|string $globalProcessId = false + null | QUI\Interfaces\Users\User $PermissionUser = null, + bool | string $globalProcessId = false ): InvoiceTemporary { if ($PermissionUser === null) { $PermissionUser = QUI::getUserBySession(); @@ -893,16 +893,18 @@ public function copy( * Create a credit note, set the invoice to credit note * - Gutschrift * - * @param null|QUI\Interfaces\Users\User $PermissionUser - * @param bool|string $globalProcessId + * @param null|User $PermissionUser * @return InvoiceTemporary * * @throws Exception + * @throws ExceptionStack * @throws QUI\Exception + * @throws QUI\Lock\Exception * @throws QUI\Permissions\Exception + * @throws Exception */ public function createCreditNote( - QUI\Interfaces\Users\User $PermissionUser = null + null | QUI\Interfaces\Users\User $PermissionUser = null ): InvoiceTemporary { // a credit node cant create a credit note if ($this->getInvoiceType() === QUI\ERP\Constants::TYPE_INVOICE_CREDIT_NOTE) { @@ -1084,8 +1086,8 @@ public function createCreditNote( * @throws QUI\Permissions\Exception */ public function createReversal( - QUI\Interfaces\Users\User $PermissionUser = null, - bool|string $globalProcessId = false + null | QUI\Interfaces\Users\User $PermissionUser = null, + bool | string $globalProcessId = false ): InvoiceTemporary { Permission::checkPermission('quiqqer.invoice.reversal', $PermissionUser); @@ -1452,7 +1454,10 @@ protected function isTransactionIdAddedToInvoice(string $txId): bool /** * Calculates the payments and set the new part payments * - * @throws + * @throws Exception + * @throws ExceptionStack + * @throws QUI\Database\Exception + * @throws QUI\Exception */ public function calculatePayments(): void { @@ -1599,7 +1604,7 @@ public function setPaymentStatus(int $paymentStatus): void * * @throws QUI\Exception */ - public function sendTo(string $recipient, bool|string $template = false): void + public function sendTo(string $recipient, bool | string $template = false): void { $type = $this->getInvoiceType(); $outputType = 'Invoice'; @@ -1635,7 +1640,7 @@ public function sendTo(string $recipient, bool|string $template = false): void * * @throws QUI\Exception */ - public function addComment(string $comment, QUI\Interfaces\Users\User $PermissionUser = null): void + public function addComment(string $comment, null | QUI\Interfaces\Users\User $PermissionUser = null): void { if (empty($comment)) { return; @@ -1855,7 +1860,7 @@ public function setProcessingStatus(int $statusId): void ); $this->setAttribute('processing_status', $Status->getId()); - } catch (QUI\DataBase\Exception $Exception) { + } catch (QUI\Database\Exception $Exception) { QUI\System\Log::addDebug($Exception->getMessage()); } diff --git a/src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php b/src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php index 47a660bc9b91a1cfa5287cb2fdad89d5fb910dba..100fa4d2df4191f7546f231d6183fee5d5bcd3fb 100644 --- a/src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php +++ b/src/QUI/ERP/Accounting/Invoice/InvoiceTemporary.php @@ -124,7 +124,7 @@ class InvoiceTemporary extends QUI\QDOM implements ErpEntityInterface, ErpTransa /** * @var array|false */ - protected array|false $addressDelivery = []; + protected array | false $addressDelivery = []; /** * @var null|QUI\ERP\Currency\Currency @@ -477,7 +477,7 @@ public function getCustomer(): ?QUI\ERP\User * @param string|QUI\ERP\Currency\Currency $currency * @throws QUI\Exception */ - public function setCurrency(QUI\ERP\Currency\Currency|string $currency): void + public function setCurrency(QUI\ERP\Currency\Currency | string $currency): void { if (is_string($currency)) { try { @@ -685,7 +685,7 @@ public function hasRefund(): bool * @throws QUI\Permissions\Exception * @throws QUI\Exception */ - public function setInvoiceType(int|string $type, QUI\Interfaces\Users\User $PermissionUser = null): void + public function setInvoiceType(int | string $type, null | QUI\Interfaces\Users\User $PermissionUser = null): void { QUI\Permissions\Permission::checkPermission( 'quiqqer.invoice.temporary.edit', @@ -729,7 +729,7 @@ public function setInvoiceType(int|string $type, QUI\Interfaces\Users\User $Perm * @throws QUI\Lock\Exception * @throws QUI\Exception */ - public function save(QUI\Interfaces\Users\User $PermissionUser = null): void + public function save(null | QUI\Interfaces\Users\User $PermissionUser = null): void { $this->update($PermissionUser); } @@ -743,7 +743,7 @@ public function save(QUI\Interfaces\Users\User $PermissionUser = null): void * @throws QUI\Lock\Exception * @throws QUI\Exception */ - public function update(QUI\Interfaces\Users\User $PermissionUser = null): void + public function update(null | QUI\Interfaces\Users\User $PermissionUser = null): void { if ($PermissionUser === null) { $PermissionUser = QUI::getUserBySession(); @@ -1073,7 +1073,7 @@ public function update(QUI\Interfaces\Users\User $PermissionUser = null): void * @throws QUI\Lock\Exception * @throws QUI\Exception */ - public function delete(QUI\Interfaces\Users\User $PermissionUser = null): void + public function delete(null | QUI\Interfaces\Users\User $PermissionUser = null): void { if ($PermissionUser === null) { $PermissionUser = QUI::getUserBySession(); @@ -1102,8 +1102,10 @@ public function delete(QUI\Interfaces\Users\User $PermissionUser = null): void * @param QUI\Interfaces\Users\User|null $PermissionUser * @return ErpEntityInterface|null */ - public function reversal(string $reason = '', QUI\Interfaces\Users\User $PermissionUser = null): ?ErpEntityInterface - { + public function reversal( + string $reason = '', + null | QUI\Interfaces\Users\User $PermissionUser = null + ): ?ErpEntityInterface { return null; } @@ -1121,8 +1123,8 @@ public function reversal(string $reason = '', QUI\Interfaces\Users\User $Permiss * @throws Exception */ public function copy( - QUI\Interfaces\Users\User $PermissionUser = null, - bool|string $globalProcessId = false + null | QUI\Interfaces\Users\User $PermissionUser = null, + bool | string $globalProcessId = false ): InvoiceTemporary { if ($PermissionUser === null) { $PermissionUser = QUI::getUserBySession(); @@ -1199,7 +1201,7 @@ public function copy( * @throws QUI\Permissions\Exception * @throws QUI\Exception */ - public function post(QUI\Interfaces\Users\User $PermissionUser = null): Invoice + public function post(null | QUI\Interfaces\Users\User $PermissionUser = null): Invoice { if ($PermissionUser === null) { $PermissionUser = QUI::getUserBySession(); @@ -1624,7 +1626,7 @@ public function post(QUI\Interfaces\Users\User $PermissionUser = null): Invoice * @throws QUI\Permissions\Exception * @throws QUI\Exception */ - public function createInvoice(QUI\Interfaces\Users\User $PermissionUser = null): Invoice + public function createInvoice(null | QUI\Interfaces\Users\User $PermissionUser = null): Invoice { return $this->post($PermissionUser); } @@ -1887,7 +1889,10 @@ protected function isTransactionIdAdded(string $txId): bool /** * Calculates the payments and set the new part payments * - * @throws + * @throws Exception + * @throws ExceptionStack + * @throws QUI\Database\Exception + * @throws QUI\Exception */ public function calculatePayments(): void { @@ -2464,7 +2469,7 @@ public function getDeliveryAddress(): ?QUI\ERP\Address * * @param array|QUI\ERP\Address $address */ - public function setDeliveryAddress(array|QUI\ERP\Address $address): void + public function setDeliveryAddress(array | QUI\ERP\Address $address): void { if ($address instanceof QUI\ERP\Address) { $this->addressDelivery = $address->getAttributes(); diff --git a/src/QUI/ERP/Accounting/Invoice/InvoiceView.php b/src/QUI/ERP/Accounting/Invoice/InvoiceView.php index 1866e53697dd4370b44c34c7211593ff2b8ea98e..2ecebb4b525649924e71d6718bd642f3cdc3d1ca 100644 --- a/src/QUI/ERP/Accounting/Invoice/InvoiceView.php +++ b/src/QUI/ERP/Accounting/Invoice/InvoiceView.php @@ -27,30 +27,22 @@ class InvoiceView extends QUI\QDOM /** * @var Invoice|InvoiceTemporary */ - protected InvoiceTemporary|Invoice $Invoice; + protected InvoiceTemporary | Invoice $Invoice; /** * InvoiceView constructor. * * @param Invoice|InvoiceTemporary $Invoice - * - * @throws Exception */ - public function __construct(Invoice|InvoiceTemporary $Invoice) + public function __construct(Invoice | InvoiceTemporary $Invoice) { - if ($Invoice instanceof Invoice || $Invoice instanceof InvoiceTemporary) { - $this->Invoice = $Invoice; - - return; - } - - throw new Exception('$Invoice must be an instance of Invoice or InvoiceTemporary'); + $this->Invoice = $Invoice; } /** * @return QUI\ERP\Accounting\ArticleList|QUI\ERP\Accounting\ArticleListUnique */ - public function getArticles(): QUI\ERP\Accounting\ArticleList|QUI\ERP\Accounting\ArticleListUnique + public function getArticles(): QUI\ERP\Accounting\ArticleList | QUI\ERP\Accounting\ArticleListUnique { try { return $this->Invoice->getArticles(); @@ -90,7 +82,7 @@ public function getCurrency(): QUI\ERP\Currency\Currency /** * @return false|null|QUI\ERP\User|QUI\Users\Nobody|QUI\Users\SystemUser|QUI\Users\User */ - public function getCustomer(): bool|QUI\Users\SystemUser|QUI\Users\Nobody|QUI\ERP\User|QUI\Users\User|null + public function getCustomer(): bool | QUI\Users\SystemUser | QUI\Users\Nobody | QUI\ERP\User | QUI\Users\User | null { try { return $this->Invoice->getCustomer(); @@ -103,7 +95,7 @@ public function getCustomer(): bool|QUI\Users\SystemUser|QUI\Users\Nobody|QUI\ER * @param null|QUI\Locale $Locale * @return string|bool */ - public function getDate(QUI\Locale $Locale = null): string|bool + public function getDate(null | QUI\Locale $Locale = null): string | bool { if ($Locale === null) { $Locale = QUI::getLocale(); @@ -120,7 +112,7 @@ public function getDate(QUI\Locale $Locale = null): string|bool * @param null $Locale * @return false|string */ - public function formatDate($dateString, $Locale = null): bool|string + public function formatDate($dateString, $Locale = null): bool | string { if ($Locale === null) { $Locale = QUI::getLocale(); @@ -160,7 +152,7 @@ public function getPayment(): Payment /** * @return Invoice|InvoiceTemporary */ - public function getInvoice(): Invoice|InvoiceTemporary + public function getInvoice(): Invoice | InvoiceTemporary { return $this->Invoice; } @@ -308,7 +300,11 @@ class_exists('QUI\ERP\Accounting\Payments\Methods\AdvancePayment\Payment') } else { $timeForPayment = $Locale->get('quiqqer/invoice', 'additional.invoice.text.timeForPayment.0'); } - } else { + } + + /* + // Else is unreachable because previous condition is always true. + else { $timeForPayment = strtotime($timeForPayment); if (date('Y-m-d') === date('Y-m-d', $timeForPayment)) { @@ -317,6 +313,7 @@ class_exists('QUI\ERP\Accounting\Payments\Methods\AdvancePayment\Payment') $timeForPayment = $Formatter->format($timeForPayment); } } + */ return $Locale->get( 'quiqqer/invoice', diff --git a/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCancelled.php b/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCancelled.php index 4e23e0e496a5242d34bab29124433a46e85704da..1f4e94557bd9a6806d69bcae03a73f754b6b29d3 100644 --- a/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCancelled.php +++ b/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCancelled.php @@ -34,7 +34,7 @@ public static function getEntityType(): string * @param Locale|null $Locale $Locale (optional) - If omitted use \QUI::getLocale() * @return string */ - public static function getEntityTypeTitle(Locale $Locale = null): string + public static function getEntityTypeTitle(null | Locale $Locale = null): string { if (empty($Locale)) { $Locale = QUI::getLocale(); @@ -51,7 +51,7 @@ public static function getEntityTypeTitle(Locale $Locale = null): string * * @throws QUI\Exception */ - public static function getMailSubject(int|string $entityId): string + public static function getMailSubject(int | string $entityId): string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); @@ -91,7 +91,7 @@ public static function getMailSubject(int|string $entityId): string * * @throws QUI\Exception */ - public static function getMailBody(int|string $entityId): string + public static function getMailBody(int | string $entityId): string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); diff --git a/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCreditNote.php b/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCreditNote.php index cc71fdc1b5f33df11ec7bee7f1f52cc7f70fa885..5b97fab4dcb04da4f152408e99cf692355c28603 100644 --- a/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCreditNote.php +++ b/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderCreditNote.php @@ -34,7 +34,7 @@ public static function getEntityType(): string * @param Locale|null $Locale $Locale (optional) - If omitted use \QUI::getLocale() * @return string */ - public static function getEntityTypeTitle(Locale $Locale = null): string + public static function getEntityTypeTitle(null | Locale $Locale = null): string { if (empty($Locale)) { $Locale = QUI::getLocale(); @@ -51,7 +51,7 @@ public static function getEntityTypeTitle(Locale $Locale = null): string * * @throws QUI\Exception */ - public static function getMailSubject(int|string $entityId): string + public static function getMailSubject(int | string $entityId): string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); @@ -91,7 +91,7 @@ public static function getMailSubject(int|string $entityId): string * * @throws QUI\Exception */ - public static function getMailBody(int|string $entityId): string + public static function getMailBody(int | string $entityId): string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); diff --git a/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php b/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php index 85bf28dc19755d06c48d57dd077a07a3015763f3..aea5a8865bdf8b5bf4ae46855468cc70dd5bc4c5 100644 --- a/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php +++ b/src/QUI/ERP/Accounting/Invoice/Output/OutputProviderInvoice.php @@ -60,7 +60,7 @@ public static function getEntityType(): string * @param Locale|null $Locale $Locale (optional) - If ommitted use \QUI::getLocale() * @return string */ - public static function getEntityTypeTitle(Locale $Locale = null): string + public static function getEntityTypeTitle(null | Locale $Locale = null): string { if (empty($Locale)) { $Locale = QUI::getLocale(); @@ -77,7 +77,7 @@ public static function getEntityTypeTitle(Locale $Locale = null): string * * @throws QUI\Exception */ - public static function getEntity(int|string $entityId): Invoice|InvoiceTemporary + public static function getEntity(int | string $entityId): Invoice | InvoiceTemporary { return InvoiceUtils::getInvoiceByString($entityId); } @@ -90,7 +90,7 @@ public static function getEntity(int|string $entityId): Invoice|InvoiceTemporary * * @throws QUI\Exception */ - public static function getDownloadFileName(int|string $entityId): string + public static function getDownloadFileName(int | string $entityId): string { return InvoiceUtils::getInvoiceFilename(self::getEntity($entityId)); } @@ -103,7 +103,7 @@ public static function getDownloadFileName(int|string $entityId): string * * @throws QUI\Exception */ - public static function getLocale(int|string $entityId): Locale + public static function getLocale(int | string $entityId): Locale { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); @@ -125,7 +125,7 @@ public static function getLocale(int|string $entityId): Locale * @throws QUI\ERP\Exception * @throws QUI\Exception */ - public static function getTemplateData(int|string $entityId): array + public static function getTemplateData(int | string $entityId): array { $Invoice = self::getEntity($entityId); $InvoiceView = $Invoice->getView(); @@ -168,8 +168,13 @@ public static function getTemplateData(int|string $entityId): array $Articles = $Invoice->getArticles(); if (get_class($Articles) !== QUI\ERP\Accounting\ArticleListUnique::class) { - $Articles->setUser($Customer); - $Articles = $Articles->toUniqueList(); + if (method_exists($Articles, 'setUser')) { + $Articles->setUser($Customer); + } + + if (method_exists($Articles, 'toUniqueList')) { + $Articles = $Articles->toUniqueList(); + } } // Delivery address @@ -243,7 +248,7 @@ public static function getTemplateData(int|string $entityId): array * @param User $User * @return bool */ - public static function hasDownloadPermission(int|string $entityId, User $User): bool + public static function hasDownloadPermission(int | string $entityId, User $User): bool { if (!QUI::getUsers()->isAuth($User) || QUI::getUsers()->isNobodyUser($User)) { return false; @@ -273,7 +278,7 @@ public static function hasDownloadPermission(int|string $entityId, User $User): * * @throws QUI\Exception */ - public static function getEmailAddress(int|string $entityId): bool|string + public static function getEmailAddress(int | string $entityId): bool | string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); @@ -297,7 +302,7 @@ public static function getEmailAddress(int|string $entityId): bool|string * * @throws QUI\Exception */ - public static function getMailSubject(int|string $entityId): string + public static function getMailSubject(int | string $entityId): string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); @@ -317,7 +322,7 @@ public static function getMailSubject(int|string $entityId): string * * @throws QUI\Exception */ - public static function getMailBody(int|string $entityId): string + public static function getMailBody(int | string $entityId): string { $Invoice = self::getEntity($entityId); $Customer = $Invoice->getCustomer(); @@ -335,7 +340,7 @@ public static function getMailBody(int|string $entityId): string * @return array */ protected static function getInvoiceLocaleVar( - Invoice|InvoiceTemporary $Invoice, + Invoice | InvoiceTemporary $Invoice, QUI\ERP\User $Customer ): array { $CustomerAddress = $Customer->getAddress(); @@ -471,7 +476,7 @@ public static function getCustomerVariables(QUI\ERP\User $Customer): array * @param $date * @return false|string */ - public static function dateFormat($date): bool|string + public static function dateFormat($date): bool | string { // date $localeCode = QUI::getLocale()->getLocalesByLang( @@ -499,7 +504,7 @@ public static function dateFormat($date): bool|string * @param Invoice|InvoiceTemporary $Invoice * @return string|false - Raw <img> "src" attribute with base64 image data or false if code can or must not be generated. */ - protected static function getEpcQrCodeImageImgSrc(Invoice|InvoiceTemporary $Invoice): bool|string + protected static function getEpcQrCodeImageImgSrc(Invoice | InvoiceTemporary $Invoice): bool | string { try { // Check currency (must be EUR) diff --git a/src/QUI/ERP/Accounting/Invoice/Payment.php b/src/QUI/ERP/Accounting/Invoice/Payment.php index e17a65e1d73675a038831b9af6862fcbc6359fe5..18b540fccd7e888766d4d63467f61b014a89e6c7 100644 --- a/src/QUI/ERP/Accounting/Invoice/Payment.php +++ b/src/QUI/ERP/Accounting/Invoice/Payment.php @@ -64,7 +64,7 @@ public function __construct(array $paymentData = []) * @param null|QUI\Locale $Locale * @return string */ - public function getTitle(QUI\Locale $Locale = null): string + public function getTitle(null | QUI\Locale $Locale = null): string { if (!isset($this->attributes['title'])) { return ''; @@ -89,7 +89,7 @@ public function getTitle(QUI\Locale $Locale = null): string * @param null|QUI\Locale $Locale * @return mixed|string */ - public function getDescription(QUI\Locale $Locale = null): mixed + public function getDescription(null | QUI\Locale $Locale = null): mixed { if (!isset($this->attributes['description'])) { return ''; @@ -146,7 +146,7 @@ protected function getPayment(): ?QUI\ERP\Accounting\Payments\Types\Payment * @param Invoice|InvoiceTemporary|InvoiceView $Invoice * @return string */ - public function getInvoiceInformationText(Invoice|InvoiceTemporary|InvoiceView $Invoice): string + public function getInvoiceInformationText(Invoice | InvoiceTemporary | InvoiceView $Invoice): string { if ($Invoice instanceof InvoiceView) { $Invoice = $Invoice->getInvoice(); diff --git a/src/QUI/ERP/Accounting/Invoice/PaymentReceiver.php b/src/QUI/ERP/Accounting/Invoice/PaymentReceiver.php index e6210e04dbf70fec9af1b2b74ae87f7f8cc633f9..67c52e4eb26b6dd7869a8959b15e46342a87cabd 100644 --- a/src/QUI/ERP/Accounting/Invoice/PaymentReceiver.php +++ b/src/QUI/ERP/Accounting/Invoice/PaymentReceiver.php @@ -19,7 +19,7 @@ class PaymentReceiver implements PaymentReceiverInterface /** * @var null|InvoiceTemporary|Invoice $Invoice */ - protected null|InvoiceTemporary|Invoice $Invoice = null; + protected null | InvoiceTemporary | Invoice $Invoice = null; /** * Get entity type descriptor @@ -37,7 +37,7 @@ public static function getType(): string * @param Locale|null $Locale $Locale (optional) - If omitted use \QUI::getLocale() * @return string */ - public static function getTypeTitle(Locale $Locale = null): string + public static function getTypeTitle(null | Locale $Locale = null): string { if (empty($Locale)) { $Locale = QUI::getLocale(); @@ -64,7 +64,7 @@ public function __construct($id) * @throws Exception * @throws QUI\ERP\Exception */ - public function getDebtorAddress(): bool|Address + public function getDebtorAddress(): bool | Address { return $this->Invoice->getCustomer()->getStandardAddress(); } @@ -116,7 +116,7 @@ public function getDate(): DateTime * * @return DateTime|false */ - public function getDueDate(): DateTime|bool + public function getDueDate(): DateTime | bool { $date = $this->Invoice->getAttribute('time_for_payment'); @@ -175,7 +175,7 @@ public function getAmountPaid(): float * * @return PaymentInterface|false */ - public function getPaymentMethod(): bool|PaymentInterface + public function getPaymentMethod(): bool | PaymentInterface { try { return QUI\ERP\Accounting\Payments\Payments::getInstance()->getPayment( diff --git a/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Factory.php b/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Factory.php index 460c496e23e6066fcba478853f955a2a8ffc2959..9eae450c16100adc8d8148cd2bdd1efa90cb3c60 100644 --- a/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Factory.php +++ b/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Factory.php @@ -32,7 +32,7 @@ class Factory extends QUI\Utils\Singleton * @todo permissions */ public function createProcessingStatus( - int|string $id, + int | string $id, string $color, array $title, array $options = [] @@ -54,7 +54,7 @@ public function createProcessingStatus( $Config->setValue( 'processing_status', - $id, + (string)$id, json_encode([ 'color' => $color, 'options' => $options diff --git a/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Handler.php b/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Handler.php index b5c17df5c9ef63971468bf6eb6b3317fbd91dfc3..fe1ec35c34b26e07f52e6b0c8216c49c57610bea 100644 --- a/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Handler.php +++ b/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Handler.php @@ -121,7 +121,7 @@ public function deleteProcessingStatus(int|string $id): void $Package = QUI::getPackage('quiqqer/invoice'); $Config = $Package->getConfig(); - $Config->del('processing_status', $Status->getId()); + $Config->del('processing_status', (string)$Status->getId()); $Config->save(); } @@ -177,7 +177,7 @@ public function updateProcessingStatus( $Config->setValue( 'processing_status', - $Status->getId(), + (string)$Status->getId(), json_encode([ 'color' => $color, 'options' => $options diff --git a/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Status.php b/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Status.php index e5cc1c9e3a9b4066cd126a9fa6171acd46e2d0e8..82b6e5ab05534233e2f87d2ad603241e2e0c8bca 100644 --- a/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Status.php +++ b/src/QUI/ERP/Accounting/Invoice/ProcessingStatus/Status.php @@ -44,7 +44,7 @@ class Status * @param int|string $id - Processing status id * @throws Exception */ - public function __construct(int|string $id) + public function __construct(int | string $id) { $list = Handler::getInstance()->getList(); @@ -90,7 +90,7 @@ public function getId(): int * @param null|QUI\Locale $Locale * @return string */ - public function getTitle(QUI\Locale $Locale = null): string + public function getTitle(null | QUI\Locale $Locale = null): string { if (!($Locale instanceof QUI\Locale)) { $Locale = QUI::getLocale(); @@ -159,7 +159,7 @@ public function getOptions(): array * @param null|QUI\Locale $Locale - optional. if no locale, all translations would be returned * @return array */ - public function toArray(QUI\Locale $Locale = null): array + public function toArray(null | QUI\Locale $Locale = null): array { $title = $this->getTitle($Locale); diff --git a/src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php b/src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php index 7de6d1e06a501686f91a09c2685ee00c22bd9307..2f7ef7ef0af04ff3f4811708575cdeaf8c5d1c04 100644 --- a/src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php +++ b/src/QUI/ERP/Accounting/Invoice/Search/InvoiceSearch.php @@ -57,7 +57,7 @@ class InvoiceSearch extends Singleton /** * @var array|bool */ - protected array|bool $limit = [0, 20]; + protected array | bool $limit = [0, 20]; /** * @var string @@ -85,7 +85,7 @@ class InvoiceSearch extends Singleton * @param array|string $value * @throws QUI\Exception */ - public function setFilter(string $filter, array|string $value): void + public function setFilter(string $filter, array | string $value): void { if ($filter === 'search') { $this->search = $value; @@ -201,7 +201,7 @@ public function disableCalcTotal(): void * @param int|string $from * @param int|string $to */ - public function limit(int|string $from, int|string $to): void + public function limit(int | string $from, int | string $to): void { $this->limit = [(int)$from, (int)$to]; } @@ -437,7 +437,7 @@ protected function getQuery(bool $count = false): array break; case 'customer_id': - $value = (int)$filter['value']; + $value = (string)$filter['value']; $where[] = $flr . ' = ' . $bind; // remove customer prefix, for better search @@ -453,7 +453,7 @@ protected function getQuery(bool $count = false): array } $binds[$bind] = [ - 'value' => $value, + 'value' => (int)$value, 'type' => PDO::PARAM_INT ]; @@ -803,7 +803,7 @@ protected function parseListForGrid(array $data): array if ($Customer->getAttribute('customerId')) { $invoiceData['customer_id_display'] = $Customer->getAttribute('customerId'); - $invoiceData['customer_id'] = $Customer->getUUID() ?? $Customer->getId(); + $invoiceData['customer_id'] = $Customer->getUUID() ?: $Customer->getId(); } else { $invoiceData['customer_id_display'] = ''; $invoiceData['customer_id'] = ''; diff --git a/src/QUI/ERP/Accounting/Invoice/Utils/Invoice.php b/src/QUI/ERP/Accounting/Invoice/Utils/Invoice.php index 09b004b3baa29e091b1c59ea0ac960bd93ac039f..b925673afcd25a9432b9df1dea46da0cbd8c138d 100644 --- a/src/QUI/ERP/Accounting/Invoice/Utils/Invoice.php +++ b/src/QUI/ERP/Accounting/Invoice/Utils/Invoice.php @@ -56,7 +56,7 @@ class Invoice * * @throws QUI\Exception */ - public static function getInvoiceByString(int|string $str): QUI\ERP\Accounting\Invoice\Invoice|InvoiceTemporary + public static function getInvoiceByString(int | string $str): QUI\ERP\Accounting\Invoice\Invoice | InvoiceTemporary { $Invoices = QUI\ERP\Accounting\Invoice\Handler::getInstance(); @@ -384,7 +384,7 @@ public static function getMissingAttributeMessage(string $missingAttribute): str * @param array|string $articles * @return array|string */ - public static function formatArticlesArray(array|string $articles): array|string + public static function formatArticlesArray(array | string $articles): array | string { $isString = is_string($articles); @@ -438,7 +438,7 @@ public static function formatArticlesArray(array|string $articles): array|string */ protected static function verificateField( $value, - array|string $eMessage = 'Error occurred', + array | string $eMessage = 'Error occurred', int $eCode = 0, array $eContext = [] ): void { @@ -457,16 +457,9 @@ protected static function verificateField( * @throws QUI\Exception */ public static function getInvoiceFilename( - QUI\ERP\Accounting\Invoice\Invoice|InvoiceTemporary $Invoice, + QUI\ERP\Accounting\Invoice\Invoice | InvoiceTemporary $Invoice, ?QUI\Locale $Locale = null ): string { - if ( - !($Invoice instanceof QUI\ERP\Accounting\Invoice\Invoice) && - !($Invoice instanceof QUI\ERP\Accounting\Invoice\InvoiceTemporary) - ) { - return ''; - } - // date $localeCode = QUI::getLocale()->getLocalesByLang( QUI::getLocale()->getCurrent() @@ -524,9 +517,9 @@ public static function getInvoiceFilename( * @return int|float */ public static function roundInvoiceSum( - float|int $amount, + float | int $amount, ?QUI\ERP\Currency\Currency $Currency = null - ): float|int { + ): float | int { if ($Currency === null) { $Currency = QUI\ERP\Defaults::getCurrency(); @@ -544,14 +537,14 @@ public static function roundInvoiceSum( * @param Invoice|InvoiceTemporary $Invoice * @return int - Unix Timestamp */ - public static function getInvoiceTimeForPaymentDate(InvoiceTemporary|Invoice $Invoice): int + public static function getInvoiceTimeForPaymentDate(InvoiceTemporary | Invoice $Invoice): int { $timeForPayment = $Invoice->getAttribute('time_for_payment'); if ($Invoice instanceof QUI\ERP\Accounting\Invoice\InvoiceTemporary) { $timeForPayment = (int)$timeForPayment; - if ($timeForPayment || $timeForPayment === 0) { + if ($timeForPayment >= 0) { $timeForPayment = strtotime('+' . $timeForPayment . ' day'); } } else { @@ -567,7 +560,7 @@ public static function getInvoiceTimeForPaymentDate(InvoiceTemporary|Invoice $In * @return array */ public static function getVatTextArrayFromVatArray( - array|string $vatArray, + array | string $vatArray, QUI\ERP\Currency\Currency $Currency ): array { if (is_string($vatArray)) { @@ -587,7 +580,7 @@ public static function getVatTextArrayFromVatArray( * @param array|string $vatArray * @return array */ - public static function getVatSumArrayFromVatArray(array|string $vatArray): array + public static function getVatSumArrayFromVatArray(array | string $vatArray): array { if (is_string($vatArray)) { $vatArray = json_decode($vatArray, true); @@ -608,7 +601,7 @@ public static function getVatSumArrayFromVatArray(array|string $vatArray): array * @param array|string $vatArray * @return int|float */ - public static function getVatSumFromVatArray(array|string $vatArray): float|int + public static function getVatSumFromVatArray(array | string $vatArray): float | int { return array_sum( self::getVatSumArrayFromVatArray($vatArray) @@ -622,7 +615,7 @@ public static function getVatSumFromVatArray(array|string $vatArray): float|int * @param QUI\ERP\Accounting\Invoice\Invoice|integer|string $Invoice - Invoice or Invoice ID * @return array */ - public static function getTransactionsByInvoice(QUI\ERP\Accounting\Invoice\Invoice|int|string $Invoice): array + public static function getTransactionsByInvoice(QUI\ERP\Accounting\Invoice\Invoice | int | string $Invoice): array { if (!($Invoice instanceof QUI\ERP\Accounting\Invoice\Invoice)) { try { @@ -671,7 +664,7 @@ public static function addressRequirementThreshold(): float } public static function getElectronicInvoice( - InvoiceTemporary|QUI\ERP\Accounting\Invoice\Invoice $Invoice, + InvoiceTemporary | QUI\ERP\Accounting\Invoice\Invoice $Invoice, $type = ZugferdProfiles::PROFILE_EN16931 ): ZugferdDocumentBuilder { $document = ZugferdDocumentBuilder::CreateNew($type);