guziki
This commit is contained in:
parent
28b6869ad5
commit
8990ee2837
5
package-lock.json
generated
5
package-lock.json
generated
@ -3133,11 +3133,6 @@
|
|||||||
"resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
|
"resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz",
|
||||||
"integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24="
|
"integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24="
|
||||||
},
|
},
|
||||||
"bootstrap": {
|
|
||||||
"version": "4.5.0",
|
|
||||||
"resolved": "https://registry.npmjs.org/bootstrap/-/bootstrap-4.5.0.tgz",
|
|
||||||
"integrity": "sha512-Z93QoXvodoVslA+PWNdk23Hze4RBYIkpb5h8I2HY2Tu2h7A0LpAgLcyrhrSUyo2/Oxm2l1fRZPs1e5hnxnliXA=="
|
|
||||||
},
|
|
||||||
"brace-expansion": {
|
"brace-expansion": {
|
||||||
"version": "1.1.11",
|
"version": "1.1.11",
|
||||||
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
|
"resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz",
|
||||||
|
35
src/App.tsx
35
src/App.tsx
@ -1,15 +1,32 @@
|
|||||||
import React from "react";
|
import React, { useState } from "react";
|
||||||
import TopBar from "./components/TopBar/"
|
import TopBar from "./components/TopBar/";
|
||||||
import Transfer from "./components/Transfer/"
|
import Transfer from "./components/Transfer/";
|
||||||
import "./App.scss";
|
import "./App.scss";
|
||||||
|
|
||||||
function App() {
|
function App() {
|
||||||
return (
|
const [isOpen, setOpen] = useState(false);
|
||||||
<div className="App">
|
const [text, setText] = useState("");
|
||||||
<TopBar/>
|
|
||||||
<Transfer/>
|
return (
|
||||||
</div>
|
<div className="App">
|
||||||
);
|
<TopBar
|
||||||
|
textChangeHandler={(e) => {
|
||||||
|
setText(e.target.value);
|
||||||
|
}}
|
||||||
|
handleOpen={(e) => {
|
||||||
|
setOpen(!isOpen);
|
||||||
|
}}
|
||||||
|
isOpen={isOpen}
|
||||||
|
/>
|
||||||
|
<Transfer
|
||||||
|
isOpen={isOpen}
|
||||||
|
handleClose={(e) => {
|
||||||
|
setOpen(!isOpen);
|
||||||
|
}}
|
||||||
|
/>
|
||||||
|
<h1>{text}</h1>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
export default App;
|
export default App;
|
||||||
|
@ -13,36 +13,37 @@
|
|||||||
align-items: center;
|
align-items: center;
|
||||||
flex-grow: 0.5;
|
flex-grow: 0.5;
|
||||||
justify-content: flex-start;
|
justify-content: flex-start;
|
||||||
|
|
||||||
|
&-image {
|
||||||
|
width: 80px;
|
||||||
|
height: 80px;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
&__logo-image {
|
&__input {
|
||||||
width: 80px;
|
&-div {
|
||||||
height: 80px;
|
width: 70%;
|
||||||
}
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
flex-grow: 3;
|
||||||
|
}
|
||||||
|
|
||||||
&__input-div {
|
&-field {
|
||||||
width: 70%;
|
width: 96%;
|
||||||
display: flex;
|
}
|
||||||
align-items: center;
|
|
||||||
flex-grow: 3;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__input-field {
|
|
||||||
width: 96%;
|
|
||||||
}
|
|
||||||
|
|
||||||
&__icon-box {
|
|
||||||
display: flex;
|
|
||||||
align-items: center;
|
|
||||||
justify-content: space-around;
|
|
||||||
flex-grow: 1.5;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
&__icon {
|
&__icon {
|
||||||
width: 50px;
|
width: 50px;
|
||||||
|
cursor: pointer;
|
||||||
|
&-box {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
justify-content: space-around;
|
||||||
|
flex-grow: 1.5;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@media only screen and (max-width: 870px) {
|
@media only screen and (max-width: 870px) {
|
||||||
.top-bar__tekst {
|
.top-bar__tekst {
|
||||||
display: none;
|
display: none;
|
||||||
|
@ -1,10 +1,42 @@
|
|||||||
import React from "react";
|
import React, { ChangeEvent } from "react";
|
||||||
import "./index.scss";
|
import "./index.scss";
|
||||||
import Input from "@material-ui/core/Input";
|
import Input from "@material-ui/core/Input";
|
||||||
import SearchIcon from "@material-ui/icons/Search";
|
import SearchIcon from "@material-ui/icons/Search";
|
||||||
import CloseIcon from "@material-ui/icons/Close";
|
import CloseIcon from "@material-ui/icons/Close";
|
||||||
|
|
||||||
export default class TopBar extends React.Component {
|
interface TopBarProps {
|
||||||
|
handleOpen: (e: React.MouseEvent) => void;
|
||||||
|
textChangeHandler: (e: React.ChangeEvent<HTMLInputElement>) => void;
|
||||||
|
isOpen: boolean;
|
||||||
|
}
|
||||||
|
|
||||||
|
interface TopBarState {}
|
||||||
|
|
||||||
|
export default class TopBar extends React.Component<TopBarProps, TopBarState> {
|
||||||
|
constructor(props: TopBarProps) {
|
||||||
|
super(props);
|
||||||
|
|
||||||
|
this.handleOpen = this.handleOpen.bind(this);
|
||||||
|
this.state = {
|
||||||
|
isOpen: false,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
handleOpen(e: React.MouseEvent) {
|
||||||
|
this.props.handleOpen(e);
|
||||||
|
this.setState({
|
||||||
|
isOpen: true,
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
handleChange(e: React.ChangeEvent<HTMLInputElement>) {
|
||||||
|
this.props.textChangeHandler(e);
|
||||||
|
}
|
||||||
|
|
||||||
|
funkcja() {
|
||||||
|
alert("chuj");
|
||||||
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<div className="top-bar">
|
<div className="top-bar">
|
||||||
@ -17,29 +49,35 @@ export default class TopBar extends React.Component {
|
|||||||
<div className="top-bar__tekst"> plan na plan </div>
|
<div className="top-bar__tekst"> plan na plan </div>
|
||||||
</div>
|
</div>
|
||||||
<div className="top-bar__input-div">
|
<div className="top-bar__input-div">
|
||||||
<SearchIcon fontSize="large"></SearchIcon>
|
<SearchIcon fontSize="large"></SearchIcon>
|
||||||
<Input
|
<Input
|
||||||
placeholder="Wyszukaj..."
|
placeholder="Wyszukaj..."
|
||||||
inputProps={{ "aria-label": "description" }}
|
inputProps={{ "aria-label": "description" }}
|
||||||
className="top-bar__input-field"
|
className="top-bar__input-field"
|
||||||
/>
|
onChange={(e) =>
|
||||||
<CloseIcon fontSize="large"></CloseIcon>
|
this.handleChange(e as ChangeEvent<HTMLInputElement>)
|
||||||
|
}
|
||||||
|
/>
|
||||||
|
<CloseIcon fontSize="large"></CloseIcon>
|
||||||
</div>
|
</div>
|
||||||
<div className="top-bar__icon-box">
|
<div className="top-bar__icon-box">
|
||||||
<img
|
<img
|
||||||
className="top-bar__icon"
|
className="top-bar__icon"
|
||||||
alt="logo"
|
alt="transfer"
|
||||||
src="https://plannaplan.pl/img/transfer.png"
|
src="https://plannaplan.pl/img/transfer.png"
|
||||||
|
onClick={this.handleOpen}
|
||||||
/>
|
/>
|
||||||
<img
|
<img
|
||||||
className="top-bar__icon"
|
className="top-bar__icon"
|
||||||
alt="logo"
|
alt="change_language"
|
||||||
src="https://plannaplan.pl/img/UK.png"
|
src="https://plannaplan.pl/img/UK.png"
|
||||||
|
onClick={this.funkcja}
|
||||||
/>
|
/>
|
||||||
<img
|
<img
|
||||||
className="top-bar__icon"
|
className="top-bar__icon"
|
||||||
alt="logo"
|
alt="profile"
|
||||||
src="https://plannaplan.pl/img/user.png"
|
src="https://plannaplan.pl/img/user.png"
|
||||||
|
onClick={this.funkcja}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
@ -3,13 +3,12 @@ import Modal from "@material-ui/core/Modal";
|
|||||||
import "./index.scss";
|
import "./index.scss";
|
||||||
|
|
||||||
interface TransferProps {
|
interface TransferProps {
|
||||||
names?: string;
|
handleClose: (e: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void;
|
||||||
}
|
|
||||||
|
|
||||||
interface TransferState {
|
|
||||||
isOpen: boolean;
|
isOpen: boolean;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
interface TransferState {}
|
||||||
|
|
||||||
export default class Transfer extends React.Component<
|
export default class Transfer extends React.Component<
|
||||||
TransferProps,
|
TransferProps,
|
||||||
TransferState
|
TransferState
|
||||||
@ -17,20 +16,14 @@ export default class Transfer extends React.Component<
|
|||||||
constructor(props: TransferProps) {
|
constructor(props: TransferProps) {
|
||||||
super(props);
|
super(props);
|
||||||
|
|
||||||
this.handleOpen = this.handleOpen.bind(this);
|
|
||||||
this.handleClose = this.handleClose.bind(this);
|
this.handleClose = this.handleClose.bind(this);
|
||||||
this.state = {
|
this.state = {
|
||||||
isOpen: false,
|
isOpen: true,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
handleOpen(e: React.MouseEvent<HTMLButtonElement, MouseEvent>) {
|
|
||||||
this.setState({
|
|
||||||
isOpen: true,
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
handleClose(e: React.MouseEvent<HTMLButtonElement, MouseEvent>) {
|
handleClose(e: React.MouseEvent<HTMLButtonElement, MouseEvent>) {
|
||||||
|
this.props.handleClose(e);
|
||||||
this.setState({
|
this.setState({
|
||||||
isOpen: false,
|
isOpen: false,
|
||||||
});
|
});
|
||||||
@ -39,22 +32,18 @@ export default class Transfer extends React.Component<
|
|||||||
render() {
|
render() {
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<button type="button" onClick={this.handleOpen}>
|
|
||||||
Open Modal
|
|
||||||
</button>
|
|
||||||
<Modal
|
<Modal
|
||||||
className="wrapper"
|
className="wrapper"
|
||||||
open={this.state.isOpen}
|
open={this.props.isOpen}
|
||||||
onClose={this.handleClose}
|
onClose={this.handleClose}
|
||||||
aria-labelledby="simple-modal-title"
|
aria-labelledby="simple-modal-title"
|
||||||
aria-describedby="simple-modal-description"
|
aria-describedby="simple-modal-description"
|
||||||
>
|
>
|
||||||
<div className="transfer">
|
<div className="transfer">
|
||||||
<button type="button" onClick={this.handleClose}>
|
<button type="button" onClick={this.handleClose}>
|
||||||
Close Modal
|
Close Modal
|
||||||
</button>
|
</button>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</Modal>
|
</Modal>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
|
@ -1 +0,0 @@
|
|||||||
dupa
|
|
Loading…
x
Reference in New Issue
Block a user