Skip to content

hirespace/hirespace-static

Repository files navigation

This application consists of 3 main parts:

Node.js backend server - a light-weight playground for creating rich prototypes
Language: TypeScript
Dependencies: express, expect.js, mocha, node.js

Custom Sass framework + image assets
Language: Sass
Dependencies: image assets in /images

Tailored Front-End framework
Language: TypeScript
Dependencies: Jasmine, jQuery, knockout, lodash, moment, rxjs

Should you consider editing, or contributing to this project, please read the To Contribute section

Setup

    # Install node, if you don't have it already
    brew install node
    
    # Clone repo
    git clone https://github.com/hirespace/hirespace-static.git
    
    # cd in and run install script (will prompt for password)
    cd hirespace-static
    ./install.sh

To run

    # After setup
    gulp

The server runs on port 6065, the tests run on port 6066. You can change these settings in gulpfile.js and js/test/karma.conf.js.

To contribute

I recommend using the WebStorm IDE. Please make sure you have the correct code style settings before you contribute in form of a pull request. JSHint will be introduced overtime.

Using git

We use git-flow, and so it would be good to try and stick to the convention. Please use the default branch prefixes.

            # Install git-flow
            brew install git-flow

If possible, development should happen on a separate feature branch named after a JIRA ticket reference (if applicable).

            # This will create a new branch called feature/HS-...
            git flow feature start HS-...

To finish a feature, run

            git flow feature finish HS-...

and then create a pull request (from your develop branch).

Using the Front-End application

To bind a controller to a specific view, bind the name to the body's hs-ctr attribute:

    <body hs-ctr="TestController"></body>

Create a new directory in js/components, e.g. Test, in which we'll create a new file called TestController.ts:

    module hirespace {
        'use strict';
    
        export class TestController {
            constructor() {
                console.log('Hello, World!');
            }
        }
    
        // The controller will only be bound if you do the below – explicitly subscribe it under the hirespace module
        hirespace.App.subscribe('TestController', TestController);
    }

hs-bind

To bind data from controllers, we use the HsBind service.

In the controller:

    ...
    export class TestController {
        BookingData: BookingData;

        constructor() {
            console.log('Hello, World!');
            
            this.BookingData.venueName = 'Test Name';
            
            this.updateView();
        }
        
        updateView() {
            hirespace.View.updateView(this, 'body');
        }
    }
    
    class BookingData {
        venueName: string;
        
        constructor() {}
    }
    ...

In the HTML:

    <elem hs-bind="BookingData.venueName"></elem>

toggle-class

The most powerful part of the application is the ToggleClass model. It enables you to toggle classes on any HTML element based on rules (or their combinations), the number of which is unlimited.

For example, to toggle class active only when there is an object called bookingData attached to the current controller, do:

    <elem hs-class="active: bookingData"></elem>

Should you wish to add an OR assertion, for example customerData.type == 'admin', you can do:

    <elem hs-class="active: bookingData || customerData.role == 'admin'"></elem>

To add a AND assertion, you might do:

    <elem hs-class="active: bookingData.venue.manager && bookingData.venue.name"></elem>

toggle-elem

The ToggleElem model enables nimble control over toggling elements' visibility. The attribute is a list of id's to toggle on click on <elem>:

    <elem hs-toggle='["elem-id-1"]'></elem>

This will toggle .is-hidden class on #elem-id-1. To toggle more elements, simply add them to the list:

    <elem hs-toggle='["elem-id-1", "elem-id-2"]'></elem>

More features to be documented overtime.

To deploy

There are a couple of things you need to do before you can perform a release. First off, please take a few moments to familiarise yourself with Divshot. Secondly, make sure you have the correct admin rights (can be obtained from [email protected] or [email protected]) and that you have Divshot's CLI installed:

    npm install -g divshot-cli

Prior to making a release, ensure your develop branch is up to date and then checkout a new release branch using git-flow. I have set up both bump-version.sh and release.sh scripts so these should be executed while on the (release) branch.

bump-version.sh merely bumps the version number in bower.json and package.json and release.sh does following:

  1. Runs gulp commands which deploy production-ready assets and runs all tests
  2. Prompts divshot login
  3. (Re)creates /dist folder
  4. Copies all dependencies over to /dist folder
  5. Pushes the (/dist) folder to staging
  6. Asks whether you want to promote staging to production

Other

  • Bootstrap grid system docs here
  • FA icons docs here

Proxy setup:

    # Given Pow is installed
    echo 6065 > ~/.pow/static.hirespace