...
Main app component resides in /src/App.tsx
. Lets have a look at it
Code Block | ||
---|---|---|
| ||
import React from 'react'; import { useSettings } from '@ombori/ga-settings'; import logo from './logo.svg'; import './App.css'; import { Schema as Settings } from './schema'; function App() { const settings = useSettings<Settings>(); const productName = settings?.productName; const productPrice = settings?.productPrice; if (!settings) { return <div className="App">Loading gridapp settings...</div> } return ( <div className="App"> <header className="App-header"> <img src={logo} className="App-logo" alt="logo" /> <p>Product name: {productName}</p> <p>Product price: {productPrice}</p> </header> </div> ); } export default App; |
...
When started, every application receives a settings object, that contains values that can be changed without recompiling rebuilding the app. During the local development settings are stored in /src/settings/index.json
file.
...
Because settings are loaded dynamically, useSettings
may return falsy value when loading is not yet complete.
Settings schema
When app is used in grid console, its settings may be changed without rebuilding the app. The settings are displayed in a form, which is autogenerated from a schema file, supplied with the app. React App template uses schema in TypeScript format, which is stored in src/schema.ts
. This file exports a single type, Schema
that is used as a result type for useSettings
call.
Lets have a look at it:
Code Block | ||
---|---|---|
| ||
/**
* @title Example schema
*/
export type Schema = {
/**
* @title Product name
* @default "My Example Product"
*/
productName: string;
/**
* @title Product price
* @default "99 USD"
*/
productPrice: string;
} |
As you may see, the file exports one type, an object with two properties: productName
and productPrice
, both stings. Along to every field, in a doxygen-style comment additional metadata is specified for every object property.
@title
- specifies a human-readable title for the form field
@default
- specifies a default value for the field. Note that the value is a TypeScript constant, and since both properties are strings, the value is put in double quotes.
Publishing the app
Now, lets try publishing our app and see how we can deploy it to a real device.
First, we need to build the app:
yarn build
...
The app is build in a so-called “gridapp bundle” - basically an archive with the all the files that will be deployed with the app.
omg app publish
This command will upload the pre-built version of the app to the Grid Console, making it available for use on your devices. Make sure you have an app created in your organisation before running the publish command.