Component for reading/saving data directly into source code.
Include the scripts in html as follow:
<script src="https://unpkg.com/config-template-merger/public/direct-data.js"></script>
Add to package.json
:
"dependencies": {
...
"direct-data": "^1.0.0",
...
}
Use Browserify to make classes available in browser
In package.json
:
"scripts": {
...
"browserify": "browserify browserify/main.js -s dok-lib -o public/gen/compact.js",
...
},
In browserify/main.js
:
const { DirectData } = require('direct-data');
module.exports = {
DirectData,
};
DirectData is used for reading and saving data. It's meant to read from JSON file, with an option to save if the current app is ran from Node.js.
const directData = new DirectData();
directData.onSave = () => console.log("Data saved.");
const data = await directData.getData("pathToData");
// manipulate data
data.field1 = 123;
data.field2 = 456;
directData.didChange("pathToData");
// after 3 sec, the updated data gets saved. Typically, it's used to save directly into the code base.
// Note: If directData is used outside of Node.js (or without a proper dataWriter), then it can be used to just read data.
ServerHandler is used on Node.js side. Attached to an express app, it exposes API to load and save to the local source.
This gives access to save and load, through the "/data" endpoint.
const { ServerHandler } = require('direct-data/src/server-handler.js');
const app = express();
new ServerHandler(app);
The second parameter (optional) is "readOnly", to disable all write.
A folder can be passed as 3rd parameter to specify the folder to save to. Ex:
const app = express();
new ServerHandler(app, false, `${__dirname}/public/database`);