Thursday, December 18, 2008

How to create a new EventType

When using notifications in Dynamics AX we get different event types when setting up a new notification rule for different fields. If we try to create a notification rule for a date field, we get event types like “is due:”, “is due in:” and “has changed:”. If we create one for a string we get “has changed:” and “is set to:”.
Let’s say we want to create a new event type for fields containing numbers that checks if the number has doubled. This is how we do it.
We first need to create a new class that extends the EventTypeCUD class. We call our new class EventTypeCUDDoubleOrMore.

Classdeclaration extends EventTypeCUD:
class EventTypeCUDDoubleOrMore extends EventTypeCUD
 {
 }

We need a description that tells the user what the event type means. This is what the user will see then choosing appropriate event type.
1
2
3
4 public EventTypeDescription description()
 {
     return "has doubled:";
 }

We need to specify what type of fields our new event type will be applied to:
 public boolean isValidEventType(Types _types)
 {;
        switch(_types)
        {
            case    Types::Integer:
            case    Types::Int64:
            case    Types::Real:
                return true;
            default:
                return false;
        }
 
        return false;
 }

We also need a condition that will trigger a notification if our event is used:
1
2
3
4 public boolean isMatchingRule()
 {
     return (currentValue >= (originalValue * 2));
 }

And last but not least we need to specify that this event has the trigger FieldChanged.
public anytype parmTypeTrigger(EventTypeTrigger _typeTrigger
                                   = typeTrigger)
 {
     ;
     typeTrigger = _typeTrigger;
     if (typeTrigger != EventTypeTrigger::FieldChanged)
         throw error("@SYS96349");
     return typeTrigger;
 }

More info on how to create a new event type class can be found in Dynamics AX developer help chapter: Implement a New EventType Class.
What they don’t mention in the developer help is how to activate your new class. This is done in the class EventType method eventTypeClassIdsHook(). There are comments in the code that helps, we need to edit this method so it looks like this:
protected static container eventTypeClassIdsHook()
 {
     //   return connull();
     return [classNum(EventTypeCUDDoubleOrMore)]; 
     //    return [classNum(myEventTypeClass1), 
     //    classNum(myEventTypeClass2), ... ];
 }

No comments:

How to identify the user that was used to change an object from AOT in AX2012

Get the object name for which we need to track these (user and date&time) information's. Login to SQL Server Management Studio an...