INSERT INTO dbo.SYSFLIGHTING(FLIGHTNAME, ENABLED)
VALUES ('<FlightObjectName>_KillSwitch', 1)
or
INSERT INTO dbo.SYSFLIGHTING(FLIGHTNAME, ENABLED)
VALUES ('<FlightObjectName>', 0)
Blog on Microsoft Dynamics AX/ D365
INSERT INTO dbo.SYSFLIGHTING(FLIGHTNAME, ENABLED)
VALUES ('<FlightObjectName>_KillSwitch', 1)
or
INSERT INTO dbo.SYSFLIGHTING(FLIGHTNAME, ENABLED)
VALUES ('<FlightObjectName>', 0)
Excel formula
=AND(ISTEXT(C2),SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(SUBSTITUTE(LOWER(C2),"a",),"b",),"c",),"d",),"e",),"f",),"g",),"h",),"i",),"j",),"k",),"l",),"m",),"n",),"o",),"p",),"q",),"r",),"s",),"t",),"u",),"v",),"w",),"x",),"y",),"z",),"-",),",",),"",),"0",),"1",),"2",),"3",),"4",) ,"5",),"6",),"7",),"8",),"9",),"&",),")",),"(",),".",),"/",),"–",),"#",),"*",),"'",),"+",),":",),";",),"$",),"%",)= "")
Public boolean SAN_validateProductAssortment(Str _itemId)
{
RetailAssortmentTable retailAssortmentTable;
RetailChannelAssortedProductView retailChannelAssortedProductView;
InventTable inventTable;
while select retailAssortmentTable
{
select firstonly retailChannelAssortedProductView
exists join inventTable
where inventTable.ItemId == _itemId
&& retailChannelAssortedProductView.AssortmentRecId == retailAssortmentTable.RecId
&& retailChannelAssortedProductView.ProductID == inventTable.Product
&& retailChannelAssortedProductView.InventLocationDataAreaId == inventTable.DataAreaId;
if(retailChannelAssortedProductView)
{
return true;
}
}
}
throw Error("Invalid item to sell based on assortments");
}
Table1 ppt;
select firstonly ppt
order ItemCode, ItemRelation, AccountCode, AccountRelation where
(ppt.ItemCode == TableGroupAll::Table && ppt.ItemRelation == _itemId &&
ppt.AccountCode == TableGroupAll::Table && ppt.AccountRelation == _accountNum) ||
(ppt.ItemCode == TableGroupAll::Table && ppt.ItemRelation == _itemId &&
ppt.AccountCode == TableGroupAll::GroupId && ppt.AccountRelation == _accountGroup) ||
(ppt.ItemCode == TableGroupAll::Table && ppt.ItemRelation == _itemId &&
ppt.AccountCode == TableGroupAll::All && ppt.AccountRelation == '') ||
(ppt.ItemCode == TableGroupAll::GroupId && ppt.ItemRelation == _ItemGroup &&
ppt.AccountCode == TableGroupAll::Table && ppt.AccountRelation == _accountNum) ||
(ppt.ItemCode == TableGroupAll::GroupId && ppt.ItemRelation == _ItemGroup &&
ppt.AccountCode == TableGroupAll::GroupId && ppt.AccountRelation == _accountGroup) ||
(ppt.ItemCode == TableGroupAll::GroupId && ppt.ItemRelation == _ItemGroup &&
ppt.AccountCode == TableGroupAll::All && ppt.AccountRelation == '') ||
(ppt.ItemCode == TableGroupAll::All && ppt.ItemRelation == '' &&
ppt.AccountCode == TableGroupAll::Table && ppt.AccountRelation == _accountNum) ||
(ppt.ItemCode == TableGroupAll::All && ppt.ItemRelation == '' &&
ppt.AccountCode == TableGroupAll::GroupId && ppt.AccountRelation == _accountGroup) ||
(ppt.ItemCode == TableGroupAll::All && ppt.ItemRelation == '' &&
ppt.AccountCode == TableGroupAll::All && ppt.AccountRelation == '');
// Return table buffer if found, otherwise return 0 as the default
if (ppt.RecId)
{
// return result
}
RetailChannelTable channelTable;
MCRChannelUser channelUser;
while select channelTable
where channelTable.ChannelType == RetailChannelType::MCRCallCenter
{
channelUser.clear();
changecompany(channelTable.DefaultCustDataAreaId)
{
channelUser = MCRChannelUser::find();
if(!channelUser)
{
channelUser.clear();
channelUser.initValue();
channelUser.Channel = channelTable.RecId;
channelUser.User = curUserId();
channelUser.insert();
}
}
}
//Input
--container _xppCallStack = xSession::xppCallStack();
Public static str POL_formatXppCallStack(container _xppCallStack, int _skipFrames)
{
str result = '';
int startFrame = 1 + _skipFrames;
// Each stack frame is four elements [Method, Line Number, Model Publisher, Model]
for (int i = startFrame; i <= conLen(_xppCallStack); i += 4)
{
str methodName = conPeek(_xppCallStack, i);
str lineNum = conPeek(_xppCallStack, i + 1);
str publisher = conPeek(_xppCallStack, i + 2);
str model = conPeek(_xppCallStack, i + 3);
// Add a newline between stack frames
if (i > 1)
{
result += '\n at';
}
// Model identifer
if (publisher || model)
{
result += strFmt('[%1%2%3]', publisher, (publisher && model ? ':' : ''), model);
}
// Code
result += strFmt('%1%2', methodName, (lineNum && lineNum != '0' ? ':' + lineNum : ''));
}
return result;
}
Copy Markup charges while posting purchase invoice using X++
Class:
Important: Code logic is just for Reference.
New class => Duplicate of class MarkupCopy & Named as SAN_MarkupCopy
/// <summary>
/// Duplicate Copy class of MarkupCopy
/// Due to extension limited capabilities on internal and private implementation from STD OOB
Helper class: To call logic
/// <summary>
/// Helper class to centralized logic to copy charges from and to table buffer for purchase
/// </summary>
class SAN_GeneratePurchaseMarkupChargesHelper
{
public static void createPurchaseHeaderMarkupCharge(
Common _fromTable,
Common _toTable,
PurchTable _purchTable )
{
MarkupCopy markupCopy;
MarkupCopyFromPurchOrderParameters copyFromPurchOrderToSubTableParameters;
markupCopy = MarkupCopy::construct();
copyFromPurchOrderToSubTableParameters =
MarkupCopyFromPurchOrderParameters::createCopyFromPurchOrderParameters(
_fromTable,
_toTable,
'',
_purchTable.CurrencyCode,
SourceDocumentLineAccountingStatus::Draft,
_purchTable,
false);
markupCopy.copyFromPurchOrder(copyFromPurchOrderToSubTableParameters);
}
public static void createPurchaseLinesMarkupCharge(
PurchLine _purchLine,
VendInvoiceInfoLine _vendInvoiceInfoLine,
PurchTable _purchTable,
VendInvoiceInfoTable _vendInvoiceInfoTable)
{
ttsbegin;
SAN_MarkupCopy markupCopy;
markupCopy = SAN_MarkupCopy::construct();
MarkupCopyFromPurchOrderParameters copyFromPurchOrderToLineParameters;
copyFromPurchOrderToLineParameters =
MarkupCopyFromPurchOrderParameters::createCopyFromPurchOrderParameters(
_purchLine,
_vendInvoiceInfoLine,
'',
'',
SourceDocumentLineAccountingStatus::Draft,
null,
false);
SysDaBinaryExpression sysDaBinaryExpressionSource, sysDaBinaryExpressionDest;
sysDaBinaryExpressionDest = new SysDaEqualsExpression(
new SysDaFieldExpression(_vendInvoiceInfoLine, fieldStr(VendInvoiceInfoLine, ParmId)), new SysDaValueExpression(_vendInvoiceInfoTable.ParmId))
.and(new SysDaEqualsExpression(
new SysDaFieldExpression(_vendInvoiceInfoLine, fieldStr(VendInvoiceInfoLine, TableRefId)), new SysDaValueExpression(_vendInvoiceInfoTable.TableRefId)));
sysDaBinaryExpressionSource = new SysDaEqualsExpression(
new SysDaFieldExpression(_purchLine, fieldStr(PurchLine, RecId)), new SysDaFieldExpression(_vendInvoiceInfoLine, fieldStr(VendInvoiceInfoLine, PurchLineRecId)));
copyFromPurchOrderToLineParameters.parmBufferToWhereClause(sysDaBinaryExpressionDest);
copyFromPurchOrderToLineParameters.parmBufferFromWhereClause(sysDaBinaryExpressionSource);
copyFromPurchOrderToLineParameters.parmDocumentStatusToExclude(DocumentStatus::Invoice);
MarkupTransTmp markUpTransTmp = markupCopy.copyForAllDocumentLinesUsingTempMarkupTrans(copyFromPurchOrderToLineParameters);
SAN_GeneratePurchaseMarkupChargesHelper::copyMarkupFromPurchOrderOptimizedCleanup(_vendInvoiceInfoTable, markUpTransTmp);
ttscommit;
}
private static void copyMarkupFromPurchOrderOptimizedCleanup(VendInvoiceInfoTable _vendInvoiceInfoTable, MarkupTransTmp _markUpTransTmpCopy)
{
MarkupTrans markupTransOtherInvoices;
VendInvoiceInfoLine vendInvoiceInfoLine;
MarkupTransMapping markUpTransMapping;
// Find if there is a MarkupTrans that is not marked Keep and it is already connected to another invoice
// we will only call delete if there exists one
select firstonly RecId from _markUpTransTmpCopy
join vendInvoiceInfoLine
where vendInvoiceInfoLine.ParmId == _vendInvoiceInfoTable.ParmId
&& vendInvoiceInfoLine.TableRefId == _vendInvoiceInfoTable.TableRefId
&& _markUpTransTmpCopy.TransTableId == vendInvoiceInfoLine.TableId
&& _markUpTransTmpCopy.TransRecId == vendInvoiceInfoLine.RecId
&& _markUpTransTmpCopy.SourceDocumentLine == 0
&& !_markUpTransTmpCopy.Keep
join markupTransOtherInvoices
where markupTransOtherInvoices.OrigTableId == _markUpTransTmpCopy.OrigTableId
&& markupTransOtherInvoices.OrigRecId == _markUpTransTmpCopy.OrigRecId
&& markupTransOtherInvoices.TransTableId == _markUpTransTmpCopy.TransTableId
&& markupTransOtherInvoices.TransRecId != _markUpTransTmpCopy.TransRecId;
if (_markUpTransTmpCopy.RecId != 0)
{
vendInvoiceInfoLine.clear();
markupTransOtherInvoices.clear();
delete_from _markUpTransTmpCopy
exists join vendInvoiceInfoLine
where vendInvoiceInfoLine.ParmId == _vendInvoiceInfoTable.ParmId
&& vendInvoiceInfoLine.TableRefId == _vendInvoiceInfoTable.TableRefId
&& _markUpTransTmpCopy.TransTableId == vendInvoiceInfoLine.TableId
&& _markUpTransTmpCopy.TransRecId == vendInvoiceInfoLine.RecId
&& _markUpTransTmpCopy.SourceDocumentLine == 0
&& !_markUpTransTmpCopy.Keep
join markupTransOtherInvoices
where markupTransOtherInvoices.OrigTableId == _markUpTransTmpCopy.OrigTableId
&& markupTransOtherInvoices.OrigRecId == _markUpTransTmpCopy.OrigRecId
&& markupTransOtherInvoices.TransTableId == _markUpTransTmpCopy.TransTableId
&& markupTransOtherInvoices.TransRecId != _markUpTransTmpCopy.TransRecId;
//Perform cascading delete action for <c>MarkupTransMapping</c> table
markUpTransMapping.clear();
markUpTransMapping.skipDataMethods(true);
markUpTransMapping.skipDeleteActions(true);
markUpTransMapping.skipEvents(true);
delete_from markUpTransMapping
notexists join _markUpTransTmpCopy
where _markUpTransTmpCopy.TransRecId == markUpTransMapping.MarkupTransTransRecId &&
_markUpTransTmpCopy.TransTableId == markUpTransMapping.MarkupTransTransTableId &&
_markUpTransTmpCopy.LineNum == markUpTransMapping.MarkupTransLineNum;
}
// Create a SourceDocumentLine record for each new charge
RecId sourceDocumentHeader = _vendInvoiceInfoTable.SourceDocumentHeader;
int SourceRelationType = tableNum(MarkupTrans);
EnumName TypeEnumName = enumStr(SourceDocumentLine_VendorInvoice);
EnumValue TypeEnumValue = SourceDocumentLine_VendorInvoice::VendorInvoiceChargeLine;
SourceDocumentLineAccountingStatus AccountingStatus = SourceDocumentLineAccountingStatus::Draft;
AccountingDate ExchangeRateDate = _vendInvoiceInfoTable.updateDate();
vendInvoiceInfoLine.clear();
SourceDocumentLine sourceDocumentLine;
sourceDocumentLine.skipDataMethods(true);
sourceDocumentLine.skipEvents(true);
sourceDocumentLine.skipTempTableForInsertRecordSet(true);
insert_recordset sourceDocumentLine
(
ParentSourceDocumentLine,
SourceDocumentHeader,
AccountingStatus,
ExchangeRateDate,
SourceRelationType,
TypeEnumName,
TypeEnumValue,
SourceImplementationRecId
)
select
SourceDocumentLine,
sourceDocumentHeader,
AccountingStatus,
ExchangeRateDate,
SourceRelationType,
TypeEnumName,
TypeEnumValue
from vendInvoiceInfoLine
where vendInvoiceInfoLine.ParmId == _vendInvoiceInfoTable.ParmId
&& vendInvoiceInfoLine.TableRefId == _vendInvoiceInfoTable.TableRefId
join RecId from _markUpTransTmpCopy
where _markUpTransTmpCopy.TransTableId == vendInvoiceInfoLine.TableId
&& _markUpTransTmpCopy.TransRecId == vendInvoiceInfoLine.RecId
&& _markUpTransTmpCopy.SourceDocumentLine == 0;
sourceDocumentLine.skipTempTableForInsertRecordSet(false);
vendInvoiceInfoLine.clear();
sourceDocumentLine.clear();
update_recordset _markUpTransTmpCopy setting
SourceDocumentLine = sourceDocumentLine.RecId
where _markUpTransTmpCopy.SourceDocumentLine == 0
join vendInvoiceInfoLine
where vendInvoiceInfoLine.ParmId == _vendInvoiceInfoTable.ParmId
&& vendInvoiceInfoLine.TableRefId == _vendInvoiceInfoTable.TableRefId
&& vendInvoiceInfoLine.TableId == _markUpTransTmpCopy.TransTableId
&& vendInvoiceInfoLine.RecId == _markUpTransTmpCopy.TransRecId
join sourceDocumentLine
where sourceDocumentLine.SourceDocumentHeader == sourceDocumentHeader &&
sourceDocumentLine.ParentSourceDocumentLine == vendInvoiceInfoLine.SourceDocumentLine &&
sourceDocumentLine.SourceImplementationRecId == _markUpTransTmpCopy.RecId;
SAN_GeneratePurchaseMarkupChargesHelper::insertMarkupTransRecordFromMarkupTransTmp(_markUpTransTmpCopy);
//dispose buffers
vendInvoiceInfoLine.dispose();
_markUpTransTmpCopy.dispose();
markupTransOtherInvoices.dispose();
markUpTransMapping.dispose();
sourceDocumentLine.dispose();
}
private static void insertMarkupTransRecordFromMarkupTransTmp(MarkupTransTmp _markUpTransTmpCopy)
{
SysDaInsertObject insertObj = SAN_GeneratePurchaseMarkupChargesHelper::buildMarkupTransInsertObject();
SysDaQueryObject queryObj = SAN_GeneratePurchaseMarkupChargesHelper::buildMarkupTransTmpQueryObject(_markUpTransTmpCopy);
SAN_GeneratePurchaseMarkupChargesHelper::insertRecords(queryObj, insertObj);
}
private static SysDaInsertObject buildMarkupTransInsertObject()
{
//insert_recordset markupTransDestination (
// BankLCImportChargeAllocation_SA, CalculatedAmount, CalculatedAmountMST_W, CurrencyCode, etc.)
MarkupTrans markupTransDestination;
markupTransDestination.skipEvents(true);
markupTransDestination.skipDataMethods(true);
markupTransDestination.skipTempTableForInsertRecordSet(true);
SysDaInsertObject markupTransInsertObject = new SysDaInsertObject(markupTransDestination);
SAN_GeneratePurchaseMarkupChargesHelper::addMarkupTransFields(markupTransInsertObject.fields());
return markupTransInsertObject;
}
private static SysDaQueryObject buildMarkupTransTmpQueryObject(MarkupTransTmp _markupTransTmpSource)
{
//select BankLCImportChargeAllocation_SA, CalculatedAmount, CalculatedAmountMST_W, CurrencyCode, etc. from markupTransTmpSource
SysDaQueryObject markupTransTmpQueryObject = new SysDaQueryObject(_markupTransTmpSource);
SAN_GeneratePurchaseMarkupChargesHelper::addMarkupTransFields(markupTransTmpQueryObject.projection());
return markupTransTmpQueryObject;
}
private static void addMarkupTransFields(SysDaSelection _selectionObject)
{
_selectionObject
.add(fieldStr(MarkupTrans, BankLCImportChargeAllocation_SA))
.add(fieldStr(MarkupTrans, CalculatedAmount))
.add(fieldStr(MarkupTrans, CalculatedAmountMST_W))
.add(fieldStr(MarkupTrans, CurrencyCode))
.add(fieldStr(MarkupTrans, CustomsAssessableValue_IN))
.add(fieldStr(MarkupTrans, CustVendPosted_RU))
.add(fieldStr(MarkupTrans, ExchRate_RU))
.add(fieldStr(MarkupTrans, ExchRateSecond_RU))
.add(fieldStr(MarkupTrans, FromAmount))
.add(fieldStr(MarkupTrans, IsAutoCharge))
.add(fieldStr(MarkupTrans, IsTieredCharge))
.add(fieldStr(MarkupTrans, ItemPosted_RU))
.add(fieldStr(MarkupTrans, Keep))
.add(fieldStr(MarkupTrans, LineNum))
.add(fieldStr(MarkupTrans, MarkupAllocateAfter_IN))
.add(fieldStr(MarkupTrans, MarkupCategory))
.add(fieldStr(MarkupTrans, MarkupClassification_BR))
.add(fieldStr(MarkupTrans, MarkupCode))
.add(fieldStr(MarkupTrans, MCRBrokerContractFee))
.add(fieldStr(MarkupTrans, MCRCouponMarkup))
.add(fieldStr(MarkupTrans, MCRInstallmentEligible))
.add(fieldStr(MarkupTrans, MCRMarkupTransCreatedBy))
.add(fieldStr(MarkupTrans, MCRMiscChargeOverride))
.add(fieldStr(MarkupTrans, MCROriginalMiscChargeValue))
.add(fieldStr(MarkupTrans, MCRReasonCode))
.add(fieldStr(MarkupTrans, MCRRetailInfoCodeId))
.add(fieldStr(MarkupTrans, MCRSavedRecId))
.add(fieldStr(MarkupTrans, MCRSavedTableId))
.add(fieldStr(MarkupTrans, ModuleCategory))
.add(fieldStr(MarkupTrans, ModuleType))
.add(fieldStr(MarkupTrans, NotionalCharges_IN))
.add(fieldStr(MarkupTrans, NotionalPct_IN))
.add(fieldStr(MarkupTrans, TaxAmount))
.add(fieldStr(MarkupTrans, TaxAmountExcise_RU))
.add(fieldStr(MarkupTrans, TaxAmountExciseMST_RU))
.add(fieldStr(MarkupTrans, TaxAmountMst_W))
.add(fieldStr(MarkupTrans, TaxAmountVAT_RU))
.add(fieldStr(MarkupTrans, TaxAmountVATMST_RU))
.add(fieldStr(MarkupTrans, TaxAutoGenerated))
.add(fieldStr(MarkupTrans, TaxGroup))
.add(fieldStr(MarkupTrans, TaxItemGroup))
.add(fieldStr(MarkupTrans, TaxValueVAT_RU))
.add(fieldStr(MarkupTrans, TaxVATType_RU))
.add(fieldStr(MarkupTrans, TaxWriteCode))
.add(fieldStr(MarkupTrans, ToAmount))
.add(fieldStr(MarkupTrans, Txt))
.add(fieldStr(MarkupTrans, Value))
.add(fieldStr(MarkupTrans, VATDocumentType_RU))
.add(fieldStr(MarkupTrans, SATProductCode_MX))
.add(fieldStr(MarkupTrans, SATUnitCode_MX))
.add(fieldStr(MarkupTrans, WithholdingTypeCode_MX))
.add(fieldStr(MarkupTrans, MarkupAutoTableRecId))
.add(fieldStr(MarkupTrans, RetailShippingPromotionDiscount))
.add(fieldStr(MarkupTrans, IsAdvancedLineProrated))
.add(fieldStr(MarkupTrans, IsOverriddenProratedLine))
.add(fieldStr(MarkupTrans, MarkupAutoLineRecId))
.add(fieldStr(MarkupTrans, IsOverriddenLine))
.add(fieldStr(MarkupTrans, PreviousValue))
.add(fieldStr(MarkupTrans, OverrideSalesTax))
.add(fieldStr(MarkupTrans, TransTableId))
.add(fieldStr(MarkupTrans, TransRecId))
.add(fieldStr(MarkupTrans, OrigTableId))
.add(fieldStr(MarkupTrans, OrigRecId))
.add(fieldStr(MarkupTrans, SpecificUnitSymbol))
.add(fieldStr(MarkupTrans, SourceDocumentLine));
if (LedgerParameters::find().EnableWHTOnCharges == NoYes::Yes)
{
_selectionObject
.add(fieldStr(MarkupTrans, TaxWithholdGroup))
.add(fieldStr(MarkupTrans, TaxWithholdItemGroup));
}
}
private static void insertRecords(SysDaQueryObject _queryObject, SysDaInsertObject _insertObject)
{
_insertObject.query(_queryObject);
SysDaInsertStatement insertStatement = new SysDaInsertStatement();
insertStatement.executeQuery(_insertObject);
}
}
SysOperationSandbox::callStaticMethod(classnum(Classnum(<Class name>)), staticMethodStr(<Class name>, <Class static method name>), [<Parm1>, <Parm2>,<Parm3>], "<operation completion Message>");
public static void updateOpr(container _callerParams)
{
if (conlen(_callerParams) != 3)
{
throw error("");
}
Anytype parm1 = conPeek(_callerParams, 1);
Anytype parm2 = conPeek(_callerParams, 2);
Anytype parm3 = conPeek(_callerParams, 3);
//Business Logic
}
Sample code only for reference.
[ExtensionOf(classStr(CustOverPaym))]
final class CustOverPaymCls_san_Extension
{
private container sanCustCRCTypes;
#define.CurrentVersion(3)
#localmacro.CurrentList
sanCustCRCTypes
#endmacro
/// <summary>
/// Set and get Parm customer credit management types
/// </summary>
/// <param name = "_sanParams">current params</param>
/// <returns>CustCRCTypes</returns>
public container san_parmCustCRCTypes(container _sanParams = sanCustCRCTypes)
{
sanCustCRCTypes = _sanParams;
return sanCustCRCTypes;
}
public container pack()
{
container packedClass = next pack();
return SysPackExtensions::appendExtension(packedClass, classStr(CustOverPaymCls_san_Extension), this.myPack());
}
private container myPack()
{
return [#CurrentVersion, #CurrentList];
}
public boolean unpack(container _packedClass)
{
boolean result = next unpack(_packedClass);
if (result)
{
container myState = SysPackExtensions::findExtension(_packedClass, classStr(CustOverPaymCls_san_Extension));
if (!this.myUnpack(myState))
{
result = false;
}
}
return result;
}
private boolean myUnpack(container packedClass)
{
Integer version = RunBase::getVersion(packedClass);
switch (version)
{
case #CurrentVersion:
[version, #currentList] = packedClass;
break;
default:
return false;
}
return true;
}
/// <summary>
/// Builds the cross company query used to calculate summarized totals. COC
/// </summary>
/// <param name = "_calcArgs">Contains arguments used to construct the query</param>
/// <returns>The generated query.</returns>
protected Query buildCrossCompanyQueryForCalcTotalSummarized(CustOverPaymCalcTotalArgs _calcArgs)
{
Query sanQuery;
sanQuery = next buildCrossCompanyQueryForCalcTotalSummarized(_calcArgs);
if(sanCustCRCTypes != conNull())
{
this.san_setQueryRangeCustCRCTypes(sanQuery);
}
return sanQuery;
}
/// <summary>
/// Builds the cross company query used to calculate not summarized totals. COC
/// </summary>
/// <param name = "_calcArgs">Contains arguments used to construct the query</param>
/// <returns>The generated query.</returns>
protected Query buildCrossCompanyQueryForCalcTotalNonSummarized(CustOverPaymCalcTotalArgs _calcArgs)
{
Query sanQuery;
sanQuery = next buildCrossCompanyQueryForCalcTotalNonSummarized(_calcArgs);
if(sanCustCRCTypes != conNull())
{
this.san_setQueryRangeCustCRCTypes(sanQuery);
}
return sanQuery;
}
/// <summary>
/// Builds the query used in methods <c>findTransactionsForReimbursementNonSummarized</c> and <c>findTransactionsForReimbursementSummarized</c>. COC
/// </summary>
/// <param name = "_findTransArgs">Contains arguments used to build the query.</param>
/// <returns>The generated query.</returns>
protected Query buildFindTransactionsForReimbursementQuery(CustOverPaymFindTransactionsForReimburseArgs _findTransArgs)
{
Query sanQuery;
sanQuery = next buildFindTransactionsForReimbursementQuery(_findTransArgs);
if(sanCustCRCTypes != conNull())
{
this.san_setQueryRangeCustCRCTypes(sanQuery);
}
return sanQuery;
}
/// <summary>
/// setting query range for customer credit management types to existing query
/// </summary>
/// <param name = "_query">Query</param>
public void san_setQueryRangeCustCRCTypes(Query _query)
{
QueryBuildDataSource qbdsCustTable;
str CustCRCTypesIds;
san_CustCreditManagementTypes custCreditManagementTypes;
#define.sanSemicolon(';')
#define.sanComma(',')
qbdsCustTable = _query.dataSourceTable(tableNum(CustTable));
if(qbdsCustTable == null)
{
qbdsCustTable = _query.addDataSource(tableNum(CustTable));
}
CustCRCTypesIds = con2StrUnlimited(sanCustCRCTypes,#sanComma);
if (CustCRCTypesIds)
{
CustCRCTypesIds = Global::strReplace(CustCRCTypesIds, #sanSemicolon, #sanComma);
qbdsCustTable.addRange(fieldNum(CustTrans, san_CustCreditMgmtType)).value(CustCRCTypesIds);
}
}
}
INSERT INTO dbo.SYSFLIGHTING(FLIGHTNAME, ENABLED) VALUES ('<FlightObjectName>_KillSwitch', 1) or INSERT INTO dbo.SYSFLIGHT...