Při použití měny v aplikaci Microsoft Dynamics NAV 2009 použitá částka je vypočtena nesprávně použít odběratelů nebo použít stránky položky dodavatele, pokud aplikujete platby v měně faktury v lokální měně. K tomuto problému dochází v následujících produktů:
-
Aplikace Microsoft Dynamics NAV 2009 R2
-
Aplikace Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
Ř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 2009 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 vysvětlit funkce určitého postupu. Nemohou však následující příklady rozšířit o další funkce nebo konstrukce podle konkrétních požadavků.
Poznámka: Před instalací této opravy hotfix ověřte, že všichni uživatelé klienta Microsoft Dynamics NAV odhlášeni systému. To zahrnuje služby Microsoft Dynamics NAV Application Server (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
objektu.
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. Před použitím změnu, importujte všechny aktualizace SEPA.
Chcete-li vyřešit tento problém, postupujte takto:-
Změňte kód v dialogovém okně Vlastnosti ve formuláři Vyrovnat položky zákazníka (232) takto:
Existující kód...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Cust. Entry-Edit",Rec); EXIT(FALSE); END; ...Změněný kód
...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Cust. Entry-Edit",Rec); IF "Applies-to ID" <> xRec."Applies-to ID" THEN CalcApplnAmount; EXIT(FALSE); END; ... -
Změňte kód ve funkci HandlChosenEntries ve formuláři Vyrovnat položky zákazníka (232) takto:
Existující kód 1...IF NOT FromZeroGenJnl THEN
AppliedCustLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0); IF AppliedCustLedgEntryTemp.FINDFIRST THEN BEGIN AppliedCustLedgEntryTemp.CALCFIELDS("Remaining Amount"); IF Type = Type::Direct THEN CalculateCurrency := ApplyingCustLedgEntry."Entry No." <> 0 ELSE CalculateCurrency := TRUE; IF (CurrencyCode <> AppliedCustLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN AppliedCustLedgEntryTemp."Remaining Amount" := GenJnlPostLine.ExchAmount( AppliedCustLedgEntryTemp."Remaining Amount", AppliedCustLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" := GenJnlPostLine.ExchAmount( AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible", AppliedCustLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedCustLedgEntryTemp."Amount to Apply" := GenJnlPostLine.ExchAmount( AppliedCustLedgEntryTemp."Amount to Apply", AppliedCustLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); END; CASE Type OF Type::Direct: ...Změněný kód 1
...IF NOT FromZeroGenJnl THEN
AppliedCustLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0); IF AppliedCustLedgEntryTemp.FINDFIRST THEN BEGIN ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedCustLedgEntryTemp); CASE Type OF Type::Direct: ...Existující kód 2
...END ELSE BEGIN
AppliedCustLedgEntryTemp.SETRANGE(Positive); AppliedCustLedgEntryTemp.FINDFIRST; END; IF (OldPmtDisc <> PmtDiscAmount) THEN ...Náhradní kód 2
...END ELSE BEGIN
AppliedCustLedgEntryTemp.SETRANGE(Positive); AppliedCustLedgEntryTemp.FINDFIRST; ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedCustLedgEntryTemp); END; IF (OldPmtDisc <> PmtDiscAmount) THEN ... -
Změňte kód ve funkci ExchangeAmountsOnLedgerEntry ve formuláři Vyrovnat položky zákazníka (232) takto:
Existující kód...CheckRounding;
END; BEGIN END. } ...Změněný kód
...CheckRounding;
END; LOCAL PROCEDURE ExchangeAmountsOnLedgerEntry@20(Type@1003 : 'Direct,GenJnlLine,SalesHeader';CurrencyCode@1000 : Code[10];VAR AppliedCustLedgEntryTemp@1001 : Record 21); VAR CalculateCurrency@1002 : Boolean; BEGIN AppliedCustLedgEntryTemp.CALCFIELDS("Remaining Amount"); IF Type = Type::Direct THEN CalculateCurrency := ApplyingCustLedgEntry."Entry No." <> 0 ELSE CalculateCurrency := TRUE; IF (CurrencyCode <> AppliedCustLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN AppliedCustLedgEntryTemp."Remaining Amount" := GenJnlPostLine.ExchAmount( AppliedCustLedgEntryTemp."Remaining Amount", AppliedCustLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible" := GenJnlPostLine.ExchAmount( AppliedCustLedgEntryTemp."Remaining Pmt. Disc. Possible", AppliedCustLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedCustLedgEntryTemp."Amount to Apply" := GenJnlPostLine.ExchAmount( AppliedCustLedgEntryTemp."Amount to Apply", AppliedCustLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); END; END; BEGIN END. } ... -
Změňte kód v dialogovém okně Vlastnosti ve formuláři Vyrovnat položky dodavatele (233) takto:
Existující kód...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Vend. Entry-Edit",Rec); EXIT(FALSE); END; ...Změněný kód
...OnModifyRecord=BEGIN
CODEUNIT.RUN(CODEUNIT::"Vend. Entry-Edit",Rec); IF "Applies-to ID" <> xRec."Applies-to ID" THEN CalcApplnAmount; EXIT(FALSE); END; ... -
Změňte kód ve funkci HandlChosenEntries ve formuláři Vyrovnat položky dodavatele (233) takto:
Existující kód 1...IF NOT FromZeroGenJnl THEN
AppliedVendLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0); IF AppliedVendLedgEntryTemp.FINDFIRST THEN BEGIN AppliedVendLedgEntryTemp.CALCFIELDS("Remaining Amount"); IF Type = Type::Direct THEN CalculateCurrency := ApplyingVendLedgEntry."Entry No." <> 0 ELSE CalculateCurrency := TRUE; IF (CurrencyCode <> AppliedVendLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN AppliedVendLedgEntryTemp."Remaining Amount" := GenJnlPostLine.ExchAmount( AppliedVendLedgEntryTemp."Remaining Amount", AppliedVendLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" := GenJnlPostLine.ExchAmount( AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible", AppliedVendLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedVendLedgEntryTemp."Amount to Apply" := GenJnlPostLine.ExchAmount( AppliedVendLedgEntryTemp."Amount to Apply", AppliedVendLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); END; CASE Type OF Type::Direct: ...Změněný kód 1
...IF NOT FromZeroGenJnl THEN
AppliedVendLedgEntryTemp.SETRANGE(Positive,CurrentAmount < 0); IF AppliedVendLedgEntryTemp.FINDFIRST THEN BEGIN ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedVendLedgEntryTemp); CASE Type OF Type::Direct: ...Existující kód 2
...END ELSE BEGIN
AppliedVendLedgEntryTemp.SETRANGE(Positive); AppliedVendLedgEntryTemp.FINDFIRST; END; IF (OldPmtdisc <> PmtDiscAmount) THEN ...Náhradní kód 2
...END ELSE BEGIN
AppliedVendLedgEntryTemp.SETRANGE(Positive); AppliedVendLedgEntryTemp.FINDFIRST; ExchangeAmountsOnLedgerEntry(Type,CurrencyCode,AppliedVendLedgEntryTemp); END; IF (OldPmtdisc <> PmtDiscAmount) THEN ... -
Změňte kód ve funkci ExchangeAmountsOnLedgerEntry ve formuláři Vyrovnat položky dodavatele (233) takto:
Existující kód...AppliesToID := AppliesToID2;
END; BEGIN END. } ...Změněný kód
...AppliesToID := AppliesToID2;
END; PROCEDURE ExchangeAmountsOnLedgerEntry@14(Type@1000 : 'Direct,GenJnlLine,PurchHeader';CurrencyCode@1001 : Code[10];VAR AppliedVendLedgEntryTemp@1002 : Record 25); VAR CalculateCurrency@1003 : Boolean; BEGIN AppliedVendLedgEntryTemp.CALCFIELDS("Remaining Amount"); IF Type = Type::Direct THEN CalculateCurrency := ApplyingVendLedgEntry."Entry No." <> 0 ELSE CalculateCurrency := TRUE; IF (CurrencyCode <> AppliedVendLedgEntryTemp."Currency Code") AND CalculateCurrency THEN BEGIN AppliedVendLedgEntryTemp."Remaining Amount" := GenJnlPostLine.ExchAmount( AppliedVendLedgEntryTemp."Remaining Amount", AppliedVendLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible" := GenJnlPostLine.ExchAmount( AppliedVendLedgEntryTemp."Remaining Pmt. Disc. Possible", AppliedVendLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); AppliedVendLedgEntryTemp."Amount to Apply" := GenJnlPostLine.ExchAmount( AppliedVendLedgEntryTemp."Amount to Apply", AppliedVendLedgEntryTemp."Currency Code", CurrencyCode,"Posting Date"); END; END; BEGIN END. } ...
Předpoklady
Musí mít jednu z následujících produktů nainstalovali tuto opravu hotfix:
-
Aplikace Microsoft Dynamics NAV 2009 R2
-
Aplikace Microsoft Dynamics NAV 2009 SP1
Informace o odinstalaci
Tato oprava hotfix nelze odebrat.
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.