Managed to get dynamic column creation
This commit is contained in:
parent
b2bd26a301
commit
48788e643d
@ -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;
|
||||||
|
}
|
@ -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) {
|
||||||
|
@ -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>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -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);
|
||||||
|
6
ReactLearning/kanban-board/src/types/ColumnPassback.ts
Normal file
6
ReactLearning/kanban-board/src/types/ColumnPassback.ts
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
type ColumnPassback = {
|
||||||
|
color: string,
|
||||||
|
title: string
|
||||||
|
}
|
||||||
|
|
||||||
|
export default ColumnPassback
|
Loading…
Reference in New Issue
Block a user