From 3cf70771cb45cc16ec33ffe44e7a1a4799d8f395 Mon Sep 17 00:00:00 2001 From: Jules Laplace Date: Tue, 23 Jun 2020 23:18:07 +0200 Subject: adding web app base --- animism-align/frontend/views/index.js | 4 + .../frontend/views/index/components/graph.form.js | 153 +++++++++++++++++++++ .../frontend/views/index/containers/graph.edit.js | 53 +++++++ .../frontend/views/index/containers/graph.index.js | 53 +++++++ .../frontend/views/index/containers/graph.new.js | 44 ++++++ .../frontend/views/index/index.container.js | 36 +++++ animism-align/frontend/views/index/index.css | 38 +++++ animism-align/frontend/views/site/site.actions.js | 3 + animism-align/frontend/views/site/site.reducer.js | 13 ++ .../views/upload/components/upload.form.js | 16 +++ .../views/upload/components/upload.index.js | 104 ++++++++++++++ .../views/upload/components/upload.indexOptions.js | 62 +++++++++ .../views/upload/components/upload.menu.js | 18 +++ .../views/upload/components/upload.show.js | 70 ++++++++++ .../frontend/views/upload/upload.actions.js | 17 +++ .../frontend/views/upload/upload.container.js | 37 +++++ animism-align/frontend/views/upload/upload.css | 10 ++ .../frontend/views/upload/upload.reducer.js | 21 +++ 18 files changed, 752 insertions(+) create mode 100644 animism-align/frontend/views/index.js create mode 100644 animism-align/frontend/views/index/components/graph.form.js create mode 100644 animism-align/frontend/views/index/containers/graph.edit.js create mode 100644 animism-align/frontend/views/index/containers/graph.index.js create mode 100644 animism-align/frontend/views/index/containers/graph.new.js create mode 100644 animism-align/frontend/views/index/index.container.js create mode 100644 animism-align/frontend/views/index/index.css create mode 100644 animism-align/frontend/views/site/site.actions.js create mode 100644 animism-align/frontend/views/site/site.reducer.js create mode 100644 animism-align/frontend/views/upload/components/upload.form.js create mode 100644 animism-align/frontend/views/upload/components/upload.index.js create mode 100644 animism-align/frontend/views/upload/components/upload.indexOptions.js create mode 100644 animism-align/frontend/views/upload/components/upload.menu.js create mode 100644 animism-align/frontend/views/upload/components/upload.show.js create mode 100644 animism-align/frontend/views/upload/upload.actions.js create mode 100644 animism-align/frontend/views/upload/upload.container.js create mode 100644 animism-align/frontend/views/upload/upload.css create mode 100644 animism-align/frontend/views/upload/upload.reducer.js (limited to 'animism-align/frontend/views') diff --git a/animism-align/frontend/views/index.js b/animism-align/frontend/views/index.js new file mode 100644 index 0000000..c50ab80 --- /dev/null +++ b/animism-align/frontend/views/index.js @@ -0,0 +1,4 @@ +export { default as index } from './index/index.container' +export { default as graph } from './graph/graph.container' +export { default as page } from './page/page.container' +export { default as upload } from './upload/upload.container' diff --git a/animism-align/frontend/views/index/components/graph.form.js b/animism-align/frontend/views/index/components/graph.form.js new file mode 100644 index 0000000..d90b663 --- /dev/null +++ b/animism-align/frontend/views/index/components/graph.form.js @@ -0,0 +1,153 @@ +import React, { Component } from 'react' +import { Link } from 'react-router-dom' + +import { session } from '../../../session' + +import { TextInput, LabelDescription, TextArea, Checkbox, SubmitButton, Loader } from '../../../common' + +const newGraph = () => ({ + path: '', + title: '', + username: session('username'), + description: '', +}) + +export default class GraphForm extends Component { + state = { + title: "", + submitTitle: "", + data: { ...newGraph() }, + errorFields: new Set([]), + } + + componentDidMount() { + const { data, isNew } = this.props + const title = isNew ? 'new project' : 'editing ' + data.title + const submitTitle = isNew ? "Create Graph" : "Save Changes" + this.setState({ + title, + submitTitle, + errorFields: new Set([]), + data: { + ...newGraph(), + ...data + }, + }) + } + + handleChange(e) { + const { errorFields } = this.state + const { name, value } = e.target + if (errorFields.has(name)) { + errorFields.delete(name) + } + let sanitizedValue = value + if (name === 'path') { + sanitizedValue = sanitizedValue.toLowerCase().replace(/ /, '-').replace(/[!@#$%^&*()[\]{}]/, '-').replace(/-+/, '-') + } + this.setState({ + errorFields, + data: { + ...this.state.data, + [name]: sanitizedValue, + } + }) + } + + handleSelect(name, value) { + const { errorFields } = this.state + if (errorFields.has(name)) { + errorFields.delete(name) + } + this.setState({ + errorFields, + data: { + ...this.state.data, + [name]: value, + } + }) + } + + handleSubmit(e) { + e.preventDefault() + const { isNew, onSubmit } = this.props + const { data } = this.state + const requiredKeys = "title username path description".split(" ") + const validKeys = "title username path description".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) { + // side effect: set username if we're creating a new graph + session.set('username', data.username) + } else { + validData.id = data.id + } + console.log('submit', validData) + onSubmit(validData) + } + } + + render() { + const { isNew } = this.props + const { title, submitTitle, errorFields, data } = this.state + return ( +
+

{title}

+
+ + + {data.path + ? 'Project URLs will be: /' + data.path + '/example' + : 'Enter the base path for this project.'} + + + +