Managed to get dynamic column creation

This commit is contained in:
James McKenzie 2021-04-28 14:26:23 +12:00
parent b2bd26a301
commit 48788e643d
5 changed files with 189 additions and 70 deletions

View File

@ -22,16 +22,48 @@ html {
/* For some reason, the CSS i need to use to get this to work isn't coming to me >:( */ /* For some reason, the CSS i need to use to get this to work isn't coming to me >:( */
.KBColumn { .KBColumn {
display: flex;
text-align: center; text-align: center;
display: block; flex-direction: column;
justify-content:flex-start;
float: left; float: left;
width: initial; width: initial;
height: auto;
flex-grow: inherit; flex-grow: inherit;
border-color: #ddd; border-color: #ddd;
border-width: 2px; border-width: 2px;
min-width: 200px;
min-height: 800px;
border-style: solid; border-style: solid;
color: "orange"; color: "orange";
margin: 5px;
padding: 5px;
} }
.taskWrapper{
display: flex;
}
.prioBlock{
order: 1;
flex: 1;
display: block;
height:100vh;
overflow: auto;
background-color: aqua;
width: inherit;
}
.taskText{
order: 5;
width: 80%;
height: 100%;
}
.panel { .panel {
width: 100%; width: 100%;
} }
.prioBlock:after
{
content: '.';
visibility: hidden;
}

View File

@ -4,6 +4,7 @@ import "./App.css";
import Header from "./components/Header"; import Header from "./components/Header";
import Column from "./types/Column"; import Column from "./types/Column";
import TaskPassback from "./types/TaskPassback"; import TaskPassback from "./types/TaskPassback";
import ColumnPassback from "./types/ColumnPassback"
type State = { type State = {
columns: Column[]; columns: Column[];
@ -19,21 +20,8 @@ class App extends React.Component<{}, State> {
this.addTask = this.addTask.bind(this); this.addTask = this.addTask.bind(this);
this.state = { this.state = {
taskIterator: 1, taskIterator: 1,
columnIterator: 3, columnIterator: 1,
columns: [ columns: [],
{
id: 1,
name: "Harry",
color: "green",
tasks: [],
},
{
id: 2,
name: "Potter",
color: "red",
tasks: [],
},
],
}; };
} }
@ -44,16 +32,21 @@ class App extends React.Component<{}, State> {
console.log(this.state.columns); console.log(this.state.columns);
} }
addColumn() { addColumn(columnInstance?: ColumnPassback) {
let columnId = this.state.columnIterator; let columnId = this.state.columnIterator;
this.setState({ columnIterator: columnId + 1 }); this.setState({ columnIterator: columnId + 1 });
if (columnInstance !== undefined){
this.state.columns.push({ this.state.columns.push({
id: columnId, id: columnId,
name: "tempName" + columnId, name: columnInstance?.title,
color: "#404552", color: columnInstance?.color,
tasks: [], tasks: [],
}); }
);
}
} }
addTask(taskInstance?: TaskPassback) { addTask(taskInstance?: TaskPassback) {

View File

@ -3,69 +3,98 @@ import Modal from "./Modal";
import Column from "../types/Column"; import Column from "../types/Column";
import TaskPassback from "../types/TaskPassback"; import TaskPassback from "../types/TaskPassback";
import Priority from "../types/Priority"; import Priority from "../types/Priority";
import ColumnPassback from "../types/ColumnPassback"
type HeaderProps = { type HeaderProps = {
addColumn: () => void; addColumn: (columnInstance?: ColumnPassback) => void;
addTask: (taskInstance?: TaskPassback) => void; addTask: (taskInstance?: TaskPassback) => void;
columns: Column[]; columns: Column[];
}; };
type State = { type State = {
show: boolean; showTask: boolean;
titleVar: string; taskTitle: string;
descVar: string; taskDesc: string;
prioVar: Priority; taskPrio: Priority;
columnNumber: number; taskColumnNumber: number;
showColumn: boolean;
columnTitle: string;
columnColor: string;
}; };
class Header extends React.Component<HeaderProps, State> { class Header extends React.Component<HeaderProps, State> {
constructor(props: HeaderProps) { constructor(props: HeaderProps) {
super(props); super(props);
this.showModal = this.showModal.bind(this); this.showTaskModal = this.showTaskModal.bind(this);
this.hideModal = this.hideModal.bind(this); this.hideModal = this.hideModal.bind(this);
this.handleInputChange = this.handleInputChange.bind(this); this.handleInputChange = this.handleInputChange.bind(this);
this.handleSelectChange = this.handleSelectChange.bind(this); this.handleSelectChange = this.handleSelectChange.bind(this);
this.showColumnModal = this.showColumnModal.bind(true);
this.hideColumnModal = this.hideColumnModal.bind(this);
this.state = { this.state = {
show: false, showTask: false,
titleVar: "", showColumn: false,
descVar: "", taskTitle: "",
prioVar: "normal", taskDesc: "",
columnNumber: props.columns[0].id, taskPrio: "normal",
taskColumnNumber: -1,
columnTitle: "",
columnColor: "#00CC00",
}; };
} }
showModal = () => { showTaskModal = () => {
let {show, columnNumber} = {...this.state} if (this.props.columns.length > 0){
show = true; let {showTask, taskColumnNumber} = {...this.state}
columnNumber = this.props.columns[0].id showTask = true;
this.setState({ show, columnNumber}); taskColumnNumber = this.props.columns[0].id
this.setState({ showTask, taskColumnNumber});
}
else{
alert("Add a column please!")
}
}; };
showColumnModal = () => {
let {showColumn} = {...this.state}
showColumn = true;
this.setState({showColumn})
}
hideModal = () => { hideModal = () => {
this.setState({ show: false }); this.setState({ showTask: false });
}; };
hideColumnModal = () => {
this.setState({showColumn: false})
}
handleInputChange(event: React.ChangeEvent<HTMLInputElement>) { handleInputChange(event: React.ChangeEvent<HTMLInputElement>) {
const target = event.target.id; const target = event.target.id;
if (target === "titleInput") { if (target === "titleInput") {
this.setState({ titleVar: event.target.value }); this.setState({ taskTitle: event.target.value });
} }
if (target === "descInput") { if (target === "descInput") {
this.setState({ descVar: event.target.value }); this.setState({ taskDesc: event.target.value });
}
if (target === "columnTitle"){
this.setState({columnTitle: event.target.value})
}
if (target === "columnColor"){
this.setState({columnColor: event.target.value})
} }
} }
handleSelectChange(event: React.ChangeEvent<HTMLSelectElement>) { handleSelectChange(event: React.ChangeEvent<HTMLSelectElement>) {
if (event.target.id === "prioritySelect") { if (event.target.id === "prioritySelect") {
const selectedValue = event.target.value as Priority; const selectedValue = event.target.value as Priority;
this.setState({ prioVar: selectedValue }); this.setState({ taskPrio: selectedValue });
} }
if (event.target.id === "columnSelect") { if (event.target.id === "columnSelect") {
const selectedValue = parseInt(event.target.value); const selectedValue = parseInt(event.target.value);
this.setState({ columnNumber: selectedValue }); this.setState({ taskColumnNumber: selectedValue });
} }
} }
@ -83,11 +112,11 @@ class Header extends React.Component<HeaderProps, State> {
> >
Kango Bango Kango Bango
</h1> </h1>
<Modal show={this.state.show} handleClose={this.hideModal}> <Modal show={this.state.showTask} handleClose={this.hideModal}>
<h3> Add Task</h3> <h3> Add Task</h3>
<p>{this.props.columns[0] && this.props.columns[0].id}</p> <p>{this.props.columns[0] && this.props.columns[0].id}</p>
<select <select
value={this.state.columnNumber} value={this.state.taskColumnNumber}
onChange={this.handleSelectChange} onChange={this.handleSelectChange}
id="columnSelect" id="columnSelect"
> >
@ -102,7 +131,7 @@ class Header extends React.Component<HeaderProps, State> {
<input <input
type="text" type="text"
id="titleInput" id="titleInput"
value={this.state.titleVar} value={this.state.taskTitle}
onChange={this.handleInputChange} onChange={this.handleInputChange}
/> />
</label> </label>
@ -113,7 +142,7 @@ class Header extends React.Component<HeaderProps, State> {
<input <input
type="textarea" type="textarea"
id="descInput" id="descInput"
value={this.state.descVar} value={this.state.taskDesc}
onChange={this.handleInputChange} onChange={this.handleInputChange}
/> />
</label> </label>
@ -123,7 +152,7 @@ class Header extends React.Component<HeaderProps, State> {
{" "} {" "}
Priority: Priority:
<select <select
value={this.state.prioVar} value={this.state.taskPrio}
onChange={this.handleSelectChange} onChange={this.handleSelectChange}
id="prioritySelect" id="prioritySelect"
> >
@ -135,12 +164,16 @@ class Header extends React.Component<HeaderProps, State> {
<br /> <br />
<button <button
onClick={() => onClick={() =>
this.props.addTask({ this.props.addTask({
title: this.state.titleVar, title: this.state.taskTitle,
description: this.state.descVar, description: this.state.taskDesc,
priority: this.state.prioVar, priority: this.state.taskPrio,
column: this.state.columnNumber, column: this.state.taskColumnNumber,
}) }
)
} }
> >
Add Task Add Task
@ -153,8 +186,58 @@ class Header extends React.Component<HeaderProps, State> {
Close Close
</button> </button>
</Modal> </Modal>
<button onClick={this.showModal}> Add task </button>
<button onClick={this.props.addColumn}> Add column </button>
<Modal show={this.state.showColumn} handleClose={this.hideModal}>
<p> NP Love is a danger - Priscilla </p>
<label>
{" "}
Title:
<input
type="text"
id="columnTitle"
value={this.state.columnTitle}
onChange={this.handleInputChange}
/>
</label>
<br />
<label>
{" "}
Title:
<input
type="text"
id="columnColor"
value={this.state.columnColor}
onChange={this.handleInputChange}
/>
</label>
<br />
<button onClick={() =>
this.props.addColumn({
title: this.state.columnTitle,
color: this.state.columnColor,
})
}
>NP Dancing - Vicky Vale</button>
<button
onClick={() => {
this.hideColumnModal();
}}
>
Close
</button>
</Modal>
<button onClick={this.showTaskModal}> Add task </button>
<button onClick={this.showColumnModal}> Add column </button>
</div> </div>
); );
} }

View File

@ -16,28 +16,33 @@ const defaultProps: KBColumnProps = {
let bgc = "#666"; let bgc = "#666";
const KBColumn = (props: KBColumnProps) => { const KBColumn = (props: KBColumnProps) => {
const { color, title, tasks, onDelete, id } = { ...defaultProps, ...props }; const { color, title, tasks, onDelete, id } = { ...defaultProps, ...props };
return (
<div className="KBColumn" style={{ backgroundColor: color, height: 200 }}>
<h3>{title}</h3>
{tasks.map((task) => (/*{
if (task.priority === 'urgent'){ let colTasks = tasks.map((task) => {
bgc = "red" if (task.priority === "urgent") {
bgc = "red";
} else if (task.priority === "important") { } else if (task.priority === "important") {
bgc = "yellow" bgc = "yellow";
} else if (task.priority === "normal") { } else if (task.priority === "normal") {
bgc = "blue" bgc = "blue";
} }
}
*/ return (
<div style={{borderColor: bgc, borderWidth: "5px"}}> <div style={{borderColor: "#ccc", borderWidth: "1px", borderStyle: "solid", margin: "10px"}} className="taskWrapper">
<div style={{width: "20px", height: "100%", backgroundColor: bgc, display: "inline"}} className="prioBlock"></div>
<div className="taskText">
<p> {task.title} </p> <p> {task.title} </p>
<p> {task.description} </p> <p> {task.description} </p>
</div> </div>
))} </div>
);
});
return (
<div className="KBColumn" style={{ backgroundColor: color }}>
<h3>{title}</h3>
{colTasks}
<button <button
onClick={() => { onClick={() => {
onDelete && onDelete(id); onDelete && onDelete(id);

View File

@ -0,0 +1,6 @@
type ColumnPassback = {
color: string,
title: string
}
export default ColumnPassback