|
C++ |
|
#include "stdafx.h"
#include "CppClient.h"
#ifdef _DEBUG
#define new DEBUG_NEW
#endif
#include <atlbase.h>
#include <ATLComTime.h>
#import "Venice\Bin\ClSdk.dll"
using namespace std;
using namespace ClSdk;
int _tmain(int argc, TCHAR* argv[], TCHAR* envp[])
{
OleInitialize (NULL);
try
{
// These are not 'real' pointers, but 'smart' pointers, looking as pointers but acting as objects, so do not use 'delete'!
IVenicePtr pVenice;
IDossierPtr pDossier;
IYearPtr pYear;
ISalesPtr pSales;
ICustmPtr pCustm;
eAccessMode eAM;
// Create the Venice object interface
pVenice.CreateInstance(__uuidof(ClSdk::Venice));
// Is option 'Access Management' installed?
eAM = pVenice->GetAccessMode ();
// Logon into Venice, allowing user interface
if (eAM == amSecure)
pVenice->LogonSecure ("13.40_", "MyApplication", lngNld, true, "ClSdkUser", "ClSdkPassword");
else
pVenice->Logon ("13.40_", "MyApplication", lngNld, true, "SDK", "ClSdkUser", "Software engineer");
// Create Dossier Context, use the default filing cabinet 'Data' and the dossier 'MyCompany'
pDossier = pVenice->CreateDossierContext("", "MyCompany");
// Create Year Context
pYear = pDossier->CreateYearContext (2025);
// ----------------------------------------------------------------------------------------------------
// This example creates a sales invoice document with analytical information. Adding Intrastat
// details is also listed but commented out.
// ----------------------------------------------------------------------------------------------------
// Create context for sales documents
pSales = pYear->CreateSales (true);
// Create context for customers
pCustm = pDossier->CreateCustm (false);
// Prepare the creation of a new Sales document.
pSales->PrepareDocument (paInsert);
// Initialize with default values.
pSales->Init ();
// In order to obtain a valid sales document header, the following properties must be assigned a value:
// Customer number, Document type (invoice by default), book, Book date, Document date, Total amount and Currency, at least one of the VAT bases and at least one of the VAT amounts.
// This does not imply however that these properties need to be set in code, they can also be assigned via the standard values.
// Note: A document number is not required. If it is set to 0, a new successive number for the given book will be assigned automatically.
// Note: While those are the only properties that are required to be filled in, other properties may require a value for the document to pass the internal validation checks.
// These are the same validation checks that are applied when manually entering a document in Venice.
pSales->pCstNum = 214;
pSales->pCstSubNum = 0;
pSales->pDocType = slsInvoice; // or slsCreditnote, slsTransfer
pSales->pBook = "FAC";
pSales->pDocNum = 0; // 0 = Automatically determine the document number
pSales->pBookDate = COleDateTime (2025, 8, 23, 0, 0, 0).m_dt;
pSales->pDocDate = COleDateTime (2025, 8, 14, 0, 0, 0).m_dt;
pSales->pExpDate = COleDateTime (2025, 9, 14, 0, 0, 0).m_dt;
pSales->pTotalDocC = 2710.40; // Positive for sales invoices and transfers. Negative for creditnotes.
pSales->pCurrency = "EUR";
// Assign (at least) one of the VAT bases: this value is positive for sales invoices and transfers, negative for creditnotes.
pSales->pBaseVat1DocC = 0.00; // at 0% VAT
pSales->pBaseVat2DocC = 0.00; // at 6% VAT
pSales->pBaseVat3DocC = 0.00; // at 12% VAT
pSales->pBaseVat4DocC = 2240.00; // at 21% VAT
pSales->pBaseVat5DocC = 0.00; // currently unused in Belgium
pSales->pBaseVat6DocC = 0.00; // currently unused in Belgium
pSales->pBaseCoPartDocC = 0.00;
pSales->pBaseIcGoodsDocC = 0.00;
pSales->pBaseIcAssmDistDocC = 0.00;
pSales->pBaseIcServicesDocC = 0.00;
pSales->pBaseExportDocC = 0.00;
pSales->pBaseForeignVatDocC = 0.00;
pSales->pBaseFinDiscountDocC = 0.00;
pSales->pBaseNotSubmitDocC = 0.00;
// Assign (at least) one of the VAT amounts: this value is positive for sales invoices and transfers, negative for creditnotes.
pSales->pVatDueNormDocC = 470.40;
pSales->pVatDedNormDocC = 0.00;
// Manually entering a document in Venice provides a number of automatic assignments. These do not get applied when creating a document via the SDK.
// The following code performs those assignments:
if (pCustm->SeekByCstNum (smEqual, pSales->pCstNum, pSales->pCstSubNum))
{
pSales->pClass = pCustm->pClass;
pSales->pStatCode = pCustm->pStat;
if ((BYTE)pCustm->pStandardBase >= asbBase0 && (BYTE)pCustm->pStandardBase <= asbBase5)
pSales->pVatCode = pCustm->pStandardBase;
pSales->pFinDiscount = pCustm->pFinDiscount;
pSales->pRepresentative = pCustm->pRepresentative;
pSales->pReminder = pCustm->pReminders;
}
// Add your code here for assigning additional properties of the document header.
// pSales->Xxx = yyy;
// Create detail lines and analytical information for each detail line.
pSales->InsertDetail (0, -2000.00, 0.00, 0.00, "701", "FLC209 Heating unit", "");
// Analytical details for centre (only when desired and when the option 'Analytical' is installed)
pSales->InsertAnaDetail (0, 0, aetCent, -2000.00 * 60/100, 0.00, 60, 0.00, "Sales.NatalieR", "Merchandise", "", "");
pSales->InsertAnaDetail (0, 1, aetCent, -2000.00 * 40/100, 0.00, 40, 0.00, "Sales.KarelM", "Merchandise", "", "");
// Analytical details for unit
pSales->InsertAnaDetail (0, 0, aetUnit, -2000.00 * 15/100, 0.00, 15, 0.00, "Admin", "Merchandise", "", "");
pSales->InsertAnaDetail (0, 1, aetUnit, -2000.00 * 85/100, 0.00, 85, 0.00, "Production", "Merchandise", "", "");
pSales->InsertDetail (1, -240.00, 0.00, 0.00, "702", "Installation and setup (3 hours)", "");
// Analytical details for centre
pSales->InsertAnaDetail (1, 0, aetCent, -240.00 * 100/100, 0.00, 100, 0.00, "Maint.PeterVH", "Services", "", "");
// Analytical details for unit
pSales->InsertAnaDetail (1, 0, aetUnit, -240.00 * 10/100, 0.00, 10, 0.00, "Admin", "Services", "", "");
pSales->InsertAnaDetail (1, 1, aetUnit, -240.00 * 90/100, 0.00, 90, 0.00, "Maintenance", "Services", "", "");
// If you have the option Intrastat, you can also add Intrastat details. In order to do this, there must be an IC relation between the company and the customer
// (= They must have enterprise numbers from differing countries in the European Community).
//pSales->InsertItrDetail (0, 2500.00, 0.00, 0.00, spDispatch, ntrNormal_Bussiness, reFlanders, trRoad, dcFCA, "85203219", "FR", "US");
//pSales->InsertItrDetail (1, 1300.00, 0.00, 0.00, spDispatch, ntrNormal_Bussiness, reFlanders, trRoad, dcFCA, "85203219", "FR", "CO");
// Write (or cancel) the document
pSales->WriteDocument (rmErrorReport);
// If you do not use WriteDocument() because you do not want to save the document (maybe because of an error) you should call CancelDocument() instead.
}
catch (_com_error CE)
{
printf ("\nError while executing application.\nReason: %s\nSource: %s", (LPCSTR)CE.Description (), (LPCSTR)CE.Source ());
}
// All objects must be out of scope (or destroyed) before calling OleUninitialize ()!
OleUninitialize ();
}
|
|
C# |
|
using System;
using ClSdk;
namespace Example
{
class Example
{
[STAThread]
static void Main(string[] args)
{
try
{
eAccessMode eAM;
// Create the Venice object
Venice oVenice = new Venice();
// Is option 'Access Management' installed?
eAM = oVenice.GetAccessMode ();
// Logon into Venice, allowing user interface
if (eAM == eAccessMode.amSecure)
oVenice.LogonSecure ("13.40_", "MyApplication", eLanguage.lngNld, true, "ClSdkUser", "ClSdkPassword");
else
oVenice.Logon ("13.40_", "MyApplication", eLanguage.lngNld, true, "SDK", "ClSdkUser", "Software engineer");
// Create Dossier Context, use the default filing cabinet 'Data' and the dossier 'MyCompany'
Dossier oDossier = oVenice.CreateDossierContext ("", "MyCompany");
// Create Year Context
Year oYear = oDossier.CreateYearContext (0);
// ----------------------------------------------------------------------------------------------------
// This example creates a sales invoice document with analytical information. Adding Intrastat
// details is also listed but commented out.
// ----------------------------------------------------------------------------------------------------
// Create context for sales documents
Sales oSales = oYear.CreateSales (true);
// Create context for customers
Custm oCustm = oDossier.CreateCustm (false);
// Prepare the creation of a new Sales document.
oSales.PrepareDocument (ePrepareAction.paInsert);
// Initialize with default values.
oSales.Init ();
// In order to obtain a valid sales document header, the following properties must be assigned a value:
// Customer number, Document type (invoice by default), book, Book date, Document date, Total amount and Currency, at least one of the VAT bases and at least one of the VAT amounts.
// This does not imply however that these properties need to be set in code, they can also be assigned via the standard values.
// Note: A document number is not required. If it is set to 0, a new successive number for the given book will be assigned automatically.
// Note: While those are the only properties that are required to be filled in, other properties may require a value for the document to pass the internal validation checks.
// These are the same validation checks that are applied when manually entering a document in Venice.
oSales.pCstNum = 214;
oSales.pCstSubNum = 0;
oSales.pDocType = eSalesDocType.slsInvoice; // or slsCreditnote, slsTransfer
oSales.pBook = "FAC";
oSales.pDocNum = 0; // 0 = Automatically determine the document number
oSales.pBookDate = new DateTime (2025, 8, 23);
oSales.pDocDate = new DateTime (2025, 8, 14);
oSales.pExpDate = new DateTime (2025, 9, 14);
oSales.pTotalDocC = 2710.40; // Positive for sales invoices and transfers. Negative for creditnotes.
oSales.pCurrency = "EUR";
// Assign (at least) one of the VAT bases: this value is positive for sales invoices and transfers, negative for creditnotes.
oSales.pBaseVat1DocC = 0.00; // at 0% VAT
oSales.pBaseVat2DocC = 0.00; // at 6% VAT
oSales.pBaseVat3DocC = 0.00; // at 12% VAT
oSales.pBaseVat4DocC = 2240.00; // at 21% VAT
oSales.pBaseVat5DocC = 0.00; // currently unused in Belgium
oSales.pBaseVat6DocC = 0.00; // currently unused in Belgium
oSales.pBaseCoPartDocC = 0.00;
oSales.pBaseIcGoodsDocC = 0.00;
oSales.pBaseIcAssmDistDocC = 0.00;
oSales.pBaseIcServicesDocC = 0.00;
oSales.pBaseExportDocC = 0.00;
oSales.pBaseForeignVatDocC = 0.00;
oSales.pBaseFinDiscountDocC = 0.00;
oSales.pBaseNotSubmitDocC = 0.00;
// Assign (at least) one of the VAT amounts: this value is positive for sales invoices and transfers, negative for creditnotes.
oSales.pVatDueNormDocC = 470.40;
oSales.pVatDedNormDocC = 0.00;
// Manually entering a document in Venice provides a number of automatic assignments. These do not get applied when creating a document via the SDK.
// The following code performs those assignments:
if (oCustm.SeekByCstNum (eSeekMode.smEqual, (int)oSales.pCstNum, (int)oSales.pCstSubNum))
{
oSales.pClass = oCustm.pClass;
oSales.pStatCode = oCustm.pStat;
if ((eAsalsBase)oCustm.pStandardBase >= eAsalsBase.asbBase0 && (eAsalsBase)oCustm.pStandardBase <= eAsalsBase.asbBase5)
oSales.pVatCode = oCustm.pStandardBase;
oSales.pFinDiscount = oCustm.pFinDiscount;
oSales.pRepresentative = oCustm.pRepresentative;
oSales.pReminder = oCustm.pReminders;
}
// Add your code here for assigning additional properties of the document header.
// oSales.Xxx = yyy;
// Create detail lines and analytical information for each detail line.
oSales.InsertDetail (0, -2000.00, 0.00, 0.00, "701", "FLC209 Heating unit", "");
// Analytical details for centre (only when desired and when the option 'Analytical' is installed)
oSales.InsertAnaDetail (0, 0, eAnaEntType.aetCent, -2000.00 * 60/100, 0.00, 60, 0.00, "Sales.NatalieR", "Merchandise", "", "");
oSales.InsertAnaDetail (0, 1, eAnaEntType.aetCent, -2000.00 * 40/100, 0.00, 40, 0.00, "Sales.KarelM", "Merchandise", "", "");
// Analytical details for unit
oSales.InsertAnaDetail (0, 0, eAnaEntType.aetUnit, -2000.00 * 15/100, 0.00, 15, 0.00, "Admin", "Merchandise", "", "");
oSales.InsertAnaDetail (0, 1, eAnaEntType.aetUnit, -2000.00 * 85/100, 0.00, 85, 0.00, "Production", "Merchandise", "", "");
oSales.InsertDetail (1, -240.00, 0.00, 0.00, "702", "Installation and setup (3 hours)", "");
// Analytical details for centre
oSales.InsertAnaDetail (1, 0, eAnaEntType.aetCent, -240.00 * 100/100, 0.00, 100, 0.00, "Maint.PeterVH", "Services", "", "");
// Analytical details for unit
oSales.InsertAnaDetail (1, 0, eAnaEntType.aetUnit, -240.00 * 10/100, 0.00, 10, 0.00, "Admin", "Services", "", "");
oSales.InsertAnaDetail (1, 1, eAnaEntType.aetUnit, -240.00 * 90/100, 0.00, 90, 0.00, "Maintenance", "Services", "", "");
// If you have the option Intrastat, you can also add Intrastat details. In order to do this, there must be an IC relation between the company and the customer
// (= They must have enterprise numbers from differing countries in the European Community).
//oSales.InsertItrDetail (0, 2500.00, 0.00, 0.00, eStatProc.spDispatch, eNatTrans.ntrNormal_Bussiness, eRegion.reFlanders, eTransport.trRoad, eDelivCond.dcFCA, "85203219", "FR", "US");
//oSales.InsertItrDetail (1, 1300.00, 0.00, 0.00, eStatProc.spDispatch, eNatTrans.ntrNormal_Bussiness, eRegion.reFlanders, eTransport.trRoad, eDelivCond.dcFCA, "85203219", "FR", "CO");
// Write (or cancel) the document
oSales.WriteDocument (eReportMode.rmErrorReport);
// If you do not use WriteDocument() because you do not want to save the document (maybe because of an error) you should call CancelDocument() instead.
}
catch (Exception ex)
{
Console.WriteLine ("Error while executing application.\nReason:" + ex.Message + "\nSource: " + ex.Source);
}
}
}
}
|
|
VBS |
|
Const amMin = -1
Const amNormal = 0
Const amSecure = 1
Const amMax = 2
Const lngMin = 0
Const lngNld = 0
Const lngFra = 1
Const lngEngNld = 2
Const lngEngFra = 3
Const lngAuto = 4
Const lngMax = 5
Const paMin = 0
Const paInsert = 0
Const paDuplicate = 1
Const paUpdate = 2
Const paView = 3
Const paMax = 4
Const rmMin = 0
Const rmNoReport = 0
Const rmErrorReport = 1
Const rmFullReport = 2
Const rmMax = 3
Const smMin = 0
Const smFirst = 0
Const smLess = 1
Const smLessOrEqual = 2
Const smEqual = 3
Const smGreaterOrEqual = 4
Const smGreater = 5
Const smLast = 6
Const smMax = 7
Const slsMin = 0
Const slsInvoice = 0
Const slsCreditnote = 1
Const slsTransfer = 2
Const slsMax = 3
Const aetMin = 0
Const aetCent = 0
Const aetUnit = 1
Const aetMax = 2
Const ccMin = 0
Const ccNone = 0
Const ccConstituent = 1
Const ccBeneficiary = 2
Const ccMax = 3
Const spArrival = 19
Const spDispatch = 29
Const ntrMin = 1
Const ntrNormal = 1
Const ntrReturn = 2
Const ntrFree = 3
Const ntrPreProc = 4
Const ntrPostProc = 5
Const ntrRepair = 6
Const ntrDefence = 7
Const ntrBuilding = 8
Const ntrOther = 9
Const ntrNormal_Bussiness = 11
Const ntrNormal_Consumer = 12
Const ntrReturn_Goods = 21
Const ntrReturn_Replace = 22
Const ntrReturn_NonReturn = 23
Const ntrFree_Warehouse = 31
Const ntrFree_Trial = 32
Const ntrFree_Leasing = 33
Const ntrFree_Free = 34
Const ntrPreProc_Return = 41
Const ntrPreProc_NoReturn = 42
Const ntrPostProc_Return = 51
Const ntrPostProc_NoReturn = 52
Const ntrRepair_Repair = 60
Const ntrClearance_Release = 71
Const ntrClearance_OtherMember = 72
Const ntrBuilding_Building = 80
Const ntrOther_Other24Month = 91
Const ntrOther_Other = 99
Const ntrMax = 100
Const reMin = 1
Const reFlanders = 1
Const reWallonia = 2
Const reBrussels = 3
Const reMax = 4
Const trMin = 1
Const trSea = 1
Const trTrack = 2
Const trRoad = 3
Const trAir = 4
Const trPost = 5
Const trUnused = 6
Const trFixed = 7
Const trRiver = 8
Const trOwn = 9
Const trMax = 10
Const dcMin = 0
Const dcEXW = 0
Const dcFCA = 1
Const dcFAS = 2
Const dcFOB = 3
Const dcCFR = 4
Const dcCIF = 5
Const dcCPT = 6
Const dcCIP = 7
Const dcDAF = 8
Const dcDES = 9
Const dcDEQ = 10
Const dcDDU = 11
Const dcDDP = 12
Const dcXXX = 13
Const dcMax = 14
' Call main
Main
sub Main
Dim oVenice
Dim oDossier
Dim oYear
' Create Venice object
Set oVenice = CreateObject("Clsdk.Venice")
' Dummy code to activate Intellisense
If False Then
Set oDossier = CreateObject("ClSdk.Dossier")
Set oYear = CreateObject("ClSdk.Year")
Set oSales = CreateObject("ClSdk.Sales")
Set oCustm = CreateObject("ClSdk.Custm")
End If
' Login
If oVenice.GetAccessMode() = amSecure Then
Call oVenice.LogonSecure("13.40_", "MyApplication", lngNld, true, "ClSdkUser", "ClSdkPassword")
Else
Call oVenice.Logon("13.40_", "MyApplication", lngNld, true, "SDK", "ClSdkUser", "Software engineer")
End If
' Create Dossier Context, using the default filing cabinet 'Data' and the dossier 'MyCompany'
Set oDossier = oVenice.CreateDossierContext("", "MyCompany")
' Create Year Context
Set oYear = oDossier.CreateYearContext(2025)
'----------------------------------------------------------------------------------------------------
' This example creates a sales invoice document with analytical information. Adding Intrastat
' details is also listed but commented out.
'----------------------------------------------------------------------------------------------------
' Create context for sales documents
Set oSales = oYear.CreateSales(true)
' Create context for customers
Set oCustm = oDossier.CreateCustm(false)
' Prepare the creation of a new Sales document.
Call oSales.PrepareDocument(paInsert)
' Initialize with default values.
Call oSales.Init()
' In order to obtain a valid sales document header, the following properties must be assigned a value:
' Customer number, Document type (invoice by default), book, Book date, Document date, Total amount and Currency, at least one of the VAT bases and at least one of the VAT amounts.
' This does not imply however that these properties need to be set in code, they can also be assigned via the standard values.
' Note: A document number is not required. If it is set to 0, a new successive number for the given book will be assigned automatically.
' Note: While those are the only properties that are required to be filled in, other properties may require a value for the document to pass the internal validation checks.
' These are the same validation checks that are applied when manually entering a document in Venice.
oSales.pCstNum = 214
oSales.pCstSubNum = 0
oSales.pDocType = slsInvoice ' or slsCreditnote, slsTransfer
oSales.pBook = "FAC"
oSales.pDocNum = 0 ' 0 = Automatically determine the document number
oSales.pBookDate = #8/23/2025#
oSales.pDocDate = #8/14/2025#
oSales.pExpDate = #9/14/2025#
oSales.pTotalDocC = 2710.40 ' Positive for sales invoices and transfers. Negative for creditnotes.
oSales.pCurrency = "EUR"
' Assign (at least) one of the VAT bases: this value is positive for sales invoices and transfers, negative for creditnotes.
oSales.pBaseVat1DocC = 0 ' at 0% VAT
oSales.pBaseVat2DocC = 0 ' at 6% VAT
oSales.pBaseVat3DocC = 0 ' at 12% VAT
oSales.pBaseVat4DocC = 2240.00 ' at 21% VAT
oSales.pBaseVat5DocC = 0 ' currently unused in Belgium
oSales.pBaseVat6DocC = 0 ' currently unused in Belgium
oSales.pBaseCoPartDocC = 0
oSales.pBaseIcGoodsDocC = 0
oSales.pBaseIcAssmDistDocC = 0
oSales.pBaseIcServicesDocC = 0
oSales.pBaseExportDocC = 0
oSales.pBaseForeignVatDocC = 0
oSales.pBaseFinDiscountDocC = 0
oSales.pBaseNotSubmitDocC = 0
' Assign (at least) one of the VAT amounts: this value is negative for sales invoices and transfers, positive for creditnotes.
oSales.pVatDueNormDocC = 470.40
oSales.pVatDedNormDocC = 0
' Manually entering a document in Venice provides a number of automatic assignments. These do not get applied when creating a document via the SDK.
' The following code performs those assignments:
If oCustm.SeekByCstNum(smEqual, oSales.pCstNum, oSales.pCstSubNum) Then
oSales.pClass = oCustm.pClass
oSales.pStatCode = oCustm.pStat
If oCustm.pStandardBase >= asbBase0 And oCustm.pStandardBase <= asbBase5 Then
oSales.pVatCode = oCustm.pStandardBase
End If
oSales.pFinDiscount = oCustm.pFinDiscount
oSales.pRepresentative = oCustm.pRepresentative
oSales.pReminder = oCustm.pReminders
End If
' Add your code here for assigning additional properties of the document header.
' oSales.Xxx = yyy
' Create detail lines and analytical information for each detail line.
Call oSales.InsertDetail(0, -2000.00, 0.00, 0.00, "701", "FLC209 Heating unit", "")
' Analytical details for centre (only when desired and when the option 'Analytical' is installed)
Call oSales.InsertAnaDetail(0, 0, aetCent, -2000.00 * 60/100, 0.0, 60, 0.0, "Sales.NatalieR", "Merchandise", "", "")
Call oSales.InsertAnaDetail(0, 1, aetCent, -2000.00 * 40/100, 0.0, 40, 0.0, "Sales.KarelM", "Merchandise", "", "")
' Analytical details for unit
Call oSales.InsertAnaDetail(0, 0, aetUnit, -2000.00 * 15/100, 0.0, 15, 0.0, "Admin", "Merchandise", "", "")
Call oSales.InsertAnaDetail(0, 1, aetUnit, -2000.00 * 85/100, 0.0, 85, 0.0, "Production", "Merchandise", "", "")
Call oSales.InsertDetail(1, -240.00, 0.00, 0.00, "702", "Installation and setup (3 hours)", "")
' Analytical details for centre
Call oSales.InsertAnaDetail(1, 0, aetCent, -240.00 * 100/100, 0.0, 100, 0.0, "Maint.PeterVH", "Services", "", "")
' Analytical details for unit
Call oSales.InsertAnaDetail(1, 0, aetUnit, -240.00 * 10/100, 0.0, 10, 0.0, "Admin", "Services", "", "")
Call oSales.InsertAnaDetail(1, 1, aetUnit, -240.00 * 90/100, 0.0, 90, 0.0, "Maintenance", "Services", "", "")
' If you have the option Intrastat, you can also add Intrastat details. In order to do this, there must be an IC relation between the company and the client
' (= They must have enterprise numbers from differing countries in the European Community).
'Call oSales.InsertItrDetail(0, 2500.00, 0.0, 0.0, eStatProc.spDispatch, eNatTrans.ntrNormal_Bussiness, eRegion.reFlanders, eTransport.trRoad, eDelivCond.dcFCAA, "85203219", "FR", "US")
'Call oSales.InsertItrDetail(1, 1300.00, 0.0, 0.0, eStatProc.spDispatch, eNatTrans.ntrNormal_Bussiness, eRegion.reFlanders, eTransport.trRoad, eDelivCond.dcFCAA, "85203219", "FR", "CO")
' Write (or cancel) the document
Call oSales.WriteDocument(rmErrorReport)
' If you do not use WriteDocument() because you do not want to save the document (maybe because of an error) you should call CancelDocument() instead.
' Error
MsgBox("Finished!")
end sub
|
|
VB.NET |
|
Imports ClSdk
Module Example
Sub Main()
Try
Dim oVenice As Venice
Dim oDossier As Dossier
Dim oYear As Year
Dim oSales As Sales
Dim oCustm As Custm
Dim eAM As eAccessMode
' Create the Venice object
oVenice = New Venice
' Is option 'Access Management' installed?
eAM = oVenice.GetAccessMode()
' Logon into Venice, allowing user interface
If eAM = eAccessMode.amSecure Then
oVenice.LogonSecure("13.40_", "MyApplication", eLanguage.lngNld, True, "ClSdkUser", "ClSdkPassword")
Else
oVenice.Logon("13.40_", "MyApplication", eLanguage.lngNld, True, "SDK", "ClSdkUser", "Software engineer")
End If
' Create Dossier Context, use the default filing cabinet 'Data' and the dossier 'MyCompany'
oDossier = oVenice.CreateDossierContext("", "MyCompany")
' Create Year Context
oYear = oDossier.CreateYearContext(2025)
' ----------------------------------------------------------------------------------------------------
' This example creates a sales invoice document with analytical information. Adding Intrastat
' details is also listed but commented out.
' ----------------------------------------------------------------------------------------------------
' Create context for sales documents
oSales = oYear.CreateSales(True)
' Create context for customers
oCustm = oDossier.CreateCustm(False)
' Prepare the creation of a new Sales document.
oSales.PrepareDocument(ePrepareAction.paInsert)
' Initialize with default values.
oSales.Init()
' In order to obtain a valid sales document header, the following properties must be assigned a value:
' Customer number, Document type (invoice by default), book, Book date, Document date, Total amount and Currency, at least one of the VAT bases and at least one of the VAT amounts.
' This does not imply however that these properties need to be set in code, they can also be assigned via the standard values.
' Note: A document number is not required. If it is set to 0, a new successive number for the given book will be assigned automatically.
' Note: While those are the only properties that are required to be filled in, other properties may require a value for the document to pass the internal validation checks.
' These are the same validation checks that are applied when manually entering a document in Venice.
oSales.pCstNum = 214
oSales.pCstSubNum = 0
oSales.pDocType = eSalesDocType.slsInvoice ' or slsCreditnote, slsTransfer
oSales.pBook = "FAC"
oSales.pDocNum = 0 ' 0 = Automatically determine the document number
oSales.pBookDate = New DateTime(2025, 8, 23)
oSales.pDocDate = New DateTime(2025, 8, 14)
oSales.pExpDate = New DateTime(2025, 9, 14)
oSales.pTotalDocC = 27104.0 / 10.0 ' Positive for sales invoices and transfers. Negative for creditnotes.
oSales.pCurrency = "EUR"
' Assign (at least) one of the VAT bases: this value is positive for sales invoices and transfers, negative for creditnotes.
oSales.pBaseVat1DocC = 0.0 ' at 0% VAT
oSales.pBaseVat2DocC = 0.0 ' at 6% VAT
oSales.pBaseVat3DocC = 0.0 ' at 12% VAT
oSales.pBaseVat4DocC = 2240.0 ' at 21% VAT
oSales.pBaseVat5DocC = 0.0 ' currently unused in Belgium
oSales.pBaseVat6DocC = 0.0 ' currently unused in Belgium
oSales.pBaseCoPartDocC = 0.0
oSales.pBaseIcGoodsDocC = 0.0
oSales.pBaseIcAssmDistDocC = 0.0
oSales.pBaseIcServicesDocC = 0.0
oSales.pBaseExportDocC = 0.0
oSales.pBaseForeignVatDocC = 0.0
oSales.pBaseFinDiscountDocC = 0.0
oSales.pBaseNotSubmitDocC = 0.0
' Assign (at least) one of the VAT amounts: this value is negative for sales invoices and transfers, positive for creditnotes.
oSales.pVatDueNormDocC = 4704.0 / 10.0
oSales.pVatDedNormDocC = 0.0
' Manually entering a document in Venice provides a number of automatic assignments. These do not get applied when creating a document via the SDK.
' The following code performs those assignments:
If oCustm.SeekByCstNum(eSeekMode.smEqual, oSales.pCstNum, oSales.pCstSubNum) Then
oSales.pClass = oCustm.pClass
oSales.pStatCode = oCustm.pStat
If oCustm.pStandardBase >= eAsalsBase.asbBase0 And oCustm.pStandardBase <= eAsalsBase.asbBase5 Then
oSales.pVatCode = oCustm.pStandardBase
End If
oSales.pFinDiscount = oCustm.pFinDiscount
oSales.pRepresentative = oCustm.pRepresentative
oSales.pReminder = oCustm.pReminders
End If
' Add your code here for assigning additional properties of the document header.
' oSales.Xxx = yyy
' Create detail lines and analytical information for each detail line.
oSales.InsertDetail(0, -2000.0, 0.0, 0.0, "701", "FLC209 Heating unit", "")
' Analytical details for centre (only when desired and when the option 'Analytical' is installed)
oSales.InsertAnaDetail(0, 0, eAnaEntType.aetCent, -2000.0 * 60 / 100, 0.0, 60, 0.0, "Sales.NatalieR", "Merchandise", "", "")
oSales.InsertAnaDetail(0, 1, eAnaEntType.aetCent, -2000.0 * 40 / 100, 0.0, 40, 0.0, "Sales.KarelM", "Merchandise", "", "")
' Analytical details for unit
oSales.InsertAnaDetail(0, 0, eAnaEntType.aetUnit, -2000.0 * 15 / 100, 0.0, 15, 0.0, "Admin", "Merchandise", "", "")
oSales.InsertAnaDetail(0, 1, eAnaEntType.aetUnit, -2000.0 * 85 / 100, 0.0, 85, 0.0, "Production", "Merchandise", "", "")
oSales.InsertDetail(1, -240.0, 0.0, 0.0, "702", "Installation and setup (3 hours)", "")
' Analytical details for centre
oSales.InsertAnaDetail(1, 0, eAnaEntType.aetCent, -240.0 * 100 / 100, 0.0, 100, 0.0, "Maint.PeterVH", "Services", "", "")
' Analytical details for unit
oSales.InsertAnaDetail(1, 0, eAnaEntType.aetUnit, -240.0 * 10 / 100, 0.0, 10, 0.0, "Admin", "Services", "", "")
oSales.InsertAnaDetail(1, 1, eAnaEntType.aetUnit, -240.0 * 90 / 100, 0.0, 90, 0.0, "Maintenance", "Services", "", "")
' If you have the option Intrastat, you can also add Intrastat details. In order to do this, there must be an IC relation between the company and the customer
' (= They must have enterprise numbers from differing countries in the European Community).
'oSales.InsertItrDetail(0, 2500.00, 0.00, 0.00, eStatProc.spDispatch, eNatTrans.ntrNormal_Bussiness, eRegion.reFlanders, eTransport.trRoad, eDelivCond.dcFCA, "85203219", "FR", "US")
'oSales.InsertItrDetail(1, 1300.00, 0.00, 0.00, eStatProc.spDispatch, eNatTrans.ntrNormal_Bussiness, eRegion.reFlanders, eTransport.trRoad, eDelivCond.dcFCA, "85203219", "FR", "CO")
' Write (or cancel) the document
oSales.WriteDocument(eReportMode.rmErrorReport)
' If you do not use WriteDocument() because you do not want to save the document (maybe because of an error) you should call CancelDocument() instead.
Catch ex As Exception
Console.WriteLine("Error while executing application." + vbCrLf + "Reason:" + ex.Message + vbCrLf + "Source: " + ex.Source)
End Try
End Sub
End Module
|
|