52 lines
1.3 KiB
JavaScript
52 lines
1.3 KiB
JavaScript
import 'core-js/fn/promise'
|
||
import React from 'react'
|
||
import { SliderPicker } from 'react-color'
|
||
import { render } from 'react-dom'
|
||
import { connect, Provider } from 'react-redux'
|
||
import { createStore } from 'redux'
|
||
import reducers from './reducers/reducers'
|
||
import Layout from './containers/Layout'
|
||
|
||
let tracker = {
|
||
push: () => {},
|
||
connectToHistory: history => history
|
||
}
|
||
|
||
let store = createStore(reducers)
|
||
|
||
@connect(
|
||
state => ({ couleur: state.themeColours.colour }),
|
||
dispatch => ({
|
||
changeColour: colour => dispatch({ type: 'CHANGE_THEME_COLOUR', colour })
|
||
})
|
||
)
|
||
class MyComponent extends React.Component {
|
||
changeColour = ({ hex }) => this.props.changeColour(hex)
|
||
render() {
|
||
return (
|
||
<div>
|
||
<p className="indication">
|
||
Visualisez sur cette page l’apparence du module pour différentes
|
||
couleurs principales.
|
||
</p>
|
||
<SliderPicker
|
||
color={this.props.couleur}
|
||
onChangeComplete={this.changeColour}
|
||
/>
|
||
<p className="indication">
|
||
La couleur sélectionnée, à déclarer comme attribut
|
||
"data-couleur" du script sur votre page est :{' '}
|
||
<b>{this.props.couleur}</b>
|
||
</p>
|
||
<Layout tracker={tracker} />
|
||
</div>
|
||
)
|
||
}
|
||
}
|
||
render(
|
||
<Provider store={store}>
|
||
<MyComponent />
|
||
</Provider>,
|
||
document.querySelector('#coulorChooser')
|
||
)
|