mon-entreprise/source/entry-colour-chooser.js

55 lines
1.3 KiB
JavaScript

import 'core-js/fn/promise'
import React from 'react'
import { render } from 'react-dom'
import { connect, Provider } from 'react-redux'
import { createStore } from 'redux'
import reducers from './reducers/reducers'
import { changeThemeColour } from './actions'
import Layout from './containers/Layout'
import { SliderPicker } from 'react-color'
import { rules, rulesFr } from 'Engine/rules'
import lang from './i18n'
let tracker = {
push: () => {},
connectToHistory: () => {}
}
let store = createStore(reducers(tracker, rulesFr))
@connect(
state => ({ couleur: state.themeColours.colour }),
dispatch => ({
changeColour: colour => dispatch(changeThemeColour(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 />
</div>
)
}
}
render(
<Provider store={store}>
<MyComponent />
</Provider>,
document.querySelector('#coulorChooser')
)