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');