GUI Components are one of the three basic components that can be added into the Fermat Framework. The two others are Addons, and Plugins. Each GUI component has a well defined responsibility within the system at usually collaborate from within one or more workflows in which it participates.
To accomplish it's mission, a GUI component must have a wireframe.
Several new concepts are introduced...
Una Wallet es un GUI Component que le permite a un usuario poder llevar acabo operaciones financieras como enviar y recibir bitcoins haciendo uso de los diferentes plugins que ofrece Fermat a travez Modules. Cada Wallet tiene un Module asociado, es decir, existe una relacion 1 a 1 entre una wallet y un modulo.
Una Wallet es un GUI Component que le permite a un usuario poder llevar acabo operaciones no financieras, tales como creacion de identidades dentro de la plataforma, tareas administrativas, etc haciendo uso de los diferentes plugins que ofrece Fermat a travez de Modules. Suelen servir para complementar la funcionalidad de las wallets. Cada Sub-App tiene un Module asociado, es decir, existe una relacion 1 a 1 entre una Sub-App y un Module.
This section will help you understand the workflow needed to be followed in order to implement a GUI component in Fermat.
### Getting Organized ---------------------
It is mandatory that you create an initial set of GitHub issues before you proceed further on the workflow. This will show the rest of the teams that someone is working in this functionality and avoid conflicting work early on. It will also hook the team leader into your workflow and allow him to guide and advise you when needed.
A basic hierarchy of issues is created as a first step. The issues are linked one to the other just by placing a link on the first comment.
Where we refer to 'Plugin Name' what we expect is the following information:
- Platform or Super Layer name - 3 characters.
- Layer name
- Plug-in name
All of them separated by " - ".
Issues that needs to be linked to it's parent must have their first line starting with "Parent: " + http link to parent issue.
Team leaders are tagged in the second line in order to ask them to assign the issue to you and at the same time subscribe to any issue update. This helps team leaders to follow the issue events and provide assistance or guidance is they see something wrong. The suggested format is:
"@team-leader-user-name please assign this issue to me."
#### Plug-in Issue Structure
The mandatory initial structure is the following: (note: the word ISSUE it is not part of the name)
##### ISSUE: '_Plugin Name_' - Plug-In
This is the root of your issue structure and must be labeled as SUPER ISSUE. It is closed only when all of it's children and grand children are closed.
##### ISSUE: '_Plugin Name_' - Analysis
This is the Analysis root. It is closed whenever all analysis is done. This issue must be linked to the root of the issue structure.
1 - ISSUE: **'_Plugin Name_' - Module - prototype**
This is the hardcoded module. Used for make the GUI prototype without use the fermat platform. This issue must be linked to the root of the issue structure.
2 - ISSUE: **'_Plugin Name_' - Module - connection**
This is the module connected with fermat platform. Used for make the GUI using the fermat platform. This issue must be linked to the root of the issue structure.
3 - ISSUE: **'_Plugin Name_' - GUI - screen - **
This issue is for a specific wireframe of a screen.
##### ISSUE: '_Plugin Name_' - Testing
This is the Testing root. It is closed whenever all testing is done. This issue must be linked to the root of the issue structure.
-
ISSUE: 'Plugin Name' - Testing - Unit Testing
-
ISSUE: 'Plugin Name' - Testing - Integration Testing
##### ISSUE: '_Plugin Name_' - QA
This is the QA root. It is closed whenever QA tests are passed. This issue must be linked to the root of the issue structure.
It is expected to have here child issues in the form 'Plugin Name' QA - Bug Fix n, where n is both the number and the bug name.
##### ISSUE: '_Plugin Name_' - Production
This is the Production root. It is closed whenever the Plug-in reaches production. It can be re-opened if bug issues are found on production and closed again once they are fixed. This issue must be linked to the root of the issue structure.
It is expected to have here child issues in the form 'Plugin Name' Production - Bug Fix n, where n is both the number and the bug name.
Los componentes de GUI se agrupan en proyectos que pueden representar una Wallet, una SubApp o un Desktop para una plataforma, por ejemplo: la plataforma CBP tiene 2 Wallets y 4 SubApps.
Cuando desees crear una nueva Wallet o Subapp o Desktop debes crear el proyecto que contendrá los componentes GUI en alguno de tres directorios que se muestran abajo siguiendo esta estructura:
+ Platform_Name
+ Client_Type (actualmente android)
+ desktop
- desktop_project_name_1
- desktop_project_name_2
+ reference_wallet
- wallet_project_name_1
- wallet_project_name_2
- wallet_project_name_n
+ sub_app
- sub_app_project_name_1
- sub_app_project_name_2
- sub_app_project_name_3
- sub_app_project_name_n
Donde:
- Platform_Name: se refiere a la plataforma done vas a crear tus componentes.
- Client_Type: se refiere a que dispositivo donde se va a crear el cliente, llamese Android, IPhone, una aplicacion Web, una aplicacion Desktop, etc, donde actualmente el ciente que estamos usando es Android por lo que el nombre de esta carpeta es "android".
- desktop: aqui colocas los proyectos que para los desktops de las subapps y las wallets.
- reference_wallet: aqui vas a crear los proyectos que representen wallets los cuales van a tener sus componentes GUI.
- sub_app: aqui vas a crear los proyectos que representen SubApps los cuales van a tener sus componentes GUI.
He aqui un ejemplo:
+ CBP
+ android
+ desktop
- fermat-cbp-android-desktop-sub-app-manager-bitdubai
- fermat-cbp-android-desktop-wallet-manager-bitdubai
+ reference_wallet
- fermat-cbp-android-reference-wallet-crypto-broker-bitdubai
- fermat-cbp-android-reference-wallet-crypto-customer-bitdubai
+ sub_app
- fermat-cbp-android-sub-app-crypto-broker-community-bitdubai
- fermat-cbp-android-sub-app-crypto-broker-identity-bitdubai
- fermat-cbp-android-sub-app-crypto-customer-community-bitdubai
- fermat-cbp-android-sub-app-crypto-customer-identity-bitdubai
Esto quiere decir que tengo un total de 8 proyectos que albergan componentes GUI, de los cuales 2 son Desktops, 2 son Wallets y 4 son SubApps.
Los nombres de los proyectos siguen el siguiente patron:
fermat-[platform_name]-[client_type]-[project_type]-[name_of_the_project]-[org_name]
Donde:
- platform_Name: se refiere a la plataforma done vas a crear tus componentes.
- client_type: se refiere a que dispositivo donde se va a crear el cliente, llamese Android, IPhone, una aplicacion Web, una aplicacion Desktop, etc, donde actualmente el ciente que estamos usando es Android por lo que el nombre de esta carpeta es "android".
- project_type: se refiere al tipo de proyecto para los que vas a crear los componentes GUI. Pueden ser desktop, reference-wallet o sub-app.
- name_of_the_project: este es el nombre del proyecto. Por ejemplo: si tu proyecto se llama Crypto Broker Community entonces has de colocar crypto-broker-community.
- org_name: este es el nombre de la organicacion desarrollador o empresa que esta creando el proyecto, por ejemplo: bitdubai.
He aqui un ejemplo:
fermat-cbp-android-sub-app-crypto-broker-community-bitdubai
Donde: cbp es la plataforma, android es el dispositivo, sub-app es el tipo de proyecto, crypto-broker-community es el nombre del proyecto y bitdubai es la organizacion resposable de los componentes de este proyecto. Esto quiere decir que el proyecto es una SubApp llamada Crypto Broker Community desarrollada para dispositivos Android y creada por BitDubai para la plataforma CBP.
Un proyecto GUI Component para Android en fermat tiene la siguiente estructura basica (Leyenda: + carpeta, > paquete, - archivo):
+ fermat-[platform_name]-[client_type]-[project_type]-[name_of_the_project]-[org_name]
- .gitignore
- build.gradle
- proguard-rules.pro
+ src
+ main
+ java
> com.bitdubai.[project_type].[name_of_the_project]
> fragmentFactory
> fragments
> preference_settings
> session
+ res
+ drawable
+ layout
+ menu
+ values
+ test
+ java
> unit.com.bitdubai.[project_type].[name_of_the_project]
Donde:
- Todo lo que va en la carpeta
src
son archivos y recursos que vas a necesitar para desarrollar tu wallet/subapp/desktop en android - Dentro de
src/main/java
se encuentra el paquete donde vas a colocar archivos Java (clases, intefaces, enums..) con tu codigo android. El mismo tiene los siguientes paquetes basicos: fragmentFactory, fragments, preference_settings y session. Cada uno de ellos explica en detalle mas adelante en este README. - Dentro de
src/main/res
se encuentran archivosxml
que representan layouts, menus, colores, strings, tamaños asi como archivos de imagenes y otros que representan los recursos visuales con los que van a interactuar las clases Java que tienen la logica android. - Todo lo que va en la carpeta
test
es codigo que se utiliza para hacer Unit Testing sobre la funcionalidades que desarrolles ensrc
- Los Unit Test se crean dentro del paquete
unit.com.bitdubai.[project_type].[name_of_the_project]
entest/java
- El archivo
build.gradle
es donde defines las dependencias del proyecto con otros de la plataforma o con librerias de terceros y aquellas que ofrece Android pero no por default (las Support Libraries por ejemplo). Tambien se define la version minima del S.O. sobre la que va a correr la app asi como la version del Android SDK que se va a usar, entre otras cosas (para mas informacion revisa este enlace) - El archivo
proguard-rules.pro
configura la herramienta Proguard. (para mas informacion revisa este enlace). NOTA: Actualmente no cofiguramos este archivo, por lo que esta vacio
cuando creas tu proyecto android para desarrollar tu wallet/subapp/desktop en un principio no va a ser reconocido como tal en la estructura de dependencias del proyecto raiz (fermat) y se va a mostrar como un directorio mas. Para que tu proyecto sea incluido en la estructura de dependencias es necesario agregar las siguientes lineas en el archivo settings.gradle
que se encuentra en la carpeta de la plataforma done vas a trabajar:
include ':fermat-[platform_name]-[client_type]-[project_type]-[name_of_the_project]-[org_name]'
project(':fermat-[platform_name]-[client_type]-[project_type]-[name_of_the_project]-[org_name]').projectDir = new File('platform_name/client_type/project_type/fermat-[platform_name]-[client_type]-[project_type]-[name_of_the_project]-[org_name]')
He aqui un ejemplo de parte del archivo settings.gradle
de la plataforma CBP (fermat/CBP/settings.gradle
):
...
//Desktop
include ':fermat-cbp-android-desktop-sub-app-manager-bitdubai'
project(':fermat-cbp-android-desktop-sub-app-manager-bitdubai').projectDir = new File('CBP/android/desktop/fermat-cbp-android-desktop-sub-app-manager-bitdubai')
include ':fermat-cbp-android-desktop-wallet-manager-bitdubai'
project(':fermat-cbp-android-desktop-wallet-manager-bitdubai').projectDir = new File('CBP/android/desktop/fermat-cbp-android-desktop-wallet-manager-bitdubai')
//Reference Wallet
include ':fermat-cbp-android-reference-wallet-crypto-broker-bitdubai'
project(':fermat-cbp-android-reference-wallet-crypto-broker-bitdubai').projectDir = new File('CBP/android/reference_wallet/fermat-cbp-android-reference-wallet-crypto-broker-bitdubai')
include ':fermat-cbp-android-reference-wallet-crypto-customer-bitdubai'
project(':fermat-cbp-android-reference-wallet-crypto-customer-bitdubai').projectDir = new File('CBP/android/reference_wallet/fermat-cbp-android-reference-wallet-crypto-customer-bitdubai')
//Sub App
include ':fermat-cbp-android-sub-app-crypto-broker-community-bitdubai'
project(':fermat-cbp-android-sub-app-crypto-broker-community-bitdubai').projectDir = new File('CBP/android/sub_app/fermat-cbp-android-sub-app-crypto-broker-community-bitdubai')
include ':fermat-cbp-android-sub-app-crypto-broker-identity-bitdubai'
project(':fermat-cbp-android-sub-app-crypto-broker-identity-bitdubai').projectDir = new File('CBP/android/sub_app/fermat-cbp-android-sub-app-crypto-broker-identity-bitdubai')
include ':fermat-cbp-android-sub-app-crypto-customer-community-bitdubai'
project(':fermat-cbp-android-sub-app-crypto-customer-community-bitdubai').projectDir = new File('CBP/android/sub_app/fermat-cbp-android-sub-app-crypto-customer-community-bitdubai')
include ':fermat-cbp-android-sub-app-crypto-customer-identity-bitdubai'
project(':fermat-cbp-android-sub-app-crypto-customer-identity-bitdubai').projectDir = new File('CBP/android/sub_app/fermat-cbp-android-sub-app-crypto-customer-identity-bitdubai')
include ':fermat-cbp-android-sub-app-customers-bitdubai'
project(':fermat-cbp-android-sub-app-customers-bitdubai').projectDir = new File('CBP/android/sub_app/fermat-cbp-android-sub-app-customers-bitdubai')
//PLUGINS
...
Un componente GUI en fermat se encuentra dividido en dos plugins, las interfaces gráficas y el module de dicha interfaz, este es el que posee las siguientes funcionalidades:
- Sirve de conexión entre los plugins de la plataforma, consumiendo los servicios que ellas proveen.
- Encapsula la lógica de presentación, recogiendo, ordenando y agrupando datos de los plugins.
-- estructura de navegación con ejemplos..
Fermat es una aplicación distinta al resto de las aplicaciones android; esta posee su porpia estructura de navegación, la cual se basa en pantallas y sub-pantallas que se van "pintando" desde objetos cargados en tiempo de ejecución, desde archivos que entregan la información sobre que es lo que se necesita dibujar en cada pantalla/sub pantalla y en que orden
Fermat posse un conjunto de librerías y paquetes desarrollados especialmente para trabajar sobre android. Seguir...
- Hay que mostrar la forma en la cual se crean los fragmentos y que todos extienden de FermatFragment.
- Hay que explicar el fragment factory, para que sirve y como se usa.
Cada GUI component posee un folder destinado al fragnent factory, el cual se encarga de conectar lo desarrollado en la estructura de navegación con los fragmentos controladores de dichas pantallas. Seguir..
- Hay que darle una brebe explicación de las sesiones.
Uno de los problemas encontrados es la persistencia de datos en memoria ya que el ciclo de vida un fragmento al no estar visible se elimina y se vuelve a crear al llamarlo nuevamente. Estos datos deben estar guardados en algún lugar en caso de que el usuario quiera cambiar de wallet y dejar la sesion abierta.
Para resolver esto existen las Sessions: son objetos que permiten persisitir en memoria y compartir entre los diferentes fragmentos que pueda tener una wallet o subapp informacion tal como la referencia al module de la wallet o subapp, referencia al Error Mananger (objeto que administra las excepciones generadas en la plataforma Fermat) y cualquier otra data que necesite tracender entre estos fragmentos dentro de un Map que trabaja con una key y el objeto que se necesite guardar.
Las sesiones se crean por cada wallet o subapp y la gestión de dichas sesiones es llevada a cabo a travez de un Wallet Manager y un Subapp Manager, teniendo así la posibilidad de regresar al momento en el que se encontraba el usuario al cambiar de pantalla.
Cada GUI component posee un folder destinado a la session. Que dependiendo del tipo de componente que se esté desarrollando puede ser una clase que herede de WalletSession o SubAppSession. Seguir...
Son sesiones que manejan informacion de una wallet, estas heredan de WalletSession
Son sesiones que manejan informacion de una subapp, estas heredan de WalletSession
- Brebe explicación de los settings con ejemplos