Skip to content
This repository has been archived by the owner on Aug 16, 2022. It is now read-only.

Commit

Permalink
💥 frappejs
Browse files Browse the repository at this point in the history
  • Loading branch information
rmehta committed Jan 16, 2018
1 parent df9fc91 commit 328a9de
Show file tree
Hide file tree
Showing 45 changed files with 159 additions and 71 deletions.
2 changes: 1 addition & 1 deletion app.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const server = require('frappe-core/server');
const server = require('frappejs/server');

server.start({
backend: 'sqllite',
Expand Down
2 changes: 1 addition & 1 deletion backends/rest_client.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');
const path = require('path');

module.exports = class RESTClient {
Expand Down
2 changes: 1 addition & 1 deletion backends/sqlite.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');
const sqlite3 = require('sqlite3').verbose();

class sqliteDatabase {
Expand Down
10 changes: 5 additions & 5 deletions client/desk/index.js
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');
const Search = require('./search');
const Router = require('frappe-core/common/router');
const Page = require('frappe-core/client/view/page');
const List = require('frappe-core/client/view/list');
const Form = require('frappe-core/client/view/form');
const Router = require('frappejs/common/router');
const Page = require('frappejs/client/view/page');
const List = require('frappejs/client/view/list');
const Form = require('frappejs/client/view/form');

module.exports = class Desk {
constructor() {
Expand Down
10 changes: 10 additions & 0 deletions client/desk/navbar.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,10 @@
const frappe = require('frappejs');

module.exports = class Navbar {
constructor({brand_label = 'App'} = {}) {
Object.assign(this, arguments[0]);
this.navbar = frappe.ui.add('div', 'navbar', frappe.header);
this.brand = frappe.ui.add('div', 'navbar-brand', this.navbar);
this.brand.textContent = this.brand_label || 'App';
}
}
2 changes: 1 addition & 1 deletion client/desk/search.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

module.exports = class Search {
constructor(parent) {
Expand Down
6 changes: 3 additions & 3 deletions client/index.js
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
const common = require('frappe-core/common');
const RESTClient = require('frappe-core/backends/rest_client');
const frappe = require('frappe-core');
const common = require('frappejs/common');
const RESTClient = require('frappejs/backends/rest_client');
const frappe = require('frappejs');
frappe.ui = require('./ui');
const Desk = require('./desk');

Expand Down
61 changes: 61 additions & 0 deletions client/style/index.scss
Original file line number Diff line number Diff line change
@@ -0,0 +1,61 @@
@import "node_modules/bootstrap/scss/bootstrap";

// html {
// font-size: 14px;
// }

.desk {
padding: 0px;
}

.nav {
display: none;
border-bottom: 1px solid $border-color;
align-items: center;
justify-content: center;
}

.two-column {
display: grid;
grid-template-columns: 1fr 4fr;
grid-auto-rows: minmax(100%, auto);
}

.main, .sidebar {
padding: 2rem;
min-height: 100vh;
}

.sidebar {
border-right: 1px solid $border-color;
}

.hide {
display: none !important;
}

.page-error {
text-align: center;
padding: 200px 0px;
}

.form-body {
.form-toolbar {
height: 2rem;
margin-bottom: 1rem;
}

.alert {
margin-top: 1rem;
}
}

.dropdown-menu-right {
right: 0;
left: auto;
}

.list-search {
max-width: 400px;
margin-bottom: 1rem;
}
8 changes: 5 additions & 3 deletions client/ui/dropdown.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

class Dropdown {
constructor({parent, label, btn_class = 'btn-secondary', items = []}) {
Expand Down Expand Up @@ -64,11 +64,13 @@ class Dropdown {
}

add_item(label, action) {
let item = frappe.ui.add('a', 'dropdown-item', this.dropdown_menu);
let item = frappe.ui.add('button', 'dropdown-item', this.dropdown_menu);
item.textContent = label;
item.setAttribute('type', 'button');
if (typeof action === 'string') {
item.src = action;
item.addEventListener('click', () => {
item.addEventListener('click', async () => {
await frappe.router.set_route(action);
this.toggle();
});
} else {
Expand Down
2 changes: 1 addition & 1 deletion client/ui/index.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');
const Dropdown = require('./dropdown');

module.exports = {
Expand Down
2 changes: 1 addition & 1 deletion client/view/controls/base.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

class BaseControl {
constructor(docfield, parent) {
Expand Down
2 changes: 1 addition & 1 deletion client/view/form.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');
const controls = require('./controls');

module.exports = class Form {
Expand Down
2 changes: 1 addition & 1 deletion client/view/list.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

module.exports = class List {
constructor({doctype, parent, fields}) {
Expand Down
6 changes: 3 additions & 3 deletions client/view/page.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

module.exports = class Page {
constructor(title) {
Expand All @@ -17,7 +17,7 @@ module.exports = class Page {
this.trigger('hide');
}

show(params) {
async show(params) {
if (frappe.router.current_page) {
frappe.router.current_page.hide();
}
Expand All @@ -31,7 +31,7 @@ module.exports = class Page {
frappe.router.current_page = this;
document.title = this.title;

this.trigger('show', params);
await this.trigger('show', params);
}

render_error(status_code, message) {
Expand Down
15 changes: 10 additions & 5 deletions common/router.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

module.exports = class Router {
constructor() {
Expand All @@ -16,6 +16,7 @@ module.exports = class Router {
if (page.param_keys) {
// make expression
// '/todo/:name/:place'.replace(/\/:([a-z1-9]+)/g, "\/([a-z0-9]+)");
page.depth = route.split('/').length;
page.expression = route.replace(/\/:([a-z1-9]+)/g, "\/([a-z0-9]+)");
this.dynamic_routes.push(page);
this.sort_dynamic_routes();
Expand All @@ -26,14 +27,18 @@ module.exports = class Router {
}

sort_dynamic_routes() {
// routes with fewer parameters first
// routes with more parts first
this.dynamic_routes = this.dynamic_routes.sort((a, b) => {
if (a.param_keys.length > b.param_keys.length) {
if (a.depth < b.depth) {
return 1;
} else if (a.param_keys.length < b.param_keys.length) {
} else if (a.depth > b.depth) {
return -1;
} else {
return a.route.length > b.route.length ? 1 : -1;
if (a.param_keys.length !== b.param_keys.length) {
return a.param_keys.length > b.param_keys.length ? 1 : -1;
} else {
return a.route.length > b.route.length ? 1 : -1;
}
}
})
}
Expand Down
1 change: 1 addition & 0 deletions docs/app.md
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
# Creating a new App
4 changes: 2 additions & 2 deletions docs/client/forms.md
Original file line number Diff line number Diff line change
Expand Up @@ -9,8 +9,8 @@ Note: A single Form object can handle multiple documents.
### Example

```js
const Page = require('frappe-core/frappe/client/view/page').Page;
const Form = require('frappe-core/frappe/client/view/form').Form;
const Page = require('frappejs/frappe/client/view/page');
const Form = require('frappejs/frappe/client/view/form');

edit_page = new Page('Edit To Do');

Expand Down
4 changes: 2 additions & 2 deletions docs/client/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,13 +23,13 @@ You can setup your client by setting up the server and then importing your contr
### Example

```js
const client = require('frappe-core/frappe/client');
const client = require('frappejs/frappe/client');

client.start({
server: 'localhost:8000',
container: document.querySelector('.container'),
}).then(() => {
const todo = require('frappe-core/frappe/models/doctype/todo/todo.js');
const todo = require('frappejs/frappe/models/doctype/todo/todo.js');
frappe.init_controller('todo', todo);

// ....
Expand Down
6 changes: 3 additions & 3 deletions docs/client/lists.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,14 +5,14 @@ A list object handles object listing and paging, for a standard model.
### Example

```js
const Page = require('frappe-core/frappe/client/view/page').Page;
const ListView = require('frappe-core/frappe/client/view/list').ListView;
const Page = require('frappejs/frappe/client/view/page');
const List = require('frappejs/frappe/client/view/list');

// create a new page
let todo_list = new Page('ToDo List');

// init a new list
todo_list.list = new ListView({
todo_list.list = new List({
doctype: 'ToDo',
parent: this.todo_list.body
});
Expand Down
2 changes: 1 addition & 1 deletion docs/client/page.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ A page is a basic container that fills up the `main` area of the Frappe.js SPA.
### Example

```js
const Page = require('frappe-core/frappe/client/view/page').Page;
const Page = require('frappejs/frappe/client/view/page').Page;

let todo_list = new Page('ToDo List');

Expand Down
2 changes: 1 addition & 1 deletion docs/client/router.md
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ Dynamic routes can be added by declaring each parameter as `:param` in the route
### Example

```js
const Page = require('frappe-core/frappe/client/view/page').Page;
const Page = require('frappejs/frappe/client/view/page').Page;

let todo_list = new Page('ToDo List');

Expand Down
2 changes: 1 addition & 1 deletion docs/client/ui/dropdown.md
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,7 @@ Methods
### Create

```js
const Dropdown = require('frappe-core/frappe/client/ui/dropdown');
const Dropdown = require('frappejs/frappe/client/ui/dropdown');

let dropdown = new Dropdown({label:'Actions', parent:this.toolbar});
```
Expand Down
3 changes: 3 additions & 0 deletions docs/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ Frappe.js is a meta-data driven framework that enables rapid application develop

## Contents

- [Making a new App](app.md)
- Models and Documents
- [Declaring Models](models/index.md)
- [Controllers](models/controllers.md)
Expand All @@ -19,5 +20,7 @@ Frappe.js is a meta-data driven framework that enables rapid application develop
- [Controls](client/controls.md)
- [UI](client/ui/index.md)
- [Dropdown](client/ui/dropdown.md)
- [Desk](client/desk.md)
- [Backends](backends.md)
- [Errors](errors.md)
- [Testing](testing.md)
2 changes: 1 addition & 1 deletion docs/models/controllers.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ You can bind events to the controller that will be called when an action is comp
The document controller represents a single record and is subclassed from the `frappe.document.Document` class

```js
const frappe = require('frappe-core');
const frappe = require('frappejs');

// extend the document and add event handlers
class todo extends frappe.document.Document {
Expand Down
4 changes: 2 additions & 2 deletions docs/server/backends.md
Original file line number Diff line number Diff line change
Expand Up @@ -22,7 +22,7 @@ The backend will implement the following `async` methods
Connection paramter required for the sqlite backend is the path of the file

```js
sqllite = require('frappe-core/frappe/backends/sqlite');
sqllite = require('frappejs/frappe/backends/sqlite');

frappe.db = await new sqlite.Database({db_path: db_path})
```
Expand All @@ -42,7 +42,7 @@ For the client, the backend is the REST API that executes calls with web-request
Before using, you must initialize the `frappe.fetch` property with `window.fetch` or `node-fetch`

```js
const Database = require('frappe-core/frappe/backends/rest_client').Database;
const Database = require('frappejs/frappe/backends/rest_client').Database;

frappe.fetch = window.fetch.bind();
frappe.db = await new Database({server: server});
Expand Down
2 changes: 1 addition & 1 deletion docs/server/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -5,7 +5,7 @@ The framework comes bundles with an `express.js` web server with pre-built backe
### Example

```js
const server = require('frappe-core/frappe/server');
const server = require('frappejs/frappe/server');

server.start({
backend: 'sqllite',
Expand Down
2 changes: 1 addition & 1 deletion model/document.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

class Document {
constructor(data) {
Expand Down
2 changes: 1 addition & 1 deletion model/meta.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
const Document = require('./document').Document;
const frappe = require('frappe-core');
const frappe = require('frappejs');

class Meta extends Document {
constructor(data) {
Expand Down
2 changes: 1 addition & 1 deletion model/models.js
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
const process = require('process');
const frappe = require('frappe-core');
const frappe = require('frappejs');

class Models {
constructor() {
Expand Down
2 changes: 1 addition & 1 deletion models/doctype/todo/todo.js
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
const frappe = require('frappe-core');
const frappe = require('frappejs');

class todo_meta extends frappe.meta.Meta {
setup_meta() {
Expand Down
Loading

0 comments on commit 328a9de

Please sign in to comment.