How to use Smart tags in Aico
Modified on Wed, 8 Jan at 1:15 PM
This article will explain the use of Smart tags when creating tasks in Automation manager.
Smart tags are used to set task parameters typically to change the values in a smart way. For example, instead of setting a fixed date, you can refer to a smart tag date of Last Period Calendar Day which will then change each period that you generate the task.
This article will outline the following:
Introducing smart tags
Wherever you see the tag icon, you can click on it to reveal the full list of smart tags.
For example, if you wanted to set the document date as the Period Last Calendar Day, you would click on this and when the document is generated, it will set the document date for the last day of that period.
Smart tag descriptions
Below is a complete description of the smart tags and their function.
Company Code
This sets the company code of the company that you are generating the task for.
When running a program for multiple company codes, this smart tag will change the company code in the program parameter to the one associated with the company you are running the program for without you having to set it multiple times.
Company Name
This sets the Company name from the Automation Manager company settings.
This is not the System manager company name, although these could have been set the same way.
Company Attribute 1 - 5
These are the 5 attributes that are found under each company in Automation Manager.
These are not the System manager company attributes.
Period
This will add the Period in the form YEAR-MO, for example, 2022-12.
Note that, in the eBS plug-in only, Period looks up the Period name in the eBS database and will set that for example DEC-22.
Period Year
Sets the Period Year from the period you are generating the tasks, for example, 2022.
This will react to any custom calendar settings for their associated companies.
Period Number
Sets the Period Number from the period you are generating the tasks, for example, 12.
This will react to any custom calendar settings for their associated companies.
Period Last Calendar Day
This will set the last calendar day of the period you are generating the tasks, for example, 31 March 2022 or 30 June 2022.
This will react to any custom calendar settings for their associated companies.
Period Last Working Day
This will set the last working day of the period you are generating the tasks for, taking into account the holiday calendar linked to the company.
This will react to any custom calendar settings for their associated companies.
Period First Calendar Day
This will set the first calendar day of the period you are generating the tasks, for example, 1 March 2022 or 1 June 2022.
This will react to any custom calendar settings for their associated companies.
Period First Working Day
This will set the first working day of the period you are generating the tasks for taking into account the holiday calendar linked to the company.
This will react to any custom calendar settings for their associated companies.
Next period First Calendar Day
This will set the first calendar day of the period after the one you are generating the tasks for. For example, if you are generating tasks for March, it will set the 1 April.
This will react to any custom calendar settings for their associated companies.
Next period First Working Day
This will set the first working day of the period after the one you are generating the tasks for, taking into account the holiday calendar linked to the company.
This will react to any custom calendar settings for their associated companies.
Prior Period Year
This will set the year before the one you are generating the tasks. For example, if you are generating tasks for January 2023 it will set 2022.
This will react to any custom calendar settings for their associated companies.
First day of Period Year
This will set the first day of the year that you are generating tasks for. For example, if you generating any period in 2022 it will set 1 January 2022.
This will react to any custom calendar settings for their associated companies. This will mean that if the “real” period is September 2022, but the custom calendar for that company says that it is Period 3 of 2023 then it will set 1 July 2022 as the first day of the Period Year.
Next Period Year
This will set the year after the one you are generating the tasks. For example, if you are generating tasks for January 2022 it will set 2023.
This will react to any custom calendar settings for their associated companies.
External Company Code
This will set the external company code value that has been set against the Company in the Automation manager integration properties.
This is not the System manager company External ID.
Empty Value
This will clear any value set in this parameter.
This is typically used when the value is coming from an SAP variant and you want to remove it, for example, if the variant has a Test Run set as True and you want to remove this value. Do NOT use this in a formula to set an empty value, it actually sends a space and has been designed to deal with the removal of a boolean true in SAP.
Next Period Number
This will set the period number of the period after the one you are generating tasks for.
This is useful when opening and closing periods using a program when you need to tell the program which period to open. It understands that Period 1 comes after Period 12.
Template Code
This will set the Automation manager task template code into the associated header. Introduced in 23.1.
Smart tag formulas
By embedding smart tags into formulas, Aico provides significant additional configurability in the program parameters. The formulas are only evaluated ONCE at the time the Aico document is first generated and they set values into the headers and program parameters stored in the Aico document.
Below are a list of examples that you can use/adapt for your templates. Click the smart tag symbol (1) that appears after the parameter you want to set. The formula box (2) is at the end of the list of pre-built smart tags.
Click in the box and the = will automatically appear. Start typing the beginning of your formula and a list of possible selections will appear. When you include one of the pre-built smart tags in your formula then it will be represented between curly brackets {}.
The formula engine supports a number of standard functions such as IF, DATEADD, DATEDIF, CONCATENATE, LEFT, RIGHT, TRUNC. You can then incorporate common comparison operators including = (equals), > (greather than), < (less than), >= (Greater than or equal to) , <= (Less than or equal to), <> (not equal to). Additionally, you can use conditional functions including AND and OR within your formulas. You can also able to resolve boolean fields to TRUE or FALSE.
Example formulas:
=DATEADD( {periodFirstCalendarDay} ,1,"MO")
Sets the date as the first calendar day of the period after the one you are closing.
=DATEADD( {periodLastCalendarDay} ,-12,"MO") or = DATEADD( {periodLastCalendarDay} ,-1 , "Y")
Sets the last calendar day of the prior year period (to compare to prior year)
= DATEADD( {periodLastCalendarDay} ,-1 , "Q")
Sets the last calendar day of the period one quarter earlier (i.e. - 3 months)
= DATEADD( {nextPeriodFirstCalendarDay} ,4 ,"D")
Sets the first calendar day of the next period PLUS 4 calendar days i.e. the 5th day of the following month.
Be careful about using NOW() in your date formulas as, whilst this is supported, the formulas are evaluated only once when the document is first generated and it is this first generation time that will be considered as NOW by the formula.
={periodNumber}-1)
Sets the period number of the prior period which is often used in comparison reports.
Be careful when using this for Period 1 as it will return 0 and this could cause an error in your report. You might then want to use a formula.
= IF({periodNumber}=1,1,{periodNumber}-1) which will mean in Period 1 you are really unable to compare with the prior period.
= IF ( {periodNumber} = 12, {nextPeriodYear}, {periodYear})
Sets the current year unless it is period 12 in which case it will set next year. This is often used in programs that open and close periods.
=CONCATENATE( "Provision posting"," ", {period} )
Sets a fixed piece of text followed by the Period Year-Period Number. This could, for example, return Provision posting 2024-10 as a document description in a journal.
To remove a formula, click on --UNSELECT-- at the very top of the smart tag drop-down list.
Additional Functions
There is a wider list of functions available but not all are relevant for Automation manager. Below is an expanded list of supported functions:
Logical:
AND, OR, IF, TRUE, FALSE, IFNULL, NULL
MathTrig:
ABS, RAND, RANDBETWEEN, SUM, SUMIF
Statistical:
AVERAGE, COUNT, COUNTIF, MAX, MIN
Text:
CONCATENATE, FIND, LEFT, LEN, MID, REPLACE, RIGHT, SEARCH, SUBSTITUTE, TEXT, TRIM, TRUNC
Date:
DATEADD, DATEDIFF
WORKDAY Formulas
WORKDAY formula support was added in 23.1. It will take into account the holidays marked in your Automation manager holiday calendar.
ISWORKDAY: Returns true/false depending on if the date is a workday or holiday.
= ISWORKDAY( {periodLastCalendarDay} )
Returns True if the last calendar day of the period is a workday.
NEXTWORKDAY: Returns the next possible workday starting from and including the given date.
= NEXTWORKDAY( {nextPeriodFirstCalendarDay})
Sets the next work day after the first calendar day of the next period. Note it will return the specified date if the specified date is already a workday i.e. if the 1st calendar day of the next period is already a workday it will return the 1st calendar day.
PREVIOUSWORKDAY: Returns the last possible workday before and including the given date.
= PREVIOUSWORKDAY( {periodLastCalendarDay} )
Sets the prior work day before the last calendar day of the next period. Note it will return the specified date if the specified date is already a workday i.e. if the last calendar day of the period is already a workday it will return the last calendar day.
WORKDAY: Returns the nth workday in the current month. nthDay can be a positive number (from the beginning of the month) or a negative (from the end of the month).
=WORKDAY(4, {nextPeriodFirstCalendarDay})
Sets 4 workdays after the first calendar day of the next period.
Was this article helpful?
That’s Great!
Thank you for your feedback
Sorry! We couldn't be helpful
Thank you for your feedback
Feedback sent
We appreciate your effort and will try to fix the article