Utilidad para abrir el formulario de apuntes desde una llamada por VBSscript. 


La llamada necesita conocer la empresa, una lista de IdDocs y de forma opcional el formulario padre que lo llama. 


Código VB6:

Sub Main()

  'Obtengo los IdDocs de la IdFactura: 1 
  lAsi = "" & gCn.DameValorCampo("SELECT IdDocs FROM dbo.funDameIdDocsAsientosFacturaCli(" & 1 & ", default, default, default)")
  
  If Len(lAsi) = 0 Then
    MsgBox gCn.Traducir(33995, "No se encontraron asientos para la factura."), vbInformation, gCn.Traducir(34005, "Ver Asientos")
  End If
  
  
  Set lFrm = gCn.AhoraProceso("ObjFormConta_Apuntes", False, True)
  If lFrm Is Nothing Then
    MsgBox "othing"
  End If

  lFrm.Carga_IdDocs gcn.IdEmpresa, CStr(lAsi) , gcn.sesion.mainform ' Importante convertir a Testo Cstr()

  frmAux.Descargar      'ATENCIÓN: DEBE ESTAR SIEMPRE QUE NO SE MUESTRE EL FORMULARIO.    
End Sub


Código C#:

using AhoraConta;
using AhoraCore;
using AhoraOCX;
using AhoraSistema;
using static AhoraCore.VBA.Interaction;

namespace AhoraScriptsVacia
{
    public class Script_72 : AhoraOCX.AhoraBaseScript
    {
        public void Main()
        {
            // Obtengo los IdDocs de la Factura
            Valor lAsi = gCn.DameValorCampo("SELECT IdDocs FROM dbo.funDameIdDocsAsientosFacturaCli(" + 1 + ", default, default, default)");

            if (lAsi.ToString().Length == 0)
            {
                MsgBox(gCn.Traducir(33995, "No se encontraron asientos para la factura."), VbMsgBoxStyle.vbInformation, gCn.Traducir(34005, "Ver Asientos"));
                return;
            }

            IfrmApuntes lFrm = (IfrmApuntes)gCn.AhoraProceso("ObjFormConta_Apuntes", out _, true);
            if (lFrm == null)
            {
                MsgBox("Null");
                return;
            }

            lFrm.Carga_IdDocs(gCn.IdCalendario, lAsi.ToString(), gCn.Sesion.MainForm);

        }
    }
}