Steve Jobs. Frases para el recuerdo

Ha muerto un personaje admirado (y odiado), un visionario, o no. Pero no se le puede negar que con muchos de sus productos ha cambiado la forma de acercarse a la tegnología de mucha gente.

Por su personalidad, y seguramente también por su enfermedad, ha dejado frases que me gustaría agrupar, para recordar. Frases que nos hacen pensar.

“Hay que decir ‘no’ a mil cosas para estar seguro de que no te estás equivocando o intentas abarcar demasiado”

“Si hoy fuese el último día de mi vida, ¿querría hacer lo que voy a hacer? Si la respuesta fuese ‘no’ durante demasiados días seguidos, sabría que necesitaba cambiar algo”

“Tu tiempo es limitado, no lo malgastes viviendo la vida de alguien distinto. No quedes atrapado en el dogma, que es vivir como otros piensan que deberías. No dejes que los ruidos de las opiniones de los demás acallen tu voz interior. Y, lo que es más importante, ten el coraje para hacer lo que te dicen tu corazón y tu intuición”

“Encontrad lo que amáis”

“A veces la vida te va a golpear en la cabeza con un ladrillo. No pierdas la fe”

“Ser el más rico del cementerio no es lo que más me importa. Acostarme por la noche y pensar que he hecho algo genial… Eso es lo que me importa”

“No puedo ir a preguntarle a los consumidores qué es lo que desean porque durante el tiempo que esté desarrollándolo, van a desear algo nuevo”

“Si tú lo deseas, puedes volar, sólo tienes que confiar mucho en ti”

Recordar que vas a morir es la mejor manera que conozco para evitar la trampa de pensar que tienes algo que perder”

“La única forma de hacer un gran trabajo es amar lo que se hace”

“Si vives cada día como si fuera el último, es muy probable que algún día hagas lo correcto”

“Estoy más orgulloso de las funcionalidades que no hemos incluido en nuestros productos de las que hemos incluido, creo firmemente que solo debemos incluir las funcionalides que  el 80% de nuestros clientes usarán. El resto de funcionalides contribuyen ha que el producto sea más dificil de entender y menos elegante”.

Por último enlace al famoso discurso de Steve Jobs en la ceremonia de graduación de la Universidad de Stanford el 12 de junio 2005

Anuncios

Objetos públicos o privados

Cuando programamos en v7, lo hacemos partiendo de objetos, y a estos les tenemos que definir una propiedades. Dentro de estas hoy voy a hablar de una, que quizás pase un poco desapercibida al no estar visible a simple vista, privado. Para acceder a ella vamos a la ventana de propiedades → estilos y los desplegamos, aquí pueden aparecer distintas características a definir, dependiendo del objeto. Algunas de ellas son:

  • Punto de inserción: para objetos formulario o acciones
  • Accesible web para procesos
  • Ejecutable en remoto para funciones
  • Privado

¿Para que sirve marcar un objeto como privado?

Pues al marcar un objeto como privado estamos diciendo que el usuario en tiempo de ejecución no va a poder verlo en ningún punto de la aplicación en la que esto es posible. Lógicamente todos los objetos se pueden ver y usar donde nosotros hemos programado que aparezcan 😉 (No vayáis a pensar que si, por ejemplo, marco como privado un opción de menú no se va a ver en ejecución en el menú que la he puesto)

Bien, ahora sabemos que cualquier objeto que hagamos (rejilla, informe, alternador, proceso, función, variable, constante, ………), es susceptible de aparecersele al usuario en algún momento!!

La siguiente pregunta que se nos viene a la cabeza es: ¿donde se ven los objetos que no están marcados como privados?

Sigue leyendo

Multiidioma real o dependiente

v7 nació sobre tres patas:

– Multiplataforma

– Orientado al trabajo en la nube, PaaS

– Multiidioma

Si embargo esta última se nos ha quedado un poco coja.

El caso es que nosotros podemos desarrollar aplicaciones con todos lo idiomas que queramos, de una forma sencilla. Con el vTraslator podemos hacer que un traductor, nos la traduzca de una forma sencilla, si conocientos informáticos. Hasta aquí muy bien….

Pero ahora queremos que el usuario pueda escoger su idioma preferido, de todos los idiomas que hemos incorporado a la aplicación,……. y nos encontramos que en ejecución solo le aparece el del sistema, español y el inglés 😦

¿por qué? ¿por qué?….. Sigue leyendo

Optimizando rejillas

A la hora de presentar una rejilla con datos en un formulario, se utiliza un “control objeto” sincronizador. Este tiene como entrada origen la ficha de la tabla del formulario y como salida una lista de la tabla destino

Si, por ejemplo, queremos cargar las líneas de un albarán haríamos un proceso con origen ficha del albarán y salida lista de las líneas. En su interior tendría:

Cargar plurales

Añadir lista a la salida

El problema que surge, es cuando en un formulario queremos cargar rejillas que pueden contener muchos registros, y seguro que no siempre los necesitamos todos. Como por ejemplo todos los albaranes de un cliente, todos los movimientos de almacén de un artículo,…..

En estos casos podemos usar un sistema mediante el cual por defecto se carguen vacias, alimentandolas mediante un evento cuando se necesite.

Vamos a desarrollar un ejemplo:

Sigue leyendo

Rebuscando

En v6 teníamos un funcionalidad en las rejillas que se denomina “Rebuscar”. Esta permitía realizar búsquedas, sobre el resultado de la búsqueda anterior indefinidamente, pudiendo mezclar de distintas formas el resultado de la nueva búsqueda con los datos de la rejilla.

Así podíamos:

– Nueva búsqueda. Realizar una búsqueda, de forma que primero limpiases la rejilla, y obteniendo los nuevos registros. Ejemplo buscar ciudades de “España”.

– Añadir nuevos registros a la rejilla. Esto nos permitía por ejemplo, si teníamos una búsqueda por países, obtener en una misma rejilla todas las ciudades de “España” con las de “Italia”.

– Quitar. Con esta opción podíamos quitar de la lista anterior las que tengan una densidad de población menor de 500000

– Cruzar. Esta opción obtenía todos los registros de la lista actual que cumpliesen las nuevas condiciones. En el ejemplo “Las ciudades costeras”

Con este ejemplo habríamos obtenido todas las ciudades de España e Italia costeras con una población mayor de 500000. Y sin embargo el programador solo nos había dejado una búsqueda de ciudades en la que podíamos escoger un país, ciudades costeras o no, y ciudades con una población mayor a una cantidad. Sigue leyendo

Controlando el acceso a los datos

Cuando se hacen aplicaciones para empresas, es normal que se requiera controlar los permisos de acceso al programa dependiendo del departamento. En este artículo os voy a explicar como lo hemos solucionado.

La aplicación está pensada para poder ser heredada y aplicarla a aplicaciones de cualquier fin, pudiendo incluso ser usada simultáneamente por más de una aplicación.

Distingo dos niveles de acceso:

  1. Acceso a menús
  2. nivel de autorización para crear/modificar datos

El control de accesos lo vamos a hacer a nivel de grupos de usuario, aprovechando la tabla que existe en vBase

Por lo que he creado cuatro tablas:

Acciones. En ella se dan de alta las acciones de menú que vamos a permitir activar o bloquear.

Tablas. Donde creamos las tablas que tendrán control de acceso a la información

Grupos – tablas. Donde definiremos los permisos de cada grupo de usuario con las tablas

Grupos – acciones. Para dar o quitar el acceso a las acciones por grupo.

Este es el esquema:

A nivel de acciones de menú no hay mas que dos posibilidades, o se permite o no se permite. Sin embargo en las tablas la cosa se puede complicar mucho (todo lo que queramos), desde controlar alta-modificación-baja, hasta controlar el acceso a cada campo (ver/modificar).

Sigue leyendo

vBase. Personalizando entidades

Al diseñar vBase nuestro objetivo era abstraer su contenido del uso que se pueda hacer desde otro proyecto. Por eso nuestra prioridad ha sido que en la tabla Entidades (ENT) no fuese necesario tener ningún dato dependiente de como interactuamos con ella a través de contabilidad, gestión, etc…
Para ello hemos creado una tabla de uso del programador “Tipo de entidad” (ENT_TIP) , donde cada proyecto podrá crear los tipos que necesite y la hemos relacionado con las entidades a través de la tabla “Entidad – Tipos de entidad” ( ENT_ENT_TIP).

Para manejar estas tablas, tenemos 4 funciones:

ENT_TIP_RSV_ALT.- Esta función nos crea un tipo de entidad, de uso reservado (El usuario no la podrá eliminar, ni modificar su código). La usaremos al inicializar nuestras aplicaciones.

fun:ENT_TIP_RSV_ALT@Entidades.dat(~CLT_TIP@vConta.dat, “Cliente “, 1)

ENT_ENT_TIP. Nos permite crear o verificar si existe una relación entre una entidad y un tipo de entidad. Nos retorna el ID de la tabla ENT_ENT_TIP.

fun:ENT_ENT_TIP@Entidades.dat(#ENT_CLT, ~CLT_TIP@vConta.dat, “N”, $EMP_ID_ENT@Entidades.dat)

ENT_ALT.- Un asistente para crear una entidad pasándole el tipo que queramos, nos retorna el ID de la entidad (tabla ENT), y se asegura que es del tipo pedido.

fun:ENT_ALT@vBase.app(~CLT_TIP@vConta.dat, $EMP_ID_ENT@Entidades.dat)

ENT_LOC.-  Un localizador de entidades, al cual le pasamos el tipo de entidad  (cliente, proveedor,..) y nos permite localizar por trozos, palabras… solo dentro de las entidades de tipo especificado.

fun:ENT_LOC@vBase.app( $EMP_ID_ENT@Entidades.dat , TIP_ENT, “”, “” )

Tipos de entidad

En esta tabla tenemos dos campos muy importantes:

Reservado: Cuando desde un proyecto creamos un tipo de entidad que necesitemos, como por ejemplo “alumno”, debemos marcarlo como “reservado”, de esta forma el usuario podrá ver y utilizar este tipo, pero no lo podrá modificar ni borrar (Al crear el tipo desde la función ENT_TIP_RSV_ALT ya se marca como tal). De esta forma, también permitimos al usuario de la aplicación crear sus propios tipos de entidad (estos no tendrán nunca la marca de reservado)

Multi empresa: Cuando indicamos que este tipo es multiempresa, le estamos indicando que el usuario cuando tenga más de una empresa, podrá definir una entidad como cliente para una empresa, sin que eso suponga que también estará como cliente para el resto.

Un ejemplo lo tenemos  en la vConta, desde donde creamos los tipos:

Id Nombre Multi Empresa Reservado
CLT Cliente Si Si
PRV Proveedor Si Si

Tipificando entidades

Una vez creados los tipos de entidad, el usuario podrá, desde la ficha de la entidad, definir que entidades son sus clientes y cuales sus proveedores (pudiendo, lógicamente, ser ambas cosas a la vez). Esto se realiza mediante la tabla ENT_ENT_TIP (Entidad – Tipos de entidad)

Localizando una entidad del tipo deseado

Cuando desde la contabilidad queremos buscar, por ejemplo un cliente, utilizamos la función ENT_LOC, que nos mostrará el siguiente localizador

A esta función se le pasa la empresa con la que estamos trabajando (necesaria para los tipos de entidad por empresa), y hasta 3 tipos de entidad (para permitirnos buscar, por ejemplo, clientes o preclientes)

Creando entidades desde otros proyectos

Para crear entidades desde otros proyectos disponemos de dos funciones que explicamos a continuación

ENT_ALT. Alta de entidad

Esta función nos realiza todo el proceso de creación de una entidad, mediante un asistente. Pero tiene 2 parámetros importantes:

–      TIP_ENT. Tipo de entidad: En el primer parámetro podemos pasarle el tipo de entidad que estamos creando (por ejemplo “CLT”, cliente), si queremos crear una entidad genérica pasaremos “”

–      EMP_ID. ID de la empresa: En el segundo parámetro indicamos con que empresa estamos trabajando.

La función nos retorna el ID de la entidad.

Dentro de la función se realiza el alta de la entidad, dirección y teléfonos de contactos, y al final se asegura que quede definida como cliente.

ENT_ENT_TIP. Verificar o crear relación entre entidad y tipo de entidad

A esta función le tenemos que pasar:

–      ID de la entidad

–      El tipo de entidad

–      La acción a realizar:

–      N. Nuevo: Nos crea el enlace, solo si no existe

–      V. Verificar: Retorna 0 si no existe

–      B. Borrar: Borra el enlace ente la entidad y el tipo

–      La empresa con la que trabajamos

La función nos retorna el ID de la tabla ENT_ENT_TIP.

Con esta función somos nosotros los que desde nuestra aplicación nos aseguramos que se establece el enlace, pudiendo además crear tablas con los datos específicos (formas de pago, tarifas,…) asociadas a la relación. Esto es importante si queremos utilizar campos de edición de clientes, donde podamos escribir el nombre, buscándonos únicamente en las entidades cliente.