Ten artykuł dotyczy systemu Microsoft Dynamics NAV dla ustawień regionalnych języka włoski (it).
Objawy
Po post i rozliczyć zwrot z faktury korygującej dostawcy, raport Lista BOM konta dostawcy (12116) nie pokazuje faktura korygująca. Ten problem występuje w następujących produktach:
-
W wersji włoskiej dla systemu Microsoft Dynamics NAV 2009 R2
-
Włoskiej wersji dodatku Service Pack 1 dla systemu Microsoft Dynamics NAV 2009
Rozwiązanie
Informacje o poprawce
Obsługiwana poprawka jest obecnie udostępniana przez firmę Microsoft. Jednak to jest przeznaczona tylko do usunięcia problemu opisanego w tym artykule. Zastosuj ją tylko w systemach, w których występuje ten problem. Ta poprawka może być wciąż w fazie testowania. Jeśli dany system nie jest poważnie narażony na ten problem, firma Microsoft zaleca, aby poczekać na następny dodatek service pack dla systemu Microsoft Dynamics NAV 2009 lub następną wersję systemu Microsoft Dynamics NAV, zawierający tę poprawkę.
Uwaga W wyjątkowych przypadkach opłaty, telefonujący do pomocy technicznej mogą zostać anulowane, jeśli pomocy technicznej dla systemu Microsoft Dynamics i produktów powiązanych Określa, że określonej aktualizacji, można rozwiązać swój problem. Koszty obsługi zwykłych zastosuje się do dodatkowych pytań i problemów, których nie można rozwiązać przy użyciu określonej aktualizacji.
Informacje dotyczące instalacji
Firma Microsoft podaje przykłady programowania wyłącznie, bez jakichkolwiek gwarancji wyrażonych wprost lub domyślnie. To obejmuje, ale nie jest ograniczona, ustawowej rękojmi co do przydatności handlowej lub przydatności do określonego celu. W tym artykule założono, że użytkownik zna demonstrowany język programowania oraz narzędzia, które są używane do tworzenia i debugowania procedur. Wykwalifikowani pracownicy pomocy technicznej firmy Microsoft mogą pomóc w wyjaśnieniu, jak działa określona procedura. Nie będą jednak modyfikować tych przykładów ani dodawać funkcjonalności i konstruować procedur w celu zaspokojenia określonych potrzeb użytkownika.
Uwaga Przed zainstalowaniem tej poprawki należy zweryfikować, że wszyscy użytkownicy klienta Microsoft Navision są wylogowani systemu. Dotyczy to również użytkowników klienta Microsoft Navision Application Services (NAS). Powinny być użytkownika klienta, który jest zalogowany w momencie wdrożyć tę poprawkę.
Aby wdrożyć tę poprawkę, musi mieć licencję deweloperską.
Firma Microsoft zaleca, aby do konta użytkownika w oknie identyfikatorów logowania systemu Windows lub w oknie identyfikatorów logowania bazy danych być przypisany identyfikator roli "SUPER". Jeśli konto użytkownika nie można przypisać Identyfikatora roli "SUPER", należy sprawdzić, czy konto użytkownika ma następujące uprawnienia:
-
Uprawnienie Modyfikacja dla obiektu, który będzie zmieniany.
-
Uprawnienie Execute obiektu 5210 identyfikator obiektu systemu i dla obiektu 9015 identyfikator obiektu systemu .
Uwaga Nie trzeba mieć prawa do magazynów danych, chyba że konieczne jest przeprowadzenie naprawy danych.
Zmiany kodu
Uwaga zawsze test poprawki kodu w kontrolowanym środowisku przed zastosowaniem poprawki na komputerach produkcyjnych. Aby rozwiązać ten problem, wykonaj następujące kroki:
-
Zmień kod w raporcie Lista BOM konta dostawcy (12116) w następujący sposób:
Istniejący kod 1... OnAfterGetRecord=BEGIN
CALCFIELDS("Amount (LCY)","Remaining Amt. (LCY)");
// Delete the following line.
IF ((OnlyOpened) OR ("Document Type" IN ["Document Type"::Payment,"Document Type"::"Credit Memo","Document Type"::" "])) AND
("Remaining Amt. (LCY)" = 0)
THEN
CurrReport.SKIP;
...Kod zastępczy 1
... OnAfterGetRecord=BEGIN
CALCFIELDS("Amount (LCY)","Remaining Amt. (LCY)");
// Add the following line.
IF ((OnlyOpened) OR ("Document Type" IN ["Document Type"::Payment,"Document Type"::Refund,"Document Type"::" "])) AND
("Remaining Amt. (LCY)" = 0)
THEN
CurrReport.SKIP;
...Istniejący kod 2
... RemainingAmountLCY := 0;
VendorBillAmnt := 0;
// Delete the following lines.
IF ("Document Type" = "Document Type"::Invoice) OR
("Document Type" = "Document Type"::"Finance Charge Memo") OR
("Document Type" = "Document Type"::Reminder)
// End of the lines.
THEN BEGIN
//TotalClosedByAmntLCY := "Remaining Amt. (LCY)"; //IT0002 - IT0004
TotalForVendor := TotalForVendor + "Amount (LCY)";
...Kod zastępczy 2
... RemainingAmountLCY := 0;
VendorBillAmnt := 0;
// Add the following lines.
IF "Document Type" IN
["Document Type"::Invoice,
"Document Type"::"Credit Memo",
"Document Type"::"Finance Charge Memo",
"Document Type"::Reminder]
// End of the lines.
THEN BEGIN
//TotalClosedByAmntLCY := "Remaining Amt. (LCY)"; //IT0002 - IT0004
TotalForVendor := TotalForVendor + "Amount (LCY)";
...Istniejący kod 3
... END;
OnAfterGetRecord=BEGIN
// IT0003.begin
VendLedgEntry3.GET("Applied Vend. Ledger Entry No.");
VendLedgEntry3.CALCFIELDS("Original Amt. (LCY)");
...Kod zastępczy 3
... END;
OnAfterGetRecord=BEGIN
// Add the following lines.
IF ("Entry No." = 0) OR ("Unapplied by Entry No." <> 0) OR
("Document Type" IN ["Document Type"::Payment,"Document Type"::Refund,"Document Type"::" "])
THEN
ShowDetailedVendorLedgerEntry := TRUE
ELSE
ShowDetailedVendorLedgerEntry := FALSE;
// End of the lines.
// IT0003.begin
VendLedgEntry3.GET("Applied Vend. Ledger Entry No.");
VendLedgEntry3.CALCFIELDS("Original Amt. (LCY)");
...Istniejący kod 4
... SectionWidth=27750;
SectionHeight=846;
OnPreSection=BEGIN
// Delete the following lines.
// IT0008.begin
// IT0011.begin
IF (VendLedgEntry1."Document Type" = VendLedgEntry1."Document Type"::Payment) OR
(VendLedgEntry1."Document Type" = VendLedgEntry1."Document Type"::"Credit Memo") OR
(VendLedgEntry1."Document Type" = VendLedgEntry1."Document Type"::" ") OR
("Unapplied by Entry No." <> 0)
THEN
// IT0011.end
CurrReport.SHOWOUTPUT(FALSE)
ELSE
CurrReport.SHOWOUTPUT(TRUE);
// IT0008.end
// IT0009.begin
//IF ("Unapplied by Entry No." <> 0) THEN
// CurrReport.SHOWOUTPUT(FALSE);
// IT0009.end
// End of the lines.
END;
}
...Kod zastępczy 4
... SectionWidth=27750;
SectionHeight=846;
OnPreSection=BEGIN
// Add the following line.
CurrReport.SHOWOUTPUT(ShowDetailedVendorLedgerEntry)
END;
}
...Istniejący kod 5
... ForeColor=65535;
SourceExpr="Unapplied by Entry No.";
DataSetFieldName=Detailed_Vendor_Ledg__Entry__Unapplied_by_Entry_No__ }
}
}
{ PROPERTIES
...Kod zastępczy 5
... ForeColor=65535;
SourceExpr="Unapplied by Entry No.";
DataSetFieldName=Detailed_Vendor_Ledg__Entry__Unapplied_by_Entry_No__ }
// Add the following lines.
{ 1130084;TextBox ;27150;0 ;150 ;423 ;Visible=No;
SourceExpr=ShowDetailedVendorLedgerEntry;
DataSetFieldName=ShowDetailedVendorLedgerEntry }
// End of the lines.
}
}
{ PROPERTIES
... -
Zmień kod w zmiennych globalnych w raporcie Lista BOM konta dostawcy (12116) w następujący sposób:
Istniejący kod... TotalVendorBillAmnt@1130010 : Decimal;
VendLedgEntry3@1130011 : Record 25;
VendorLedgerEmtryTypeINT@1102601000 : Integer;
BEGIN
{
...Kod zastępczy
... TotalVendorBillAmnt@1130010 : Decimal;
VendLedgEntry3@1130011 : Record 25;
VendorLedgerEmtryTypeINT@1102601000 : Integer;
// Add the following line.
ShowDetailedVendorLedgerEntry@1130012 : Boolean INDATASET;
BEGIN
{
... -
Zmień kod w raporcie Lista BOM konta dostawcy (12116) w następujący sposób:
Istniejący kod 1... </TableCell>
</TableCells>
<Visibility>
// Delete the following lines.
<Hidden>=IIF(Fields!Detailed_Vendor_Ledg__Entry_Entry_No_.Value=0 OR
Fields!Detailed_Vendor_Ledg__Entry__Unapplied_by_Entry_No__.Value<>0 OR
Fields!VendLedgEntry1_DocumentType.Value="1" OR
Fields!VendLedgEntry1_DocumentType.Value="3" OR
Fields!VendLedgEntry1_DocumentType.Value="0",
TRUE,FALSE)</Hidden>
// End of the lines.
</Visibility>
</TableRow>
<TableRow>
...Kod zastępczy 1
... </TableCell>
</TableCells>
<Visibility>
// Add the following line.
<Hidden>=IIF(Fields!ShowDetailedVendorLedgerEntry.Value,TRUE,FALSE)</Hidden>
</Visibility>
</TableRow>
<TableRow>
...Istniejący kod 2
... <Field Name="Detailed_Vendor_Ledg__Entry_Vendor_Ledger_Entry_No_">
<DataField>Detailed_Vendor_Ledg__Entry_Vendor_Ledger_Entry_No_</DataField>
</Field>
</Fields>
<Query>
<CommandText />
...Kod zastępczy 2
... <Field Name="Detailed_Vendor_Ledg__Entry_Vendor_Ledger_Entry_No_">
<DataField>Detailed_Vendor_Ledg__Entry_Vendor_Ledger_Entry_No_</DataField>
</Field>
// Add the following lines.
<Field Name="ShowDetailedVendorLedgerEntry">
<DataField>ShowDetailedVendorLedgerEntry</DataField>
</Field>
// End of the lines.
</Fields>
<Query>
<CommandText />
...
Wymagania wstępne
Musi mieć jedną z następujących produktów, w celu zastosowania tej poprawki:
-
W wersji włoskiej dla systemu Microsoft Dynamics NAV 2009 R2
-
Włoskiej wersji dodatku Service Pack 1 dla systemu Microsoft Dynamics NAV 2009
Informacje dotyczące usuwania
Nie można usunąć tej poprawki.
Stan
Firma Microsoft potwierdziła, że jest to problem występujący w produktach firmy Microsoft wymienionych w sekcji „Dotyczy”.
Uwaga Jest to artykuł " szybkiej publikacji" tworzony bezpośrednio przez organizację pomocy technicznej firmy Microsoft. Informacje zawarte w niniejszym dokumencie są dostarczane jako odpowiedź na pojawiające się problemy. W wyniku przyspieszonego udostępnienia, materiały te mogą zawierać błędy typograficzne i mogą być zmieniane w dowolnym czasie bez uprzedzenia. Zobacz Warunki użytkowania w celu uzyskania innych informacji.