diff --git a/docs/src/app/app-routes.jsx b/docs/src/app/app-routes.jsx index 8fbe82249fe4dc..5155cbce57ebb1 100644 --- a/docs/src/app/app-routes.jsx +++ b/docs/src/app/app-routes.jsx @@ -36,7 +36,7 @@ import IconMenus from './components/pages/components/icon-menus'; import LeftNavPage from './components/pages/components/LeftNav/Page'; import Lists from './components/pages/components/lists'; import Menus from './components/pages/components/menus'; -import Paper from './components/pages/components/paper'; +import PaperPage from './components/pages/components/Paper/Page'; import Popover from './components/pages/components/popover'; import Progress from './components/pages/components/progress'; import RefreshIndicator from './components/pages/components/refresh-indicator'; @@ -97,7 +97,7 @@ const AppRoutes = ( - + diff --git a/docs/src/app/components/pages/components/Paper/ExampleCircle.jsx b/docs/src/app/components/pages/components/Paper/ExampleCircle.jsx new file mode 100644 index 00000000000000..6f9c783f51f161 --- /dev/null +++ b/docs/src/app/components/pages/components/Paper/ExampleCircle.jsx @@ -0,0 +1,37 @@ +import React from 'react'; +import Paper from 'material-ui/lib/paper'; + +const style = { + root: { + height: 100, + width: 100, + marginLeft: 40, + textAlign: 'center', + display: 'inline-block', + }, + p: { + lineHeight: '80px', + }, +}; + +const PaperExampleCircle = () => ( +
+ +

circle=true

+
+ +

circle=true

+
+ +

circle=true

+
+ +

circle=true

+
+ +

circle=true

+
+
+); + +export default PaperExampleCircle; diff --git a/docs/src/app/components/pages/components/Paper/ExampleRounded.jsx b/docs/src/app/components/pages/components/Paper/ExampleRounded.jsx new file mode 100644 index 00000000000000..acba3da39aada1 --- /dev/null +++ b/docs/src/app/components/pages/components/Paper/ExampleRounded.jsx @@ -0,0 +1,37 @@ +import React from 'react'; +import Paper from 'material-ui/lib/paper'; + +const style = { + root: { + height: 100, + width: 100, + marginLeft: 40, + textAlign: 'center', + display: 'inline-block', + }, + p: { + lineHeight: '80px', + }, +}; + +const PaperExampleRounded = () => ( +
+ +

rounded=false

+
+ +

rounded=false

+
+ +

rounded=false

+
+ +

rounded=false

+
+ +

rounded=false

+
+
+); + +export default PaperExampleRounded; diff --git a/docs/src/app/components/pages/components/Paper/ExampleSimple.jsx b/docs/src/app/components/pages/components/Paper/ExampleSimple.jsx new file mode 100644 index 00000000000000..1a0ea8dded8607 --- /dev/null +++ b/docs/src/app/components/pages/components/Paper/ExampleSimple.jsx @@ -0,0 +1,37 @@ +import React from 'react'; +import Paper from 'material-ui/lib/paper'; + +const style = { + root: { + height: 100, + width: 100, + marginLeft: 40, + textAlign: 'center', + display: 'inline-block', + }, + p: { + lineHeight: '80px', + }, +}; + +const PaperExampleSimple = () => ( +
+ +

zDepth=1

+
+ +

zDepth=2

+
+ +

zDepth=3

+
+ +

zDepth=4

+
+ +

zDepth=5

+
+
+); + +export default PaperExampleSimple; diff --git a/docs/src/app/components/pages/components/Paper/Page.jsx b/docs/src/app/components/pages/components/Paper/Page.jsx new file mode 100644 index 00000000000000..e340dba5b12520 --- /dev/null +++ b/docs/src/app/components/pages/components/Paper/Page.jsx @@ -0,0 +1,31 @@ +import React from 'react'; +import CodeExample from '../../../CodeExample'; +import PropTypeDescription from '../../../PropTypeDescription'; +import MarkdownElement from '../../../MarkdownElement'; + +import paperReadmeText from './README'; +import paperCode from '!raw!material-ui/lib/paper'; +import PaperExampleSimple from './ExampleSimple'; +import paperExampleSimpleCode from '!raw!./ExampleSimple'; +import PaperExampleRounded from './ExampleRounded'; +import paperExampleRoundedCode from '!raw!./ExampleRounded'; +import PaperExampleCircle from './ExampleCircle'; +import paperExampleCircleCode from '!raw!./ExampleCircle'; + +const PaperPage = () => ( +
+ + + + + + + + + + + +
+); + +export default PaperPage; diff --git a/docs/src/app/components/pages/components/Paper/README.md b/docs/src/app/components/pages/components/Paper/README.md new file mode 100644 index 00000000000000..41615003a9df2b --- /dev/null +++ b/docs/src/app/components/pages/components/Paper/README.md @@ -0,0 +1,5 @@ +## Paper +A [Paper](https://www.google.com/design/spec/layout/principles.html#principles-how-paper-works) +element is a basic container that can give depth to the page. + +### Examples diff --git a/docs/src/app/components/pages/components/paper.jsx b/docs/src/app/components/pages/components/paper.jsx deleted file mode 100644 index d664e283f642b6..00000000000000 --- a/docs/src/app/components/pages/components/paper.jsx +++ /dev/null @@ -1,157 +0,0 @@ -import React from 'react'; -import {ClearFix, Mixins, Paper} from 'material-ui'; -import ComponentDoc from '../../component-doc'; - -const {StyleResizable} = Mixins; -import Code from 'paper-code'; -import CodeExample from '../../CodeExample'; -import CodeBlock from '../../CodeExample/CodeBlock'; - -const PaperPage = React.createClass({ - - mixins: [StyleResizable], - - getStyles() { - let styles = { - root: { - height: '100px', - width: '100px', - margin: '0 auto', - marginBottom: '64px', - textAlign: 'center', - }, - group: { - float: 'left', - width: '100%', - }, - p: { - lineHeight: '80px', - height: '100%', - }, - }; - - if (this.isDeviceSize(StyleResizable.statics.Sizes.MEDIUM)) { - styles.group.width = '33%'; - } - - return styles; - }, - - _createParagraphElement(text) { - return

{text}

; - }, - - _createPaperElement(zDepth, text) { - return ( - - {this._createParagraphElement(text)} - - ); - }, - - _getGroupDefault() { - let elements = []; - for (let i = 1; i <= 5; i++) { - elements.push(this._createPaperElement(i, 'zDepth=' + i)); - } - return elements; - }, - - _getGroupRounded() { - let elements = []; - for (let i = 1; i <= 5; i++) { - elements.push(React.cloneElement(this._createPaperElement(i, 'rounded=false'), {rounded: false})); - } - return elements; - }, - - _getGroupCircle() { - let elements = []; - for (let i = 1; i <= 5; i++) { - elements.push(React.cloneElement(this._createPaperElement(i, 'circle=true'), {circle: true})); - } - return elements; - }, - - render() { - - let componentInfo = [ - { - name: 'Props', - infoArray: [ - { - name: 'circle', - type: 'bool', - header: 'default: false', - desc: 'Set to true to generate a circlular paper container.', - }, - { - name: 'rounded', - type: 'bool', - header: 'default: true', - desc: 'By default, the paper container will have a border radius. ' + - 'Set this to false to generate a container with sharp corners.', - }, - { - name: 'style', - type: 'object', - header: 'optional', - desc: 'Override the inline-styles of Paper\'s root element.', - }, - { - name: 'zDepth', - type: 'oneOf [0,1,2,3,4,5]', - header: 'default: 1', - desc: 'This number represents the zDepth of the paper shadow.', - }, - { - name: 'transitionEnabled', - type: 'bool', - header: 'default: true', - desc: 'Set to false to disable CSS transitions for the paper element.', - }, - ], - }, - ]; - - let groupStyle = this.getStyles().group; - - return ( - - - - - { - `//Import statement: -import Paper from 'material-ui/lib/paper'; - -//See material-ui/lib/index.js for more - ` - } - - - - -
- - {this._getGroupDefault()} - - - {this._getGroupRounded()} - - - {this._getGroupCircle()} - -
-
-
- ); - }, - -}); - -export default PaperPage; diff --git a/docs/src/app/components/raw-code/paper-code.txt b/docs/src/app/components/raw-code/paper-code.txt deleted file mode 100644 index 649cbc52d44064..00000000000000 --- a/docs/src/app/components/raw-code/paper-code.txt +++ /dev/null @@ -1,48 +0,0 @@ -//Rounded Corners - -

zDepth=1

-
- -

zDepth=2

-
- -

zDepth=3

-
- -

zDepth=4

-
- -

zDepth=5

-
-//Sharp Corners - -

rounded=false

-
- -

rounded=false

-
- -

rounded=false

-
- -

rounded=false

-
- -

rounded=false

-
-//Circular - -

circle=true

-
- -

circle=true

-
- -

circle=true

-
- -

circle=true

-
- -

circle=true

-
diff --git a/src/paper.jsx b/src/paper.jsx index 94d57849d92ed7..86031024393790 100644 --- a/src/paper.jsx +++ b/src/paper.jsx @@ -9,15 +9,35 @@ import ThemeManager from './styles/theme-manager'; const Paper = React.createClass({ propTypes: { + /** + * Children passed into the paper element. + */ children: React.PropTypes.node, + + /** + * Set to true to generate a circlular paper container. + */ circle: React.PropTypes.bool, + + /** + * By default, the paper container will have a border radius. + * Set this to false to generate a container with sharp corners. + */ rounded: React.PropTypes.bool, /** * Override the inline-styles of the root element. */ style: React.PropTypes.object, + + /** + * Set to false to disable CSS transitions for the paper element. + */ transitionEnabled: React.PropTypes.bool, + + /** + * This number represents the zDepth of the paper shadow. + */ zDepth: PropTypes.zDepth, },