Version of Microsoft Dynamics AX: D365O
1. Selects
Using intercompany functionality to fetch data from all companies at once, not just from the current company, as in the case with a regular select, use keyword crosscompany.
data:image/s3,"s3://crabby-images/22de0/22de01fe768fb3bc2be99afcab46813299ae081b" alt="Picture1 Picture1"
To select data not from all companies at once, but only from some of them, use keyword crosscompany and specified a list of companies:
data:image/s3,"s3://crabby-images/e581b/e581b9ab0f93d99bb82f8d1a499ee23811ff66c2" alt="Picture2 Working with Intercompany functionality"
data:image/s3,"s3://crabby-images/bed63/bed63740a5672fc997b71db99c8b9777088ce6e7" alt="Picture3 Working with Intercompany functionality"
Another way to fetch data from a company other than the current company is to “switch” to another company using changecompany. In this case, all the code is executing in the context of the specified company.
data:image/s3,"s3://crabby-images/27775/2777581ed44f9aeb9fbf9660595342d8a65e2ae0" alt="Picture4 Working with Intercompany functionality"
2. Forms data sources
If you need to fetch data from multiple companies at the same time in the form data source, you need to change the value of property Cross Company Auto Query to «Yes». In this case, the data will be selecting from all existing companies.
data:image/s3,"s3://crabby-images/5dbc9/5dbc9690b9db6ebdee0b14864d0590695508d8d2" alt="Picture5 Picture5"
To limit the list of companies, you need it set the values of the required companies in the init() method of this data source.
data:image/s3,"s3://crabby-images/54624/54624f630bd9e99a7c724dd2aac0f6d851dbf11b" alt="Picture6 Picture6"
data:image/s3,"s3://crabby-images/542bb/542bbba59305a0c99d3cd7f563b92b3af96cefcc" alt="Picture7 Picture7"
3. Copying records
To copy a record from one company to another, you need to “switch” to the desired company using changecompany and initialize all the fields (except system fields) of the new record with buf2buf function.
Below is the code for a method that creates a new record and initializes its fields with the values of the original record:
data:image/s3,"s3://crabby-images/d7719/d7719a78c0d3f094844a890535bacdac5232f0ac" alt="Picture8 Picture8"
As an example of the standard buf2buf function using you can see the class CustFreeInvoiceCorrection.
data:image/s3,"s3://crabby-images/d2103/d21039df7afe31162f7b17fc938daa06d89295fe" alt="Picture9 Picture9"
In cases where, for some reason, you to save the values of the system fields of the original record, except for field DataAreaId, since this field must in any case correspond to the company in which the new record is created, use the table data method.
At the same time, when creating a new record, some of the system fields can be overridden, and field DataAreaId must be overridden.
Overriding system fields must be allowed by special construction with using OverwriteSystemfieldsPermission().assert() и overwriteSystemfields().
Here is an example of code that overrides system fields in the new record.
data:image/s3,"s3://crabby-images/c1160/c1160540701393c75536a6bfb162a0982814c274" alt="Picture10 Working with Intercompany functionality"
4. Intercompany Sales Purchase orders
An example of the standard Intercompany functionality is association between purchase order in one company and sales order in another company.
Having a purchase order, you can get an intercompany sales order and having a sales order, you can get an intercompany purchase order.
Below are custom examples of receiving sales and purchase orders.
data:image/s3,"s3://crabby-images/992c5/992c5c9ff8c987e98b70b5e0518924fe916716af" alt="Picture11 Picture11"
data:image/s3,"s3://crabby-images/fe099/fe099ef2b53e2a7241d665b250e5567b9aa97625" alt="Picture12 Working with Intercompany functionality"
Here is an example of standard code in MarkupCopy class that gets intercompany sales order..
data:image/s3,"s3://crabby-images/cb9db/cb9db054ef15e0b58cae54ce8ee5279d65765046" alt="Picture13 Working with Intercompany functionality"