Skip to content
forked from gyliu513/dcos-ui

The UI for The Datacenter Operating System

License

Notifications You must be signed in to change notification settings

hchenxa/dcos-ui

 
 

Repository files navigation

DC/OS UI Velocity

Requirements

Node 4.x and NPM 3.x (and above) are required. We suggest using nvm or n to keep multiple Node versions on your system.

DC/OS Installation Instructions:

  1. Follow the instructions here to install a local cluster.
  2. Clone this repo:
git clone git@github.com:dcos/dcos-ui.git && cd dcos-ui
  1. Install dependencies:
npm i
  1. Add developer files for config overrides:
npm run scaffold

This will create webpack/proxy.dev.js and src/js/config/Config.dev.js. These files aren't tracked by git and provide a place to override proxy and general dcos-ui configuration.

  1. Start the development server:
npm start
  1. Navigate to http://localhost:4200

Using External Plugins

DC/OS UI comes bundled with some internal plugins within the /plugins directory. You can also load more plugins from another directory and they will be loaded into DC/OS UI along with the internal plugins. To set a directory for external plugins run:

npm config set externalplugins ../relative/path/to/plugins/directory

Adding npm Package Dependencies

If you want to add a new npm package to 'node_modules':

  1. Install the new package
  • Install and save dependencies in package.json

    npm install [your package] --save
    
  • Then, add the package to devDependencies

    npm install [your package] --save-dev
    
  1. Create a synced npm-shrinkwrap.json with devDependencies included by running

    npm shrinkwrap --dev
    
  2. Commit to repository

Development Setup (Sublime Text Only)

  1. Add the following to your Sublime Text User Settings:
{
  ...
  "rulers": [80], // lines no longer than 80 chars
  "tab_size": 2, // use two spaces for indentation
  "translate_tabs_to_spaces": true, // use spaces for indentation
  "ensure_newline_at_eof_on_save": true, // add newline on save
  "trim_trailing_white_space_on_save": true, // trim trailing white space on save
  "default_line_ending": "unix"
}
  1. Add Sublime-linter with jshint & jsxhint:
  • Installing SublimeLinter is straightforward using Sublime Package Manager, see instructions
  • SublimeLinter-eslint needs a global eslint in your system, see instructions
  1. Syntax Highlihgting for files containing JSX
  • Install Babel using Sublime Package Manager, see instructions. From here you can decide to use Babel for all .js files. See their docs for that. If you don't want to do that, continue reading.

  • Installing ApplySyntax using Sublime Package Manager, see instructions

  • Open up the user configuration file for ApplySyntax: Sublime Text -> Preferences -> Package Settings -> ApplySyntax -> Settings - User

  • Replace the contents with this:

    {
      // Put your custom syntax rules here:
      "syntaxes": [
        {
          "name": "Babel/JavaScript (Babel)",
          "rules": [
            {"first_line": "^\\/\\*\\*\\s@jsx\\sReact\\.DOM\\s\\*\\/"}
          ]
        }
      ]
    }
    

Module examples

Check out these module types that you can use as a blueprint.

Testing

See more info on testing here.

License and Author

Copyright 2016 Mesosphere, Inc.

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this repository except in compliance with the License.

The contents of this repository are solely licensed under the terms described in the LICENSE file included in this repository.

Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License.

Authors are listed in Authors.md file.

About

The UI for The Datacenter Operating System

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 54.9%
  • CSS 44.3%
  • Other 0.8%