Sen descrición

jojo 45e103aa88 Try HTML element for main menu %!s(int64=5) %!d(string=hai) anos
server ca18f2f4d3 clean up & server authentication dev %!s(int64=5) %!d(string=hai) anos
src 45e103aa88 Try HTML element for main menu %!s(int64=5) %!d(string=hai) anos
www 64892d4666 remove cordova unnecessary dirs from git %!s(int64=6) %!d(string=hai) anos
.babelrc c9ce57239b init commit %!s(int64=6) %!d(string=hai) anos
.editorconfig c9ce57239b init commit %!s(int64=6) %!d(string=hai) anos
.eslintrc.json 08fd02fe2e changing webpack config %!s(int64=6) %!d(string=hai) anos
.gitignore 4d383fc990 refactor webpack config - end %!s(int64=6) %!d(string=hai) anos
README.md 8a6be9ff40 Create README.md %!s(int64=5) %!d(string=hai) anos
config.xml 232f7365ee cordova start %!s(int64=6) %!d(string=hai) anos
package-lock.json 95e6788666 adding socket.io %!s(int64=5) %!d(string=hai) anos
package.json 95e6788666 adding socket.io %!s(int64=5) %!d(string=hai) anos
settings.json c9ce57239b init commit %!s(int64=6) %!d(string=hai) anos
webpack.config.js 66ee802f7b introducing composition + prompt renderer %!s(int64=6) %!d(string=hai) anos

README.md

TWELVE HEROES

The digital version of the boardgame

How to modify & run

1. requirements

  • NodeJS : >= v10.17.0
  • npm : >= v6.11.3

2. Clone the repo

  • clone with your username (It will ask for your bitbucket password):
    git clone https://USERNAME@bitbucket.org/jojolb/twelve-heroes.git

! So far all the code I worked on is in the branch named "test" !

3. Work in your branch

  • cd twelve-heroes
  • All the new code in on branch "test" so go there :
    git checkout test

  • Create your own branch from this code and name it as you want :
    git checkout -b \<name of your branch\> test

  • To push modifs :
    from project root folder ("twelve-heroes/") : 1) git add . ( <-- with '.', it will add all modified files for a commit) 2) git commit -m "description of the change" 3) git push origin \<name of your branch\>

4. To run the app for tests

  • go in project root folder ("twelve-heroes/")
  • do once : npm install (<-- this will install all dependencies, might take some time)
  • do : npm run start
    Wait.... It will run the server (socket.io stuff) and launch app in chrome
    ( or do : npm run dev to launch app in chrome only without server)

Some info about the project

1. npm stuff

  • file package.json contains project config for npm
  • File package-lock.json is generated by npm. It never needs to be changed manually
  • Directory node_modules contains all dependant libraries. It is not on git, it is only locally
  • npm is usefull to keep track of dependencies and install them rapidly.
  • it provides npm scripts (see below). These are shortcuts for bilding, testing, deploying

2. Editor config & VS code settings

  • File .editorconfig contains config for editing
  • Install on VS code the plugin "EditorConfig for Visual Studio Code"
  • It will ensure we have same code format
  • With VS code, select code and select "Format Selection"
  • File settings.json contains config for VS code editor (overrides global config)

3. ES lint

  • File .eslintrc.json contains Linter configuration
  • It defines common coding rules
  • It acts like a "compiler", it will throw warnings or errors if coding rules were not respected

4. Babel

  • File .babelrc contains Babel config
  • Here we can use Javascript ES6 to code (new keywords like 'class')
  • Babel takes care of "transpiling" this ES6 code to ES5
  • Most browsers are compatible ES5 and not ES6, this is why it is necessary

5. Cordova

  • File config.xml contains Cordova config
  • Cordova is a framework that will package our app for Apple or Android
  • Directory "plugins" and "platforms" are not in git. They are used by Cordova when used to run the project.

6. Webpack

  • File webpack.config.js contains webpack config
  • Webpack is a powerful tool that lightens the code and bundles it intelligently. It is kind of a "compiler"
  • It also allows to run a local server to test our JS code (using BrowserSync plugin)
  • It supports "Hot reloading", meaning that once app is running, you can modify the code and it will reloads live in the browser
  • Directory "www" is where webpack is going to put the "compiled" app

7. Git ignore

  • File .gitignore is used for git
  • It defines the files we don't want to version on git (like build files, binaries, external node libraries)

8. Source code

  • "src" contains app code (client code)
  • "server" contains server code

NPM scripts

"scripts": {

"server": "babel-node server/main.js",
"dev": "webpack --watch",
"precor-build": "cordova prepare",
"cor-build": "CORDOVA=true cordova build -- --webpackConfig webpack.config.js",
"cordova": "CORDOVA=true cordova run -- -w webpack.config.js",
"start": "npm-run-all --parallel server dev lint:watch",
"lint": "esw webpack.config.* src --color",
"lint:watch": "npm run lint -- --watch",
"localtunnel": "lt --port 3000",
"share": "npm-run-all --parallel open:src localtunnel",
"test": "mocha --reporter progress \"src/**/*.test.js\"",
"test:watch": "npm run test -- --watch",
"clean": "git clean -fdx -e node_modules"

}

1. How NPM scripts work

  • In package.json, in section "scripts" are defined the npm scripts
  • npm run <script name> will run <script name>
  • npm start is a shortcut for npm run start
  • pre and post keywords :
    • Using prescript-name and postscript-name
    • with npm run script-name it will first run prescript-name, then script-name, and finally postscript-name
  • Using npm-run-all, it will run at the same time all the scripts declared behind this keyword
    • Useful for example to run clients and server at the same time, along with the "linting"

2. Description of the project npm scripts

  • npm run server
    • It launches the server (listening for clients connections using sockets)
  • npm run dev
    • It is launching the app for dev (not using cordova)
  • npm cor-build
    • It builds the code and prepares it for Cordova
  • npm run cordova
    • It runs the app using Cordova
    • Today the only target is "browser" (no Apple or Android yet)
  • npm run start or npm start
    • It runs in parallel the server, the app and the linting
    • While it is running you can modify app code and save
      • The linter will show live new errors or warnings, if any
      • Refresh page on chrome to see the changes
  • npm run lint
    • It checks the code once, see above
  • npm run lint:watch
    • It checks the code, see above
    • In addition to the command above, it checks live again the code after save
  • npm run localtunnel
    • It allows to share temporarily the app
    • After running npm start or npm run dev
    • Run this and it will give a public http address
    • If other person goes to this http address it will access the app
    • Useful to share briefly to the other what we are doing
    • Use run share below instead
  • npm run share
    • It runs in parallel the dev and localtunnel
  • npm run test
    • It runs once all the tests : all files *.test.js
    • Says what passed or failed
  • npm run test:watch
    • It runs the tests like above, after modifs to code and save, it will re-run automatically the tests
  • npm run clean
    • It cleans the build directory
    • WARNING : It will also remove new files or directory created and not added yet into git

Useful links

1. Google drive stuff

https://drive.google.com/open?id=11j-IW2OL5ZOaeF3YGyvXjFDLz7BJdpW_

2. Trello

https://trello.com/b/FZXHfg2J/twelve-heroes