diff options
author | Samy Pesse <samypesse@gmail.com> | 2016-10-13 13:23:19 +0200 |
---|---|---|
committer | Samy Pesse <samypesse@gmail.com> | 2016-10-13 13:23:19 +0200 |
commit | c42c5897fee1841d2be0207faeda81bc42f250e2 (patch) | |
tree | 45fd9a773ba05ae362390e63ce0f2eaaa0154ede | |
parent | 3aea3e5d88384822440517c9a2b722c405547155 (diff) | |
download | gitbook-c42c5897fee1841d2be0207faeda81bc42f250e2.zip gitbook-c42c5897fee1841d2be0207faeda81bc42f250e2.tar.gz gitbook-c42c5897fee1841d2be0207faeda81bc42f250e2.tar.bz2 |
Refactor code of plugin sharing
-rw-r--r-- | packages/gitbook-plugin-sharing/package.json | 2 | ||||
-rw-r--r-- | packages/gitbook-plugin-sharing/src/components/ShareButton.js | 44 | ||||
-rw-r--r-- | packages/gitbook-plugin-sharing/src/components/SharingButtons.js | 63 | ||||
-rw-r--r-- | packages/gitbook-plugin-sharing/src/components/SiteButton.js | 29 | ||||
-rw-r--r-- | packages/gitbook-plugin-sharing/src/index.js | 137 | ||||
-rw-r--r-- | packages/gitbook-plugin-sharing/src/shapes/options.js | 19 | ||||
-rw-r--r-- | packages/gitbook-plugin-sharing/src/shapes/site.js | 13 | ||||
-rw-r--r-- | packages/gitbook/package.json | 2 |
8 files changed, 172 insertions, 137 deletions
diff --git a/packages/gitbook-plugin-sharing/package.json b/packages/gitbook-plugin-sharing/package.json index b0540e8..40d5923 100644 --- a/packages/gitbook-plugin-sharing/package.json +++ b/packages/gitbook-plugin-sharing/package.json @@ -74,4 +74,4 @@ "url": "https://github.com/GitbookIO/gitbook/issues" }, "license": "Apache-2.0" -} +}
\ No newline at end of file diff --git a/packages/gitbook-plugin-sharing/src/components/ShareButton.js b/packages/gitbook-plugin-sharing/src/components/ShareButton.js new file mode 100644 index 0000000..5a6cd6e --- /dev/null +++ b/packages/gitbook-plugin-sharing/src/components/ShareButton.js @@ -0,0 +1,44 @@ +const GitBook = require('gitbook-core'); +const { React, Dropdown } = GitBook; + +const SITES = require('../SITES'); + +// Share button with dropdown list of sites +const ShareButton = React.createClass({ + propTypes: { + siteIds: React.PropTypes.arrayOf(React.PropTypes.string).isRequired, + onShare: React.PropTypes.func.isRequired + }, + + getInitialState() { + return { open: false }; + }, + + onToggle() { + this.setState({ open: !this.state.open }); + }, + + render() { + const { siteIds, onShare } = this.props; + + const items = siteIds.map((id) => ( + <Dropdown.Item onClick={() => onShare(SITES[id])} key={id}> + {SITES[id].label} + </Dropdown.Item> + )); + + return ( + <Dropdown.Container> + <GitBook.Button onClick={this.onToggle}> + <GitBook.Icon id="share-alt" /> + </GitBook.Button> + + <Dropdown.Menu open={this.state.open}> + {items} + </Dropdown.Menu> + </Dropdown.Container> + ); + } +}); + +module.exports = ShareButton; diff --git a/packages/gitbook-plugin-sharing/src/components/SharingButtons.js b/packages/gitbook-plugin-sharing/src/components/SharingButtons.js new file mode 100644 index 0000000..445458a --- /dev/null +++ b/packages/gitbook-plugin-sharing/src/components/SharingButtons.js @@ -0,0 +1,63 @@ +const GitBook = require('gitbook-core'); +const { React } = GitBook; + +const SITES = require('../SITES'); +const optionsShape = require('../shapes/options'); +const SiteButton = require('./SiteButton'); +const ShareButton = require('./ShareButton'); + +/** + * Displays the group of sharing buttons + */ +const SharingButtons = React.createClass({ + propTypes: { + options: optionsShape.isRequired, + page: GitBook.Shapes.Page.isRequired + }, + + onShare(site) { + site.onShare(location.href, this.props.page.title); + }, + + render() { + const { options } = this.props; + + // Highlighted sites + const mainButtons = SITES + .ALL + .filter(id => options[id]) + .map(id => <SiteButton key={id} onShare={this.onShare} site={SITES[id]} />); + + // Other sites + let shareButton = undefined; + if (options.all.length > 0) { + shareButton = ( + <ShareButton siteIds={options.all} + onShare={this.onShare} /> + ); + } + + return ( + <GitBook.ButtonGroup> + { mainButtons } + { shareButton } + </GitBook.ButtonGroup> + ); + } +}); + +function mapStateToProps(state) { + let options = state.config.getIn(['pluginsConfig', 'sharing']); + if (options) { + options = options.toJS(); + } else { + options = { all: [] }; + } + + return { + page: state.page, + options + }; +} + +module.exports = GitBook.connect(SharingButtons, mapStateToProps); diff --git a/packages/gitbook-plugin-sharing/src/components/SiteButton.js b/packages/gitbook-plugin-sharing/src/components/SiteButton.js new file mode 100644 index 0000000..e03720d --- /dev/null +++ b/packages/gitbook-plugin-sharing/src/components/SiteButton.js @@ -0,0 +1,29 @@ +const GitBook = require('gitbook-core'); +const { React } = GitBook; + +const siteShape = require('../shapes/site'); + +// An individual site sharing button +const SiteButton = React.createClass({ + propTypes: { + site: siteShape.isRequired, + onShare: React.PropTypes.func.isRequired + }, + + onClick(e) { + e.preventDefault(); + this.props.onShare(this.props.site); + }, + + render() { + const { site } = this.props; + + return ( + <GitBook.Button onClick={this.onClick}> + <GitBook.Icon id={site.icon}/> + </GitBook.Button> + ); + } +}); + +module.exports = SiteButton; diff --git a/packages/gitbook-plugin-sharing/src/index.js b/packages/gitbook-plugin-sharing/src/index.js index 357ccbb..174adfc 100644 --- a/packages/gitbook-plugin-sharing/src/index.js +++ b/packages/gitbook-plugin-sharing/src/index.js @@ -1,142 +1,9 @@ const GitBook = require('gitbook-core'); -const { - React, - Dropdown -} = GitBook; -const { string, arrayOf, shape, func } = React.PropTypes; - -const SITES = require('./SITES'); -const optionsShape = require('./optionsShape'); -const siteShape = shape({ - label: string.isRequired, - icon: string.isRequired, - onShare: func.isRequired -}); +const SharingButtons = require('./components/SharingButtons'); module.exports = GitBook.createPlugin({ activate: (dispatch, getState, { Components }) => { // Dispatch initialization actions - dispatch(Components.registerComponent(Sharing, { role: 'toolbar:buttons:right' })); - }, - deactivate: (dispatch, getState) => { - // Dispatch cleanup actions - }, - reduce: (state, action) => state -}); - -/** - * Displays the group of sharing buttons - */ -let Sharing = React.createClass({ - propTypes: { - options: optionsShape.isRequired, - page: GitBook.Shapes.Page.isRequired - }, - - onShare(site) { - site.onShare(location.href, this.props.page.title); - }, - - render() { - const { options } = this.props; - - // Highlighted sites - const mainButtons = SITES - .ALL - .filter(id => options[id]) - .map(id => <SiteButton key={id} onShare={this.onShare} site={SITES[id]} />); - - // Other sites - let shareButton = undefined; - if (options.all.length > 0) { - shareButton = ( - <ShareButton siteIds={options.all} - onShare={this.onShare} /> - ); - } - - return ( - <GitBook.ButtonGroup> - { mainButtons } - { shareButton } - </GitBook.ButtonGroup> - ); - } -}); - -function mapStateToProps(state) { - let options = state.config.getIn(['pluginsConfig', 'sharing']); - if (options) { - options = options.toJS(); - } else { - options = { all: [] }; - } - - return { - page: state.page, - options - }; -} - -Sharing = GitBook.connect(Sharing, mapStateToProps); - -// An individual site sharing button -const SiteButton = React.createClass({ - propTypes: { - site: siteShape.isRequired, - onShare: func.isRequired - }, - - onClick(e) { - e.preventDefault(); - this.props.onShare(this.props.site); - }, - - render() { - const { site } = this.props; - - return ( - <GitBook.Button onClick={this.onClick}> - <GitBook.Icon id={site.icon}/> - </GitBook.Button> - ); - } -}); - -// Share button with dropdown list of sites -const ShareButton = React.createClass({ - propTypes: { - siteIds: arrayOf(string).isRequired, - onShare: func.isRequired - }, - - getInitialState() { - return { open: false }; - }, - - onToggle() { - this.setState({ open: !this.state.open }); - }, - - render() { - const { siteIds, onShare } = this.props; - - const items = siteIds.map((id) => ( - <Dropdown.Item onClick={() => onShare(SITES[id])} key={id}> - {SITES[id].label} - </Dropdown.Item> - )); - - return ( - <Dropdown.Container> - <GitBook.Button onClick={this.onToggle}> - <GitBook.Icon id="share-alt" /> - </GitBook.Button> - - <Dropdown.Menu open={this.state.open}> - {items} - </Dropdown.Menu> - </Dropdown.Container> - ); + dispatch(Components.registerComponent(SharingButtons, { role: 'toolbar:buttons:right' })); } }); diff --git a/packages/gitbook-plugin-sharing/src/shapes/options.js b/packages/gitbook-plugin-sharing/src/shapes/options.js new file mode 100644 index 0000000..885feb6 --- /dev/null +++ b/packages/gitbook-plugin-sharing/src/shapes/options.js @@ -0,0 +1,19 @@ +const { + bool, + arrayOf, + oneOf, + shape +} = require('gitbook-core').React.PropTypes; +const { ALL } = require('../SITES'); + +const optionsShape = shape({ + facebook: bool, + twitter: bool, + google: bool, + weibo: bool, + instapaper: bool, + vk: bool, + all: arrayOf(oneOf(ALL)).isRequired +}); + +module.exports = optionsShape; diff --git a/packages/gitbook-plugin-sharing/src/shapes/site.js b/packages/gitbook-plugin-sharing/src/shapes/site.js new file mode 100644 index 0000000..2227429 --- /dev/null +++ b/packages/gitbook-plugin-sharing/src/shapes/site.js @@ -0,0 +1,13 @@ +const { + string, + func, + shape +} = require('gitbook-core').React.PropTypes; + +const siteShape = shape({ + label: string.isRequired, + icon: string.isRequired, + onShare: func.isRequired +}); + +module.exports = siteShape; diff --git a/packages/gitbook/package.json b/packages/gitbook/package.json index 7d0a382..d0bc07b 100644 --- a/packages/gitbook/package.json +++ b/packages/gitbook/package.json @@ -107,4 +107,4 @@ "babel-register": "^6.14.0", "mocha": "^3.0.2" } -} +}
\ No newline at end of file |