From e8e4d9abecb728fc0937f095107c32ebbd53f8a1 Mon Sep 17 00:00:00 2001 From: James McKenzie Date: Fri, 30 Apr 2021 16:37:41 +1200 Subject: [PATCH] Refactor 1 --- ReactLearning/kanban-board/package.json | 4 -- ReactLearning/kanban-board/src/App.css | 69 ++++++++++++++-------- ReactLearning/kanban-board/src/App.tsx | 6 +- .../kanban-board/src/components/Header.tsx | 46 ++++++++++----- .../kanban-board/src/components/KBColumn.tsx | 22 +++---- 5 files changed, 90 insertions(+), 57 deletions(-) diff --git a/ReactLearning/kanban-board/package.json b/ReactLearning/kanban-board/package.json index 2a0439e..8f8dbb5 100644 --- a/ReactLearning/kanban-board/package.json +++ b/ReactLearning/kanban-board/package.json @@ -3,9 +3,6 @@ "version": "0.1.0", "private": true, "dependencies": { - "@fortawesome/fontawesome-svg-core": "^1.2.35", - "@fortawesome/free-solid-svg-icons": "^5.15.3", - "@fortawesome/react-fontawesome": "^0.1.14", "@testing-library/jest-dom": "^5.12.0", "@testing-library/react": "^11.2.6", "@testing-library/user-event": "^12.8.3", @@ -13,7 +10,6 @@ "@types/node": "^12.20.10", "@types/react": "^17.0.3", "@types/react-dom": "^17.0.3", - "font-awesome": "^4.7.0", "react": "^17.0.2", "react-dom": "^17.0.2", "react-icons": "^4.2.0", diff --git a/ReactLearning/kanban-board/src/App.css b/ReactLearning/kanban-board/src/App.css index 22c8fdd..d87bd07 100644 --- a/ReactLearning/kanban-board/src/App.css +++ b/ReactLearning/kanban-board/src/App.css @@ -1,5 +1,7 @@ html { background-color: #383c4a; + + overflow: hidden; } .header { @@ -26,67 +28,85 @@ html { text-align: center; flex-direction: column; justify-content: flex-start; - float: left; - width: initial; - position: relative; - height: auto; - flex-grow: inherit; + max-width: 22vw; + min-width: 22vw; + + min-height: 25vh; border-color: #ddd; border-width: 2px; - min-width: 300px; - min-height: 200px; - max-width: 25%; border-style: solid; - color: "orange"; + color: #eee; margin: 5px; padding: 5px; flex-wrap: nowrap; + overflow-y: auto; + overflow-x: hidden; + padding-left: 1px; + margin-left: 1px; + margin-right: 1px; + padding-right: 1px; + max-height: 88vh; } - .taskWrapper { display: flex; - min-height: 100px; flex-direction: row; - align-items: stretch; - position: relative; + border-color: #ccc; + border-width: 2px; + border-style: solid; + margin: 2px; } .prioBlock { order: 1; - flex: 1; + flex: 3; display: flex; overflow: hidden; - - } .taskText { order: 5; - flex: 5; + flex: 20; height: 100%; + overflow: auto; } -.actionBlock{ +.actionBlock { order: 10; flex: 1; display: flex; - background-color: purple; - justify-content: flex-end; + background-color: #ddd; + justify-content: flex-start; + flex-direction: column; + align-items: flex-end; +} +.App { + display: flex; + align-items: stretch; + order: 1; + flex: 1; + flex-direction: column; + min-height: 100vh; + overflow: hidden; +} +.footer { + display: flex; + order: 400; + color: #eee; } .panel { display: flex; flex: 1; + order: 1; + justify-content: flex-start; flex-direction: row; flex-wrap: nowrap; width: 100%; - overflow-x:auto; + overflow-x: auto; overflow-y: hidden; - height: 100%; align-items: stretch; - background-color: lavender; + background-color: #404552; } - .modal { position: fixed; z-index: 20; @@ -140,4 +160,3 @@ html { .display-none { display: none; } - diff --git a/ReactLearning/kanban-board/src/App.tsx b/ReactLearning/kanban-board/src/App.tsx index 13596c1..c083075 100644 --- a/ReactLearning/kanban-board/src/App.tsx +++ b/ReactLearning/kanban-board/src/App.tsx @@ -120,7 +120,7 @@ class App extends React.Component<{}, State> { columns[fromColumnIndex + 1] = toColumn; this.setState({ columns: columns }); }; - /* Regresses the task to the column immediately to the left + /* Regresses the task to the column immediately to the left @param columnId: The column which the task is originally hosted at @param taskId: The UID for the task @return void @@ -218,6 +218,10 @@ class App extends React.Component<{}, State> { /> ))} +
+ Not to be taken seriously. Done as a practice React + TS + MobX + project +
); } diff --git a/ReactLearning/kanban-board/src/components/Header.tsx b/ReactLearning/kanban-board/src/components/Header.tsx index cb2ac13..18c0bd4 100644 --- a/ReactLearning/kanban-board/src/components/Header.tsx +++ b/ReactLearning/kanban-board/src/components/Header.tsx @@ -66,9 +66,7 @@ class Header extends React.Component { if (target === "titleInput") { this.setState({ taskTitle: event.target.value }); } - if (target === "descInput") { - this.setState({ taskDesc: event.target.value }); - } + if (target === "columnTitle") { this.setState({ columnTitle: event.target.value }); } @@ -76,6 +74,9 @@ class Header extends React.Component { this.setState({ columnColor: event.target.value }); } }; + handleTextAreaChange = (event: React.ChangeEvent) => { + this.setState({ taskDesc: event?.target.value }); + }; handleSelectChange = (event: React.ChangeEvent) => { if (event.target.id === "prioritySelect") { @@ -93,6 +94,7 @@ class Header extends React.Component { return (

{ > Kango Bango

- -

Add Task

-

{this.props.columns[0] && this.props.columns[0].id}

+ + +

Add Task 🤔

@@ -129,11 +138,10 @@ class Header extends React.Component { @@ -145,6 +153,7 @@ class Header extends React.Component { value={this.state.taskPrio} onChange={this.handleSelectChange} id="prioritySelect" + title="prioSelect" > @@ -172,8 +181,11 @@ class Header extends React.Component { Close
- - +

Lets add a column! 🤔

- - + +
); } diff --git a/ReactLearning/kanban-board/src/components/KBColumn.tsx b/ReactLearning/kanban-board/src/components/KBColumn.tsx index dfbf57b..2a8aba8 100644 --- a/ReactLearning/kanban-board/src/components/KBColumn.tsx +++ b/ReactLearning/kanban-board/src/components/KBColumn.tsx @@ -39,15 +39,7 @@ class KBColumn extends React.Component { } return ( -
+
{ } /> this.props.progressTask && this.props.progressTask(this.props.id, task.id) } /> this.props.regressTask && this.props.regressTask(this.props.id, task.id) @@ -88,7 +80,11 @@ class KBColumn extends React.Component { render() { return ( -
+

{this.props.title}

{this.getTaskRender()}
);