If you haven't installed Node.js on your local PC, please complete the installation of Node.js.
Once installed, verify the installation by running node -v
in your command line or terminal. This will display the installed version of Node.js.
Move to react project's root directory
cd signage_solution/react_signage
To ensure proper communication between the client and servers, modify the server addresses in the src/constants.js
file:
-
Locate and open the
src/constants.js
file in your project's directory. -
Update the kiosk and flask server addresses and port numbers to match those of the servers you want to communicate with. Ensure that both the server and client are on the same Wi-Fi network.
// src/constants.js export const kiosk = 'http://{IP address of kiosk server}:4000'; export const flask = 'http://{IP address of flask server}:5001'; // Replace the IP addresses and ports as needed.
When running the project locally, you can use localhost in place of the IP address.
// For local setup in src/constants.js export const kiosk = 'http://localhost:4000'; export const flask = 'http://localhost:5001';
- Install Dependencies
npm install
- Start the Project
npm run start
Before starting the setup process, ensure the following requirements are met:
- Raspberry Pi Setup: You should have a Raspberry Pi that successfully boots with the webOS OSE image.
- Network Connection: The Raspberry Pi and your local PC must be connected to the same network. This connection is essential for the setup process using the webOS OSE CLI from your local PC.
- Node.js on Local PC: Node.js must be installed on your local PC as it is required to run the webOS OSE CLI.
-
Install the webOS OSE CLI by executing the following command:
sudo npm install -g @webosose/ares-cli
-
After installing the webOS OSE CLI, you can verify its installation by running:
ares
-
To set up a new device for development, use the ares-setup-device command. This will guide you through the process of registering and configuring a new device for your development environment:
ares-setup-device
-
To verify the devices that are already set up, use the following command:
ares-install -D
This will list all the devices that have been set up and are ready for development.
Before running the deploy.sh
script, ensure you are in the root directory of the React project, which is the parent directory where the build
will be created. The deploy.sh
script automates the building and deploying process of the project.
- The
deploy.sh
script should be located in the react project's root directory. - An
icon.png
file should also be placed in the react project's root directory. - Raspberry Pi with webOS set must be powered on
- The local PC (from which you are deploying) and the Raspberry Pi must be connected to the same network for successful deployment.
The deploy.sh
script performs the following actions:
- Builds the React project.
- Creates the appinfo.json file and copies the icon.png file into the build directory.
- Packages the application into an IPK file.
- Removes any existing installation of the app on the specified device.
- Installs and launches the new version of the app on the device.
- Opens the app inspector for debugging purposes.
- Cleans up by removing the build and IPK directories.
The script takes five arguments:
- Device name
- App ID
- App version
- Vendor name
- App title
- Install Dependencies
npm install
- Change its execution permission with the following command:
chmod +x deploy.sh
- To deploy your project, execute the deploy.sh script from the root directory of your React project:
example usage:
./deploy.sh {DEVICE_NAME} {APP_ID} {APP_VERSION} {VENDOR_NAME} {APP_TITLE}
./deploy.sh jongmal kr.ac.knu.app.signage 1.0.0 "My Company" "new app"
This script simplifies the deployment process, ensuring that your application is built, packaged, and deployed efficiently to your target device.
Note: When the deploy.sh
script removes any existing installation of the app, you may encounter an error message in the console during the initial deployment, or if the app corresponding to the APP_ID
does not exist on the device. This error is not a major concern and does not impede the deployment process.