Curso de Software de Ventas Pt 51 – Cartera, Movimientos, Cierra de Caja

Si notaran el titulo en este articulo voy a regalar el código para que lo descarguen y les sea mas fácil terminar.

Como ya ha demorado mucho este curso voy a montar casi todo lo que falta en este articulo lo descarguen y quede prácticamente listo el software.

Pero primero debemos tener algunas cosas listas:

La base de datos debe tener las siguientes tablas:

Tabla ClaseMovimiento:

Esta tabla tiene los siguientes registros predeterminados:

Tabla Movimientos:

Tabla Tipo Movimientos con sus registros predeterminados:

Tabla Personas Movimiento:

Para el Cierre de Caja se necesita la siguiente Tabla:

Debe dejar todo esto listo para poder pasar al siguiente paso.

Siguiente paso es Pegas las siguientes funciones en el Modulo Consultas Mod_consultas

'---- MOVIMIENTOS

Function Fun_GuardarPersona(Cedula, Nombres, Telefono, Direccion)
    Dim RecorsetTemp As New ADODB.RecordSet
    Dim sql As String
     
    On Error GoTo error
        RecorsetTemp.Open "Select * From PersonaMovimiento Where CedulaPersona = '" & Cedula & "'", ConexionADO, adOpenKeyset, adLockOptimistic
        
        If RecorsetTemp.RecordCount > 0 Then
            Fun_GuardarPersona = RecorsetTemp("idPersonaMovimiento")
            Exit Function
        Else
            IdPersona = UltimoIdTabla("PersonaMovimiento", "idPersonaMovimiento")
            RecorsetTemp.AddNew
            RecorsetTemp!idPersonaMovimiento = IdPersona
            RecorsetTemp!CedulaPersona = Cedula
            RecorsetTemp!NombresPersona = Nombres
            RecorsetTemp!TelefonoPersona = Telefono
            RecorsetTemp!DireccionPersona = Direccion
            RecorsetTemp.Update
            Fun_GuardarPersona = IdPersona
        End If
    Exit Function
error:
    MsgBox "Fun_GuardarPersona - " & Err.Description, vbInformation, "Error - Guardar Nº " & Err.Number
End Function

Sub Fun_GuardarMovimiento(CodigoMov, NMov, Fecha, Tipo, ClaseMov, IdPers, Concepto, Valor)
    Dim RecorsetTemp As New ADODB.RecordSet
    Dim sql As String
     
    On Error GoTo error
        RecorsetTemp.Open "Select * From Movimientos Where idMovimientos = " & CodigoMov, ConexionADO, adOpenKeyset, adLockOptimistic
        
        If RecorsetTemp.RecordCount > 0 Then
        Else
            RecorsetTemp.AddNew
            RecorsetTemp!idMovimientos = UltimoIdTabla("Movimientos", "idMovimientos")
        End If
        RecorsetTemp!ConceptoMovimeinto = Concepto
        RecorsetTemp!Fecha_Movimiento = Fecha
        RecorsetTemp!Valor_Movimeinto = CCur(Valor)
        RecorsetTemp!idPersonaMovimiento = IdPers
        RecorsetTemp!idClaseMovimieno = ClaseMov 'Gatos o Ingreso
        RecorsetTemp!idTipoMovimiento = Tipo  'A que cuenta
        RecorsetTemp.Update
        MsgBox "Movimiento Guardado", vbInformation, "Guardar"
    Exit Sub
error:
    MsgBox "Fun_GuardarMovimiento - " & Err.Description, vbInformation, "Error - Guardar Nº " & Err.Number
End Sub


Sub Fun_BorrarCampoTablaCodigo(Campo, Codigo, Tabla)
     Dim RecorsetTemp As New ADODB.RecordSet
     Dim sql As String
     
     If Codigo <> "" Then
        sql = "DELETE FROM " & Tabla & " Where " & Campo & " = " & Codigo
        RecorsetTemp.Open sql, ConexionADO, adOpenKeyset, adLockOptimistic
     End If
End Sub

Sub Fun_GuardarCuenta(Codigo, Nombre)
    Dim RecorsetTemp As New ADODB.RecordSet
    Dim sql As String
     
    On Error GoTo error
        RecorsetTemp.Open "Select * From ClaseMovimiento Where idClaseMovimieno = " & Codigo, ConexionADO, adOpenKeyset, adLockOptimistic
        
        If RecorsetTemp.RecordCount > 0 Then
        Else
            RecorsetTemp.AddNew
            RecorsetTemp!idClaseMovimieno = UltimoIdTabla("ClaseMovimiento", "idClaseMovimieno")
        End If
        RecorsetTemp!Nombre_Clase = Nombre
        RecorsetTemp.Update
    Exit Sub
error:
    MsgBox "Fun_GuardarCuenta - " & Err.Description, vbInformation, "Error - Guardar Nº " & Err.Number
End Sub

 

En el Modulo de Conexión:

En Código por si prefiere copiar y pegar:

Global Glo_UsuarioLogin As String
Global Glo_NombreUsuario As String
Global Glo_IdentificacionUs As String
Global Glo_IdUsuario As Integer
Global Glo_FormQueAbre As String
Global glob_ModificarPro As Boolean
Global glob_ModificarCliente As Boolean

'---- Variables de Datos de la empresa
Global Glo_NombreEmpresa As String
Global Glo_NitEmpresa As String
Global Glo_PropietarioEmpresa As String
Global Glo_TelefonoEmpresa As String
Global Glo_DireccionEmpresa As String
Global Glo_DescripcionEmpresa As String
Global Glo_LogoEmpresa As String
Global G_Empresa_Regimen As String

Global Path_Archivo_Ini As String
'-------------- Variables Configuracion ---------------
Global glob_conf_ImpreFacturacion As String
Global glob_conf_ImpreInformes As String
Global glob_conf_ImpreCierreCaja As String
Global glob_conf_ImpresoraTikets As String

Global glob_ModificarProveedor As Boolean

'----------- variable de impresion -----------------
Global glob_Item_Impresion_mes As String
Global glob_Item_Impresion_dia As String

Global glob_FormularioSolicBuscarCli As String
Global glob_FormularioSolicBuscarPro As String

Global Glo_FormularioFacturasCli As Form

En el formulario Buscar Cliente en el botón Factura hay que agregar la siguiente linea:

Private Sub cmdFacturas_Click()
  Set Glo_FormularioFacturasCli = Me
  IdCliente = msGrid.TextMatrix(msGrid.Row, 1)
  If IdCliente <> "" Then
     frmFacturasCliente.Show
  End If
End Sub

Luego de esto reemplazamos en el formulario frmFacturasCliente en el Sub Procedimiento DatosCliente quedando de la siguiente manera:

Sub DatosCliente()
    Fila = Glo_FormularioFacturasCli.msGrid.Row
    txtCodigoCli.Text = Glo_FormularioFacturasCli.msGrid.TextMatrix(Fila, 1)
    txtNombre_Cli.Text = Glo_FormularioFacturasCli.msGrid.TextMatrix(Fila, 2)
End Sub

Lo unico que se hizo fue cambiar frmBuscarCliente por Glo_FormularioFacturasCli que es la variable que declaramos esto es necesario porque hay 2 maneras de llegar al formulario de frmFacturasCliente y debe tomar ese valor dependiendo el formulario que lo abrio.

Todo listo para agregar los formularios al software.

Descargue de este link los formulario y los informes:

Formularios Y Reportes Finales Software (349 descargas )

Puede descomprimir y luego pegar todos dentro de la carpeta del proyecto en el vídeo explico detallado estos pasos:

Esta es la lista de de formularios:

Para agregar un formulario al proyecto debe dar clic derecho en la ventana del Proyecto y le da clic derecho sobre el nombre del proyecto

Paso 1:

Paso 2:

Seleccionamos el formulario y le damos al botón Abrir

Para agregar un Reporte debemos seleccionar otra opción

Después de agregar los formularios y los reportes hay que agregar los item al Menú del formulario Principal, los que se deben crear de la siguiente manera:

La configuración de cada uno es la siguiente:

Caption: Cartera de Clientes
Name: mnuCarteraClientes

Caption: Movimientos
Name: mnuMovimientos

Caption: Caja
Name: mnuCaja

Caption: Abrir Caja
Name: mnuAbrirCaja

Caption: Cierre Caja
Name: mnuCierreCaja

Caption: –
Name: mnuRaya3

Caption: Egresos – Ingresos
Name: mnuEgresosIngresos

Caption: Lista de Ingresos y Egresos
Name: mnuListaIngrEgre

Caption: Informe de Ventas por dia
Name: mnuInformeVentasDia

En el evento clic de algunos menús va lo siguiente:

Private Sub mnuCarteraClientes_Click()
      frmCarteraClientes.Show
End Sub

Private Sub mnuAbrirCaja_Click()
      frmAbrirCaja.Show
End Sub


Private Sub mnuCierreCaja_Click()
      frmCuadreCaja.Show
End Sub


Private Sub mnuEgresosIngresos_Click()
      frmMovimientos.Show
End Sub

Private Sub mnuListaIngrEgre_Click()
      frmListaMovimientos.Show
End Sub

Private Sub mnuInformeVentasDia_Click()
    glob_Item_Impresion_dia = "VentasDia"
    frmInformeDia.Show
End Sub

Con estos cambios ya tienen todo el software listo para trabajar, faltaría el pago de facturas de proveedor pero es lo mismo que clientes solo que para proveedores al igual que la cartera de Proveedores en el vídeo explico en detalle todo el funcionamiento de los formularios.

 

Pude comprar el Código Listo con el instalador incluido Software de Ventas Cactus 1.0 + Código

Corrección Formulario Ventas Guardado de Saldo de Cliente:

En el formulario de Ventas Puede reemplazar el procedimiento de Finalizar_Guardado_Factura:

Sub Finalizar_Guardado_Factura()
    
    Num_Factura = Ultima_Factura_Venta() 'Ultima venta
     
    FechaHora = txtFechaApro.Text & " " & Time 'fecha y hora
    
    Comentario = "-"
    If txtObervacionesPro.Text <> "" Then  'comentario
       Comentario = txtObervacionesPro.Text
    End If
    
    'calcular saldo
    SaldoFactura = 0
    If cmdTipoFact.ListIndex = 1 Then
        If CCur(txtAbonoFact.Text) > 0 Then
           SaldoFactura = CCur(txtTotalFactura) - CCur(txtAbonoFact.Text)
        Else
           SaldoFactura = CCur(txtTotalFactura)
        End If
    End If

        'Se guarda en la tabla ventas
    
    sql = "Insert Into tblVentas (Num_Factura, FechaHora, TipoFact, Dias, ImpuestoTotal, TotalFactura, EstadoFact, Comentario, Efectivo, Cambio, IdCliente, IdUsuario, SaldoFactura) " _
        & " VALUES (" & Num_Factura & ",'" & FechaHora & "'," & Me.cmdTipoFact.ListIndex & "," & txtDias.Text & ",'" & CCur(txtImpuestoFact) & "','" & CCur(txtTotalFactura) & "',1,'" & Comentario & "','" & CCur(txtVECambio.Text) & "','" & CCur(txtCambio.Text) & "'," & CodigoCliente & "," & Glo_IdUsuario & ", '" & SaldoFactura & "')"
    
    ConexionADO.Execute sql
    
    'A los productos del detalle se les asigna el numero de factura
    sql = "Update tblDetalle_Venta set Num_Factura = '" & Num_Factura & "', Num_VentaTemp = '0'  where Num_VentaTemp = " & ConsecutivoTemp
    ConexionADO.Execute sql
    
    '*************** Consulta que resta todos los articulos de inventario
   sql = "UPDATE tblProductos as ar INNER JOIN tblDetalle_Venta as d ON ar.IdProducto = d.IdProducto SET ar.ExistPro = (ar.ExistPro - d.Cantidad_dv) where d.Num_Factura = " & Num_Factura
   ConexionADO.Execute sql
   
      '/*//*********************** crear el historial de cada articulo en el kardex
   sql = "INSERT INTO tblKardex (Fecha, IdProducto, Detalle, D_C, Cantidad, Costo,Cant_Saldo) Select '" & FechaHora & "', dt.IdProducto, 'Venta de Mercancia según Fra. N° " & Num_Factura & " '," _
        & Num_Factura & ", dt.Cantidad_dv * -1, dt.P_Costo_dv, (Select ExistPro from tblProductos where IdProducto = dt.IdProducto) from tblDetalle_Venta as dt Where dt.Num_Factura = " & Num_Factura
   
   ConexionADO.Execute sql
   
    'Registramos el Saldo Total en la Tabla Saldos
    IdCliente = CodigoCliente
    
    consulta = "Select IdCliente, Saldo from tblSaldos_Clientes Where IdCliente = " & IdCliente
    Set RecordCliente = ConexionADO.Execute(consulta)
    
    
    If RecordCliente.RecordCount = 0 Then
        sqlSaldo = "Insert into tblSaldos_Clientes (IdCliente, Saldo, FechaMod) Values (" & IdCliente & ", '" & SaldoFactura & "', now()) "
    Else
        'Se toma el saldo guardado en la tabla y se le suma al saldo de la factura actual y se actualiza el saldo en la tabla
        Saldo = RecordCliente("Saldo") + SaldoFactura
        sqlSaldo = "Update tblSaldos_Clientes SET Saldo = '" & Saldo & "', FechaMod = Now() Where IdCliente = " & IdCliente
    End If
    
    ConexionADO.Execute sqlSaldo
    
   If chkImprimirSiNo.Value = 1 Then ' si el checkbox esta chuliado se imprime
        If glob_conf_ImpresoraTikets = 0 Then
           Call ImprimirFactura_carta(Num_Factura)
        Else
           Call ImprimirFactura_Ticket(Num_Factura)
        End If
   End If
    
   ConsecutivoTemp = UltimaVentaTemp
   
   Call LlenarGridProductos
   
   MsgBox "Venta Guardada", vbInformation, "Guardar"
   
   Call LimpiarVenta
   
End Sub

 

 

Total Page Visits: 8361 - Today Page Visits: 14

Deja una respuesta