summaryrefslogtreecommitdiff
path: root/animism-align/frontend/app/views/venue/components
diff options
context:
space:
mode:
Diffstat (limited to 'animism-align/frontend/app/views/venue/components')
-rw-r--r--animism-align/frontend/app/views/venue/components/venue.form.js209
-rw-r--r--animism-align/frontend/app/views/venue/components/venue.menu.js57
2 files changed, 266 insertions, 0 deletions
diff --git a/animism-align/frontend/app/views/venue/components/venue.form.js b/animism-align/frontend/app/views/venue/components/venue.form.js
new file mode 100644
index 0000000..decd465
--- /dev/null
+++ b/animism-align/frontend/app/views/venue/components/venue.form.js
@@ -0,0 +1,209 @@
+import React, { Component } from 'react'
+import { Link } from 'react-router-dom'
+
+import { capitalize } from 'app/utils'
+
+import { TextInput, NumberInput, LabelDescription, Select, TextArea, Checkbox, SubmitButton, Loader } from 'app/common'
+
+const newVenue = () => ({
+ title: '',
+ date: '',
+ settings: {
+ about: {
+ curator: "",
+ author: "",
+ artists: "",
+ credits: "",
+ },
+ },
+})
+
+export default class VenueForm extends Component {
+ state = {
+ title: "",
+ submitTitle: "",
+ data: { ...newVenue() },
+ errorFields: new Set([]),
+ }
+
+ constructor(props) {
+ super(props)
+ this.handleKeyDown = this.handleKeyDown.bind(this)
+ this.handleSelect = this.handleSelect.bind(this)
+ this.handleChange = this.handleChange.bind(this)
+ this.handleSettingsChange = this.handleSettingsChange.bind(this)
+ this.handleSettingsChangeEvent = this.handleSettingsChangeEvent.bind(this)
+ this.handleSubmit = this.handleSubmit.bind(this)
+ }
+
+ componentDidMount() {
+ const { data, isNew } = this.props
+ const title = isNew ? 'New venue' : 'Editing ' + data.title
+ const submitTitle = isNew ? "Add Venue" : "Save Changes"
+ this.setState({
+ title,
+ submitTitle,
+ errorFields: new Set([]),
+ data: {
+ ...newVenue(),
+ ...data
+ },
+ })
+ window.addEventListener('keydown', this.handleKeyDown)
+ }
+
+ componentWillUnmount() {
+ window.removeEventListener('keydown', this.handleKeyDown)
+ }
+
+ handleKeyDown(e) {
+ // console.log(e, e.keyCode)
+ if ((e.ctrlKey || e.metaKey) && e.keyCode === 83) {
+ if (e) {
+ e.preventDefault()
+ }
+ this.handleSubmit()
+ }
+ }
+
+ handleChange(e) {
+ const { name, value } = e.target
+ this.handleSelect(name, value)
+ }
+
+ handleSelect(name, value) {
+ const { errorFields } = this.state
+ if (errorFields.has(name)) {
+ errorFields.delete(name)
+ }
+ this.setState({
+ errorFields,
+ data: {
+ ...this.state.data,
+ [name]: value,
+ }
+ })
+ }
+
+ handleSettingsChangeEvent(e) {
+ const { name, value } = e.target
+ this.handleSettingsChange(name, value)
+ }
+
+ handleSettingsChange(name, value) {
+ console.log(name, value)
+ if (name !== 'multiple') {
+ value = { [name]: value }
+ }
+ this.setState({
+ data: {
+ ...this.state.data,
+ settings: {
+ ...this.state.data.settings,
+ ...value,
+ }
+ }
+ })
+ }
+
+ handleSubmit(e) {
+ if (e) {
+ e.preventDefault()
+ }
+ const { isNew, onSubmit } = this.props
+ const { data } = this.state
+ const requiredKeys = "title date".split(" ")
+ const validKeys = "title date settings".split(" ")
+ const validData = validKeys.reduce((a,b) => { a[b] = data[b]; return a }, {})
+ const errorFields = requiredKeys.filter(key => !validData[key])
+ if (errorFields.length) {
+ console.log('error', errorFields, validData)
+ this.setState({ errorFields: new Set(errorFields) })
+ } else {
+ if (isNew) {
+ //
+ } else {
+ validData.id = data.id
+ }
+ console.log('submit', validData)
+ onSubmit(validData)
+ }
+ }
+
+ render() {
+ const { isNew } = this.props
+ const { title, submitTitle, errorFields, data } = this.state
+ // console.log(data)
+ return (
+ <div className='form'>
+ <h1>{title}</h1>
+ <form onSubmit={this.handleSubmit}>
+ <SubmitButton
+ title={submitTitle}
+ onClick={this.handleSubmit}
+ />
+ <TextInput
+ title="Title"
+ name="title"
+ required
+ data={data}
+ onChange={this.handleChange}
+ autoComplete="off"
+ />
+ <TextInput
+ title="Date"
+ name="date"
+ required
+ data={data}
+ onChange={this.handleChange}
+ autoComplete="off"
+ />
+
+ <TextArea
+ title="Curator"
+ name="curator"
+ data={data.settings.about}
+ onChange={this.handleSettingsChangeEvent}
+ autoComplete="off"
+ />
+
+ <TextArea
+ title="Author"
+ name="author"
+ data={data.settings.about}
+ onChange={this.handleSettingsChangeEvent}
+ autoComplete="off"
+ />
+
+ <TextArea
+ title="Artists"
+ name="artists"
+ data={data.settings.about}
+ onChange={this.handleSettingsChangeEvent}
+ autoComplete="off"
+ />
+
+ <TextArea
+ title="Credits"
+ name="credits"
+ className="credits"
+ data={data.settings.about}
+ onChange={this.handleSettingsChangeEvent}
+ autoComplete="off"
+ />
+
+ <SubmitButton
+ title={submitTitle}
+ onClick={this.handleSubmit}
+ />
+ {!!errorFields.size &&
+ <label>
+ <span></span>
+ <span>Please complete the required fields</span>
+ </label>
+ }
+ </form>
+ </div>
+ )
+ }
+}
diff --git a/animism-align/frontend/app/views/venue/components/venue.menu.js b/animism-align/frontend/app/views/venue/components/venue.menu.js
new file mode 100644
index 0000000..1e1a7cd
--- /dev/null
+++ b/animism-align/frontend/app/views/venue/components/venue.menu.js
@@ -0,0 +1,57 @@
+import React, { Component } from 'react'
+import { Route } from 'react-router-dom'
+import { connect } from 'react-redux'
+
+import { history } from 'app/store'
+import actions from 'app/actions'
+import { MenuButton } from 'app/common'
+
+const mapStateToProps = state => ({
+ venue: state.venue,
+})
+
+export default class VenueMenu extends Component {
+ render() {
+ return (
+ <div className='menuButtons'>
+ <Route exact path='/venue/:id/show/' component={VenueShowMenu} />
+ <Route exact path='/venue/:id/edit/' component={VenueEditMenu} />
+ <Route exact path='/venue/new/' component={VenueNewMenu} />
+ <Route exact path='/venue/' component={VenueIndexMenu} />
+ </div>
+ )
+ }
+}
+
+const VenueIndexMenu = () => ([
+ <MenuButton key='new' name="new" href="/venue/new/" />,
+])
+
+const VenueShowMenu = connect(mapStateToProps)((props) => ([
+ <MenuButton key='back' name="back" href="/venue/" />,
+ <MenuButton key='edit' name="edit" href={"/venue/" + props.match.params.id + "/edit/"} />,
+ <MenuButton key='delete' name="delete" onClick={() => {
+ const { res: venue } = props.venue.show
+ if (confirm("Really delete this venue?")) {
+ actions.venue.destroy(venue).then(() => {
+ history.push('/venue/')
+ })
+ }
+ }} />,
+]))
+
+const VenueNewMenu = (props) => ([
+ <MenuButton key='back' name="back" href="/venue/" />,
+])
+
+const VenueEditMenu = connect(mapStateToProps)((props) => ([
+ <MenuButton key='back' name="back" href="/venue/" />,
+ <MenuButton key='delete' name="delete" onClick={() => {
+ const { res: venue } = props.venue.show
+ if (confirm("Really delete this venue?")) {
+ actions.venue.destroy(venue).then(() => {
+ history.push('/venue/')
+ })
+ }
+ }} />,
+]))