AnsweredAssumed Answered

Add-In not getting triggered when using epdm template

Question asked by Tara Campese on Jan 6, 2017
Latest reply on Jan 11, 2017 by Tara Campese

I have an epdm template for creating Corrective Action Reports in epdm. It was set to automatically check in the excel file after the form is filled out. However, whenever the form is filled out and it's automatically checked in, the values are filled out on the data card, but not in the file. If anyone except the file author checks it out, all the data gets cleared out and the form appears blank. This only happens about 20% of the time, but it's enough to be a serious issue.


After extensive research and working with our VAR, the problem was determined to be the template option "Check in the file using the following comment:". Since unchecking that, the problem has been resolved, but this has made it so the user has to check the file in themself after creation. I am trying to reduce the burden on the user by having the file automatically check in.


I created an add-in that opens a file using the "post-add" hook and can get it to trigger when an excel file is created in that specific folder. The add-in opens the newly created file, refreshes all sheets, saves, closes, and checks the file in. It works great when a file is created manually. However, when a file is created using the template, neither the pre-add or post-add hooks get called.


Does anyone have any experience with this? Is there a way around it?





Edit: Added Code (Below)

  Public Sub OnCmd(ByRef poCmd As EdmCmd, ByRef ppoData As System.Array) Implements IEdmAddIn5.OnCmd


            Dim vault As IEdmVault5 = poCmd.mpoVault


            Dim CARfolder As IEdmFolder5 = vault.GetObject(EdmObjectType.EdmObject_Folder, ppoData(0).mlObjectID1)

            If CARfolder.Name = "Corrective Action Reports" Then

                Dim xlApp As New Microsoft.Office.Interop.Excel.Application

                Dim excelBook As Workbook = xlApp.Workbooks.Open(ppoData(0).mbsStrData1)




                Dim CARfile As IEdmFile5 = vault.GetObject(EdmObjectType.EdmObject_File, ppoData(0).mlObjectID2)


            End If


        Catch ex As System.Runtime.InteropServices.COMException

            MessageBox.Show("HRESULT = 0x" + ex.ErrorCode.ToString("X") + " " + ex.Message)

        Catch ex As Exception



        End Try


    End Sub