Rancher UI
Go to file
Westly Wright ff1d1e56c4
refactor global resource memeber access
pass the access types down rather that own the access types and manipulate

rancher/rancher#18938
2019-03-25 11:55:59 -07:00
.github update headers 2018-10-01 15:33:02 -07:00
app Better dark theme project nav 2019-03-22 15:47:53 -07:00
blueprints Switch to @rancher/ember-api-store 2019-01-10 16:44:35 -07:00
config Flip the lazy loading switch for all engines and remove browserify 2018-10-11 12:03:44 -07:00
lib refactor global resource memeber access 2019-03-25 11:55:59 -07:00
public route 53 2019-02-06 14:28:36 -07:00
scripts update drone syntax for 1.x 2019-03-21 14:06:29 -07:00
server Fix websocket forwarded headers 2019-02-20 12:57:04 -07:00
ssl New cert with SAN for Chrome 58+ 2018-10-26 12:19:48 -07:00
tests Flip the lazy loading switch for all engines and remove browserify 2018-10-11 12:03:44 -07:00
translations Drop "Rotate CA Certs" option from rotate certs modal 2019-03-20 15:10:45 -07:00
vendor Show containerd version/icon on nodes 2019-03-12 13:05:51 -07:00
.ackrc Catalog support 2017-12-12 03:44:43 -07:00
.bowerrc Initial Import 2014-12-17 14:19:03 -07:00
.dockerignore Dockerfile 2017-02-11 00:50:06 -07:00
.drone.yml Create dist folder instead of conditionally setting DAPPER_OUTPUT 2019-03-25 10:27:45 -07:00
.editorconfig Ember 1.12 updates 2015-06-26 01:37:39 -07:00
.ember-cli Add selfsigned SSL for local devlopment 2016-02-01 13:11:46 -07:00
.eslintignore Flip the lazy loading switch for all engines and remove browserify 2018-10-11 12:03:44 -07:00
.eslintrc.js Support Aliyun/Tencent/Huawe hosted k8s 2018-12-05 10:29:32 +08:00
.gitignore ignore temp Dockerfile.dapper 2019-03-24 14:38:27 -07:00
.gitmodules term.js -> xterm.js (rancher/rancher#5049) 2016-07-08 13:50:33 -07:00
.ignore Flip the lazy loading switch for all engines and remove browserify 2018-10-11 12:03:44 -07:00
.travis.yml Update to 2.16.2 from beta branch for fixes 2017-11-08 11:18:52 -07:00
.watchmanconfig Webhooks (#954) 2016-12-27 16:33:04 -07:00
Dockerfile Update build/test to use docker build image 2018-10-30 14:34:54 -07:00
Dockerfile.dapper Create dist folder instead of conditionally setting DAPPER_OUTPUT 2019-03-25 10:27:45 -07:00
LICENSE Remove notice from license 2015-02-25 15:23:22 -07:00
README.md Copyright date 2019-03-22 14:46:24 -07:00
crowdin.yml Add the script for updating i18n files 2017-10-13 20:38:04 +08:00
ember-cli-build.js fixup 2018-12-18 14:10:06 -07:00
jsconfig.json Add Conatiner Cloud user registration system 2017-02-10 17:02:54 -07:00
package.json bump master to 2.3 2019-03-20 11:22:47 -07:00
testem.js Missed what seemed to be a critical update to the testem.js file 3.3 2018-08-16 15:06:54 -07:00
yarn.lock security resolutions from github 2019-03-19 11:48:44 -07:00

README.md

Rancher UI

Perhaps you like managing Cattle.

Usage

Prerequisites:

If you're on a Mac and use Homebrew, you can follow these steps:

  brew install node watchman yarn

Setup:

  git clone 'https://github.com/rancher/ui'
  cd 'ui'
  ./scripts/update-dependencies

Run development server:

  yarn start

Connect to UI at https://localhost:8000/ . The server automatically picks up file changes, restarts itself, and reloads the web browser. This is intended only for development, see below for distributing customizations.

Run development server pointed at another instance of the Rancher API

  RANCHER="http://rancher:8080/" yarn start

RANCHER can also be hostname[:port] or ip[:port].

Compiling for distribution

Rancher releases include a static copy of the UI passed in during build as a tarball. To generate that, run:

  ./scripts/build-static

Customizing

We highly suggest making customizations as an ember-cli addon rather than forking this repo, making a bunch of changes and then fighting conflicts to keep it up to date with upstream forever. ui-example-addon-machine is an example addon that adds a custom screen for a docker-machine driver. If there is no way for you to get to what you want to change from an addon, PRs to this repo that add generalized hooks so that you can are accepted.

Translations

Rancher UI supports localization via translations files. You can swap translations live by utilizing the Language Picker located in the footer. If you would like to add your own translations files follow the directions below.

  • Fork the Rancher UI repo
  • Copy the en-us.yaml file located in /translations folder and rename using the <language-code>/<country-code>.yaml format (Supported Locales)
  • Replace the values on each key with you're new values corresponding to your language
  • Ensure you replace the languageName value as this is what will be displayed in the language picker in the UI
  • While developing you can use SHFT + L when not focused in an input or text area to toggle the languages between your currently selected language and a special none language to see what key values are missing
  • When you've finished you're translations issue a pull request back to the Rancher UI repo to have your translation included

Hosting remotely

If you want to customize the UI, re-packaging all of Rancher to distribute the UI is possible but not terribly convenient. Instead you can change Cattle to load the UI source from a remote web server:

  • Build with ./scripts/build-static -l -c 'your-server.com'
  • Upload ./dist/static/latest2 so that it's available at https://your-server.com/latest2
    • It must be available over HTTPS.
    • You can rename the "latest2" part with the -v flag
  • Change the value of http[s]://your-rancher:8080/v3/settings/ui-index to the same https://yourserver.com/latest2 URL

Running Tests

  yarn global add ember-cli
  • ember test
  • ember test --server

Bugs & Issues

Please submit bugs and issues to rancher/rancher with a title starting with [UI] .

Or just click here to create a new issue.

License

Copyright (c) 2014-2019 Rancher Labs, Inc.

Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at

http://www.apache.org/licenses/LICENSE-2.0

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.