This Framework is to make a simple SQL web capture data program in typescript (class based), but with out knowledge of web programming (HTML, CSS, VUE).
- Vue 3 with SFC
- Nuxt 3
- Native HTML components
- Backend with Node express and VFPnode proyect https://github.com/siavcom/VFP-NODE
- SQL Data Base Postgres ( 12 or newer) or MSSQL (17 or newer)
- Make a simple program in typescript (class based), but with out knowledge of web programming (HTML, CSS, VUE).
It's based in use a main form (like ThisForm in VFP) made in typescript only, where each form has it owns components ( editBox, comboBox, checkBox, grid, modalContainer ,etc) and has it own methods (click(), when, valid() etc()) forming a component tree.
this.Form
/ | \
/ | \
/ | \
/ | \
/ | \
Component1 Component2 Component..n
/ | \
/ | \
click() when() valid()...etc()
there are some components where each one have it's own components (grid have a several columns components)
grid
/ | \
/ | \
/ | \
/ | \
Column1 Column2 Column..n
Each component has it own propierties.
- basic props
- Style props
- Position props (outdated)
and methods
-
click
-
when
-
valid
-
setFocus
-
interactiveChange
-
init
-
keyPress Handles key press events for the input. The pressed key value is stored in this.prop.Key.
-
onChangeValue When the value of this component changes, this method is called. It recieves an optional parameter styles, which is the styles of the component (style,inputStyle,labelsStyle). If it is not provided, it uses the component styles of the object. sample :The method changes the color of the input depending on the value selected. A = green, B = red, X = blue. @param {any} styles - The style of the component.
To make a reference to especific propierty you can do by using a complete name reference tree Map (Object) example: propierties : this.Form.style.display="inline-block" this.Form.style.width='800px'. this.Form.component1.prop.Type = 'editText' this.Form.component2.prop.Value='Customer name 1' or this.Parent.component2.prop.Value='Customer name 1' this.Parent.component1.component2.prop.Value='Customer name 1'
Calling a method :
this.Form.component4.click(). this.Parent.component1.component2.click()
- Form
- editText
- textLabel
- comboBox
- checkBox
- optionGroup
- grid
- Form (component container)
- Component Each component have serveral properties where each properties afect visual and database behaviour as values to.
- BaseClass: "editText", // HTML base class (Form, - - editText, comboBox, sppiner, grid, checkBox ...)
- Name: "", // Name of component.
- textLabel: "", // text label showing before input.
- Type 'text', // data types :
- number
- text
- date
- dateTime
- spinner
- checkBox.
- Value: '', // Value of component .
- First: false // component who receives a focus when new register is inserted .
- Disabled: false
- ErrorMessage: "" // Error message if component is not valid (after valid()=false or prop.Valid=false).
- Format: ""
- InputMask: ""
- MaxLength: 0
- Min:0 // Minimun value for number
- Max:99999 // Maximun value for number
- Placeholder: ""
- Position: 'main', // main, header , footer.
- ReadOnly: false
- TabIndex: 1 // Tab index of component.
Image: ''
- ReadOnly: false
- TabIndex: 0
- ToolTipText: 'Principal name ',.
- Visible: true
- background: "white",
- color: "#b94295",
- width: "64px",
- height: "auto",
- Maxheight: '13px',
- MaxWidth: 'auto',
- fontFamily: "Arial",
- fontSize: "13px", // automaticamente vue lo cambiara por font-size (para eso se utiliza la anotacion Camello)
- textAlign: "left",
- ...... serveral css style properties : .
# each prop.Value component can be gatter from a field of local SQL where :
- ControlSource: "tableName.fieldName // Name of sql field.
- RecordSource: 'viewTableName'
- SqlUpdate: true //true, when lost focus component, update field component. When false, update field component since tableUpdate method
- Capture: true // When capture is true, can't lost focus until Validate or esc
- First: false
- Focus: false // When put 1 , take focus this component
- Last: false
- Map: // Read only. Main structure map of this component, class, method example : "this.Form.componentName"
- Grid: false
- id: 0
- Key: 0
- Status: "I" // P)rocess, A)ctive , I)nitialization.
- Valid:true // (Internal use). the value of the component is good
- KeyId : true when this component is a field index for a table select , update or delete
- Currency: ' ' //USD,EUR,MXN
- CurrencyDisplay : 'code' //to use the ISO currency code
- Decimals : 2
- Max: "999999999"
- Min: "0"
- Step: "1"
- Style: 'decimal' // decimal, currency,percent,unit
- BoundColumn: 2 // The value is atached to column
- ColumnCount: 2 // Total column numbers in a comboBox
- ColumnWidths: '80%','20%' // width each column
- MultiSelect: true, // Can multiple select
- List: [], // List array result when MultiSelect=true
- Row: 0
- RowSourceType: 1 // How to fill the comboBox :
1-Value.
2-Alias,
3-Query SQL Server
4-Local Sql
5-Array
when RowSourceType=2 or 3, you have to specify the RowSource
- RowSourceType= 1
- ColumnCount = 2
- RowSource="House,H,Building,B,Departament,D"
- RowSourceType : 2
- RowSource : 'table.cod_nom,nom_nom'
Notes : You already have a local table SQL
- RowSourceType : 3
- RowSource : 'select cod_nom,nom_nom from lla1_nom order by nom_nom'
- RowSourceType : 4
- RowSource : 'select cod_nom,nom_nom from lla1_nom order by nom_nom'
- RowSourceType: 5
- ColumnCount = 2
- RowSource:[["Datos", "Tablas", "Indices", "Vistas", "Menú del sistema","Otros"],["D", "T", "I", "V", "M","O"]]
- Style = 2; //0=DropDown Combo 2=DropDown List
- display: "inline-block"
- flexGrow: "0" /* do not grow - initial value: 0 */
- flexShrink: "0" /* do not shrink - initial value: 1 */
- flexBasis: "auto" /* width/height - initial value: auto */
- flexWrap: "wrap"
- background: "white"
- color: "#b94295"
- width: "auto"
- maxWidth: "auto"
- minWidth: "auto"
- height: "auto"
- fontSize: "13px"
- fontFamily: "Arial"
- zIndex: 100 // tabIndex
- alignContent: "center"
- textAlign: "left"
- ....... serveral css style properties : .
A grid have a several columns where each column is a input or label component where each component if bind to a SQL table field .
For a complete example, take a look in page directory. Each directory is a Vue View Page. pages/SqlDictionary is the SQL database maintennce dicctionary, you can add tables with fields, index and SQL views for manipulate data access.
This have a 2 principal files, a view VUE (Main.vue) and typescript program (ThisForm.ts) ThisForm.tx is the begin typesccript program where is a component definition .
Each component has a separate typescript file.
-
select ().
-
useNodata (
, <alias?>). -
use (
-
tableUpdate(,,).
-
appendBlank(,).
-
deleteRow(<key_pri>,).
-
delete(,,).
-
insert(,).
-
execute(,<alias?>,).
-
select().
-
recCount().
-
recno().
-
goto().
-
skip().
-
scatter(,).
- Install Node.js 18.x or newer (recommended active LTS release) https://nodejs.org/en/download/ or use nvm https://github.com/nvm-sh/nvm
-
useful extensions for vscode .- Eslint
-
useful extensions for vscode .- Prettier Eslint
-
useful extensions for vscode .- Vue Official
-
Download back-end framework from https://github.com/siavcom/VFP-NODE and extrac it in a folder.
-
make a company folder in back-end forlder/app/emresas/
-
copy a sample faolder company in the company folder
-
rename sample folder to your company name
-
change the db.config.js file and use your SQL Server connection parameters
-
open a terminal in the back-end folder and run node server_socket.js
-
Download this framework from https://github.com/siavcom/web-ones-technology and extrac it in a folder.
-
open a terminal in the framework folder run npm install
you have to make a company folder in yout computer in /sistemas/name> run npx nuxi dev
-
Create a new SQL table. Go to SQL data diccionary in a menu .
-
Chose SQL Server table
-
Chose system menu
-
Add a new table
-
fill al data table caracteristics
-
save table
-
Create a new definition SQL table Go to SQL data diccionary in a menu .
- Chose table definition
- Chose system menu
- Chose table
- Add a new definition
- click accept
- insert fields
- fill up all caracteristics
- click accept notes : when a field is a primary key, the default value has to be m.
-
Create a new SQL view.
-
Create a new SQL index.
-
Vue 3 SFC
-
Nuxt 3
-
@nuxtjs/axios
-
@pinia/nuxt
-
pinia-plugin-persistedstate
-
@zip.js/zip.js
-
alasql
-
buffer
-
file-saver
-
socket.io-client
-
vue-sweetalert2
-
xlsx
-
@nuxt/image
-
maska
-
Back End https://github.com/siavcom/VFP-NODE
-
SQL Server ( MSSQL, Postgres soon )
- Object class programing.
- TypeScript.
- Some basic html css styles propierties.
- Ansi 99 standard SQL instructions.
- SQL Server skills ( MSSQL or/and Postgres )
- This framework is based in a SQL database.
- It's not complete yet. If you require install and use , let me know by mail or skype siavcom@hotmail.com.
- If you want a new feature, let me know by mail or skype siavcom@hotmail.com
- To use this Framework, you have to restore a initial SQL backup .
- If you are a VFP programer, clipper, dbase III or IV, this is the right option for programing in the web.
- If you have a question, let me now by mail or skype siavcom@hotmail.com
- I can help you if you want to use this framwork.
- I use linux (ubuntu 22.04, ubuntu 24.04) and Windows 10 to make this project.
-
I'm a old FOX programer with a lot experience in desing and programing in Visual Fox Pro (VFP),MSSQL and Postgres databases.
-
Author :
-
Fer Blocks (Principal desing,programinig and project director) . Linkedin https://www.linkedin.com/in/fernando-cuadras-846a20102/ .
-
Lupita Sotelo (Reports and SQL desing) .
-
Raul Castro (html and css desing) .
-
-
http://siavcom.com.mx skype & e-mail : siavcom@hotmail.com
[alias] type : string .Local SQL table alias.
[table] type : string .SQL Server remote view name.
[memoryObject] type : Object. It have field and value field SQL table example : m={ code_id : '000021', PurchaseDate : '2022-10-21' }.
[updateType] : type: number . Value = 0 Only row witch posisioned. Value = 1 All table rows until update error. if error, return a false else return true. Value= 2 All table rows.
[force]: type : boolean . Value =false If a update table fail because other user change data first, return false. Value =true If a update table fail because other user change data first.
[key_pri]: type: number. Table key_pri(id) number in SQLServer.
[recno] : type: number .Local SQL id recno number.
[SqlUpdate] type: boolean . Value=true. Delete SQLServer. Value=false. Only local SQL .
[sqlQuery] type: string. Sql Server query to execute.
[resultType] type : string.
[row] type: number. Recno row id to go.
[rowNumbers] type: number Row number. Forward it is Positive and backward it is negative.
[type] type: string . Value='MEMVAR'. Return a object with all field values). Value= 'FIELDS',). Return a object with specific field values).
[fieldArray] type: array. Array with specific field to obtain values.
position
Development: $ npx nuxi dev --port=3000 $ npm run dev