Srážkové daně jsou vypočteny nesprávně Pokud použijete základní vyloučena daň z přidané hodnoty v italské verzi Microsoft Dynamics NAV 5.0 Service Pack 1


Tento článek se týká aplikace Microsoft Dynamics NAV pro národní jazyk italštiny (it).

Příznaky


Pokud máte základní vyloučené daň z přidané hodnoty částky uvedené v italské verzi Microsoft Dynamics NAV 5.0 Service Pack 1 (SP1), srážkové daně jsou vypočteny nesprávně.

Řešení


Informace o opravě hotfix

Podporovaná oprava hotfix je nyní k dispozici od společnosti Microsoft. Však je určena pouze k odstranění problému popsaného v tomto článku. Použijte ji pouze u systémů, ve kterých dochází k tomuto konkrétnímu problému. Tato oprava hotfix může být dále testována. Proto pokud jste závažně tento problém, doporučujeme počkat na další aktualizaci service pack produktu Microsoft Dynamics NAV nebo další verze produktu Microsoft Dynamics NAV, která obsahuje tuto opravu hotfix.

Poznámka: Ve zvláštních případech poplatky, které jsou třeba obvykle zaplatit za telefonní hovory mohou být stornovány, jestliže pracovník technické podpory společnosti Microsoft Dynamics a souvisejících produktů Určuje, že konkrétní aktualizace odstraní váš problém. Výdaje na technickou podporu použije dalších otázek a problémů, které nelze vyřešit konkrétní aktualizací.


Informace o instalaci

Společnost Microsoft poskytuje ukázky programování pouze pro ilustraci bez žádné záruky výslovně uvedené nebo odvozené. To zahrnuje, ale není omezen pouze na předpokládané záruky obchodovatelnosti nebo vhodnosti pro určitý účel. Tento článek předpokládá, že jste obeznámeni s programovacím jazykem, který je předmětem ukázky a s nástroji, které slouží k vytvoření a ladění skriptu. Pracovníci podpory společnosti Microsoft mohou pomoci vysvětlit funkce určitého postupu, nemohou však následující příklady rozšířit o další funkce nebo vytvářet postupy podle vašich konkrétních požadavků.

Poznámka: Před instalací této opravy hotfix ověřte, že všichni uživatelé klienta Microsoft Navision odhlášeni systému. To zahrnuje uživatele klienta Microsoft Navision Application Services (NAS). Je třeba klienta pouze uživatel přihlášený při implementaci opravy hotfix.

Chcete-li implementovat tuto opravu hotfix, musí mít licenci vývojáře.

Doporučujeme, aby uživatelský účet v okně přihlášení systému Windows nebo v okně přihlášení databáze přidělí "SUPER" ID role. Pokud uživatelský účet nelze přiřadit ID role "SUPER", musíte ověřit, že uživatelský účet má následující oprávnění:
  • Změnit oprávnění pro objekt, který budete měnit.
  • Oprávnění ke spuštění pro System Object ID 5210 objekt a System Object ID 9015 objekt.


Poznámka: Nemáte práva k úložištím dat. Pokud nebudete provádět opravu dat.

Změny kódu

Poznámka: Vždy otestujte opravy kódu v kontrolovaném prostředí před instalací opravy v provozních počítačích.
Chcete-li vyřešit tento problém, postupujte takto:
  1. Změňte kód ve funkci CreateTmpWithhSocSec v srážkové-příspěvek procedura (12101) takto:
    Existující kód 1
    ...TmpWithholdingSocSec."Total Amount" := GetRemainingWithhTaxAmount(ComputedWithholdingTax);
    // IT0001.end

    // Delete the following lines.
    TmpWithholdingSocSec."Base - Excluded Amount" := ComputedWithholdingTax."Remaining - Excluded Amount";
    TmpWithholdingSocSec.VALIDATE("Non Taxable Amount By Treaty",ComputedWithholdingTax."Non Taxable Remaining Amount");
    // End of the lines.

    IF ComputedSocSec.FIND('-') THEN BEGIN
    ...
    Změněný kód 1
    ...TmpWithholdingSocSec."Total Amount" := GetRemainingWithhTaxAmount(ComputedWithholdingTax);
    // IT0001.end

    // Add the following lines.
    TmpWithholdingSocSec."Base - Excluded Amount" := GetBaseExcludedAmount(ComputedWithholdingTax);
    TmpWithholdingSocSec.VALIDATE("Non Taxable Amount By Treaty",GetNonTaxableAmount(ComputedWithholdingTax));
    // End of the lines.

    IF ComputedSocSec.FIND('-') THEN BEGIN
    ...
    Existující kód 2
    ...TmpWithholdingSocSec."Base - Excluded Amount" := CurrencyExchRate.ExchangeAmtFCYToFCY(
    "Document Date",
    ComputedWithholdingTax."Currency Code",
    "Currency Code",

    // Delete the following line.
    ComputedWithholdingTax."Remaining - Excluded Amount");

    TmpWithholdingSocSec.VALIDATE("Non Taxable Amount By Treaty",CurrencyExchRate.ExchangeAmtFCYToFCY(

    "Document Date",
    ComputedWithholdingTax."Currency Code",
    "Currency Code",

    // Delete the following line.
    ComputedWithholdingTax."Non Taxable Remaining Amount"))

    ;

    IF ComputedSocSec.FIND('-') THEN BEGIN
    ...
    Náhradní kód 2
    ...TmpWithholdingSocSec."Base - Excluded Amount" := CurrencyExchRate.ExchangeAmtFCYToFCY(
    "Document Date",
    ComputedWithholdingTax."Currency Code",
    "Currency Code",

    // Add the following line.
    GetBaseExcludedAmount(ComputedWithholdingTax));

    TmpWithholdingSocSec.VALIDATE("Non Taxable Amount By Treaty",CurrencyExchRate.ExchangeAmtFCYToFCY(

    "Document Date",
    ComputedWithholdingTax."Currency Code",
    "Currency Code",

    // Add the following line.
    GetNonTaxableAmount(ComputedWithholdingTax)))

    ;

    IF ComputedSocSec.FIND('-') THEN BEGIN
    ...
  2. Vytvoření nové funkce FindApplyingDocument . Chcete-li to provést, postupujte takto:
    1. Přidat nový parametr místní a potom zadejte parametr takto:
      • Var: Ano
      • Název: VendLedgEntry
      • Datový typ: záznam
      • Podtyp: Položka dodavatele
    2. Přidat nový parametr místní a potom zadejte parametr takto:
      • Var: No
      • Název: ComputedWithholdingTax
      • Datový typ: záznam
      • Podtyp: vypočítané srážkové daně
    3. Přidat nový místní proměnné a proměnné zadejte následujícím způsobem:
      • Název: DtldVendLedgEntry
      • Datový typ: záznam
      • Podtyp: Detailní položky dodavatele. Položka
    4. Přidat nový místní proměnné a proměnné zadejte následujícím způsobem:
      • Název: TempDtldVendLedgEntry
      • Datový typ: dočasný záznam
      • Podtyp: Detailní položky dodavatele. Položka
    5. Přidejte následující kód ve funkci GetRemainingWithhTaxAmount :
      WITH VendLedgEntry DO BEGINRESET;
      SETRANGE("Document No.",ComputedWithholdingTax."Document No.");
      IF VendLedgEntry.FINDFIRST THEN BEGIN
      SETRANGE("Document No.");
      DtldVendLedgEntry.SETRANGE(Unapplied,FALSE);
      DtldVendLedgEntry.SETRANGE("Entry Type",DtldVendLedgEntry."Entry Type"::Application);
      DtldVendLedgEntry.SETRANGE("Vendor Ledger Entry No.","Entry No.");
      IF DtldVendLedgEntry.FINDSET THEN
      REPEAT
      TempDtldVendLedgEntry := DtldVendLedgEntry;
      TempDtldVendLedgEntry.INSERT;
      UNTIL DtldVendLedgEntry.NEXT = 0;

      DtldVendLedgEntry.SETFILTER("Vendor Ledger Entry No.",'<>%1',"Entry No.");
      TempDtldVendLedgEntry.SETCURRENTKEY("Transaction No.","Vendor No.","Entry Type");
      IF TempDtldVendLedgEntry.FINDSET THEN
      REPEAT
      DtldVendLedgEntry.SETRANGE("Transaction No.",TempDtldVendLedgEntry."Transaction No.");
      IF DtldVendLedgEntry.FINDSET THEN
      REPEAT
      GET(DtldVendLedgEntry."Vendor Ledger Entry No.");
      IF NOT MARK THEN
      MARK(TRUE);
      UNTIL DtldVendLedgEntry.NEXT = 0;
      UNTIL TempDtldVendLedgEntry.NEXT = 0;
      END;
      END;
  3. Vytvoření nové funkce GetBaseExcludedAmount . Chcete-li to provést, postupujte takto:
    1. Přidat nový parametr místní a potom zadejte parametr takto:
      • Var: No
      • Název: ComputedWithholdingTax
      • Datový typ: záznam
      • Podtyp: vypočítané srážkové daně
    2. Návratové proměnné zadejte následujícím způsobem:
      • Návratový typ: desetinné číslo
    3. Přidat nový místní proměnné a proměnné zadejte následujícím způsobem:
      • Název: VendLedgEntry
      • Datový typ: záznam
      • Podtyp: Položka dodavatele
    4. Přidat nový místní proměnné a proměnné zadejte následujícím způsobem:
      • Název: BaseExcludedAmount
      • Datový typ: desetinné číslo
    5. Přidejte následující kód ve funkci GetBaseExcludedAmount :
      FindApplyingDocument(VendLedgEntry,ComputedWithholdingTax);BaseExcludedAmount := ComputedWithholdingTax."Base - Excluded Amount";
      VendLedgEntry.MARKEDONLY(TRUE);
      IF VendLedgEntry.FINDSET THEN
      REPEAT
      ComputedWithholdingTax.SETRANGE("Document No.",VendLedgEntry."Document No.");
      IF ComputedWithholdingTax.FINDFIRST THEN
      BaseExcludedAmount -= ComputedWithholdingTax."Base - Excluded Amount";
      UNTIL VendLedgEntry.NEXT = 0;
      EXIT(BaseExcludedAmount);
  4. Vytvoření nové funkce GetNonTaxableAmount . Chcete-li to provést, postupujte takto:
    1. Přidat nový parametr místní a potom zadejte parametr takto:
      • Var: No
      • Název: ComputedWithholdingTax
      • Datový typ: záznam
      • Podtyp: vypočítané srážkové daně
    2. Návratové proměnné zadejte následujícím způsobem:
      • Návratový typ: desetinné číslo
    3. Přidat nový místní proměnné a proměnné zadejte následujícím způsobem:
      • Název: VendLedgEntry
      • Datový typ: záznam
      • Podtyp: Položka dodavatele
    4. Přidat nový místní proměnné a proměnné zadejte následujícím způsobem:
      • Název: NonTaxableAmount
      • Datový typ: desetinné číslo
    5. Přidejte následující kód ve funkci GetNonTaxableAmount :
      FindApplyingDocument(VendLedgEntry,ComputedWithholdingTax);NonTaxableAmount := ComputedWithholdingTax."Non Taxable Amount By Treaty";
      VendLedgEntry.MARKEDONLY(TRUE);
      IF VendLedgEntry.FINDSET THEN
      REPEAT
      ComputedWithholdingTax.SETRANGE("Document No.",VendLedgEntry."Document No.");
      IF ComputedWithholdingTax.FINDFIRST THEN
      NonTaxableAmount -= ComputedWithholdingTax."Non Taxable Amount By Treaty";
      UNTIL VendLedgEntry.NEXT = 0;
      EXIT(NonTaxableAmount);

Předpoklady

Italskou verzi produktu Microsoft Dynamics NAV 5.0 Service Pack 1 nainstalována tuto opravu hotfix, musí mít.

Informace o odinstalaci

Tato oprava hotfix nelze odebrat.

Další informace


Další informace získáte v následujícím článku znalostní báze Microsoft Knowledge Base:
974684 italskou verzi produktu Microsoft Dynamics NAV odečte snížení nesprávné srážkové daně při zpracování platby nákupní faktury

Stav


Společnost Microsoft potvrdila, že se jedná o problém v produktech společnosti Microsoft, které jsou uvedeny v části "Platí pro".
Poznámka: Toto je článek "Rychlé publikování" vytvářen přímo v rámci odborné pomoci společnosti Microsoft. Informace obsažené v tomto dokumentu jsou poskytovány tak, jak je v reakci na vznikající problémy. V důsledku rychlosti v jeho zpřístupnění materiály, mohou obsahovat typografické chyby a mohou být upraveny kdykoli bez předchozího upozornění. Viz Podmínky použití pro další aspekty.