mirror of
https://github.com/RetroShare/RetroShare.git
synced 2024-10-01 02:35:48 -04:00
50 lines
2.2 KiB
Markdown
50 lines
2.2 KiB
Markdown
|
A new approach to build a webinterface for RS
|
||
|
=============================================
|
||
|
|
||
|
1. get JSON encoded data from the backend, data contains a state token
|
||
|
2. render data with mithril.js
|
||
|
3. ask the backend if the state token from step 1 expired. If yes, then start again with step 1.
|
||
|
|
||
|
Steps 1. and 3. are common for most things, only Step 2. differs. This allows to re-use code for steps 1. and 3.
|
||
|
|
||
|
BUILD / DEVELOPMENT
|
||
|
------------
|
||
|
|
||
|
- install tools
|
||
|
sudo apt-get install TODO (insert package names for nodejs, ruby, sass here)
|
||
|
- run this once in webui-src directory, to install more tools
|
||
|
npm install
|
||
|
- start build
|
||
|
npm run watch
|
||
|
- the build process watches files for changes, and rebuilds and reloads the page. Build output is in ./public
|
||
|
- use the --webinterface 9090 command line parameter to enable webui in retroshare-nogui
|
||
|
- set the --docroot parameter of retroshare-nogui to point to the "libresapi/src/webui-src/public" directory
|
||
|
(or symlink from /usr/share/RetroShare06/webui on Linux, ./webui on Windows)
|
||
|
- retroshare-gui does not have a --docroot parameter. Use symlinks then.
|
||
|
|
||
|
CONTRIBUTE
|
||
|
----------
|
||
|
|
||
|
- if you are a web developer or want to become one
|
||
|
get in contact!
|
||
|
- lots of work to do, i need you!
|
||
|
|
||
|
TODO
|
||
|
----
|
||
|
[ ] make stylesheets or find reusable sass/css components
|
||
|
google material design has nice rules for color, spacing and everything: https://www.google.de/design/spec/material-design/introduction.html
|
||
|
[ ] find icons, maybe use google material design iconfont
|
||
|
[ ] use urls/mithril routing for the menu. urls could replace state stored in rs.content
|
||
|
[ ] drag and drop private key upload and import
|
||
|
[ ] link from peer location to chat (use urls and mithril routing)
|
||
|
[ ] add/remove friend, own cert
|
||
|
[ ] downloads, search
|
||
|
[ ] make reusable infinite list controller, the js part to load data from Pagination.h (tweak Pagination.h to make everything work)
|
||
|
should provide forward, backward and follow-list-end
|
||
|
[ ] backend: view/create identities
|
||
|
[ ] backend: chat lobby participants list
|
||
|
[ ] chat: send_message
|
||
|
[ ] backend: chat typing notifications
|
||
|
[ ] make routines to handle retroshare links
|
||
|
[ ] backend: edit shared folders
|
||
|
[ ] backend: view shared files
|