aboutsummaryrefslogtreecommitdiff
path: root/src/lib/components/Window
diff options
context:
space:
mode:
authorEugene Sokolov <eug-vs@keemail.me>2020-02-03 13:30:27 +0000
committerGitHub <noreply@github.com>2020-02-03 13:30:27 +0000
commit989173ea6e39ac27893f3cc5efba043ebda9df67 (patch)
tree4281d872404091155d1ddeaa5727bc5fb51fdd8a /src/lib/components/Window
parent53143dfc36e66e285256706a8ec837e2bd2f8427 (diff)
parent5bcc9b41e59bf7215abf395ea899cdbc2d06db9a (diff)
downloadreact-benzin-989173ea6e39ac27893f3cc5efba043ebda9df67.tar.gz
Merge pull request #2 from eug-vs/typescript
Add Typescript support
Diffstat (limited to 'src/lib/components/Window')
-rw-r--r--src/lib/components/Window/Window.tsx (renamed from src/lib/components/Window/Window.js)18
-rw-r--r--src/lib/components/Window/WindowSurface.tsx (renamed from src/lib/components/Window/WindowSurface/WindowSurface.js)12
-rw-r--r--src/lib/components/Window/types.ts11
3 files changed, 33 insertions, 8 deletions
diff --git a/src/lib/components/Window/Window.js b/src/lib/components/Window/Window.tsx
index 027213f..ea8e264 100644
--- a/src/lib/components/Window/Window.js
+++ b/src/lib/components/Window/Window.tsx
@@ -2,10 +2,17 @@ import React from 'react';
import { Typography, Divider, makeStyles } from '@material-ui/core';
-import WindowSurface from './WindowSurface/WindowSurface';
+import WindowSurface from './WindowSurface';
+import { SurfaceSize, SurfacePosition } from './types';
-const useStyles = makeStyles(theme => ({
+interface PropTypes {
+ type: 'primary' | 'secondary' | 'mono';
+ name?: string;
+}
+
+
+const useStyles = makeStyles((theme: any) => ({
header: {
padding: theme.spacing(1, 0, 1, 2),
background: theme.palette.background.elevation2,
@@ -13,14 +20,14 @@ const useStyles = makeStyles(theme => ({
}));
-const Window = ({ type, name, children }) => {
+const Window: React.FC<PropTypes> = ({ type, name, children }) => {
const classes = useStyles();
- const size = {
+ const size: SurfaceSize = {
height: '85vh',
};
- const position = {
+ const position: SurfacePosition = {
bottom: '3vh',
};
@@ -51,5 +58,4 @@ const Window = ({ type, name, children }) => {
);
};
-
export default Window;
diff --git a/src/lib/components/Window/WindowSurface/WindowSurface.js b/src/lib/components/Window/WindowSurface.tsx
index 7859bf6..701a767 100644
--- a/src/lib/components/Window/WindowSurface/WindowSurface.js
+++ b/src/lib/components/Window/WindowSurface.tsx
@@ -2,8 +2,16 @@ import React from 'react';
import { Paper, makeStyles } from '@material-ui/core';
+import { SurfaceSize, SurfacePosition } from './types';
-const useStyles = makeStyles(theme => ({
+
+interface PropTypes {
+ size: SurfaceSize;
+ position: SurfacePosition;
+}
+
+
+const useStyles = makeStyles((theme: any) => ({
surface: {
position: 'absolute',
display: 'flex',
@@ -18,7 +26,7 @@ const useStyles = makeStyles(theme => ({
}));
-const WindowSurface = ({ size, position, children }) => {
+const WindowSurface: React.FC<PropTypes> = ({ size, position, children }) => {
const classes = useStyles();
return (
diff --git a/src/lib/components/Window/types.ts b/src/lib/components/Window/types.ts
new file mode 100644
index 0000000..9e18fe3
--- /dev/null
+++ b/src/lib/components/Window/types.ts
@@ -0,0 +1,11 @@
+export interface SurfaceSize {
+ height: string;
+ width?: string;
+}
+
+export interface SurfacePosition {
+ bottom: string;
+ left?: string;
+ right?: string;
+}
+