date of last meeting field

In the Accounts module I want to add a Date of last meeting field and have it auto populate.  Is there a way to have it locate the last meeting held and put the date of that meeting in the field?  Thanks so much

Parents
  • Hi Amy,

    You can achieve this functionality by creating a few calculated fields via Studio. 

    Meetings Module

    1. Go to Admin > Studio > Meetings > Fields > Add Field
    2. Create a custom date field (e.g. meeting_held_date_c) with the following formula in the 'Calculated Value' section: 
      date(ifElse(equal($status,"Held"),$date_start,""))

      This formula checks to see if the status is held, and if so, inherits the start date of the meeting.

    3. (Optional) Add the field to the Meetings record view layout

    Accounts Module

    1. Go to Admin > Studio > Accounts > Fields > Add Field
    2. Create a custom date field with the following formula in the 'Calculated Value' section:
      maxRelatedDate($meetings,"meeting_held_date_c")

      This formula reviews all related meetings to the account to return the highest date value in the previously created custom field.

    3. (Optional) Add the field to the Accounts record view layout

    Once both fields are created, any meetings saved will populate the custom field if their status is held. Similarly, any accounts saved will populate the highest related date from the custom field. 

    Any pre-existing records will be empty. To remedy that issue, you will need to perform 1 of the following operations on the existing leads:

    1. Individually save the necessary meetings and then the related accounts
    2. Run a 'Recalculate Values' operation from the Meetings list view on the desired records and then again on the Accounts list view

    I hope this helps!

  • Hey Chris,

    Is there a way to find the related record with the highest date value and then copy fields from that record? For example, I would like to copy the Sales Stage of the most recently created related Opportunity.

    Thanks!

Reply Children
  • Hi Mustafa,

    I don't think there is a way you could achieve this with Sugar Logic. Sugar Logic functions do not have the means of comparing one related record to another (i.e. give me the most recent created record). 

    This specific use case can be achieved in SugarBPM though. Here is how I would build the process definitions:

    1. Create a dropdown field (e.g. Most Recent Opportunity) with the following dropdown options
      Note: For my examples, I am going to use the Opportunity Type field but you will want to use your own custom field to ensure it is isolated for your use case
      1. blank
      2. Yes
      3. No
    2. Create a SugarBPM process definition on the Opportunities module
    3. The definition has two start events. The first start event should be set to trigger on new records only:
    4. The action after that start event updates all the opportunities related to the parent account. It will set your custom dropdown field value to 'No'
    5. The next field action sets the value of your custom dropdown for the current opportunity to 'Yes'
    6. The last action then sets the field on the account equal to the opportunity sales stage value

      Note: For copying the sales stage value, you will need to manually enter the text shown above because the field is not available to select from the list of field variables: {::Opportunities::sales_stage::}
    7. Then, the second start event will be set to trigger on all updates where the opportunity's custom dropdown value is set to 'Yes'

      This start event will feed directly into the last action to update the parent account.

    This definition would ensure that only the most recently created opportunity will update the account record with its sales stage value. I caution that this is a very specific use case though. If you had to handle a scenario where you had to make comparisons between the related records (e.g. copy the sales stage of the opportunity with the nearest expected close date), then this solution would not suffice. Much like Sugar Logic, SugarBPM is not equipped to handle comparisons between related records. Your best solution for those more complex comparisons would be a custom-developed logic hook.

    Chris