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
    }