2
0
mirror of https://github.com/frappe/books.git synced 2025-01-26 00:28:25 +00:00
books/docs/app.md

110 lines
2.3 KiB
Markdown
Raw Normal View History

2018-01-16 11:39:17 +05:30
# Creating a new App
2018-01-16 12:05:07 +05:30
2018-01-16 12:59:49 +05:30
## Install Frappe.js
2018-01-16 12:19:38 +05:30
2018-01-16 12:05:07 +05:30
```
yarn add frappejs
```
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
FrappeJS comes with an Express Server on the backend, VueJS for the front-end and a CLI to run these things with built-in webpack configs.
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
## Config
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
FrappeJS requires a file named `frappe.conf.js` to be present in the root of your directory. Minimum configuration looks like:
2018-01-16 12:19:38 +05:30
```
2018-09-11 23:45:18 +05:30
module.exports = {
staticPath: './static', // uploaded files are served from this directory
distPath: './dist', // bundled assets are built and served here
dev: {
// your client side entry files
entry: {
app: './src/main.js'
},
outputDir: './dist',
assetsPublicPath: '/',
devServerPort: 8000,
env: {
PORT: process.env.PORT || 8000
}
},
node: {
paths: {
main: 'server/index.js' // your server entry file
}
},
electron: {
// wip
}
}
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
```
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
You also need an `index.html` located in the `src` directory. It can look like
2018-01-16 12:19:38 +05:30
```html
<!DOCTYPE html>
<html lang="en">
<head>
2018-09-11 23:45:18 +05:30
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>My Awesome App</title>
2018-01-16 12:19:38 +05:30
</head>
<body>
2018-09-11 23:45:18 +05:30
<div id="app"></div>
2018-01-16 12:19:38 +05:30
</body>
</html>
```
2018-03-21 15:18:01 +05:30
2018-09-11 23:45:18 +05:30
### Server
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
Assuming you have a `server/index.js` file, you can start the frappejs server in just a few lines of code.
2018-01-16 12:19:38 +05:30
```js
const server = require('frappejs/server');
server.start({
backend: 'sqlite',
2018-09-11 23:45:18 +05:30
connection_params: {
db_path: 'test.db'
}
2018-01-16 12:19:38 +05:30
});
```
2018-09-11 23:45:18 +05:30
### Client
2018-01-16 12:19:38 +05:30
2018-09-11 23:45:18 +05:30
In your client file you will have to initialize `frappe` and `models`.
2018-01-16 12:19:38 +05:30
`frappejs/client` lib will initialize your server and user interface with the Desk.
2018-09-11 23:45:18 +05:30
Example starting point for an app:
2018-01-16 12:19:38 +05:30
```js
2018-09-11 23:45:18 +05:30
import frappe from 'frappejs';
import io from 'socket.io-client';
import HTTPClient from 'frappejs/backends/http';
import common from 'frappejs/common';
import coreModels from 'frappejs/models';
2018-01-16 12:59:49 +05:30
2018-09-11 23:45:18 +05:30
frappe.init();
frappe.registerLibs(common);
frappe.registerModels(coreModels);
2018-01-16 12:59:49 +05:30
2018-09-11 23:45:18 +05:30
const server = 'localhost:8000';
frappe.fetch = window.fetch.bind();
frappe.db = new HTTPClient({ server });
const socket = io.connect(`http://${server}`);
frappe.db.bindSocketClient(socket);
2018-01-16 12:59:49 +05:30
```
2018-09-11 23:45:18 +05:30
## Start
2018-01-16 12:59:49 +05:30
2018-09-11 23:45:18 +05:30
To start the server and build webpack simultaneously you can use the cli command
2018-01-16 12:59:49 +05:30
2018-09-11 23:45:18 +05:30
```bash
./node_modules/.bin/frappe start
2018-02-13 15:35:41 +05:30
```