diff --git a/package.json b/package.json index 07b4dbf..d163a08 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "react-component-playground", - "version": "0.3.5", + "version": "0.3.6", "description": "Isolated loader for React components", "main": "build/bundle.js", "repository": { diff --git a/src/components/component-playground.jsx b/src/components/component-playground.jsx index df94e95..6abe79b 100644 --- a/src/components/component-playground.jsx +++ b/src/components/component-playground.jsx @@ -207,20 +207,17 @@ module.exports = React.createClass({ }, _renderHomeButton: function() { - return - - - - - - - - - - + var classes = classNames({ + 'button': true, + 'play-button': true, + 'selected-button': !this.constructor.isFixtureSelected(this.props) + }); + + return + ; }, diff --git a/src/components/component-playground.less b/src/components/component-playground.less index 4023636..cf8a6a0 100644 --- a/src/components/component-playground.less +++ b/src/components/component-playground.less @@ -9,19 +9,24 @@ @left-nav-color: #adaaa4; @left-nav-color-selected: #dddcda; -@header-height: 140px; - -@atom-size: 200px; -@atom-nucleus-size: 30px; -@atom-ring-width: 8px; -@atom-ring-rotation: 70deg; -@atom-rotation-duration: 20s; -@atom-color: #61dafb; - -@header-menu-button-size: 50px; -@header-menu-editor-icon: url(); -@header-menu-editor-icon-selected: url(); -@header-menu-full-screen-icon: url(); +@header-height: 70px; // 50 + 2 * 10 margins +@header-button-size: @header-height - 2 * @default-spacing; + +@play-button-icon: url(); +@play-button-icon-selected: url(); +@editor-button-icon: url(); +@editor-button-icon-selected: url(); +@full-screen-button-icon: url(); + +@play-button-electron-size: 5px; +@play-button-electron-color: #61dafb; +@play-button-electron-duration: 5s; + +@keyframes roundandround { + to { + transform: rotate(360deg); + } +} @fixture-line-height: 30px; @fixture-component-font-size: 16px; @@ -52,85 +57,76 @@ .header { position: relative; height: @header-height; - background: @default-darken-color; overflow: hidden; - .atom { + .button { + display: inline-block; + width: @header-button-size; + height: @header-button-size; + border-radius: 100%; + background-position: center center; + background-repeat: no-repeat; + color: @left-nav-color; + + &:hover, + &.selected-button { + background-color: @left-nav-bgcolor-selected; + } + } + + .play-button { position: absolute; top: @default-spacing; - left: (@left-nav-width - @atom-size) / 2; - width: @atom-size; - height: @atom-size; - - .electron { - position: absolute; - width: 100%; - height: 100%; + left: @default-spacing; + background-image: @play-button-icon; + background-position: 15px center; // fine tune arrow position - &:nth-child(2) { - transform: rotateZ(60deg); - } - - &:nth-child(3) { - transform: rotateZ(120deg); - } - - .ring { - display: block; - width: 100%; - height: 100%; - border: @atom-ring-width solid @atom-color; - box-sizing: border-box; - border-radius: 50%; - transform: rotateX(@atom-ring-rotation); - } + &.selected-button { + background-image: @play-button-icon-selected; } - .nucleus { + .electron { position: absolute; top: 50%; left: 50%; - width: @atom-nucleus-size; - height: @atom-nucleus-size; - margin: 0.5 * -@atom-nucleus-size 0 0 0.5 * -@atom-nucleus-size; - background: @atom-color; - border-radius: 100%; + width: 0; + height: 0; + animation: roundandround @play-button-electron-duration infinite linear; + + &:after { + content: ''; + position: absolute; + top: -@header-button-size / 2; + margin: -@play-button-electron-size / 2 0 0 + -@play-button-electron-size / 2; + width: @play-button-electron-size; + height: @play-button-electron-size; + border-radius: 100%; + background: @play-button-electron-color; + } } } .menu { position: absolute; bottom: @default-spacing; - right: @default-spacing; + right: 0; margin: 0; .button { - display: inline-block; - width: @header-menu-button-size; - height: @header-menu-button-size; - border-radius: 3px; - background-color: fadeout(@left-nav-bgcolor, 10%); - background-position: center center; - background-repeat: no-repeat; - color: @left-nav-color; - - &:hover, - &.selected-button { - background-color: fadeout(@left-nav-bgcolor-selected, 10%); - } + margin-right: @default-spacing; + } - &.fixture-editor-button { - margin-right: @default-spacing; - background-image: @header-menu-editor-icon; + .fixture-editor-button { + background-image: @editor-button-icon; - &.selected-button { - background-image: @header-menu-editor-icon-selected; - } + &.selected-button { + background-image: @editor-button-icon-selected; } + } - &.full-screen-button { - background-image: @header-menu-full-screen-icon; - } + .full-screen-button { + background-image: @full-screen-button-icon; } } } @@ -141,6 +137,7 @@ bottom: 0; left: 0; right: 0; + background: @default-darken-color; overflow-x: hidden; overflow-y: auto; @@ -151,7 +148,6 @@ .component { padding: 0.5 * @default-spacing 0; - border-top: 1px solid @default-darken-color; .component-name { display: block; diff --git a/tests/components/component-playground/default/render/dom.js b/tests/components/component-playground/default/render/dom.js index 74fb146..920335e 100644 --- a/tests/components/component-playground/default/render/dom.js +++ b/tests/components/component-playground/default/render/dom.js @@ -61,4 +61,9 @@ describe(`ComponentPlayground (${FIXTURE}) Render DOM`, function() { it('should not render fixture editor', function() { expect(component.refs.editor).to.not.exist; }); + + it('should add selected class on home button', function() { + expect($(component.refs.homeButton.getDOMNode()) + .hasClass('selected-button')).to.be.true; + }); }); diff --git a/tests/components/component-playground/selected-fixture-and-editor/render/dom.js b/tests/components/component-playground/selected-fixture-and-editor/render/dom.js index 46780eb..d40a5bb 100644 --- a/tests/components/component-playground/selected-fixture-and-editor/render/dom.js +++ b/tests/components/component-playground/selected-fixture-and-editor/render/dom.js @@ -24,9 +24,7 @@ describe(`ComponentPlayground (${FIXTURE}) Render DOM`, function() { }); it('should add selected class on editor button', function() { - // XXX: Class is set on button parent - expect($(component.getDOMNode()) - .find('.fixture-editor-button') + expect($(component.refs.editorButton.getDOMNode()) .hasClass('selected-button')).to.be.true; }); diff --git a/tests/components/component-playground/selected-fixture/events/dom.js b/tests/components/component-playground/selected-fixture/events/dom.js index 3f0c7ce..2afee06 100644 --- a/tests/components/component-playground/selected-fixture/events/dom.js +++ b/tests/components/component-playground/selected-fixture/events/dom.js @@ -29,7 +29,7 @@ describe(`ComponentPlayground (${FIXTURE}) Events DOM`, function() { }); it('should route link on home button', function() { - utils.Simulate.click(component.refs.homeLink.getDOMNode()); + utils.Simulate.click(component.refs.homeButton.getDOMNode()); expect(component.props.router.routeLink).to.have.been.called; }); diff --git a/tests/components/component-playground/selected-fixture/render/dom.js b/tests/components/component-playground/selected-fixture/render/dom.js index e9ae4a4..0f0acc1 100644 --- a/tests/components/component-playground/selected-fixture/render/dom.js +++ b/tests/components/component-playground/selected-fixture/render/dom.js @@ -27,6 +27,11 @@ describe(`ComponentPlayground (${FIXTURE}) Render DOM`, function() { expect($previewContainer.hasClass(fixture.containerClassName)).to.be.true; }); + it('should remove selected class on home button', function() { + expect($(component.refs.homeButton.getDOMNode()) + .hasClass('selected-button')).to.be.false; + }); + it('should add extra class to selected fixture', function() { var $fixture = $component.find('.component-fixture.selected');