Skip to content

iSCInc/mobile-wiki

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

renovate-app badge

Overview

Mobile Wiki is an application built on top of Ember and Ember FastBoot. This combination allows us serve server side rendered application to end client (The same code is executed on frontend and backend).

Setup

To begin your journey with Mobile Wiki all you need to do is:

  1. On devboxes, the repo is already downloaded. cd /usr/wikia/mobile-wiki
  2. Use npm run setup
  3. Use npm run dev
  4. Start developing

It's recommended to host mobile-wiki application on your devbox machine (make sure mobileWikiDev role is enabled). This setup solves many problems like dependencies, cross-domain scripting, etc. Development on local machine isn't tested. If you make that happen, please add "how to" here.

More available scripts are listed here

Access Mobile Wiki

Devbox environment

Open http://muppet.yourname.wikia-dev.pl/wiki/Kermit from mobile device or while emulating it in desktop browser. Or use curl -H "Host:muppet.yourname.wikia-dev.pl" "http://dev-yourname:7001/wiki/Kermit"

Scripts

  • npm run setup - install all dependencies
  • npm run build - build files for dev environment
  • npm run build-prod - build files for prod environment
  • npm run fastboot-server - run built application (requires application to be build first)
  • npm run dev - build, run application and watch files
  • npm run test - run tests
  • npm run linter - run ESLint on files that are outside ember project
  • npm run stylelint - run stylelint against all .scss in style folder
  • npm run stylelint -- --fix - run stylelint and fix all issues that can be automatically fixed
  • npm run clean - remove all dependencies and build directory
  • npm run svgo - optimize all SVG files in the repository (check out tasks/optimize-svg.sh for details and configuration)
  • (Experimental) npm run fastboot-debug - build and run application in debugging mode. Server side code can be interrupted by debuggers.

Settings

Mobile Wiki application currently supports three types of configuration.

  • Ember & FastBoot configuration computed at build time config/environment.js
  • Ember & FastBoot runtime configuration app/instance-initializers/config.js which has access to environment variables
  • Express server configuration (middleware in front of FastBoot server) config/fastboot-server.js

Some tips if you develop outside of devbox:

  • The devboxDomain must have your devbox name (without the dev- prefix) in it
  • If you want to test with consul, use mediawikiDomain: 'consul.service.sjc-dev.consul' or mediawikiDomain: 'consul.service.poz-dev.consul'

Development

FastBoot and Server side funtionality

  • Check if code is executed on server side: inject fastboot service fastboot: Ember.inject.service() and this.get('fastboot.isFastBoot')
  • Require node package: Whitelist package in package.json and const proc = FastBoot.require('proc')
  • Read request headers: this.get('fastboot.request.headers')
  • Set response headers: this.get('fastboot.request.headers').set('x-header', 'value')
  • more on https://ember-fastboot.com/docs/user-guide

Linting

  • npm run lint:js
  • npm run lint:js -- --fix

Shoebox

To improve frontend performance we avoid making the same requests on backend and frontend. Shoebox helps us passing data from server to browser. Shoebox serilize data to JSON and puts it as script tag in HTML. In the browser shoebox reads data from HTML and uses it in Ember application.

const shoebox = this.get('fastboot.shoebox');

let data;

if (this.get('fastboot.isFastBoot')) {
  data = this.get('model').fetchData();

  shoebox.put('unique-key', data);
} else {
  data = shoebox.retrieve('unique-key');
}

// use your data

Sandboxes

Mobile-wiki is deployed to sandboxes using the mobile-wiki-deploy-sandbox jenkins job.

If you're in the #iris-tech channel, you can also make use of sandbot which is a chat bot with the following commands:

  • sandbot status - current status
  • sandbot taking <name of sandbox> to reserve one
  • sandbot releasing <name-of sandbox> to release one

See also

Mercury space - Confluence - Legacy documentation created before Mercury and Mobile Wiki split

Packages

No packages published

Languages

  • JavaScript 79.0%
  • CSS 12.5%
  • HTML 7.0%
  • Shell 1.2%
  • Python 0.3%