Log user and date upon row addition
/*
* Log user and date upon row addition
*
* The script checks who and when adds rows to the IJC table.
* Whenever a new row is added, username and time are stored in IJC fields.
* Attention: fields for username and date must be defined in the IJC table
* before running this script.
*
* Usage:
* 1. Add User and Date fields into the table
* 2. Edit the name of User and Date fields
* 3. Run button script
*
* @author Ondrej Svoboda <osvoboda@chemaxon.com>
*/
 
afterEdit= {event ->
   //Names of fields where username and date is stored
   def userFieldName="username"
   def dateFieldName="textDate"
   println "after edit operation"
    def widget=event.widget
  // find user and date fields
  def userField=widget.boundFields.find{it.name==userFieldName}
  def dateField=widget.boundFields.find{it.name==dateFieldName}
  // get the username and date
  def vs=widget.vertexState
  // get entity from the widget vertex state
  def ety=vs.getVertex().getEntity()
  // get id of the row you are adding
  selectedRowId=vs.getSelectedRowsIds()
  // go to the schema
  def rs=vs.resultSet
  def dataTree=rs.dataTree
  def schema=dataTree.schema
   // get user
   def user=DIFUtilities.findCapability(schema,IJCUserLoginService.class).getMe()
   // get date
   def today = new Date()
   // get entity data provider
   def edp = ety.schema.dataProvider.getEntityDataProvider(ety)
   // get access to the environment through lock
       def lock = edp.lockable.withLock('Updating'){ envRW ->
      // control whether date and user fields are filled. If so, do not update them
      def data=vs.getData(selectedRowId,DFEnvironmentRO.DEV_NULL)
      println data[selectedRowId[0]][userField.id]
      if((data[selectedRowId[0]][userField.id]==null) && (data[selectedRowId[0]][dateField.id]==null)) {
       // Defines empty map
               def vals = [:]
               vals[userField.id] = user.getUsername()
               // date field is defined as a string, the format can be arbitrary
               vals[dateField.id] = today.format("yyyy-MM-dd \'at\' HH:mm:ss")
               // Create the DFUpdateDescription and update the DFEntityDataProvider
                def ud = DFUpdateDescription.create(ety, selectedRowId, vals)
                def submitList = Collections.singletonList(ud)
                edp.update(submitList, DFUndoConfig.OFF, envRW)
               println "Updating field $userFieldName to value ${user.getUsername()} and field $dateFieldName to value $today"
               }
     }
// by returning false, the action proceeds as expected
return false
}