En transaktion för en försäljningsfaktura som skapas för en anläggningstillgång skapas två incorreclty för transaktioner av vinst eller förlust om momsbeloppet för inköp av anläggningstillgången delvis dras av i den italienska versionen av Microsoft Dynamics NAV


Den här artikeln gäller för Microsoft Dynamics NAV för språk italienska (it).

Symptom


Anta att du har en anläggningstillgång i den italienska versionen av Microsoft Dynamics NAV. Moms (VAT) för inköp av anläggningstillgången är delvis dras av. I det här fallet skapar transaktionen för motsvarande faktura två transaktioner på vinst eller förlust i stället för en transaktion om du säljer en anläggningstillgång.
Det här problemet uppstår i följande produkter:
  • Den italienska versionen av Microsoft Dynamics NAV 2009 R2
  • Den italienska versionen av Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
  • Den italienska versionen av Microsoft Dynamics NAV 5.0 Service Pack 1 (SP1)

Lösning


Information om snabbkorrigeringen

En snabbkorrigering är nu tillgänglig från Microsoft. Den är endast avsedd att åtgärda det problem som beskrivs i denna artikel. Använd den bara på datorer där detta problem uppstår. Snabbkorrigeringen kan komma att testas igen. Om inte störs alltför mycket av detta problem rekommenderar vi att du väntar på Nästa service pack-versionen för Microsoft Dynamics NAV eller nästa Microsoft Dynamics NAV-version som innehåller den här snabbkorrigeringen.

Obs! I särskilda fall, de avgifter som är normalt för support vara avgiftsfri om en supporttekniker för Microsoft Dynamics och relaterade produkter som bestämmer att en särskild uppdatering kan lösa ditt problem. De vanliga supportkostnaderna gäller för övriga supportfrågor och problem som inte berör den särskilda uppdateringen.


Installationsinformation

Microsoft tillhandahåller programmeringsexempel endast utan garanti varken uttryckliga eller underförstådda. Detta inkluderar men är inte begränsat till, underförstådda garantier om säljbarhet eller lämplighet för ett särskilt ändamål. Den här artikeln förutsätter att du är bekant med det programmeringsspråk som demonstreras och de verktyg som används för att skapa och felsöka procedurer. Microsofts supporttekniker kan hjälpa till med att förklara funktionen hos en viss procedur, men kan inte ändra dessa exempel för att ge ytterligare funktioner eller skapa procedurer som motsvarar dina speciella behov.

Obs! Innan du installerar den här snabbkorrigeringen måste du kontrollera att alla användare av Microsoft Navision-klient har loggat ut. Detta inkluderar Microsoft Navision Application Services (NAS) klientanvändare. Du ska endast klientanvändare som är inloggad när du implementerar den här snabbkorrigeringen.

Om du vill genomföra den här snabbkorrigeringen måste du ha en utvecklarlicens.

Vi rekommenderar att tilldelas användarkontot i fönstret Windows-inloggningar eller i fönstret databasinloggningar "SUPER" roll-ID. Om användarkontot inte kan tilldelas "SUPER" roll-ID måste du kontrollera att användarkontot har följande behörigheter:
  • Ändra behörighet för objektet ändras.
  • Körbehörighet för systemet objektet ID 5210 objektet och objektet System objektet ID 9015 .


Obs! Du har inte behörighet för datalager inte data reparation.

Kod ändras

Obs! Alltid åtgärdas testa koden i en kontrollerad miljö innan du installerar korrigeringar för produktionsdatorer.
Lös problemet så här:
  1. Ändra koden i Data objekt nummer 3 i konto bok blad - Skriv ut rapport (12109) enligt följande:
    Befintlig kod
    ...CurrReport.CREATETOTALS(Amount,IcreasesAmnt,DecreasesAmnt,"Additional-Currency Amount");
    END;

    // Delete the following lines.
    OnAfterGetRecord=BEGIN
    CALCFIELDS(Amount,"Debit Amount","Credit Amount","Additional-Currency Amount");

    IF NOT UseAmtsInAddCurr THEN BEGIN
    Amnt := Amnt + Amount;
    IF Amount > 0 THEN
    IcreasesAmnt := Amount
    ELSE
    DecreasesAmnt := ABS(Amount);
    END ELSE BEGIN
    Amnt := Amnt + "Additional-Currency Amount";
    IF "Additional-Currency Amount" > 0 THEN
    IcreasesAmnt := "Additional-Currency Amount"
    ELSE
    DecreasesAmnt := ABS("Additional-Currency Amount");
    END;
    // End of the lines.

    END;

    DataItemLinkReference=G/L Account;
    ...
    Ersättningskod
    ...CurrReport.CREATETOTALS(Amount,IcreasesAmnt,DecreasesAmnt,"Additional-Currency Amount");
    END;

    // Add the following lines.
    OnAfterGetRecord=VAR
    GroupAmount@1130001 : Decimal;
    BEGIN
    CALCFIELDS(Amount,"Debit Amount","Credit Amount","Additional-Currency Amount");
    IF TempGLBookEntry.GET("Entry No.") THEN
    CurrReport.SKIP
    ELSE BEGIN
    GroupAmount := GroupBookEntry("GL Book Entry",UseAmtsInAddCurr);
    Amnt += GroupAmount;
    IF GroupAmount > 0 THEN BEGIN
    IcreasesAmnt := ABS(GroupAmount);
    DecreasesAmnt := 0;
    END ELSE BEGIN
    IcreasesAmnt := 0;
    DecreasesAmnt := ABS(GroupAmount);
    END;
    END;
    // End of the lines.

    END;

    DataItemLinkReference=G/L Account;
    ...
  2. Ändra koden i Data objekt nummer 3 avsnitt i boken bladet konto - Skriv ut rapport (12109) enligt följande:
    Befintlig kod
    ...{ 1130104;TextBox ;18000;423 ;1800 ;423 ;SourceExpr=Amnt;
    AutoFormatType=1;
    DataSetFieldName=Amnt_Control1130104 }

    // Delete the following line.
    { 1130105;TextBox ;18000;846 ;1800 ;423 ;SourceExpr=StartOnHand + Amount;

    AutoFormatType=1;
    DataSetFieldName=StartOnHand___Amount_Control1130105 }
    ...
    Ersättningskod
    ...{ 1130104;TextBox ;18000;423 ;1800 ;423 ;SourceExpr=Amnt;
    AutoFormatType=1;
    DataSetFieldName=Amnt_Control1130104 }

    // Add the following line.
    { 1130105;TextBox ;18000;846 ;1800 ;423 ;SourceExpr=StartOnHand + IcreasesAmnt - DecreasesAmnt;

    AutoFormatType=1;
    DataSetFieldName=StartOnHand___Amount_Control1130105 }
    { 1130111;TextBox ;0 ;846 ;150 ;423 ;Name=TotalAmount;
    ...
  3. Lägg till en ny global variabel i konto bok blad - Skriv ut rapport (12109) och ange variabeln enligt följande:
    • Namn: TempGLBookEntry
    • Datatyp: temporär post
    • Undertyp: post för GL-bok (12144)
  4. Lägga till en lokal funktion i konto bok blad - Skriv ut rapport (12109) enligt följande:
    LOCAL PROCEDURE GroupBookEntry@1130001(GLBookEntry@1130001 : Record 12144;UseAmtsInAddCurr@1130002 : Boolean) GroupAmount@1130003 : Decimal;VAR
    GLBookEntry1@1130004 : Record 12144;
    BEGIN
    GLBookEntry1.SETRANGE("G/L Account No.",GLBookEntry."G/L Account No.");
    GLBookEntry1.SETRANGE("Transaction No.",GLBookEntry."Transaction No.");
    IF GLBookEntry1.FINDSET THEN
    REPEAT
    TempGLBookEntry."Entry No." := GLBookEntry1."Entry No.";
    TempGLBookEntry.INSERT;
    GLBookEntry1.CALCFIELDS(Amount,"Additional-Currency Amount");
    IF UseAmtsInAddCurr THEN
    GroupAmount := GroupAmount + GLBookEntry1."Additional-Currency Amount"
    ELSE
    GroupAmount := GroupAmount + GLBookEntry1.Amount;
    UNTIL GLBookEntry1.NEXT = 0;
    EXIT(GroupAmount);
    END;
  5. Ändra koden i Data objekt nummer 2 i G/L-bok - Skriv ut rapport (12121) enligt följande:
    Befintlig kod 1
    ...END;
    END;

    // Delete the following lines.
    OnAfterGetRecord=BEGIN
    IF ReportType = ReportType::Reprint THEN
    LastNo := "Progressive No."
    ELSE
    LastNo := LastNo + 1;
    // End of the lines.

    TotalDebit := TotalDebit + "Debit Amount";
    TotalCredit := TotalCredit + "Credit Amount";
    ...
    Ersättningskod 1
    ...END;
    END;

    // Add the following lines.
    OnAfterGetRecord=VAR
    GroupAmount@1130001 : Decimal;
    BEGIN
    // End of the lines.

    TotalDebit := TotalDebit + "Debit Amount";
    TotalCredit := TotalCredit + "Credit Amount";
    ...
    Befintlig kod 2
    ...END;
    "Source Type" :: "Fixed Asset":
    BEGIN
    FA.GET("Source No.");
    Descr := FA.Description;
    END;
    ...
    Ersättningskod 2
    ...END;
    "Source Type" :: "Fixed Asset":
    BEGIN

    // Add the following lines.
    IF TempGLBookEntry.GET("Entry No.") THEN
    CurrReport.SKIP
    ELSE BEGIN
    GroupAmount := GroupBookEntry("GL Book Entry");
    IF GroupAmount > 0 THEN BEGIN
    "Debit Amount" := GroupAmount;
    "Credit Amount" := 0;
    END ELSE BEGIN
    "Debit Amount" := 0;
    "Credit Amount" := GroupAmount;
    END;
    END;
    // End of the lines.

    FA.GET("Source No.");
    Descr := FA.Description;
    END;
    ...
    Befintlig kod 3
    ...ELSE
    Descr := '';
    END;


    IF (NOT CurrReport.PREVIEW) AND
    (ReportType = ReportType::"Final Print")
    THEN BEGIN
    ...
    Ersättningskod 3
    ...ELSE
    Descr := '';
    END;

    // Add the following lines.
    IF ReportType = ReportType::Reprint THEN
    LastNo := "Progressive No."
    ELSE
    LastNo := LastNo + 1;
    // End of the lines.

    IF (NOT CurrReport.PREVIEW) AND
    (ReportType = ReportType::"Final Print")
    THEN BEGIN
    ...
  6. Lägga till en ny global variabel i den boken Redovisning - Skriv ut rapport (12121) och ange variabeln enligt följande:
    • Namn: TempGLBookEntry
    • Datatyp: temporär post
    • Undertyp: post för GL-bok (12144)
  7. Ändra koden i dokumentationen i G/L-bok - Skriv ut rapport (12121) enligt följande:
    Befintlig kod
    ...EndDate := Date."Period Start" - 1;
    END;
    ...
    Ersättningskod
    ...EndDate := Date."Period Start" - 1;
    END;

    // Add the following lines.
    LOCAL PROCEDURE GroupBookEntry@1130002(GLBookEntry@1130001 : Record 12144) GroupAmount@1130002 : Decimal;
    VAR
    GLBookEntry1@1130003 : Record 12144;
    BEGIN
    GLBookEntry1.SETRANGE("G/L Account No.",GLBookEntry."G/L Account No.");
    GLBookEntry1.SETRANGE("Transaction No.",GLBookEntry."Transaction No.");
    IF GLBookEntry1.FINDSET THEN
    REPEAT
    TempGLBookEntry."Entry No." := GLBookEntry1."Entry No.";
    TempGLBookEntry.INSERT;
    GLBookEntry1.CALCFIELDS(Amount);
    GroupAmount := GroupAmount + GLBookEntry1.Amount;
    UNTIL GLBookEntry1.NEXT = 0;
    EXIT(GroupAmount);
    END;
    // End of the lines.
    ...

Förutsättningar

Du måste ha någon av följande produkter som har installerat den här snabbkorrigeringen:
  • Den italienska versionen av Microsoft Dynamics NAV 2009 R2
  • Den italienska versionen av Microsoft Dynamics NAV 2009 Service Pack 1 (SP1)
  • Den italienska versionen av Microsoft Dynamics NAV 5.0 Service Pack 1 (SP1)

Information om borttagning

Du kan inte ta bort den här snabbkorrigeringen.

Status


Microsoft har bekräftat att detta är ett problem i Microsoft-produkterna som nämns i avsnittet "Gäller".
Obs! Detta är en "SNABBPUBLICERING"-artikel skapad direkt från Microsoft support-organisationen. Informationen häri tillhandahålls i befintligt skick som svar på nya problem. Till följd av hastigheten för att göra det tillgängligt kan materialet innehålla typografiska fel och kan ändras när som helst utan föregående meddelande. Se Villkoren för användning för andra överväganden.