diff --git a/.gitignore b/.gitignore index 4d29575..098e05f 100644 --- a/.gitignore +++ b/.gitignore @@ -4,7 +4,7 @@ /node_modules /.pnp .pnp.js - +/.history # testing /coverage diff --git a/.history/package_20200224135508.json b/.history/package_20200224135508.json new file mode 100644 index 0000000..3dae2b2 --- /dev/null +++ b/.history/package_20200224135508.json @@ -0,0 +1,35 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.0", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224140959.json b/.history/package_20200224140959.json new file mode 100644 index 0000000..4e19ca1 --- /dev/null +++ b/.history/package_20200224140959.json @@ -0,0 +1,34 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224141751.json b/.history/package_20200224141751.json new file mode 100644 index 0000000..3d8bcdc --- /dev/null +++ b/.history/package_20200224141751.json @@ -0,0 +1,35 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.2", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224143051.json b/.history/package_20200224143051.json new file mode 100644 index 0000000..6be8fd6 --- /dev/null +++ b/.history/package_20200224143051.json @@ -0,0 +1,35 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.3", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224143753.json b/.history/package_20200224143753.json new file mode 100644 index 0000000..e414361 --- /dev/null +++ b/.history/package_20200224143753.json @@ -0,0 +1,35 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.4", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224144921.json b/.history/package_20200224144921.json new file mode 100644 index 0000000..1bb054e --- /dev/null +++ b/.history/package_20200224144921.json @@ -0,0 +1,36 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "fabric": "^4.0.0-beta.7", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.5", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224154546.json b/.history/package_20200224154546.json new file mode 100644 index 0000000..0a7fba1 --- /dev/null +++ b/.history/package_20200224154546.json @@ -0,0 +1,37 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@fortawesome/fontawesome-free": "^5.12.1", + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "fabric": "^4.0.0-beta.7", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.7", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224161116.json b/.history/package_20200224161116.json new file mode 100644 index 0000000..a977be3 --- /dev/null +++ b/.history/package_20200224161116.json @@ -0,0 +1,37 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@fortawesome/fontawesome-free": "^5.12.1", + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "fabric": "^4.0.0-beta.7", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.8", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200224162029.json b/.history/package_20200224162029.json new file mode 100644 index 0000000..02a313b --- /dev/null +++ b/.history/package_20200224162029.json @@ -0,0 +1,37 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@fortawesome/fontawesome-free": "^5.12.1", + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "fabric": "^4.0.0-beta.7", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.9", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/package_20200225132606.json b/.history/package_20200225132606.json new file mode 100644 index 0000000..4099ca4 --- /dev/null +++ b/.history/package_20200225132606.json @@ -0,0 +1,37 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "private": true, + "dependencies": { + "@fortawesome/fontawesome-free": "^5.12.1", + "@testing-library/jest-dom": "^4.2.4", + "@testing-library/react": "^9.3.2", + "@testing-library/user-event": "^7.1.2", + "fabric": "^4.0.0-beta.7", + "react": "^16.12.0", + "react-dom": "^16.12.0", + "react-image-markup": "^1.0.11", + "react-scripts": "3.4.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "eslintConfig": { + "extends": "react-app" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + } +} diff --git a/.history/src/App_20200220160215.css b/.history/src/App_20200220160215.css new file mode 100644 index 0000000..74b5e05 --- /dev/null +++ b/.history/src/App_20200220160215.css @@ -0,0 +1,38 @@ +.App { + text-align: center; +} + +.App-logo { + height: 40vmin; + pointer-events: none; +} + +@media (prefers-reduced-motion: no-preference) { + .App-logo { + animation: App-logo-spin infinite 20s linear; + } +} + +.App-header { + background-color: #282c34; + min-height: 100vh; + display: flex; + flex-direction: column; + align-items: center; + justify-content: center; + font-size: calc(10px + 2vmin); + color: white; +} + +.App-link { + color: #61dafb; +} + +@keyframes App-logo-spin { + from { + transform: rotate(0deg); + } + to { + transform: rotate(360deg); + } +} diff --git a/.history/src/App_20200220160215.js b/.history/src/App_20200220160215.js new file mode 100644 index 0000000..ce9cbd2 --- /dev/null +++ b/.history/src/App_20200220160215.js @@ -0,0 +1,26 @@ +import React from 'react'; +import logo from './logo.svg'; +import './App.css'; + +function App() { + return ( +
+
+ logo +

+ Edit src/App.js and save to reload. +

+ + Learn React + +
+
+ ); +} + +export default App; diff --git a/.history/src/App_20200224135621.js b/.history/src/App_20200224135621.js new file mode 100644 index 0000000..cd07f21 --- /dev/null +++ b/.history/src/App_20200224135621.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import Editor from './components/Editor/Editor'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135625.js b/.history/src/App_20200224135625.js new file mode 100644 index 0000000..0aa6f62 --- /dev/null +++ b/.history/src/App_20200224135625.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker' +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135627.js b/.history/src/App_20200224135627.js new file mode 100644 index 0000000..bd71d0c --- /dev/null +++ b/.history/src/App_20200224135627.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; + +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135628.js b/.history/src/App_20200224135628.js new file mode 100644 index 0000000..56c7168 --- /dev/null +++ b/.history/src/App_20200224135628.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135632.js b/.history/src/App_20200224135632.js new file mode 100644 index 0000000..d3a5ec7 --- /dev/null +++ b/.history/src/App_20200224135632.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +impo +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135642.js b/.history/src/App_20200224135642.js new file mode 100644 index 0000000..5defc55 --- /dev/null +++ b/.history/src/App_20200224135642.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'tra' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135645.js b/.history/src/App_20200224135645.js new file mode 100644 index 0000000..69befbe --- /dev/null +++ b/.history/src/App_20200224135645.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135647.js b/.history/src/App_20200224135647.js new file mode 100644 index 0000000..9b5a12b --- /dev/null +++ b/.history/src/App_20200224135647.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135939.js b/.history/src/App_20200224135939.js new file mode 100644 index 0000000..18e2e04 --- /dev/null +++ b/.history/src/App_20200224135939.js @@ -0,0 +1,61 @@ +import React from 'react'; + +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135941.js b/.history/src/App_20200224135941.js new file mode 100644 index 0000000..9b5a12b --- /dev/null +++ b/.history/src/App_20200224135941.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135944.js b/.history/src/App_20200224135944.js new file mode 100644 index 0000000..69f6a7d --- /dev/null +++ b/.history/src/App_20200224135944.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224135959.css b/.history/src/App_20200224135959.css new file mode 100644 index 0000000..d60639b --- /dev/null +++ b/.history/src/App_20200224135959.css @@ -0,0 +1,35 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224144006.js b/.history/src/App_20200224144006.js new file mode 100644 index 0000000..6f7cd8e --- /dev/null +++ b/.history/src/App_20200224144006.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144346.js b/.history/src/App_20200224144346.js new file mode 100644 index 0000000..3793ccf --- /dev/null +++ b/.history/src/App_20200224144346.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144353.js b/.history/src/App_20200224144353.js new file mode 100644 index 0000000..69f6a7d --- /dev/null +++ b/.history/src/App_20200224144353.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144354.js b/.history/src/App_20200224144354.js new file mode 100644 index 0000000..9295e31 --- /dev/null +++ b/.history/src/App_20200224144354.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144357.js b/.history/src/App_20200224144357.js new file mode 100644 index 0000000..054cf7e --- /dev/null +++ b/.history/src/App_20200224144357.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144401.js b/.history/src/App_20200224144401.js new file mode 100644 index 0000000..547ebcc --- /dev/null +++ b/.history/src/App_20200224144401.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +// import '@fortawesome/fontawesome-free/css/all.css' +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144927.js b/.history/src/App_20200224144927.js new file mode 100644 index 0000000..2363522 --- /dev/null +++ b/.history/src/App_20200224144927.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144935.js b/.history/src/App_20200224144935.js new file mode 100644 index 0000000..49e88e3 --- /dev/null +++ b/.history/src/App_20200224144935.js @@ -0,0 +1,49 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+ +
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144937.js b/.history/src/App_20200224144937.js new file mode 100644 index 0000000..ab6fffa --- /dev/null +++ b/.history/src/App_20200224144937.js @@ -0,0 +1,49 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+ ) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144939.js b/.history/src/App_20200224144939.js new file mode 100644 index 0000000..29d6a7f --- /dev/null +++ b/.history/src/App_20200224144939.js @@ -0,0 +1,49 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+ +
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144942.js b/.history/src/App_20200224144942.js new file mode 100644 index 0000000..bfb2a5a --- /dev/null +++ b/.history/src/App_20200224144942.js @@ -0,0 +1,34 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+ +
+ +
+
+ ) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144944.js b/.history/src/App_20200224144944.js new file mode 100644 index 0000000..890a5fb --- /dev/null +++ b/.history/src/App_20200224144944.js @@ -0,0 +1,33 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+ +
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144948.js b/.history/src/App_20200224144948.js new file mode 100644 index 0000000..1a075b9 --- /dev/null +++ b/.history/src/App_20200224144948.js @@ -0,0 +1,32 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224144954.js b/.history/src/App_20200224144954.js new file mode 100644 index 0000000..9cd984d --- /dev/null +++ b/.history/src/App_20200224144954.js @@ -0,0 +1,31 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + return ( +
+
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153259.js b/.history/src/App_20200224153259.js new file mode 100644 index 0000000..8611a5c --- /dev/null +++ b/.history/src/App_20200224153259.js @@ -0,0 +1,31 @@ +import React from 'react'; +import './App.css'; +import { Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + return ( +
+
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153300.js b/.history/src/App_20200224153300.js new file mode 100644 index 0000000..ccf7d5b --- /dev/null +++ b/.history/src/App_20200224153300.js @@ -0,0 +1,31 @@ +import React from 'react'; +import './App.css'; +import { Editor } from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + return ( +
+
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153304.js b/.history/src/App_20200224153304.js new file mode 100644 index 0000000..9cd984d --- /dev/null +++ b/.history/src/App_20200224153304.js @@ -0,0 +1,31 @@ +import React from 'react'; +import './App.css'; +import Editor from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + return ( +
+
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153317.js b/.history/src/App_20200224153317.js new file mode 100644 index 0000000..ccf7d5b --- /dev/null +++ b/.history/src/App_20200224153317.js @@ -0,0 +1,31 @@ +import React from 'react'; +import './App.css'; +import { Editor } from 'react-image-markup'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + return ( +
+
+ +
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153502.js b/.history/src/App_20200224153502.js new file mode 100644 index 0000000..cd07f21 --- /dev/null +++ b/.history/src/App_20200224153502.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import Editor from './components/Editor/Editor'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153508.js b/.history/src/App_20200224153508.js new file mode 100644 index 0000000..e0015b6 --- /dev/null +++ b/.history/src/App_20200224153508.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import {} Editor from './components/Editor/Editor'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153511.js b/.history/src/App_20200224153511.js new file mode 100644 index 0000000..6bcbcfd --- /dev/null +++ b/.history/src/App_20200224153511.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from './components/Editor/Editor'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153514.js b/.history/src/App_20200224153514.js new file mode 100644 index 0000000..1dea767 --- /dev/null +++ b/.history/src/App_20200224153514.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './assets/css/App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153524.js b/.history/src/App_20200224153524.js new file mode 100644 index 0000000..12af0a9 --- /dev/null +++ b/.history/src/App_20200224153524.js @@ -0,0 +1,63 @@ +import React from 'react'; +import '.App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153525.js b/.history/src/App_20200224153525.js new file mode 100644 index 0000000..10f2eb7 --- /dev/null +++ b/.history/src/App_20200224153525.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153550.js b/.history/src/App_20200224153550.js new file mode 100644 index 0000000..a2c2764 --- /dev/null +++ b/.history/src/App_20200224153550.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153607.js b/.history/src/App_20200224153607.js new file mode 100644 index 0000000..d860b27 --- /dev/null +++ b/.history/src/App_20200224153607.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153615.js b/.history/src/App_20200224153615.js new file mode 100644 index 0000000..c1828e3 --- /dev/null +++ b/.history/src/App_20200224153615.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153627.js b/.history/src/App_20200224153627.js new file mode 100644 index 0000000..d860b27 --- /dev/null +++ b/.history/src/App_20200224153627.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +// import ColorPicker from './components/ColorPicker/ColorPicker'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153629.js b/.history/src/App_20200224153629.js new file mode 100644 index 0000000..3842f6b --- /dev/null +++ b/.history/src/App_20200224153629.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153659.js b/.history/src/App_20200224153659.js new file mode 100644 index 0000000..f1e07d4 --- /dev/null +++ b/.history/src/App_20200224153659.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153746.js b/.history/src/App_20200224153746.js new file mode 100644 index 0000000..225e761 --- /dev/null +++ b/.history/src/App_20200224153746.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +@import "../path/to/node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153749.js b/.history/src/App_20200224153749.js new file mode 100644 index 0000000..e948838 --- /dev/null +++ b/.history/src/App_20200224153749.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +@import "../to/node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153751.js b/.history/src/App_20200224153751.js new file mode 100644 index 0000000..d523ec0 --- /dev/null +++ b/.history/src/App_20200224153751.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +@import "..//node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153752.js b/.history/src/App_20200224153752.js new file mode 100644 index 0000000..4e31d63 --- /dev/null +++ b/.history/src/App_20200224153752.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +@import "../node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153756.js b/.history/src/App_20200224153756.js new file mode 100644 index 0000000..39282ad --- /dev/null +++ b/.history/src/App_20200224153756.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import "../node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153758.js b/.history/src/App_20200224153758.js new file mode 100644 index 0000000..cea3827 --- /dev/null +++ b/.history/src/App_20200224153758.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import "../node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224153834.js b/.history/src/App_20200224153834.js new file mode 100644 index 0000000..356dbb8 --- /dev/null +++ b/.history/src/App_20200224153834.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +i +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154034.js b/.history/src/App_20200224154034.js new file mode 100644 index 0000000..39282ad --- /dev/null +++ b/.history/src/App_20200224154034.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import "../node_modules/@fortawesome/fontawesome-free/css/fontawesome.css"; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154038.js b/.history/src/App_20200224154038.js new file mode 100644 index 0000000..f1e07d4 --- /dev/null +++ b/.history/src/App_20200224154038.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154043.js b/.history/src/App_20200224154043.js new file mode 100644 index 0000000..3842f6b --- /dev/null +++ b/.history/src/App_20200224154043.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154049.css b/.history/src/App_20200224154049.css new file mode 100644 index 0000000..0c40c57 --- /dev/null +++ b/.history/src/App_20200224154049.css @@ -0,0 +1,35 @@ +import '@fortawesome/fontawesome-free/css/all.css' +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154054.css b/.history/src/App_20200224154054.css new file mode 100644 index 0000000..a7e65d1 --- /dev/null +++ b/.history/src/App_20200224154054.css @@ -0,0 +1,35 @@ +@import '@fortawesome/fontawesome-free/css/all.css' +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154058.css b/.history/src/App_20200224154058.css new file mode 100644 index 0000000..eee8ce9 --- /dev/null +++ b/.history/src/App_20200224154058.css @@ -0,0 +1,35 @@ +@import '@fortawesome/fontawesome-free/css/all.css'; +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154105.css b/.history/src/App_20200224154105.css new file mode 100644 index 0000000..78e89ce --- /dev/null +++ b/.history/src/App_20200224154105.css @@ -0,0 +1,35 @@ +@import 'fortawesome/fontawesome-free/css/all.css'; +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154203.css b/.history/src/App_20200224154203.css new file mode 100644 index 0000000..b87fd66 --- /dev/null +++ b/.history/src/App_20200224154203.css @@ -0,0 +1,35 @@ +@import url('/font-awesome-4.6.3/css/font-awesome.min.css'); +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154215.css b/.history/src/App_20200224154215.css new file mode 100644 index 0000000..d60639b --- /dev/null +++ b/.history/src/App_20200224154215.css @@ -0,0 +1,35 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154218.js b/.history/src/App_20200224154218.js new file mode 100644 index 0000000..8c66a49 --- /dev/null +++ b/.history/src/App_20200224154218.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +@import url('/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154219.js b/.history/src/App_20200224154219.js new file mode 100644 index 0000000..de55637 --- /dev/null +++ b/.history/src/App_20200224154219.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import url('/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154222.js b/.history/src/App_20200224154222.js new file mode 100644 index 0000000..5541b8c --- /dev/null +++ b/.history/src/App_20200224154222.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import ('/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154229.js b/.history/src/App_20200224154229.js new file mode 100644 index 0000000..02ba0f2 --- /dev/null +++ b/.history/src/App_20200224154229.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import ('/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154232.js b/.history/src/App_20200224154232.js new file mode 100644 index 0000000..71e3ce3 --- /dev/null +++ b/.history/src/App_20200224154232.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import * ('/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154233.js b/.history/src/App_20200224154233.js new file mode 100644 index 0000000..6ed8845 --- /dev/null +++ b/.history/src/App_20200224154233.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import * from ('/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154234.js b/.history/src/App_20200224154234.js new file mode 100644 index 0000000..2fd25b5 --- /dev/null +++ b/.history/src/App_20200224154234.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import * from '/font-awesome-4.6.3/css/font-awesome.min.css'); +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154236.js b/.history/src/App_20200224154236.js new file mode 100644 index 0000000..b2ed9cd --- /dev/null +++ b/.history/src/App_20200224154236.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import * from '/font-awesome-4.6.3/css/font-awesome.min.css'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154240.css b/.history/src/App_20200224154240.css new file mode 100644 index 0000000..78e89ce --- /dev/null +++ b/.history/src/App_20200224154240.css @@ -0,0 +1,35 @@ +@import 'fortawesome/fontawesome-free/css/all.css'; +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154244.css b/.history/src/App_20200224154244.css new file mode 100644 index 0000000..10407e8 --- /dev/null +++ b/.history/src/App_20200224154244.css @@ -0,0 +1,35 @@ +@import ''; +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154245.css b/.history/src/App_20200224154245.css new file mode 100644 index 0000000..d60639b --- /dev/null +++ b/.history/src/App_20200224154245.css @@ -0,0 +1,35 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} \ No newline at end of file diff --git a/.history/src/App_20200224154249.js b/.history/src/App_20200224154249.js new file mode 100644 index 0000000..544a533 --- /dev/null +++ b/.history/src/App_20200224154249.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import * from 'fortawesome/fontawesome-free/css/all.css'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154327.js b/.history/src/App_20200224154327.js new file mode 100644 index 0000000..3842f6b --- /dev/null +++ b/.history/src/App_20200224154327.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; + +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154703.js b/.history/src/App_20200224154703.js new file mode 100644 index 0000000..4990639 --- /dev/null +++ b/.history/src/App_20200224154703.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154707.js b/.history/src/App_20200224154707.js new file mode 100644 index 0000000..e957d89 --- /dev/null +++ b/.history/src/App_20200224154707.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154711.js b/.history/src/App_20200224154711.js new file mode 100644 index 0000000..3dd41b7 --- /dev/null +++ b/.history/src/App_20200224154711.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154715.js b/.history/src/App_20200224154715.js new file mode 100644 index 0000000..8a0aab9 --- /dev/null +++ b/.history/src/App_20200224154715.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154719.js b/.history/src/App_20200224154719.js new file mode 100644 index 0000000..f1e07d4 --- /dev/null +++ b/.history/src/App_20200224154719.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154720.js b/.history/src/App_20200224154720.js new file mode 100644 index 0000000..f1e07d4 --- /dev/null +++ b/.history/src/App_20200224154720.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224154743.css b/.history/src/App_20200224154743.css new file mode 100644 index 0000000..96fabe7 --- /dev/null +++ b/.history/src/App_20200224154743.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid grey; +} \ No newline at end of file diff --git a/.history/src/App_20200224154754.css b/.history/src/App_20200224154754.css new file mode 100644 index 0000000..6b95fb2 --- /dev/null +++ b/.history/src/App_20200224154754.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #504d58; +} \ No newline at end of file diff --git a/.history/src/App_20200224154843.css b/.history/src/App_20200224154843.css new file mode 100644 index 0000000..2d371db --- /dev/null +++ b/.history/src/App_20200224154843.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52; +} \ No newline at end of file diff --git a/.history/src/App_20200224154852.css b/.history/src/App_20200224154852.css new file mode 100644 index 0000000..40ceb03 --- /dev/null +++ b/.history/src/App_20200224154852.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307; +} \ No newline at end of file diff --git a/.history/src/App_20200224154853.css b/.history/src/App_20200224154853.css new file mode 100644 index 0000000..a69b5f4 --- /dev/null +++ b/.history/src/App_20200224154853.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307c; +} \ No newline at end of file diff --git a/.history/src/App_20200224154857.css b/.history/src/App_20200224154857.css new file mode 100644 index 0000000..45f3e85 --- /dev/null +++ b/.history/src/App_20200224154857.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: ##52307c; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307c; +} \ No newline at end of file diff --git a/.history/src/App_20200224154900.css b/.history/src/App_20200224154900.css new file mode 100644 index 0000000..e5cae23 --- /dev/null +++ b/.history/src/App_20200224154900.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #52307c; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307c; +} \ No newline at end of file diff --git a/.history/src/App_20200224154903.css b/.history/src/App_20200224154903.css new file mode 100644 index 0000000..195fe8b --- /dev/null +++ b/.history/src/App_20200224154903.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #52307c; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #52307c; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307c; +} \ No newline at end of file diff --git a/.history/src/App_20200224154935.css b/.history/src/App_20200224154935.css new file mode 100644 index 0000000..fb3c352 --- /dev/null +++ b/.history/src/App_20200224154935.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #381663; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #52307c; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307c; +} \ No newline at end of file diff --git a/.history/src/App_20200224154937.css b/.history/src/App_20200224154937.css new file mode 100644 index 0000000..7e2c5bf --- /dev/null +++ b/.history/src/App_20200224154937.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #381663; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #381663; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307c; +} \ No newline at end of file diff --git a/.history/src/App_20200224154939.css b/.history/src/App_20200224154939.css new file mode 100644 index 0000000..d7a7b95 --- /dev/null +++ b/.history/src/App_20200224154939.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #381663; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #381663; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #381663; +} \ No newline at end of file diff --git a/.history/src/App_20200224154959.css b/.history/src/App_20200224154959.css new file mode 100644 index 0000000..0e04247 --- /dev/null +++ b/.history/src/App_20200224154959.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #52307x; +} \ No newline at end of file diff --git a/.history/src/App_20200224155001.css b/.history/src/App_20200224155001.css new file mode 100644 index 0000000..6b95fb2 --- /dev/null +++ b/.history/src/App_20200224155001.css @@ -0,0 +1,38 @@ + +.app{ + margin-top:60px; + flex-direction: column; + display: flex; +} +.container{ + display: flex; +} +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ + display: flex; + justify-content: center; +} +.tools{ + padding: 10px; + flex-direction: column; + align-items: center; + justify-content: center; + display: flex; + background-color: #504d58; + margin-bottom: -2px; +} +canvas{ + border: 1px solid #504d58; +} \ No newline at end of file diff --git a/.history/src/App_20200224155824.js b/.history/src/App_20200224155824.js new file mode 100644 index 0000000..c68d08c --- /dev/null +++ b/.history/src/App_20200224155824.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224155827.js b/.history/src/App_20200224155827.js new file mode 100644 index 0000000..a78d768 --- /dev/null +++ b/.history/src/App_20200224155827.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = () => { + + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224155838.js b/.history/src/App_20200224155838.js new file mode 100644 index 0000000..decd13f --- /dev/null +++ b/.history/src/App_20200224155838.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = (color) => { + + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224155849.js b/.history/src/App_20200224155849.js new file mode 100644 index 0000000..8588a69 --- /dev/null +++ b/.history/src/App_20200224155849.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = (color) => { + this.editor.current.changeColor(color) + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224155922.js b/.history/src/App_20200224155922.js new file mode 100644 index 0000000..4521a46 --- /dev/null +++ b/.history/src/App_20200224155922.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = (color) => { + this.editor.current.changeColor(color) + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224155925.js b/.history/src/App_20200224155925.js new file mode 100644 index 0000000..0a3fef6 --- /dev/null +++ b/.history/src/App_20200224155925.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = (color) => { + this.editor.current.changeColor(color) + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224160818.js b/.history/src/App_20200224160818.js new file mode 100644 index 0000000..497d948 --- /dev/null +++ b/.history/src/App_20200224160818.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = (color) => { + this.editor.current.changeColor(color) + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224160821.js b/.history/src/App_20200224160821.js new file mode 100644 index 0000000..f95df63 --- /dev/null +++ b/.history/src/App_20200224160821.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + changeColorForAll = (color) => { + this.editor.current.changeColor(color) + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224160826.js b/.history/src/App_20200224160826.js new file mode 100644 index 0000000..4427d39 --- /dev/null +++ b/.history/src/App_20200224160826.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162153.js b/.history/src/App_20200224162153.js new file mode 100644 index 0000000..7fc4c2c --- /dev/null +++ b/.history/src/App_20200224162153.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162202.js b/.history/src/App_20200224162202.js new file mode 100644 index 0000000..96f7726 --- /dev/null +++ b/.history/src/App_20200224162202.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162204.js b/.history/src/App_20200224162204.js new file mode 100644 index 0000000..e2055ab --- /dev/null +++ b/.history/src/App_20200224162204.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162211.js b/.history/src/App_20200224162211.js new file mode 100644 index 0000000..06fd7aa --- /dev/null +++ b/.history/src/App_20200224162211.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162213.js b/.history/src/App_20200224162213.js new file mode 100644 index 0000000..d2a1d00 --- /dev/null +++ b/.history/src/App_20200224162213.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() + } toggleCrop={ () => this.toggleCropper()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162216.js b/.history/src/App_20200224162216.js new file mode 100644 index 0000000..4298025 --- /dev/null +++ b/.history/src/App_20200224162216.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() + } } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162217.js b/.history/src/App_20200224162217.js new file mode 100644 index 0000000..6034698 --- /dev/null +++ b/.history/src/App_20200224162217.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping() + } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162219.js b/.history/src/App_20200224162219.js new file mode 100644 index 0000000..f1b2303 --- /dev/null +++ b/.history/src/App_20200224162219.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162600.js b/.history/src/App_20200224162600.js new file mode 100644 index 0000000..5c832c4 --- /dev/null +++ b/.history/src/App_20200224162600.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162601.js b/.history/src/App_20200224162601.js new file mode 100644 index 0000000..5bb1b53 --- /dev/null +++ b/.history/src/App_20200224162601.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162603.js b/.history/src/App_20200224162603.js new file mode 100644 index 0000000..9f4aa77 --- /dev/null +++ b/.history/src/App_20200224162603.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162608.js b/.history/src/App_20200224162608.js new file mode 100644 index 0000000..00f3964 --- /dev/null +++ b/.history/src/App_20200224162608.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162610.js b/.history/src/App_20200224162610.js new file mode 100644 index 0000000..eb0f191 --- /dev/null +++ b/.history/src/App_20200224162610.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + evet={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162612.js b/.history/src/App_20200224162612.js new file mode 100644 index 0000000..948be48 --- /dev/null +++ b/.history/src/App_20200224162612.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162927.js b/.history/src/App_20200224162927.js new file mode 100644 index 0000000..4702028 --- /dev/null +++ b/.history/src/App_20200224162927.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if() + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162930.js b/.history/src/App_20200224162930.js new file mode 100644 index 0000000..ea02107 --- /dev/null +++ b/.history/src/App_20200224162930.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(croppingImage) + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162931.js b/.history/src/App_20200224162931.js new file mode 100644 index 0000000..95c59f8 --- /dev/null +++ b/.history/src/App_20200224162931.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(croppingImage){ + + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162943.js b/.history/src/App_20200224162943.js new file mode 100644 index 0000000..2451683 --- /dev/null +++ b/.history/src/App_20200224162943.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162946.js b/.history/src/App_20200224162946.js new file mode 100644 index 0000000..4365a07 --- /dev/null +++ b/.history/src/App_20200224162946.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(croppingImage){ + this.editor.current.applyCropping() + } else{ + + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224162952.js b/.history/src/App_20200224162952.js new file mode 100644 index 0000000..a195ad8 --- /dev/null +++ b/.history/src/App_20200224162952.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163000.js b/.history/src/App_20200224163000.js new file mode 100644 index 0000000..a886fa8 --- /dev/null +++ b/.history/src/App_20200224163000.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163013.js b/.history/src/App_20200224163013.js new file mode 100644 index 0000000..e174ad8 --- /dev/null +++ b/.history/src/App_20200224163013.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping() + } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163016.js b/.history/src/App_20200224163016.js new file mode 100644 index 0000000..9fd4c01 --- /dev/null +++ b/.history/src/App_20200224163016.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping() + } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163018.js b/.history/src/App_20200224163018.js new file mode 100644 index 0000000..c06cfc1 --- /dev/null +++ b/.history/src/App_20200224163018.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.toggleCropper() + } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163022.js b/.history/src/App_20200224163022.js new file mode 100644 index 0000000..f31d694 --- /dev/null +++ b/.history/src/App_20200224163022.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.toggleCropper() } + } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163024.js b/.history/src/App_20200224163024.js new file mode 100644 index 0000000..4537d3d --- /dev/null +++ b/.history/src/App_20200224163024.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.toggleCropper() } + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163031.js b/.history/src/App_20200224163031.js new file mode 100644 index 0000000..7352212 --- /dev/null +++ b/.history/src/App_20200224163031.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } else{ + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.toggleCropper() } + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163032.js b/.history/src/App_20200224163032.js new file mode 100644 index 0000000..0cfb0a5 --- /dev/null +++ b/.history/src/App_20200224163032.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163157.js b/.history/src/App_20200224163157.js new file mode 100644 index 0000000..1c11840 --- /dev/null +++ b/.history/src/App_20200224163157.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163442.js b/.history/src/App_20200224163442.js new file mode 100644 index 0000000..99742e4 --- /dev/null +++ b/.history/src/App_20200224163442.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163802.js b/.history/src/App_20200224163802.js new file mode 100644 index 0000000..ece16da --- /dev/null +++ b/.history/src/App_20200224163802.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163803.js b/.history/src/App_20200224163803.js new file mode 100644 index 0000000..65c18c0 --- /dev/null +++ b/.history/src/App_20200224163803.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163807.js b/.history/src/App_20200224163807.js new file mode 100644 index 0000000..196b39e --- /dev/null +++ b/.history/src/App_20200224163807.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163809.js b/.history/src/App_20200224163809.js new file mode 100644 index 0000000..51ddfa7 --- /dev/null +++ b/.history/src/App_20200224163809.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }) + if(this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163816.js b/.history/src/App_20200224163816.js new file mode 100644 index 0000000..99742e4 --- /dev/null +++ b/.history/src/App_20200224163816.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163819.js b/.history/src/App_20200224163819.js new file mode 100644 index 0000000..1400dbb --- /dev/null +++ b/.history/src/App_20200224163819.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163822.js b/.history/src/App_20200224163822.js new file mode 100644 index 0000000..1400dbb --- /dev/null +++ b/.history/src/App_20200224163822.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163900.js b/.history/src/App_20200224163900.js new file mode 100644 index 0000000..3769ab3 --- /dev/null +++ b/.history/src/App_20200224163900.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + ), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163904.js b/.history/src/App_20200224163904.js new file mode 100644 index 0000000..f515e68 --- /dev/null +++ b/.history/src/App_20200224163904.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + + }), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163909.js b/.history/src/App_20200224163909.js new file mode 100644 index 0000000..7d56b3c --- /dev/null +++ b/.history/src/App_20200224163909.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(cr) + }), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163912.js b/.history/src/App_20200224163912.js new file mode 100644 index 0000000..cb1a447 --- /dev/null +++ b/.history/src/App_20200224163912.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(crop) + }), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163913.js b/.history/src/App_20200224163913.js new file mode 100644 index 0000000..93d465c --- /dev/null +++ b/.history/src/App_20200224163913.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(croppingImage) + }), + ) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163915.js b/.history/src/App_20200224163915.js new file mode 100644 index 0000000..17244e1 --- /dev/null +++ b/.history/src/App_20200224163915.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(croppingImage) + }), + ) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224163920.js b/.history/src/App_20200224163920.js new file mode 100644 index 0000000..e007828 --- /dev/null +++ b/.history/src/App_20200224163920.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(this.state.croppingImage) + }), + ) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164024.js b/.history/src/App_20200224164024.js new file mode 100644 index 0000000..976f968 --- /dev/null +++ b/.history/src/App_20200224164024.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(this.state.croppingImage) + }), + ) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164026.js b/.history/src/App_20200224164026.js new file mode 100644 index 0000000..4d30601 --- /dev/null +++ b/.history/src/App_20200224164026.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }, + function(){ + console.log(this.state.croppingImage) + }), + ) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164131.js b/.history/src/App_20200224164131.js new file mode 100644 index 0000000..b93aff2 --- /dev/null +++ b/.history/src/App_20200224164131.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + } + ) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164132.js b/.history/src/App_20200224164132.js new file mode 100644 index 0000000..6a15c3a --- /dev/null +++ b/.history/src/App_20200224164132.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + }) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164139.js b/.history/src/App_20200224164139.js new file mode 100644 index 0000000..b6f3345 --- /dev/null +++ b/.history/src/App_20200224164139.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + })) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164147.js b/.history/src/App_20200224164147.js new file mode 100644 index 0000000..af73287 --- /dev/null +++ b/.history/src/App_20200224164147.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + })) + console.log(this.state.croppingImage) + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164149.js b/.history/src/App_20200224164149.js new file mode 100644 index 0000000..c20e682 --- /dev/null +++ b/.history/src/App_20200224164149.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + })) + console.log(this.state.croppingImage,"LLL") + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164202.js b/.history/src/App_20200224164202.js new file mode 100644 index 0000000..c20e682 --- /dev/null +++ b/.history/src/App_20200224164202.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.isOpened + })) + console.log(this.state.croppingImage,"LLL") + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164336.js b/.history/src/App_20200224164336.js new file mode 100644 index 0000000..dddf31a --- /dev/null +++ b/.history/src/App_20200224164336.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + console.log(this.state.croppingImage,"LLL") + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } else { + // this.editor.current.set('crop') + // } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164339.js b/.history/src/App_20200224164339.js new file mode 100644 index 0000000..044596f --- /dev/null +++ b/.history/src/App_20200224164339.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + console.log(this.state.croppingImage,"LLL") + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164341.js b/.history/src/App_20200224164341.js new file mode 100644 index 0000000..86d1c03 --- /dev/null +++ b/.history/src/App_20200224164341.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164342.js b/.history/src/App_20200224164342.js new file mode 100644 index 0000000..ad678ab --- /dev/null +++ b/.history/src/App_20200224164342.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164346.js b/.history/src/App_20200224164346.js new file mode 100644 index 0000000..7d2032e --- /dev/null +++ b/.history/src/App_20200224164346.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.set + } else { + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164347.js b/.history/src/App_20200224164347.js new file mode 100644 index 0000000..d268f5b --- /dev/null +++ b/.history/src/App_20200224164347.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState + } else { + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164350.js b/.history/src/App_20200224164350.js new file mode 100644 index 0000000..32f7eec --- /dev/null +++ b/.history/src/App_20200224164350.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({cr}) + } else { + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164355.js b/.history/src/App_20200224164355.js new file mode 100644 index 0000000..5a5d8fe --- /dev/null +++ b/.history/src/App_20200224164355.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : }) + } else { + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164357.js b/.history/src/App_20200224164357.js new file mode 100644 index 0000000..976e477 --- /dev/null +++ b/.history/src/App_20200224164357.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + } else { + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164400.js b/.history/src/App_20200224164400.js new file mode 100644 index 0000000..37d5cbc --- /dev/null +++ b/.history/src/App_20200224164400.js @@ -0,0 +1,74 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + } else { + this.editor.current.set('crop') + this.setState({croppingImage : false}) + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164403.js b/.history/src/App_20200224164403.js new file mode 100644 index 0000000..eb43fba --- /dev/null +++ b/.history/src/App_20200224164403.js @@ -0,0 +1,74 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + } else { + this.editor.current.set('crop') + this.setState({croppingImage : true}) + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164410.js b/.history/src/App_20200224164410.js new file mode 100644 index 0000000..050f962 --- /dev/null +++ b/.history/src/App_20200224164410.js @@ -0,0 +1,74 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + } else { + this.editor.current.set('crop') + this.setState({croppingImage : true}) + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164451.js b/.history/src/App_20200224164451.js new file mode 100644 index 0000000..8f28b29 --- /dev/null +++ b/.history/src/App_20200224164451.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + this. + } else { + this.editor.current.set('crop') + this.setState({croppingImage : true}) + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164452.js b/.history/src/App_20200224164452.js new file mode 100644 index 0000000..8f8bdd8 --- /dev/null +++ b/.history/src/App_20200224164452.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + this.ed + } else { + this.editor.current.set('crop') + this.setState({croppingImage : true}) + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164458.js b/.history/src/App_20200224164458.js new file mode 100644 index 0000000..6d1a14c --- /dev/null +++ b/.history/src/App_20200224164458.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + this.editor.current.set('crop') + this.setState({croppingImage : true}) + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164516.js b/.history/src/App_20200224164516.js new file mode 100644 index 0000000..852da15 --- /dev/null +++ b/.history/src/App_20200224164516.js @@ -0,0 +1,76 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.editor.current.applyCropping() + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164519.js b/.history/src/App_20200224164519.js new file mode 100644 index 0000000..3054a0a --- /dev/null +++ b/.history/src/App_20200224164519.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + // this.setState(prev => ({ + // croppingImage: !prev.isOpened + // })) + + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164521.js b/.history/src/App_20200224164521.js new file mode 100644 index 0000000..1fdf4a7 --- /dev/null +++ b/.history/src/App_20200224164521.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.toggleCropper()} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164621.js b/.history/src/App_20200224164621.js new file mode 100644 index 0000000..a838805 --- /dev/null +++ b/.history/src/App_20200224164621.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.applyCropping() : () => this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164624.js b/.history/src/App_20200224164624.js new file mode 100644 index 0000000..a3e84b1 --- /dev/null +++ b/.history/src/App_20200224164624.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164628.js b/.history/src/App_20200224164628.js new file mode 100644 index 0000000..5848d33 --- /dev/null +++ b/.history/src/App_20200224164628.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164638.js b/.history/src/App_20200224164638.js new file mode 100644 index 0000000..5052b3f --- /dev/null +++ b/.history/src/App_20200224164638.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164640.js b/.history/src/App_20200224164640.js new file mode 100644 index 0000000..1ef93ea --- /dev/null +++ b/.history/src/App_20200224164640.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164650.js b/.history/src/App_20200224164650.js new file mode 100644 index 0000000..57c6daa --- /dev/null +++ b/.history/src/App_20200224164650.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164652.js b/.history/src/App_20200224164652.js new file mode 100644 index 0000000..1ef93ea --- /dev/null +++ b/.history/src/App_20200224164652.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({croppingImage : false}) + this.editor.current.applyCropping() + } else { + + this.setState({croppingImage : true}) + this.editor.current.set('crop') + } + console.log(this.state.croppingImage,"LLL") + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164653.js b/.history/src/App_20200224164653.js new file mode 100644 index 0000000..d46d0ff --- /dev/null +++ b/.history/src/App_20200224164653.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164655.js b/.history/src/App_20200224164655.js new file mode 100644 index 0000000..dd21066 --- /dev/null +++ b/.history/src/App_20200224164655.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164724.js b/.history/src/App_20200224164724.js new file mode 100644 index 0000000..41bd894 --- /dev/null +++ b/.history/src/App_20200224164724.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + cropper="true" + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164739.js b/.history/src/App_20200224164739.js new file mode 100644 index 0000000..0a54fdb --- /dev/null +++ b/.history/src/App_20200224164739.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + cropper=true + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164741.js b/.history/src/App_20200224164741.js new file mode 100644 index 0000000..27e6724 --- /dev/null +++ b/.history/src/App_20200224164741.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + cropper={true + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164742.js b/.history/src/App_20200224164742.js new file mode 100644 index 0000000..6b5fd5b --- /dev/null +++ b/.history/src/App_20200224164742.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + cropper={true} + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164751.js b/.history/src/App_20200224164751.js new file mode 100644 index 0000000..295f2d2 --- /dev/null +++ b/.history/src/App_20200224164751.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + cropper={true} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164907.js b/.history/src/App_20200224164907.js new file mode 100644 index 0000000..d44c734 --- /dev/null +++ b/.history/src/App_20200224164907.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224164914.js b/.history/src/App_20200224164914.js new file mode 100644 index 0000000..ab6c065 --- /dev/null +++ b/.history/src/App_20200224164914.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170315.js b/.history/src/App_20200224170315.js new file mode 100644 index 0000000..55be084 --- /dev/null +++ b/.history/src/App_20200224170315.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170317.js b/.history/src/App_20200224170317.js new file mode 100644 index 0000000..55be084 --- /dev/null +++ b/.history/src/App_20200224170317.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170324.js b/.history/src/App_20200224170324.js new file mode 100644 index 0000000..741eecf --- /dev/null +++ b/.history/src/App_20200224170324.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('selectMode')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170327.js b/.history/src/App_20200224170327.js new file mode 100644 index 0000000..0623b33 --- /dev/null +++ b/.history/src/App_20200224170327.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + // toggleCropper = () => { + // if (this.state.croppingImage) { + // this.setState({croppingImage : false}) + // this.editor.current.applyCropping() + // } else { + + // this.setState({croppingImage : true}) + // this.editor.current.set('crop') + // } + // console.log(this.state.croppingImage,"LLL") + // } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> */} + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170835.js b/.history/src/App_20200224170835.js new file mode 100644 index 0000000..948be48 --- /dev/null +++ b/.history/src/App_20200224170835.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170839.js b/.history/src/App_20200224170839.js new file mode 100644 index 0000000..f1b2303 --- /dev/null +++ b/.history/src/App_20200224170839.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } toggleCrop={ () => this.toggleCropper()} + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224170844.js b/.history/src/App_20200224170844.js new file mode 100644 index 0000000..948be48 --- /dev/null +++ b/.history/src/App_20200224170844.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171120.js b/.history/src/App_20200224171120.js new file mode 100644 index 0000000..b5c36ec --- /dev/null +++ b/.history/src/App_20200224171120.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if() + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171122.js b/.history/src/App_20200224171122.js new file mode 100644 index 0000000..948be48 --- /dev/null +++ b/.history/src/App_20200224171122.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + this.setState(prev => ({ + croppingImage: !prev.isOpened + }), + ) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171133.js b/.history/src/App_20200224171133.js new file mode 100644 index 0000000..73e59f0 --- /dev/null +++ b/.history/src/App_20200224171133.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171135.js b/.history/src/App_20200224171135.js new file mode 100644 index 0000000..c93f57d --- /dev/null +++ b/.history/src/App_20200224171135.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.set + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171139.js b/.history/src/App_20200224171139.js new file mode 100644 index 0000000..ac7c263 --- /dev/null +++ b/.history/src/App_20200224171139.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171143.js b/.history/src/App_20200224171143.js new file mode 100644 index 0000000..a374323 --- /dev/null +++ b/.history/src/App_20200224171143.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171146.js b/.history/src/App_20200224171146.js new file mode 100644 index 0000000..2642797 --- /dev/null +++ b/.history/src/App_20200224171146.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + } + else{ + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171149.js b/.history/src/App_20200224171149.js new file mode 100644 index 0000000..3a6677e --- /dev/null +++ b/.history/src/App_20200224171149.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + } + else{ + this.setState({croppingImage: false}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171151.js b/.history/src/App_20200224171151.js new file mode 100644 index 0000000..b1d6f03 --- /dev/null +++ b/.history/src/App_20200224171151.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171236.js b/.history/src/App_20200224171236.js new file mode 100644 index 0000000..bc47a6e --- /dev/null +++ b/.history/src/App_20200224171236.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171238.js b/.history/src/App_20200224171238.js new file mode 100644 index 0000000..8fd8ded --- /dev/null +++ b/.history/src/App_20200224171238.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + re + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171240.js b/.history/src/App_20200224171240.js new file mode 100644 index 0000000..6c34647 --- /dev/null +++ b/.history/src/App_20200224171240.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + retur + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171243.js b/.history/src/App_20200224171243.js new file mode 100644 index 0000000..0e613f0 --- /dev/null +++ b/.history/src/App_20200224171243.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + retur + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171248.js b/.history/src/App_20200224171248.js new file mode 100644 index 0000000..baea086 --- /dev/null +++ b/.history/src/App_20200224171248.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + return + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + this.editor.current.applyCropping()} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171256.js b/.history/src/App_20200224171256.js new file mode 100644 index 0000000..3d2e4d1 --- /dev/null +++ b/.history/src/App_20200224171256.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + return + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171258.js b/.history/src/App_20200224171258.js new file mode 100644 index 0000000..beb69fb --- /dev/null +++ b/.history/src/App_20200224171258.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + return this.editor.current.applyCropping()} + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171302.js b/.history/src/App_20200224171302.js new file mode 100644 index 0000000..a3b706d --- /dev/null +++ b/.history/src/App_20200224171302.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171303.js b/.history/src/App_20200224171303.js new file mode 100644 index 0000000..a3b706d --- /dev/null +++ b/.history/src/App_20200224171303.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171327.js b/.history/src/App_20200224171327.js new file mode 100644 index 0000000..a0e44f9 --- /dev/null +++ b/.history/src/App_20200224171327.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: true}) + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171329.js b/.history/src/App_20200224171329.js new file mode 100644 index 0000000..71dea06 --- /dev/null +++ b/.history/src/App_20200224171329.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171341.js b/.history/src/App_20200224171341.js new file mode 100644 index 0000000..c7b25d9 --- /dev/null +++ b/.history/src/App_20200224171341.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + return this.editor.current.applyCropping()} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171349.js b/.history/src/App_20200224171349.js new file mode 100644 index 0000000..0b64fb2 --- /dev/null +++ b/.history/src/App_20200224171349.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + return this.editor.current.applyCropping()} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171351.js b/.history/src/App_20200224171351.js new file mode 100644 index 0000000..acd7eb1 --- /dev/null +++ b/.history/src/App_20200224171351.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + return this.editor.current.set()} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171353.js b/.history/src/App_20200224171353.js new file mode 100644 index 0000000..a6be9fe --- /dev/null +++ b/.history/src/App_20200224171353.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () =>{ + if(this.state.croppingImage){ + this.setState({croppingImage: false}) + return this.editor.current.applyCropping()} /> + } + else{ + this.setState({croppingImage: true}) + return this.editor.current.set('crop')} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper() } + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171355.js b/.history/src/App_20200224171355.js new file mode 100644 index 0000000..3ce9930 --- /dev/null +++ b/.history/src/App_20200224171355.js @@ -0,0 +1,72 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop')} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.toggleCropper()} + iconClassName={croppingImage ? "far fa-check-circle fa-lg" : "fas fa-crop-alt fa-lg"} + event={croppingImage ? () => this.editor.current.applyCropping() : () => this.editor.current.set('crop') + } + /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171401.js b/.history/src/App_20200224171401.js new file mode 100644 index 0000000..4d60dcb --- /dev/null +++ b/.history/src/App_20200224171401.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop')} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171405.js b/.history/src/App_20200224171405.js new file mode 100644 index 0000000..8dcf50d --- /dev/null +++ b/.history/src/App_20200224171405.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop')} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171406.js b/.history/src/App_20200224171406.js new file mode 100644 index 0000000..58e91b4 --- /dev/null +++ b/.history/src/App_20200224171406.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop')} /> + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.toggleCropper} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171411.js b/.history/src/App_20200224171411.js new file mode 100644 index 0000000..b06c903 --- /dev/null +++ b/.history/src/App_20200224171411.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop')} /> + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.toggleCropper} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171422.js b/.history/src/App_20200224171422.js new file mode 100644 index 0000000..1524af5 --- /dev/null +++ b/.history/src/App_20200224171422.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} /> + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.toggleCropper} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171424.js b/.history/src/App_20200224171424.js new file mode 100644 index 0000000..de8bb88 --- /dev/null +++ b/.history/src/App_20200224171424.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.toggleCropper} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171543.js b/.history/src/App_20200224171543.js new file mode 100644 index 0000000..076f207 --- /dev/null +++ b/.history/src/App_20200224171543.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + return this.toggleCropper + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171545.js b/.history/src/App_20200224171545.js new file mode 100644 index 0000000..9cd0198 --- /dev/null +++ b/.history/src/App_20200224171545.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + return this.toggleCropper + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171554.js b/.history/src/App_20200224171554.js new file mode 100644 index 0000000..c38f762 --- /dev/null +++ b/.history/src/App_20200224171554.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + return < + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171556.js b/.history/src/App_20200224171556.js new file mode 100644 index 0000000..c54be14 --- /dev/null +++ b/.history/src/App_20200224171556.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + return +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171557.js b/.history/src/App_20200224171557.js new file mode 100644 index 0000000..c1574de --- /dev/null +++ b/.history/src/App_20200224171557.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + return +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171558.js b/.history/src/App_20200224171558.js new file mode 100644 index 0000000..684f1d8 --- /dev/null +++ b/.history/src/App_20200224171558.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + return + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171656.js b/.history/src/App_20200224171656.js new file mode 100644 index 0000000..330f8ce --- /dev/null +++ b/.history/src/App_20200224171656.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + // const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171657.js b/.history/src/App_20200224171657.js new file mode 100644 index 0000000..f0948cb --- /dev/null +++ b/.history/src/App_20200224171657.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171704.js b/.history/src/App_20200224171704.js new file mode 100644 index 0000000..aa4fdd5 --- /dev/null +++ b/.history/src/App_20200224171704.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.user ? : } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171709.js b/.history/src/App_20200224171709.js new file mode 100644 index 0000000..e7f4070 --- /dev/null +++ b/.history/src/App_20200224171709.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return ( this.editor.current.set('crop')} />) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171715.js b/.history/src/App_20200224171715.js new file mode 100644 index 0000000..0b17e7c --- /dev/null +++ b/.history/src/App_20200224171715.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : } + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171721.js b/.history/src/App_20200224171721.js new file mode 100644 index 0000000..d27fe7c --- /dev/null +++ b/.history/src/App_20200224171721.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171723.js b/.history/src/App_20200224171723.js new file mode 100644 index 0000000..1f37629 --- /dev/null +++ b/.history/src/App_20200224171723.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171725.js b/.history/src/App_20200224171725.js new file mode 100644 index 0000000..bbaf6f3 --- /dev/null +++ b/.history/src/App_20200224171725.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171727.js b/.history/src/App_20200224171727.js new file mode 100644 index 0000000..41f019d --- /dev/null +++ b/.history/src/App_20200224171727.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping()} /> + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171734.js b/.history/src/App_20200224171734.js new file mode 100644 index 0000000..b25f5ff --- /dev/null +++ b/.history/src/App_20200224171734.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171738.js b/.history/src/App_20200224171738.js new file mode 100644 index 0000000..703b77b --- /dev/null +++ b/.history/src/App_20200224171738.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} /> : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171740.js b/.history/src/App_20200224171740.js new file mode 100644 index 0000000..26126bf --- /dev/null +++ b/.history/src/App_20200224171740.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} /> : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171741.js b/.history/src/App_20200224171741.js new file mode 100644 index 0000000..8521a57 --- /dev/null +++ b/.history/src/App_20200224171741.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171742.js b/.history/src/App_20200224171742.js new file mode 100644 index 0000000..596f58f --- /dev/null +++ b/.history/src/App_20200224171742.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> : + + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171745.js b/.history/src/App_20200224171745.js new file mode 100644 index 0000000..fd54b47 --- /dev/null +++ b/.history/src/App_20200224171745.js @@ -0,0 +1,70 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> + : + + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171747.js b/.history/src/App_20200224171747.js new file mode 100644 index 0000000..bb0fe35 --- /dev/null +++ b/.history/src/App_20200224171747.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171753.js b/.history/src/App_20200224171753.js new file mode 100644 index 0000000..51b71b0 --- /dev/null +++ b/.history/src/App_20200224171753.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + return () + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171757.js b/.history/src/App_20200224171757.js new file mode 100644 index 0000000..28978a7 --- /dev/null +++ b/.history/src/App_20200224171757.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171758.js b/.history/src/App_20200224171758.js new file mode 100644 index 0000000..9a78089 --- /dev/null +++ b/.history/src/App_20200224171758.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171800.js b/.history/src/App_20200224171800.js new file mode 100644 index 0000000..985d7b6 --- /dev/null +++ b/.history/src/App_20200224171800.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171821.js b/.history/src/App_20200224171821.js new file mode 100644 index 0000000..b1088ce --- /dev/null +++ b/.history/src/App_20200224171821.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171826.js b/.history/src/App_20200224171826.js new file mode 100644 index 0000000..5637ff1 --- /dev/null +++ b/.history/src/App_20200224171826.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + toggleCropper= /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171834.js b/.history/src/App_20200224171834.js new file mode 100644 index 0000000..9a403d5 --- /dev/null +++ b/.history/src/App_20200224171834.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + toggleCropper={() => this.toggleCropper} /> + : + this.editor.current.set('crop')} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171838.js b/.history/src/App_20200224171838.js new file mode 100644 index 0000000..d946d3e --- /dev/null +++ b/.history/src/App_20200224171838.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + toggleCropper={() => this.toggleCropper} /> + : + this.editor.current.set('crop')} + toggleCropper={() => this.toggleCropper} />} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224171918.js b/.history/src/App_20200224171918.js new file mode 100644 index 0000000..a1c8d07 --- /dev/null +++ b/.history/src/App_20200224171918.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + toggleCropper={() => this.toggleCropper} /> + : + this.editor.current.set('crop')} + toggleCropper={() => this.toggleCropper} />} +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172037.js b/.history/src/App_20200224172037.js new file mode 100644 index 0000000..5ea63f6 --- /dev/null +++ b/.history/src/App_20200224172037.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + } /> + : + this.editor.current.set('crop')} + toggleCropper={() => this.toggleCropper} />} +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172038.js b/.history/src/App_20200224172038.js new file mode 100644 index 0000000..a79233f --- /dev/null +++ b/.history/src/App_20200224172038.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + } /> + : + this.editor.current.set('crop')} + toggleCropper={() => this.toggleCropper} />} +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172039.js b/.history/src/App_20200224172039.js new file mode 100644 index 0000000..a1b4619 --- /dev/null +++ b/.history/src/App_20200224172039.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + /> + : + this.editor.current.set('crop')} + toggleCropper={() => this.toggleCropper} />} +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172044.js b/.history/src/App_20200224172044.js new file mode 100644 index 0000000..8764088 --- /dev/null +++ b/.history/src/App_20200224172044.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} + /> + : + this.editor.current.set('crop')} + />} +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172409.js b/.history/src/App_20200224172409.js new file mode 100644 index 0000000..3718722 --- /dev/null +++ b/.history/src/App_20200224172409.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + /> + : + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172411.js b/.history/src/App_20200224172411.js new file mode 100644 index 0000000..ca14296 --- /dev/null +++ b/.history/src/App_20200224172411.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + /> + : + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172417.js b/.history/src/App_20200224172417.js new file mode 100644 index 0000000..decaa18 --- /dev/null +++ b/.history/src/App_20200224172417.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={this.state.showMyComponent ? {} : { display: 'none' }} + /> + : + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172423.js b/.history/src/App_20200224172423.js new file mode 100644 index 0000000..4a1eae1 --- /dev/null +++ b/.history/src/App_20200224172423.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={crop ? {} : { display: 'none' }} + /> + : + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172425.js b/.history/src/App_20200224172425.js new file mode 100644 index 0000000..daf971e --- /dev/null +++ b/.history/src/App_20200224172425.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={croppingImage ? {} : { display: 'none' }} + /> + : + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172448.js b/.history/src/App_20200224172448.js new file mode 100644 index 0000000..38e41b8 --- /dev/null +++ b/.history/src/App_20200224172448.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={croppingImage ? {} : { display: 'none' }} + /> + + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172449.js b/.history/src/App_20200224172449.js new file mode 100644 index 0000000..055a602 --- /dev/null +++ b/.history/src/App_20200224172449.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={croppingImage ? {} : { display: 'none' }} + /> + + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172452.js b/.history/src/App_20200224172452.js new file mode 100644 index 0000000..0270e64 --- /dev/null +++ b/.history/src/App_20200224172452.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={croppingImage ? {} : { display: 'none' }} + /> + + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172454.js b/.history/src/App_20200224172454.js new file mode 100644 index 0000000..888863d --- /dev/null +++ b/.history/src/App_20200224172454.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} + style={croppingImage ? {} : { display: 'none' }} + /> + + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172456.js b/.history/src/App_20200224172456.js new file mode 100644 index 0000000..03b2dee --- /dev/null +++ b/.history/src/App_20200224172456.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} + /> + + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172502.js b/.history/src/App_20200224172502.js new file mode 100644 index 0000000..c6508fd --- /dev/null +++ b/.history/src/App_20200224172502.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172506.js b/.history/src/App_20200224172506.js new file mode 100644 index 0000000..70d7df5 --- /dev/null +++ b/.history/src/App_20200224172506.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172508.js b/.history/src/App_20200224172508.js new file mode 100644 index 0000000..53761c9 --- /dev/null +++ b/.history/src/App_20200224172508.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172510.js b/.history/src/App_20200224172510.js new file mode 100644 index 0000000..302719b --- /dev/null +++ b/.history/src/App_20200224172510.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} + /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172512.js b/.history/src/App_20200224172512.js new file mode 100644 index 0000000..4751a5f --- /dev/null +++ b/.history/src/App_20200224172512.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172514.js b/.history/src/App_20200224172514.js new file mode 100644 index 0000000..8db2d1e --- /dev/null +++ b/.history/src/App_20200224172514.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} style={croppingImage ? {} : { display: 'none' }}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172518.js b/.history/src/App_20200224172518.js new file mode 100644 index 0000000..bad6eb0 --- /dev/null +++ b/.history/src/App_20200224172518.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} style={croppingImage ? {} : }/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172520.js b/.history/src/App_20200224172520.js new file mode 100644 index 0000000..844d8b9 --- /dev/null +++ b/.history/src/App_20200224172520.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} style={croppingImage ? { display: 'none' }{} : }/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172522.js b/.history/src/App_20200224172522.js new file mode 100644 index 0000000..04f06a2 --- /dev/null +++ b/.history/src/App_20200224172522.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} style={croppingImage ? { display: 'none' } : {}}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172613.js b/.history/src/App_20200224172613.js new file mode 100644 index 0000000..4751a5f --- /dev/null +++ b/.history/src/App_20200224172613.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172618.js b/.history/src/App_20200224172618.js new file mode 100644 index 0000000..c442ea6 --- /dev/null +++ b/.history/src/App_20200224172618.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} croppingImage={style={croppingImage ? { display: 'none' } : {}}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172621.js b/.history/src/App_20200224172621.js new file mode 100644 index 0000000..40ddb32 --- /dev/null +++ b/.history/src/App_20200224172621.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} style={croppingImage ? {} : { display: 'none' }} /> + this.editor.current.set('crop')} croppingImage={croppingImage}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172639.js b/.history/src/App_20200224172639.js new file mode 100644 index 0000000..57ee7d0 --- /dev/null +++ b/.history/src/App_20200224172639.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage=} /> + this.editor.current.set('crop')} croppingImage={croppingImage}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172641.js b/.history/src/App_20200224172641.js new file mode 100644 index 0000000..2c92afe --- /dev/null +++ b/.history/src/App_20200224172641.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={x} /> + this.editor.current.set('crop')} croppingImage={croppingImage}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172643.js b/.history/src/App_20200224172643.js new file mode 100644 index 0000000..ccb0b9c --- /dev/null +++ b/.history/src/App_20200224172643.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} /> + this.editor.current.set('crop')} croppingImage={croppingImage}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172735.js b/.history/src/App_20200224172735.js new file mode 100644 index 0000000..f9586bc --- /dev/null +++ b/.history/src/App_20200224172735.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} cropper/> + this.editor.current.set('crop')} croppingImage={croppingImage}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172741.js b/.history/src/App_20200224172741.js new file mode 100644 index 0000000..9504989 --- /dev/null +++ b/.history/src/App_20200224172741.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} cropper ={true}/> + this.editor.current.set('crop')} croppingImage={croppingImage}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224172745.js b/.history/src/App_20200224172745.js new file mode 100644 index 0000000..653c182 --- /dev/null +++ b/.history/src/App_20200224172745.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} cropper ={true}/> + this.editor.current.set('crop')} croppingImage={croppingImage} cropper ={true}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173011.js b/.history/src/App_20200224173011.js new file mode 100644 index 0000000..c516c5a --- /dev/null +++ b/.history/src/App_20200224173011.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} toggleCropper ={true}/> + this.editor.current.set('crop')} croppingImage={croppingImage} toggleCropper ={true}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173013.js b/.history/src/App_20200224173013.js new file mode 100644 index 0000000..e726ae8 --- /dev/null +++ b/.history/src/App_20200224173013.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} croppingImage={croppingImage} toggleCropper ={true}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173017.js b/.history/src/App_20200224173017.js new file mode 100644 index 0000000..92584cb --- /dev/null +++ b/.history/src/App_20200224173017.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} croppingImage={croppingImage} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173021.js b/.history/src/App_20200224173021.js new file mode 100644 index 0000000..d712acf --- /dev/null +++ b/.history/src/App_20200224173021.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} croppingImage={croppingImage} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173024.js b/.history/src/App_20200224173024.js new file mode 100644 index 0000000..d46cdd5 --- /dev/null +++ b/.history/src/App_20200224173024.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173028.js b/.history/src/App_20200224173028.js new file mode 100644 index 0000000..8524dc6 --- /dev/null +++ b/.history/src/App_20200224173028.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173125.js b/.history/src/App_20200224173125.js new file mode 100644 index 0000000..5aa497a --- /dev/null +++ b/.history/src/App_20200224173125.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173239.js b/.history/src/App_20200224173239.js new file mode 100644 index 0000000..b3b797f --- /dev/null +++ b/.history/src/App_20200224173239.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173241.js b/.history/src/App_20200224173241.js new file mode 100644 index 0000000..31caf1c --- /dev/null +++ b/.history/src/App_20200224173241.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + returncroppingImage + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173243.js b/.history/src/App_20200224173243.js new file mode 100644 index 0000000..01d0178 --- /dev/null +++ b/.history/src/App_20200224173243.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return croppingImage + } + else { + this.setState({ croppingImage: true }) + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173245.js b/.history/src/App_20200224173245.js new file mode 100644 index 0000000..cb84eb6 --- /dev/null +++ b/.history/src/App_20200224173245.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return croppingImage + } + else { + this.setState({ croppingImage: true }) + return croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173253.js b/.history/src/App_20200224173253.js new file mode 100644 index 0000000..d4c8a4f --- /dev/null +++ b/.history/src/App_20200224173253.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.state/croppingImage + } + else { + this.setState({ croppingImage: true }) + return croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173254.js b/.history/src/App_20200224173254.js new file mode 100644 index 0000000..0141d6c --- /dev/null +++ b/.history/src/App_20200224173254.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.state.croppingImage + } + else { + this.setState({ croppingImage: true }) + return croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173258.js b/.history/src/App_20200224173258.js new file mode 100644 index 0000000..13412ae --- /dev/null +++ b/.history/src/App_20200224173258.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.state.croppingImage + } + else { + this.setState({ croppingImage: true }) + return this.state.croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173400.js b/.history/src/App_20200224173400.js new file mode 100644 index 0000000..0c086c9 --- /dev/null +++ b/.history/src/App_20200224173400.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + return this.state.croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173405.js b/.history/src/App_20200224173405.js new file mode 100644 index 0000000..58766c8 --- /dev/null +++ b/.history/src/App_20200224173405.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + return this.state.croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173407.js b/.history/src/App_20200224173407.js new file mode 100644 index 0000000..0c086c9 --- /dev/null +++ b/.history/src/App_20200224173407.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + return this.state.croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173413.js b/.history/src/App_20200224173413.js new file mode 100644 index 0000000..202d262 --- /dev/null +++ b/.history/src/App_20200224173413.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + return this.state.croppingImage + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173427.js b/.history/src/App_20200224173427.js new file mode 100644 index 0000000..a9f53f8 --- /dev/null +++ b/.history/src/App_20200224173427.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + event={() => this.editor.current.applyCropping()} + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173431.js b/.history/src/App_20200224173431.js new file mode 100644 index 0000000..11f7392 --- /dev/null +++ b/.history/src/App_20200224173431.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + this.editor.current.applyCropping() + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173450.js b/.history/src/App_20200224173450.js new file mode 100644 index 0000000..052d578 --- /dev/null +++ b/.history/src/App_20200224173450.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173451.js b/.history/src/App_20200224173451.js new file mode 100644 index 0000000..7291778 --- /dev/null +++ b/.history/src/App_20200224173451.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173456.js b/.history/src/App_20200224173456.js new file mode 100644 index 0000000..d325936 --- /dev/null +++ b/.history/src/App_20200224173456.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + } toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173458.js b/.history/src/App_20200224173458.js new file mode 100644 index 0000000..e797918 --- /dev/null +++ b/.history/src/App_20200224173458.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173503.js b/.history/src/App_20200224173503.js new file mode 100644 index 0000000..798f01f --- /dev/null +++ b/.history/src/App_20200224173503.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + this.editor.current.set('crop') + + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173506.js b/.history/src/App_20200224173506.js new file mode 100644 index 0000000..0df9c9d --- /dev/null +++ b/.history/src/App_20200224173506.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + this.editor.current.set('crop') + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173945.js b/.history/src/App_20200224173945.js new file mode 100644 index 0000000..9b7023d --- /dev/null +++ b/.history/src/App_20200224173945.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224173951.js b/.history/src/App_20200224173951.js new file mode 100644 index 0000000..84e792f --- /dev/null +++ b/.history/src/App_20200224173951.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + } + else { + this.setState({ croppingImage: true }) + this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174308.js b/.history/src/App_20200224174308.js new file mode 100644 index 0000000..b1bf03c --- /dev/null +++ b/.history/src/App_20200224174308.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + this.editor.current.applyCropping() + + } + else { + this.setState({ croppingImage: true }) + this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174312.js b/.history/src/App_20200224174312.js new file mode 100644 index 0000000..ecd628c --- /dev/null +++ b/.history/src/App_20200224174312.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping() + + } + else { + this.setState({ croppingImage: true }) + this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174315.js b/.history/src/App_20200224174315.js new file mode 100644 index 0000000..d304374 --- /dev/null +++ b/.history/src/App_20200224174315.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping() + + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174421.js b/.history/src/App_20200224174421.js new file mode 100644 index 0000000..5c74131 --- /dev/null +++ b/.history/src/App_20200224174421.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping() + + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174424.js b/.history/src/App_20200224174424.js new file mode 100644 index 0000000..0bb2a32 --- /dev/null +++ b/.history/src/App_20200224174424.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping() + + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174427.js b/.history/src/App_20200224174427.js new file mode 100644 index 0000000..de01f71 --- /dev/null +++ b/.history/src/App_20200224174427.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + return this.editor.current.applyCropping() + + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174433.js b/.history/src/App_20200224174433.js new file mode 100644 index 0000000..7a12efa --- /dev/null +++ b/.history/src/App_20200224174433.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174434.js b/.history/src/App_20200224174434.js new file mode 100644 index 0000000..a39f110 --- /dev/null +++ b/.history/src/App_20200224174434.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + return this.editor.current.set('crop') + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174436.js b/.history/src/App_20200224174436.js new file mode 100644 index 0000000..44f1f4d --- /dev/null +++ b/.history/src/App_20200224174436.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174441.js b/.history/src/App_20200224174441.js new file mode 100644 index 0000000..1c95d9c --- /dev/null +++ b/.history/src/App_20200224174441.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174444.js b/.history/src/App_20200224174444.js new file mode 100644 index 0000000..4133e46 --- /dev/null +++ b/.history/src/App_20200224174444.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + } toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174448.js b/.history/src/App_20200224174448.js new file mode 100644 index 0000000..ec733af --- /dev/null +++ b/.history/src/App_20200224174448.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + return this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174450.js b/.history/src/App_20200224174450.js new file mode 100644 index 0000000..3ffa7fb --- /dev/null +++ b/.history/src/App_20200224174450.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174854.js b/.history/src/App_20200224174854.js new file mode 100644 index 0000000..105e4ce --- /dev/null +++ b/.history/src/App_20200224174854.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: false }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174857.js b/.history/src/App_20200224174857.js new file mode 100644 index 0000000..2e5bf4d --- /dev/null +++ b/.history/src/App_20200224174857.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: prop }) + } + else { + this.setState({ croppingImage: true }) + + } + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174859.js b/.history/src/App_20200224174859.js new file mode 100644 index 0000000..04335d7 --- /dev/null +++ b/.history/src/App_20200224174859.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: prop }) + } + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174900.js b/.history/src/App_20200224174900.js new file mode 100644 index 0000000..6443d31 --- /dev/null +++ b/.history/src/App_20200224174900.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac") + if (this.state.croppingImage) { + this.setState({ croppingImage: prop }) + + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174902.js b/.history/src/App_20200224174902.js new file mode 100644 index 0000000..5da454a --- /dev/null +++ b/.history/src/App_20200224174902.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac") + this.setState({ croppingImage: prop }) + + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174904.js b/.history/src/App_20200224174904.js new file mode 100644 index 0000000..5951bde --- /dev/null +++ b/.history/src/App_20200224174904.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac".prop) + this.setState({ croppingImage: prop }) + + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper ={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper ={this.toggleCropper}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174907.js b/.history/src/App_20200224174907.js new file mode 100644 index 0000000..2c8f087 --- /dev/null +++ b/.history/src/App_20200224174907.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174910.js b/.history/src/App_20200224174910.js new file mode 100644 index 0000000..3c34ea3 --- /dev/null +++ b/.history/src/App_20200224174910.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174952.js b/.history/src/App_20200224174952.js new file mode 100644 index 0000000..9952bfd --- /dev/null +++ b/.history/src/App_20200224174952.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174954.js b/.history/src/App_20200224174954.js new file mode 100644 index 0000000..c21d222 --- /dev/null +++ b/.history/src/App_20200224174954.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224174956.js b/.history/src/App_20200224174956.js new file mode 100644 index 0000000..ae1110f --- /dev/null +++ b/.history/src/App_20200224174956.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175003.js b/.history/src/App_20200224175003.js new file mode 100644 index 0000000..d84475e --- /dev/null +++ b/.history/src/App_20200224175003.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175030.js b/.history/src/App_20200224175030.js new file mode 100644 index 0000000..32bdf1a --- /dev/null +++ b/.history/src/App_20200224175030.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false}/> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175055.js b/.history/src/App_20200224175055.js new file mode 100644 index 0000000..be2b248 --- /dev/null +++ b/.history/src/App_20200224175055.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175057.js b/.history/src/App_20200224175057.js new file mode 100644 index 0000000..13ca54c --- /dev/null +++ b/.history/src/App_20200224175057.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175110.js b/.history/src/App_20200224175110.js new file mode 100644 index 0000000..dd2469e --- /dev/null +++ b/.history/src/App_20200224175110.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={() => this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175112.js b/.history/src/App_20200224175112.js new file mode 100644 index 0000000..c61afb0 --- /dev/null +++ b/.history/src/App_20200224175112.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={() => this.toggleCropper()} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175116.js b/.history/src/App_20200224175116.js new file mode 100644 index 0000000..1c592a4 --- /dev/null +++ b/.history/src/App_20200224175116.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={(true) => this.toggleCropper()} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175121.js b/.history/src/App_20200224175121.js new file mode 100644 index 0000000..63eb3de --- /dev/null +++ b/.history/src/App_20200224175121.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={(true) => this.toggleCropper(true)} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175127.js b/.history/src/App_20200224175127.js new file mode 100644 index 0000000..dd2469e --- /dev/null +++ b/.history/src/App_20200224175127.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={() => this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175130.js b/.history/src/App_20200224175130.js new file mode 100644 index 0000000..ab42953 --- /dev/null +++ b/.history/src/App_20200224175130.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={(true) => this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175139.js b/.history/src/App_20200224175139.js new file mode 100644 index 0000000..13ca54c --- /dev/null +++ b/.history/src/App_20200224175139.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175140.js b/.history/src/App_20200224175140.js new file mode 100644 index 0000000..13ca54c --- /dev/null +++ b/.history/src/App_20200224175140.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} + + + +export default App; diff --git a/.history/src/App_20200224175434.js b/.history/src/App_20200224175434.js new file mode 100644 index 0000000..28edd4d --- /dev/null +++ b/.history/src/App_20200224175434.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175448.js b/.history/src/App_20200224175448.js new file mode 100644 index 0000000..25663d7 --- /dev/null +++ b/.history/src/App_20200224175448.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} display: 'block'/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175449.js b/.history/src/App_20200224175449.js new file mode 100644 index 0000000..28edd4d --- /dev/null +++ b/.history/src/App_20200224175449.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175502.js b/.history/src/App_20200224175502.js new file mode 100644 index 0000000..5155742 --- /dev/null +++ b/.history/src/App_20200224175502.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={(props.color) ? { backgroundColor: props.color } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175509.js b/.history/src/App_20200224175509.js new file mode 100644 index 0000000..266c165 --- /dev/null +++ b/.history/src/App_20200224175509.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={) ? { backgroundColor: props.color } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175515.js b/.history/src/App_20200224175515.js new file mode 100644 index 0000000..ba29d0c --- /dev/null +++ b/.history/src/App_20200224175515.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.cro ? { backgroundColor: props.color } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175517.js b/.history/src/App_20200224175517.js new file mode 100644 index 0000000..96349cc --- /dev/null +++ b/.history/src/App_20200224175517.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? { backgroundColor: props.color } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175522.js b/.history/src/App_20200224175522.js new file mode 100644 index 0000000..38bf3c1 --- /dev/null +++ b/.history/src/App_20200224175522.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? { di } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175525.js b/.history/src/App_20200224175525.js new file mode 100644 index 0000000..1099bd8 --- /dev/null +++ b/.history/src/App_20200224175525.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175527.js b/.history/src/App_20200224175527.js new file mode 100644 index 0000000..89443e6 --- /dev/null +++ b/.history/src/App_20200224175527.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} } : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175528.js b/.history/src/App_20200224175528.js new file mode 100644 index 0000000..0563118 --- /dev/null +++ b/.history/src/App_20200224175528.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175531.js b/.history/src/App_20200224175531.js new file mode 100644 index 0000000..13817b9 --- /dev/null +++ b/.history/src/App_20200224175531.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {displ}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175534.js b/.history/src/App_20200224175534.js new file mode 100644 index 0000000..6153cd8 --- /dev/null +++ b/.history/src/App_20200224175534.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {display: "none"}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175545.js b/.history/src/App_20200224175545.js new file mode 100644 index 0000000..309044d --- /dev/null +++ b/.history/src/App_20200224175545.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {display: "none"}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} style={this.state.croppingImage ? {} : {display: "none"}}/> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175612.js b/.history/src/App_20200224175612.js new file mode 100644 index 0000000..7786682 --- /dev/null +++ b/.history/src/App_20200224175612.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {display: "none"}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} style={this.state.croppingImage ? {} :}/> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175613.js b/.history/src/App_20200224175613.js new file mode 100644 index 0000000..9e31613 --- /dev/null +++ b/.history/src/App_20200224175613.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {display: "none"}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} style={this.state.croppingImage ? {display: "none"} :}/> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175614.js b/.history/src/App_20200224175614.js new file mode 100644 index 0000000..1347707 --- /dev/null +++ b/.history/src/App_20200224175614.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {display: "none"}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} style={this.state.croppingImage ? {display: "none"} : {}}/> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175625.js b/.history/src/App_20200224175625.js new file mode 100644 index 0000000..6153cd8 --- /dev/null +++ b/.history/src/App_20200224175625.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} style={this.state.croppingImage ? {} : {display: "none"}}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175629.js b/.history/src/App_20200224175629.js new file mode 100644 index 0000000..378b270 --- /dev/null +++ b/.history/src/App_20200224175629.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175630.js b/.history/src/App_20200224175630.js new file mode 100644 index 0000000..06dc181 --- /dev/null +++ b/.history/src/App_20200224175630.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175632.js b/.history/src/App_20200224175632.js new file mode 100644 index 0000000..52147b0 --- /dev/null +++ b/.history/src/App_20200224175632.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {if} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175710.js b/.history/src/App_20200224175710.js new file mode 100644 index 0000000..cc6467e --- /dev/null +++ b/.history/src/App_20200224175710.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175713.js b/.history/src/App_20200224175713.js new file mode 100644 index 0000000..7a48c7f --- /dev/null +++ b/.history/src/App_20200224175713.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175728.js b/.history/src/App_20200224175728.js new file mode 100644 index 0000000..bf0b631 --- /dev/null +++ b/.history/src/App_20200224175728.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const isLoggedIn = this.state.isLoggedIn; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175732.js b/.history/src/App_20200224175732.js new file mode 100644 index 0000000..16c6425 --- /dev/null +++ b/.history/src/App_20200224175732.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state.isLoggedIn; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175733.js b/.history/src/App_20200224175733.js new file mode 100644 index 0000000..6a34a2e --- /dev/null +++ b/.history/src/App_20200224175733.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state. + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175735.js b/.history/src/App_20200224175735.js new file mode 100644 index 0000000..c87c28b --- /dev/null +++ b/.history/src/App_20200224175735.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175736.js b/.history/src/App_20200224175736.js new file mode 100644 index 0000000..a2b4309 --- /dev/null +++ b/.history/src/App_20200224175736.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {isLoggedIn ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175740.js b/.history/src/App_20200224175740.js new file mode 100644 index 0000000..16f333e --- /dev/null +++ b/.history/src/App_20200224175740.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + { const croppingImage = this.state; + ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175743.js b/.history/src/App_20200224175743.js new file mode 100644 index 0000000..16f333e --- /dev/null +++ b/.history/src/App_20200224175743.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + { const croppingImage = this.state; + ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175744.js b/.history/src/App_20200224175744.js new file mode 100644 index 0000000..581c4bf --- /dev/null +++ b/.history/src/App_20200224175744.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + { croppingImage = this.state; + ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175746.js b/.history/src/App_20200224175746.js new file mode 100644 index 0000000..2051153 --- /dev/null +++ b/.history/src/App_20200224175746.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + { croppingImage + ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175749.js b/.history/src/App_20200224175749.js new file mode 100644 index 0000000..9f6b4d1 --- /dev/null +++ b/.history/src/App_20200224175749.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage + ? ( + + ) : ( + + )} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175754.js b/.history/src/App_20200224175754.js new file mode 100644 index 0000000..ff45bce --- /dev/null +++ b/.history/src/App_20200224175754.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage + ? ( + + ) : ( + + )} + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175756.js b/.history/src/App_20200224175756.js new file mode 100644 index 0000000..910214d --- /dev/null +++ b/.history/src/App_20200224175756.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage + ? ( + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + ) : ( + + )} + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175758.js b/.history/src/App_20200224175758.js new file mode 100644 index 0000000..aa40153 --- /dev/null +++ b/.history/src/App_20200224175758.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage + ? ( + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + ) : ( + + )} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175759.js b/.history/src/App_20200224175759.js new file mode 100644 index 0000000..95b5780 --- /dev/null +++ b/.history/src/App_20200224175759.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage + ? ( + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + ) : ( + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + )} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175811.js b/.history/src/App_20200224175811.js new file mode 100644 index 0000000..0f2ec0e --- /dev/null +++ b/.history/src/App_20200224175811.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {!croppingImage + ? ( + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + ) : ( + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + )} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175843.js b/.history/src/App_20200224175843.js new file mode 100644 index 0000000..da7df4d --- /dev/null +++ b/.history/src/App_20200224175843.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175845.js b/.history/src/App_20200224175845.js new file mode 100644 index 0000000..0f2ec0e --- /dev/null +++ b/.history/src/App_20200224175845.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {!croppingImage + ? ( + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + ) : ( + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + )} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175943.js b/.history/src/App_20200224175943.js new file mode 100644 index 0000000..202d1c8 --- /dev/null +++ b/.history/src/App_20200224175943.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {!croppingImage + ? ( + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175944.js b/.history/src/App_20200224175944.js new file mode 100644 index 0000000..1b36571 --- /dev/null +++ b/.history/src/App_20200224175944.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224175947.js b/.history/src/App_20200224175947.js new file mode 100644 index 0000000..b335d4f --- /dev/null +++ b/.history/src/App_20200224175947.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180019.js b/.history/src/App_20200224180019.js new file mode 100644 index 0000000..485ea42 --- /dev/null +++ b/.history/src/App_20200224180019.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + return croppingImage + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180112.js b/.history/src/App_20200224180112.js new file mode 100644 index 0000000..b05964d --- /dev/null +++ b/.history/src/App_20200224180112.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + return this.setcroppingImage + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180113.js b/.history/src/App_20200224180113.js new file mode 100644 index 0000000..a3256f8 --- /dev/null +++ b/.history/src/App_20200224180113.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + return this.setState.croppingImage + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180121.js b/.history/src/App_20200224180121.js new file mode 100644 index 0000000..a1a02cd --- /dev/null +++ b/.history/src/App_20200224180121.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + return this.state.croppingImage + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180242.js b/.history/src/App_20200224180242.js new file mode 100644 index 0000000..b335d4f --- /dev/null +++ b/.history/src/App_20200224180242.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180247.js b/.history/src/App_20200224180247.js new file mode 100644 index 0000000..d3cb41d --- /dev/null +++ b/.history/src/App_20200224180247.js @@ -0,0 +1,54 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180756.js b/.history/src/App_20200224180756.js new file mode 100644 index 0000000..2f46dc7 --- /dev/null +++ b/.history/src/App_20200224180756.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180801.js b/.history/src/App_20200224180801.js new file mode 100644 index 0000000..046ebb6 --- /dev/null +++ b/.history/src/App_20200224180801.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? } + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180809.js b/.history/src/App_20200224180809.js new file mode 100644 index 0000000..a4fc5f9 --- /dev/null +++ b/.history/src/App_20200224180809.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} />} + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180811.js b/.history/src/App_20200224180811.js new file mode 100644 index 0000000..2bdcf4d --- /dev/null +++ b/.history/src/App_20200224180811.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : } + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180814.js b/.history/src/App_20200224180814.js new file mode 100644 index 0000000..a0d463e --- /dev/null +++ b/.history/src/App_20200224180814.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180815.js b/.history/src/App_20200224180815.js new file mode 100644 index 0000000..1ca9339 --- /dev/null +++ b/.history/src/App_20200224180815.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180911.js b/.history/src/App_20200224180911.js new file mode 100644 index 0000000..1a530aa --- /dev/null +++ b/.history/src/App_20200224180911.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180913.js b/.history/src/App_20200224180913.js new file mode 100644 index 0000000..73daa8e --- /dev/null +++ b/.history/src/App_20200224180913.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180917.js b/.history/src/App_20200224180917.js new file mode 100644 index 0000000..1f8acd2 --- /dev/null +++ b/.history/src/App_20200224180917.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224180919.js b/.history/src/App_20200224180919.js new file mode 100644 index 0000000..08e34e8 --- /dev/null +++ b/.history/src/App_20200224180919.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181032.js b/.history/src/App_20200224181032.js new file mode 100644 index 0000000..95eeb33 --- /dev/null +++ b/.history/src/App_20200224181032.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181052.js b/.history/src/App_20200224181052.js new file mode 100644 index 0000000..eadb1fc --- /dev/null +++ b/.history/src/App_20200224181052.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181055.js b/.history/src/App_20200224181055.js new file mode 100644 index 0000000..62387e5 --- /dev/null +++ b/.history/src/App_20200224181055.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={false} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181107.js b/.history/src/App_20200224181107.js new file mode 100644 index 0000000..da23dc9 --- /dev/null +++ b/.history/src/App_20200224181107.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={false} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181114.js b/.history/src/App_20200224181114.js new file mode 100644 index 0000000..4a6d385 --- /dev/null +++ b/.history/src/App_20200224181114.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={false} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181116.js b/.history/src/App_20200224181116.js new file mode 100644 index 0000000..4a6941f --- /dev/null +++ b/.history/src/App_20200224181116.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181122.js b/.history/src/App_20200224181122.js new file mode 100644 index 0000000..8a23fd2 --- /dev/null +++ b/.history/src/App_20200224181122.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropo} + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181124.js b/.history/src/App_20200224181124.js new file mode 100644 index 0000000..cfe1a04 --- /dev/null +++ b/.history/src/App_20200224181124.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage} + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181136.js b/.history/src/App_20200224181136.js new file mode 100644 index 0000000..e540cd7 --- /dev/null +++ b/.history/src/App_20200224181136.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181519.js b/.history/src/App_20200224181519.js new file mode 100644 index 0000000..4dfbdcb --- /dev/null +++ b/.history/src/App_20200224181519.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + com + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181524.js b/.history/src/App_20200224181524.js new file mode 100644 index 0000000..4926e60 --- /dev/null +++ b/.history/src/App_20200224181524.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + componentDidUpdate() + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181529.js b/.history/src/App_20200224181529.js new file mode 100644 index 0000000..8d54164 --- /dev/null +++ b/.history/src/App_20200224181529.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + componentDidUpdate(){ + console.log("A") + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181549.js b/.history/src/App_20200224181549.js new file mode 100644 index 0000000..e540cd7 --- /dev/null +++ b/.history/src/App_20200224181549.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + this.forceUpdate() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181552.js b/.history/src/App_20200224181552.js new file mode 100644 index 0000000..3686538 --- /dev/null +++ b/.history/src/App_20200224181552.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + {croppingImage ? this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181602.js b/.history/src/App_20200224181602.js new file mode 100644 index 0000000..c19ee23 --- /dev/null +++ b/.history/src/App_20200224181602.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + : this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181605.js b/.history/src/App_20200224181605.js new file mode 100644 index 0000000..038d965 --- /dev/null +++ b/.history/src/App_20200224181605.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181616.js b/.history/src/App_20200224181616.js new file mode 100644 index 0000000..e3e09ce --- /dev/null +++ b/.history/src/App_20200224181616.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181619.js b/.history/src/App_20200224181619.js new file mode 100644 index 0000000..cf9251f --- /dev/null +++ b/.history/src/App_20200224181619.js @@ -0,0 +1,54 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181621.js b/.history/src/App_20200224181621.js new file mode 100644 index 0000000..cb1d782 --- /dev/null +++ b/.history/src/App_20200224181621.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + console.log("mtac", prop) + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181706.js b/.history/src/App_20200224181706.js new file mode 100644 index 0000000..e8b9a8a --- /dev/null +++ b/.history/src/App_20200224181706.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181711.js b/.history/src/App_20200224181711.js new file mode 100644 index 0000000..e748cf4 --- /dev/null +++ b/.history/src/App_20200224181711.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + return this.toggleCropper + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181715.js b/.history/src/App_20200224181715.js new file mode 100644 index 0000000..c967fc3 --- /dev/null +++ b/.history/src/App_20200224181715.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + return this.toggleCropper() + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181716.js b/.history/src/App_20200224181716.js new file mode 100644 index 0000000..3d891da --- /dev/null +++ b/.history/src/App_20200224181716.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + return this.toggleCropper(prop) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181728.js b/.history/src/App_20200224181728.js new file mode 100644 index 0000000..e9f36ac --- /dev/null +++ b/.history/src/App_20200224181728.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + return this.toggleCropper(this.state.) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181729.js b/.history/src/App_20200224181729.js new file mode 100644 index 0000000..6df4d54 --- /dev/null +++ b/.history/src/App_20200224181729.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + return this.toggleCropper(this.state.croppingImage) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181740.js b/.history/src/App_20200224181740.js new file mode 100644 index 0000000..92ca54c --- /dev/null +++ b/.history/src/App_20200224181740.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + toggleCropper(this.state.croppingImage) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181743.js b/.history/src/App_20200224181743.js new file mode 100644 index 0000000..fba1d22 --- /dev/null +++ b/.history/src/App_20200224181743.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + this.toggleCropper(this.state.croppingImage) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224181750.js b/.history/src/App_20200224181750.js new file mode 100644 index 0000000..f1cdcb4 --- /dev/null +++ b/.history/src/App_20200224181750.js @@ -0,0 +1,52 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182319.js b/.history/src/App_20200224182319.js new file mode 100644 index 0000000..2de0358 --- /dev/null +++ b/.history/src/App_20200224182319.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {crop} + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182321.js b/.history/src/App_20200224182321.js new file mode 100644 index 0000000..ddf87ee --- /dev/null +++ b/.history/src/App_20200224182321.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? } + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182325.js b/.history/src/App_20200224182325.js new file mode 100644 index 0000000..d1a437a --- /dev/null +++ b/.history/src/App_20200224182325.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? } + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182327.js b/.history/src/App_20200224182327.js new file mode 100644 index 0000000..cb4cf0a --- /dev/null +++ b/.history/src/App_20200224182327.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> :} + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182331.js b/.history/src/App_20200224182331.js new file mode 100644 index 0000000..ba4170a --- /dev/null +++ b/.history/src/App_20200224182331.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> :} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182336.js b/.history/src/App_20200224182336.js new file mode 100644 index 0000000..ec20408 --- /dev/null +++ b/.history/src/App_20200224182336.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182338.js b/.history/src/App_20200224182338.js new file mode 100644 index 0000000..0c0b080 --- /dev/null +++ b/.history/src/App_20200224182338.js @@ -0,0 +1,54 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182340.js b/.history/src/App_20200224182340.js new file mode 100644 index 0000000..ee19b73 --- /dev/null +++ b/.history/src/App_20200224182340.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182341.js b/.history/src/App_20200224182341.js new file mode 100644 index 0000000..0ad49b1 --- /dev/null +++ b/.history/src/App_20200224182341.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + < Tool iconClassName="far fa-check-circle fa-lg" event={() => this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182343.js b/.history/src/App_20200224182343.js new file mode 100644 index 0000000..e9e0a55 --- /dev/null +++ b/.history/src/App_20200224182343.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182344.js b/.history/src/App_20200224182344.js new file mode 100644 index 0000000..e9e0a55 --- /dev/null +++ b/.history/src/App_20200224182344.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: prop }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182400.js b/.history/src/App_20200224182400.js new file mode 100644 index 0000000..3de643f --- /dev/null +++ b/.history/src/App_20200224182400.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182401.js b/.history/src/App_20200224182401.js new file mode 100644 index 0000000..8503f42 --- /dev/null +++ b/.history/src/App_20200224182401.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => {\ + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182403.js b/.history/src/App_20200224182403.js new file mode 100644 index 0000000..3de643f --- /dev/null +++ b/.history/src/App_20200224182403.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182406.js b/.history/src/App_20200224182406.js new file mode 100644 index 0000000..3de643f --- /dev/null +++ b/.history/src/App_20200224182406.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} />} + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182429.js b/.history/src/App_20200224182429.js new file mode 100644 index 0000000..d330259 --- /dev/null +++ b/.history/src/App_20200224182429.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : } + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182431.js b/.history/src/App_20200224182431.js new file mode 100644 index 0000000..2ddc87f --- /dev/null +++ b/.history/src/App_20200224182431.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + : } + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182434.js b/.history/src/App_20200224182434.js new file mode 100644 index 0000000..99790b6 --- /dev/null +++ b/.history/src/App_20200224182434.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182435.js b/.history/src/App_20200224182435.js new file mode 100644 index 0000000..1b98201 --- /dev/null +++ b/.history/src/App_20200224182435.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182455.js b/.history/src/App_20200224182455.js new file mode 100644 index 0000000..aa61b2c --- /dev/null +++ b/.history/src/App_20200224182455.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + slertt + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182501.js b/.history/src/App_20200224182501.js new file mode 100644 index 0000000..776aa3c --- /dev/null +++ b/.history/src/App_20200224182501.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import { findAllByPlaceholderText } from '@testing-library/react'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + findAllByPlaceholderText('sfsf' + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182505.js b/.history/src/App_20200224182505.js new file mode 100644 index 0000000..d6e7b0a --- /dev/null +++ b/.history/src/App_20200224182505.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + alllert + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182508.js b/.history/src/App_20200224182508.js new file mode 100644 index 0000000..e256fe8 --- /dev/null +++ b/.history/src/App_20200224182508.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + // alllert + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182747.js b/.history/src/App_20200224182747.js new file mode 100644 index 0000000..c7db288 --- /dev/null +++ b/.history/src/App_20200224182747.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }) + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182752.js b/.history/src/App_20200224182752.js new file mode 100644 index 0000000..2f41eb7 --- /dev/null +++ b/.history/src/App_20200224182752.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182821.js b/.history/src/App_20200224182821.js new file mode 100644 index 0000000..94bad78 --- /dev/null +++ b/.history/src/App_20200224182821.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182824.js b/.history/src/App_20200224182824.js new file mode 100644 index 0000000..f3592ef --- /dev/null +++ b/.history/src/App_20200224182824.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224182906.js b/.history/src/App_20200224182906.js new file mode 100644 index 0000000..82f863c --- /dev/null +++ b/.history/src/App_20200224182906.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224183010.js b/.history/src/App_20200224183010.js new file mode 100644 index 0000000..c2c7e50 --- /dev/null +++ b/.history/src/App_20200224183010.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={true} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224183013.js b/.history/src/App_20200224183013.js new file mode 100644 index 0000000..14958df --- /dev/null +++ b/.history/src/App_20200224183013.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={true} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={false} /> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200224183020.js b/.history/src/App_20200224183020.js new file mode 100644 index 0000000..82f863c --- /dev/null +++ b/.history/src/App_20200224183020.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} crop={false} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225125948.js b/.history/src/App_20200225125948.js new file mode 100644 index 0000000..fadaf7c --- /dev/null +++ b/.history/src/App_20200225125948.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} crop={true} /> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225125950.js b/.history/src/App_20200225125950.js new file mode 100644 index 0000000..58fd1f1 --- /dev/null +++ b/.history/src/App_20200225125950.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + console.log('sdfsadf'); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225125952.js b/.history/src/App_20200225125952.js new file mode 100644 index 0000000..8e3e7e2 --- /dev/null +++ b/.history/src/App_20200225125952.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState({ croppingImage: true }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225125954.js b/.history/src/App_20200225125954.js new file mode 100644 index 0000000..c97bc18 --- /dev/null +++ b/.history/src/App_20200225125954.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225125958.js b/.history/src/App_20200225125958.js new file mode 100644 index 0000000..b8d8758 --- /dev/null +++ b/.history/src/App_20200225125958.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130002.js b/.history/src/App_20200225130002.js new file mode 100644 index 0000000..8c1340c --- /dev/null +++ b/.history/src/App_20200225130002.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + pre + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130004.js b/.history/src/App_20200225130004.js new file mode 100644 index 0000000..b8d8758 --- /dev/null +++ b/.history/src/App_20200225130004.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130007.js b/.history/src/App_20200225130007.js new file mode 100644 index 0000000..e1646d3 --- /dev/null +++ b/.history/src/App_20200225130007.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + croppingImage + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130010.js b/.history/src/App_20200225130010.js new file mode 100644 index 0000000..3631733 --- /dev/null +++ b/.history/src/App_20200225130010.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + croppingImage: !prev.co + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130012.js b/.history/src/App_20200225130012.js new file mode 100644 index 0000000..ca5ffa9 --- /dev/null +++ b/.history/src/App_20200225130012.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + croppingImage: !prev.croppingImage + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130021.js b/.history/src/App_20200225130021.js new file mode 100644 index 0000000..20e4976 --- /dev/null +++ b/.history/src/App_20200225130021.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + croppingImage = !prev.croppingImage + }); + + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130036.js b/.history/src/App_20200225130036.js new file mode 100644 index 0000000..ec04657 --- /dev/null +++ b/.history/src/App_20200225130036.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + croppingImage = !prev.croppingImage + }); + console.log(this.state.croppingImage) + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130038.js b/.history/src/App_20200225130038.js new file mode 100644 index 0000000..ff1fdd8 --- /dev/null +++ b/.history/src/App_20200225130038.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = (prop) => { + + this.setState(prev => { + croppingImage = !prev.croppingImage + }); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130039.js b/.history/src/App_20200225130039.js new file mode 100644 index 0000000..520b4de --- /dev/null +++ b/.history/src/App_20200225130039.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + + this.setState(prev => { + croppingImage = !prev.croppingImage + }); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130040.js b/.history/src/App_20200225130040.js new file mode 100644 index 0000000..21294d0 --- /dev/null +++ b/.history/src/App_20200225130040.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => { + croppingImage = !prev.croppingImage + }); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130251.js b/.history/src/App_20200225130251.js new file mode 100644 index 0000000..d05cc88 --- /dev/null +++ b/.history/src/App_20200225130251.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage = !prev.croppingImage + }); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130254.js b/.history/src/App_20200225130254.js new file mode 100644 index 0000000..67b8319 --- /dev/null +++ b/.history/src/App_20200225130254.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage = !prev.croppingImage + })); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130257.js b/.history/src/App_20200225130257.js new file mode 100644 index 0000000..f5c5130 --- /dev/null +++ b/.history/src/App_20200225130257.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130435.js b/.history/src/App_20200225130435.js new file mode 100644 index 0000000..bda062c --- /dev/null +++ b/.history/src/App_20200225130435.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130439.js b/.history/src/App_20200225130439.js new file mode 100644 index 0000000..07c62bb --- /dev/null +++ b/.history/src/App_20200225130439.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> : + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225130441.js b/.history/src/App_20200225130441.js new file mode 100644 index 0000000..cdcdda7 --- /dev/null +++ b/.history/src/App_20200225130441.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + console.log(this.state.croppingImage,"LL") + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225131221.js b/.history/src/App_20200225131221.js new file mode 100644 index 0000000..aeb6c6e --- /dev/null +++ b/.history/src/App_20200225131221.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225131319.js b/.history/src/App_20200225131319.js new file mode 100644 index 0000000..37b452b --- /dev/null +++ b/.history/src/App_20200225131319.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225131320.js b/.history/src/App_20200225131320.js new file mode 100644 index 0000000..65df79a --- /dev/null +++ b/.history/src/App_20200225131320.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225131321.js b/.history/src/App_20200225131321.js new file mode 100644 index 0000000..6fb14c3 --- /dev/null +++ b/.history/src/App_20200225131321.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134245.js b/.history/src/App_20200225134245.js new file mode 100644 index 0000000..660c975 --- /dev/null +++ b/.history/src/App_20200225134245.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134246.js b/.history/src/App_20200225134246.js new file mode 100644 index 0000000..739bea9 --- /dev/null +++ b/.history/src/App_20200225134246.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + // {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134248.js b/.history/src/App_20200225134248.js new file mode 100644 index 0000000..660c975 --- /dev/null +++ b/.history/src/App_20200225134248.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134252.js b/.history/src/App_20200225134252.js new file mode 100644 index 0000000..7bc86b7 --- /dev/null +++ b/.history/src/App_20200225134252.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134254.js b/.history/src/App_20200225134254.js new file mode 100644 index 0000000..ebd77b6 --- /dev/null +++ b/.history/src/App_20200225134254.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134257.js b/.history/src/App_20200225134257.js new file mode 100644 index 0000000..bbcbc8f --- /dev/null +++ b/.history/src/App_20200225134257.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + } + render() { + const {croppingImage} = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper}/> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134259.js b/.history/src/App_20200225134259.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225134259.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134400.js b/.history/src/App_20200225134400.js new file mode 100644 index 0000000..c8288a0 --- /dev/null +++ b/.history/src/App_20200225134400.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134403.js b/.history/src/App_20200225134403.js new file mode 100644 index 0000000..ce70ff5 --- /dev/null +++ b/.history/src/App_20200225134403.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225134407.js b/.history/src/App_20200225134407.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225134407.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135755.js b/.history/src/App_20200225135755.js new file mode 100644 index 0000000..02fd559 --- /dev/null +++ b/.history/src/App_20200225135755.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + if(croppingImage) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135801.js b/.history/src/App_20200225135801.js new file mode 100644 index 0000000..a5a6e2e --- /dev/null +++ b/.history/src/App_20200225135801.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135803.js b/.history/src/App_20200225135803.js new file mode 100644 index 0000000..ce58c96 --- /dev/null +++ b/.history/src/App_20200225135803.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(croppingImage){ + + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135808.js b/.history/src/App_20200225135808.js new file mode 100644 index 0000000..e789078 --- /dev/null +++ b/.history/src/App_20200225135808.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135815.js b/.history/src/App_20200225135815.js new file mode 100644 index 0000000..5c6e13b --- /dev/null +++ b/.history/src/App_20200225135815.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135816.js b/.history/src/App_20200225135816.js new file mode 100644 index 0000000..d8895ca --- /dev/null +++ b/.history/src/App_20200225135816.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state,croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135817.js b/.history/src/App_20200225135817.js new file mode 100644 index 0000000..a721c47 --- /dev/null +++ b/.history/src/App_20200225135817.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225135946.js b/.history/src/App_20200225135946.js new file mode 100644 index 0000000..2f3501b --- /dev/null +++ b/.history/src/App_20200225135946.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(!this.state.croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140005.js b/.history/src/App_20200225140005.js new file mode 100644 index 0000000..a721c47 --- /dev/null +++ b/.history/src/App_20200225140005.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state.croppingImage){ + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140013.js b/.history/src/App_20200225140013.js new file mode 100644 index 0000000..9151641 --- /dev/null +++ b/.history/src/App_20200225140013.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state.croppingImage){ + + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140014.js b/.history/src/App_20200225140014.js new file mode 100644 index 0000000..8e4e331 --- /dev/null +++ b/.history/src/App_20200225140014.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140018.js b/.history/src/App_20200225140018.js new file mode 100644 index 0000000..f2ebdd6 --- /dev/null +++ b/.history/src/App_20200225140018.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140042.js b/.history/src/App_20200225140042.js new file mode 100644 index 0000000..e2148e2 --- /dev/null +++ b/.history/src/App_20200225140042.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140046.js b/.history/src/App_20200225140046.js new file mode 100644 index 0000000..4f6fad5 --- /dev/null +++ b/.history/src/App_20200225140046.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140051.js b/.history/src/App_20200225140051.js new file mode 100644 index 0000000..41c573b --- /dev/null +++ b/.history/src/App_20200225140051.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state.) + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140054.js b/.history/src/App_20200225140054.js new file mode 100644 index 0000000..34009f8 --- /dev/null +++ b/.history/src/App_20200225140054.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state.croppingImage){ + + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140057.js b/.history/src/App_20200225140057.js new file mode 100644 index 0000000..54bea77 --- /dev/null +++ b/.history/src/App_20200225140057.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if(this.state.croppingImage){ + + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140058.js b/.history/src/App_20200225140058.js new file mode 100644 index 0000000..5801810 --- /dev/null +++ b/.history/src/App_20200225140058.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140059.js b/.history/src/App_20200225140059.js new file mode 100644 index 0000000..1726bc7 --- /dev/null +++ b/.history/src/App_20200225140059.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140118.js b/.history/src/App_20200225140118.js new file mode 100644 index 0000000..7239128 --- /dev/null +++ b/.history/src/App_20200225140118.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log(this.state.croppingImage) + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140132.js b/.history/src/App_20200225140132.js new file mode 100644 index 0000000..51ea415 --- /dev/null +++ b/.history/src/App_20200225140132.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log(this.state.croppingImage) + if (!this.state.croppingImage) { + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140252.js b/.history/src/App_20200225140252.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225140252.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140255.js b/.history/src/App_20200225140255.js new file mode 100644 index 0000000..51ea415 --- /dev/null +++ b/.history/src/App_20200225140255.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log(this.state.croppingImage) + if (!this.state.croppingImage) { + this.editor.current.applyCropping() + } + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140257.js b/.history/src/App_20200225140257.js new file mode 100644 index 0000000..3a5111f --- /dev/null +++ b/.history/src/App_20200225140257.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log(this.state.croppingImage) + + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140258.js b/.history/src/App_20200225140258.js new file mode 100644 index 0000000..f63dbde --- /dev/null +++ b/.history/src/App_20200225140258.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + console.log(this.state.croppingImage) + + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + if (!this.state.croppingImage) { + this.editor.current.applyCropping() + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140301.js b/.history/src/App_20200225140301.js new file mode 100644 index 0000000..a371cd8 --- /dev/null +++ b/.history/src/App_20200225140301.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + if (this.state.croppingImage) { + this.editor.current.applyCropping() + } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140325.js b/.history/src/App_20200225140325.js new file mode 100644 index 0000000..749452b --- /dev/null +++ b/.history/src/App_20200225140325.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + // if (this.state.croppingImage) { + // this.editor.current.applyCropping() + // } + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140517.js b/.history/src/App_20200225140517.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225140517.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140849.js b/.history/src/App_20200225140849.js new file mode 100644 index 0000000..af8daca --- /dev/null +++ b/.history/src/App_20200225140849.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + if(this.) + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140857.js b/.history/src/App_20200225140857.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225140857.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225140911.js b/.history/src/App_20200225140911.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225140911.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141034.js b/.history/src/App_20200225141034.js new file mode 100644 index 0000000..b17afd7 --- /dev/null +++ b/.history/src/App_20200225141034.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +import crop from 'react-image-markup/src/assets/js/crop'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + crop} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141042.js b/.history/src/App_20200225141042.js new file mode 100644 index 0000000..82db04e --- /dev/null +++ b/.history/src/App_20200225141042.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + this.editor.current.set('crop')} toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141046.js b/.history/src/App_20200225141046.js new file mode 100644 index 0000000..fe9ae1c --- /dev/null +++ b/.history/src/App_20200225141046.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + } toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141050.js b/.history/src/App_20200225141050.js new file mode 100644 index 0000000..6b1d70c --- /dev/null +++ b/.history/src/App_20200225141050.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop') + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + } toggleCropper={this.toggleCropper} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141056.js b/.history/src/App_20200225141056.js new file mode 100644 index 0000000..f5aad3a --- /dev/null +++ b/.history/src/App_20200225141056.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop') + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + } /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141111.js b/.history/src/App_20200225141111.js new file mode 100644 index 0000000..9016d7e --- /dev/null +++ b/.history/src/App_20200225141111.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop') + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141122.js b/.history/src/App_20200225141122.js new file mode 100644 index 0000000..87128b4 --- /dev/null +++ b/.history/src/App_20200225141122.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141127.js b/.history/src/App_20200225141127.js new file mode 100644 index 0000000..6f8b775 --- /dev/null +++ b/.history/src/App_20200225141127.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ + croppingImage: !prev.croppingImage + }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141129.js b/.history/src/App_20200225141129.js new file mode 100644 index 0000000..5afff93 --- /dev/null +++ b/.history/src/App_20200225141129.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: !prev.croppingImage + }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141133.js b/.history/src/App_20200225141133.js new file mode 100644 index 0000000..74bb247 --- /dev/null +++ b/.history/src/App_20200225141133.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true + }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141136.js b/.history/src/App_20200225141136.js new file mode 100644 index 0000000..6e4ef88 --- /dev/null +++ b/.history/src/App_20200225141136.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true } + }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141137.js b/.history/src/App_20200225141137.js new file mode 100644 index 0000000..a8d9b81 --- /dev/null +++ b/.history/src/App_20200225141137.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true + }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141139.js b/.history/src/App_20200225141139.js new file mode 100644 index 0000000..2599701 --- /dev/null +++ b/.history/src/App_20200225141139.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141143.js b/.history/src/App_20200225141143.js new file mode 100644 index 0000000..8381702 --- /dev/null +++ b/.history/src/App_20200225141143.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} toggleCropper={this.toggleCropper} /> : + cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141147.js b/.history/src/App_20200225141147.js new file mode 100644 index 0000000..0e5628b --- /dev/null +++ b/.history/src/App_20200225141147.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> : + cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141156.js b/.history/src/App_20200225141156.js new file mode 100644 index 0000000..d531267 --- /dev/null +++ b/.history/src/App_20200225141156.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.editor.current.applyCropping()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141203.js b/.history/src/App_20200225141203.js new file mode 100644 index 0000000..2599971 --- /dev/null +++ b/.history/src/App_20200225141203.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + toggleCropper = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141207.js b/.history/src/App_20200225141207.js new file mode 100644 index 0000000..c2ed687 --- /dev/null +++ b/.history/src/App_20200225141207.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141210.js b/.history/src/App_20200225141210.js new file mode 100644 index 0000000..16f5a5e --- /dev/null +++ b/.history/src/App_20200225141210.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141216.js b/.history/src/App_20200225141216.js new file mode 100644 index 0000000..4bdc3e9 --- /dev/null +++ b/.history/src/App_20200225141216.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: !prev.croppingImage + }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141218.js b/.history/src/App_20200225141218.js new file mode 100644 index 0000000..bf8dedd --- /dev/null +++ b/.history/src/App_20200225141218.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: !prev.croppingImage + }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141227.js b/.history/src/App_20200225141227.js new file mode 100644 index 0000000..1152cf0 --- /dev/null +++ b/.history/src/App_20200225141227.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: !prev. }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141230.js b/.history/src/App_20200225141230.js new file mode 100644 index 0000000..e40f2eb --- /dev/null +++ b/.history/src/App_20200225141230.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + } /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141235.js b/.history/src/App_20200225141235.js new file mode 100644 index 0000000..bc65b13 --- /dev/null +++ b/.history/src/App_20200225141235.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141258.js b/.history/src/App_20200225141258.js new file mode 100644 index 0000000..92aeecb --- /dev/null +++ b/.history/src/App_20200225141258.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141259.js b/.history/src/App_20200225141259.js new file mode 100644 index 0000000..b7f99d3 --- /dev/null +++ b/.history/src/App_20200225141259.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141310.js b/.history/src/App_20200225141310.js new file mode 100644 index 0000000..f738b9f --- /dev/null +++ b/.history/src/App_20200225141310.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141311.js b/.history/src/App_20200225141311.js new file mode 100644 index 0000000..cccf942 --- /dev/null +++ b/.history/src/App_20200225141311.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141610.js b/.history/src/App_20200225141610.js new file mode 100644 index 0000000..c635d89 --- /dev/null +++ b/.history/src/App_20200225141610.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cr +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141613.js b/.history/src/App_20200225141613.js new file mode 100644 index 0000000..271196f --- /dev/null +++ b/.history/src/App_20200225141613.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141623.js b/.history/src/App_20200225141623.js new file mode 100644 index 0000000..b9dfe17 --- /dev/null +++ b/.history/src/App_20200225141623.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141628.js b/.history/src/App_20200225141628.js new file mode 100644 index 0000000..a077185 --- /dev/null +++ b/.history/src/App_20200225141628.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141633.js b/.history/src/App_20200225141633.js new file mode 100644 index 0000000..ac24545 --- /dev/null +++ b/.history/src/App_20200225141633.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141638.js b/.history/src/App_20200225141638.js new file mode 100644 index 0000000..a11c704 --- /dev/null +++ b/.history/src/App_20200225141638.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + {/* } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141639.js b/.history/src/App_20200225141639.js new file mode 100644 index 0000000..13ccf73 --- /dev/null +++ b/.history/src/App_20200225141639.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage(){ + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141642.js b/.history/src/App_20200225141642.js new file mode 100644 index 0000000..aad4634 --- /dev/null +++ b/.history/src/App_20200225141642.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141646.js b/.history/src/App_20200225141646.js new file mode 100644 index 0000000..9cf50de --- /dev/null +++ b/.history/src/App_20200225141646.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + // this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141706.js b/.history/src/App_20200225141706.js new file mode 100644 index 0000000..2be2e07 --- /dev/null +++ b/.history/src/App_20200225141706.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + // this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141707.js b/.history/src/App_20200225141707.js new file mode 100644 index 0000000..54c214f --- /dev/null +++ b/.history/src/App_20200225141707.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141714.js b/.history/src/App_20200225141714.js new file mode 100644 index 0000000..54c214f --- /dev/null +++ b/.history/src/App_20200225141714.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141717.js b/.history/src/App_20200225141717.js new file mode 100644 index 0000000..01659f0 --- /dev/null +++ b/.history/src/App_20200225141717.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141719.js b/.history/src/App_20200225141719.js new file mode 100644 index 0000000..a9ed155 --- /dev/null +++ b/.history/src/App_20200225141719.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper && crop ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141723.js b/.history/src/App_20200225141723.js new file mode 100644 index 0000000..1f40136 --- /dev/null +++ b/.history/src/App_20200225141723.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper && croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141831.js b/.history/src/App_20200225141831.js new file mode 100644 index 0000000..54c214f --- /dev/null +++ b/.history/src/App_20200225141831.js @@ -0,0 +1,63 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + this.setState({ croppingImage: false }); + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141840.js b/.history/src/App_20200225141840.js new file mode 100644 index 0000000..85fcd08 --- /dev/null +++ b/.history/src/App_20200225141840.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + this.setState({ croppingImage: true }); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225141842.js b/.history/src/App_20200225141842.js new file mode 100644 index 0000000..6e7e686 --- /dev/null +++ b/.history/src/App_20200225141842.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {cropper ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142010.js b/.history/src/App_20200225142010.js new file mode 100644 index 0000000..82f369b --- /dev/null +++ b/.history/src/App_20200225142010.js @@ -0,0 +1,61 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + } + cropImage() { + this.editor.current.set('crop'); + cropper = true; + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142014.js b/.history/src/App_20200225142014.js new file mode 100644 index 0000000..23448b2 --- /dev/null +++ b/.history/src/App_20200225142014.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + cropper = false; + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142015.js b/.history/src/App_20200225142015.js new file mode 100644 index 0000000..6db0586 --- /dev/null +++ b/.history/src/App_20200225142015.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142032.js b/.history/src/App_20200225142032.js new file mode 100644 index 0000000..6b888a5 --- /dev/null +++ b/.history/src/App_20200225142032.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.set + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142035.js b/.history/src/App_20200225142035.js new file mode 100644 index 0000000..b822396 --- /dev/null +++ b/.history/src/App_20200225142035.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({}) + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142042.js b/.history/src/App_20200225142042.js new file mode 100644 index 0000000..a4ea8f1 --- /dev/null +++ b/.history/src/App_20200225142042.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ({})}) + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142047.js b/.history/src/App_20200225142047.js new file mode 100644 index 0000000..e25c51e --- /dev/null +++ b/.history/src/App_20200225142047.js @@ -0,0 +1,60 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ({}})) + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142048.js b/.history/src/App_20200225142048.js new file mode 100644 index 0000000..5efb6fa --- /dev/null +++ b/.history/src/App_20200225142048.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ({ + + }})) + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142052.js b/.history/src/App_20200225142052.js new file mode 100644 index 0000000..d9deb6b --- /dev/null +++ b/.history/src/App_20200225142052.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ( + + })) + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142054.js b/.history/src/App_20200225142054.js new file mode 100644 index 0000000..d7668a0 --- /dev/null +++ b/.history/src/App_20200225142054.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ( + + })) + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142059.js b/.history/src/App_20200225142059.js new file mode 100644 index 0000000..17b697f --- /dev/null +++ b/.history/src/App_20200225142059.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ( + + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142100.js b/.history/src/App_20200225142100.js new file mode 100644 index 0000000..8713159 --- /dev/null +++ b/.history/src/App_20200225142100.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ( + cr + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142109.js b/.history/src/App_20200225142109.js new file mode 100644 index 0000000..a45de2b --- /dev/null +++ b/.history/src/App_20200225142109.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ( + croppingImage : !prev.crop + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142111.js b/.history/src/App_20200225142111.js new file mode 100644 index 0000000..018ef3d --- /dev/null +++ b/.history/src/App_20200225142111.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState({prev => ( + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142118.js b/.history/src/App_20200225142118.js new file mode 100644 index 0000000..144846b --- /dev/null +++ b/.history/src/App_20200225142118.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ( + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142119.js b/.history/src/App_20200225142119.js new file mode 100644 index 0000000..2174c23 --- /dev/null +++ b/.history/src/App_20200225142119.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => {( + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142123.js b/.history/src/App_20200225142123.js new file mode 100644 index 0000000..144846b --- /dev/null +++ b/.history/src/App_20200225142123.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ( + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142129.js b/.history/src/App_20200225142129.js new file mode 100644 index 0000000..57c862e --- /dev/null +++ b/.history/src/App_20200225142129.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({} + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142130.js b/.history/src/App_20200225142130.js new file mode 100644 index 0000000..e1e6cfa --- /dev/null +++ b/.history/src/App_20200225142130.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142131.js b/.history/src/App_20200225142131.js new file mode 100644 index 0000000..e1e6cfa --- /dev/null +++ b/.history/src/App_20200225142131.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142136.js b/.history/src/App_20200225142136.js new file mode 100644 index 0000000..2430d24 --- /dev/null +++ b/.history/src/App_20200225142136.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142137.js b/.history/src/App_20200225142137.js new file mode 100644 index 0000000..2430d24 --- /dev/null +++ b/.history/src/App_20200225142137.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +let cropper; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142143.js b/.history/src/App_20200225142143.js new file mode 100644 index 0000000..b1c7127 --- /dev/null +++ b/.history/src/App_20200225142143.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142408.js b/.history/src/App_20200225142408.js new file mode 100644 index 0000000..15a16da --- /dev/null +++ b/.history/src/App_20200225142408.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + this.editor.current.set('crop'); + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142413.js b/.history/src/App_20200225142413.js new file mode 100644 index 0000000..3e9d3c3 --- /dev/null +++ b/.history/src/App_20200225142413.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop');); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142415.js b/.history/src/App_20200225142415.js new file mode 100644 index 0000000..84018c5 --- /dev/null +++ b/.history/src/App_20200225142415.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142419.js b/.history/src/App_20200225142419.js new file mode 100644 index 0000000..d63337b --- /dev/null +++ b/.history/src/App_20200225142419.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + this.editor.current.applyCropping() + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142421.js b/.history/src/App_20200225142421.js new file mode 100644 index 0000000..b54d0f0 --- /dev/null +++ b/.history/src/App_20200225142421.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142422.js b/.history/src/App_20200225142422.js new file mode 100644 index 0000000..1acc296 --- /dev/null +++ b/.history/src/App_20200225142422.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),this.editor.current.applyCropping()); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142439.js b/.history/src/App_20200225142439.js new file mode 100644 index 0000000..b54d0f0 --- /dev/null +++ b/.history/src/App_20200225142439.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142440.js b/.history/src/App_20200225142440.js new file mode 100644 index 0000000..56b0baa --- /dev/null +++ b/.history/src/App_20200225142440.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142443.js b/.history/src/App_20200225142443.js new file mode 100644 index 0000000..4dd3c0a --- /dev/null +++ b/.history/src/App_20200225142443.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping( = > ) + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142447.js b/.history/src/App_20200225142447.js new file mode 100644 index 0000000..5e2c8d1 --- /dev/null +++ b/.history/src/App_20200225142447.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() = > ) + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142448.js b/.history/src/App_20200225142448.js new file mode 100644 index 0000000..9764220 --- /dev/null +++ b/.history/src/App_20200225142448.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => ) + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }),); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142450.js b/.history/src/App_20200225142450.js new file mode 100644 index 0000000..9a11c84 --- /dev/null +++ b/.history/src/App_20200225142450.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => ) + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142452.js b/.history/src/App_20200225142452.js new file mode 100644 index 0000000..51da582 --- /dev/null +++ b/.history/src/App_20200225142452.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => this.setState(prev => ({ + croppingImage : !prev.croppingImage + }));) + + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142454.js b/.history/src/App_20200225142454.js new file mode 100644 index 0000000..53ea942 --- /dev/null +++ b/.history/src/App_20200225142454.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => this.setState(prev => ({ + croppingImage : !prev.croppingImage + }))) + + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142502.js b/.history/src/App_20200225142502.js new file mode 100644 index 0000000..53ea942 --- /dev/null +++ b/.history/src/App_20200225142502.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => this.setState(prev => ({ + croppingImage : !prev.croppingImage + }))) + + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142613.js b/.history/src/App_20200225142613.js new file mode 100644 index 0000000..995a9cb --- /dev/null +++ b/.history/src/App_20200225142613.js @@ -0,0 +1,64 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => this.setState(prev => ({ + croppingImage : !prev.croppingImage + }))) + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142617.js b/.history/src/App_20200225142617.js new file mode 100644 index 0000000..b2744dc --- /dev/null +++ b/.history/src/App_20200225142617.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping(() => ) + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142618.js b/.history/src/App_20200225142618.js new file mode 100644 index 0000000..d4f2076 --- /dev/null +++ b/.history/src/App_20200225142618.js @@ -0,0 +1,62 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142619.js b/.history/src/App_20200225142619.js new file mode 100644 index 0000000..ba37b00 --- /dev/null +++ b/.history/src/App_20200225142619.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), this.editor.current.set('crop')); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142623.js b/.history/src/App_20200225142623.js new file mode 100644 index 0000000..28889cd --- /dev/null +++ b/.history/src/App_20200225142623.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142624.js b/.history/src/App_20200225142624.js new file mode 100644 index 0000000..6fe29bd --- /dev/null +++ b/.history/src/App_20200225142624.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142627.js b/.history/src/App_20200225142627.js new file mode 100644 index 0000000..18e4da3 --- /dev/null +++ b/.history/src/App_20200225142627.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142628.js b/.history/src/App_20200225142628.js new file mode 100644 index 0000000..722d1d1 --- /dev/null +++ b/.history/src/App_20200225142628.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // })) + + } + cropImage() { + this.editor.current.set('crop') + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142633.js b/.history/src/App_20200225142633.js new file mode 100644 index 0000000..e56ebea --- /dev/null +++ b/.history/src/App_20200225142633.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // })) + + } + cropImage() { + this.editor.current.set('crop') + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + } + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142634.js b/.history/src/App_20200225142634.js new file mode 100644 index 0000000..0cab0a9 --- /dev/null +++ b/.history/src/App_20200225142634.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // })) + + } + cropImage() { + this.editor.current.set('crop') + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142653.js b/.history/src/App_20200225142653.js new file mode 100644 index 0000000..837bba7 --- /dev/null +++ b/.history/src/App_20200225142653.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + }), ); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142655.js b/.history/src/App_20200225142655.js new file mode 100644 index 0000000..0749253 --- /dev/null +++ b/.history/src/App_20200225142655.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + // this.setState(prev => ({ + // croppingImage : !prev.croppingImage + // })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142656.js b/.history/src/App_20200225142656.js new file mode 100644 index 0000000..aa32120 --- /dev/null +++ b/.history/src/App_20200225142656.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {/* {croppingImage ? */} + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142659.js b/.history/src/App_20200225142659.js new file mode 100644 index 0000000..181ee35 --- /dev/null +++ b/.history/src/App_20200225142659.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + {/* } */} + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142702.js b/.history/src/App_20200225142702.js new file mode 100644 index 0000000..7cfa886 --- /dev/null +++ b/.history/src/App_20200225142702.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142703.js b/.history/src/App_20200225142703.js new file mode 100644 index 0000000..16d6cbb --- /dev/null +++ b/.history/src/App_20200225142703.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage : !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142734.js b/.history/src/App_20200225142734.js new file mode 100644 index 0000000..5607097 --- /dev/null +++ b/.history/src/App_20200225142734.js @@ -0,0 +1,65 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142905.js b/.history/src/App_20200225142905.js new file mode 100644 index 0000000..0331158 --- /dev/null +++ b/.history/src/App_20200225142905.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142907.js b/.history/src/App_20200225142907.js new file mode 100644 index 0000000..0331158 --- /dev/null +++ b/.history/src/App_20200225142907.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142912.js b/.history/src/App_20200225142912.js new file mode 100644 index 0000000..5e7c07d --- /dev/null +++ b/.history/src/App_20200225142912.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout() + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142915.js b/.history/src/App_20200225142915.js new file mode 100644 index 0000000..7b013a7 --- /dev/null +++ b/.history/src/App_20200225142915.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(=> { + + }) + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142919.js b/.history/src/App_20200225142919.js new file mode 100644 index 0000000..7d148de --- /dev/null +++ b/.history/src/App_20200225142919.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout() => { + + }) + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142924.js b/.history/src/App_20200225142924.js new file mode 100644 index 0000000..57021de --- /dev/null +++ b/.history/src/App_20200225142924.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout() => { + + },100) + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142928.js b/.history/src/App_20200225142928.js new file mode 100644 index 0000000..132f707 --- /dev/null +++ b/.history/src/App_20200225142928.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + + },100) + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142930.js b/.history/src/App_20200225142930.js new file mode 100644 index 0000000..bdf9356 --- /dev/null +++ b/.history/src/App_20200225142930.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },100) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225142959.js b/.history/src/App_20200225142959.js new file mode 100644 index 0000000..bab1910 --- /dev/null +++ b/.history/src/App_20200225142959.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143050.js b/.history/src/App_20200225143050.js new file mode 100644 index 0000000..3229c72 --- /dev/null +++ b/.history/src/App_20200225143050.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + const { croppingImage } = this.state; + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143053.js b/.history/src/App_20200225143053.js new file mode 100644 index 0000000..9db3204 --- /dev/null +++ b/.history/src/App_20200225143053.js @@ -0,0 +1,68 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143123.js b/.history/src/App_20200225143123.js new file mode 100644 index 0000000..b863910 --- /dev/null +++ b/.history/src/App_20200225143123.js @@ -0,0 +1,66 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143126.js b/.history/src/App_20200225143126.js new file mode 100644 index 0000000..c741c1d --- /dev/null +++ b/.history/src/App_20200225143126.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + return ( +
+
+ +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143209.js b/.history/src/App_20200225143209.js new file mode 100644 index 0000000..169b1c3 --- /dev/null +++ b/.history/src/App_20200225143209.js @@ -0,0 +1,67 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143213.js b/.history/src/App_20200225143213.js new file mode 100644 index 0000000..28327f5 --- /dev/null +++ b/.history/src/App_20200225143213.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143215.js b/.history/src/App_20200225143215.js new file mode 100644 index 0000000..f4a2291 --- /dev/null +++ b/.history/src/App_20200225143215.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143216.js b/.history/src/App_20200225143216.js new file mode 100644 index 0000000..8f7e7d0 --- /dev/null +++ b/.history/src/App_20200225143216.js @@ -0,0 +1,73 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { +
+ +
+ } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143223.js b/.history/src/App_20200225143223.js new file mode 100644 index 0000000..df2d266 --- /dev/null +++ b/.history/src/App_20200225143223.js @@ -0,0 +1,74 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + retur () +
+ +
+ } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143225.js b/.history/src/App_20200225143225.js new file mode 100644 index 0000000..2707760 --- /dev/null +++ b/.history/src/App_20200225143225.js @@ -0,0 +1,74 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return () +
+ +
+ } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143227.js b/.history/src/App_20200225143227.js new file mode 100644 index 0000000..6d96d02 --- /dev/null +++ b/.history/src/App_20200225143227.js @@ -0,0 +1,74 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return ( +
+ +
+ } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143229.js b/.history/src/App_20200225143229.js new file mode 100644 index 0000000..7dc1a09 --- /dev/null +++ b/.history/src/App_20200225143229.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return ( +
+ +
+ + )} + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143231.js b/.history/src/App_20200225143231.js new file mode 100644 index 0000000..2b2eb0a --- /dev/null +++ b/.history/src/App_20200225143231.js @@ -0,0 +1,76 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return ( +
+ +
+ + ) + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143237.js b/.history/src/App_20200225143237.js new file mode 100644 index 0000000..d61b8a4 --- /dev/null +++ b/.history/src/App_20200225143237.js @@ -0,0 +1,76 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143238.js b/.history/src/App_20200225143238.js new file mode 100644 index 0000000..84dba02 --- /dev/null +++ b/.history/src/App_20200225143238.js @@ -0,0 +1,76 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143239.js b/.history/src/App_20200225143239.js new file mode 100644 index 0000000..84dba02 --- /dev/null +++ b/.history/src/App_20200225143239.js @@ -0,0 +1,76 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143322.js b/.history/src/App_20200225143322.js new file mode 100644 index 0000000..6ceab3c --- /dev/null +++ b/.history/src/App_20200225143322.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + console.logz9'ddd + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143324.js b/.history/src/App_20200225143324.js new file mode 100644 index 0000000..bfd2c53 --- /dev/null +++ b/.history/src/App_20200225143324.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + console.logz(ddd + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143326.js b/.history/src/App_20200225143326.js new file mode 100644 index 0000000..cb0412f --- /dev/null +++ b/.history/src/App_20200225143326.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + console.logz('ddd + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143328.js b/.history/src/App_20200225143328.js new file mode 100644 index 0000000..6c77b4a --- /dev/null +++ b/.history/src/App_20200225143328.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + console.logz('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143332.js b/.history/src/App_20200225143332.js new file mode 100644 index 0000000..ac4c4fa --- /dev/null +++ b/.history/src/App_20200225143332.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143533.js b/.history/src/App_20200225143533.js new file mode 100644 index 0000000..8d637f3 --- /dev/null +++ b/.history/src/App_20200225143533.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: !prev.croppingImage + })); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143536.js b/.history/src/App_20200225143536.js new file mode 100644 index 0000000..8f73d6a --- /dev/null +++ b/.history/src/App_20200225143536.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: !prev.croppingImage + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143543.js b/.history/src/App_20200225143543.js new file mode 100644 index 0000000..ec3d89c --- /dev/null +++ b/.history/src/App_20200225143543.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState(prev => ({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143547.js b/.history/src/App_20200225143547.js new file mode 100644 index 0000000..a23e16e --- /dev/null +++ b/.history/src/App_20200225143547.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: !prev.croppingImage + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143550.js b/.history/src/App_20200225143550.js new file mode 100644 index 0000000..7eaf9f7 --- /dev/null +++ b/.history/src/App_20200225143550.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + })) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143552.js b/.history/src/App_20200225143552.js new file mode 100644 index 0000000..1ffffbd --- /dev/null +++ b/.history/src/App_20200225143552.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }) + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143553.js b/.history/src/App_20200225143553.js new file mode 100644 index 0000000..705aca1 --- /dev/null +++ b/.history/src/App_20200225143553.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143554.js b/.history/src/App_20200225143554.js new file mode 100644 index 0000000..705aca1 --- /dev/null +++ b/.history/src/App_20200225143554.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143621.js b/.history/src/App_20200225143621.js new file mode 100644 index 0000000..6e8393e --- /dev/null +++ b/.history/src/App_20200225143621.js @@ -0,0 +1,78 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + setTimeout(() => { + this.setState({ + croppingImage: true + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143623.js b/.history/src/App_20200225143623.js new file mode 100644 index 0000000..ae75ef3 --- /dev/null +++ b/.history/src/App_20200225143623.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + setTimeout(() => { + this.setState({ + croppingImage: true + }); + }); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143625.js b/.history/src/App_20200225143625.js new file mode 100644 index 0000000..0e11bbb --- /dev/null +++ b/.history/src/App_20200225143625.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + setTimeout(() => { + this.setState({ + croppingImage: true + }); + ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143627.js b/.history/src/App_20200225143627.js new file mode 100644 index 0000000..7ba5489 --- /dev/null +++ b/.history/src/App_20200225143627.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143628.js b/.history/src/App_20200225143628.js new file mode 100644 index 0000000..17681f8 --- /dev/null +++ b/.history/src/App_20200225143628.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143631.js b/.history/src/App_20200225143631.js new file mode 100644 index 0000000..d74712b --- /dev/null +++ b/.history/src/App_20200225143631.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143632.js b/.history/src/App_20200225143632.js new file mode 100644 index 0000000..36c366d --- /dev/null +++ b/.history/src/App_20200225143632.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143633.js b/.history/src/App_20200225143633.js new file mode 100644 index 0000000..36c366d --- /dev/null +++ b/.history/src/App_20200225143633.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143739.js b/.history/src/App_20200225143739.js new file mode 100644 index 0000000..503210b --- /dev/null +++ b/.history/src/App_20200225143739.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ HEllo +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225143749.js b/.history/src/App_20200225143749.js new file mode 100644 index 0000000..36c366d --- /dev/null +++ b/.history/src/App_20200225143749.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + // ,1000}); + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151823.js b/.history/src/App_20200225151823.js new file mode 100644 index 0000000..4e12f4c --- /dev/null +++ b/.history/src/App_20200225151823.js @@ -0,0 +1,79 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + // setTimeout(() => { + this.setState({ + croppingImage: true + }); + + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151826.js b/.history/src/App_20200225151826.js new file mode 100644 index 0000000..2534607 --- /dev/null +++ b/.history/src/App_20200225151826.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+ ) + } +} +export default App; diff --git a/.history/src/App_20200225151828.js b/.history/src/App_20200225151828.js new file mode 100644 index 0000000..a34d00c --- /dev/null +++ b/.history/src/App_20200225151828.js @@ -0,0 +1,77 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + a() { + console.log('ddd'); + return ( +
+ +
+ ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151830.js b/.history/src/App_20200225151830.js new file mode 100644 index 0000000..e2f95ea --- /dev/null +++ b/.history/src/App_20200225151830.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + a() { + console.log('ddd'); + return ( + + ) + } + render() { + return ( +
+ {this.a()} +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151832.js b/.history/src/App_20200225151832.js new file mode 100644 index 0000000..7f2698a --- /dev/null +++ b/.history/src/App_20200225151832.js @@ -0,0 +1,75 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + a() { + console.log('ddd'); + return ( + + ) + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151834.js b/.history/src/App_20200225151834.js new file mode 100644 index 0000000..489adb7 --- /dev/null +++ b/.history/src/App_20200225151834.js @@ -0,0 +1,69 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ +
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151836.js b/.history/src/App_20200225151836.js new file mode 100644 index 0000000..aad9091 --- /dev/null +++ b/.history/src/App_20200225151836.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225151837.js b/.history/src/App_20200225151837.js new file mode 100644 index 0000000..7b78825 --- /dev/null +++ b/.history/src/App_20200225151837.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153156.js b/.history/src/App_20200225153156.js new file mode 100644 index 0000000..b849e2e --- /dev/null +++ b/.history/src/App_20200225153156.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153157.js b/.history/src/App_20200225153157.js new file mode 100644 index 0000000..4c6bc87 --- /dev/null +++ b/.history/src/App_20200225153157.js @@ -0,0 +1,71 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153324.js b/.history/src/App_20200225153324.js new file mode 100644 index 0000000..9d622ea --- /dev/null +++ b/.history/src/App_20200225153324.js @@ -0,0 +1,59 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153341.js b/.history/src/App_20200225153341.js new file mode 100644 index 0000000..e08cbf8 --- /dev/null +++ b/.history/src/App_20200225153341.js @@ -0,0 +1,58 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + // },1000) + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153342.js b/.history/src/App_20200225153342.js new file mode 100644 index 0000000..ae0515e --- /dev/null +++ b/.history/src/App_20200225153342.js @@ -0,0 +1,57 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153344.js b/.history/src/App_20200225153344.js new file mode 100644 index 0000000..f54f9ef --- /dev/null +++ b/.history/src/App_20200225153344.js @@ -0,0 +1,56 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + + this.editor.current.applyCropping() + // setTimeout(() => { + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153346.js b/.history/src/App_20200225153346.js new file mode 100644 index 0000000..5c8a23b --- /dev/null +++ b/.history/src/App_20200225153346.js @@ -0,0 +1,54 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153348.js b/.history/src/App_20200225153348.js new file mode 100644 index 0000000..c134bb8 --- /dev/null +++ b/.history/src/App_20200225153348.js @@ -0,0 +1,54 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153427.js b/.history/src/App_20200225153427.js new file mode 100644 index 0000000..0ab65e0 --- /dev/null +++ b/.history/src/App_20200225153427.js @@ -0,0 +1,54 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153435.js b/.history/src/App_20200225153435.js new file mode 100644 index 0000000..a4e7760 --- /dev/null +++ b/.history/src/App_20200225153435.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225153442.js b/.history/src/App_20200225153442.js new file mode 100644 index 0000000..842c184 --- /dev/null +++ b/.history/src/App_20200225153442.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ + +
+
+ ) + } +} +export default App; diff --git a/.history/src/App_20200225153446.js b/.history/src/App_20200225153446.js new file mode 100644 index 0000000..63f8088 --- /dev/null +++ b/.history/src/App_20200225153446.js @@ -0,0 +1,55 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + + + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154415.js b/.history/src/App_20200225154415.js new file mode 100644 index 0000000..0616e08 --- /dev/null +++ b/.history/src/App_20200225154415.js @@ -0,0 +1,53 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154417.js b/.history/src/App_20200225154417.js new file mode 100644 index 0000000..ea9944f --- /dev/null +++ b/.history/src/App_20200225154417.js @@ -0,0 +1,42 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154501.js b/.history/src/App_20200225154501.js new file mode 100644 index 0000000..3dd986c --- /dev/null +++ b/.history/src/App_20200225154501.js @@ -0,0 +1,42 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154507.js b/.history/src/App_20200225154507.js new file mode 100644 index 0000000..84265ac --- /dev/null +++ b/.history/src/App_20200225154507.js @@ -0,0 +1,38 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + + + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154509.js b/.history/src/App_20200225154509.js new file mode 100644 index 0000000..a3e4623 --- /dev/null +++ b/.history/src/App_20200225154509.js @@ -0,0 +1,36 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154516.js b/.history/src/App_20200225154516.js new file mode 100644 index 0000000..3271634 --- /dev/null +++ b/.history/src/App_20200225154516.js @@ -0,0 +1,29 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154518.js b/.history/src/App_20200225154518.js new file mode 100644 index 0000000..a3e4623 --- /dev/null +++ b/.history/src/App_20200225154518.js @@ -0,0 +1,36 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154722.js b/.history/src/App_20200225154722.js new file mode 100644 index 0000000..3676f8d --- /dev/null +++ b/.history/src/App_20200225154722.js @@ -0,0 +1,29 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154729.js b/.history/src/App_20200225154729.js new file mode 100644 index 0000000..a3e4623 --- /dev/null +++ b/.history/src/App_20200225154729.js @@ -0,0 +1,36 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154733.js b/.history/src/App_20200225154733.js new file mode 100644 index 0000000..dac36ab --- /dev/null +++ b/.history/src/App_20200225154733.js @@ -0,0 +1,36 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154737.js b/.history/src/App_20200225154737.js new file mode 100644 index 0000000..9d04697 --- /dev/null +++ b/.history/src/App_20200225154737.js @@ -0,0 +1,36 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154739.js b/.history/src/App_20200225154739.js new file mode 100644 index 0000000..212266e --- /dev/null +++ b/.history/src/App_20200225154739.js @@ -0,0 +1,36 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225154919.js b/.history/src/App_20200225154919.js new file mode 100644 index 0000000..fdd0fd8 --- /dev/null +++ b/.history/src/App_20200225154919.js @@ -0,0 +1,35 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155010.js b/.history/src/App_20200225155010.js new file mode 100644 index 0000000..0c2653f --- /dev/null +++ b/.history/src/App_20200225155010.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155014.js b/.history/src/App_20200225155014.js new file mode 100644 index 0000000..eae646f --- /dev/null +++ b/.history/src/App_20200225155014.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155018.js b/.history/src/App_20200225155018.js new file mode 100644 index 0000000..3c9977e --- /dev/null +++ b/.history/src/App_20200225155018.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ Horizontal +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155020.js b/.history/src/App_20200225155020.js new file mode 100644 index 0000000..751f7be --- /dev/null +++ b/.history/src/App_20200225155020.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ HorizontalToolbar +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155023.js b/.history/src/App_20200225155023.js new file mode 100644 index 0000000..1a34385 --- /dev/null +++ b/.history/src/App_20200225155023.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ < +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155026.js b/.history/src/App_20200225155026.js new file mode 100644 index 0000000..f167282 --- /dev/null +++ b/.history/src/App_20200225155026.js @@ -0,0 +1,27 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ + +
+ +
+
+ ) + } +} +export default App; diff --git a/.history/src/App_20200225155029.js b/.history/src/App_20200225155029.js new file mode 100644 index 0000000..6f60269 --- /dev/null +++ b/.history/src/App_20200225155029.js @@ -0,0 +1,27 @@ +import React from 'react'; +import './App.css'; +import Tool from './components/Tools/Tool'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155132.js b/.history/src/App_20200225155132.js new file mode 100644 index 0000000..d36458f --- /dev/null +++ b/.history/src/App_20200225155132.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/App_20200225155156.js b/.history/src/App_20200225155156.js new file mode 100644 index 0000000..6fc3880 --- /dev/null +++ b/.history/src/App_20200225155156.js @@ -0,0 +1,26 @@ +import React from 'react'; +import './App.css'; +import { Editor } from 'react-image-markup'; + +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+ +
+
+
) + } +} +export default App; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200220125508.jsx b/.history/src/components/ColorPanel/ColorPanel_20200220125508.jsx new file mode 100644 index 0000000..98b62de --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200220125508.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155717.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155717.jsx new file mode 100644 index 0000000..e5e7f65 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155717.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + props + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155719.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155719.jsx new file mode 100644 index 0000000..2521d4f --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155719.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + this.props. + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155721.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155721.jsx new file mode 100644 index 0000000..52ecfd8 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155721.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + this.props + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155724.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155724.jsx new file mode 100644 index 0000000..98b62de --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155724.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155725.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155725.jsx new file mode 100644 index 0000000..98b62de --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155725.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155753.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155753.jsx new file mode 100644 index 0000000..ceef6e0 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155753.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.props. + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155756.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155756.jsx new file mode 100644 index 0000000..4bfa410 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155756.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.props.changeColo + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155759.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155759.jsx new file mode 100644 index 0000000..baad1db --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155759.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.props.changeColorForAll + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224155814.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224155814.jsx new file mode 100644 index 0000000..62fce49 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224155814.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.props.changeColorForAll(color) + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224160834.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224160834.jsx new file mode 100644 index 0000000..98b62de --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224160834.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224160836.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224160836.jsx new file mode 100644 index 0000000..109f6f0 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224160836.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224160840.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224160840.jsx new file mode 100644 index 0000000..508287c --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224160840.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPanel_20200224160851.jsx b/.history/src/components/ColorPanel/ColorPanel_20200224160851.jsx new file mode 100644 index 0000000..4cafbc0 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPanel_20200224160851.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200220153059.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200220153059.jsx new file mode 100644 index 0000000..80bf0c9 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200220153059.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../assets/js/methods'; +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140034.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140034.jsx new file mode 100644 index 0000000..274ae9b --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140034.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'reac' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140035.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140035.jsx new file mode 100644 index 0000000..f2c6b09 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140035.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140051.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140051.jsx new file mode 100644 index 0000000..866e039 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140051.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import Editor from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140106.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140106.jsx new file mode 100644 index 0000000..b706bd4 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140106.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140109.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140109.jsx new file mode 100644 index 0000000..9f07d0b --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140109.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140110.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140110.jsx new file mode 100644 index 0000000..c8a2c3f --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224140110.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155036.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155036.jsx new file mode 100644 index 0000000..05204c8 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155036.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155041.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155041.jsx new file mode 100644 index 0000000..5471581 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155041.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155047.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155047.jsx new file mode 100644 index 0000000..faf815c --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155047.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155050.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155050.jsx new file mode 100644 index 0000000..53d1fcc --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155050.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155052.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155052.jsx new file mode 100644 index 0000000..61b9ee7 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155052.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor() + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155055.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155055.jsx new file mode 100644 index 0000000..f2c6b09 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155055.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155131.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155131.jsx new file mode 100644 index 0000000..a2ed24e --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155131.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(this.editor) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155133.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155133.jsx new file mode 100644 index 0000000..318cc7e --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155133.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +// import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(this.editor) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155144.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155144.jsx new file mode 100644 index 0000000..e6eacf1 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155144.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +// import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155149.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155149.jsx new file mode 100644 index 0000000..467acae --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155149.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; + +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155152.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155152.jsx new file mode 100644 index 0000000..e6eacf1 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155152.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +// import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155157.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155157.jsx new file mode 100644 index 0000000..bcf39fc --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155157.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +// import Editor from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155158.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155158.jsx new file mode 100644 index 0000000..829073b --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155158.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import Editor from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155200.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155200.jsx new file mode 100644 index 0000000..8068adc --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155200.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import Editor from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155202.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155202.jsx new file mode 100644 index 0000000..c4b7c1a --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155202.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import {} Editor from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155204.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155204.jsx new file mode 100644 index 0000000..1e0ebc6 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155204.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { Editor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155210.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155210.jsx new file mode 100644 index 0000000..ddab3b1 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155210.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { Editor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155211.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155211.jsx new file mode 100644 index 0000000..0641b43 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155211.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { Editor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155214.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155214.jsx new file mode 100644 index 0000000..223ece4 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155214.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { Editor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155248.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155248.jsx new file mode 100644 index 0000000..c8d658a --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155248.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155253.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155253.jsx new file mode 100644 index 0000000..48a8170 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155253.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155255.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155255.jsx new file mode 100644 index 0000000..f4f54a0 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155255.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155258.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155258.jsx new file mode 100644 index 0000000..7855d9b --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155258.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/rea' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155301.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155301.jsx new file mode 100644 index 0000000..01e808e --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155301.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155302.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155302.jsx new file mode 100644 index 0000000..651250f --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155302.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155304.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155304.jsx new file mode 100644 index 0000000..5186e69 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155304.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155308.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155308.jsx new file mode 100644 index 0000000..259aeae --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155308.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/assets/js/' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155309.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155309.jsx new file mode 100644 index 0000000..e8f5d83 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155309.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/assets/js/methods' +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(Editor,"AA") + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155314.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155314.jsx new file mode 100644 index 0000000..fb3d443 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155314.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/assets/js/methods' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155315.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155315.jsx new file mode 100644 index 0000000..0f9c5fc --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155315.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/assets/js/methods' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor() + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155317.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155317.jsx new file mode 100644 index 0000000..f2cec4f --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155317.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/assets/js/methods' +const ColorPicker = (props) => { + let chooseColor = () => { + changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155737.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155737.jsx new file mode 100644 index 0000000..b4a77d6 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155737.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor } from '../../../../node_modules/react-image-markup/src/assets/js/methods' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155740.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155740.jsx new file mode 100644 index 0000000..c8a2c3f --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224155740.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160053.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160053.jsx new file mode 100644 index 0000000..467acae --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160053.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; + +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160127.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160127.jsx new file mode 100644 index 0000000..05204c8 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160127.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160134.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160134.jsx new file mode 100644 index 0000000..88db3ee --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160134.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +import { changeColor} from 'react-image-markup' +const ColorPicker = (props) => { + let chooseColor = () => { + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160914.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160914.jsx new file mode 100644 index 0000000..f1860af --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160914.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(props) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160941.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160941.jsx new file mode 100644 index 0000000..b55e7b0 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160941.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(props.ed) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160946.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160946.jsx new file mode 100644 index 0000000..331772e --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224160946.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(props.editor.current) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161001.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161001.jsx new file mode 100644 index 0000000..81616c5 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161001.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(props.editor.current.cahngeColor + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161005.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161005.jsx new file mode 100644 index 0000000..c019ca3 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161005.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + console.log(props.editor.current.changeColor + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161008.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161008.jsx new file mode 100644 index 0000000..973ccf5 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161008.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.editor.current.changeColor + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161009.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161009.jsx new file mode 100644 index 0000000..646ca85 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161009.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.editor.current.changeColor() + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161015.jsx b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161015.jsx new file mode 100644 index 0000000..4b30a40 --- /dev/null +++ b/.history/src/components/ColorPanel/ColorPicker/ColorPicker_20200224161015.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.editor.current.changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153240.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153240.jsx new file mode 100644 index 0000000..e69de29 diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153244.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153244.jsx new file mode 100644 index 0000000..4b30a40 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153244.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.editor.current.changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153252.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153252.jsx new file mode 100644 index 0000000..89205ef --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153252.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './HorizontalToolbar.module.css'; +const HorizontalToolbar = (props) => { + let chooseColor = () => { + props.editor.current.changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153314.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153314.jsx new file mode 100644 index 0000000..2cac731 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153314.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +const HorizontalToolbar = (props) => { + let chooseColor = () => { + props.editor.current.changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153317.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153317.jsx new file mode 100644 index 0000000..09e890a --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153317.jsx @@ -0,0 +1,10 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +const HorizontalToolbar = (props) => { + + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153331.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153331.jsx new file mode 100644 index 0000000..0b0ca78 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153331.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153333.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153333.jsx new file mode 100644 index 0000000..65f26f3 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153333.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153353.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153353.jsx new file mode 100644 index 0000000..7304e90 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153353.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153357.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153357.jsx new file mode 100644 index 0000000..300394e --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153357.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from '../components/ColorPanel/ColorPanel'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153405.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153405.jsx new file mode 100644 index 0000000..7304e90 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153405.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from './components/ColorPanel/ColorPanel'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153410.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153410.jsx new file mode 100644 index 0000000..09a7211 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153410.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from './ColorPanel/ColorPanel'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153419.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153419.jsx new file mode 100644 index 0000000..a7dacd2 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153419.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from './ColorPanel/ColorPanel'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153454.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153454.jsx new file mode 100644 index 0000000..98f9e93 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153454.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from './ColorPanel/ColorPanel'; +import Tool from './components/Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153455.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153455.jsx new file mode 100644 index 0000000..c95e36b --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153455.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from './ColorPanel/ColorPanel'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153534.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153534.jsx new file mode 100644 index 0000000..f1376f3 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153534.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from '../ColorPanel/ColorPanel'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153537.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153537.jsx new file mode 100644 index 0000000..f1376f3 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153537.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from '../ColorPanel/ColorPanel'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153541.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153541.jsx new file mode 100644 index 0000000..1532928 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153541.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from '../ColorPanel/ColorPanel'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153543.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153543.jsx new file mode 100644 index 0000000..87fb4de --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153543.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from '../ColorPanel/ColorPanel'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153547.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153547.jsx new file mode 100644 index 0000000..745b10b --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153547.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import ColorPanel from '../ColorPanel/ColorPanel'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153554.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153554.jsx new file mode 100644 index 0000000..06f1ff4 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153554.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153556.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153556.jsx new file mode 100644 index 0000000..b431165 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153556.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153558.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153558.jsx new file mode 100644 index 0000000..2e02665 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153558.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153601.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153601.jsx new file mode 100644 index 0000000..e1379d0 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153601.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153603.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153603.jsx new file mode 100644 index 0000000..49d6ed4 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153603.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153604.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153604.jsx new file mode 100644 index 0000000..59e1915 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153604.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153611.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153611.jsx new file mode 100644 index 0000000..2cac478 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153611.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; + +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153612.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153612.jsx new file mode 100644 index 0000000..4de2a48 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153612.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; + +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153614.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153614.jsx new file mode 100644 index 0000000..fe55655 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153614.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; + +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153617.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153617.jsx new file mode 100644 index 0000000..8674b48 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153617.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +import +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153627.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153627.jsx new file mode 100644 index 0000000..5e337b9 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153627.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from './Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153632.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153632.jsx new file mode 100644 index 0000000..a04e991 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153632.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153635.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153635.jsx new file mode 100644 index 0000000..6452ffb --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225153635.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +const HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154014.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154014.jsx new file mode 100644 index 0000000..9e6a0a6 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154014.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +class HorizontalToolbar = (props) => { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154021.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154021.jsx new file mode 100644 index 0000000..aba10d2 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154021.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +class HorizontalToolbar extends React.Component { + + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154025.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154025.jsx new file mode 100644 index 0000000..ce088d2 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154025.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +class HorizontalToolbar extends React.Component { + render(){ + + } + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154027.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154027.jsx new file mode 100644 index 0000000..71fa9ce --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154027.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel' +class HorizontalToolbar extends React.Component { + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154030.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154030.jsx new file mode 100644 index 0000000..1326362 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154030.jsx @@ -0,0 +1,28 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154036.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154036.jsx new file mode 100644 index 0000000..1007e06 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154036.jsx @@ -0,0 +1,36 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154039.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154039.jsx new file mode 100644 index 0000000..22e3f26 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154039.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154047.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154047.jsx new file mode 100644 index 0000000..22fe453 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154047.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154058.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154058.jsx new file mode 100644 index 0000000..863e619 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154058.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154103.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154103.jsx new file mode 100644 index 0000000..351106e --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154103.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154111.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154111.jsx new file mode 100644 index 0000000..abd1e92 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154111.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154116.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154116.jsx new file mode 100644 index 0000000..f46fccb --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154116.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.props.current.set('text')} /> + this.props.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154120.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154120.jsx new file mode 100644 index 0000000..863e619 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154120.jsx @@ -0,0 +1,35 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154124.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154124.jsx new file mode 100644 index 0000000..e774cc8 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154124.jsx @@ -0,0 +1,36 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154347.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154347.jsx new file mode 100644 index 0000000..7f46235 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154347.jsx @@ -0,0 +1,36 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.propseditor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154348.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154348.jsx new file mode 100644 index 0000000..53109ba --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154348.jsx @@ -0,0 +1,36 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.editor.current.set('freeDrawing')} /> + this.editor.current.set('circle')} /> + this.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154407.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154407.jsx new file mode 100644 index 0000000..4f0d7b4 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154407.jsx @@ -0,0 +1,36 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.editor.current.set('arrow')} /> + this.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154410.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154410.jsx new file mode 100644 index 0000000..2702687 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154410.jsx @@ -0,0 +1,36 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154419.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154419.jsx new file mode 100644 index 0000000..0a1c7dd --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154419.jsx @@ -0,0 +1,48 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154423.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154423.jsx new file mode 100644 index 0000000..c43d3c5 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154423.jsx @@ -0,0 +1,48 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154427.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154427.jsx new file mode 100644 index 0000000..3df3f08 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154427.jsx @@ -0,0 +1,48 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154442.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154442.jsx new file mode 100644 index 0000000..0a34a8f --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154442.jsx @@ -0,0 +1,47 @@ +import React from 'react'; +// import style from './horizontalToolbar.module.css'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154459.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154459.jsx new file mode 100644 index 0000000..243dbf1 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154459.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154959.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154959.jsx new file mode 100644 index 0000000..bb90d3f --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225154959.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default VerticalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155001.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155001.jsx new file mode 100644 index 0000000..243dbf1 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155001.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155034.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155034.jsx new file mode 100644 index 0000000..ca8ba21 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155034.jsx @@ -0,0 +1,43 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155035.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155035.jsx new file mode 100644 index 0000000..f8dfc71 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155035.jsx @@ -0,0 +1,43 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render() { + return ( +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155041.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155041.jsx new file mode 100644 index 0000000..245fc7d --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155041.jsx @@ -0,0 +1,31 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + render() { + return ( +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155044.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155044.jsx new file mode 100644 index 0000000..a07c6b6 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155044.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155047.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155047.jsx new file mode 100644 index 0000000..d609596 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155047.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155051.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155051.jsx new file mode 100644 index 0000000..2c3803e --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155051.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155052.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155052.jsx new file mode 100644 index 0000000..7cac509 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155052.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155058.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155058.jsx new file mode 100644 index 0000000..6315fc9 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155058.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155101.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155101.jsx new file mode 100644 index 0000000..3c6425a --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155101.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.props.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155106.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155106.jsx new file mode 100644 index 0000000..707299c --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155106.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.props.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155107.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155107.jsx new file mode 100644 index 0000000..45a17a5 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155107.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.props.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155115.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155115.jsx new file mode 100644 index 0000000..a7e4826 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155115.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +class HorizontalToolbar extends React.Component { + // constructor(props) { + // super(props); + // } + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.props.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155138.jsx b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155138.jsx new file mode 100644 index 0000000..a563d86 --- /dev/null +++ b/.history/src/components/HorizontalToolbar/HorizontalToolbar_20200225155138.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +class HorizontalToolbar extends React.Component { + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.props.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/Tools/Tool_20200221134936.jsx b/.history/src/components/Tools/Tool_20200221134936.jsx new file mode 100644 index 0000000..5c3440e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200221134936.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162300.jsx b/.history/src/components/Tools/Tool_20200224162300.jsx new file mode 100644 index 0000000..906d6e4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162300.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162302.jsx b/.history/src/components/Tools/Tool_20200224162302.jsx new file mode 100644 index 0000000..906d6e4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162302.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162305.jsx b/.history/src/components/Tools/Tool_20200224162305.jsx new file mode 100644 index 0000000..f885815 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162305.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool ex = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162307.jsx b/.history/src/components/Tools/Tool_20200224162307.jsx new file mode 100644 index 0000000..b9c9f6f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162307.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162309.jsx b/.history/src/components/Tools/Tool_20200224162309.jsx new file mode 100644 index 0000000..f8d7bf4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162309.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends Cm = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162311.jsx b/.history/src/components/Tools/Tool_20200224162311.jsx new file mode 100644 index 0000000..081467f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162311.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { Component } from 'react'; +class Tool extends Component = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162315.jsx b/.history/src/components/Tools/Tool_20200224162315.jsx new file mode 100644 index 0000000..af7e1f7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162315.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +import from 'react'; +class Tool extends Component = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162317.jsx b/.history/src/components/Tools/Tool_20200224162317.jsx new file mode 100644 index 0000000..16cdb63 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162317.jsx @@ -0,0 +1,12 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +import from 'react'; +class Tool extends Component = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162319.jsx b/.history/src/components/Tools/Tool_20200224162319.jsx new file mode 100644 index 0000000..a833be3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162319.jsx @@ -0,0 +1,11 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162323.jsx b/.history/src/components/Tools/Tool_20200224162323.jsx new file mode 100644 index 0000000..2a7ae45 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162323.jsx @@ -0,0 +1,11 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162327.jsx b/.history/src/components/Tools/Tool_20200224162327.jsx new file mode 100644 index 0000000..7f7f8bf --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162327.jsx @@ -0,0 +1,13 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + render(){ + + } + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162329.jsx b/.history/src/components/Tools/Tool_20200224162329.jsx new file mode 100644 index 0000000..2c278ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162329.jsx @@ -0,0 +1,13 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + render(){ + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162333.jsx b/.history/src/components/Tools/Tool_20200224162333.jsx new file mode 100644 index 0000000..1f61fd7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162333.jsx @@ -0,0 +1,14 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + con + render(){ + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162338.jsx b/.history/src/components/Tools/Tool_20200224162338.jsx new file mode 100644 index 0000000..1745abb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162338.jsx @@ -0,0 +1,16 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props){ + + } + render(){ + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162341.jsx b/.history/src/components/Tools/Tool_20200224162341.jsx new file mode 100644 index 0000000..243563f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162341.jsx @@ -0,0 +1,16 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props){ + super(props) + } + render(){ + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162343.jsx b/.history/src/components/Tools/Tool_20200224162343.jsx new file mode 100644 index 0000000..0683f23 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162343.jsx @@ -0,0 +1,16 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162347.jsx b/.history/src/components/Tools/Tool_20200224162347.jsx new file mode 100644 index 0000000..4b09ddc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162347.jsx @@ -0,0 +1,16 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162348.jsx b/.history/src/components/Tools/Tool_20200224162348.jsx new file mode 100644 index 0000000..ec2e509 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162348.jsx @@ -0,0 +1,16 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162420.jsx b/.history/src/components/Tools/Tool_20200224162420.jsx new file mode 100644 index 0000000..f20e9e7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162420.jsx @@ -0,0 +1,17 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.iconClassName) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162509.jsx b/.history/src/components/Tools/Tool_20200224162509.jsx new file mode 100644 index 0000000..9655c15 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162509.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.iconClassName) + props.to + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162517.jsx b/.history/src/components/Tools/Tool_20200224162517.jsx new file mode 100644 index 0000000..dd550dc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162517.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.iconClassName) + props.toggleCrop(); + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162525.jsx b/.history/src/components/Tools/Tool_20200224162525.jsx new file mode 100644 index 0000000..f357df9 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162525.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.iconClassName) + props.toggleCrop; + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162530.jsx b/.history/src/components/Tools/Tool_20200224162530.jsx new file mode 100644 index 0000000..ec0dcd2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162530.jsx @@ -0,0 +1,17 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162635.jsx b/.history/src/components/Tools/Tool_20200224162635.jsx new file mode 100644 index 0000000..ba4bf92 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162635.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + props.toggleCropper + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162638.jsx b/.history/src/components/Tools/Tool_20200224162638.jsx new file mode 100644 index 0000000..6f43c90 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162638.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + props.toggleCrop() + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162646.jsx b/.history/src/components/Tools/Tool_20200224162646.jsx new file mode 100644 index 0000000..f5a5fe5 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162646.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + props.toggleCrop + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162650.jsx b/.history/src/components/Tools/Tool_20200224162650.jsx new file mode 100644 index 0000000..d7292cb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162650.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + // props.toggleCrop + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162704.jsx b/.history/src/components/Tools/Tool_20200224162704.jsx new file mode 100644 index 0000000..a9f0986 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162704.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162706.jsx b/.history/src/components/Tools/Tool_20200224162706.jsx new file mode 100644 index 0000000..7caaa34 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162706.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162714.jsx b/.history/src/components/Tools/Tool_20200224162714.jsx new file mode 100644 index 0000000..4af352b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162714.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162716.jsx b/.history/src/components/Tools/Tool_20200224162716.jsx new file mode 100644 index 0000000..1733a4d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162716.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162755.jsx b/.history/src/components/Tools/Tool_20200224162755.jsx new file mode 100644 index 0000000..5981077 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162755.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162759.jsx b/.history/src/components/Tools/Tool_20200224162759.jsx new file mode 100644 index 0000000..dc0b9ea --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162759.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162834.jsx b/.history/src/components/Tools/Tool_20200224162834.jsx new file mode 100644 index 0000000..a098c1c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162834.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.event = this + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162838.jsx b/.history/src/components/Tools/Tool_20200224162838.jsx new file mode 100644 index 0000000..d5a5761 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162838.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.event = props.event + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162842.jsx b/.history/src/components/Tools/Tool_20200224162842.jsx new file mode 100644 index 0000000..1be34a7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162842.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.event = props.event + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162843.jsx b/.history/src/components/Tools/Tool_20200224162843.jsx new file mode 100644 index 0000000..1be34a7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162843.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.event = props.event + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162856.jsx b/.history/src/components/Tools/Tool_20200224162856.jsx new file mode 100644 index 0000000..828f9ef --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162856.jsx @@ -0,0 +1,17 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162857.jsx b/.history/src/components/Tools/Tool_20200224162857.jsx new file mode 100644 index 0000000..af3bcba --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162857.jsx @@ -0,0 +1,17 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224162911.jsx b/.history/src/components/Tools/Tool_20200224162911.jsx new file mode 100644 index 0000000..7b05f49 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224162911.jsx @@ -0,0 +1,17 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164819.jsx b/.history/src/components/Tools/Tool_20200224164819.jsx new file mode 100644 index 0000000..02beb09 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164819.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + if(this.) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164821.jsx b/.history/src/components/Tools/Tool_20200224164821.jsx new file mode 100644 index 0000000..5edfb5a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164821.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + if() + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164825.jsx b/.history/src/components/Tools/Tool_20200224164825.jsx new file mode 100644 index 0000000..7811878 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164825.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164924.jsx b/.history/src/components/Tools/Tool_20200224164924.jsx new file mode 100644 index 0000000..8789492 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164924.jsx @@ -0,0 +1,19 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + compo + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164928.jsx b/.history/src/components/Tools/Tool_20200224164928.jsx new file mode 100644 index 0000000..1f8a1ab --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164928.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + componentDidMount(){ + if() + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164930.jsx b/.history/src/components/Tools/Tool_20200224164930.jsx new file mode 100644 index 0000000..b7cf393 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164930.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + componentDidMount(){ + if(props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164933.jsx b/.history/src/components/Tools/Tool_20200224164933.jsx new file mode 100644 index 0000000..a322b2f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164933.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + componentDidMount(){ + if(!this.props) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164937.jsx b/.history/src/components/Tools/Tool_20200224164937.jsx new file mode 100644 index 0000000..61d70ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164937.jsx @@ -0,0 +1,23 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + + } + componentDidMount(){ + if(!this.props.event){ + + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164948.jsx b/.history/src/components/Tools/Tool_20200224164948.jsx new file mode 100644 index 0000000..cf78b58 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164948.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224164952.jsx b/.history/src/components/Tools/Tool_20200224164952.jsx new file mode 100644 index 0000000..4f7f459 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224164952.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165028.jsx b/.history/src/components/Tools/Tool_20200224165028.jsx new file mode 100644 index 0000000..be8c307 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165028.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165030.jsx b/.history/src/components/Tools/Tool_20200224165030.jsx new file mode 100644 index 0000000..3a82b3b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165030.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165034.jsx b/.history/src/components/Tools/Tool_20200224165034.jsx new file mode 100644 index 0000000..e0f778d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165034.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165042.jsx b/.history/src/components/Tools/Tool_20200224165042.jsx new file mode 100644 index 0000000..986dc31 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165042.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165044.jsx b/.history/src/components/Tools/Tool_20200224165044.jsx new file mode 100644 index 0000000..4e4c66a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165044.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165054.jsx b/.history/src/components/Tools/Tool_20200224165054.jsx new file mode 100644 index 0000000..db09f44 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165054.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165056.jsx b/.history/src/components/Tools/Tool_20200224165056.jsx new file mode 100644 index 0000000..7d2b38c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165056.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165112.jsx b/.history/src/components/Tools/Tool_20200224165112.jsx new file mode 100644 index 0000000..83c7954 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165112.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165118.jsx b/.history/src/components/Tools/Tool_20200224165118.jsx new file mode 100644 index 0000000..d94c11a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165118.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165123.jsx b/.history/src/components/Tools/Tool_20200224165123.jsx new file mode 100644 index 0000000..b47a38e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165123.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165126.jsx b/.history/src/components/Tools/Tool_20200224165126.jsx new file mode 100644 index 0000000..6d51484 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165126.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224165142.jsx b/.history/src/components/Tools/Tool_20200224165142.jsx new file mode 100644 index 0000000..6d51484 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224165142.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170029.jsx b/.history/src/components/Tools/Tool_20200224170029.jsx new file mode 100644 index 0000000..a6b52cb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170029.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170031.jsx b/.history/src/components/Tools/Tool_20200224170031.jsx new file mode 100644 index 0000000..6d51484 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170031.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170037.jsx b/.history/src/components/Tools/Tool_20200224170037.jsx new file mode 100644 index 0000000..efe98ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170037.jsx @@ -0,0 +1,25 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + componentDidMount(){ + if(!this.props.event){ + this.setState({cropper:true}) + } + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170216.jsx b/.history/src/components/Tools/Tool_20200224170216.jsx new file mode 100644 index 0000000..991e726 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170216.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170220.jsx b/.history/src/components/Tools/Tool_20200224170220.jsx new file mode 100644 index 0000000..b3c6ea0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170220.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170223.jsx b/.history/src/components/Tools/Tool_20200224170223.jsx new file mode 100644 index 0000000..9cbb5eb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170223.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170229.jsx b/.history/src/components/Tools/Tool_20200224170229.jsx new file mode 100644 index 0000000..11ffad2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170229.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170230.jsx b/.history/src/components/Tools/Tool_20200224170230.jsx new file mode 100644 index 0000000..a1f1038 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170230.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170240.jsx b/.history/src/components/Tools/Tool_20200224170240.jsx new file mode 100644 index 0000000..6b57ff8 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170240.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + this.state = { + cropper: false + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170246.jsx b/.history/src/components/Tools/Tool_20200224170246.jsx new file mode 100644 index 0000000..3846541 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170246.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170247.jsx b/.history/src/components/Tools/Tool_20200224170247.jsx new file mode 100644 index 0000000..65da760 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170247.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170305.jsx b/.history/src/components/Tools/Tool_20200224170305.jsx new file mode 100644 index 0000000..cef8822 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170305.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170443.jsx b/.history/src/components/Tools/Tool_20200224170443.jsx new file mode 100644 index 0000000..e08c8a6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170443.jsx @@ -0,0 +1,20 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + componentDidMount(){ + + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170449.jsx b/.history/src/components/Tools/Tool_20200224170449.jsx new file mode 100644 index 0000000..901d9e0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170449.jsx @@ -0,0 +1,20 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + componentDidMount(){ + console.log(this.props.event) + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170452.jsx b/.history/src/components/Tools/Tool_20200224170452.jsx new file mode 100644 index 0000000..1b7e8c0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170452.jsx @@ -0,0 +1,20 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props) + } + componentDidMount(){ + console.log(this.props.event,"KKK") + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170510.jsx b/.history/src/components/Tools/Tool_20200224170510.jsx new file mode 100644 index 0000000..13b2b79 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170510.jsx @@ -0,0 +1,20 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + } + componentDidMount(){ + console.log(this.props.event,"KKK") + } + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170512.jsx b/.history/src/components/Tools/Tool_20200224170512.jsx new file mode 100644 index 0000000..4e9c836 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170512.jsx @@ -0,0 +1,18 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170609.jsx b/.history/src/components/Tools/Tool_20200224170609.jsx new file mode 100644 index 0000000..85e3211 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170609.jsx @@ -0,0 +1,19 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + if(prop) + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170614.jsx b/.history/src/components/Tools/Tool_20200224170614.jsx new file mode 100644 index 0000000..16ef4c2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170614.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170632.jsx b/.history/src/components/Tools/Tool_20200224170632.jsx new file mode 100644 index 0000000..40838fd --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170632.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170635.jsx b/.history/src/components/Tools/Tool_20200224170635.jsx new file mode 100644 index 0000000..6c53a9f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170635.jsx @@ -0,0 +1,21 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170638.jsx b/.history/src/components/Tools/Tool_20200224170638.jsx new file mode 100644 index 0000000..4ee6a2d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170638.jsx @@ -0,0 +1,22 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + this. + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170645.jsx b/.history/src/components/Tools/Tool_20200224170645.jsx new file mode 100644 index 0000000..0e439e8 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170645.jsx @@ -0,0 +1,22 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + this.eventOnClick = + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170649.jsx b/.history/src/components/Tools/Tool_20200224170649.jsx new file mode 100644 index 0000000..26a2b84 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170649.jsx @@ -0,0 +1,23 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + console.log(props.event) + this.eventOnClick = props.event; + + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170650.jsx b/.history/src/components/Tools/Tool_20200224170650.jsx new file mode 100644 index 0000000..3d57d2e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170650.jsx @@ -0,0 +1,23 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170652.jsx b/.history/src/components/Tools/Tool_20200224170652.jsx new file mode 100644 index 0000000..ec54b9b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170652.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + console.log(props.event) + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170658.jsx b/.history/src/components/Tools/Tool_20200224170658.jsx new file mode 100644 index 0000000..8dec04a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170658.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
+ +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170705.jsx b/.history/src/components/Tools/Tool_20200224170705.jsx new file mode 100644 index 0000000..85ab515 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170705.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.e} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170707.jsx b/.history/src/components/Tools/Tool_20200224170707.jsx new file mode 100644 index 0000000..530d895 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170707.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.event} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170708.jsx b/.history/src/components/Tools/Tool_20200224170708.jsx new file mode 100644 index 0000000..3b9e943 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170708.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.eventOnClick} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170722.jsx b/.history/src/components/Tools/Tool_20200224170722.jsx new file mode 100644 index 0000000..93108fe --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170722.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.eventOnClick} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170725.jsx b/.history/src/components/Tools/Tool_20200224170725.jsx new file mode 100644 index 0000000..534d4ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170725.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + this.eventOnClick = + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.eventOnClick} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170729.jsx b/.history/src/components/Tools/Tool_20200224170729.jsx new file mode 100644 index 0000000..5e6785c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170729.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + this.eventOnClick = props.cropper + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.eventOnClick} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170730.jsx b/.history/src/components/Tools/Tool_20200224170730.jsx new file mode 100644 index 0000000..c2b1374 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170730.jsx @@ -0,0 +1,24 @@ +import React, { Component } from 'react'; +import style from './Tool.module.css'; +class Tool extends Component { + constructor(props) { + super(props) + + this.eventOnClick = props.event; + + if(props.cropper){ + this.eventOnClick = props.cropper; + } + console.log(this.eventOnClick,"LLL") + } + + render() { + return ( +
this.eventOnClick} > + +
+ ); + } + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170900.jsx b/.history/src/components/Tools/Tool_20200224170900.jsx new file mode 100644 index 0000000..5c3440e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170900.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224170901.jsx b/.history/src/components/Tools/Tool_20200224170901.jsx new file mode 100644 index 0000000..5c3440e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224170901.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171020.jsx b/.history/src/components/Tools/Tool_20200224171020.jsx new file mode 100644 index 0000000..c1172ba --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171020.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + props.toggleCrop() + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171030.jsx b/.history/src/components/Tools/Tool_20200224171030.jsx new file mode 100644 index 0000000..3c38e79 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171030.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171045.jsx b/.history/src/components/Tools/Tool_20200224171045.jsx new file mode 100644 index 0000000..dca193a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171045.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + props.to + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171048.jsx b/.history/src/components/Tools/Tool_20200224171048.jsx new file mode 100644 index 0000000..ef1d85b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171048.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + props.toggleCrop + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171049.jsx b/.history/src/components/Tools/Tool_20200224171049.jsx new file mode 100644 index 0000000..9a1461e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171049.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + props.toggleCrop; + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171056.jsx b/.history/src/components/Tools/Tool_20200224171056.jsx new file mode 100644 index 0000000..35c00da --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171056.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + props.toggleCrop(); + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171057.jsx b/.history/src/components/Tools/Tool_20200224171057.jsx new file mode 100644 index 0000000..35c00da --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171057.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + props.toggleCrop(); + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171205.jsx b/.history/src/components/Tools/Tool_20200224171205.jsx new file mode 100644 index 0000000..9a1461e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171205.jsx @@ -0,0 +1,12 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + props.toggleCrop; + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171209.jsx b/.history/src/components/Tools/Tool_20200224171209.jsx new file mode 100644 index 0000000..3c38e79 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171209.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171900.jsx b/.history/src/components/Tools/Tool_20200224171900.jsx new file mode 100644 index 0000000..42358c3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171900.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171905.jsx b/.history/src/components/Tools/Tool_20200224171905.jsx new file mode 100644 index 0000000..7c5bb96 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171905.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224171908.jsx b/.history/src/components/Tools/Tool_20200224171908.jsx new file mode 100644 index 0000000..e90f070 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224171908.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172021.jsx b/.history/src/components/Tools/Tool_20200224172021.jsx new file mode 100644 index 0000000..7520400 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172021.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172028.jsx b/.history/src/components/Tools/Tool_20200224172028.jsx new file mode 100644 index 0000000..3c38e79 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172028.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172626.jsx b/.history/src/components/Tools/Tool_20200224172626.jsx new file mode 100644 index 0000000..ca515de --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172626.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172654.jsx b/.history/src/components/Tools/Tool_20200224172654.jsx new file mode 100644 index 0000000..d32f523 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172654.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172715.jsx b/.history/src/components/Tools/Tool_20200224172715.jsx new file mode 100644 index 0000000..67814c7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172715.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172717.jsx b/.history/src/components/Tools/Tool_20200224172717.jsx new file mode 100644 index 0000000..49fd72d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172717.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172720.jsx b/.history/src/components/Tools/Tool_20200224172720.jsx new file mode 100644 index 0000000..4129863 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172720.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172750.jsx b/.history/src/components/Tools/Tool_20200224172750.jsx new file mode 100644 index 0000000..41100ec --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172750.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172755.jsx b/.history/src/components/Tools/Tool_20200224172755.jsx new file mode 100644 index 0000000..364556f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172755.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172814.jsx b/.history/src/components/Tools/Tool_20200224172814.jsx new file mode 100644 index 0000000..8736ec7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172814.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172817.jsx b/.history/src/components/Tools/Tool_20200224172817.jsx new file mode 100644 index 0000000..8736ec7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172817.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172823.jsx b/.history/src/components/Tools/Tool_20200224172823.jsx new file mode 100644 index 0000000..364556f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172823.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172824.jsx b/.history/src/components/Tools/Tool_20200224172824.jsx new file mode 100644 index 0000000..7622aa7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172824.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172829.jsx b/.history/src/components/Tools/Tool_20200224172829.jsx new file mode 100644 index 0000000..364556f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172829.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172837.jsx b/.history/src/components/Tools/Tool_20200224172837.jsx new file mode 100644 index 0000000..8736ec7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172837.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172852.jsx b/.history/src/components/Tools/Tool_20200224172852.jsx new file mode 100644 index 0000000..e64a231 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172852.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + console.log(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172924.jsx b/.history/src/components/Tools/Tool_20200224172924.jsx new file mode 100644 index 0000000..758e4a1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172924.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props) + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172926.jsx b/.history/src/components/Tools/Tool_20200224172926.jsx new file mode 100644 index 0000000..3f2ba58 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172926.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172933.jsx b/.history/src/components/Tools/Tool_20200224172933.jsx new file mode 100644 index 0000000..58e537c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172933.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172935.jsx b/.history/src/components/Tools/Tool_20200224172935.jsx new file mode 100644 index 0000000..a822044 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172935.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172937.jsx b/.history/src/components/Tools/Tool_20200224172937.jsx new file mode 100644 index 0000000..dbd438b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172937.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +cropper ={true} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172939.jsx b/.history/src/components/Tools/Tool_20200224172939.jsx new file mode 100644 index 0000000..3f2ba58 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172939.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172942.jsx b/.history/src/components/Tools/Tool_20200224172942.jsx new file mode 100644 index 0000000..32c8e13 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172942.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224172945.jsx b/.history/src/components/Tools/Tool_20200224172945.jsx new file mode 100644 index 0000000..a4f095a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224172945.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props){ + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173036.jsx b/.history/src/components/Tools/Tool_20200224173036.jsx new file mode 100644 index 0000000..de5d977 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173036.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.t){ + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173041.jsx b/.history/src/components/Tools/Tool_20200224173041.jsx new file mode 100644 index 0000000..a7cf5af --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173041.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173104.jsx b/.history/src/components/Tools/Tool_20200224173104.jsx new file mode 100644 index 0000000..c456fc4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173104.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + console.log("AA") + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173136.jsx b/.history/src/components/Tools/Tool_20200224173136.jsx new file mode 100644 index 0000000..adf7425 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173136.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173141.jsx b/.history/src/components/Tools/Tool_20200224173141.jsx new file mode 100644 index 0000000..bc53654 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173141.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + props.toggleCroppe + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173142.jsx b/.history/src/components/Tools/Tool_20200224173142.jsx new file mode 100644 index 0000000..9e83be1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173142.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + props.toggleCropper + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173156.jsx b/.history/src/components/Tools/Tool_20200224173156.jsx new file mode 100644 index 0000000..c39c371 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173156.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + props.toggleCropper + } + let + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173201.jsx b/.history/src/components/Tools/Tool_20200224173201.jsx new file mode 100644 index 0000000..d9884e4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173201.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + if(props.toggleCropper){ + props.toggleCropper + } + let cropper = () => { + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173210.jsx b/.history/src/components/Tools/Tool_20200224173210.jsx new file mode 100644 index 0000000..f51b55e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173210.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173215.jsx b/.history/src/components/Tools/Tool_20200224173215.jsx new file mode 100644 index 0000000..e57adef --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173215.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173224.jsx b/.history/src/components/Tools/Tool_20200224173224.jsx new file mode 100644 index 0000000..b41278a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173224.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173309.jsx b/.history/src/components/Tools/Tool_20200224173309.jsx new file mode 100644 index 0000000..f2a6771 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173309.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + + let cropper = () => { + if(props.toggleCropper){ + let props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173313.jsx b/.history/src/components/Tools/Tool_20200224173313.jsx new file mode 100644 index 0000000..587db28 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173313.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropp + let cropper = () => { + if(props.toggleCropper){ + let props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173317.jsx b/.history/src/components/Tools/Tool_20200224173317.jsx new file mode 100644 index 0000000..0917492 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173317.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = + let cropper = () => { + if(props.toggleCropper){ + let props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173319.jsx b/.history/src/components/Tools/Tool_20200224173319.jsx new file mode 100644 index 0000000..5f766e3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173319.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = fa + let cropper = () => { + if(props.toggleCropper){ + let props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173321.jsx b/.history/src/components/Tools/Tool_20200224173321.jsx new file mode 100644 index 0000000..c20fc36 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173321.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = false; + let cropper = () => { + if(props.toggleCropper){ + let props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173330.jsx b/.history/src/components/Tools/Tool_20200224173330.jsx new file mode 100644 index 0000000..e240ae2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173330.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = false; + let cropper = () => { + if(props.toggleCropper){ + croppedImage = props.toggleCropper() + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173523.jsx b/.history/src/components/Tools/Tool_20200224173523.jsx new file mode 100644 index 0000000..f5eac7a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173523.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = false; + let cropper = () => { + if(props.toggleCropper){ + croppedImage = props.toggleCropper() + } + else{ + + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173527.jsx b/.history/src/components/Tools/Tool_20200224173527.jsx new file mode 100644 index 0000000..d6c3ffc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173527.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + else{ + + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173534.jsx b/.history/src/components/Tools/Tool_20200224173534.jsx new file mode 100644 index 0000000..d6c3ffc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173534.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let croppedImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + else{ + + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173537.jsx b/.history/src/components/Tools/Tool_20200224173537.jsx new file mode 100644 index 0000000..840d90d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173537.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + else{ + + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173541.jsx b/.history/src/components/Tools/Tool_20200224173541.jsx new file mode 100644 index 0000000..0388e50 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173541.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + else{ + + } + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173553.jsx b/.history/src/components/Tools/Tool_20200224173553.jsx new file mode 100644 index 0000000..9dde00d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173553.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173555.jsx b/.history/src/components/Tools/Tool_20200224173555.jsx new file mode 100644 index 0000000..910194e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173555.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + props.toggleCropper() + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173557.jsx b/.history/src/components/Tools/Tool_20200224173557.jsx new file mode 100644 index 0000000..3fc3392 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173557.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173600.jsx b/.history/src/components/Tools/Tool_20200224173600.jsx new file mode 100644 index 0000000..f736cd0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173600.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173602.jsx b/.history/src/components/Tools/Tool_20200224173602.jsx new file mode 100644 index 0000000..de7d605 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173602.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173606.jsx b/.history/src/components/Tools/Tool_20200224173606.jsx new file mode 100644 index 0000000..5aa0cd4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173606.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173611.jsx b/.history/src/components/Tools/Tool_20200224173611.jsx new file mode 100644 index 0000000..6359f5b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173611.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173619.jsx b/.history/src/components/Tools/Tool_20200224173619.jsx new file mode 100644 index 0000000..be8b786 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173619.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + console.log("LLL") + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173622.jsx b/.history/src/components/Tools/Tool_20200224173622.jsx new file mode 100644 index 0000000..6628c51 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173622.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + console.log("LLL") + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173718.jsx b/.history/src/components/Tools/Tool_20200224173718.jsx new file mode 100644 index 0000000..0b2f6d5 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173718.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if() + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173721.jsx b/.history/src/components/Tools/Tool_20200224173721.jsx new file mode 100644 index 0000000..3071ea0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173721.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.) + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173722.jsx b/.history/src/components/Tools/Tool_20200224173722.jsx new file mode 100644 index 0000000..e982ea2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173722.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper) + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173723.jsx b/.history/src/components/Tools/Tool_20200224173723.jsx new file mode 100644 index 0000000..b452637 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173723.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + + } + props.toggleCropper() + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173725.jsx b/.history/src/components/Tools/Tool_20200224173725.jsx new file mode 100644 index 0000000..9bffea8 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173725.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173727.jsx b/.history/src/components/Tools/Tool_20200224173727.jsx new file mode 100644 index 0000000..5a88462 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173727.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173745.jsx b/.history/src/components/Tools/Tool_20200224173745.jsx new file mode 100644 index 0000000..8be6056 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173745.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} +// style={!props.croppingImage && props.cropper ? {display: 'block'} : { display: 'none' }} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173751.jsx b/.history/src/components/Tools/Tool_20200224173751.jsx new file mode 100644 index 0000000..4953aa6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173751.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173752.jsx b/.history/src/components/Tools/Tool_20200224173752.jsx new file mode 100644 index 0000000..9050394 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173752.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173754.jsx b/.history/src/components/Tools/Tool_20200224173754.jsx new file mode 100644 index 0000000..a03453a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173754.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173804.jsx b/.history/src/components/Tools/Tool_20200224173804.jsx new file mode 100644 index 0000000..b61d7fa --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173804.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173812.jsx b/.history/src/components/Tools/Tool_20200224173812.jsx new file mode 100644 index 0000000..8e50da8 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173812.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173827.jsx b/.history/src/components/Tools/Tool_20200224173827.jsx new file mode 100644 index 0000000..6079644 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173827.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173831.jsx b/.history/src/components/Tools/Tool_20200224173831.jsx new file mode 100644 index 0000000..da07aa5 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173831.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173844.jsx b/.history/src/components/Tools/Tool_20200224173844.jsx new file mode 100644 index 0000000..4e8f3d7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173844.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173845.jsx b/.history/src/components/Tools/Tool_20200224173845.jsx new file mode 100644 index 0000000..75705e1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173845.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173911.jsx b/.history/src/components/Tools/Tool_20200224173911.jsx new file mode 100644 index 0000000..ad813c6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173911.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173913.jsx b/.history/src/components/Tools/Tool_20200224173913.jsx new file mode 100644 index 0000000..71f942f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173913.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173915.jsx b/.history/src/components/Tools/Tool_20200224173915.jsx new file mode 100644 index 0000000..e4faace --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173915.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173935.jsx b/.history/src/components/Tools/Tool_20200224173935.jsx new file mode 100644 index 0000000..5a1db0a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173935.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173936.jsx b/.history/src/components/Tools/Tool_20200224173936.jsx new file mode 100644 index 0000000..81a20f7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173936.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224173938.jsx b/.history/src/components/Tools/Tool_20200224173938.jsx new file mode 100644 index 0000000..f73bbfb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224173938.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174025.jsx b/.history/src/components/Tools/Tool_20200224174025.jsx new file mode 100644 index 0000000..d86e1e5 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174025.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + console.log(props.event,) + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174028.jsx b/.history/src/components/Tools/Tool_20200224174028.jsx new file mode 100644 index 0000000..dffaaeb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174028.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + console.log(props.event,props.toggleCropper) + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174320.jsx b/.history/src/components/Tools/Tool_20200224174320.jsx new file mode 100644 index 0000000..a7c0e01 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174320.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + } + + } + console.log(props.event,props.toggleCropper) + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174324.jsx b/.history/src/components/Tools/Tool_20200224174324.jsx new file mode 100644 index 0000000..3e4e109 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174324.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x) + } + + } + console.log(props.event,props.toggleCropper) + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174333.jsx b/.history/src/components/Tools/Tool_20200224174333.jsx new file mode 100644 index 0000000..5b53a72 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174333.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + console.log(props.event,props.toggleCropper) + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174335.jsx b/.history/src/components/Tools/Tool_20200224174335.jsx new file mode 100644 index 0000000..a1f018c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174335.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174456.jsx b/.history/src/components/Tools/Tool_20200224174456.jsx new file mode 100644 index 0000000..b0b4e75 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174456.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174513.jsx b/.history/src/components/Tools/Tool_20200224174513.jsx new file mode 100644 index 0000000..47492d1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174513.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174515.jsx b/.history/src/components/Tools/Tool_20200224174515.jsx new file mode 100644 index 0000000..d43e5c6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174515.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174517.jsx b/.history/src/components/Tools/Tool_20200224174517.jsx new file mode 100644 index 0000000..0722ed6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174517.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174522.jsx b/.history/src/components/Tools/Tool_20200224174522.jsx new file mode 100644 index 0000000..d45201c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174522.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + console.log(x,"LLL") + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174526.jsx b/.history/src/components/Tools/Tool_20200224174526.jsx new file mode 100644 index 0000000..40ef272 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174526.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174534.jsx b/.history/src/components/Tools/Tool_20200224174534.jsx new file mode 100644 index 0000000..226d14a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174534.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + let x = props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174541.jsx b/.history/src/components/Tools/Tool_20200224174541.jsx new file mode 100644 index 0000000..7939db0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174541.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropperImage = false; + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174544.jsx b/.history/src/components/Tools/Tool_20200224174544.jsx new file mode 100644 index 0000000..adfef51 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174544.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174557.jsx b/.history/src/components/Tools/Tool_20200224174557.jsx new file mode 100644 index 0000000..231fc16 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174557.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool = (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174605.jsx b/.history/src/components/Tools/Tool_20200224174605.jsx new file mode 100644 index 0000000..415945c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174605.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component (props) => { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174608.jsx b/.history/src/components/Tools/Tool_20200224174608.jsx new file mode 100644 index 0000000..3f5363f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174608.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174612.jsx b/.history/src/components/Tools/Tool_20200224174612.jsx new file mode 100644 index 0000000..08ebe5f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174612.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + render(){ + + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174614.jsx b/.history/src/components/Tools/Tool_20200224174614.jsx new file mode 100644 index 0000000..eb39fb4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174614.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + let cropper = () => { + if(props.toggleCropper){ + props.toggleCropper() + } + + } + render(){ + return ( +
+ +
+ ); + } + } + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174616.jsx b/.history/src/components/Tools/Tool_20200224174616.jsx new file mode 100644 index 0000000..bff337e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174616.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + let cropper = () => { + if (props.toggleCropper) { + props.toggleCropper() + } + +} +render(){ + return ( +
+ +
+ ); +} + } + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174620.jsx b/.history/src/components/Tools/Tool_20200224174620.jsx new file mode 100644 index 0000000..55fa8d7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174620.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + cropper = () => { + if (props.toggleCropper) { + props.toggleCropper() + } + +} +render(){ + return ( +
+ +
+ ); +} + } + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174622.jsx b/.history/src/components/Tools/Tool_20200224174622.jsx new file mode 100644 index 0000000..79e4e90 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174622.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + cropper = () => { + if (props.toggleCropper) { + props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174633.jsx b/.history/src/components/Tools/Tool_20200224174633.jsx new file mode 100644 index 0000000..85a2428 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174633.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor() + cropper = () => { + if (props.toggleCropper) { + props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174637.jsx b/.history/src/components/Tools/Tool_20200224174637.jsx new file mode 100644 index 0000000..4a59287 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174637.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(){ + super(props) + } + cropper = () => { + if (props.toggleCropper) { + props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174640.jsx b/.history/src/components/Tools/Tool_20200224174640.jsx new file mode 100644 index 0000000..b9db50d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174640.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (props.toggleCropper) { + props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174648.jsx b/.history/src/components/Tools/Tool_20200224174648.jsx new file mode 100644 index 0000000..fc1b6dc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174648.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174651.jsx b/.history/src/components/Tools/Tool_20200224174651.jsx new file mode 100644 index 0000000..932fcfd --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174651.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174655.jsx b/.history/src/components/Tools/Tool_20200224174655.jsx new file mode 100644 index 0000000..620c00d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174655.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174656.jsx b/.history/src/components/Tools/Tool_20200224174656.jsx new file mode 100644 index 0000000..66b6c7d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174656.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174659.jsx b/.history/src/components/Tools/Tool_20200224174659.jsx new file mode 100644 index 0000000..e948e91 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174659.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174709.jsx b/.history/src/components/Tools/Tool_20200224174709.jsx new file mode 100644 index 0000000..e236ee1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174709.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + } + componentDidMount() + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174711.jsx b/.history/src/components/Tools/Tool_20200224174711.jsx new file mode 100644 index 0000000..38fd0b8 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174711.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + } + componentDidMount(){ + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174750.jsx b/.history/src/components/Tools/Tool_20200224174750.jsx new file mode 100644 index 0000000..5e7ecc5 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174750.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.) + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + } + componentDidMount(){ + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174802.jsx b/.history/src/components/Tools/Tool_20200224174802.jsx new file mode 100644 index 0000000..322a21d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174802.jsx @@ -0,0 +1,29 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + + } + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + } + componentDidMount(){ + + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174806.jsx b/.history/src/components/Tools/Tool_20200224174806.jsx new file mode 100644 index 0000000..a269664 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174806.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + + } + } + cropper = () => { + if (this.props.toggleCropper) { + this.props.toggleCropper() + } + } + + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174809.jsx b/.history/src/components/Tools/Tool_20200224174809.jsx new file mode 100644 index 0000000..af3ed8b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174809.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + + } + } + cropper = () => { + } + + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174814.jsx b/.history/src/components/Tools/Tool_20200224174814.jsx new file mode 100644 index 0000000..d030ff5 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174814.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper + } + } + cropper = () => { + } + + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174822.jsx b/.history/src/components/Tools/Tool_20200224174822.jsx new file mode 100644 index 0000000..1d8c4d7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174822.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper + } + } + cropper = () => { + } + + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174826.jsx b/.history/src/components/Tools/Tool_20200224174826.jsx new file mode 100644 index 0000000..d148d35 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174826.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper() + } + } + cropper = () => { + } + + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174837.jsx b/.history/src/components/Tools/Tool_20200224174837.jsx new file mode 100644 index 0000000..c1ec1a2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174837.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper(true) + } + } + cropper = () => { + } + + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174840.jsx b/.history/src/components/Tools/Tool_20200224174840.jsx new file mode 100644 index 0000000..5985c25 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174840.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +import { render } from '@testing-library/react'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper(true) + } + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224174847.jsx b/.history/src/components/Tools/Tool_20200224174847.jsx new file mode 100644 index 0000000..0de9ba1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224174847.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper(true) + } + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175008.jsx b/.history/src/components/Tools/Tool_20200224175008.jsx new file mode 100644 index 0000000..d1777cb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175008.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper(props.) + } + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175011.jsx b/.history/src/components/Tools/Tool_20200224175011.jsx new file mode 100644 index 0000000..29cae1f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175011.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175147.jsx b/.history/src/components/Tools/Tool_20200224175147.jsx new file mode 100644 index 0000000..2175554 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175147.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} + + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175152.jsx b/.history/src/components/Tools/Tool_20200224175152.jsx new file mode 100644 index 0000000..024fbde --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175152.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175220.jsx b/.history/src/components/Tools/Tool_20200224175220.jsx new file mode 100644 index 0000000..db83f55 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175220.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175223.jsx b/.history/src/components/Tools/Tool_20200224175223.jsx new file mode 100644 index 0000000..52ac301 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175223.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175300.jsx b/.history/src/components/Tools/Tool_20200224175300.jsx new file mode 100644 index 0000000..593e566 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175300.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175309.jsx b/.history/src/components/Tools/Tool_20200224175309.jsx new file mode 100644 index 0000000..d1e3119 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175309.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175311.jsx b/.history/src/components/Tools/Tool_20200224175311.jsx new file mode 100644 index 0000000..0611425 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175311.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175315.jsx b/.history/src/components/Tools/Tool_20200224175315.jsx new file mode 100644 index 0000000..c6cad5b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175315.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175316.jsx b/.history/src/components/Tools/Tool_20200224175316.jsx new file mode 100644 index 0000000..972b6ec --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175316.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175328.jsx b/.history/src/components/Tools/Tool_20200224175328.jsx new file mode 100644 index 0000000..024fbde --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175328.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props){ + super(props) + if(props.toggleCropper && props.event){ + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175425.jsx b/.history/src/components/Tools/Tool_20200224175425.jsx new file mode 100644 index 0000000..371bb4d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175425.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224175952.jsx b/.history/src/components/Tools/Tool_20200224175952.jsx new file mode 100644 index 0000000..973c1f6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224175952.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180031.jsx b/.history/src/components/Tools/Tool_20200224180031.jsx new file mode 100644 index 0000000..9c42969 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180031.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180032.jsx b/.history/src/components/Tools/Tool_20200224180032.jsx new file mode 100644 index 0000000..973c1f6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180032.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180035.jsx b/.history/src/components/Tools/Tool_20200224180035.jsx new file mode 100644 index 0000000..aac9175 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180035.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180042.jsx b/.history/src/components/Tools/Tool_20200224180042.jsx new file mode 100644 index 0000000..96d69ec --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180042.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180056.jsx b/.history/src/components/Tools/Tool_20200224180056.jsx new file mode 100644 index 0000000..e852c6e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180056.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180059.jsx b/.history/src/components/Tools/Tool_20200224180059.jsx new file mode 100644 index 0000000..96d69ec --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180059.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180102.jsx b/.history/src/components/Tools/Tool_20200224180102.jsx new file mode 100644 index 0000000..37a5e29 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180102.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180153.jsx b/.history/src/components/Tools/Tool_20200224180153.jsx new file mode 100644 index 0000000..2c4b41e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180153.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180201.jsx b/.history/src/components/Tools/Tool_20200224180201.jsx new file mode 100644 index 0000000..a7d263a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180201.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + props.toggleCropper() + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180204.jsx b/.history/src/components/Tools/Tool_20200224180204.jsx new file mode 100644 index 0000000..fc29485 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180204.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + props.toggleCropper(props.crop) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180210.jsx b/.history/src/components/Tools/Tool_20200224180210.jsx new file mode 100644 index 0000000..3bbf672 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180210.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180229.jsx b/.history/src/components/Tools/Tool_20200224180229.jsx new file mode 100644 index 0000000..27ab804 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180229.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180232.jsx b/.history/src/components/Tools/Tool_20200224180232.jsx new file mode 100644 index 0000000..25b6edb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180232.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180234.jsx b/.history/src/components/Tools/Tool_20200224180234.jsx new file mode 100644 index 0000000..c54ad66 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180234.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224180236.jsx b/.history/src/components/Tools/Tool_20200224180236.jsx new file mode 100644 index 0000000..9438eea --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224180236.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181206.jsx b/.history/src/components/Tools/Tool_20200224181206.jsx new file mode 100644 index 0000000..3b8a1ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181206.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181208.jsx b/.history/src/components/Tools/Tool_20200224181208.jsx new file mode 100644 index 0000000..24bb529 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181208.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181212.jsx b/.history/src/components/Tools/Tool_20200224181212.jsx new file mode 100644 index 0000000..8394837 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181212.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + handleEven + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181214.jsx b/.history/src/components/Tools/Tool_20200224181214.jsx new file mode 100644 index 0000000..2dc3296 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181214.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + handleEvent(){ + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181223.jsx b/.history/src/components/Tools/Tool_20200224181223.jsx new file mode 100644 index 0000000..ede19bd --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181223.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181235.jsx b/.history/src/components/Tools/Tool_20200224181235.jsx new file mode 100644 index 0000000..12dde12 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181235.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181238.jsx b/.history/src/components/Tools/Tool_20200224181238.jsx new file mode 100644 index 0000000..b8f0674 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181238.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + else{ + + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181243.jsx b/.history/src/components/Tools/Tool_20200224181243.jsx new file mode 100644 index 0000000..446087b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181243.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + else{ + this.props.e + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181244.jsx b/.history/src/components/Tools/Tool_20200224181244.jsx new file mode 100644 index 0000000..d31854a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181244.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + else{ + this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181246.jsx b/.history/src/components/Tools/Tool_20200224181246.jsx new file mode 100644 index 0000000..bd1111a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181246.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + this.props.toggleCropper(props.crop) + } + else{ + this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181252.jsx b/.history/src/components/Tools/Tool_20200224181252.jsx new file mode 100644 index 0000000..20646b0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181252.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181253.jsx b/.history/src/components/Tools/Tool_20200224181253.jsx new file mode 100644 index 0000000..fb681be --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181253.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181256.jsx b/.history/src/components/Tools/Tool_20200224181256.jsx new file mode 100644 index 0000000..623ed7c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181256.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181312.jsx b/.history/src/components/Tools/Tool_20200224181312.jsx new file mode 100644 index 0000000..e188877 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181312.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + return this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181315.jsx b/.history/src/components/Tools/Tool_20200224181315.jsx new file mode 100644 index 0000000..41fc600 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181315.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + return this.props.event + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181316.jsx b/.history/src/components/Tools/Tool_20200224181316.jsx new file mode 100644 index 0000000..e188877 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181316.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + return this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181317.jsx b/.history/src/components/Tools/Tool_20200224181317.jsx new file mode 100644 index 0000000..728b347 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181317.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + else{ + return this.props.event + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181333.jsx b/.history/src/components/Tools/Tool_20200224181333.jsx new file mode 100644 index 0000000..fc29485 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181333.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + props.toggleCropper(props.crop) + if (props.toggleCropper && props.event) { + let x = props.toggleCropper(props.crop) + console.log(x,"LLL") + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181344.jsx b/.history/src/components/Tools/Tool_20200224181344.jsx new file mode 100644 index 0000000..c54ad66 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181344.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181347.jsx b/.history/src/components/Tools/Tool_20200224181347.jsx new file mode 100644 index 0000000..9438eea --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181347.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181353.jsx b/.history/src/components/Tools/Tool_20200224181353.jsx new file mode 100644 index 0000000..19eeb90 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181353.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181408.jsx b/.history/src/components/Tools/Tool_20200224181408.jsx new file mode 100644 index 0000000..394e303 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181408.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181415.jsx b/.history/src/components/Tools/Tool_20200224181415.jsx new file mode 100644 index 0000000..ae2c658 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181415.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181419.jsx b/.history/src/components/Tools/Tool_20200224181419.jsx new file mode 100644 index 0000000..33548b7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181419.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (thisprops.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181420.jsx b/.history/src/components/Tools/Tool_20200224181420.jsx new file mode 100644 index 0000000..c0738f7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181420.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181423.jsx b/.history/src/components/Tools/Tool_20200224181423.jsx new file mode 100644 index 0000000..401a29c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181423.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181424.jsx b/.history/src/components/Tools/Tool_20200224181424.jsx new file mode 100644 index 0000000..1395469 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181424.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181426.jsx b/.history/src/components/Tools/Tool_20200224181426.jsx new file mode 100644 index 0000000..6f96021 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181426.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181430.jsx b/.history/src/components/Tools/Tool_20200224181430.jsx new file mode 100644 index 0000000..fb15e78 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181430.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + compo + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181437.jsx b/.history/src/components/Tools/Tool_20200224181437.jsx new file mode 100644 index 0000000..fbf40ca --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181437.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181439.jsx b/.history/src/components/Tools/Tool_20200224181439.jsx new file mode 100644 index 0000000..1264bb2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181439.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181441.jsx b/.history/src/components/Tools/Tool_20200224181441.jsx new file mode 100644 index 0000000..4246b57 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181441.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this. + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181444.jsx b/.history/src/components/Tools/Tool_20200224181444.jsx new file mode 100644 index 0000000..6bb58d1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181444.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent() + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181445.jsx b/.history/src/components/Tools/Tool_20200224181445.jsx new file mode 100644 index 0000000..c66eab3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181445.jsx @@ -0,0 +1,24 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224181451.jsx b/.history/src/components/Tools/Tool_20200224181451.jsx new file mode 100644 index 0000000..cd9de45 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224181451.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182531.jsx b/.history/src/components/Tools/Tool_20200224182531.jsx new file mode 100644 index 0000000..8286604 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182531.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182533.jsx b/.history/src/components/Tools/Tool_20200224182533.jsx new file mode 100644 index 0000000..30a56cc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182533.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182540.jsx b/.history/src/components/Tools/Tool_20200224182540.jsx new file mode 100644 index 0000000..44837a3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182540.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182543.jsx b/.history/src/components/Tools/Tool_20200224182543.jsx new file mode 100644 index 0000000..d3fa442 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182543.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182544.jsx b/.history/src/components/Tools/Tool_20200224182544.jsx new file mode 100644 index 0000000..d3fa442 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182544.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182547.jsx b/.history/src/components/Tools/Tool_20200224182547.jsx new file mode 100644 index 0000000..5bfe0f6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182547.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182548.jsx b/.history/src/components/Tools/Tool_20200224182548.jsx new file mode 100644 index 0000000..5bfe0f6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182548.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182556.jsx b/.history/src/components/Tools/Tool_20200224182556.jsx new file mode 100644 index 0000000..d3fa442 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182556.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182557.jsx b/.history/src/components/Tools/Tool_20200224182557.jsx new file mode 100644 index 0000000..d3fa442 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182557.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182601.jsx b/.history/src/components/Tools/Tool_20200224182601.jsx new file mode 100644 index 0000000..055246a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182601.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182602.jsx b/.history/src/components/Tools/Tool_20200224182602.jsx new file mode 100644 index 0000000..055246a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182602.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182603.jsx b/.history/src/components/Tools/Tool_20200224182603.jsx new file mode 100644 index 0000000..055246a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182603.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + componentDidMount(){ + this.handleEvent(); + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182619.jsx b/.history/src/components/Tools/Tool_20200224182619.jsx new file mode 100644 index 0000000..89ddd71 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182619.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182621.jsx b/.history/src/components/Tools/Tool_20200224182621.jsx new file mode 100644 index 0000000..89ddd71 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182621.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182634.jsx b/.history/src/components/Tools/Tool_20200224182634.jsx new file mode 100644 index 0000000..c71d5d3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182634.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( + + ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182640.jsx b/.history/src/components/Tools/Tool_20200224182640.jsx new file mode 100644 index 0000000..03e9124 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182640.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +

dasdasd

+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182641.jsx b/.history/src/components/Tools/Tool_20200224182641.jsx new file mode 100644 index 0000000..03e9124 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182641.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +

dasdasd

+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182647.jsx b/.history/src/components/Tools/Tool_20200224182647.jsx new file mode 100644 index 0000000..89ddd71 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182647.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182652.jsx b/.history/src/components/Tools/Tool_20200224182652.jsx new file mode 100644 index 0000000..a10894e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182652.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
this.handleEvent}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182653.jsx b/.history/src/components/Tools/Tool_20200224182653.jsx new file mode 100644 index 0000000..a10894e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182653.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
this.handleEvent}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182654.jsx b/.history/src/components/Tools/Tool_20200224182654.jsx new file mode 100644 index 0000000..a10894e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182654.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
this.handleEvent}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182702.jsx b/.history/src/components/Tools/Tool_20200224182702.jsx new file mode 100644 index 0000000..d473a44 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182702.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
this.handleEvent()}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182717.jsx b/.history/src/components/Tools/Tool_20200224182717.jsx new file mode 100644 index 0000000..dcbf9d2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182717.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
this.handeEvent()}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182934.jsx b/.history/src/components/Tools/Tool_20200224182934.jsx new file mode 100644 index 0000000..602e1fa --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182934.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
this.handeEvent()}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182936.jsx b/.history/src/components/Tools/Tool_20200224182936.jsx new file mode 100644 index 0000000..da6593d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182936.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
}> + +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182947.jsx b/.history/src/components/Tools/Tool_20200224182947.jsx new file mode 100644 index 0000000..bf8d103 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182947.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182952.jsx b/.history/src/components/Tools/Tool_20200224182952.jsx new file mode 100644 index 0000000..d9b621d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182952.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224182958.jsx b/.history/src/components/Tools/Tool_20200224182958.jsx new file mode 100644 index 0000000..471f751 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224182958.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handeEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224183002.jsx b/.history/src/components/Tools/Tool_20200224183002.jsx new file mode 100644 index 0000000..f16a345 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224183002.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224183038.jsx b/.history/src/components/Tools/Tool_20200224183038.jsx new file mode 100644 index 0000000..f4a2825 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224183038.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200224183040.jsx b/.history/src/components/Tools/Tool_20200224183040.jsx new file mode 100644 index 0000000..c9ba2ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200224183040.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log("HANS") + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225125935.jsx b/.history/src/components/Tools/Tool_20200225125935.jsx new file mode 100644 index 0000000..c3ae4aa --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225125935.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(this.props.crop) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130045.jsx b/.history/src/components/Tools/Tool_20200225130045.jsx new file mode 100644 index 0000000..2532f0f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130045.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if (this.props.toggleCropper && this.props.event) { + this.props.toggleCropper(t) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130048.jsx b/.history/src/components/Tools/Tool_20200225130048.jsx new file mode 100644 index 0000000..2e8194c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130048.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + + this.props.toggleCropper(t) + } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130051.jsx b/.history/src/components/Tools/Tool_20200225130051.jsx new file mode 100644 index 0000000..139fc46 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130051.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + this.props.toggleCropper(t) + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130052.jsx b/.history/src/components/Tools/Tool_20200225130052.jsx new file mode 100644 index 0000000..01f6310 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130052.jsx @@ -0,0 +1,19 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + this.props.toggleCropper() + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130103.jsx b/.history/src/components/Tools/Tool_20200225130103.jsx new file mode 100644 index 0000000..7e37b18 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130103.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper) + this.props.toggleCropper() + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130107.jsx b/.history/src/components/Tools/Tool_20200225130107.jsx new file mode 100644 index 0000000..86e3017 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130107.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + + } + this.props.toggleCropper() + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130109.jsx b/.history/src/components/Tools/Tool_20200225130109.jsx new file mode 100644 index 0000000..f3c1cbd --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130109.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + this.props.toggleCropper() + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130122.jsx b/.history/src/components/Tools/Tool_20200225130122.jsx new file mode 100644 index 0000000..75cd013 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130122.jsx @@ -0,0 +1,23 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130125.jsx b/.history/src/components/Tools/Tool_20200225130125.jsx new file mode 100644 index 0000000..3574a2b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130125.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + else{ + + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130127.jsx b/.history/src/components/Tools/Tool_20200225130127.jsx new file mode 100644 index 0000000..ab74d83 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130127.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + this.props.toggleCropper(); + + } + else{ + + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130128.jsx b/.history/src/components/Tools/Tool_20200225130128.jsx new file mode 100644 index 0000000..56da27f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130128.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + else{ + + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130132.jsx b/.history/src/components/Tools/Tool_20200225130132.jsx new file mode 100644 index 0000000..7c5f867 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130132.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + else{ + this.props.event(); + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130514.jsx b/.history/src/components/Tools/Tool_20200225130514.jsx new file mode 100644 index 0000000..832974d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130514.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + else{ + this.props.event(); + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130538.jsx b/.history/src/components/Tools/Tool_20200225130538.jsx new file mode 100644 index 0000000..b01064c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130538.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + else{ + this.props.event(); + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130556.jsx b/.history/src/components/Tools/Tool_20200225130556.jsx new file mode 100644 index 0000000..92d6f9a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130556.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log(this.props,"A") + if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + } + else{ + this.props.event(); + } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130558.jsx b/.history/src/components/Tools/Tool_20200225130558.jsx new file mode 100644 index 0000000..98df57a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130558.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + + } + handleEvent(){ + console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130618.jsx b/.history/src/components/Tools/Tool_20200225130618.jsx new file mode 100644 index 0000000..3a52e2a --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130618.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130619.jsx b/.history/src/components/Tools/Tool_20200225130619.jsx new file mode 100644 index 0000000..a2bd867 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130619.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130652.jsx b/.history/src/components/Tools/Tool_20200225130652.jsx new file mode 100644 index 0000000..019ea10 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130652.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130655.jsx b/.history/src/components/Tools/Tool_20200225130655.jsx new file mode 100644 index 0000000..06760b1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130655.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130700.jsx b/.history/src/components/Tools/Tool_20200225130700.jsx new file mode 100644 index 0000000..5f17d29 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130700.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130706.jsx b/.history/src/components/Tools/Tool_20200225130706.jsx new file mode 100644 index 0000000..01ab96e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130706.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130712.jsx b/.history/src/components/Tools/Tool_20200225130712.jsx new file mode 100644 index 0000000..7b1f49f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130712.jsx @@ -0,0 +1,28 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + console.log(props) + } + handleEvent(){ + console.log("YYYY") + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130715.jsx b/.history/src/components/Tools/Tool_20200225130715.jsx new file mode 100644 index 0000000..f212876 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130715.jsx @@ -0,0 +1,27 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + console.log("YYYY") + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130738.jsx b/.history/src/components/Tools/Tool_20200225130738.jsx new file mode 100644 index 0000000..4ad7112 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130738.jsx @@ -0,0 +1,26 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130741.jsx b/.history/src/components/Tools/Tool_20200225130741.jsx new file mode 100644 index 0000000..9f66deb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130741.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + // this.props.toggleCropper(); + // this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130750.jsx b/.history/src/components/Tools/Tool_20200225130750.jsx new file mode 100644 index 0000000..b1ced46 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130750.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130806.jsx b/.history/src/components/Tools/Tool_20200225130806.jsx new file mode 100644 index 0000000..8c9aca9 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130806.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + props.toggleCropper(); + props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130807.jsx b/.history/src/components/Tools/Tool_20200225130807.jsx new file mode 100644 index 0000000..8c9aca9 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130807.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + props.toggleCropper(); + props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130813.jsx b/.history/src/components/Tools/Tool_20200225130813.jsx new file mode 100644 index 0000000..26f1ce6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130813.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + props.toggleCropper(); + props.event(); + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130815.jsx b/.history/src/components/Tools/Tool_20200225130815.jsx new file mode 100644 index 0000000..43169bc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130815.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + props.toggleCropper(); + props.event(); + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130819.jsx b/.history/src/components/Tools/Tool_20200225130819.jsx new file mode 100644 index 0000000..a41c346 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130819.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + props.toggleCropper(); + props.event(); + + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130824.jsx b/.history/src/components/Tools/Tool_20200225130824.jsx new file mode 100644 index 0000000..b1ced46 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130824.jsx @@ -0,0 +1,25 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + constructor(props) { + super(props) + } + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130850.jsx b/.history/src/components/Tools/Tool_20200225130850.jsx new file mode 100644 index 0000000..5820e32 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130850.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +class Tool extends React.Component { + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130854.jsx b/.history/src/components/Tools/Tool_20200225130854.jsx new file mode 100644 index 0000000..384a9c3 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130854.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool extends React.Component { + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130856.jsx b/.history/src/components/Tools/Tool_20200225130856.jsx new file mode 100644 index 0000000..e072a60 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130856.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool { + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130858.jsx b/.history/src/components/Tools/Tool_20200225130858.jsx new file mode 100644 index 0000000..b1239e7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130858.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool() { + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130901.jsx b/.history/src/components/Tools/Tool_20200225130901.jsx new file mode 100644 index 0000000..103bd2d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130901.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = () { + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130903.jsx b/.history/src/components/Tools/Tool_20200225130903.jsx new file mode 100644 index 0000000..44f17f2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130903.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = () =>{ + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130906.jsx b/.history/src/components/Tools/Tool_20200225130906.jsx new file mode 100644 index 0000000..bee9839 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130906.jsx @@ -0,0 +1,22 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) =>{ + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + render() { + return ( +
+ +
+ ); + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130910.jsx b/.history/src/components/Tools/Tool_20200225130910.jsx new file mode 100644 index 0000000..ee75e99 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130910.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) =>{ + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130911.jsx b/.history/src/components/Tools/Tool_20200225130911.jsx new file mode 100644 index 0000000..a2c5c87 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130911.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent(){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130916.jsx b/.history/src/components/Tools/Tool_20200225130916.jsx new file mode 100644 index 0000000..be30860 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130916.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent (){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130927.jsx b/.history/src/components/Tools/Tool_20200225130927.jsx new file mode 100644 index 0000000..08bfd71 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130927.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (){ + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130930.jsx b/.history/src/components/Tools/Tool_20200225130930.jsx new file mode 100644 index 0000000..b485d06 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130930.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = () => { + // console.log(this.props,"A") + // if(this.props && this.props.toggleCropper){ + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130932.jsx b/.history/src/components/Tools/Tool_20200225130932.jsx new file mode 100644 index 0000000..9cdda3e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130932.jsx @@ -0,0 +1,20 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = () => { + + this.props.toggleCropper(); + this.props.event(); + // } + // else{ + // this.props.event(); + // } + } + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130935.jsx b/.history/src/components/Tools/Tool_20200225130935.jsx new file mode 100644 index 0000000..a6f5682 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130935.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = () => { + + this.props.toggleCropper(); + this.props.event(); + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130937.jsx b/.history/src/components/Tools/Tool_20200225130937.jsx new file mode 100644 index 0000000..fb2a3f2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130937.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (props) => { + + this.props.toggleCropper(); + this.props.event(); + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130940.jsx b/.history/src/components/Tools/Tool_20200225130940.jsx new file mode 100644 index 0000000..e25f558 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130940.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (props) => { + + props.toggleCropper(); + this.props.event(); + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130942.jsx b/.history/src/components/Tools/Tool_20200225130942.jsx new file mode 100644 index 0000000..cd14bb0 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130942.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130943.jsx b/.history/src/components/Tools/Tool_20200225130943.jsx new file mode 100644 index 0000000..b7cc532 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130943.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130953.jsx b/.history/src/components/Tools/Tool_20200225130953.jsx new file mode 100644 index 0000000..a77850d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130953.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + +} +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225130954.jsx b/.history/src/components/Tools/Tool_20200225130954.jsx new file mode 100644 index 0000000..e963165 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225130954.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131000.jsx b/.history/src/components/Tools/Tool_20200225131000.jsx new file mode 100644 index 0000000..276eb69 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131000.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131002.jsx b/.history/src/components/Tools/Tool_20200225131002.jsx new file mode 100644 index 0000000..4b6757d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131002.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131004.jsx b/.history/src/components/Tools/Tool_20200225131004.jsx new file mode 100644 index 0000000..51a2698 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131004.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131007.jsx b/.history/src/components/Tools/Tool_20200225131007.jsx new file mode 100644 index 0000000..fa6bc76 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131007.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131012.jsx b/.history/src/components/Tools/Tool_20200225131012.jsx new file mode 100644 index 0000000..3ee6560 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131012.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131026.jsx b/.history/src/components/Tools/Tool_20200225131026.jsx new file mode 100644 index 0000000..eabbb0e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131026.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } +} +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131027.jsx b/.history/src/components/Tools/Tool_20200225131027.jsx new file mode 100644 index 0000000..4388e6b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131027.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131031.jsx b/.history/src/components/Tools/Tool_20200225131031.jsx new file mode 100644 index 0000000..ee58bcc --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131031.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131040.jsx b/.history/src/components/Tools/Tool_20200225131040.jsx new file mode 100644 index 0000000..5ff3a55 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131040.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + console.log("AAAA") + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131057.jsx b/.history/src/components/Tools/Tool_20200225131057.jsx new file mode 100644 index 0000000..dc5b82b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131057.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + console.log("AAAA") + props.toggleCropper; + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131100.jsx b/.history/src/components/Tools/Tool_20200225131100.jsx new file mode 100644 index 0000000..a823697 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131100.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + console.log("AAAA") + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131103.jsx b/.history/src/components/Tools/Tool_20200225131103.jsx new file mode 100644 index 0000000..85b439d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131103.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + console.log(props,"AAAA") + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131127.jsx b/.history/src/components/Tools/Tool_20200225131127.jsx new file mode 100644 index 0000000..b80ce62 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131127.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + console.log(props,"AAAA") + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131135.jsx b/.history/src/components/Tools/Tool_20200225131135.jsx new file mode 100644 index 0000000..5ff3a55 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131135.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = (props) => { + console.log("AAAA") + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131136.jsx b/.history/src/components/Tools/Tool_20200225131136.jsx new file mode 100644 index 0000000..e164a76 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131136.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + console.log("AAAA") + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225131206.jsx b/.history/src/components/Tools/Tool_20200225131206.jsx new file mode 100644 index 0000000..834e6c7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225131206.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225132747.jsx b/.history/src/components/Tools/Tool_20200225132747.jsx new file mode 100644 index 0000000..a7ed2d6 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225132747.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + // props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134224.jsx b/.history/src/components/Tools/Tool_20200225134224.jsx new file mode 100644 index 0000000..834e6c7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134224.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper(); + props.event(); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134329.jsx b/.history/src/components/Tools/Tool_20200225134329.jsx new file mode 100644 index 0000000..16ebff1 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134329.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(); + props.toggleCropper(); + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134330.jsx b/.history/src/components/Tools/Tool_20200225134330.jsx new file mode 100644 index 0000000..b8a13c2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134330.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(); + props.toggleCropper(); + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134332.jsx b/.history/src/components/Tools/Tool_20200225134332.jsx new file mode 100644 index 0000000..92f809e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134332.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + await props.event(); + props.toggleCropper(); + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134526.jsx b/.history/src/components/Tools/Tool_20200225134526.jsx new file mode 100644 index 0000000..b8a13c2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134526.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(); + props.toggleCropper(); + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134533.jsx b/.history/src/components/Tools/Tool_20200225134533.jsx new file mode 100644 index 0000000..c1b7a06 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134533.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => ); + props.toggleCropper(); + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134535.jsx b/.history/src/components/Tools/Tool_20200225134535.jsx new file mode 100644 index 0000000..c1b7a06 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134535.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => ); + props.toggleCropper(); + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134538.jsx b/.history/src/components/Tools/Tool_20200225134538.jsx new file mode 100644 index 0000000..5681a6b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134538.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => props.toggleCropper()); + ; + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134543.jsx b/.history/src/components/Tools/Tool_20200225134543.jsx new file mode 100644 index 0000000..a04b709 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134543.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => props.toggleCropper()); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134608.jsx b/.history/src/components/Tools/Tool_20200225134608.jsx new file mode 100644 index 0000000..4461eaf --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134608.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => ); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134611.jsx b/.history/src/components/Tools/Tool_20200225134611.jsx new file mode 100644 index 0000000..bdd7b7d --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134611.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => console); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134615.jsx b/.history/src/components/Tools/Tool_20200225134615.jsx new file mode 100644 index 0000000..de8b624 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134615.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => console.log("AA")); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134618.jsx b/.history/src/components/Tools/Tool_20200225134618.jsx new file mode 100644 index 0000000..e81222b --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134618.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + props.event(() => console.log("AA")); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134634.jsx b/.history/src/components/Tools/Tool_20200225134634.jsx new file mode 100644 index 0000000..c4a2eb4 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134634.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + props.event(() => console.log("AA")); + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134636.jsx b/.history/src/components/Tools/Tool_20200225134636.jsx new file mode 100644 index 0000000..cd38f57 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134636.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134637.jsx b/.history/src/components/Tools/Tool_20200225134637.jsx new file mode 100644 index 0000000..5a7957f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134637.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(() => console.log("AA")); + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134707.jsx b/.history/src/components/Tools/Tool_20200225134707.jsx new file mode 100644 index 0000000..522782e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134707.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + + props.event(); + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134711.jsx b/.history/src/components/Tools/Tool_20200225134711.jsx new file mode 100644 index 0000000..069c041 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134711.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + let promise = + props.event(); + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134713.jsx b/.history/src/components/Tools/Tool_20200225134713.jsx new file mode 100644 index 0000000..53d29be --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134713.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + let promise = props.event(); + + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134715.jsx b/.history/src/components/Tools/Tool_20200225134715.jsx new file mode 100644 index 0000000..5db87ea --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134715.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + let promise = props.event(); + + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134730.jsx b/.history/src/components/Tools/Tool_20200225134730.jsx new file mode 100644 index 0000000..b8389ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134730.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + let promise = props.event(); + promise.then() + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134735.jsx b/.history/src/components/Tools/Tool_20200225134735.jsx new file mode 100644 index 0000000..b8389ce --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134735.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + let promise = props.event(); + promise.then() + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225134744.jsx b/.history/src/components/Tools/Tool_20200225134744.jsx new file mode 100644 index 0000000..3e07c4e --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225134744.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + let promise = props.event(); + promise.then(res => console.log(res)) + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135057.jsx b/.history/src/components/Tools/Tool_20200225135057.jsx new file mode 100644 index 0000000..468a743 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135057.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + async props.event(); + promise.then(res => console.log(res)) + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135109.jsx b/.history/src/components/Tools/Tool_20200225135109.jsx new file mode 100644 index 0000000..0689825 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135109.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + async handleEvent = () => { + props.event(); + promise.then(res => console.log(res)) + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135116.jsx b/.history/src/components/Tools/Tool_20200225135116.jsx new file mode 100644 index 0000000..468a743 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135116.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + async props.event(); + promise.then(res => console.log(res)) + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135119.jsx b/.history/src/components/Tools/Tool_20200225135119.jsx new file mode 100644 index 0000000..78fc0be --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135119.jsx @@ -0,0 +1,18 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(); + promise.then(res => console.log(res)) + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135121.jsx b/.history/src/components/Tools/Tool_20200225135121.jsx new file mode 100644 index 0000000..0cbba32 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135121.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(); + props.toggleCropper() + + } + return ( +
+ +
+ ); + + } + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135737.jsx b/.history/src/components/Tools/Tool_20200225135737.jsx new file mode 100644 index 0000000..d1dd3d7 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135737.jsx @@ -0,0 +1,17 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.event(); + props.toggleCropper() + + } + return ( +
+ +
+ ); + +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135748.jsx b/.history/src/components/Tools/Tool_20200225135748.jsx new file mode 100644 index 0000000..cf787bf --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135748.jsx @@ -0,0 +1,16 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + + } + return ( +
+ +
+ ); + +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135855.jsx b/.history/src/components/Tools/Tool_20200225135855.jsx new file mode 100644 index 0000000..540f900 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135855.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); + +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225135858.jsx b/.history/src/components/Tools/Tool_20200225135858.jsx new file mode 100644 index 0000000..b7861fb --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225135858.jsx @@ -0,0 +1,14 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225140714.jsx b/.history/src/components/Tools/Tool_20200225140714.jsx new file mode 100644 index 0000000..d5fd833 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225140714.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + props. + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225140724.jsx b/.history/src/components/Tools/Tool_20200225140724.jsx new file mode 100644 index 0000000..585e4ee --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225140724.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + props.event() + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225140830.jsx b/.history/src/components/Tools/Tool_20200225140830.jsx new file mode 100644 index 0000000..a7f9b3f --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225140830.jsx @@ -0,0 +1,15 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + let handleEvent = () => { + props.toggleCropper() + props.event() + } + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225140833.jsx b/.history/src/components/Tools/Tool_20200225140833.jsx new file mode 100644 index 0000000..2f20a3c --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225140833.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/Tools/Tool_20200225141104.jsx b/.history/src/components/Tools/Tool_20200225141104.jsx new file mode 100644 index 0000000..a2bd5c2 --- /dev/null +++ b/.history/src/components/Tools/Tool_20200225141104.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154746.jsx b/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154746.jsx new file mode 100644 index 0000000..243dbf1 --- /dev/null +++ b/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154746.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class HorizontalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154805.jsx b/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154805.jsx new file mode 100644 index 0000000..b214145 --- /dev/null +++ b/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154805.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class VerticalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154809.jsx b/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154809.jsx new file mode 100644 index 0000000..9979198 --- /dev/null +++ b/.history/src/components/VerticalToolbar/VerticalToolbar_20200225154809.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class VerticalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default VerticalToolbar; diff --git a/.history/src/index_20200220160215.js b/.history/src/index_20200220160215.js new file mode 100644 index 0000000..87d1be5 --- /dev/null +++ b/.history/src/index_20200220160215.js @@ -0,0 +1,12 @@ +import React from 'react'; +import ReactDOM from 'react-dom'; +import './index.css'; +import App from './App'; +import * as serviceWorker from './serviceWorker'; + +ReactDOM.render(, document.getElementById('root')); + +// If you want your app to work offline and load faster, you can change +// unregister() to register() below. Note this comes with some pitfalls. +// Learn more about service workers: https://bit.ly/CRA-PWA +serviceWorker.unregister(); diff --git a/.history/src/index_20200224153552.js b/.history/src/index_20200224153552.js new file mode 100644 index 0000000..b94d956 --- /dev/null +++ b/.history/src/index_20200224153552.js @@ -0,0 +1,12 @@ +import React from 'react'; +import ReactDOM from 'react-dom'; +import './index.css'; +import App from './App'; +import * as serviceWorker from './serviceWorker'; +import '@fortawesome/fontawesome-free/css/all.css' +ReactDOM.render(, document.getElementById('root')); + +// If you want your app to work offline and load faster, you can change +// unregister() to register() below. Note this comes with some pitfalls. +// Learn more about service workers: https://bit.ly/CRA-PWA +serviceWorker.unregister(); diff --git a/.history/src/index_20200224153600.js b/.history/src/index_20200224153600.js new file mode 100644 index 0000000..739e678 --- /dev/null +++ b/.history/src/index_20200224153600.js @@ -0,0 +1,11 @@ +import React from 'react'; +import ReactDOM from 'react-dom'; +import './index.css'; +import App from './App'; +import * as serviceWorker from './serviceWorker'; +ReactDOM.render(, document.getElementById('root')); + +// If you want your app to work offline and load faster, you can change +// unregister() to register() below. Note this comes with some pitfalls. +// Learn more about service workers: https://bit.ly/CRA-PWA +serviceWorker.unregister(); diff --git a/package-lock.json b/package-lock.json new file mode 100644 index 0000000..4d9d5f6 --- /dev/null +++ b/package-lock.json @@ -0,0 +1,14106 @@ +{ + "name": "react-image-markup-demo", + "version": "0.1.0", + "lockfileVersion": 1, + "requires": true, + "dependencies": { + "@babel/code-frame": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.8.3.tgz", + "integrity": "sha512-a9gxpmdXtZEInkCSHUJDLHZVBgb1QS0jhss4cPP93EW7s+uC5bikET2twEF3KV+7rDblJcmNvTR7VJejqd2C2g==", + "requires": { + "@babel/highlight": "^7.8.3" + } + }, + "@babel/compat-data": { + "version": "7.8.5", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.8.5.tgz", + "integrity": "sha512-jWYUqQX/ObOhG1UiEkbH5SANsE/8oKXiQWjj7p7xgj9Zmnt//aUvyz4dBkK0HNsS8/cbyC5NmmH87VekW+mXFg==", + "requires": { + "browserslist": "^4.8.5", + "invariant": "^2.2.4", + "semver": "^5.5.0" + } + }, + "@babel/core": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.8.4.tgz", + "integrity": "sha512-0LiLrB2PwrVI+a2/IEskBopDYSd8BCb3rOvH7D5tzoWd696TBEduBvuLVm4Nx6rltrLZqvI3MCalB2K2aVzQjA==", + "requires": { + "@babel/code-frame": "^7.8.3", + "@babel/generator": "^7.8.4", + "@babel/helpers": "^7.8.4", + "@babel/parser": "^7.8.4", + "@babel/template": "^7.8.3", + "@babel/traverse": "^7.8.4", + "@babel/types": "^7.8.3", + "convert-source-map": "^1.7.0", + "debug": "^4.1.0", + "gensync": "^1.0.0-beta.1", + "json5": "^2.1.0", + "lodash": "^4.17.13", + "resolve": "^1.3.2", + "semver": "^5.4.1", + "source-map": "^0.5.0" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" + } + } + }, + "@babel/generator": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.8.4.tgz", + "integrity": "sha512-PwhclGdRpNAf3IxZb0YVuITPZmmrXz9zf6fH8lT4XbrmfQKr6ryBzhv593P5C6poJRciFCL/eHGW2NuGrgEyxA==", + "requires": { + "@babel/types": "^7.8.3", + "jsesc": "^2.5.1", + "lodash": "^4.17.13", + "source-map": "^0.5.0" + }, + "dependencies": { + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" + } + } + }, + "@babel/helper-annotate-as-pure": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.8.3.tgz", + "integrity": "sha512-6o+mJrZBxOoEX77Ezv9zwW7WV8DdluouRKNY/IR5u/YTMuKHgugHOzYWlYvYLpLA9nPsQCAAASpCIbjI9Mv+Uw==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-builder-binary-assignment-operator-visitor": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.8.3.tgz", + "integrity": "sha512-5eFOm2SyFPK4Rh3XMMRDjN7lBH0orh3ss0g3rTYZnBQ+r6YPj7lgDyCvPphynHvUrobJmeMignBr6Acw9mAPlw==", + "requires": { + "@babel/helper-explode-assignable-expression": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-builder-react-jsx": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-react-jsx/-/helper-builder-react-jsx-7.8.3.tgz", + "integrity": "sha512-JT8mfnpTkKNCboTqZsQTdGo3l3Ik3l7QIt9hh0O9DYiwVel37VoJpILKM4YFbP2euF32nkQSb+F9cUk9b7DDXQ==", + "requires": { + "@babel/types": "^7.8.3", + "esutils": "^2.0.0" + } + }, + "@babel/helper-call-delegate": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-call-delegate/-/helper-call-delegate-7.8.3.tgz", + "integrity": "sha512-6Q05px0Eb+N4/GTyKPPvnkig7Lylw+QzihMpws9iiZQv7ZImf84ZsZpQH7QoWN4n4tm81SnSzPgHw2qtO0Zf3A==", + "requires": { + "@babel/helper-hoist-variables": "^7.8.3", + "@babel/traverse": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-compilation-targets": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.8.4.tgz", + "integrity": "sha512-3k3BsKMvPp5bjxgMdrFyq0UaEO48HciVrOVF0+lon8pp95cyJ2ujAh0TrBHNMnJGT2rr0iKOJPFFbSqjDyf/Pg==", + "requires": { + "@babel/compat-data": "^7.8.4", + "browserslist": "^4.8.5", + "invariant": "^2.2.4", + "levenary": "^1.1.1", + "semver": "^5.5.0" + } + }, + "@babel/helper-create-class-features-plugin": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.8.3.tgz", + "integrity": "sha512-qmp4pD7zeTxsv0JNecSBsEmG1ei2MqwJq4YQcK3ZWm/0t07QstWfvuV/vm3Qt5xNMFETn2SZqpMx2MQzbtq+KA==", + "requires": { + "@babel/helper-function-name": "^7.8.3", + "@babel/helper-member-expression-to-functions": "^7.8.3", + "@babel/helper-optimise-call-expression": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-replace-supers": "^7.8.3", + "@babel/helper-split-export-declaration": "^7.8.3" + } + }, + "@babel/helper-create-regexp-features-plugin": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.8.3.tgz", + "integrity": "sha512-Gcsm1OHCUr9o9TcJln57xhWHtdXbA2pgQ58S0Lxlks0WMGNXuki4+GLfX0p+L2ZkINUGZvfkz8rzoqJQSthI+Q==", + "requires": { + "@babel/helper-regex": "^7.8.3", + "regexpu-core": "^4.6.0" + } + }, + "@babel/helper-define-map": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-define-map/-/helper-define-map-7.8.3.tgz", + "integrity": "sha512-PoeBYtxoZGtct3md6xZOCWPcKuMuk3IHhgxsRRNtnNShebf4C8YonTSblsK4tvDbm+eJAw2HAPOfCr+Q/YRG/g==", + "requires": { + "@babel/helper-function-name": "^7.8.3", + "@babel/types": "^7.8.3", + "lodash": "^4.17.13" + } + }, + "@babel/helper-explode-assignable-expression": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-explode-assignable-expression/-/helper-explode-assignable-expression-7.8.3.tgz", + "integrity": "sha512-N+8eW86/Kj147bO9G2uclsg5pwfs/fqqY5rwgIL7eTBklgXjcOJ3btzS5iM6AitJcftnY7pm2lGsrJVYLGjzIw==", + "requires": { + "@babel/traverse": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-function-name": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.8.3.tgz", + "integrity": "sha512-BCxgX1BC2hD/oBlIFUgOCQDOPV8nSINxCwM3o93xP4P9Fq6aV5sgv2cOOITDMtCfQ+3PvHp3l689XZvAM9QyOA==", + "requires": { + "@babel/helper-get-function-arity": "^7.8.3", + "@babel/template": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-get-function-arity": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-get-function-arity/-/helper-get-function-arity-7.8.3.tgz", + "integrity": "sha512-FVDR+Gd9iLjUMY1fzE2SR0IuaJToR4RkCDARVfsBBPSP53GEqSFjD8gNyxg246VUyc/ALRxFaAK8rVG7UT7xRA==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-hoist-variables": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.8.3.tgz", + "integrity": "sha512-ky1JLOjcDUtSc+xkt0xhYff7Z6ILTAHKmZLHPxAhOP0Nd77O+3nCsd6uSVYur6nJnCI029CrNbYlc0LoPfAPQg==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-member-expression-to-functions": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.8.3.tgz", + "integrity": "sha512-fO4Egq88utkQFjbPrSHGmGLFqmrshs11d46WI+WZDESt7Wu7wN2G2Iu+NMMZJFDOVRHAMIkB5SNh30NtwCA7RA==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-module-imports": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.8.3.tgz", + "integrity": "sha512-R0Bx3jippsbAEtzkpZ/6FIiuzOURPcMjHp+Z6xPe6DtApDJx+w7UYyOLanZqO8+wKR9G10s/FmHXvxaMd9s6Kg==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-module-transforms": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.8.3.tgz", + "integrity": "sha512-C7NG6B7vfBa/pwCOshpMbOYUmrYQDfCpVL/JCRu0ek8B5p8kue1+BCXpg2vOYs7w5ACB9GTOBYQ5U6NwrMg+3Q==", + "requires": { + "@babel/helper-module-imports": "^7.8.3", + "@babel/helper-simple-access": "^7.8.3", + "@babel/helper-split-export-declaration": "^7.8.3", + "@babel/template": "^7.8.3", + "@babel/types": "^7.8.3", + "lodash": "^4.17.13" + } + }, + "@babel/helper-optimise-call-expression": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.8.3.tgz", + "integrity": "sha512-Kag20n86cbO2AvHca6EJsvqAd82gc6VMGule4HwebwMlwkpXuVqrNRj6CkCV2sKxgi9MyAUnZVnZ6lJ1/vKhHQ==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-plugin-utils": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.8.3.tgz", + "integrity": "sha512-j+fq49Xds2smCUNYmEHF9kGNkhbet6yVIBp4e6oeQpH1RUs/Ir06xUKzDjDkGcaaokPiTNs2JBWHjaE4csUkZQ==" + }, + "@babel/helper-regex": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-regex/-/helper-regex-7.8.3.tgz", + "integrity": "sha512-BWt0QtYv/cg/NecOAZMdcn/waj/5P26DR4mVLXfFtDokSR6fyuG0Pj+e2FqtSME+MqED1khnSMulkmGl8qWiUQ==", + "requires": { + "lodash": "^4.17.13" + } + }, + "@babel/helper-remap-async-to-generator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.8.3.tgz", + "integrity": "sha512-kgwDmw4fCg7AVgS4DukQR/roGp+jP+XluJE5hsRZwxCYGg+Rv9wSGErDWhlI90FODdYfd4xG4AQRiMDjjN0GzA==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.3", + "@babel/helper-wrap-function": "^7.8.3", + "@babel/template": "^7.8.3", + "@babel/traverse": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-replace-supers": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.8.3.tgz", + "integrity": "sha512-xOUssL6ho41U81etpLoT2RTdvdus4VfHamCuAm4AHxGr+0it5fnwoVdwUJ7GFEqCsQYzJUhcbsN9wB9apcYKFA==", + "requires": { + "@babel/helper-member-expression-to-functions": "^7.8.3", + "@babel/helper-optimise-call-expression": "^7.8.3", + "@babel/traverse": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-simple-access": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.8.3.tgz", + "integrity": "sha512-VNGUDjx5cCWg4vvCTR8qQ7YJYZ+HBjxOgXEl7ounz+4Sn7+LMD3CFrCTEU6/qXKbA2nKg21CwhhBzO0RpRbdCw==", + "requires": { + "@babel/template": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-split-export-declaration": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.8.3.tgz", + "integrity": "sha512-3x3yOeyBhW851hroze7ElzdkeRXQYQbFIb7gLK1WQYsw2GWDay5gAJNw1sWJ0VFP6z5J1whqeXH/WCdCjZv6dA==", + "requires": { + "@babel/types": "^7.8.3" + } + }, + "@babel/helper-wrap-function": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.8.3.tgz", + "integrity": "sha512-LACJrbUET9cQDzb6kG7EeD7+7doC3JNvUgTEQOx2qaO1fKlzE/Bf05qs9w1oXQMmXlPO65lC3Tq9S6gZpTErEQ==", + "requires": { + "@babel/helper-function-name": "^7.8.3", + "@babel/template": "^7.8.3", + "@babel/traverse": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/helpers": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.8.4.tgz", + "integrity": "sha512-VPbe7wcQ4chu4TDQjimHv/5tj73qz88o12EPkO2ValS2QiQS/1F2SsjyIGNnAD0vF/nZS6Cf9i+vW6HIlnaR8w==", + "requires": { + "@babel/template": "^7.8.3", + "@babel/traverse": "^7.8.4", + "@babel/types": "^7.8.3" + } + }, + "@babel/highlight": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.8.3.tgz", + "integrity": "sha512-PX4y5xQUvy0fnEVHrYOarRPXVWafSjTW9T0Hab8gVIawpl2Sj0ORyrygANq+KjcNlSSTw0YCLSNA8OyZ1I4yEg==", + "requires": { + "chalk": "^2.0.0", + "esutils": "^2.0.2", + "js-tokens": "^4.0.0" + } + }, + "@babel/parser": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.8.4.tgz", + "integrity": "sha512-0fKu/QqildpXmPVaRBoXOlyBb3MC+J0A66x97qEfLOMkn3u6nfY5esWogQwi/K0BjASYy4DbnsEWnpNL6qT5Mw==" + }, + "@babel/plugin-proposal-async-generator-functions": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-async-generator-functions/-/plugin-proposal-async-generator-functions-7.8.3.tgz", + "integrity": "sha512-NZ9zLv848JsV3hs8ryEh7Uaz/0KsmPLqv0+PdkDJL1cJy0K4kOCFa8zc1E3mp+RHPQcpdfb/6GovEsW4VDrOMw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-remap-async-to-generator": "^7.8.3", + "@babel/plugin-syntax-async-generators": "^7.8.0" + } + }, + "@babel/plugin-proposal-class-properties": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-class-properties/-/plugin-proposal-class-properties-7.8.3.tgz", + "integrity": "sha512-EqFhbo7IosdgPgZggHaNObkmO1kNUe3slaKu54d5OWvy+p9QIKOzK1GAEpAIsZtWVtPXUHSMcT4smvDrCfY4AA==", + "requires": { + "@babel/helper-create-class-features-plugin": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-proposal-decorators": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-decorators/-/plugin-proposal-decorators-7.8.3.tgz", + "integrity": "sha512-e3RvdvS4qPJVTe288DlXjwKflpfy1hr0j5dz5WpIYYeP7vQZg2WfAEIp8k5/Lwis/m5REXEteIz6rrcDtXXG7w==", + "requires": { + "@babel/helper-create-class-features-plugin": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-decorators": "^7.8.3" + } + }, + "@babel/plugin-proposal-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-dynamic-import/-/plugin-proposal-dynamic-import-7.8.3.tgz", + "integrity": "sha512-NyaBbyLFXFLT9FP+zk0kYlUlA8XtCUbehs67F0nnEg7KICgMc2mNkIeu9TYhKzyXMkrapZFwAhXLdnt4IYHy1w==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-dynamic-import": "^7.8.0" + } + }, + "@babel/plugin-proposal-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-json-strings/-/plugin-proposal-json-strings-7.8.3.tgz", + "integrity": "sha512-KGhQNZ3TVCQG/MjRbAUwuH+14y9q0tpxs1nWWs3pbSleRdDro9SAMMDyye8HhY1gqZ7/NqIc8SKhya0wRDgP1Q==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-json-strings": "^7.8.0" + } + }, + "@babel/plugin-proposal-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-nullish-coalescing-operator/-/plugin-proposal-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-TS9MlfzXpXKt6YYomudb/KU7nQI6/xnapG6in1uZxoxDghuSMZsPb6D2fyUwNYSAp4l1iR7QtFOjkqcRYcUsfw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.0" + } + }, + "@babel/plugin-proposal-numeric-separator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-numeric-separator/-/plugin-proposal-numeric-separator-7.8.3.tgz", + "integrity": "sha512-jWioO1s6R/R+wEHizfaScNsAx+xKgwTLNXSh7tTC4Usj3ItsPEhYkEpU4h+lpnBwq7NBVOJXfO6cRFYcX69JUQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-numeric-separator": "^7.8.3" + } + }, + "@babel/plugin-proposal-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-object-rest-spread/-/plugin-proposal-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-8qvuPwU/xxUCt78HocNlv0mXXo0wdh9VT1R04WU8HGOfaOob26pF+9P5/lYjN/q7DHOX1bvX60hnhOvuQUJdbA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-object-rest-spread": "^7.8.0" + } + }, + "@babel/plugin-proposal-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-catch-binding/-/plugin-proposal-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-0gkX7J7E+AtAw9fcwlVQj8peP61qhdg/89D5swOkjYbkboA2CVckn3kiyum1DE0wskGb7KJJxBdyEBApDLLVdw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.0" + } + }, + "@babel/plugin-proposal-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-optional-chaining/-/plugin-proposal-optional-chaining-7.8.3.tgz", + "integrity": "sha512-QIoIR9abkVn+seDE3OjA08jWcs3eZ9+wJCKSRgo3WdEU2csFYgdScb+8qHB3+WXsGJD55u+5hWCISI7ejXS+kg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-optional-chaining": "^7.8.0" + } + }, + "@babel/plugin-proposal-unicode-property-regex": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-proposal-unicode-property-regex/-/plugin-proposal-unicode-property-regex-7.8.3.tgz", + "integrity": "sha512-1/1/rEZv2XGweRwwSkLpY+s60za9OZ1hJs4YDqFHCw0kYWYwL5IFljVY1MYBL+weT1l9pokDO2uhSTLVxzoHkQ==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-async-generators": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-async-generators/-/plugin-syntax-async-generators-7.8.4.tgz", + "integrity": "sha512-tycmZxkGfZaxhMRbXlPXuVFpdWlXpir2W4AMhSJgRKzk/eDlIXOhb2LHWoLpDF7TEHylV5zNhykX6KAgHJmTNw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-decorators": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-decorators/-/plugin-syntax-decorators-7.8.3.tgz", + "integrity": "sha512-8Hg4dNNT9/LcA1zQlfwuKR8BUc/if7Q7NkTam9sGTcJphLwpf2g4S42uhspQrIrR+dpzE0dtTqBVFoHl8GtnnQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-dynamic-import": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-dynamic-import/-/plugin-syntax-dynamic-import-7.8.3.tgz", + "integrity": "sha512-5gdGbFon+PszYzqs83S3E5mpi7/y/8M9eC90MRTZfduQOYW76ig6SOSPNe41IG5LoP3FGBn2N0RjVDSQiS94kQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-flow": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-flow/-/plugin-syntax-flow-7.8.3.tgz", + "integrity": "sha512-innAx3bUbA0KSYj2E2MNFSn9hiCeowOFLxlsuhXzw8hMQnzkDomUr9QCD7E9VF60NmnG1sNTuuv6Qf4f8INYsg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-json-strings": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-json-strings/-/plugin-syntax-json-strings-7.8.3.tgz", + "integrity": "sha512-lY6kdGpWHvjoe2vk4WrAapEuBR69EMxZl+RoGRhrFGNYVK8mOPAW8VfbT/ZgrFbXlDNiiaxQnAtgVCZ6jv30EA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-jsx": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.8.3.tgz", + "integrity": "sha512-WxdW9xyLgBdefoo0Ynn3MRSkhe5tFVxxKNVdnZSh318WrG2e2jH+E9wd/++JsqcLJZPfz87njQJ8j2Upjm0M0A==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-nullish-coalescing-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-nullish-coalescing-operator/-/plugin-syntax-nullish-coalescing-operator-7.8.3.tgz", + "integrity": "sha512-aSff4zPII1u2QD7y+F8oDsz19ew4IGEJg9SVW+bqwpwtfFleiQDMdzA/R+UlWDzfnHFCxxleFT0PMIrR36XLNQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-numeric-separator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-numeric-separator/-/plugin-syntax-numeric-separator-7.8.3.tgz", + "integrity": "sha512-H7dCMAdN83PcCmqmkHB5dtp+Xa9a6LKSvA2hiFBC/5alSHxM5VgWZXFqDi0YFe8XNGT6iCa+z4V4zSt/PdZ7Dw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-object-rest-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-object-rest-spread/-/plugin-syntax-object-rest-spread-7.8.3.tgz", + "integrity": "sha512-XoqMijGZb9y3y2XskN+P1wUGiVwWZ5JmoDRwx5+3GmEplNyVM2s2Dg8ILFQm8rWM48orGy5YpI5Bl8U1y7ydlA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-catch-binding": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-catch-binding/-/plugin-syntax-optional-catch-binding-7.8.3.tgz", + "integrity": "sha512-6VPD0Pc1lpTqw0aKoeRTMiB+kWhAoT24PA+ksWSBrFtl5SIRVpZlwN3NNPQjehA2E/91FV3RjLWoVTglWcSV3Q==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-optional-chaining": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-optional-chaining/-/plugin-syntax-optional-chaining-7.8.3.tgz", + "integrity": "sha512-KoK9ErH1MBlCPxV0VANkXW2/dw4vlbGDrFgz8bmUsBGYkFRcbRwMh6cIJubdPrkxRwuGdtCk0v/wPTKbQgBjkg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.0" + } + }, + "@babel/plugin-syntax-top-level-await": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-top-level-await/-/plugin-syntax-top-level-await-7.8.3.tgz", + "integrity": "sha512-kwj1j9lL/6Wd0hROD3b/OZZ7MSrZLqqn9RAZ5+cYYsflQ9HZBIKCUkr3+uL1MEJ1NePiUbf98jjiMQSv0NMR9g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-syntax-typescript": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.8.3.tgz", + "integrity": "sha512-GO1MQ/SGGGoiEXY0e0bSpHimJvxqB7lktLLIq2pv8xG7WZ8IMEle74jIe1FhprHBWjwjZtXHkycDLZXIWM5Wfg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-arrow-functions": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.8.3.tgz", + "integrity": "sha512-0MRF+KC8EqH4dbuITCWwPSzsyO3HIWWlm30v8BbbpOrS1B++isGxPnnuq/IZvOX5J2D/p7DQalQm+/2PnlKGxg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-async-to-generator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.8.3.tgz", + "integrity": "sha512-imt9tFLD9ogt56Dd5CI/6XgpukMwd/fLGSrix2httihVe7LOGVPhyhMh1BU5kDM7iHD08i8uUtmV2sWaBFlHVQ==", + "requires": { + "@babel/helper-module-imports": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-remap-async-to-generator": "^7.8.3" + } + }, + "@babel/plugin-transform-block-scoped-functions": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.8.3.tgz", + "integrity": "sha512-vo4F2OewqjbB1+yaJ7k2EJFHlTP3jR634Z9Cj9itpqNjuLXvhlVxgnjsHsdRgASR8xYDrx6onw4vW5H6We0Jmg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-block-scoping": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.8.3.tgz", + "integrity": "sha512-pGnYfm7RNRgYRi7bids5bHluENHqJhrV4bCZRwc5GamaWIIs07N4rZECcmJL6ZClwjDz1GbdMZFtPs27hTB06w==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "lodash": "^4.17.13" + } + }, + "@babel/plugin-transform-classes": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.8.3.tgz", + "integrity": "sha512-SjT0cwFJ+7Rbr1vQsvphAHwUHvSUPmMjMU/0P59G8U2HLFqSa082JO7zkbDNWs9kH/IUqpHI6xWNesGf8haF1w==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.3", + "@babel/helper-define-map": "^7.8.3", + "@babel/helper-function-name": "^7.8.3", + "@babel/helper-optimise-call-expression": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-replace-supers": "^7.8.3", + "@babel/helper-split-export-declaration": "^7.8.3", + "globals": "^11.1.0" + } + }, + "@babel/plugin-transform-computed-properties": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.8.3.tgz", + "integrity": "sha512-O5hiIpSyOGdrQZRQ2ccwtTVkgUDBBiCuK//4RJ6UfePllUTCENOzKxfh6ulckXKc0DixTFLCfb2HVkNA7aDpzA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-destructuring": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.8.3.tgz", + "integrity": "sha512-H4X646nCkiEcHZUZaRkhE2XVsoz0J/1x3VVujnn96pSoGCtKPA99ZZA+va+gK+92Zycd6OBKCD8tDb/731bhgQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-dotall-regex": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.8.3.tgz", + "integrity": "sha512-kLs1j9Nn4MQoBYdRXH6AeaXMbEJFaFu/v1nQkvib6QzTj8MZI5OQzqmD83/2jEM1z0DLilra5aWO5YpyC0ALIw==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-duplicate-keys": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.8.3.tgz", + "integrity": "sha512-s8dHiBUbcbSgipS4SMFuWGqCvyge5V2ZeAWzR6INTVC3Ltjig/Vw1G2Gztv0vU/hRG9X8IvKvYdoksnUfgXOEQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-exponentiation-operator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.8.3.tgz", + "integrity": "sha512-zwIpuIymb3ACcInbksHaNcR12S++0MDLKkiqXHl3AzpgdKlFNhog+z/K0+TGW+b0w5pgTq4H6IwV/WhxbGYSjQ==", + "requires": { + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-flow-strip-types": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-flow-strip-types/-/plugin-transform-flow-strip-types-7.8.3.tgz", + "integrity": "sha512-g/6WTWG/xbdd2exBBzMfygjX/zw4eyNC4X8pRaq7aRHRoDUCzAIu3kGYIXviOv8BjCuWm8vDBwjHcjiRNgXrPA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-flow": "^7.8.3" + } + }, + "@babel/plugin-transform-for-of": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.8.4.tgz", + "integrity": "sha512-iAXNlOWvcYUYoV8YIxwS7TxGRJcxyl8eQCfT+A5j8sKUzRFvJdcyjp97jL2IghWSRDaL2PU2O2tX8Cu9dTBq5A==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-function-name": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.8.3.tgz", + "integrity": "sha512-rO/OnDS78Eifbjn5Py9v8y0aR+aSYhDhqAwVfsTl0ERuMZyr05L1aFSCJnbv2mmsLkit/4ReeQ9N2BgLnOcPCQ==", + "requires": { + "@babel/helper-function-name": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-literals": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.8.3.tgz", + "integrity": "sha512-3Tqf8JJ/qB7TeldGl+TT55+uQei9JfYaregDcEAyBZ7akutriFrt6C/wLYIer6OYhleVQvH/ntEhjE/xMmy10A==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-member-expression-literals": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.8.3.tgz", + "integrity": "sha512-3Wk2EXhnw+rP+IDkK6BdtPKsUE5IeZ6QOGrPYvw52NwBStw9V1ZVzxgK6fSKSxqUvH9eQPR3tm3cOq79HlsKYA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-modules-amd": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.8.3.tgz", + "integrity": "sha512-MadJiU3rLKclzT5kBH4yxdry96odTUwuqrZM+GllFI/VhxfPz+k9MshJM+MwhfkCdxxclSbSBbUGciBngR+kEQ==", + "requires": { + "@babel/helper-module-transforms": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "babel-plugin-dynamic-import-node": "^2.3.0" + } + }, + "@babel/plugin-transform-modules-commonjs": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.8.3.tgz", + "integrity": "sha512-JpdMEfA15HZ/1gNuB9XEDlZM1h/gF/YOH7zaZzQu2xCFRfwc01NXBMHHSTT6hRjlXJJs5x/bfODM3LiCk94Sxg==", + "requires": { + "@babel/helper-module-transforms": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-simple-access": "^7.8.3", + "babel-plugin-dynamic-import-node": "^2.3.0" + } + }, + "@babel/plugin-transform-modules-systemjs": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.8.3.tgz", + "integrity": "sha512-8cESMCJjmArMYqa9AO5YuMEkE4ds28tMpZcGZB/jl3n0ZzlsxOAi3mC+SKypTfT8gjMupCnd3YiXCkMjj2jfOg==", + "requires": { + "@babel/helper-hoist-variables": "^7.8.3", + "@babel/helper-module-transforms": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "babel-plugin-dynamic-import-node": "^2.3.0" + } + }, + "@babel/plugin-transform-modules-umd": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.8.3.tgz", + "integrity": "sha512-evhTyWhbwbI3/U6dZAnx/ePoV7H6OUG+OjiJFHmhr9FPn0VShjwC2kdxqIuQ/+1P50TMrneGzMeyMTFOjKSnAw==", + "requires": { + "@babel/helper-module-transforms": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-named-capturing-groups-regex": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.8.3.tgz", + "integrity": "sha512-f+tF/8UVPU86TrCb06JoPWIdDpTNSGGcAtaD9mLP0aYGA0OS0j7j7DHJR0GTFrUZPUU6loZhbsVZgTh0N+Qdnw==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.3" + } + }, + "@babel/plugin-transform-new-target": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.8.3.tgz", + "integrity": "sha512-QuSGysibQpyxexRyui2vca+Cmbljo8bcRckgzYV4kRIsHpVeyeC3JDO63pY+xFZ6bWOBn7pfKZTqV4o/ix9sFw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-object-super": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.8.3.tgz", + "integrity": "sha512-57FXk+gItG/GejofIyLIgBKTas4+pEU47IXKDBWFTxdPd7F80H8zybyAY7UoblVfBhBGs2EKM+bJUu2+iUYPDQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-replace-supers": "^7.8.3" + } + }, + "@babel/plugin-transform-parameters": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.8.4.tgz", + "integrity": "sha512-IsS3oTxeTsZlE5KqzTbcC2sV0P9pXdec53SU+Yxv7o/6dvGM5AkTotQKhoSffhNgZ/dftsSiOoxy7evCYJXzVA==", + "requires": { + "@babel/helper-call-delegate": "^7.8.3", + "@babel/helper-get-function-arity": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-property-literals": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.8.3.tgz", + "integrity": "sha512-uGiiXAZMqEoQhRWMK17VospMZh5sXWg+dlh2soffpkAl96KAm+WZuJfa6lcELotSRmooLqg0MWdH6UUq85nmmg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-react-constant-elements": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-constant-elements/-/plugin-transform-react-constant-elements-7.8.3.tgz", + "integrity": "sha512-glrzN2U+egwRfkNFtL34xIBYTxbbUF2qJTP8HD3qETBBqzAWSeNB821X0GjU06+dNpq/UyCIjI72FmGE5NNkQQ==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-react-display-name": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.8.3.tgz", + "integrity": "sha512-3Jy/PCw8Fe6uBKtEgz3M82ljt+lTg+xJaM4og+eyu83qLT87ZUSckn0wy7r31jflURWLO83TW6Ylf7lyXj3m5A==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-react-jsx": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.8.3.tgz", + "integrity": "sha512-r0h+mUiyL595ikykci+fbwm9YzmuOrUBi0b+FDIKmi3fPQyFokWVEMJnRWHJPPQEjyFJyna9WZC6Viv6UHSv1g==", + "requires": { + "@babel/helper-builder-react-jsx": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-jsx": "^7.8.3" + } + }, + "@babel/plugin-transform-react-jsx-self": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-self/-/plugin-transform-react-jsx-self-7.8.3.tgz", + "integrity": "sha512-01OT7s5oa0XTLf2I8XGsL8+KqV9lx3EZV+jxn/L2LQ97CGKila2YMroTkCEIE0HV/FF7CMSRsIAybopdN9NTdg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-jsx": "^7.8.3" + } + }, + "@babel/plugin-transform-react-jsx-source": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-source/-/plugin-transform-react-jsx-source-7.8.3.tgz", + "integrity": "sha512-PLMgdMGuVDtRS/SzjNEQYUT8f4z1xb2BAT54vM1X5efkVuYBf5WyGUMbpmARcfq3NaglIwz08UVQK4HHHbC6ag==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-jsx": "^7.8.3" + } + }, + "@babel/plugin-transform-regenerator": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.8.3.tgz", + "integrity": "sha512-qt/kcur/FxrQrzFR432FGZznkVAjiyFtCOANjkAKwCbt465L6ZCiUQh2oMYGU3Wo8LRFJxNDFwWn106S5wVUNA==", + "requires": { + "regenerator-transform": "^0.14.0" + } + }, + "@babel/plugin-transform-reserved-words": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.8.3.tgz", + "integrity": "sha512-mwMxcycN3omKFDjDQUl+8zyMsBfjRFr0Zn/64I41pmjv4NJuqcYlEtezwYtw9TFd9WR1vN5kiM+O0gMZzO6L0A==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-runtime": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.8.3.tgz", + "integrity": "sha512-/vqUt5Yh+cgPZXXjmaG9NT8aVfThKk7G4OqkVhrXqwsC5soMn/qTCxs36rZ2QFhpfTJcjw4SNDIZ4RUb8OL4jQ==", + "requires": { + "@babel/helper-module-imports": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "resolve": "^1.8.1", + "semver": "^5.5.1" + } + }, + "@babel/plugin-transform-shorthand-properties": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.8.3.tgz", + "integrity": "sha512-I9DI6Odg0JJwxCHzbzW08ggMdCezoWcuQRz3ptdudgwaHxTjxw5HgdFJmZIkIMlRymL6YiZcped4TTCB0JcC8w==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-spread": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.8.3.tgz", + "integrity": "sha512-CkuTU9mbmAoFOI1tklFWYYbzX5qCIZVXPVy0jpXgGwkplCndQAa58s2jr66fTeQnA64bDox0HL4U56CFYoyC7g==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-sticky-regex": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.8.3.tgz", + "integrity": "sha512-9Spq0vGCD5Bb4Z/ZXXSK5wbbLFMG085qd2vhL1JYu1WcQ5bXqZBAYRzU1d+p79GcHs2szYv5pVQCX13QgldaWw==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/helper-regex": "^7.8.3" + } + }, + "@babel/plugin-transform-template-literals": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.8.3.tgz", + "integrity": "sha512-820QBtykIQOLFT8NZOcTRJ1UNuztIELe4p9DCgvj4NK+PwluSJ49we7s9FB1HIGNIYT7wFUJ0ar2QpCDj0escQ==", + "requires": { + "@babel/helper-annotate-as-pure": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-typeof-symbol": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.8.4.tgz", + "integrity": "sha512-2QKyfjGdvuNfHsb7qnBBlKclbD4CfshH2KvDabiijLMGXPHJXGxtDzwIF7bQP+T0ysw8fYTtxPafgfs/c1Lrqg==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/plugin-transform-typescript": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.8.3.tgz", + "integrity": "sha512-Ebj230AxcrKGZPKIp4g4TdQLrqX95TobLUWKd/CwG7X1XHUH1ZpkpFvXuXqWbtGRWb7uuEWNlrl681wsOArAdQ==", + "requires": { + "@babel/helper-create-class-features-plugin": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-syntax-typescript": "^7.8.3" + } + }, + "@babel/plugin-transform-unicode-regex": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.8.3.tgz", + "integrity": "sha512-+ufgJjYdmWfSQ+6NS9VGUR2ns8cjJjYbrbi11mZBTaWm+Fui/ncTLFF28Ei1okavY+xkojGr1eJxNsWYeA5aZw==", + "requires": { + "@babel/helper-create-regexp-features-plugin": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3" + } + }, + "@babel/preset-env": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.8.4.tgz", + "integrity": "sha512-HihCgpr45AnSOHRbS5cWNTINs0TwaR8BS8xIIH+QwiW8cKL0llV91njQMpeMReEPVs+1Ao0x3RLEBLtt1hOq4w==", + "requires": { + "@babel/compat-data": "^7.8.4", + "@babel/helper-compilation-targets": "^7.8.4", + "@babel/helper-module-imports": "^7.8.3", + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-proposal-async-generator-functions": "^7.8.3", + "@babel/plugin-proposal-dynamic-import": "^7.8.3", + "@babel/plugin-proposal-json-strings": "^7.8.3", + "@babel/plugin-proposal-nullish-coalescing-operator": "^7.8.3", + "@babel/plugin-proposal-object-rest-spread": "^7.8.3", + "@babel/plugin-proposal-optional-catch-binding": "^7.8.3", + "@babel/plugin-proposal-optional-chaining": "^7.8.3", + "@babel/plugin-proposal-unicode-property-regex": "^7.8.3", + "@babel/plugin-syntax-async-generators": "^7.8.0", + "@babel/plugin-syntax-dynamic-import": "^7.8.0", + "@babel/plugin-syntax-json-strings": "^7.8.0", + "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.0", + "@babel/plugin-syntax-object-rest-spread": "^7.8.0", + "@babel/plugin-syntax-optional-catch-binding": "^7.8.0", + "@babel/plugin-syntax-optional-chaining": "^7.8.0", + "@babel/plugin-syntax-top-level-await": "^7.8.3", + "@babel/plugin-transform-arrow-functions": "^7.8.3", + "@babel/plugin-transform-async-to-generator": "^7.8.3", + "@babel/plugin-transform-block-scoped-functions": "^7.8.3", + "@babel/plugin-transform-block-scoping": "^7.8.3", + "@babel/plugin-transform-classes": "^7.8.3", + "@babel/plugin-transform-computed-properties": "^7.8.3", + "@babel/plugin-transform-destructuring": "^7.8.3", + "@babel/plugin-transform-dotall-regex": "^7.8.3", + "@babel/plugin-transform-duplicate-keys": "^7.8.3", + "@babel/plugin-transform-exponentiation-operator": "^7.8.3", + "@babel/plugin-transform-for-of": "^7.8.4", + "@babel/plugin-transform-function-name": "^7.8.3", + "@babel/plugin-transform-literals": "^7.8.3", + "@babel/plugin-transform-member-expression-literals": "^7.8.3", + "@babel/plugin-transform-modules-amd": "^7.8.3", + "@babel/plugin-transform-modules-commonjs": "^7.8.3", + "@babel/plugin-transform-modules-systemjs": "^7.8.3", + "@babel/plugin-transform-modules-umd": "^7.8.3", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.8.3", + "@babel/plugin-transform-new-target": "^7.8.3", + "@babel/plugin-transform-object-super": "^7.8.3", + "@babel/plugin-transform-parameters": "^7.8.4", + "@babel/plugin-transform-property-literals": "^7.8.3", + "@babel/plugin-transform-regenerator": "^7.8.3", + "@babel/plugin-transform-reserved-words": "^7.8.3", + "@babel/plugin-transform-shorthand-properties": "^7.8.3", + "@babel/plugin-transform-spread": "^7.8.3", + "@babel/plugin-transform-sticky-regex": "^7.8.3", + "@babel/plugin-transform-template-literals": "^7.8.3", + "@babel/plugin-transform-typeof-symbol": "^7.8.4", + "@babel/plugin-transform-unicode-regex": "^7.8.3", + "@babel/types": "^7.8.3", + "browserslist": "^4.8.5", + "core-js-compat": "^3.6.2", + "invariant": "^2.2.2", + "levenary": "^1.1.1", + "semver": "^5.5.0" + } + }, + "@babel/preset-react": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/preset-react/-/preset-react-7.8.3.tgz", + "integrity": "sha512-9hx0CwZg92jGb7iHYQVgi0tOEHP/kM60CtWJQnmbATSPIQQ2xYzfoCI3EdqAhFBeeJwYMdWQuDUHMsuDbH9hyQ==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-transform-react-display-name": "^7.8.3", + "@babel/plugin-transform-react-jsx": "^7.8.3", + "@babel/plugin-transform-react-jsx-self": "^7.8.3", + "@babel/plugin-transform-react-jsx-source": "^7.8.3" + } + }, + "@babel/preset-typescript": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.8.3.tgz", + "integrity": "sha512-qee5LgPGui9zQ0jR1TeU5/fP9L+ovoArklEqY12ek8P/wV5ZeM/VYSQYwICeoT6FfpJTekG9Ilay5PhwsOpMHA==", + "requires": { + "@babel/helper-plugin-utils": "^7.8.3", + "@babel/plugin-transform-typescript": "^7.8.3" + } + }, + "@babel/runtime": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.8.4.tgz", + "integrity": "sha512-neAp3zt80trRVBI1x0azq6c57aNBqYZH8KhMm3TaB7wEI5Q4A2SHfBHE8w9gOhI/lrqxtEbXZgQIrHP+wvSGwQ==", + "requires": { + "regenerator-runtime": "^0.13.2" + } + }, + "@babel/template": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.8.3.tgz", + "integrity": "sha512-04m87AcQgAFdvuoyiQ2kgELr2tV8B4fP/xJAVUL3Yb3bkNdMedD3d0rlSQr3PegP0cms3eHjl1F7PWlvWbU8FQ==", + "requires": { + "@babel/code-frame": "^7.8.3", + "@babel/parser": "^7.8.3", + "@babel/types": "^7.8.3" + } + }, + "@babel/traverse": { + "version": "7.8.4", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.8.4.tgz", + "integrity": "sha512-NGLJPZwnVEyBPLI+bl9y9aSnxMhsKz42so7ApAv9D+b4vAFPpY013FTS9LdKxcABoIYFU52HcYga1pPlx454mg==", + "requires": { + "@babel/code-frame": "^7.8.3", + "@babel/generator": "^7.8.4", + "@babel/helper-function-name": "^7.8.3", + "@babel/helper-split-export-declaration": "^7.8.3", + "@babel/parser": "^7.8.4", + "@babel/types": "^7.8.3", + "debug": "^4.1.0", + "globals": "^11.1.0", + "lodash": "^4.17.13" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "@babel/types": { + "version": "7.8.3", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.8.3.tgz", + "integrity": "sha512-jBD+G8+LWpMBBWvVcdr4QysjUE4mU/syrhN17o1u3gx0/WzJB1kwiVZAXRtWbsIPOwW8pF/YJV5+nmetPzepXg==", + "requires": { + "esutils": "^2.0.2", + "lodash": "^4.17.13", + "to-fast-properties": "^2.0.0" + } + }, + "@cnakazawa/watch": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/@cnakazawa/watch/-/watch-1.0.4.tgz", + "integrity": "sha512-v9kIhKwjeZThiWrLmj0y17CWoyddASLj9O2yvbZkbvw/N3rWOYy9zkV66ursAoVr0mV15bL8g0c4QZUE6cdDoQ==", + "requires": { + "exec-sh": "^0.3.2", + "minimist": "^1.2.0" + } + }, + "@csstools/convert-colors": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/@csstools/convert-colors/-/convert-colors-1.4.0.tgz", + "integrity": "sha512-5a6wqoJV/xEdbRNKVo6I4hO3VjyDq//8q2f9I6PBAvMesJHFauXDorcNCsr9RzvsZnaWi5NYCcfyqP1QeFHFbw==" + }, + "@csstools/normalize.css": { + "version": "10.1.0", + "resolved": "https://registry.npmjs.org/@csstools/normalize.css/-/normalize.css-10.1.0.tgz", + "integrity": "sha512-ij4wRiunFfaJxjB0BdrYHIH8FxBJpOwNPhhAcunlmPdXudL1WQV1qoP9un6JsEBAgQH+7UXyyjh0g7jTxXK6tg==" + }, + "@fortawesome/fontawesome-free": { + "version": "5.12.1", + "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-free/-/fontawesome-free-5.12.1.tgz", + "integrity": "sha512-ZtjIIFplxncqxvogq148C3hBLQE+W3iJ8E4UvJ09zIJUgzwLcROsWwFDErVSXY2Plzao5J9KUYNHKHMEUYDMKw==" + }, + "@hapi/address": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/@hapi/address/-/address-2.1.4.tgz", + "integrity": "sha512-QD1PhQk+s31P1ixsX0H0Suoupp3VMXzIVMSwobR3F3MSUO2YCV0B7xqLcUw/Bh8yuvd3LhpyqLQWTNcRmp6IdQ==" + }, + "@hapi/bourne": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/@hapi/bourne/-/bourne-1.3.2.tgz", + "integrity": "sha512-1dVNHT76Uu5N3eJNTYcvxee+jzX4Z9lfciqRRHCU27ihbUcYi+iSc2iml5Ke1LXe1SyJCLA0+14Jh4tXJgOppA==" + }, + "@hapi/hoek": { + "version": "8.5.1", + "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-8.5.1.tgz", + "integrity": "sha512-yN7kbciD87WzLGc5539Tn0sApjyiGHAJgKvG9W8C7O+6c7qmoQMfVs0W4bX17eqz6C78QJqqFrtgdK5EWf6Qow==" + }, + "@hapi/joi": { + "version": "15.1.1", + "resolved": "https://registry.npmjs.org/@hapi/joi/-/joi-15.1.1.tgz", + "integrity": "sha512-entf8ZMOK8sc+8YfeOlM8pCfg3b5+WZIKBfUaaJT8UsjAAPjartzxIYm3TIbjvA4u+u++KbcXD38k682nVHDAQ==", + "requires": { + "@hapi/address": "2.x.x", + "@hapi/bourne": "1.x.x", + "@hapi/hoek": "8.x.x", + "@hapi/topo": "3.x.x" + } + }, + "@hapi/topo": { + "version": "3.1.6", + "resolved": "https://registry.npmjs.org/@hapi/topo/-/topo-3.1.6.tgz", + "integrity": "sha512-tAag0jEcjwH+P2quUfipd7liWCNX2F8NvYjQp2wtInsZxnMlypdw0FtAOLxtvvkO+GSRRbmNi8m/5y42PQJYCQ==", + "requires": { + "@hapi/hoek": "^8.3.0" + } + }, + "@jest/console": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/console/-/console-24.9.0.tgz", + "integrity": "sha512-Zuj6b8TnKXi3q4ymac8EQfc3ea/uhLeCGThFqXeC8H9/raaH8ARPUTdId+XyGd03Z4In0/VjD2OYFcBF09fNLQ==", + "requires": { + "@jest/source-map": "^24.9.0", + "chalk": "^2.0.1", + "slash": "^2.0.0" + } + }, + "@jest/core": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/core/-/core-24.9.0.tgz", + "integrity": "sha512-Fogg3s4wlAr1VX7q+rhV9RVnUv5tD7VuWfYy1+whMiWUrvl7U3QJSJyWcDio9Lq2prqYsZaeTv2Rz24pWGkJ2A==", + "requires": { + "@jest/console": "^24.7.1", + "@jest/reporters": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "graceful-fs": "^4.1.15", + "jest-changed-files": "^24.9.0", + "jest-config": "^24.9.0", + "jest-haste-map": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-resolve": "^24.9.0", + "jest-resolve-dependencies": "^24.9.0", + "jest-runner": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-snapshot": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "jest-watcher": "^24.9.0", + "micromatch": "^3.1.10", + "p-each-series": "^1.0.0", + "realpath-native": "^1.1.0", + "rimraf": "^2.5.4", + "slash": "^2.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "ansi-escapes": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", + "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" + } + } + }, + "@jest/environment": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/environment/-/environment-24.9.0.tgz", + "integrity": "sha512-5A1QluTPhvdIPFYnO3sZC3smkNeXPVELz7ikPbhUj0bQjB07EoE9qtLrem14ZUYWdVayYbsjVwIiL4WBIMV4aQ==", + "requires": { + "@jest/fake-timers": "^24.9.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "jest-mock": "^24.9.0" + } + }, + "@jest/fake-timers": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/fake-timers/-/fake-timers-24.9.0.tgz", + "integrity": "sha512-eWQcNa2YSwzXWIMC5KufBh3oWRIijrQFROsIqt6v/NS9Io/gknw1jsAC9c+ih/RQX4A3O7SeWAhQeN0goKhT9A==", + "requires": { + "@jest/types": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-mock": "^24.9.0" + } + }, + "@jest/reporters": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/reporters/-/reporters-24.9.0.tgz", + "integrity": "sha512-mu4X0yjaHrffOsWmVLzitKmmmWSQ3GGuefgNscUSWNiUNcEOSEQk9k3pERKEQVBb0Cnn88+UESIsZEMH3o88Gw==", + "requires": { + "@jest/environment": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "glob": "^7.1.2", + "istanbul-lib-coverage": "^2.0.2", + "istanbul-lib-instrument": "^3.0.1", + "istanbul-lib-report": "^2.0.4", + "istanbul-lib-source-maps": "^3.0.1", + "istanbul-reports": "^2.2.6", + "jest-haste-map": "^24.9.0", + "jest-resolve": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-util": "^24.9.0", + "jest-worker": "^24.6.0", + "node-notifier": "^5.4.2", + "slash": "^2.0.0", + "source-map": "^0.6.0", + "string-length": "^2.0.0" + } + }, + "@jest/source-map": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/source-map/-/source-map-24.9.0.tgz", + "integrity": "sha512-/Xw7xGlsZb4MJzNDgB7PW5crou5JqWiBQaz6xyPd3ArOg2nfn/PunV8+olXbbEZzNl591o5rWKE9BRDaFAuIBg==", + "requires": { + "callsites": "^3.0.0", + "graceful-fs": "^4.1.15", + "source-map": "^0.6.0" + } + }, + "@jest/test-result": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/test-result/-/test-result-24.9.0.tgz", + "integrity": "sha512-XEFrHbBonBJ8dGp2JmF8kP/nQI/ImPpygKHwQ/SY+es59Z3L5PI4Qb9TQQMAEeYsThG1xF0k6tmG0tIKATNiiA==", + "requires": { + "@jest/console": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/istanbul-lib-coverage": "^2.0.0" + } + }, + "@jest/test-sequencer": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/test-sequencer/-/test-sequencer-24.9.0.tgz", + "integrity": "sha512-6qqsU4o0kW1dvA95qfNog8v8gkRN9ph6Lz7r96IvZpHdNipP2cBcb07J1Z45mz/VIS01OHJ3pY8T5fUY38tg4A==", + "requires": { + "@jest/test-result": "^24.9.0", + "jest-haste-map": "^24.9.0", + "jest-runner": "^24.9.0", + "jest-runtime": "^24.9.0" + } + }, + "@jest/transform": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/transform/-/transform-24.9.0.tgz", + "integrity": "sha512-TcQUmyNRxV94S0QpMOnZl0++6RMiqpbH/ZMccFB/amku6Uwvyb1cjYX7xkp5nGNkbX4QPH/FcB6q1HBTHynLmQ==", + "requires": { + "@babel/core": "^7.1.0", + "@jest/types": "^24.9.0", + "babel-plugin-istanbul": "^5.1.0", + "chalk": "^2.0.1", + "convert-source-map": "^1.4.0", + "fast-json-stable-stringify": "^2.0.0", + "graceful-fs": "^4.1.15", + "jest-haste-map": "^24.9.0", + "jest-regex-util": "^24.9.0", + "jest-util": "^24.9.0", + "micromatch": "^3.1.10", + "pirates": "^4.0.1", + "realpath-native": "^1.1.0", + "slash": "^2.0.0", + "source-map": "^0.6.1", + "write-file-atomic": "2.4.1" + } + }, + "@jest/types": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/@jest/types/-/types-24.9.0.tgz", + "integrity": "sha512-XKK7ze1apu5JWQ5eZjHITP66AX+QsLlbaJRBGYr8pNzwcAE2JVkwnf0yqjHTsDRcjR0mujy/NmZMXw5kl+kGBw==", + "requires": { + "@types/istanbul-lib-coverage": "^2.0.0", + "@types/istanbul-reports": "^1.1.1", + "@types/yargs": "^13.0.0" + } + }, + "@mrmlnc/readdir-enhanced": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/@mrmlnc/readdir-enhanced/-/readdir-enhanced-2.2.1.tgz", + "integrity": "sha512-bPHp6Ji8b41szTOcaP63VlnbbO5Ny6dwAATtY6JTjh5N2OLrb5Qk/Th5cRkRQhkWCt+EJsYrNB0MiL+Gpn6e3g==", + "requires": { + "call-me-maybe": "^1.0.1", + "glob-to-regexp": "^0.3.0" + } + }, + "@nodelib/fs.stat": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/@nodelib/fs.stat/-/fs.stat-1.1.3.tgz", + "integrity": "sha512-shAmDyaQC4H92APFoIaVDHCx5bStIocgvbwQyxPRrbUY20V1EYTbSDchWbuwlMG3V17cprZhA6+78JfB+3DTPw==" + }, + "@sheerun/mutationobserver-shim": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/@sheerun/mutationobserver-shim/-/mutationobserver-shim-0.3.2.tgz", + "integrity": "sha512-vTCdPp/T/Q3oSqwHmZ5Kpa9oI7iLtGl3RQaA/NyLHikvcrPxACkkKVr/XzkSPJWXHRhKGzVvb0urJsbMlRxi1Q==" + }, + "@svgr/babel-plugin-add-jsx-attribute": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-add-jsx-attribute/-/babel-plugin-add-jsx-attribute-4.2.0.tgz", + "integrity": "sha512-j7KnilGyZzYr/jhcrSYS3FGWMZVaqyCG0vzMCwzvei0coIkczuYMcniK07nI0aHJINciujjH11T72ICW5eL5Ig==" + }, + "@svgr/babel-plugin-remove-jsx-attribute": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-attribute/-/babel-plugin-remove-jsx-attribute-4.2.0.tgz", + "integrity": "sha512-3XHLtJ+HbRCH4n28S7y/yZoEQnRpl0tvTZQsHqvaeNXPra+6vE5tbRliH3ox1yZYPCxrlqaJT/Mg+75GpDKlvQ==" + }, + "@svgr/babel-plugin-remove-jsx-empty-expression": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-remove-jsx-empty-expression/-/babel-plugin-remove-jsx-empty-expression-4.2.0.tgz", + "integrity": "sha512-yTr2iLdf6oEuUE9MsRdvt0NmdpMBAkgK8Bjhl6epb+eQWk6abBaX3d65UZ3E3FWaOwePyUgNyNCMVG61gGCQ7w==" + }, + "@svgr/babel-plugin-replace-jsx-attribute-value": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-replace-jsx-attribute-value/-/babel-plugin-replace-jsx-attribute-value-4.2.0.tgz", + "integrity": "sha512-U9m870Kqm0ko8beHawRXLGLvSi/ZMrl89gJ5BNcT452fAjtF2p4uRzXkdzvGJJJYBgx7BmqlDjBN/eCp5AAX2w==" + }, + "@svgr/babel-plugin-svg-dynamic-title": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-dynamic-title/-/babel-plugin-svg-dynamic-title-4.3.3.tgz", + "integrity": "sha512-w3Be6xUNdwgParsvxkkeZb545VhXEwjGMwExMVBIdPQJeyMQHqm9Msnb2a1teHBqUYL66qtwfhNkbj1iarCG7w==" + }, + "@svgr/babel-plugin-svg-em-dimensions": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-svg-em-dimensions/-/babel-plugin-svg-em-dimensions-4.2.0.tgz", + "integrity": "sha512-C0Uy+BHolCHGOZ8Dnr1zXy/KgpBOkEUYY9kI/HseHVPeMbluaX3CijJr7D4C5uR8zrc1T64nnq/k63ydQuGt4w==" + }, + "@svgr/babel-plugin-transform-react-native-svg": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-react-native-svg/-/babel-plugin-transform-react-native-svg-4.2.0.tgz", + "integrity": "sha512-7YvynOpZDpCOUoIVlaaOUU87J4Z6RdD6spYN4eUb5tfPoKGSF9OG2NuhgYnq4jSkAxcpMaXWPf1cePkzmqTPNw==" + }, + "@svgr/babel-plugin-transform-svg-component": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/@svgr/babel-plugin-transform-svg-component/-/babel-plugin-transform-svg-component-4.2.0.tgz", + "integrity": "sha512-hYfYuZhQPCBVotABsXKSCfel2slf/yvJY8heTVX1PCTaq/IgASq1IyxPPKJ0chWREEKewIU/JMSsIGBtK1KKxw==" + }, + "@svgr/babel-preset": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/babel-preset/-/babel-preset-4.3.3.tgz", + "integrity": "sha512-6PG80tdz4eAlYUN3g5GZiUjg2FMcp+Wn6rtnz5WJG9ITGEF1pmFdzq02597Hn0OmnQuCVaBYQE1OVFAnwOl+0A==", + "requires": { + "@svgr/babel-plugin-add-jsx-attribute": "^4.2.0", + "@svgr/babel-plugin-remove-jsx-attribute": "^4.2.0", + "@svgr/babel-plugin-remove-jsx-empty-expression": "^4.2.0", + "@svgr/babel-plugin-replace-jsx-attribute-value": "^4.2.0", + "@svgr/babel-plugin-svg-dynamic-title": "^4.3.3", + "@svgr/babel-plugin-svg-em-dimensions": "^4.2.0", + "@svgr/babel-plugin-transform-react-native-svg": "^4.2.0", + "@svgr/babel-plugin-transform-svg-component": "^4.2.0" + } + }, + "@svgr/core": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/core/-/core-4.3.3.tgz", + "integrity": "sha512-qNuGF1QON1626UCaZamWt5yedpgOytvLj5BQZe2j1k1B8DUG4OyugZyfEwBeXozCUwhLEpsrgPrE+eCu4fY17w==", + "requires": { + "@svgr/plugin-jsx": "^4.3.3", + "camelcase": "^5.3.1", + "cosmiconfig": "^5.2.1" + } + }, + "@svgr/hast-util-to-babel-ast": { + "version": "4.3.2", + "resolved": "https://registry.npmjs.org/@svgr/hast-util-to-babel-ast/-/hast-util-to-babel-ast-4.3.2.tgz", + "integrity": "sha512-JioXclZGhFIDL3ddn4Kiq8qEqYM2PyDKV0aYno8+IXTLuYt6TOgHUbUAAFvqtb0Xn37NwP0BTHglejFoYr8RZg==", + "requires": { + "@babel/types": "^7.4.4" + } + }, + "@svgr/plugin-jsx": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/plugin-jsx/-/plugin-jsx-4.3.3.tgz", + "integrity": "sha512-cLOCSpNWQnDB1/v+SUENHH7a0XY09bfuMKdq9+gYvtuwzC2rU4I0wKGFEp1i24holdQdwodCtDQdFtJiTCWc+w==", + "requires": { + "@babel/core": "^7.4.5", + "@svgr/babel-preset": "^4.3.3", + "@svgr/hast-util-to-babel-ast": "^4.3.2", + "svg-parser": "^2.0.0" + } + }, + "@svgr/plugin-svgo": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/@svgr/plugin-svgo/-/plugin-svgo-4.3.1.tgz", + "integrity": "sha512-PrMtEDUWjX3Ea65JsVCwTIXuSqa3CG9px+DluF1/eo9mlDrgrtFE7NE/DjdhjJgSM9wenlVBzkzneSIUgfUI/w==", + "requires": { + "cosmiconfig": "^5.2.1", + "merge-deep": "^3.0.2", + "svgo": "^1.2.2" + } + }, + "@svgr/webpack": { + "version": "4.3.3", + "resolved": "https://registry.npmjs.org/@svgr/webpack/-/webpack-4.3.3.tgz", + "integrity": "sha512-bjnWolZ6KVsHhgyCoYRFmbd26p8XVbulCzSG53BDQqAr+JOAderYK7CuYrB3bDjHJuF6LJ7Wrr42+goLRV9qIg==", + "requires": { + "@babel/core": "^7.4.5", + "@babel/plugin-transform-react-constant-elements": "^7.0.0", + "@babel/preset-env": "^7.4.5", + "@babel/preset-react": "^7.0.0", + "@svgr/core": "^4.3.3", + "@svgr/plugin-jsx": "^4.3.3", + "@svgr/plugin-svgo": "^4.3.1", + "loader-utils": "^1.2.3" + } + }, + "@testing-library/dom": { + "version": "6.12.2", + "resolved": "https://registry.npmjs.org/@testing-library/dom/-/dom-6.12.2.tgz", + "integrity": "sha512-KCnvHra5fV+wDxg3wJObGvZFxq7v1DJt829GNFLuRDjKxVNc/B5AdsylNF5PMHFbWMXDsHwM26d2NZcZO9KjbQ==", + "requires": { + "@babel/runtime": "^7.6.2", + "@sheerun/mutationobserver-shim": "^0.3.2", + "@types/testing-library__dom": "^6.0.0", + "aria-query": "3.0.0", + "pretty-format": "^24.9.0", + "wait-for-expect": "^3.0.0" + } + }, + "@testing-library/jest-dom": { + "version": "4.2.4", + "resolved": "https://registry.npmjs.org/@testing-library/jest-dom/-/jest-dom-4.2.4.tgz", + "integrity": "sha512-j31Bn0rQo12fhCWOUWy9fl7wtqkp7In/YP2p5ZFyRuiiB9Qs3g+hS4gAmDWONbAHcRmVooNJ5eOHQDCOmUFXHg==", + "requires": { + "@babel/runtime": "^7.5.1", + "chalk": "^2.4.1", + "css": "^2.2.3", + "css.escape": "^1.5.1", + "jest-diff": "^24.0.0", + "jest-matcher-utils": "^24.0.0", + "lodash": "^4.17.11", + "pretty-format": "^24.0.0", + "redent": "^3.0.0" + } + }, + "@testing-library/react": { + "version": "9.4.1", + "resolved": "https://registry.npmjs.org/@testing-library/react/-/react-9.4.1.tgz", + "integrity": "sha512-sta3ui24HPgW92quHyQj6gpOkNgLNx8BX/QOU4k1bddo43ZdqlGwmzCYwL93bExfhergwiau+IzBGl7TCsSFeA==", + "requires": { + "@babel/runtime": "^7.8.3", + "@testing-library/dom": "^6.11.0", + "@types/testing-library__react": "^9.1.2" + } + }, + "@testing-library/user-event": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/@testing-library/user-event/-/user-event-7.2.1.tgz", + "integrity": "sha512-oZ0Ib5I4Z2pUEcoo95cT1cr6slco9WY7yiPpG+RGNkj8YcYgJnM7pXmYmorNOReh8MIGcKSqXyeGjxnr8YiZbA==" + }, + "@types/babel__core": { + "version": "7.1.5", + "resolved": "https://registry.npmjs.org/@types/babel__core/-/babel__core-7.1.5.tgz", + "integrity": "sha512-+ckxwNj892FWgvwrUWLOghQ2JDgOgeqTPwrcl+0t1pG59CP8qMJ6S/efmEd999vCFSJKOpyMakvU+w380rduUQ==", + "requires": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0", + "@types/babel__generator": "*", + "@types/babel__template": "*", + "@types/babel__traverse": "*" + } + }, + "@types/babel__generator": { + "version": "7.6.1", + "resolved": "https://registry.npmjs.org/@types/babel__generator/-/babel__generator-7.6.1.tgz", + "integrity": "sha512-bBKm+2VPJcMRVwNhxKu8W+5/zT7pwNEqeokFOmbvVSqGzFneNxYcEBro9Ac7/N9tlsaPYnZLK8J1LWKkMsLAew==", + "requires": { + "@babel/types": "^7.0.0" + } + }, + "@types/babel__template": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/@types/babel__template/-/babel__template-7.0.2.tgz", + "integrity": "sha512-/K6zCpeW7Imzgab2bLkLEbz0+1JlFSrUMdw7KoIIu+IUdu51GWaBZpd3y1VXGVXzynvGa4DaIaxNZHiON3GXUg==", + "requires": { + "@babel/parser": "^7.1.0", + "@babel/types": "^7.0.0" + } + }, + "@types/babel__traverse": { + "version": "7.0.9", + "resolved": "https://registry.npmjs.org/@types/babel__traverse/-/babel__traverse-7.0.9.tgz", + "integrity": "sha512-jEFQ8L1tuvPjOI8lnpaf73oCJe+aoxL6ygqSy6c8LcW98zaC+4mzWuQIRCEvKeCOu+lbqdXcg4Uqmm1S8AP1tw==", + "requires": { + "@babel/types": "^7.3.0" + } + }, + "@types/eslint-visitor-keys": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/@types/eslint-visitor-keys/-/eslint-visitor-keys-1.0.0.tgz", + "integrity": "sha512-OCutwjDZ4aFS6PB1UZ988C4YgwlBHJd6wCeQqaLdmadZ/7e+w79+hbMUFC1QXDNCmdyoRfAFdm0RypzwR+Qpag==" + }, + "@types/events": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/events/-/events-3.0.0.tgz", + "integrity": "sha512-EaObqwIvayI5a8dCzhFrjKzVwKLxjoG9T6Ppd5CEo07LRKfQ8Yokw54r5+Wq7FaBQ+yXRvQAYPrHwya1/UFt9g==" + }, + "@types/glob": { + "version": "7.1.1", + "resolved": "https://registry.npmjs.org/@types/glob/-/glob-7.1.1.tgz", + "integrity": "sha512-1Bh06cbWJUHMC97acuD6UMG29nMt0Aqz1vF3guLfG+kHHJhy3AyohZFFxYk2f7Q1SQIrNwvncxAE0N/9s70F2w==", + "requires": { + "@types/events": "*", + "@types/minimatch": "*", + "@types/node": "*" + } + }, + "@types/istanbul-lib-coverage": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.1.tgz", + "integrity": "sha512-hRJD2ahnnpLgsj6KWMYSrmXkM3rm2Dl1qkx6IOFD5FnuNPXJIG5L0dhgKXCYTRMGzU4n0wImQ/xfmRc4POUFlg==" + }, + "@types/istanbul-lib-report": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/@types/istanbul-lib-report/-/istanbul-lib-report-3.0.0.tgz", + "integrity": "sha512-plGgXAPfVKFoYfa9NpYDAkseG+g6Jr294RqeqcqDixSbU34MZVJRi/P+7Y8GDpzkEwLaGZZOpKIEmeVZNtKsrg==", + "requires": { + "@types/istanbul-lib-coverage": "*" + } + }, + "@types/istanbul-reports": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/@types/istanbul-reports/-/istanbul-reports-1.1.1.tgz", + "integrity": "sha512-UpYjBi8xefVChsCoBpKShdxTllC9pwISirfoZsUa2AAdQg/Jd2KQGtSbw+ya7GPo7x/wAPlH6JBhKhAsXUEZNA==", + "requires": { + "@types/istanbul-lib-coverage": "*", + "@types/istanbul-lib-report": "*" + } + }, + "@types/json-schema": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/@types/json-schema/-/json-schema-7.0.4.tgz", + "integrity": "sha512-8+KAKzEvSUdeo+kmqnKrqgeE+LcA0tjYWFY7RPProVYwnqDjukzO+3b6dLD56rYX5TdWejnEOLJYOIeh4CXKuA==" + }, + "@types/minimatch": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/@types/minimatch/-/minimatch-3.0.3.tgz", + "integrity": "sha512-tHq6qdbT9U1IRSGf14CL0pUlULksvY9OZ+5eEgl1N7t+OA3tGvNpxJCzuKQlsNgCVwbAs670L1vcVQi8j9HjnA==" + }, + "@types/node": { + "version": "13.7.4", + "resolved": "https://registry.npmjs.org/@types/node/-/node-13.7.4.tgz", + "integrity": "sha512-oVeL12C6gQS/GAExndigSaLxTrKpQPxewx9bOcwfvJiJge4rr7wNaph4J+ns5hrmIV2as5qxqN8YKthn9qh0jw==" + }, + "@types/parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/@types/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha512-//oorEZjL6sbPcKUaCdIGlIUeH26mgzimjBB77G6XRgnDl/L5wOnpyBGRe/Mmf5CVW3PwEBE1NjiMZ/ssFh4wA==" + }, + "@types/prop-types": { + "version": "15.7.3", + "resolved": "https://registry.npmjs.org/@types/prop-types/-/prop-types-15.7.3.tgz", + "integrity": "sha512-KfRL3PuHmqQLOG+2tGpRO26Ctg+Cq1E01D2DMriKEATHgWLfeNDmq9e29Q9WIky0dQ3NPkd1mzYH8Lm936Z9qw==" + }, + "@types/q": { + "version": "1.5.2", + "resolved": "https://registry.npmjs.org/@types/q/-/q-1.5.2.tgz", + "integrity": "sha512-ce5d3q03Ex0sy4R14722Rmt6MT07Ua+k4FwDfdcToYJcMKNtRVQvJ6JCAPdAmAnbRb6CsX6aYb9m96NGod9uTw==" + }, + "@types/react": { + "version": "16.9.22", + "resolved": "https://registry.npmjs.org/@types/react/-/react-16.9.22.tgz", + "integrity": "sha512-7OSt4EGiLvy0h5R7X+r0c7S739TCU/LvWbkNOrm10lUwNHe7XPz5OLhLOSZeCkqO9JSCly1NkYJ7ODTUqVnHJQ==", + "requires": { + "@types/prop-types": "*", + "csstype": "^2.2.0" + } + }, + "@types/react-dom": { + "version": "16.9.5", + "resolved": "https://registry.npmjs.org/@types/react-dom/-/react-dom-16.9.5.tgz", + "integrity": "sha512-BX6RQ8s9D+2/gDhxrj8OW+YD4R+8hj7FEM/OJHGNR0KipE1h1mSsf39YeyC81qafkq+N3rU3h3RFbLSwE5VqUg==", + "requires": { + "@types/react": "*" + } + }, + "@types/stack-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/@types/stack-utils/-/stack-utils-1.0.1.tgz", + "integrity": "sha512-l42BggppR6zLmpfU6fq9HEa2oGPEI8yrSPL3GITjfRInppYFahObbIQOQK3UGxEnyQpltZLaPe75046NOZQikw==" + }, + "@types/testing-library__dom": { + "version": "6.12.1", + "resolved": "https://registry.npmjs.org/@types/testing-library__dom/-/testing-library__dom-6.12.1.tgz", + "integrity": "sha512-cgqnEjxKk31tQt29j4baSWaZPNjQf3bHalj2gcHQTpW5SuHRal76gOpF0vypeEo6o+sS5inOvvNdzLY0B3FB2A==", + "requires": { + "pretty-format": "^24.3.0" + } + }, + "@types/testing-library__react": { + "version": "9.1.2", + "resolved": "https://registry.npmjs.org/@types/testing-library__react/-/testing-library__react-9.1.2.tgz", + "integrity": "sha512-CYaMqrswQ+cJACy268jsLAw355DZtPZGt3Jwmmotlcu8O/tkoXBI6AeZ84oZBJsIsesozPKzWzmv/0TIU+1E9Q==", + "requires": { + "@types/react-dom": "*", + "@types/testing-library__dom": "*" + } + }, + "@types/yargs": { + "version": "13.0.8", + "resolved": "https://registry.npmjs.org/@types/yargs/-/yargs-13.0.8.tgz", + "integrity": "sha512-XAvHLwG7UQ+8M4caKIH0ZozIOYay5fQkAgyIXegXT9jPtdIGdhga+sUEdAr1CiG46aB+c64xQEYyEzlwWVTNzA==", + "requires": { + "@types/yargs-parser": "*" + } + }, + "@types/yargs-parser": { + "version": "15.0.0", + "resolved": "https://registry.npmjs.org/@types/yargs-parser/-/yargs-parser-15.0.0.tgz", + "integrity": "sha512-FA/BWv8t8ZWJ+gEOnLLd8ygxH/2UFbAvgEonyfN6yWGLKc7zVjbpl2Y4CTjid9h2RfgPP6SEt6uHwEOply00yw==" + }, + "@typescript-eslint/eslint-plugin": { + "version": "2.19.2", + "resolved": "https://registry.npmjs.org/@typescript-eslint/eslint-plugin/-/eslint-plugin-2.19.2.tgz", + "integrity": "sha512-HX2qOq2GOV04HNrmKnTpSIpHjfl7iwdXe3u/Nvt+/cpmdvzYvY0NHSiTkYN257jHnq4OM/yo+OsFgati+7LqJA==", + "requires": { + "@typescript-eslint/experimental-utils": "2.19.2", + "eslint-utils": "^1.4.3", + "functional-red-black-tree": "^1.0.1", + "regexpp": "^3.0.0", + "tsutils": "^3.17.1" + } + }, + "@typescript-eslint/experimental-utils": { + "version": "2.19.2", + "resolved": "https://registry.npmjs.org/@typescript-eslint/experimental-utils/-/experimental-utils-2.19.2.tgz", + "integrity": "sha512-B88QuwT1wMJR750YvTJBNjMZwmiPpbmKYLm1yI7PCc3x0NariqPwqaPsoJRwU9DmUi0cd9dkhz1IqEnwfD+P1A==", + "requires": { + "@types/json-schema": "^7.0.3", + "@typescript-eslint/typescript-estree": "2.19.2", + "eslint-scope": "^5.0.0" + } + }, + "@typescript-eslint/parser": { + "version": "2.19.2", + "resolved": "https://registry.npmjs.org/@typescript-eslint/parser/-/parser-2.19.2.tgz", + "integrity": "sha512-8uwnYGKqX9wWHGPGdLB9sk9+12sjcdqEEYKGgbS8A0IvYX59h01o8os5qXUHMq2na8vpDRaV0suTLM7S8wraTA==", + "requires": { + "@types/eslint-visitor-keys": "^1.0.0", + "@typescript-eslint/experimental-utils": "2.19.2", + "@typescript-eslint/typescript-estree": "2.19.2", + "eslint-visitor-keys": "^1.1.0" + } + }, + "@typescript-eslint/typescript-estree": { + "version": "2.19.2", + "resolved": "https://registry.npmjs.org/@typescript-eslint/typescript-estree/-/typescript-estree-2.19.2.tgz", + "integrity": "sha512-Xu/qa0MDk6upQWqE4Qy2X16Xg8Vi32tQS2PR0AvnT/ZYS4YGDvtn2MStOh5y8Zy2mg4NuL06KUHlvCh95j9C6Q==", + "requires": { + "debug": "^4.1.1", + "eslint-visitor-keys": "^1.1.0", + "glob": "^7.1.6", + "is-glob": "^4.0.1", + "lodash": "^4.17.15", + "semver": "^6.3.0", + "tsutils": "^3.17.1" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "@webassemblyjs/ast": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ast/-/ast-1.8.5.tgz", + "integrity": "sha512-aJMfngIZ65+t71C3y2nBBg5FFG0Okt9m0XEgWZ7Ywgn1oMAT8cNwx00Uv1cQyHtidq0Xn94R4TAywO+LCQ+ZAQ==", + "requires": { + "@webassemblyjs/helper-module-context": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/wast-parser": "1.8.5" + } + }, + "@webassemblyjs/floating-point-hex-parser": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/floating-point-hex-parser/-/floating-point-hex-parser-1.8.5.tgz", + "integrity": "sha512-9p+79WHru1oqBh9ewP9zW95E3XAo+90oth7S5Re3eQnECGq59ly1Ri5tsIipKGpiStHsUYmY3zMLqtk3gTcOtQ==" + }, + "@webassemblyjs/helper-api-error": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-api-error/-/helper-api-error-1.8.5.tgz", + "integrity": "sha512-Za/tnzsvnqdaSPOUXHyKJ2XI7PDX64kWtURyGiJJZKVEdFOsdKUCPTNEVFZq3zJ2R0G5wc2PZ5gvdTRFgm81zA==" + }, + "@webassemblyjs/helper-buffer": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-buffer/-/helper-buffer-1.8.5.tgz", + "integrity": "sha512-Ri2R8nOS0U6G49Q86goFIPNgjyl6+oE1abW1pS84BuhP1Qcr5JqMwRFT3Ah3ADDDYGEgGs1iyb1DGX+kAi/c/Q==" + }, + "@webassemblyjs/helper-code-frame": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-code-frame/-/helper-code-frame-1.8.5.tgz", + "integrity": "sha512-VQAadSubZIhNpH46IR3yWO4kZZjMxN1opDrzePLdVKAZ+DFjkGD/rf4v1jap744uPVU6yjL/smZbRIIJTOUnKQ==", + "requires": { + "@webassemblyjs/wast-printer": "1.8.5" + } + }, + "@webassemblyjs/helper-fsm": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-fsm/-/helper-fsm-1.8.5.tgz", + "integrity": "sha512-kRuX/saORcg8se/ft6Q2UbRpZwP4y7YrWsLXPbbmtepKr22i8Z4O3V5QE9DbZK908dh5Xya4Un57SDIKwB9eow==" + }, + "@webassemblyjs/helper-module-context": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-module-context/-/helper-module-context-1.8.5.tgz", + "integrity": "sha512-/O1B236mN7UNEU4t9X7Pj38i4VoU8CcMHyy3l2cV/kIF4U5KoHXDVqcDuOs1ltkac90IM4vZdHc52t1x8Yfs3g==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "mamacro": "^0.0.3" + } + }, + "@webassemblyjs/helper-wasm-bytecode": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-bytecode/-/helper-wasm-bytecode-1.8.5.tgz", + "integrity": "sha512-Cu4YMYG3Ddl72CbmpjU/wbP6SACcOPVbHN1dI4VJNJVgFwaKf1ppeFJrwydOG3NDHxVGuCfPlLZNyEdIYlQ6QQ==" + }, + "@webassemblyjs/helper-wasm-section": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/helper-wasm-section/-/helper-wasm-section-1.8.5.tgz", + "integrity": "sha512-VV083zwR+VTrIWWtgIUpqfvVdK4ff38loRmrdDBgBT8ADXYsEZ5mPQ4Nde90N3UYatHdYoDIFb7oHzMncI02tA==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5" + } + }, + "@webassemblyjs/ieee754": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/ieee754/-/ieee754-1.8.5.tgz", + "integrity": "sha512-aaCvQYrvKbY/n6wKHb/ylAJr27GglahUO89CcGXMItrOBqRarUMxWLJgxm9PJNuKULwN5n1csT9bYoMeZOGF3g==", + "requires": { + "@xtuc/ieee754": "^1.2.0" + } + }, + "@webassemblyjs/leb128": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/leb128/-/leb128-1.8.5.tgz", + "integrity": "sha512-plYUuUwleLIziknvlP8VpTgO4kqNaH57Y3JnNa6DLpu/sGcP6hbVdfdX5aHAV716pQBKrfuU26BJK29qY37J7A==", + "requires": { + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/utf8": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/utf8/-/utf8-1.8.5.tgz", + "integrity": "sha512-U7zgftmQriw37tfD934UNInokz6yTmn29inT2cAetAsaU9YeVCveWEwhKL1Mg4yS7q//NGdzy79nlXh3bT8Kjw==" + }, + "@webassemblyjs/wasm-edit": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-edit/-/wasm-edit-1.8.5.tgz", + "integrity": "sha512-A41EMy8MWw5yvqj7MQzkDjU29K7UJq1VrX2vWLzfpRHt3ISftOXqrtojn7nlPsZ9Ijhp5NwuODuycSvfAO/26Q==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/helper-wasm-section": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5", + "@webassemblyjs/wasm-opt": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5", + "@webassemblyjs/wast-printer": "1.8.5" + } + }, + "@webassemblyjs/wasm-gen": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-gen/-/wasm-gen-1.8.5.tgz", + "integrity": "sha512-BCZBT0LURC0CXDzj5FXSc2FPTsxwp3nWcqXQdOZE4U7h7i8FqtFK5Egia6f9raQLpEKT1VL7zr4r3+QX6zArWg==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/ieee754": "1.8.5", + "@webassemblyjs/leb128": "1.8.5", + "@webassemblyjs/utf8": "1.8.5" + } + }, + "@webassemblyjs/wasm-opt": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-opt/-/wasm-opt-1.8.5.tgz", + "integrity": "sha512-HKo2mO/Uh9A6ojzu7cjslGaHaUU14LdLbGEKqTR7PBKwT6LdPtLLh9fPY33rmr5wcOMrsWDbbdCHq4hQUdd37Q==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-buffer": "1.8.5", + "@webassemblyjs/wasm-gen": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5" + } + }, + "@webassemblyjs/wasm-parser": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wasm-parser/-/wasm-parser-1.8.5.tgz", + "integrity": "sha512-pi0SYE9T6tfcMkthwcgCpL0cM9nRYr6/6fjgDtL6q/ZqKHdMWvxitRi5JcZ7RI4SNJJYnYNaWy5UUrHQy998lw==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-api-error": "1.8.5", + "@webassemblyjs/helper-wasm-bytecode": "1.8.5", + "@webassemblyjs/ieee754": "1.8.5", + "@webassemblyjs/leb128": "1.8.5", + "@webassemblyjs/utf8": "1.8.5" + } + }, + "@webassemblyjs/wast-parser": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-parser/-/wast-parser-1.8.5.tgz", + "integrity": "sha512-daXC1FyKWHF1i11obK086QRlsMsY4+tIOKgBqI1lxAnkp9xe9YMcgOxm9kLe+ttjs5aWV2KKE1TWJCN57/Btsg==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/floating-point-hex-parser": "1.8.5", + "@webassemblyjs/helper-api-error": "1.8.5", + "@webassemblyjs/helper-code-frame": "1.8.5", + "@webassemblyjs/helper-fsm": "1.8.5", + "@xtuc/long": "4.2.2" + } + }, + "@webassemblyjs/wast-printer": { + "version": "1.8.5", + "resolved": "https://registry.npmjs.org/@webassemblyjs/wast-printer/-/wast-printer-1.8.5.tgz", + "integrity": "sha512-w0U0pD4EhlnvRyeJzBqaVSJAo9w/ce7/WPogeXLzGkO6hzhr4GnQIZ4W4uUt5b9ooAaXPtnXlj0gzsXEOUNYMg==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/wast-parser": "1.8.5", + "@xtuc/long": "4.2.2" + } + }, + "@xtuc/ieee754": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/@xtuc/ieee754/-/ieee754-1.2.0.tgz", + "integrity": "sha512-DX8nKgqcGwsc0eJSqYt5lwP4DH5FlHnmuWWBRy7X0NcaGR0ZtuyeESgMwTYVEtxmsNGY+qit4QYT/MIYTOTPeA==" + }, + "@xtuc/long": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/@xtuc/long/-/long-4.2.2.tgz", + "integrity": "sha512-NuHqBY1PB/D8xU6s/thBgOAiAP7HOYDQ32+BFZILJ8ivkUkAHQnWfn6WhL79Owj1qmUnoN/YPhktdIoucipkAQ==" + }, + "abab": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/abab/-/abab-2.0.3.tgz", + "integrity": "sha512-tsFzPpcttalNjFBCFMqsKYQcWxxen1pgJR56by//QwvJc4/OUS3kPOOttx2tSIfjsylB0pYu7f5D3K1RCxUnUg==" + }, + "abbrev": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/abbrev/-/abbrev-1.1.1.tgz", + "integrity": "sha512-nne9/IiQ/hzIhY6pdDnbBtz7DjPTKrY00P/zvPSm5pOFkl6xuGrGnXn/VtTNNfNtAfZ9/1RtehkszU9qcTii0Q==", + "optional": true + }, + "accepts": { + "version": "1.3.7", + "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.7.tgz", + "integrity": "sha512-Il80Qs2WjYlJIBNzNkK6KYqlVMTbZLXgHx2oT0pU/fjRHyEp+PEfEPY0R3WCwAGVOtauxh1hOxNgIf5bv7dQpA==", + "requires": { + "mime-types": "~2.1.24", + "negotiator": "0.6.2" + } + }, + "acorn": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-7.1.0.tgz", + "integrity": "sha512-kL5CuoXA/dgxlBbVrflsflzQ3PAas7RYZB52NOm/6839iVYJgKMJ3cQJD+t2i5+qFa8h3MDpEOJiS64E8JLnSQ==" + }, + "acorn-globals": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/acorn-globals/-/acorn-globals-4.3.4.tgz", + "integrity": "sha512-clfQEh21R+D0leSbUdWf3OcfqyaCSAQ8Ryq00bofSekfr9W8u1jyYZo6ir0xu9Gtcf7BjcHJpnbZH7JOCpP60A==", + "requires": { + "acorn": "^6.0.1", + "acorn-walk": "^6.0.1" + }, + "dependencies": { + "acorn": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz", + "integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==" + } + } + }, + "acorn-jsx": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/acorn-jsx/-/acorn-jsx-5.1.0.tgz", + "integrity": "sha512-tMUqwBWfLFbJbizRmEcWSLw6HnFzfdJs2sOJEOwwtVPMoH/0Ay+E703oZz78VSXZiiDcZrQ5XKjPIUQixhmgVw==" + }, + "acorn-walk": { + "version": "6.2.0", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-6.2.0.tgz", + "integrity": "sha512-7evsyfH1cLOCdAzZAd43Cic04yKydNx0cF+7tiA19p1XnLLPU4dpCQOqpjqwokFe//vS0QqfqqjCS2JkiIs0cA==" + }, + "address": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/address/-/address-1.1.2.tgz", + "integrity": "sha512-aT6camzM4xEA54YVJYSqxz1kv4IHnQZRtThJJHhUMRExaU5spC7jX5ugSwTaTgJliIgs4VhZOk7htClvQ/LmRA==" + }, + "adjust-sourcemap-loader": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/adjust-sourcemap-loader/-/adjust-sourcemap-loader-2.0.0.tgz", + "integrity": "sha512-4hFsTsn58+YjrU9qKzML2JSSDqKvN8mUGQ0nNIrfPi8hmIONT4L3uUaT6MKdMsZ9AjsU6D2xDkZxCkbQPxChrA==", + "requires": { + "assert": "1.4.1", + "camelcase": "5.0.0", + "loader-utils": "1.2.3", + "object-path": "0.11.4", + "regex-parser": "2.2.10" + }, + "dependencies": { + "camelcase": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.0.0.tgz", + "integrity": "sha512-faqwZqnWxbxn+F1d399ygeamQNy3lPp/H9H6rNrqYh4FSVCtcY+3cub1MxA8o9mDd55mM8Aghuu/kuyYA6VTsA==" + }, + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=" + }, + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", + "requires": { + "minimist": "^1.2.0" + } + }, + "loader-utils": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.2.3.tgz", + "integrity": "sha512-fkpz8ejdnEMG3s37wGL07iSBDg99O9D5yflE9RGNH3hRdx9SOwYfnGYdZOUIZitN8E+E2vkq3MUMYMvPYl5ZZA==", + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^2.0.0", + "json5": "^1.0.1" + } + } + } + }, + "aggregate-error": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/aggregate-error/-/aggregate-error-3.0.1.tgz", + "integrity": "sha512-quoaXsZ9/BLNae5yiNoUz+Nhkwz83GhWwtYFglcjEQB2NDHCIpApbqXxIFnm4Pq/Nvhrsq5sYJFyohrrxnTGAA==", + "requires": { + "clean-stack": "^2.0.0", + "indent-string": "^4.0.0" + } + }, + "ajv": { + "version": "6.12.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-6.12.0.tgz", + "integrity": "sha512-D6gFiFA0RRLyUbvijN74DWAjXSFxWKaWP7mldxkVhyhAV3+SWA9HEJPHQ2c9soIeTFJqcSdFDGFgdqs1iUU2Hw==", + "requires": { + "fast-deep-equal": "^3.1.1", + "fast-json-stable-stringify": "^2.0.0", + "json-schema-traverse": "^0.4.1", + "uri-js": "^4.2.2" + } + }, + "ajv-errors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/ajv-errors/-/ajv-errors-1.0.1.tgz", + "integrity": "sha512-DCRfO/4nQ+89p/RK43i8Ezd41EqdGIU4ld7nGF8OQ14oc/we5rEntLCUa7+jrn3nn83BosfwZA0wb4pon2o8iQ==" + }, + "ajv-keywords": { + "version": "3.4.1", + "resolved": "https://registry.npmjs.org/ajv-keywords/-/ajv-keywords-3.4.1.tgz", + "integrity": "sha512-RO1ibKvd27e6FEShVFfPALuHI3WjSVNeK5FIsmme/LYRNxjKuNj+Dt7bucLa6NdSv3JcVTyMlm9kGR84z1XpaQ==" + }, + "alphanum-sort": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/alphanum-sort/-/alphanum-sort-1.0.2.tgz", + "integrity": "sha1-l6ERlkmyEa0zaR2fn0hqjsn74KM=" + }, + "ansi-colors": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/ansi-colors/-/ansi-colors-3.2.4.tgz", + "integrity": "sha512-hHUXGagefjN2iRrID63xckIvotOXOojhQKWIPUZ4mNUZ9nLZW+7FMNoE1lOkEhNWYsx/7ysGIuJYCiMAA9FnrA==" + }, + "ansi-escapes": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-4.3.0.tgz", + "integrity": "sha512-EiYhwo0v255HUL6eDyuLrXEkTi7WwVCLAw+SeOQ7M7qdun1z1pum4DEm/nuqIVbPvi9RPPc9k9LbyBv6H0DwVg==", + "requires": { + "type-fest": "^0.8.1" + } + }, + "ansi-html": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/ansi-html/-/ansi-html-0.0.7.tgz", + "integrity": "sha1-gTWEAhliqenm/QOflA0S9WynhZ4=" + }, + "ansi-regex": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-5.0.0.tgz", + "integrity": "sha512-bY6fj56OUQ0hU1KjFNDQuJFezqKdrAyFdIevADiqrWHwSlbmBNMHp5ak2f40Pm8JTFyM2mqxkG6ngkHO11f/lg==" + }, + "ansi-styles": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-3.2.1.tgz", + "integrity": "sha512-VT0ZI6kZRdTh8YyJw3SMbYm/u+NqfsAxEpWO0Pf9sq8/e94WxxOpPKx9FR1FlyCtOVDNOQ+8ntlqFxiRc+r5qA==", + "requires": { + "color-convert": "^1.9.0" + } + }, + "anymatch": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-2.0.0.tgz", + "integrity": "sha512-5teOsQWABXHHBFP9y3skS5P3d/WfWXpv3FUpy+LorMrNYaT9pI4oLMQX7jzQ2KklNpGpWHzdCXTDT2Y3XGlZBw==", + "requires": { + "micromatch": "^3.1.4", + "normalize-path": "^2.1.1" + }, + "dependencies": { + "normalize-path": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-2.1.1.tgz", + "integrity": "sha1-GrKLVW4Zg2Oowab35vogE3/mrtk=", + "requires": { + "remove-trailing-separator": "^1.0.1" + } + } + } + }, + "aproba": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/aproba/-/aproba-1.2.0.tgz", + "integrity": "sha512-Y9J6ZjXtoYh8RnXVCMOU/ttDmk1aBjunq9vO0ta5x85WDQiQfUF9sIPBITdbiiIVcBo03Hi3jMxigBtsddlXRw==" + }, + "are-we-there-yet": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/are-we-there-yet/-/are-we-there-yet-1.1.5.tgz", + "integrity": "sha512-5hYdAkZlcG8tOLujVDTgCT+uPX0VnpAH28gWsLfzpXYm7wP6mp5Q/gYyR7YQ0cKVJcXJnl3j2kpBan13PtQf6w==", + "optional": true, + "requires": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==", + "optional": true + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "argparse": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/argparse/-/argparse-1.0.10.tgz", + "integrity": "sha512-o5Roy6tNG4SL/FOkCAN6RzjiakZS25RLYFrcMttJqbdd8BWrnA+fGz57iN5Pb06pvBGvl5gQ0B48dJlslXvoTg==", + "requires": { + "sprintf-js": "~1.0.2" + } + }, + "aria-query": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/aria-query/-/aria-query-3.0.0.tgz", + "integrity": "sha1-ZbP8wcoRVajJrmTW7uKX8V1RM8w=", + "requires": { + "ast-types-flow": "0.0.7", + "commander": "^2.11.0" + } + }, + "arity-n": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/arity-n/-/arity-n-1.0.4.tgz", + "integrity": "sha1-2edrEXM+CFacCEeuezmyhgswt0U=" + }, + "arr-diff": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/arr-diff/-/arr-diff-4.0.0.tgz", + "integrity": "sha1-1kYQdP6/7HHn4VI1dhoyml3HxSA=" + }, + "arr-flatten": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/arr-flatten/-/arr-flatten-1.1.0.tgz", + "integrity": "sha512-L3hKV5R/p5o81R7O02IGnwpDmkp6E982XhtbuwSe3O4qOtMMMtodicASA1Cny2U+aCXcNpml+m4dPsvsJ3jatg==" + }, + "arr-union": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/arr-union/-/arr-union-3.1.0.tgz", + "integrity": "sha1-45sJrqne+Gao8gbiiK9jkZuuOcQ=" + }, + "array-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/array-equal/-/array-equal-1.0.0.tgz", + "integrity": "sha1-jCpe8kcv2ep0KwTHenUJO6J1fJM=" + }, + "array-flatten": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-2.1.2.tgz", + "integrity": "sha512-hNfzcOV8W4NdualtqBFPyVO+54DSJuZGY9qT4pRroB6S9e3iiido2ISIC5h9R2sPJ8H3FHCIiEnsv1lPXO3KtQ==" + }, + "array-includes": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/array-includes/-/array-includes-3.1.1.tgz", + "integrity": "sha512-c2VXaCHl7zPsvpkFsw4nxvFie4fh1ur9bpcgsVkIjqn0H/Xwdg+7fv3n2r/isyS8EBj5b06M9kHyZuIr4El6WQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0", + "is-string": "^1.0.5" + } + }, + "array-union": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/array-union/-/array-union-1.0.2.tgz", + "integrity": "sha1-mjRBDk9OPaI96jdb5b5w8kd47Dk=", + "requires": { + "array-uniq": "^1.0.1" + } + }, + "array-uniq": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/array-uniq/-/array-uniq-1.0.3.tgz", + "integrity": "sha1-r2rId6Jcx/dOBYiUdThY39sk/bY=" + }, + "array-unique": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/array-unique/-/array-unique-0.3.2.tgz", + "integrity": "sha1-qJS3XUvE9s1nnvMkSp/Y9Gri1Cg=" + }, + "array.prototype.flat": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/array.prototype.flat/-/array.prototype.flat-1.2.3.tgz", + "integrity": "sha512-gBlRZV0VSmfPIeWfuuy56XZMvbVfbEUnOXUvt3F/eUUUSyzlgLxhEX4YAEpxNAogRGehPSnfXyPtYyKAhkzQhQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1" + } + }, + "arrify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/arrify/-/arrify-1.0.1.tgz", + "integrity": "sha1-iYUI2iIm84DfkEcoRWhJwVAaSw0=" + }, + "asap": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/asap/-/asap-2.0.6.tgz", + "integrity": "sha1-5QNHYR1+aQlDIIu9r+vLwvuGbUY=" + }, + "asn1": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/asn1/-/asn1-0.2.4.tgz", + "integrity": "sha512-jxwzQpLQjSmWXgwaCZE9Nz+glAG01yF1QnWgbhGwHI5A6FRIEY6IVqtHhIepHqI7/kyEyQEagBC5mBEFlIYvdg==", + "requires": { + "safer-buffer": "~2.1.0" + } + }, + "asn1.js": { + "version": "4.10.1", + "resolved": "https://registry.npmjs.org/asn1.js/-/asn1.js-4.10.1.tgz", + "integrity": "sha512-p32cOF5q0Zqs9uBiONKYLm6BClCoBCM5O9JfeUSlnQLBTxYdTK+pW+nXflm8UkKd2UYlEbYz5qEi0JuZR9ckSw==", + "requires": { + "bn.js": "^4.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "assert": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/assert/-/assert-1.4.1.tgz", + "integrity": "sha1-mZEtWRg2tab1s0XA8H7vwI/GXZE=", + "requires": { + "util": "0.10.3" + } + }, + "assert-plus": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assert-plus/-/assert-plus-1.0.0.tgz", + "integrity": "sha1-8S4PPF13sLHN2RRpQuTpbB5N1SU=" + }, + "assign-symbols": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/assign-symbols/-/assign-symbols-1.0.0.tgz", + "integrity": "sha1-WWZ/QfrdTyDMvCu5a41Pf3jsA2c=" + }, + "ast-types-flow": { + "version": "0.0.7", + "resolved": "https://registry.npmjs.org/ast-types-flow/-/ast-types-flow-0.0.7.tgz", + "integrity": "sha1-9wtzXGvKGlycItmCw+Oef+ujva0=" + }, + "astral-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/astral-regex/-/astral-regex-1.0.0.tgz", + "integrity": "sha512-+Ryf6g3BKoRc7jfp7ad8tM4TtMiaWvbF/1/sQcZPkkS7ag3D5nMBCe2UfOTONtAkaG0tO0ij3C5Lwmf1EiyjHg==" + }, + "async": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/async/-/async-2.6.3.tgz", + "integrity": "sha512-zflvls11DCy+dQWzTW2dzuilv8Z5X/pjfmZOWba6TNIVDm+2UDaJmXSOXlasHKfNBs8oo3M0aT50fDEWfKZjXg==", + "requires": { + "lodash": "^4.17.14" + } + }, + "async-each": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/async-each/-/async-each-1.0.3.tgz", + "integrity": "sha512-z/WhQ5FPySLdvREByI2vZiTWwCnF0moMJ1hK9YQwDTHKh6I7/uSckMetoRGb5UBZPC1z0jlw+n/XCgjeH7y1AQ==" + }, + "async-limiter": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/async-limiter/-/async-limiter-1.0.1.tgz", + "integrity": "sha512-csOlWGAcRFJaI6m+F2WKdnMKr4HhdhFVBk0H/QbJFMCr+uO2kwohwXQPxw/9OCxp05r5ghVBFSyioixx3gfkNQ==" + }, + "asynckit": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/asynckit/-/asynckit-0.4.0.tgz", + "integrity": "sha1-x57Zf380y48robyXkLzDZkdLS3k=" + }, + "atob": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/atob/-/atob-2.1.2.tgz", + "integrity": "sha512-Wm6ukoaOGJi/73p/cl2GvLjTI5JM1k/O14isD73YML8StrH/7/lRFgmg8nICZgD3bZZvjwCGxtMOD3wWNAu8cg==" + }, + "autoprefixer": { + "version": "9.7.4", + "resolved": "https://registry.npmjs.org/autoprefixer/-/autoprefixer-9.7.4.tgz", + "integrity": "sha512-g0Ya30YrMBAEZk60lp+qfX5YQllG+S5W3GYCFvyHTvhOki0AEQJLPEcIuGRsqVwLi8FvXPVtwTGhfr38hVpm0g==", + "requires": { + "browserslist": "^4.8.3", + "caniuse-lite": "^1.0.30001020", + "chalk": "^2.4.2", + "normalize-range": "^0.1.2", + "num2fraction": "^1.2.2", + "postcss": "^7.0.26", + "postcss-value-parser": "^4.0.2" + } + }, + "aws-sign2": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/aws-sign2/-/aws-sign2-0.7.0.tgz", + "integrity": "sha1-tG6JCTSpWR8tL2+G1+ap8bP+dqg=" + }, + "aws4": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/aws4/-/aws4-1.9.1.tgz", + "integrity": "sha512-wMHVg2EOHaMRxbzgFJ9gtjOOCrI80OHLG14rxi28XwOW8ux6IiEbRCGGGqCtdAIg4FQCbW20k9RsT4y3gJlFug==" + }, + "axobject-query": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/axobject-query/-/axobject-query-2.1.2.tgz", + "integrity": "sha512-ICt34ZmrVt8UQnvPl6TVyDTkmhXmAyAT4Jh5ugfGUX4MOrZ+U/ZY6/sdylRw3qGNr9Ub5AJsaHeDMzNLehRdOQ==" + }, + "babel-code-frame": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-code-frame/-/babel-code-frame-6.26.0.tgz", + "integrity": "sha1-Y/1D99weO7fONZR9uP42mj9Yx0s=", + "requires": { + "chalk": "^1.1.3", + "esutils": "^2.0.2", + "js-tokens": "^3.0.2" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + }, + "ansi-styles": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-2.2.1.tgz", + "integrity": "sha1-tDLdM1i2NM914eRmQ2gkBTPB3b4=" + }, + "chalk": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-1.1.3.tgz", + "integrity": "sha1-qBFcVeSnAv5NFQq9OHKCKn4J/Jg=", + "requires": { + "ansi-styles": "^2.2.1", + "escape-string-regexp": "^1.0.2", + "has-ansi": "^2.0.0", + "strip-ansi": "^3.0.0", + "supports-color": "^2.0.0" + } + }, + "js-tokens": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-3.0.2.tgz", + "integrity": "sha1-mGbfOVECEw449/mWvOtlRDIJwls=" + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "supports-color": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-2.0.0.tgz", + "integrity": "sha1-U10EXOa2Nj+kARcIRimZXp3zJMc=" + } + } + }, + "babel-eslint": { + "version": "10.0.3", + "resolved": "https://registry.npmjs.org/babel-eslint/-/babel-eslint-10.0.3.tgz", + "integrity": "sha512-z3U7eMY6r/3f3/JB9mTsLjyxrv0Yb1zb8PCWCLpguxfCzBIZUwy23R1t/XKewP+8mEN2Ck8Dtr4q20z6ce6SoA==", + "requires": { + "@babel/code-frame": "^7.0.0", + "@babel/parser": "^7.0.0", + "@babel/traverse": "^7.0.0", + "@babel/types": "^7.0.0", + "eslint-visitor-keys": "^1.0.0", + "resolve": "^1.12.0" + } + }, + "babel-extract-comments": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/babel-extract-comments/-/babel-extract-comments-1.0.0.tgz", + "integrity": "sha512-qWWzi4TlddohA91bFwgt6zO/J0X+io7Qp184Fw0m2JYRSTZnJbFR8+07KmzudHCZgOiKRCrjhylwv9Xd8gfhVQ==", + "requires": { + "babylon": "^6.18.0" + } + }, + "babel-jest": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/babel-jest/-/babel-jest-24.9.0.tgz", + "integrity": "sha512-ntuddfyiN+EhMw58PTNL1ph4C9rECiQXjI4nMMBKBaNjXvqLdkXpPRcMSr4iyBrJg/+wz9brFUD6RhOAT6r4Iw==", + "requires": { + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/babel__core": "^7.1.0", + "babel-plugin-istanbul": "^5.1.0", + "babel-preset-jest": "^24.9.0", + "chalk": "^2.4.2", + "slash": "^2.0.0" + } + }, + "babel-loader": { + "version": "8.0.6", + "resolved": "https://registry.npmjs.org/babel-loader/-/babel-loader-8.0.6.tgz", + "integrity": "sha512-4BmWKtBOBm13uoUwd08UwjZlaw3O9GWf456R9j+5YykFZ6LUIjIKLc0zEZf+hauxPOJs96C8k6FvYD09vWzhYw==", + "requires": { + "find-cache-dir": "^2.0.0", + "loader-utils": "^1.0.2", + "mkdirp": "^0.5.1", + "pify": "^4.0.1" + } + }, + "babel-plugin-dynamic-import-node": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/babel-plugin-dynamic-import-node/-/babel-plugin-dynamic-import-node-2.3.0.tgz", + "integrity": "sha512-o6qFkpeQEBxcqt0XYlWzAVxNCSCZdUgcR8IRlhD/8DylxjjO4foPcvTW0GGKa/cVt3rvxZ7o5ippJ+/0nvLhlQ==", + "requires": { + "object.assign": "^4.1.0" + } + }, + "babel-plugin-istanbul": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/babel-plugin-istanbul/-/babel-plugin-istanbul-5.2.0.tgz", + "integrity": "sha512-5LphC0USA8t4i1zCtjbbNb6jJj/9+X6P37Qfirc/70EQ34xKlMW+a1RHGwxGI+SwWpNwZ27HqvzAobeqaXwiZw==", + "requires": { + "@babel/helper-plugin-utils": "^7.0.0", + "find-up": "^3.0.0", + "istanbul-lib-instrument": "^3.3.0", + "test-exclude": "^5.2.3" + } + }, + "babel-plugin-jest-hoist": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/babel-plugin-jest-hoist/-/babel-plugin-jest-hoist-24.9.0.tgz", + "integrity": "sha512-2EMA2P8Vp7lG0RAzr4HXqtYwacfMErOuv1U3wrvxHX6rD1sV6xS3WXG3r8TRQ2r6w8OhvSdWt+z41hQNwNm3Xw==", + "requires": { + "@types/babel__traverse": "^7.0.6" + } + }, + "babel-plugin-macros": { + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/babel-plugin-macros/-/babel-plugin-macros-2.8.0.tgz", + "integrity": "sha512-SEP5kJpfGYqYKpBrj5XU3ahw5p5GOHJ0U5ssOSQ/WBVdwkD2Dzlce95exQTs3jOVWPPKLBN2rlEWkCK7dSmLvg==", + "requires": { + "@babel/runtime": "^7.7.2", + "cosmiconfig": "^6.0.0", + "resolve": "^1.12.0" + }, + "dependencies": { + "cosmiconfig": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-6.0.0.tgz", + "integrity": "sha512-xb3ZL6+L8b9JLLCx3ZdoZy4+2ECphCMo2PwqgP1tlfVq6M6YReyzBJtvWWtbDSpNr9hn96pkCiZqUcFEc+54Qg==", + "requires": { + "@types/parse-json": "^4.0.0", + "import-fresh": "^3.1.0", + "parse-json": "^5.0.0", + "path-type": "^4.0.0", + "yaml": "^1.7.2" + } + }, + "import-fresh": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", + "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "parse-json": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-5.0.0.tgz", + "integrity": "sha512-OOY5b7PAEFV0E2Fir1KOkxchnZNCdowAJgQ5NuxjpBKTRP3pQhwkrkxqQjeoKJ+fO7bCpmIZaogI4eZGDMEGOw==", + "requires": { + "@babel/code-frame": "^7.0.0", + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1", + "lines-and-columns": "^1.1.6" + } + }, + "path-type": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-4.0.0.tgz", + "integrity": "sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==" + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" + } + } + }, + "babel-plugin-named-asset-import": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/babel-plugin-named-asset-import/-/babel-plugin-named-asset-import-0.3.6.tgz", + "integrity": "sha512-1aGDUfL1qOOIoqk9QKGIo2lANk+C7ko/fqH0uIyC71x3PEGz0uVP8ISgfEsFuG+FKmjHTvFK/nNM8dowpmUxLA==" + }, + "babel-plugin-syntax-object-rest-spread": { + "version": "6.13.0", + "resolved": "https://registry.npmjs.org/babel-plugin-syntax-object-rest-spread/-/babel-plugin-syntax-object-rest-spread-6.13.0.tgz", + "integrity": "sha1-/WU28rzhODb/o6VFjEkDpZe7O/U=" + }, + "babel-plugin-transform-object-rest-spread": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-object-rest-spread/-/babel-plugin-transform-object-rest-spread-6.26.0.tgz", + "integrity": "sha1-DzZpLVD+9rfi1LOsFHgTepY7ewY=", + "requires": { + "babel-plugin-syntax-object-rest-spread": "^6.8.0", + "babel-runtime": "^6.26.0" + } + }, + "babel-plugin-transform-react-remove-prop-types": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/babel-plugin-transform-react-remove-prop-types/-/babel-plugin-transform-react-remove-prop-types-0.4.24.tgz", + "integrity": "sha512-eqj0hVcJUR57/Ug2zE1Yswsw4LhuqqHhD+8v120T1cl3kjg76QwtyBrdIk4WVwK+lAhBJVYCd/v+4nc4y+8JsA==" + }, + "babel-preset-jest": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/babel-preset-jest/-/babel-preset-jest-24.9.0.tgz", + "integrity": "sha512-izTUuhE4TMfTRPF92fFwD2QfdXaZW08qvWTFCI51V8rW5x00UuPgc3ajRoWofXOuxjfcOM5zzSYsQS3H8KGCAg==", + "requires": { + "@babel/plugin-syntax-object-rest-spread": "^7.0.0", + "babel-plugin-jest-hoist": "^24.9.0" + } + }, + "babel-preset-react-app": { + "version": "9.1.1", + "resolved": "https://registry.npmjs.org/babel-preset-react-app/-/babel-preset-react-app-9.1.1.tgz", + "integrity": "sha512-YkWP2UwY//TLltNlEBRngDOrYhvSLb+CA330G7T9M5UhGEMWe+JK/8IXJc5p2fDTSfSiETf+PY0+PYXFMix81Q==", + "requires": { + "@babel/core": "7.8.4", + "@babel/plugin-proposal-class-properties": "7.8.3", + "@babel/plugin-proposal-decorators": "7.8.3", + "@babel/plugin-proposal-numeric-separator": "7.8.3", + "@babel/plugin-transform-flow-strip-types": "7.8.3", + "@babel/plugin-transform-react-display-name": "7.8.3", + "@babel/plugin-transform-runtime": "7.8.3", + "@babel/preset-env": "7.8.4", + "@babel/preset-react": "7.8.3", + "@babel/preset-typescript": "7.8.3", + "@babel/runtime": "7.8.4", + "babel-plugin-macros": "2.8.0", + "babel-plugin-transform-react-remove-prop-types": "0.4.24" + } + }, + "babel-runtime": { + "version": "6.26.0", + "resolved": "https://registry.npmjs.org/babel-runtime/-/babel-runtime-6.26.0.tgz", + "integrity": "sha1-llxwWGaOgrVde/4E/yM3vItWR/4=", + "requires": { + "core-js": "^2.4.0", + "regenerator-runtime": "^0.11.0" + }, + "dependencies": { + "core-js": { + "version": "2.6.11", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-2.6.11.tgz", + "integrity": "sha512-5wjnpaT/3dV+XB4borEsnAYQchn00XSgTAWKDkEqv+K8KevjbzmofK6hfJ9TZIlpj2N0xQpazy7PiRQiWHqzWg==" + }, + "regenerator-runtime": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.11.1.tgz", + "integrity": "sha512-MguG95oij0fC3QV3URf4V2SDYGJhJnJGqvIIgdECeODCT98wSWDAJ94SSuVpYQUoTcGUIL6L4yNB7j1DFFHSBg==" + } + } + }, + "babylon": { + "version": "6.18.0", + "resolved": "https://registry.npmjs.org/babylon/-/babylon-6.18.0.tgz", + "integrity": "sha512-q/UEjfGJ2Cm3oKV71DJz9d25TPnq5rhBVL2Q4fA5wcC3jcrdn7+SssEybFIxwAvvP+YCsCYNKughoF33GxgycQ==" + }, + "balanced-match": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.0.tgz", + "integrity": "sha1-ibTRmasr7kneFk6gK4nORi1xt2c=" + }, + "base": { + "version": "0.11.2", + "resolved": "https://registry.npmjs.org/base/-/base-0.11.2.tgz", + "integrity": "sha512-5T6P4xPgpp0YDFvSWwEZ4NoE3aM4QBQXDzmVbraCkFj8zHM+mba8SyqB5DbZWyR7mYHo6Y7BdQo3MoA4m0TeQg==", + "requires": { + "cache-base": "^1.0.1", + "class-utils": "^0.3.5", + "component-emitter": "^1.2.1", + "define-property": "^1.0.0", + "isobject": "^3.0.1", + "mixin-deep": "^1.2.0", + "pascalcase": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "base64-js": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/base64-js/-/base64-js-1.3.1.tgz", + "integrity": "sha512-mLQ4i2QO1ytvGWFWmcngKO//JXAQueZvwEKtjgQFM4jIK0kU+ytMfplL8j+n5mspOfjHwoAg+9yhb7BwAHm36g==" + }, + "batch": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/batch/-/batch-0.6.1.tgz", + "integrity": "sha1-3DQxT05nkxgJP8dgJyUl+UvyXBY=" + }, + "bcrypt-pbkdf": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/bcrypt-pbkdf/-/bcrypt-pbkdf-1.0.2.tgz", + "integrity": "sha1-pDAdOJtqQ/m2f/PKEaP2Y342Dp4=", + "requires": { + "tweetnacl": "^0.14.3" + } + }, + "big.js": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/big.js/-/big.js-5.2.2.tgz", + "integrity": "sha512-vyL2OymJxmarO8gxMr0mhChsO9QGwhynfuu4+MHTAW6czfq9humCB7rKpUjDd9YUiDPU4mzpyupFSvOClAwbmQ==" + }, + "binary-extensions": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.0.0.tgz", + "integrity": "sha512-Phlt0plgpIIBOGTT/ehfFnbNlfsDEiqmzE2KRXoX1bLIlir4X/MR+zSyBEkL05ffWgnRSf/DXv+WrUAVr93/ow==" + }, + "bindings": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/bindings/-/bindings-1.5.0.tgz", + "integrity": "sha512-p2q/t/mhvuOj/UeLlV6566GD/guowlr0hHxClI0W9m7MWYkL1F0hLo+0Aexs9HSPCtR1SXQ0TD3MMKrXZajbiQ==", + "optional": true, + "requires": { + "file-uri-to-path": "1.0.0" + } + }, + "bluebird": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/bluebird/-/bluebird-3.7.2.tgz", + "integrity": "sha512-XpNj6GDQzdfW+r2Wnn7xiSAd7TM3jzkxGXBGTtWKuSXv1xUV+azxAm8jdWZN06QTQk+2N2XB9jRDkvbmQmcRtg==" + }, + "bn.js": { + "version": "4.11.8", + "resolved": "https://registry.npmjs.org/bn.js/-/bn.js-4.11.8.tgz", + "integrity": "sha512-ItfYfPLkWHUjckQCk8xC+LwxgK8NYcXywGigJgSwOP8Y2iyWT4f2vsZnoOXTTbo+o5yXmIUJ4gn5538SO5S3gA==" + }, + "body-parser": { + "version": "1.19.0", + "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.19.0.tgz", + "integrity": "sha512-dhEPs72UPbDnAQJ9ZKMNTP6ptJaionhP5cBb541nXPlW60Jepo9RV/a4fX4XWW9CuFNK22krhrj1+rgzifNCsw==", + "requires": { + "bytes": "3.1.0", + "content-type": "~1.0.4", + "debug": "2.6.9", + "depd": "~1.1.2", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "on-finished": "~2.3.0", + "qs": "6.7.0", + "raw-body": "2.4.0", + "type-is": "~1.6.17" + }, + "dependencies": { + "bytes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", + "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", + "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" + } + } + }, + "bonjour": { + "version": "3.5.0", + "resolved": "https://registry.npmjs.org/bonjour/-/bonjour-3.5.0.tgz", + "integrity": "sha1-jokKGD2O6aI5OzhExpGkK897yfU=", + "requires": { + "array-flatten": "^2.1.0", + "deep-equal": "^1.0.1", + "dns-equal": "^1.0.0", + "dns-txt": "^2.0.2", + "multicast-dns": "^6.0.1", + "multicast-dns-service-types": "^1.1.0" + } + }, + "boolbase": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/boolbase/-/boolbase-1.0.0.tgz", + "integrity": "sha1-aN/1++YMUes3cl6p4+0xDcwed24=" + }, + "brace-expansion": { + "version": "1.1.11", + "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", + "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "braces": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-2.3.2.tgz", + "integrity": "sha512-aNdbnj9P8PjdXU4ybaWLK2IF3jc/EoDYbC7AazW6to3TRsfXxscC9UXOB5iDiEQrkyIbWp2SLQda4+QAa7nc3w==", + "requires": { + "arr-flatten": "^1.1.0", + "array-unique": "^0.3.2", + "extend-shallow": "^2.0.1", + "fill-range": "^4.0.0", + "isobject": "^3.0.1", + "repeat-element": "^1.1.2", + "snapdragon": "^0.8.1", + "snapdragon-node": "^2.0.1", + "split-string": "^3.0.2", + "to-regex": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "brorand": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/brorand/-/brorand-1.1.0.tgz", + "integrity": "sha1-EsJe/kCkXjwyPrhnWgoM5XsiNx8=" + }, + "browser-process-hrtime": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/browser-process-hrtime/-/browser-process-hrtime-0.1.3.tgz", + "integrity": "sha512-bRFnI4NnjO6cnyLmOV/7PVoDEMJChlcfN0z4s1YMBY989/SvlfMI1lgCnkFUs53e9gQF+w7qu7XdllSTiSl8Aw==" + }, + "browser-resolve": { + "version": "1.11.3", + "resolved": "https://registry.npmjs.org/browser-resolve/-/browser-resolve-1.11.3.tgz", + "integrity": "sha512-exDi1BYWB/6raKHmDTCicQfTkqwN5fioMFV4j8BsfMU4R2DK/QfZfK7kOVkmWCNANf0snkBzqGqAJBao9gZMdQ==", + "requires": { + "resolve": "1.1.7" + }, + "dependencies": { + "resolve": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.1.7.tgz", + "integrity": "sha1-IDEU2CrSxe2ejgQRs5ModeiJ6Xs=" + } + } + }, + "browserify-aes": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/browserify-aes/-/browserify-aes-1.2.0.tgz", + "integrity": "sha512-+7CHXqGuspUn/Sl5aO7Ea0xWGAtETPXNSAjHo48JfLdPWcMng33Xe4znFvQweqc/uzk5zSOI3H52CYnjCfb5hA==", + "requires": { + "buffer-xor": "^1.0.3", + "cipher-base": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.3", + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "browserify-cipher": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/browserify-cipher/-/browserify-cipher-1.0.1.tgz", + "integrity": "sha512-sPhkz0ARKbf4rRQt2hTpAHqn47X3llLkUGn+xEJzLjwY8LRs2p0v7ljvI5EyoRO/mexrNunNECisZs+gw2zz1w==", + "requires": { + "browserify-aes": "^1.0.4", + "browserify-des": "^1.0.0", + "evp_bytestokey": "^1.0.0" + } + }, + "browserify-des": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/browserify-des/-/browserify-des-1.0.2.tgz", + "integrity": "sha512-BioO1xf3hFwz4kc6iBhI3ieDFompMhrMlnDFC4/0/vd5MokpuAc3R+LYbwTA9A5Yc9pq9UYPqffKpW2ObuwX5A==", + "requires": { + "cipher-base": "^1.0.1", + "des.js": "^1.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "browserify-rsa": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/browserify-rsa/-/browserify-rsa-4.0.1.tgz", + "integrity": "sha1-IeCr+vbyApzy+vsTNWenAdQTVSQ=", + "requires": { + "bn.js": "^4.1.0", + "randombytes": "^2.0.1" + } + }, + "browserify-sign": { + "version": "4.0.4", + "resolved": "https://registry.npmjs.org/browserify-sign/-/browserify-sign-4.0.4.tgz", + "integrity": "sha1-qk62jl17ZYuqa/alfmMMvXqT0pg=", + "requires": { + "bn.js": "^4.1.1", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.2", + "elliptic": "^6.0.0", + "inherits": "^2.0.1", + "parse-asn1": "^5.0.0" + } + }, + "browserify-zlib": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/browserify-zlib/-/browserify-zlib-0.2.0.tgz", + "integrity": "sha512-Z942RysHXmJrhqk88FmKBVq/v5tqmSkDz7p54G/MGyjMnCFFnC79XWNbg+Vta8W6Wb2qtSZTSxIGkJrRpCFEiA==", + "requires": { + "pako": "~1.0.5" + } + }, + "browserslist": { + "version": "4.8.7", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.8.7.tgz", + "integrity": "sha512-gFOnZNYBHrEyUML0xr5NJ6edFaaKbTFX9S9kQHlYfCP0Rit/boRIz4G+Avq6/4haEKJXdGGUnoolx+5MWW2BoA==", + "requires": { + "caniuse-lite": "^1.0.30001027", + "electron-to-chromium": "^1.3.349", + "node-releases": "^1.1.49" + } + }, + "bser": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/bser/-/bser-2.1.1.tgz", + "integrity": "sha512-gQxTNE/GAfIIrmHLUE3oJyp5FO6HRBfhjnw4/wMmA63ZGDJnWBmgY/lyQBpnDUkGmAhbSe39tx2d/iTOAfglwQ==", + "requires": { + "node-int64": "^0.4.0" + } + }, + "buffer": { + "version": "4.9.2", + "resolved": "https://registry.npmjs.org/buffer/-/buffer-4.9.2.tgz", + "integrity": "sha512-xq+q3SRMOxGivLhBNaUdC64hDTQwejJ+H0T/NB1XMtTVEwNTrfFF3gAxiyW0Bu/xWEGhjVKgUcMhCrUy2+uCWg==", + "requires": { + "base64-js": "^1.0.2", + "ieee754": "^1.1.4", + "isarray": "^1.0.0" + } + }, + "buffer-from": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-from/-/buffer-from-1.1.1.tgz", + "integrity": "sha512-MQcXEUbCKtEo7bhqEs6560Hyd4XaovZlO/k9V3hjVUF/zwW7KBVdSK4gIt/bzwS9MbR5qob+F5jusZsb0YQK2A==" + }, + "buffer-indexof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/buffer-indexof/-/buffer-indexof-1.1.1.tgz", + "integrity": "sha512-4/rOEg86jivtPTeOUUT61jJO1Ya1TrR/OkqCSZDyq84WJh3LuuiphBYJN+fm5xufIk4XAFcEwte/8WzC8If/1g==" + }, + "buffer-xor": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/buffer-xor/-/buffer-xor-1.0.3.tgz", + "integrity": "sha1-JuYe0UIvtw3ULm42cp7VHYVf6Nk=" + }, + "builtin-status-codes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/builtin-status-codes/-/builtin-status-codes-3.0.0.tgz", + "integrity": "sha1-hZgoeOIbmOHGZCXgPQF0eI9Wnug=" + }, + "bytes": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.0.0.tgz", + "integrity": "sha1-0ygVQE1olpn4Wk6k+odV3ROpYEg=" + }, + "cacache": { + "version": "13.0.1", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-13.0.1.tgz", + "integrity": "sha512-5ZvAxd05HDDU+y9BVvcqYu2LLXmPnQ0hW62h32g4xBTgL/MppR4/04NHfj/ycM2y6lmTnbw6HVi+1eN0Psba6w==", + "requires": { + "chownr": "^1.1.2", + "figgy-pudding": "^3.5.1", + "fs-minipass": "^2.0.0", + "glob": "^7.1.4", + "graceful-fs": "^4.2.2", + "infer-owner": "^1.0.4", + "lru-cache": "^5.1.1", + "minipass": "^3.0.0", + "minipass-collect": "^1.0.2", + "minipass-flush": "^1.0.5", + "minipass-pipeline": "^1.2.2", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "p-map": "^3.0.0", + "promise-inflight": "^1.0.1", + "rimraf": "^2.7.1", + "ssri": "^7.0.0", + "unique-filename": "^1.1.1" + }, + "dependencies": { + "rimraf": { + "version": "2.7.1", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.7.1.tgz", + "integrity": "sha512-uWjbaKIK3T1OSVptzX7Nl6PvQ3qAGtKEtVRjRuazjfL3Bx5eI409VZSqgND+4UNnmzLVdPj9FqFJNPqBZFve4w==", + "requires": { + "glob": "^7.1.3" + } + } + } + }, + "cache-base": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cache-base/-/cache-base-1.0.1.tgz", + "integrity": "sha512-AKcdTnFSWATd5/GCPRxr2ChwIJ85CeyrEyjRHlKxQ56d4XJMGym0uAiKn0xbLOGOl3+yRpOTi484dVCEc5AUzQ==", + "requires": { + "collection-visit": "^1.0.0", + "component-emitter": "^1.2.1", + "get-value": "^2.0.6", + "has-value": "^1.0.0", + "isobject": "^3.0.1", + "set-value": "^2.0.0", + "to-object-path": "^0.3.0", + "union-value": "^1.0.0", + "unset-value": "^1.0.0" + } + }, + "call-me-maybe": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/call-me-maybe/-/call-me-maybe-1.0.1.tgz", + "integrity": "sha1-JtII6onje1y95gJQoV8DHBak1ms=" + }, + "caller-callsite": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-callsite/-/caller-callsite-2.0.0.tgz", + "integrity": "sha1-hH4PzgoiN1CpoCfFSzNzGtMVQTQ=", + "requires": { + "callsites": "^2.0.0" + }, + "dependencies": { + "callsites": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-2.0.0.tgz", + "integrity": "sha1-BuuE8A7qQT2oav/vrL/7Ngk7PFA=" + } + } + }, + "caller-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/caller-path/-/caller-path-2.0.0.tgz", + "integrity": "sha1-Ro+DBE42mrIBD6xfBs7uFbsssfQ=", + "requires": { + "caller-callsite": "^2.0.0" + } + }, + "callsites": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/callsites/-/callsites-3.1.0.tgz", + "integrity": "sha512-P8BjAsXvZS+VIDUI11hHCQEv74YT67YUi5JJFNWIqL235sBmjX4+qx9Muvls5ivyNENctx46xQLQ3aTuE7ssaQ==" + }, + "camel-case": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/camel-case/-/camel-case-4.1.1.tgz", + "integrity": "sha512-7fa2WcG4fYFkclIvEmxBbTvmibwF2/agfEBc6q3lOpVu0A13ltLsA+Hr/8Hp6kp5f+G7hKi6t8lys6XxP+1K6Q==", + "requires": { + "pascal-case": "^3.1.1", + "tslib": "^1.10.0" + } + }, + "camelcase": { + "version": "5.3.1", + "resolved": "https://registry.npmjs.org/camelcase/-/camelcase-5.3.1.tgz", + "integrity": "sha512-L28STB170nwWS63UjtlEOE3dldQApaJXZkOI1uMFfzf3rRuPegHaHesyee+YxQ+W6SvRDQV6UrdOdRiR153wJg==" + }, + "caniuse-api": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/caniuse-api/-/caniuse-api-3.0.0.tgz", + "integrity": "sha512-bsTwuIg/BZZK/vreVTYYbSWoe2F+71P7K5QGEX+pT250DZbfU1MQ5prOKpPR+LL6uWKK3KMwMCAS74QB3Um1uw==", + "requires": { + "browserslist": "^4.0.0", + "caniuse-lite": "^1.0.0", + "lodash.memoize": "^4.1.2", + "lodash.uniq": "^4.5.0" + } + }, + "caniuse-lite": { + "version": "1.0.30001030", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001030.tgz", + "integrity": "sha512-QGK0W4Ft/Ac+zTjEiRJfwDNATvS3fodDczBXrH42784kcfqcDKpEPfN08N0HQjrAp8He/Jw8QiSS9QRn7XAbUw==" + }, + "canvas": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/canvas/-/canvas-2.6.1.tgz", + "integrity": "sha512-S98rKsPcuhfTcYbtF53UIJhcbgIAK533d1kJKMwsMwAIFgfd58MOyxRud3kktlzWiEkFliaJtvyZCBtud/XVEA==", + "optional": true, + "requires": { + "nan": "^2.14.0", + "node-pre-gyp": "^0.11.0", + "simple-get": "^3.0.3" + } + }, + "capture-exit": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/capture-exit/-/capture-exit-2.0.0.tgz", + "integrity": "sha512-PiT/hQmTonHhl/HFGN+Lx3JJUznrVYJ3+AQsnthneZbvW7x+f08Tk7yLJTLEOUvBTbduLeeBkxEaYXUOUrRq6g==", + "requires": { + "rsvp": "^4.8.4" + } + }, + "case-sensitive-paths-webpack-plugin": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/case-sensitive-paths-webpack-plugin/-/case-sensitive-paths-webpack-plugin-2.3.0.tgz", + "integrity": "sha512-/4YgnZS8y1UXXmC02xD5rRrBEu6T5ub+mQHLNRj0fzTRbgdBYhsNo2V5EqwgqrExjxsjtF/OpAKAMkKsxbD5XQ==" + }, + "caseless": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/caseless/-/caseless-0.12.0.tgz", + "integrity": "sha1-G2gcIf+EAzyCZUMJBolCDRhxUdw=" + }, + "chalk": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/chalk/-/chalk-2.4.2.tgz", + "integrity": "sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==", + "requires": { + "ansi-styles": "^3.2.1", + "escape-string-regexp": "^1.0.5", + "supports-color": "^5.3.0" + }, + "dependencies": { + "supports-color": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", + "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", + "requires": { + "has-flag": "^3.0.0" + } + } + } + }, + "chardet": { + "version": "0.7.0", + "resolved": "https://registry.npmjs.org/chardet/-/chardet-0.7.0.tgz", + "integrity": "sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==" + }, + "chokidar": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.3.1.tgz", + "integrity": "sha512-4QYCEWOcK3OJrxwvyyAOxFuhpvOVCYkr33LPfFNBjAD/w3sEzWsp2BUOkI4l9bHvWioAd0rc6NlHUOEaWkTeqg==", + "requires": { + "anymatch": "~3.1.1", + "braces": "~3.0.2", + "fsevents": "~2.1.2", + "glob-parent": "~5.1.0", + "is-binary-path": "~2.1.0", + "is-glob": "~4.0.1", + "normalize-path": "~3.0.0", + "readdirp": "~3.3.0" + }, + "dependencies": { + "anymatch": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.1.tgz", + "integrity": "sha512-mM8522psRCqzV+6LhomX5wgp25YVibjh8Wj23I5RPkPppSVSjyKD2A2mBJmWGa+KN7f2D6LNh9jkBCeyLktzjg==", + "requires": { + "normalize-path": "^3.0.0", + "picomatch": "^2.0.4" + } + }, + "braces": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.2.tgz", + "integrity": "sha512-b8um+L1RzM3WDSzvhm6gIz1yfTbBt6YTlcEKAvsmqCZZFw46z626lVj9j1yEPW33H5H+lBQpZMP1k8l+78Ha0A==", + "requires": { + "fill-range": "^7.0.1" + } + }, + "fill-range": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.0.1.tgz", + "integrity": "sha512-qOo9F+dMUmC2Lcb4BbVvnKJxTPjCm+RRpe4gDuGrzkL7mEVl/djYSu2OdQ2Pa302N4oqkSg9ir6jaLWJ2USVpQ==", + "requires": { + "to-regex-range": "^5.0.1" + } + }, + "fsevents": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.2.tgz", + "integrity": "sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA==", + "optional": true + }, + "is-number": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", + "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==" + }, + "to-regex-range": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", + "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", + "requires": { + "is-number": "^7.0.0" + } + } + } + }, + "chownr": { + "version": "1.1.4", + "resolved": "https://registry.npmjs.org/chownr/-/chownr-1.1.4.tgz", + "integrity": "sha512-jJ0bqzaylmJtVnNgzTeSOs8DPavpbYgEr/b0YL8/2GO3xJEhInFmhKMUnEJQjZumK7KXGFhUy89PrsJWlakBVg==" + }, + "chrome-trace-event": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.2.tgz", + "integrity": "sha512-9e/zx1jw7B4CO+c/RXoCsfg/x1AfUBioy4owYH0bJprEYAx5hRFLRhWBqHAG57D0ZM4H7vxbP7bPe0VwhQRYDQ==", + "requires": { + "tslib": "^1.9.0" + } + }, + "ci-info": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ci-info/-/ci-info-2.0.0.tgz", + "integrity": "sha512-5tK7EtrZ0N+OLFMthtqOj4fI2Jeb88C4CAZPu25LDVUgXJ0A3Js4PMGqrn0JU1W0Mh1/Z8wZzYPxqUrXeBboCQ==" + }, + "cipher-base": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/cipher-base/-/cipher-base-1.0.4.tgz", + "integrity": "sha512-Kkht5ye6ZGmwv40uUDZztayT2ThLQGfnj/T71N/XzeZeo3nf8foyW7zGTsPYkEya3m5f3cAypH+qe7YOrM1U2Q==", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "class-utils": { + "version": "0.3.6", + "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", + "integrity": "sha512-qOhPa/Fj7s6TY8H8esGu5QNpMMQxz79h+urzrNYN6mn+9BnxlDGf5QZ+XeCDsxSjPqsSR56XOZOJmpeurnLMeg==", + "requires": { + "arr-union": "^3.1.0", + "define-property": "^0.2.5", + "isobject": "^3.0.0", + "static-extend": "^0.1.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "clean-css": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/clean-css/-/clean-css-4.2.3.tgz", + "integrity": "sha512-VcMWDN54ZN/DS+g58HYL5/n4Zrqe8vHJpGA8KdgUXFU4fuP/aHNw8eld9SyEIyabIMJX/0RaY/fplOo5hYLSFA==", + "requires": { + "source-map": "~0.6.0" + } + }, + "clean-stack": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/clean-stack/-/clean-stack-2.2.0.tgz", + "integrity": "sha512-4diC9HaTE+KRAMWhDhrGOECgWZxoevMc5TlkObMqNSsVU62PYzXZ/SMTjzyGAFF1YusgxGcSWTEXBhp0CPwQ1A==" + }, + "cli-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/cli-cursor/-/cli-cursor-3.1.0.tgz", + "integrity": "sha512-I/zHAwsKf9FqGoXM4WWRACob9+SNukZTd94DWF57E4toouRulbCxcUh6RKUEOQlYTHJnzkPMySvPNaaSLNfLZw==", + "requires": { + "restore-cursor": "^3.1.0" + } + }, + "cli-width": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cli-width/-/cli-width-2.2.0.tgz", + "integrity": "sha1-/xnt6Kml5XkyQUewwR8PvLq+1jk=" + }, + "cliui": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-5.0.0.tgz", + "integrity": "sha512-PYeGSEmmHM6zvoef2w8TPzlrnNpXIjTipYK780YswmIP9vjxmd6Y2a3CB2Ks6/AU8NHjZugXvo8w3oWM2qnwXA==", + "requires": { + "string-width": "^3.1.0", + "strip-ansi": "^5.2.0", + "wrap-ansi": "^5.1.0" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "clone-deep": { + "version": "0.2.4", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-0.2.4.tgz", + "integrity": "sha1-TnPdCen7lxzDhnDF3O2cGJZIHMY=", + "requires": { + "for-own": "^0.1.3", + "is-plain-object": "^2.0.1", + "kind-of": "^3.0.2", + "lazy-cache": "^1.0.3", + "shallow-clone": "^0.1.2" + } + }, + "co": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/co/-/co-4.6.0.tgz", + "integrity": "sha1-bqa989hTrlTMuOR7+gvz+QMfsYQ=" + }, + "coa": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/coa/-/coa-2.0.2.tgz", + "integrity": "sha512-q5/jG+YQnSy4nRTV4F7lPepBJZ8qBNJJDBuJdoejDyLXgmL7IEo+Le2JDZudFTFt7mrCqIRaSjws4ygRCTCAXA==", + "requires": { + "@types/q": "^1.5.1", + "chalk": "^2.4.1", + "q": "^1.1.2" + } + }, + "code-point-at": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/code-point-at/-/code-point-at-1.1.0.tgz", + "integrity": "sha1-DQcLTQQ6W+ozovGkDi7bPZpMz3c=" + }, + "collection-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/collection-visit/-/collection-visit-1.0.0.tgz", + "integrity": "sha1-S8A3PBZLwykbTTaMgpzxqApZ3KA=", + "requires": { + "map-visit": "^1.0.0", + "object-visit": "^1.0.0" + } + }, + "color": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/color/-/color-3.1.2.tgz", + "integrity": "sha512-vXTJhHebByxZn3lDvDJYw4lR5+uB3vuoHsuYA5AKuxRVn5wzzIfQKGLBmgdVRHKTJYeK5rvJcHnrd0Li49CFpg==", + "requires": { + "color-convert": "^1.9.1", + "color-string": "^1.5.2" + } + }, + "color-convert": { + "version": "1.9.3", + "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-1.9.3.tgz", + "integrity": "sha512-QfAUtd+vFdAtFQcC8CCyYt1fYWxSqAiK2cSD6zDB8N3cpsEBAvRxp9zOGg6G/SHHJYAT88/az/IuDGALsNVbGg==", + "requires": { + "color-name": "1.1.3" + } + }, + "color-name": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.3.tgz", + "integrity": "sha1-p9BVi9icQveV3UIyj3QIMcpTvCU=" + }, + "color-string": { + "version": "1.5.3", + "resolved": "https://registry.npmjs.org/color-string/-/color-string-1.5.3.tgz", + "integrity": "sha512-dC2C5qeWoYkxki5UAXapdjqO672AM4vZuPGRQfO8b5HKuKGBbKWpITyDYN7TOFKvRW7kOgAn3746clDBMDJyQw==", + "requires": { + "color-name": "^1.0.0", + "simple-swizzle": "^0.2.2" + } + }, + "combined-stream": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/combined-stream/-/combined-stream-1.0.8.tgz", + "integrity": "sha512-FQN4MRfuJeHf7cBbBMJFXhKSDq+2kAArBlmRBvcvFE5BB1HZKXtSFASDhdlz9zOYwxh8lDdnvmMOe/+5cdoEdg==", + "requires": { + "delayed-stream": "~1.0.0" + } + }, + "commander": { + "version": "2.20.3", + "resolved": "https://registry.npmjs.org/commander/-/commander-2.20.3.tgz", + "integrity": "sha512-GpVkmM8vF2vQUkj2LvZmD35JxeJOLCwJ9cUkugyk2nuhbv3+mJvpLYYt+0+USMxE+oj+ey/lJEnhZw75x/OMcQ==" + }, + "common-tags": { + "version": "1.8.0", + "resolved": "https://registry.npmjs.org/common-tags/-/common-tags-1.8.0.tgz", + "integrity": "sha512-6P6g0uetGpW/sdyUy/iQQCbFF0kWVMSIVSyYz7Zgjcgh8mgw8PQzDNZeyZ5DQ2gM7LBoZPHmnjz8rUthkBG5tw==" + }, + "commondir": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/commondir/-/commondir-1.0.1.tgz", + "integrity": "sha1-3dgA2gxmEnOTzKWVDqloo6rxJTs=" + }, + "component-emitter": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/component-emitter/-/component-emitter-1.3.0.tgz", + "integrity": "sha512-Rd3se6QB+sO1TwqZjscQrurpEPIfO0/yYnSin6Q/rD3mOutHvUrCAhJub3r90uNb+SESBuE0QYoB90YdfatsRg==" + }, + "compose-function": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/compose-function/-/compose-function-3.0.3.tgz", + "integrity": "sha1-ntZ18TzFRQHTCVCkhv9qe6OrGF8=", + "requires": { + "arity-n": "^1.0.4" + } + }, + "compressible": { + "version": "2.0.18", + "resolved": "https://registry.npmjs.org/compressible/-/compressible-2.0.18.tgz", + "integrity": "sha512-AF3r7P5dWxL8MxyITRMlORQNaOA2IkAFaTr4k7BUumjPtRpGDTZpl0Pb1XCO6JeDCBdp126Cgs9sMxqSjgYyRg==", + "requires": { + "mime-db": ">= 1.43.0 < 2" + } + }, + "compression": { + "version": "1.7.4", + "resolved": "https://registry.npmjs.org/compression/-/compression-1.7.4.tgz", + "integrity": "sha512-jaSIDzP9pZVS4ZfQ+TzvtiWhdpFhE2RDHz8QJkpX9SIpLq88VueF5jJw6t+6CUQcAoA6t+x89MLrWAqpfDE8iQ==", + "requires": { + "accepts": "~1.3.5", + "bytes": "3.0.0", + "compressible": "~2.0.16", + "debug": "2.6.9", + "on-headers": "~1.0.2", + "safe-buffer": "5.1.2", + "vary": "~1.1.2" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + } + } + }, + "concat-map": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", + "integrity": "sha1-2Klr13/Wjfd5OnMDajug1UBdR3s=" + }, + "concat-stream": { + "version": "1.6.2", + "resolved": "https://registry.npmjs.org/concat-stream/-/concat-stream-1.6.2.tgz", + "integrity": "sha512-27HBghJxjiZtIk3Ycvn/4kbJk/1uZuJFfuPEns6LaEvpvG1f0hTea8lilrouyo9mVc2GWdcEZ8OLoGmSADlrCw==", + "requires": { + "buffer-from": "^1.0.0", + "inherits": "^2.0.3", + "readable-stream": "^2.2.2", + "typedarray": "^0.0.6" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "confusing-browser-globals": { + "version": "1.0.9", + "resolved": "https://registry.npmjs.org/confusing-browser-globals/-/confusing-browser-globals-1.0.9.tgz", + "integrity": "sha512-KbS1Y0jMtyPgIxjO7ZzMAuUpAKMt1SzCL9fsrKsX6b0zJPTaT0SiSPmewwVZg9UAO83HVIlEhZF84LIjZ0lmAw==" + }, + "connect-history-api-fallback": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/connect-history-api-fallback/-/connect-history-api-fallback-1.6.0.tgz", + "integrity": "sha512-e54B99q/OUoH64zYYRf3HBP5z24G38h5D3qXu23JGRoigpX5Ss4r9ZnDk3g0Z8uQC2x2lPaJ+UlWBc1ZWBWdLg==" + }, + "console-browserify": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/console-browserify/-/console-browserify-1.2.0.tgz", + "integrity": "sha512-ZMkYO/LkF17QvCPqM0gxw8yUzigAOZOSWSHg91FH6orS7vcEj5dVZTidN2fQ14yBSdg97RqhSNwLUXInd52OTA==" + }, + "console-control-strings": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/console-control-strings/-/console-control-strings-1.1.0.tgz", + "integrity": "sha1-PXz0Rk22RG6mRL9LOVB/mFEAjo4=", + "optional": true + }, + "constants-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/constants-browserify/-/constants-browserify-1.0.0.tgz", + "integrity": "sha1-wguW2MYXdIqvHBYCF2DNJ/y4y3U=" + }, + "contains-path": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/contains-path/-/contains-path-0.1.0.tgz", + "integrity": "sha1-/ozxhP9mcLa67wGp1IYaXL7EEgo=" + }, + "content-disposition": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.3.tgz", + "integrity": "sha512-ExO0774ikEObIAEV9kDo50o+79VCUdEB6n6lzKgGwupcVeRlhrj3qGAfwq8G6uBJjkqLrhT0qEYFcWng8z1z0g==", + "requires": { + "safe-buffer": "5.1.2" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + } + } + }, + "content-type": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.4.tgz", + "integrity": "sha512-hIP3EEPs8tB9AT1L+NUqtwOAps4mk2Zob89MWXMHjHWg9milF/j4osnnQLXBCBFBk/tvIG/tUc9mOUJiPBhPXA==" + }, + "convert-source-map": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-1.7.0.tgz", + "integrity": "sha512-4FJkXzKXEDB1snCFZlLP4gpC3JILicCpGbzG9f9G7tGqGCzETQ2hWPrcinA9oU4wtf2biUaEH5065UnMeR33oA==", + "requires": { + "safe-buffer": "~5.1.1" + }, + "dependencies": { + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + } + } + }, + "cookie": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.4.0.tgz", + "integrity": "sha512-+Hp8fLp57wnUSt0tY0tHEXh4voZRDnoIrZPqlo3DPiI4y9lwg/jqx+1Om94/W6ZaPDOUbnjOt/99w66zk+l1Xg==" + }, + "cookie-signature": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", + "integrity": "sha1-4wOogrNCzD7oylE6eZmXNNqzriw=" + }, + "copy-concurrently": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/copy-concurrently/-/copy-concurrently-1.0.5.tgz", + "integrity": "sha512-f2domd9fsVDFtaFcbaRZuYXwtdmnzqbADSwhSWYxYB/Q8zsdUUFMXVRwXGDMWmbEzAn1kdRrtI1T/KTFOL4X2A==", + "requires": { + "aproba": "^1.1.1", + "fs-write-stream-atomic": "^1.0.8", + "iferr": "^0.1.5", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.0" + } + }, + "copy-descriptor": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/copy-descriptor/-/copy-descriptor-0.1.1.tgz", + "integrity": "sha1-Z29us8OZl8LuGsOpJP1hJHSPV40=" + }, + "core-js": { + "version": "3.6.4", + "resolved": "https://registry.npmjs.org/core-js/-/core-js-3.6.4.tgz", + "integrity": "sha512-4paDGScNgZP2IXXilaffL9X7968RuvwlkK3xWtZRVqgd8SYNiVKRJvkFd1aqqEuPfN7E68ZHEp9hDj6lHj4Hyw==" + }, + "core-js-compat": { + "version": "3.6.4", + "resolved": "https://registry.npmjs.org/core-js-compat/-/core-js-compat-3.6.4.tgz", + "integrity": "sha512-zAa3IZPvsJ0slViBQ2z+vgyyTuhd3MFn1rBQjZSKVEgB0UMYhUkCj9jJUVPgGTGqWvsBVmfnruXgTcNyTlEiSA==", + "requires": { + "browserslist": "^4.8.3", + "semver": "7.0.0" + }, + "dependencies": { + "semver": { + "version": "7.0.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-7.0.0.tgz", + "integrity": "sha512-+GB6zVA9LWh6zovYQLALHwv5rb2PHGlJi3lfiqIHxR0uuwCgefcOJc59v9fv1w8GbStwxuuqqAjI9NMAOOgq1A==" + } + } + }, + "core-util-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/core-util-is/-/core-util-is-1.0.2.tgz", + "integrity": "sha1-tf1UIgqivFq1eqtxQMlAdUUDwac=" + }, + "cosmiconfig": { + "version": "5.2.1", + "resolved": "https://registry.npmjs.org/cosmiconfig/-/cosmiconfig-5.2.1.tgz", + "integrity": "sha512-H65gsXo1SKjf8zmrJ67eJk8aIRKV5ff2D4uKZIBZShbhGSpEmsQOPW/SKMKYhSTrqR7ufy6RP69rPogdaPh/kA==", + "requires": { + "import-fresh": "^2.0.0", + "is-directory": "^0.3.1", + "js-yaml": "^3.13.1", + "parse-json": "^4.0.0" + } + }, + "create-ecdh": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/create-ecdh/-/create-ecdh-4.0.3.tgz", + "integrity": "sha512-GbEHQPMOswGpKXM9kCWVrremUcBmjteUaQ01T9rkKCPDXfUHX0IoP9LpHYo2NPFampa4e+/pFDc3jQdxrxQLaw==", + "requires": { + "bn.js": "^4.1.0", + "elliptic": "^6.0.0" + } + }, + "create-hash": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/create-hash/-/create-hash-1.2.0.tgz", + "integrity": "sha512-z00bCGNHDG8mHAkP7CtT1qVu+bFQUPjYq/4Iv3C3kWjTFV10zIjfSoeqXo9Asws8gwSHDGj/hl2u4OGIjapeCg==", + "requires": { + "cipher-base": "^1.0.1", + "inherits": "^2.0.1", + "md5.js": "^1.3.4", + "ripemd160": "^2.0.1", + "sha.js": "^2.4.0" + } + }, + "create-hmac": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/create-hmac/-/create-hmac-1.1.7.tgz", + "integrity": "sha512-MJG9liiZ+ogc4TzUwuvbER1JRdgvUFSB5+VR/g5h82fGaIRWMWddtKBHi7/sVhfjQZ6SehlyhvQYrcYkaUIpLg==", + "requires": { + "cipher-base": "^1.0.3", + "create-hash": "^1.1.0", + "inherits": "^2.0.1", + "ripemd160": "^2.0.0", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "cross-spawn": { + "version": "6.0.5", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-6.0.5.tgz", + "integrity": "sha512-eTVLrBSt7fjbDygz805pMnstIs2VTBNkRm0qxZd+M7A5XDdxVRWO5MxGBXZhjY4cqLYLdtrGqRf8mBPmzwSpWQ==", + "requires": { + "nice-try": "^1.0.4", + "path-key": "^2.0.1", + "semver": "^5.5.0", + "shebang-command": "^1.2.0", + "which": "^1.2.9" + } + }, + "crypto-browserify": { + "version": "3.12.0", + "resolved": "https://registry.npmjs.org/crypto-browserify/-/crypto-browserify-3.12.0.tgz", + "integrity": "sha512-fz4spIh+znjO2VjL+IdhEpRJ3YN6sMzITSBijk6FK2UvTqruSQW+/cCZTSNsMiZNvUeq0CqurF+dAbyiGOY6Wg==", + "requires": { + "browserify-cipher": "^1.0.0", + "browserify-sign": "^4.0.0", + "create-ecdh": "^4.0.0", + "create-hash": "^1.1.0", + "create-hmac": "^1.1.0", + "diffie-hellman": "^5.0.0", + "inherits": "^2.0.1", + "pbkdf2": "^3.0.3", + "public-encrypt": "^4.0.0", + "randombytes": "^2.0.0", + "randomfill": "^1.0.3" + } + }, + "css": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/css/-/css-2.2.4.tgz", + "integrity": "sha512-oUnjmWpy0niI3x/mPL8dVEI1l7MnG3+HHyRPHf+YFSbK+svOhXpmSOcDURUh2aOCgl2grzrOPt1nHLuCVFULLw==", + "requires": { + "inherits": "^2.0.3", + "source-map": "^0.6.1", + "source-map-resolve": "^0.5.2", + "urix": "^0.1.0" + } + }, + "css-blank-pseudo": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/css-blank-pseudo/-/css-blank-pseudo-0.1.4.tgz", + "integrity": "sha512-LHz35Hr83dnFeipc7oqFDmsjHdljj3TQtxGGiNWSOsTLIAubSm4TEz8qCaKFpk7idaQ1GfWscF4E6mgpBysA1w==", + "requires": { + "postcss": "^7.0.5" + } + }, + "css-color-names": { + "version": "0.0.4", + "resolved": "https://registry.npmjs.org/css-color-names/-/css-color-names-0.0.4.tgz", + "integrity": "sha1-gIrcLnnPhHOAabZGyyDsJ762KeA=" + }, + "css-declaration-sorter": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/css-declaration-sorter/-/css-declaration-sorter-4.0.1.tgz", + "integrity": "sha512-BcxQSKTSEEQUftYpBVnsH4SF05NTuBokb19/sBt6asXGKZ/6VP7PLG1CBCkFDYOnhXhPh0jMhO6xZ71oYHXHBA==", + "requires": { + "postcss": "^7.0.1", + "timsort": "^0.3.0" + } + }, + "css-has-pseudo": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/css-has-pseudo/-/css-has-pseudo-0.10.0.tgz", + "integrity": "sha512-Z8hnfsZu4o/kt+AuFzeGpLVhFOGO9mluyHBaA2bA8aCGTwah5sT3WV/fTHH8UNZUytOIImuGPrl/prlb4oX4qQ==", + "requires": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^5.0.0-rc.4" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "css-loader": { + "version": "3.4.2", + "resolved": "https://registry.npmjs.org/css-loader/-/css-loader-3.4.2.tgz", + "integrity": "sha512-jYq4zdZT0oS0Iykt+fqnzVLRIeiPWhka+7BqPn+oSIpWJAHak5tmB/WZrJ2a21JhCeFyNnnlroSl8c+MtVndzA==", + "requires": { + "camelcase": "^5.3.1", + "cssesc": "^3.0.0", + "icss-utils": "^4.1.1", + "loader-utils": "^1.2.3", + "normalize-path": "^3.0.0", + "postcss": "^7.0.23", + "postcss-modules-extract-imports": "^2.0.0", + "postcss-modules-local-by-default": "^3.0.2", + "postcss-modules-scope": "^2.1.1", + "postcss-modules-values": "^3.0.0", + "postcss-value-parser": "^4.0.2", + "schema-utils": "^2.6.0" + } + }, + "css-prefers-color-scheme": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/css-prefers-color-scheme/-/css-prefers-color-scheme-3.1.1.tgz", + "integrity": "sha512-MTu6+tMs9S3EUqzmqLXEcgNRbNkkD/TGFvowpeoWJn5Vfq7FMgsmRQs9X5NXAURiOBmOxm/lLjsDNXDE6k9bhg==", + "requires": { + "postcss": "^7.0.5" + } + }, + "css-select": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-2.1.0.tgz", + "integrity": "sha512-Dqk7LQKpwLoH3VovzZnkzegqNSuAziQyNZUcrdDM401iY+R5NkGBXGmtO05/yaXQziALuPogeG0b7UAgjnTJTQ==", + "requires": { + "boolbase": "^1.0.0", + "css-what": "^3.2.1", + "domutils": "^1.7.0", + "nth-check": "^1.0.2" + } + }, + "css-select-base-adapter": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/css-select-base-adapter/-/css-select-base-adapter-0.1.1.tgz", + "integrity": "sha512-jQVeeRG70QI08vSTwf1jHxp74JoZsr2XSgETae8/xC8ovSnL2WF87GTLO86Sbwdt2lK4Umg4HnnwMO4YF3Ce7w==" + }, + "css-tree": { + "version": "1.0.0-alpha.37", + "resolved": "https://registry.npmjs.org/css-tree/-/css-tree-1.0.0-alpha.37.tgz", + "integrity": "sha512-DMxWJg0rnz7UgxKT0Q1HU/L9BeJI0M6ksor0OgqOnF+aRCDWg/N2641HmVyU9KVIu0OVVWOb2IpC9A+BJRnejg==", + "requires": { + "mdn-data": "2.0.4", + "source-map": "^0.6.1" + } + }, + "css-what": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-3.2.1.tgz", + "integrity": "sha512-WwOrosiQTvyms+Ti5ZC5vGEK0Vod3FTt1ca+payZqvKuGJF+dq7bG63DstxtN0dpm6FxY27a/zS3Wten+gEtGw==" + }, + "css.escape": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/css.escape/-/css.escape-1.5.1.tgz", + "integrity": "sha1-QuJ9T6BK4y+TGktNQZH6nN3ul8s=" + }, + "cssdb": { + "version": "4.4.0", + "resolved": "https://registry.npmjs.org/cssdb/-/cssdb-4.4.0.tgz", + "integrity": "sha512-LsTAR1JPEM9TpGhl/0p3nQecC2LJ0kD8X5YARu1hk/9I1gril5vDtMZyNxcEpxxDj34YNck/ucjuoUd66K03oQ==" + }, + "cssesc": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-3.0.0.tgz", + "integrity": "sha512-/Tb/JcjK111nNScGob5MNtsntNM1aCNUDipB/TkwZFhyDrrE47SOx/18wF2bbjgc3ZzCSKW1T5nt5EbFoAz/Vg==" + }, + "cssnano": { + "version": "4.1.10", + "resolved": "https://registry.npmjs.org/cssnano/-/cssnano-4.1.10.tgz", + "integrity": "sha512-5wny+F6H4/8RgNlaqab4ktc3e0/blKutmq8yNlBFXA//nSFFAqAngjNVRzUvCgYROULmZZUoosL/KSoZo5aUaQ==", + "requires": { + "cosmiconfig": "^5.0.0", + "cssnano-preset-default": "^4.0.7", + "is-resolvable": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "cssnano-preset-default": { + "version": "4.0.7", + "resolved": "https://registry.npmjs.org/cssnano-preset-default/-/cssnano-preset-default-4.0.7.tgz", + "integrity": "sha512-x0YHHx2h6p0fCl1zY9L9roD7rnlltugGu7zXSKQx6k2rYw0Hi3IqxcoAGF7u9Q5w1nt7vK0ulxV8Lo+EvllGsA==", + "requires": { + "css-declaration-sorter": "^4.0.1", + "cssnano-util-raw-cache": "^4.0.1", + "postcss": "^7.0.0", + "postcss-calc": "^7.0.1", + "postcss-colormin": "^4.0.3", + "postcss-convert-values": "^4.0.1", + "postcss-discard-comments": "^4.0.2", + "postcss-discard-duplicates": "^4.0.2", + "postcss-discard-empty": "^4.0.1", + "postcss-discard-overridden": "^4.0.1", + "postcss-merge-longhand": "^4.0.11", + "postcss-merge-rules": "^4.0.3", + "postcss-minify-font-values": "^4.0.2", + "postcss-minify-gradients": "^4.0.2", + "postcss-minify-params": "^4.0.2", + "postcss-minify-selectors": "^4.0.2", + "postcss-normalize-charset": "^4.0.1", + "postcss-normalize-display-values": "^4.0.2", + "postcss-normalize-positions": "^4.0.2", + "postcss-normalize-repeat-style": "^4.0.2", + "postcss-normalize-string": "^4.0.2", + "postcss-normalize-timing-functions": "^4.0.2", + "postcss-normalize-unicode": "^4.0.1", + "postcss-normalize-url": "^4.0.1", + "postcss-normalize-whitespace": "^4.0.2", + "postcss-ordered-values": "^4.1.2", + "postcss-reduce-initial": "^4.0.3", + "postcss-reduce-transforms": "^4.0.2", + "postcss-svgo": "^4.0.2", + "postcss-unique-selectors": "^4.0.1" + } + }, + "cssnano-util-get-arguments": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-arguments/-/cssnano-util-get-arguments-4.0.0.tgz", + "integrity": "sha1-7ToIKZ8h11dBsg87gfGU7UnMFQ8=" + }, + "cssnano-util-get-match": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/cssnano-util-get-match/-/cssnano-util-get-match-4.0.0.tgz", + "integrity": "sha1-wOTKB/U4a7F+xeUiULT1lhNlFW0=" + }, + "cssnano-util-raw-cache": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-raw-cache/-/cssnano-util-raw-cache-4.0.1.tgz", + "integrity": "sha512-qLuYtWK2b2Dy55I8ZX3ky1Z16WYsx544Q0UWViebptpwn/xDBmog2TLg4f+DBMg1rJ6JDWtn96WHbOKDWt1WQA==", + "requires": { + "postcss": "^7.0.0" + } + }, + "cssnano-util-same-parent": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/cssnano-util-same-parent/-/cssnano-util-same-parent-4.0.1.tgz", + "integrity": "sha512-WcKx5OY+KoSIAxBW6UBBRay1U6vkYheCdjyVNDm85zt5K9mHoGOfsOsqIszfAqrQQFIIKgjh2+FDgIj/zsl21Q==" + }, + "csso": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/csso/-/csso-4.0.2.tgz", + "integrity": "sha512-kS7/oeNVXkHWxby5tHVxlhjizRCSv8QdU7hB2FpdAibDU8FjTAolhNjKNTiLzXtUrKT6HwClE81yXwEk1309wg==", + "requires": { + "css-tree": "1.0.0-alpha.37" + } + }, + "cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==" + }, + "cssstyle": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-1.4.0.tgz", + "integrity": "sha512-GBrLZYZ4X4x6/QEoBnIrqb8B/f5l4+8me2dkom/j1Gtbxy0kBv6OGzKuAsGM75bkGwGAFkt56Iwg28S3XTZgSA==", + "requires": { + "cssom": "0.3.x" + } + }, + "csstype": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/csstype/-/csstype-2.6.9.tgz", + "integrity": "sha512-xz39Sb4+OaTsULgUERcCk+TJj8ylkL4aSVDQiX/ksxbELSqwkgt4d4RD7fovIdgJGSuNYqwZEiVjYY5l0ask+Q==" + }, + "cyclist": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/cyclist/-/cyclist-1.0.1.tgz", + "integrity": "sha1-WW6WmP0MgOEgOMK4LW6xs1tiJNk=" + }, + "d": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/d/-/d-1.0.1.tgz", + "integrity": "sha512-m62ShEObQ39CfralilEQRjH6oAMtNCV1xJyEx5LpRYUVN+EviphDgUc/F3hnYbADmkiNs67Y+3ylmlG7Lnu+FA==", + "requires": { + "es5-ext": "^0.10.50", + "type": "^1.0.1" + } + }, + "damerau-levenshtein": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/damerau-levenshtein/-/damerau-levenshtein-1.0.6.tgz", + "integrity": "sha512-JVrozIeElnj3QzfUIt8tB8YMluBJom4Vw9qTPpjGYQ9fYlB3D/rb6OordUxf3xeFB35LKWs0xqcO5U6ySvBtug==" + }, + "dashdash": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/dashdash/-/dashdash-1.14.1.tgz", + "integrity": "sha1-hTz6D3y+L+1d4gMmuN1YEDX24vA=", + "requires": { + "assert-plus": "^1.0.0" + } + }, + "data-urls": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/data-urls/-/data-urls-1.1.0.tgz", + "integrity": "sha512-YTWYI9se1P55u58gL5GkQHW4P6VJBJ5iBT+B5a7i2Tjadhv52paJG0qHX4A0OR6/t52odI64KP2YvFpkDOi3eQ==", + "requires": { + "abab": "^2.0.0", + "whatwg-mimetype": "^2.2.0", + "whatwg-url": "^7.0.0" + }, + "dependencies": { + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + } + } + }, + "debug": { + "version": "2.6.9", + "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", + "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", + "requires": { + "ms": "2.0.0" + }, + "dependencies": { + "ms": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", + "integrity": "sha1-VgiurfwAvmwpAd9fmGF4jeDVl8g=" + } + } + }, + "decamelize": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/decamelize/-/decamelize-1.2.0.tgz", + "integrity": "sha1-9lNNFRSCabIDUue+4m9QH5oZEpA=" + }, + "decode-uri-component": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/decode-uri-component/-/decode-uri-component-0.2.0.tgz", + "integrity": "sha1-6zkTMzRYd1y4TNGh+uBiEGu4dUU=" + }, + "decompress-response": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/decompress-response/-/decompress-response-4.2.1.tgz", + "integrity": "sha512-jOSne2qbyE+/r8G1VU+G/82LBs2Fs4LAsTiLSHOCOMZQl2OKZ6i8i4IyHemTe+/yIXOtTcRQMzPcgyhoFlqPkw==", + "optional": true, + "requires": { + "mimic-response": "^2.0.0" + } + }, + "deep-equal": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/deep-equal/-/deep-equal-1.1.1.tgz", + "integrity": "sha512-yd9c5AdiqVcR+JjcwUQb9DkhJc8ngNr0MahEBGvDiJw8puWab2yZlh+nkasOnZP+EGTAP6rRp2JzJhJZzvNF8g==", + "requires": { + "is-arguments": "^1.0.4", + "is-date-object": "^1.0.1", + "is-regex": "^1.0.4", + "object-is": "^1.0.1", + "object-keys": "^1.1.1", + "regexp.prototype.flags": "^1.2.0" + } + }, + "deep-extend": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/deep-extend/-/deep-extend-0.6.0.tgz", + "integrity": "sha512-LOHxIOaPYdHlJRtCQfDIVZtfw/ufM8+rVj649RIHzcm/vGwQRXFt6OPqIFWsm2XEMrNIEtWR64sY1LEKD2vAOA==", + "optional": true + }, + "deep-is": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/deep-is/-/deep-is-0.1.3.tgz", + "integrity": "sha1-s2nW+128E+7PUk+RsHD+7cNXzzQ=" + }, + "default-gateway": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/default-gateway/-/default-gateway-4.2.0.tgz", + "integrity": "sha512-h6sMrVB1VMWVrW13mSc6ia/DwYYw5MN6+exNu1OaJeFac5aSAvwM7lZ0NVfTABuSkQelr4h5oebg3KB1XPdjgA==", + "requires": { + "execa": "^1.0.0", + "ip-regex": "^2.1.0" + } + }, + "define-properties": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/define-properties/-/define-properties-1.1.3.tgz", + "integrity": "sha512-3MqfYKj2lLzdMSf8ZIZE/V+Zuy+BgD6f164e8K2w7dgnpKArBDerGYpM46IYYcjnkdPNMjPk9A6VFB8+3SKlXQ==", + "requires": { + "object-keys": "^1.0.12" + } + }, + "define-property": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-2.0.2.tgz", + "integrity": "sha512-jwK2UV4cnPpbcG7+VRARKTZPUWowwXA8bzH5NP6ud0oeAxyYPuGZUAC7hMugpCdz4BeSZl2Dl9k66CHJ/46ZYQ==", + "requires": { + "is-descriptor": "^1.0.2", + "isobject": "^3.0.1" + }, + "dependencies": { + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "del": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/del/-/del-4.1.1.tgz", + "integrity": "sha512-QwGuEUouP2kVwQenAsOof5Fv8K9t3D8Ca8NxcXKrIpEHjTXK5J2nXLdP+ALI1cgv8wj7KuwBhTwBkOZSJKM5XQ==", + "requires": { + "@types/glob": "^7.1.1", + "globby": "^6.1.0", + "is-path-cwd": "^2.0.0", + "is-path-in-cwd": "^2.0.0", + "p-map": "^2.0.0", + "pify": "^4.0.1", + "rimraf": "^2.6.3" + }, + "dependencies": { + "globby": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/globby/-/globby-6.1.0.tgz", + "integrity": "sha1-9abXDoOV4hyFj7BInWTfAkJNUGw=", + "requires": { + "array-union": "^1.0.1", + "glob": "^7.0.3", + "object-assign": "^4.0.1", + "pify": "^2.0.0", + "pinkie-promise": "^2.0.0" + }, + "dependencies": { + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + } + } + }, + "p-map": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-2.1.0.tgz", + "integrity": "sha512-y3b8Kpd8OAN444hxfBbFfj1FY/RjtTd8tzYwhUqNYXx0fXx2iX4maP4Qr6qhIKbQXI02wTLAda4fYUbDagTUFw==" + } + } + }, + "delayed-stream": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delayed-stream/-/delayed-stream-1.0.0.tgz", + "integrity": "sha1-3zrhmayt+31ECqrgsp4icrJOxhk=" + }, + "delegates": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/delegates/-/delegates-1.0.0.tgz", + "integrity": "sha1-hMbhWbgZBP3KWaDvRM2HDTElD5o=", + "optional": true + }, + "depd": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/depd/-/depd-1.1.2.tgz", + "integrity": "sha1-m81S4UwJd2PnSbJ0xDRu0uVgtak=" + }, + "des.js": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/des.js/-/des.js-1.0.1.tgz", + "integrity": "sha512-Q0I4pfFrv2VPd34/vfLrFOoRmlYj3OV50i7fskps1jZWK1kApMWWT9G6RRUeYedLcBDIhnSDaUvJMb3AhUlaEA==", + "requires": { + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0" + } + }, + "destroy": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.0.4.tgz", + "integrity": "sha1-l4hXRCxEdJ5CBmE+N5RiBYJqvYA=" + }, + "detect-libc": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/detect-libc/-/detect-libc-1.0.3.tgz", + "integrity": "sha1-+hN8S9aY7fVc1c0CrFWfkaTEups=", + "optional": true + }, + "detect-newline": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/detect-newline/-/detect-newline-2.1.0.tgz", + "integrity": "sha1-9B8cEL5LAOh7XxPaaAdZ8sW/0+I=" + }, + "detect-node": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/detect-node/-/detect-node-2.0.4.tgz", + "integrity": "sha512-ZIzRpLJrOj7jjP2miAtgqIfmzbxa4ZOr5jJc601zklsfEx9oTzmmj2nVpIPRpNlRTIh8lc1kyViIY7BWSGNmKw==" + }, + "detect-port-alt": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/detect-port-alt/-/detect-port-alt-1.1.6.tgz", + "integrity": "sha512-5tQykt+LqfJFBEYaDITx7S7cR7mJ/zQmLXZ2qt5w04ainYZw6tBf9dBunMjVeVOdYVRUzUOE4HkY5J7+uttb5Q==", + "requires": { + "address": "^1.0.1", + "debug": "^2.6.0" + } + }, + "diff-sequences": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/diff-sequences/-/diff-sequences-24.9.0.tgz", + "integrity": "sha512-Dj6Wk3tWyTE+Fo1rW8v0Xhwk80um6yFYKbuAxc9c3EZxIHFDYwbi34Uk42u1CdnIiVorvt4RmlSDjIPyzGC2ew==" + }, + "diffie-hellman": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/diffie-hellman/-/diffie-hellman-5.0.3.tgz", + "integrity": "sha512-kqag/Nl+f3GwyK25fhUMYj81BUOrZ9IuJsjIcDE5icNM9FJHAVm3VcUDxdLPoQtTuUylWm6ZIknYJwwaPxsUzg==", + "requires": { + "bn.js": "^4.1.0", + "miller-rabin": "^4.0.0", + "randombytes": "^2.0.0" + } + }, + "dir-glob": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/dir-glob/-/dir-glob-2.0.0.tgz", + "integrity": "sha512-37qirFDz8cA5fimp9feo43fSuRo2gHwaIn6dXL8Ber1dGwUosDrGZeCCXq57WnIqE4aQ+u3eQZzsk1yOzhdwag==", + "requires": { + "arrify": "^1.0.1", + "path-type": "^3.0.0" + } + }, + "dns-equal": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/dns-equal/-/dns-equal-1.0.0.tgz", + "integrity": "sha1-s55/HabrCnW6nBcySzR1PEfgZU0=" + }, + "dns-packet": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/dns-packet/-/dns-packet-1.3.1.tgz", + "integrity": "sha512-0UxfQkMhYAUaZI+xrNZOz/as5KgDU0M/fQ9b6SpkyLbk3GEswDi6PADJVaYJradtRVsRIlF1zLyOodbcTCDzUg==", + "requires": { + "ip": "^1.1.0", + "safe-buffer": "^5.0.1" + } + }, + "dns-txt": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/dns-txt/-/dns-txt-2.0.2.tgz", + "integrity": "sha1-uR2Ab10nGI5Ks+fRB9iBocxGQrY=", + "requires": { + "buffer-indexof": "^1.0.0" + } + }, + "doctrine": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-3.0.0.tgz", + "integrity": "sha512-yS+Q5i3hBf7GBkd4KG8a7eBNNWNGLTaEwwYWUijIYM7zrlYDM0BFXHjjPWlWZ1Rg7UaddZeIDmi9jF3HmqiQ2w==", + "requires": { + "esutils": "^2.0.2" + } + }, + "dom-converter": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/dom-converter/-/dom-converter-0.2.0.tgz", + "integrity": "sha512-gd3ypIPfOMr9h5jIKq8E3sHOTCjeirnl0WK5ZdS1AW0Odt0b1PaWaHdJ4Qk4klv+YB9aJBS7mESXjFoDQPu6DA==", + "requires": { + "utila": "~0.4" + } + }, + "dom-serializer": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/dom-serializer/-/dom-serializer-0.2.2.tgz", + "integrity": "sha512-2/xPb3ORsQ42nHYiSunXkDjPLBaEj/xTwUO4B7XCZQTRk7EBtTOPaygh10YAAh2OI1Qrp6NWfpAhzswj0ydt9g==", + "requires": { + "domelementtype": "^2.0.1", + "entities": "^2.0.0" + }, + "dependencies": { + "domelementtype": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-2.0.1.tgz", + "integrity": "sha512-5HOHUDsYZWV8FGWN0Njbr/Rn7f/eWSQi1v7+HsUVwXgn8nWWlL64zKDkS0n8ZmQ3mlWOMuXOnR+7Nx/5tMO5AQ==" + } + } + }, + "domain-browser": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/domain-browser/-/domain-browser-1.2.0.tgz", + "integrity": "sha512-jnjyiM6eRyZl2H+W8Q/zLMA481hzi0eszAaBUzIVnmYVDBbnLxVNnfu1HgEBvCbL+71FrxMl3E6lpKH7Ge3OXA==" + }, + "domelementtype": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/domelementtype/-/domelementtype-1.3.1.tgz", + "integrity": "sha512-BSKB+TSpMpFI/HOxCNr1O8aMOTZ8hT3pM3GQ0w/mWRmkhEDSFJkkyzz4XQsBV44BChwGkrDfMyjVD0eA2aFV3w==" + }, + "domexception": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/domexception/-/domexception-1.0.1.tgz", + "integrity": "sha512-raigMkn7CJNNo6Ihro1fzG7wr3fHuYVytzquZKX5n0yizGsTcYgzdIUwj1X9pK0VvjeihV+XiclP+DjwbsSKug==", + "requires": { + "webidl-conversions": "^4.0.2" + } + }, + "domhandler": { + "version": "2.4.2", + "resolved": "https://registry.npmjs.org/domhandler/-/domhandler-2.4.2.tgz", + "integrity": "sha512-JiK04h0Ht5u/80fdLMCEmV4zkNh2BcoMFBmZ/91WtYZ8qVXSKjiw7fXMgFPnHcSZgOo3XdinHvmnDUeMf5R4wA==", + "requires": { + "domelementtype": "1" + } + }, + "domutils": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.7.0.tgz", + "integrity": "sha512-Lgd2XcJ/NjEw+7tFvfKxOzCYKZsdct5lczQ2ZaQY8Djz7pfAD3Gbp8ySJWtreII/vDlMVmxwa6pHmdxIYgttDg==", + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "dot-case": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/dot-case/-/dot-case-3.0.3.tgz", + "integrity": "sha512-7hwEmg6RiSQfm/GwPL4AAWXKy3YNNZA3oFv2Pdiey0mwkRCPZ9x6SZbkLcn8Ma5PYeVokzoD4Twv2n7LKp5WeA==", + "requires": { + "no-case": "^3.0.3", + "tslib": "^1.10.0" + } + }, + "dot-prop": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/dot-prop/-/dot-prop-5.2.0.tgz", + "integrity": "sha512-uEUyaDKoSQ1M4Oq8l45hSE26SnTxL6snNnqvK/VWx5wJhmff5z0FUVJDKDanor/6w3kzE3i7XZOk+7wC0EXr1A==", + "requires": { + "is-obj": "^2.0.0" + } + }, + "dotenv": { + "version": "8.2.0", + "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-8.2.0.tgz", + "integrity": "sha512-8sJ78ElpbDJBHNeBzUbUVLsqKdccaa/BXF1uPTw3GrvQTBgrQrtObr2mUrE38vzYd8cEv+m/JBfDLioYcfXoaw==" + }, + "dotenv-expand": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/dotenv-expand/-/dotenv-expand-5.1.0.tgz", + "integrity": "sha512-YXQl1DSa4/PQyRfgrv6aoNjhasp/p4qs9FjJ4q4cQk+8m4r6k4ZSiEyytKG8f8W9gi8WsQtIObNmKd+tMzNTmA==" + }, + "duplexer": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.1.tgz", + "integrity": "sha1-rOb/gIwc5mtX0ev5eXessCM0z8E=" + }, + "duplexify": { + "version": "3.7.1", + "resolved": "https://registry.npmjs.org/duplexify/-/duplexify-3.7.1.tgz", + "integrity": "sha512-07z8uv2wMyS51kKhD1KsdXJg5WQ6t93RneqRxUHnskXVtlYYkLqM0gqStQZ3pj073g687jPCHrqNfCzawLYh5g==", + "requires": { + "end-of-stream": "^1.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.0.0", + "stream-shift": "^1.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "ecc-jsbn": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/ecc-jsbn/-/ecc-jsbn-0.1.2.tgz", + "integrity": "sha1-OoOpBOVDUyh4dMVkt1SThoSamMk=", + "requires": { + "jsbn": "~0.1.0", + "safer-buffer": "^2.1.0" + } + }, + "ee-first": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", + "integrity": "sha1-WQxhFWsK4vTwJVcyoViyZrxWsh0=" + }, + "electron-to-chromium": { + "version": "1.3.360", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.3.360.tgz", + "integrity": "sha512-RE1pv2sjQiDRRN1nI0fJ0eQHZ9le4oobu16OArnwEUV5ycAU5SNjFyvzjZ1gPUAqBa2Ud1XagtW8j3ZXfHuQHA==" + }, + "elliptic": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/elliptic/-/elliptic-6.5.2.tgz", + "integrity": "sha512-f4x70okzZbIQl/NSRLkI/+tteV/9WqL98zx+SQ69KbXxmVrmjwsNUPn/gYJJ0sHvEak24cZgHIPegRePAtA/xw==", + "requires": { + "bn.js": "^4.4.0", + "brorand": "^1.0.1", + "hash.js": "^1.0.0", + "hmac-drbg": "^1.0.0", + "inherits": "^2.0.1", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.0" + } + }, + "emoji-regex": { + "version": "8.0.0", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-8.0.0.tgz", + "integrity": "sha512-MSjYzcWNOA0ewAHpz0MxpYFvwg6yjy1NG3xteoqz644VCo/RPgnr1/GGt+ic3iJTzQ8Eu3TdM14SawnVUmGE6A==" + }, + "emojis-list": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-3.0.0.tgz", + "integrity": "sha512-/kyM18EfinwXZbno9FyUGeFh87KC8HRQBQGildHZbEuRyWFOmv1U10o9BBp8XVZDVNNuQKyIGIu5ZYAAXJ0V2Q==" + }, + "encodeurl": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", + "integrity": "sha1-rT/0yG7C0CkyL1oCw6mmBslbP1k=" + }, + "end-of-stream": { + "version": "1.4.4", + "resolved": "https://registry.npmjs.org/end-of-stream/-/end-of-stream-1.4.4.tgz", + "integrity": "sha512-+uw1inIHVPQoaVuHzRyXd21icM+cnt4CzD5rW+NC1wjOUSTOs+Te7FOv7AhN7vS9x/oIyhLP5PR1H+phQAHu5Q==", + "requires": { + "once": "^1.4.0" + } + }, + "enhanced-resolve": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-4.1.1.tgz", + "integrity": "sha512-98p2zE+rL7/g/DzMHMTF4zZlCgeVdJ7yr6xzEpJRYwFYrGi9ANdn5DnJURg6RpBkyk60XYDnWIv51VfIhfNGuA==", + "requires": { + "graceful-fs": "^4.1.2", + "memory-fs": "^0.5.0", + "tapable": "^1.0.0" + }, + "dependencies": { + "memory-fs": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.5.0.tgz", + "integrity": "sha512-jA0rdU5KoQMC0e6ppoNRtpp6vjFq6+NY7r8hywnC7V+1Xj/MtHwGIbB1QaK/dunyjWteJzmkpd7ooeWg10T7GA==", + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + } + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "entities": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/entities/-/entities-2.0.0.tgz", + "integrity": "sha512-D9f7V0JSRwIxlRI2mjMqufDrRDnx8p+eEOz7aUM9SuvF8gsBzra0/6tbjl1m8eQHrZlYj6PxqE00hZ1SAIKPLw==" + }, + "errno": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/errno/-/errno-0.1.7.tgz", + "integrity": "sha512-MfrRBDWzIWifgq6tJj60gkAwtLNb6sQPlcFrSOflcP1aFmmruKQ2wRnze/8V6kgyz7H3FF8Npzv78mZ7XLLflg==", + "requires": { + "prr": "~1.0.1" + } + }, + "error-ex": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/error-ex/-/error-ex-1.3.2.tgz", + "integrity": "sha512-7dFHNmqeFSEt2ZBsCriorKnn3Z2pj+fd9kmI6QoWw4//DL+icEBfc0U7qJCisqrTsKTjw4fNFy2pW9OqStD84g==", + "requires": { + "is-arrayish": "^0.2.1" + } + }, + "es-abstract": { + "version": "1.17.4", + "resolved": "https://registry.npmjs.org/es-abstract/-/es-abstract-1.17.4.tgz", + "integrity": "sha512-Ae3um/gb8F0mui/jPL+QiqmglkUsaQf7FwBEHYIFkztkneosu9imhqHpBzQ3h1vit8t5iQ74t6PEVvphBZiuiQ==", + "requires": { + "es-to-primitive": "^1.2.1", + "function-bind": "^1.1.1", + "has": "^1.0.3", + "has-symbols": "^1.0.1", + "is-callable": "^1.1.5", + "is-regex": "^1.0.5", + "object-inspect": "^1.7.0", + "object-keys": "^1.1.1", + "object.assign": "^4.1.0", + "string.prototype.trimleft": "^2.1.1", + "string.prototype.trimright": "^2.1.1" + } + }, + "es-to-primitive": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/es-to-primitive/-/es-to-primitive-1.2.1.tgz", + "integrity": "sha512-QCOllgZJtaUo9miYBcLChTUaHNjJF3PYs1VidD7AwiEj1kYxKeQTctLAezAOH5ZKRH0g2IgPn6KwB4IT8iRpvA==", + "requires": { + "is-callable": "^1.1.4", + "is-date-object": "^1.0.1", + "is-symbol": "^1.0.2" + } + }, + "es5-ext": { + "version": "0.10.53", + "resolved": "https://registry.npmjs.org/es5-ext/-/es5-ext-0.10.53.tgz", + "integrity": "sha512-Xs2Stw6NiNHWypzRTY1MtaG/uJlwCk8kH81920ma8mvN8Xq1gsfhZvpkImLQArw8AHnv8MT2I45J3c0R8slE+Q==", + "requires": { + "es6-iterator": "~2.0.3", + "es6-symbol": "~3.1.3", + "next-tick": "~1.0.0" + } + }, + "es6-iterator": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/es6-iterator/-/es6-iterator-2.0.3.tgz", + "integrity": "sha1-p96IkUGgWpSwhUQDstCg+/qY87c=", + "requires": { + "d": "1", + "es5-ext": "^0.10.35", + "es6-symbol": "^3.1.1" + } + }, + "es6-symbol": { + "version": "3.1.3", + "resolved": "https://registry.npmjs.org/es6-symbol/-/es6-symbol-3.1.3.tgz", + "integrity": "sha512-NJ6Yn3FuDinBaBRWl/q5X/s4koRHBrgKAu+yGI6JCBeiu3qrcbJhwT2GeR/EXVfylRk8dpQVJoLEFhK+Mu31NA==", + "requires": { + "d": "^1.0.1", + "ext": "^1.1.2" + } + }, + "escape-html": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", + "integrity": "sha1-Aljq5NPQwJdN4cFpGI7wBR0dGYg=" + }, + "escape-string-regexp": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-1.0.5.tgz", + "integrity": "sha1-G2HAViGQqN/2rjuyzwIAyhMLhtQ=" + }, + "escodegen": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/escodegen/-/escodegen-1.14.1.tgz", + "integrity": "sha512-Bmt7NcRySdIfNPfU2ZoXDrrXsG9ZjvDxcAlMfDUgRBjLOWTuIACXPBFJH7Z+cLb40JeQco5toikyc9t9P8E9SQ==", + "requires": { + "esprima": "^4.0.1", + "estraverse": "^4.2.0", + "esutils": "^2.0.2", + "optionator": "^0.8.1", + "source-map": "~0.6.1" + } + }, + "eslint": { + "version": "6.8.0", + "resolved": "https://registry.npmjs.org/eslint/-/eslint-6.8.0.tgz", + "integrity": "sha512-K+Iayyo2LtyYhDSYwz5D5QdWw0hCacNzyq1Y821Xna2xSJj7cijoLLYmLxTQgcgZ9mC61nryMy9S7GRbYpI5Ig==", + "requires": { + "@babel/code-frame": "^7.0.0", + "ajv": "^6.10.0", + "chalk": "^2.1.0", + "cross-spawn": "^6.0.5", + "debug": "^4.0.1", + "doctrine": "^3.0.0", + "eslint-scope": "^5.0.0", + "eslint-utils": "^1.4.3", + "eslint-visitor-keys": "^1.1.0", + "espree": "^6.1.2", + "esquery": "^1.0.1", + "esutils": "^2.0.2", + "file-entry-cache": "^5.0.1", + "functional-red-black-tree": "^1.0.1", + "glob-parent": "^5.0.0", + "globals": "^12.1.0", + "ignore": "^4.0.6", + "import-fresh": "^3.0.0", + "imurmurhash": "^0.1.4", + "inquirer": "^7.0.0", + "is-glob": "^4.0.0", + "js-yaml": "^3.13.1", + "json-stable-stringify-without-jsonify": "^1.0.1", + "levn": "^0.3.0", + "lodash": "^4.17.14", + "minimatch": "^3.0.4", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "optionator": "^0.8.3", + "progress": "^2.0.0", + "regexpp": "^2.0.1", + "semver": "^6.1.2", + "strip-ansi": "^5.2.0", + "strip-json-comments": "^3.0.1", + "table": "^5.2.3", + "text-table": "^0.2.0", + "v8-compile-cache": "^2.0.3" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + }, + "globals": { + "version": "12.3.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-12.3.0.tgz", + "integrity": "sha512-wAfjdLgFsPZsklLJvOBUBmzYE8/CwhEqSBEMRXA3qxIiNtyqvjYurAtIfDh6chlEPUfmTY3MnZh5Hfh4q0UlIw==", + "requires": { + "type-fest": "^0.8.1" + } + }, + "import-fresh": { + "version": "3.2.1", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-3.2.1.tgz", + "integrity": "sha512-6e1q1cnWP2RXD9/keSkxHScg508CdXqXWgWBaETNhyuBFz+kUZlKboh+ISK+bU++DmbHimVBrOz/zzPe0sZ3sQ==", + "requires": { + "parent-module": "^1.0.0", + "resolve-from": "^4.0.0" + } + }, + "regexpp": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-2.0.1.tgz", + "integrity": "sha512-lv0M6+TkDVniA3aD1Eg0DVpfU/booSu7Eev3TDO/mZKHBfVjgCGTV4t4buppESEYDtkArYFOxTJWv6S5C+iaNw==" + }, + "resolve-from": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-4.0.0.tgz", + "integrity": "sha512-pb/MYmXstAkysRFx8piNI1tGFNQIFA3vkE3Gq4EuA1dF6gHp/+vgZqsCGJapvy8N3Q+4o7FwvquPJcnZ7RYy4g==" + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "eslint-config-react-app": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/eslint-config-react-app/-/eslint-config-react-app-5.2.0.tgz", + "integrity": "sha512-WrHjoGpKr1kLLiWDD81tme9jMM0hk5cMxasLSdyno6DdPt+IfLOrDJBVo6jN7tn4y1nzhs43TmUaZWO6Sf0blw==", + "requires": { + "confusing-browser-globals": "^1.0.9" + } + }, + "eslint-import-resolver-node": { + "version": "0.3.3", + "resolved": "https://registry.npmjs.org/eslint-import-resolver-node/-/eslint-import-resolver-node-0.3.3.tgz", + "integrity": "sha512-b8crLDo0M5RSe5YG8Pu2DYBj71tSB6OvXkfzwbJU2w7y8P4/yo0MyF8jU26IEuEuHF2K5/gcAJE3LhQGqBBbVg==", + "requires": { + "debug": "^2.6.9", + "resolve": "^1.13.1" + } + }, + "eslint-loader": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/eslint-loader/-/eslint-loader-3.0.3.tgz", + "integrity": "sha512-+YRqB95PnNvxNp1HEjQmvf9KNvCin5HXYYseOXVC2U0KEcw4IkQ2IQEBG46j7+gW39bMzeu0GsUhVbBY3Votpw==", + "requires": { + "fs-extra": "^8.1.0", + "loader-fs-cache": "^1.0.2", + "loader-utils": "^1.2.3", + "object-hash": "^2.0.1", + "schema-utils": "^2.6.1" + } + }, + "eslint-module-utils": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/eslint-module-utils/-/eslint-module-utils-2.5.2.tgz", + "integrity": "sha512-LGScZ/JSlqGKiT8OC+cYRxseMjyqt6QO54nl281CK93unD89ijSeRV6An8Ci/2nvWVKe8K/Tqdm75RQoIOCr+Q==", + "requires": { + "debug": "^2.6.9", + "pkg-dir": "^2.0.0" + }, + "dependencies": { + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=" + }, + "pkg-dir": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-2.0.0.tgz", + "integrity": "sha1-9tXREJ4Z1j7fQo4L1X4Sd3YVM0s=", + "requires": { + "find-up": "^2.1.0" + } + } + } + }, + "eslint-plugin-flowtype": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-flowtype/-/eslint-plugin-flowtype-4.6.0.tgz", + "integrity": "sha512-W5hLjpFfZyZsXfo5anlu7HM970JBDqbEshAJUkeczP6BFCIfJXuiIBQXyberLRtOStT0OGPF8efeTbxlHk4LpQ==", + "requires": { + "lodash": "^4.17.15" + } + }, + "eslint-plugin-import": { + "version": "2.20.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-import/-/eslint-plugin-import-2.20.0.tgz", + "integrity": "sha512-NK42oA0mUc8Ngn4kONOPsPB1XhbUvNHqF+g307dPV28aknPoiNnKLFd9em4nkswwepdF5ouieqv5Th/63U7YJQ==", + "requires": { + "array-includes": "^3.0.3", + "array.prototype.flat": "^1.2.1", + "contains-path": "^0.1.0", + "debug": "^2.6.9", + "doctrine": "1.5.0", + "eslint-import-resolver-node": "^0.3.2", + "eslint-module-utils": "^2.4.1", + "has": "^1.0.3", + "minimatch": "^3.0.4", + "object.values": "^1.1.0", + "read-pkg-up": "^2.0.0", + "resolve": "^1.12.0" + }, + "dependencies": { + "doctrine": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-1.5.0.tgz", + "integrity": "sha1-N53Ocw9hZvds76TmcHoVmwLFpvo=", + "requires": { + "esutils": "^2.0.2", + "isarray": "^1.0.0" + } + } + } + }, + "eslint-plugin-jsx-a11y": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/eslint-plugin-jsx-a11y/-/eslint-plugin-jsx-a11y-6.2.3.tgz", + "integrity": "sha512-CawzfGt9w83tyuVekn0GDPU9ytYtxyxyFZ3aSWROmnRRFQFT2BiPJd7jvRdzNDi6oLWaS2asMeYSNMjWTV4eNg==", + "requires": { + "@babel/runtime": "^7.4.5", + "aria-query": "^3.0.0", + "array-includes": "^3.0.3", + "ast-types-flow": "^0.0.7", + "axobject-query": "^2.0.2", + "damerau-levenshtein": "^1.0.4", + "emoji-regex": "^7.0.2", + "has": "^1.0.3", + "jsx-ast-utils": "^2.2.1" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + } + } + }, + "eslint-plugin-react": { + "version": "7.18.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-react/-/eslint-plugin-react-7.18.0.tgz", + "integrity": "sha512-p+PGoGeV4SaZRDsXqdj9OWcOrOpZn8gXoGPcIQTzo2IDMbAKhNDnME9myZWqO3Ic4R3YmwAZ1lDjWl2R2hMUVQ==", + "requires": { + "array-includes": "^3.1.1", + "doctrine": "^2.1.0", + "has": "^1.0.3", + "jsx-ast-utils": "^2.2.3", + "object.entries": "^1.1.1", + "object.fromentries": "^2.0.2", + "object.values": "^1.1.1", + "prop-types": "^15.7.2", + "resolve": "^1.14.2" + }, + "dependencies": { + "doctrine": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/doctrine/-/doctrine-2.1.0.tgz", + "integrity": "sha512-35mSku4ZXK0vfCuHEDAwt55dg2jNajHZ1odvF+8SSr82EsZY4QmXfuWso8oEd8zRhVObSN18aM0CjSdoBX7zIw==", + "requires": { + "esutils": "^2.0.2" + } + } + } + }, + "eslint-plugin-react-hooks": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/eslint-plugin-react-hooks/-/eslint-plugin-react-hooks-1.7.0.tgz", + "integrity": "sha512-iXTCFcOmlWvw4+TOE8CLWj6yX1GwzT0Y6cUfHHZqWnSk144VmVIRcVGtUAzrLES7C798lmvnt02C7rxaOX1HNA==" + }, + "eslint-scope": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-5.0.0.tgz", + "integrity": "sha512-oYrhJW7S0bxAFDvWqzvMPRm6pcgcnWc4QnofCAqRTRfQC0JcwenzGglTtsLyIuuWFfkqDG9vz67cnttSd53djw==", + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "eslint-utils": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/eslint-utils/-/eslint-utils-1.4.3.tgz", + "integrity": "sha512-fbBN5W2xdY45KulGXmLHZ3c3FHfVYmKg0IrAKGOkT/464PQsx2UeIzfz1RmEci+KLm1bBaAzZAh8+/E+XAeZ8Q==", + "requires": { + "eslint-visitor-keys": "^1.1.0" + } + }, + "eslint-visitor-keys": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/eslint-visitor-keys/-/eslint-visitor-keys-1.1.0.tgz", + "integrity": "sha512-8y9YjtM1JBJU/A9Kc+SbaOV4y29sSWckBwMHa+FGtVj5gN/sbnKDf6xJUl+8g7FAij9LVaP8C24DUiH/f/2Z9A==" + }, + "espree": { + "version": "6.1.2", + "resolved": "https://registry.npmjs.org/espree/-/espree-6.1.2.tgz", + "integrity": "sha512-2iUPuuPP+yW1PZaMSDM9eyVf8D5P0Hi8h83YtZ5bPc/zHYjII5khoixIUTMO794NOY8F/ThF1Bo8ncZILarUTA==", + "requires": { + "acorn": "^7.1.0", + "acorn-jsx": "^5.1.0", + "eslint-visitor-keys": "^1.1.0" + } + }, + "esprima": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/esprima/-/esprima-4.0.1.tgz", + "integrity": "sha512-eGuFFw7Upda+g4p+QHvnW0RyTX/SVeJBDM/gCtMARO0cLuT2HcEKnTPvhjV6aGeqrCB/sbNop0Kszm0jsaWU4A==" + }, + "esquery": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/esquery/-/esquery-1.1.0.tgz", + "integrity": "sha512-MxYW9xKmROWF672KqjO75sszsA8Mxhw06YFeS5VHlB98KDHbOSurm3ArsjO60Eaf3QmGMCP1yn+0JQkNLo/97Q==", + "requires": { + "estraverse": "^4.0.0" + } + }, + "esrecurse": { + "version": "4.2.1", + "resolved": "https://registry.npmjs.org/esrecurse/-/esrecurse-4.2.1.tgz", + "integrity": "sha512-64RBB++fIOAXPw3P9cy89qfMlvZEXZkqqJkjqqXIvzP5ezRZjW+lPWjw35UX/3EhUPFYbg5ER4JYgDw4007/DQ==", + "requires": { + "estraverse": "^4.1.0" + } + }, + "estraverse": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/estraverse/-/estraverse-4.3.0.tgz", + "integrity": "sha512-39nnKffWz8xN1BU/2c79n9nB9HDzo0niYUqx6xyqUnyoAnQyyWpOTdZEeiCch8BBu515t4wp9ZmgVfVhn9EBpw==" + }, + "esutils": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/esutils/-/esutils-2.0.3.tgz", + "integrity": "sha512-kVscqXk4OCp68SZ0dkgEKVi6/8ij300KBWTJq32P/dYeWTSwK41WyTxalN1eRmA5Z9UU/LX9D7FWSmV9SAYx6g==" + }, + "etag": { + "version": "1.8.1", + "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", + "integrity": "sha1-Qa4u62XvpiJorr/qg6x9eSmbCIc=" + }, + "eventemitter3": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/eventemitter3/-/eventemitter3-4.0.0.tgz", + "integrity": "sha512-qerSRB0p+UDEssxTtm6EDKcE7W4OaoisfIMl4CngyEhjpYglocpNg6UEqCvemdGhosAsg4sO2dXJOdyBifPGCg==" + }, + "events": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/events/-/events-3.1.0.tgz", + "integrity": "sha512-Rv+u8MLHNOdMjTAFeT3nCjHn2aGlx435FP/sDHNaRhDEMwyI/aB22Kj2qIN8R0cw3z28psEQLYwxVKLsKrMgWg==" + }, + "eventsource": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/eventsource/-/eventsource-1.0.7.tgz", + "integrity": "sha512-4Ln17+vVT0k8aWq+t/bF5arcS3EpT9gYtW66EPacdj/mAFevznsnyoHLPy2BA8gbIQeIHoPsvwmfBftfcG//BQ==", + "requires": { + "original": "^1.0.0" + } + }, + "evp_bytestokey": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/evp_bytestokey/-/evp_bytestokey-1.0.3.tgz", + "integrity": "sha512-/f2Go4TognH/KvCISP7OUsHn85hT9nUkxxA9BEWxFn+Oj9o8ZNLm/40hdlgSLyuOimsrTKLUMEorQexp/aPQeA==", + "requires": { + "md5.js": "^1.3.4", + "safe-buffer": "^5.1.1" + } + }, + "exec-sh": { + "version": "0.3.4", + "resolved": "https://registry.npmjs.org/exec-sh/-/exec-sh-0.3.4.tgz", + "integrity": "sha512-sEFIkc61v75sWeOe72qyrqg2Qg0OuLESziUDk/O/z2qgS15y2gWVFrI6f2Qn/qw/0/NCfCEsmNA4zOjkwEZT1A==" + }, + "execa": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/execa/-/execa-1.0.0.tgz", + "integrity": "sha512-adbxcyWV46qiHyvSp50TKt05tB4tK3HcmF7/nxfAdhnox83seTDbwnaqKO4sXRy7roHAIFqJP/Rw/AuEbX61LA==", + "requires": { + "cross-spawn": "^6.0.0", + "get-stream": "^4.0.0", + "is-stream": "^1.1.0", + "npm-run-path": "^2.0.0", + "p-finally": "^1.0.0", + "signal-exit": "^3.0.0", + "strip-eof": "^1.0.0" + } + }, + "exit": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/exit/-/exit-0.1.2.tgz", + "integrity": "sha1-BjJjj42HfMghB9MKD/8aF8uhzQw=" + }, + "expand-brackets": { + "version": "2.1.4", + "resolved": "https://registry.npmjs.org/expand-brackets/-/expand-brackets-2.1.4.tgz", + "integrity": "sha1-t3c14xXOMPa27/D4OwQVGiJEliI=", + "requires": { + "debug": "^2.3.3", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "posix-character-classes": "^0.1.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "expect": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/expect/-/expect-24.9.0.tgz", + "integrity": "sha512-wvVAx8XIol3Z5m9zvZXiyZOQ+sRJqNTIm6sGjdWlaZIeupQGO3WbYI+15D/AmEwZywL6wtJkbAbJtzkOfBuR0Q==", + "requires": { + "@jest/types": "^24.9.0", + "ansi-styles": "^3.2.0", + "jest-get-type": "^24.9.0", + "jest-matcher-utils": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-regex-util": "^24.9.0" + } + }, + "express": { + "version": "4.17.1", + "resolved": "https://registry.npmjs.org/express/-/express-4.17.1.tgz", + "integrity": "sha512-mHJ9O79RqluphRrcw2X/GTh3k9tVv8YcoyY4Kkh4WDMUYKRZUq0h1o0w2rrrxBqM7VoeUVqgb27xlEMXTnYt4g==", + "requires": { + "accepts": "~1.3.7", + "array-flatten": "1.1.1", + "body-parser": "1.19.0", + "content-disposition": "0.5.3", + "content-type": "~1.0.4", + "cookie": "0.4.0", + "cookie-signature": "1.0.6", + "debug": "2.6.9", + "depd": "~1.1.2", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "finalhandler": "~1.1.2", + "fresh": "0.5.2", + "merge-descriptors": "1.0.1", + "methods": "~1.1.2", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "path-to-regexp": "0.1.7", + "proxy-addr": "~2.0.5", + "qs": "6.7.0", + "range-parser": "~1.2.1", + "safe-buffer": "5.1.2", + "send": "0.17.1", + "serve-static": "1.14.1", + "setprototypeof": "1.1.1", + "statuses": "~1.5.0", + "type-is": "~1.6.18", + "utils-merge": "1.0.1", + "vary": "~1.1.2" + }, + "dependencies": { + "array-flatten": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", + "integrity": "sha1-ml9pkFGx5wczKPKgCJaLZOopVdI=" + }, + "qs": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.7.0.tgz", + "integrity": "sha512-VCdBRNFTX1fyE7Nb6FYoURo/SPe62QCaAyzJvUjwRaIsc+NePBEniHlvxFmmX56+HZphIGtV0XeCirBtpDrTyQ==" + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + } + } + }, + "ext": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/ext/-/ext-1.4.0.tgz", + "integrity": "sha512-Key5NIsUxdqKg3vIsdw9dSuXpPCQ297y6wBjL30edxwPgt2E44WcWBZey/ZvUc6sERLTxKdyCu4gZFmUbk1Q7A==", + "requires": { + "type": "^2.0.0" + }, + "dependencies": { + "type": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/type/-/type-2.0.0.tgz", + "integrity": "sha512-KBt58xCHry4Cejnc2ISQAF7QY+ORngsWfxezO68+12hKV6lQY8P/psIkcbjeHWn7MqcgciWJyCCevFMJdIXpow==" + } + } + }, + "extend": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend/-/extend-3.0.2.tgz", + "integrity": "sha512-fjquC59cD7CyW6urNXK0FBufkZcoiGG80wTuPujX590cB5Ttln20E2UB4S/WARVqhXffZl2LNgS+gQdPIIim/g==" + }, + "extend-shallow": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-3.0.2.tgz", + "integrity": "sha1-Jqcarwc7OfshJxcnRhMcJwQCjbg=", + "requires": { + "assign-symbols": "^1.0.0", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "external-editor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/external-editor/-/external-editor-3.1.0.tgz", + "integrity": "sha512-hMQ4CX1p1izmuLYyZqLMO/qGNw10wSv9QDCPfzXfyFrOaCSSoRfqE1Kf1s5an66J5JZC62NewG+mK49jOCtQew==", + "requires": { + "chardet": "^0.7.0", + "iconv-lite": "^0.4.24", + "tmp": "^0.0.33" + } + }, + "extglob": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/extglob/-/extglob-2.0.4.tgz", + "integrity": "sha512-Nmb6QXkELsuBr24CJSkilo6UHHgbekK5UiZgfE6UHD3Eb27YC6oD+bhcT+tJ6cl8dmsgdQxnWlcry8ksBIBLpw==", + "requires": { + "array-unique": "^0.3.2", + "define-property": "^1.0.0", + "expand-brackets": "^2.1.4", + "extend-shallow": "^2.0.1", + "fragment-cache": "^0.2.1", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "extsprintf": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/extsprintf/-/extsprintf-1.3.0.tgz", + "integrity": "sha1-lpGEQOMEGnpBT4xS48V06zw+HgU=" + }, + "fabric": { + "version": "4.0.0-beta.7", + "resolved": "https://registry.npmjs.org/fabric/-/fabric-4.0.0-beta.7.tgz", + "integrity": "sha512-yV/DM2Cyk65E0kd4a2gWfhPA3p6VMDnC7EIe86p4nXeq360Dkru3JwRgdXJ5HwoY2r9n3Yqn/2roTMfS45G9fA==", + "requires": { + "canvas": "^2.6.1", + "jsdom": "^15.1.0" + }, + "dependencies": { + "cssom": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", + "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", + "optional": true + }, + "cssstyle": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.2.0.tgz", + "integrity": "sha512-sEb3XFPx3jNnCAMtqrXPDeSgQr+jojtCeNf8cvMNMh1cG970+lljssvQDzPq6lmmJu2Vhqood/gtEomBiHOGnA==", + "optional": true, + "requires": { + "cssom": "~0.3.6" + }, + "dependencies": { + "cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", + "optional": true + } + } + }, + "jsdom": { + "version": "15.2.1", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-15.2.1.tgz", + "integrity": "sha512-fAl1W0/7T2G5vURSyxBzrJ1LSdQn6Tr5UX/xD4PXDx/PDgwygedfW6El/KIj3xJ7FU61TTYnc/l/B7P49Eqt6g==", + "optional": true, + "requires": { + "abab": "^2.0.0", + "acorn": "^7.1.0", + "acorn-globals": "^4.3.2", + "array-equal": "^1.0.0", + "cssom": "^0.4.1", + "cssstyle": "^2.0.0", + "data-urls": "^1.1.0", + "domexception": "^1.0.1", + "escodegen": "^1.11.1", + "html-encoding-sniffer": "^1.0.2", + "nwsapi": "^2.2.0", + "parse5": "5.1.0", + "pn": "^1.1.0", + "request": "^2.88.0", + "request-promise-native": "^1.0.7", + "saxes": "^3.1.9", + "symbol-tree": "^3.2.2", + "tough-cookie": "^3.0.1", + "w3c-hr-time": "^1.0.1", + "w3c-xmlserializer": "^1.1.2", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^7.0.0", + "ws": "^7.0.0", + "xml-name-validator": "^3.0.0" + } + }, + "parse5": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.0.tgz", + "integrity": "sha512-fxNG2sQjHvlVAYmzBZS9YlDp6PTSSDwa98vkD4QgVDDCAo84z5X1t5XyJQ62ImdLXx5NdIIfihey6xpum9/gRQ==", + "optional": true + }, + "tough-cookie": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-3.0.1.tgz", + "integrity": "sha512-yQyJ0u4pZsv9D4clxO69OEjLWYw+jbgspjTue4lTQZLfV0c5l1VmK2y1JK8E9ahdpltPOaAThPcp5nKPUgSnsg==", + "optional": true, + "requires": { + "ip-regex": "^2.1.0", + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + }, + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "optional": true, + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "ws": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.1.tgz", + "integrity": "sha512-sucePNSafamSKoOqoNfBd8V0StlkzJKL2ZAhGQinCfNQ+oacw+Pk7lcdAElecBF2VkLNZRiIb5Oi1Q5lVUVt2A==", + "optional": true + } + } + }, + "fast-deep-equal": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/fast-deep-equal/-/fast-deep-equal-3.1.1.tgz", + "integrity": "sha512-8UEa58QDLauDNfpbrX55Q9jrGHThw2ZMdOky5Gl1CDtVeJDPVrG4Jxx1N8jw2gkWaff5UUuX1KJd+9zGe2B+ZA==" + }, + "fast-glob": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/fast-glob/-/fast-glob-2.2.7.tgz", + "integrity": "sha512-g1KuQwHOZAmOZMuBtHdxDtju+T2RT8jgCC9aANsbpdiDDTSnjgfuVsIBNKbUeJI3oKMRExcfNDtJl4OhbffMsw==", + "requires": { + "@mrmlnc/readdir-enhanced": "^2.2.1", + "@nodelib/fs.stat": "^1.1.2", + "glob-parent": "^3.1.0", + "is-glob": "^4.0.0", + "merge2": "^1.2.3", + "micromatch": "^3.1.10" + }, + "dependencies": { + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "requires": { + "is-extglob": "^2.1.0" + } + } + } + } + } + }, + "fast-json-stable-stringify": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fast-json-stable-stringify/-/fast-json-stable-stringify-2.1.0.tgz", + "integrity": "sha512-lhd/wF+Lk98HZoTCtlVraHtfh5XYijIjalXck7saUtuanSDyLMxnHhSXEDJqHxD7msR8D0uCmqlkwjCV8xvwHw==" + }, + "fast-levenshtein": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/fast-levenshtein/-/fast-levenshtein-2.0.6.tgz", + "integrity": "sha1-PYpcZog6FqMMqGQ+hR8Zuqd5eRc=" + }, + "faye-websocket": { + "version": "0.10.0", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.10.0.tgz", + "integrity": "sha1-TkkvjQTftviQA1B/btvy1QHnxvQ=", + "requires": { + "websocket-driver": ">=0.5.1" + } + }, + "fb-watchman": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/fb-watchman/-/fb-watchman-2.0.1.tgz", + "integrity": "sha512-DkPJKQeY6kKwmuMretBhr7G6Vodr7bFwDYTXIkfG1gjvNpaxBTQV3PbXg6bR1c1UP4jPOX0jHUbbHANL9vRjVg==", + "requires": { + "bser": "2.1.1" + } + }, + "figgy-pudding": { + "version": "3.5.1", + "resolved": "https://registry.npmjs.org/figgy-pudding/-/figgy-pudding-3.5.1.tgz", + "integrity": "sha512-vNKxJHTEKNThjfrdJwHc7brvM6eVevuO5nTj6ez8ZQ1qbXTvGthucRF7S4vf2cr71QVnT70V34v0S1DyQsti0w==" + }, + "figures": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/figures/-/figures-3.2.0.tgz", + "integrity": "sha512-yaduQFRKLXYOGgEn6AZau90j3ggSOyiqXU0F9JZfeXYhNa+Jk4X+s45A2zg5jns87GAFa34BBm2kXw4XpNcbdg==", + "requires": { + "escape-string-regexp": "^1.0.5" + } + }, + "file-entry-cache": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/file-entry-cache/-/file-entry-cache-5.0.1.tgz", + "integrity": "sha512-bCg29ictuBaKUwwArK4ouCaqDgLZcysCFLmM/Yn/FDoqndh/9vNuQfXRDvTuXKLxfD/JtZQGKFT8MGcJBK644g==", + "requires": { + "flat-cache": "^2.0.1" + } + }, + "file-loader": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/file-loader/-/file-loader-4.3.0.tgz", + "integrity": "sha512-aKrYPYjF1yG3oX0kWRrqrSMfgftm7oJW5M+m4owoldH5C51C0RkIwB++JbRvEW3IU6/ZG5n8UvEcdgwOt2UOWA==", + "requires": { + "loader-utils": "^1.2.3", + "schema-utils": "^2.5.0" + } + }, + "file-uri-to-path": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/file-uri-to-path/-/file-uri-to-path-1.0.0.tgz", + "integrity": "sha512-0Zt+s3L7Vf1biwWZ29aARiVYLx7iMGnEUl9x33fbB/j3jR81u/O2LbqK+Bm1CDSNDKVtJ/YjwY7TUd5SkeLQLw==", + "optional": true + }, + "filesize": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/filesize/-/filesize-6.0.1.tgz", + "integrity": "sha512-u4AYWPgbI5GBhs6id1KdImZWn5yfyFrrQ8OWZdN7ZMfA8Bf4HcO0BGo9bmUIEV8yrp8I1xVfJ/dn90GtFNNJcg==" + }, + "fill-range": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-4.0.0.tgz", + "integrity": "sha1-1USBHUKPmOsGpj3EAtJAPDKMOPc=", + "requires": { + "extend-shallow": "^2.0.1", + "is-number": "^3.0.0", + "repeat-string": "^1.6.1", + "to-regex-range": "^2.1.0" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "finalhandler": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.1.2.tgz", + "integrity": "sha512-aAWcW57uxVNrQZqFXjITpW3sIUQmHGG3qSb9mUah9MgMC4NeWhNOlNjXEYq3HjRAvL6arUviZGGJsBg6z0zsWA==", + "requires": { + "debug": "2.6.9", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "on-finished": "~2.3.0", + "parseurl": "~1.3.3", + "statuses": "~1.5.0", + "unpipe": "~1.0.0" + } + }, + "find-cache-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-2.1.0.tgz", + "integrity": "sha512-Tq6PixE0w/VMFfCgbONnkiQIVol/JJL7nRMi20fqzA4NRs9AfeqMGeRdPi3wIhYkxjeBaWh2rxwapn5Tu3IqOQ==", + "requires": { + "commondir": "^1.0.1", + "make-dir": "^2.0.0", + "pkg-dir": "^3.0.0" + } + }, + "find-up": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-3.0.0.tgz", + "integrity": "sha512-1yD6RmLI1XBfxugvORwlck6f75tYL+iR0jqwsOrOxMZyGYqUuDhJ0l4AXdO1iX/FTs9cBAMEk1gWSEx1kSbylg==", + "requires": { + "locate-path": "^3.0.0" + } + }, + "flat-cache": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flat-cache/-/flat-cache-2.0.1.tgz", + "integrity": "sha512-LoQe6yDuUMDzQAEH8sgmh4Md6oZnc/7PjtwjNFSzveXqSHt6ka9fPBuso7IGf9Rz4uqnSnWiFH2B/zj24a5ReA==", + "requires": { + "flatted": "^2.0.0", + "rimraf": "2.6.3", + "write": "1.0.3" + } + }, + "flatted": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/flatted/-/flatted-2.0.1.tgz", + "integrity": "sha512-a1hQMktqW9Nmqr5aktAux3JMNqaucxGcjtjWnZLHX7yyPCmlSV3M54nGYbqT8K+0GhF3NBgmJCc3ma+WOgX8Jg==" + }, + "flatten": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/flatten/-/flatten-1.0.3.tgz", + "integrity": "sha512-dVsPA/UwQ8+2uoFe5GHtiBMu48dWLTdsuEd7CKGlZlD78r1TTWBvDuFaFGKCo/ZfEr95Uk56vZoX86OsHkUeIg==" + }, + "flush-write-stream": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/flush-write-stream/-/flush-write-stream-1.1.1.tgz", + "integrity": "sha512-3Z4XhFZ3992uIq0XOqb9AreonueSYphE6oYbpt5+3u06JWklbsPkNv3ZKkP9Bz/r+1MWCaMoSQ28P85+1Yc77w==", + "requires": { + "inherits": "^2.0.3", + "readable-stream": "^2.3.6" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "follow-redirects": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/follow-redirects/-/follow-redirects-1.10.0.tgz", + "integrity": "sha512-4eyLK6s6lH32nOvLLwlIOnr9zrL8Sm+OvW4pVTJNoXeGzYIkHVf+pADQi+OJ0E67hiuSLezPVPyBcIZO50TmmQ==", + "requires": { + "debug": "^3.0.0" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "for-in": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-1.0.2.tgz", + "integrity": "sha1-gQaNKVqBQuwKxybG4iAMMPttXoA=" + }, + "for-own": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/for-own/-/for-own-0.1.5.tgz", + "integrity": "sha1-UmXGgaTylNq78XyVCbZ2OqhFEM4=", + "requires": { + "for-in": "^1.0.1" + } + }, + "forever-agent": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/forever-agent/-/forever-agent-0.6.1.tgz", + "integrity": "sha1-+8cfDEGt6zf5bFd60e1C2P2sypE=" + }, + "fork-ts-checker-webpack-plugin": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/fork-ts-checker-webpack-plugin/-/fork-ts-checker-webpack-plugin-3.1.1.tgz", + "integrity": "sha512-DuVkPNrM12jR41KM2e+N+styka0EgLkTnXmNcXdgOM37vtGeY+oCBK/Jx0hzSeEU6memFCtWb4htrHPMDfwwUQ==", + "requires": { + "babel-code-frame": "^6.22.0", + "chalk": "^2.4.1", + "chokidar": "^3.3.0", + "micromatch": "^3.1.10", + "minimatch": "^3.0.4", + "semver": "^5.6.0", + "tapable": "^1.0.0", + "worker-rpc": "^0.1.0" + } + }, + "form-data": { + "version": "2.3.3", + "resolved": "https://registry.npmjs.org/form-data/-/form-data-2.3.3.tgz", + "integrity": "sha512-1lLKB2Mu3aGP1Q/2eCOx0fNbRMe7XdwktwOruhfqqd0rIJWwN4Dh+E3hrPSlDCXnSR7UtZ1N38rVXm+6+MEhJQ==", + "requires": { + "asynckit": "^0.4.0", + "combined-stream": "^1.0.6", + "mime-types": "^2.1.12" + } + }, + "forwarded": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.1.2.tgz", + "integrity": "sha1-mMI9qxF1ZXuMBXPozszZGw/xjIQ=" + }, + "fragment-cache": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/fragment-cache/-/fragment-cache-0.2.1.tgz", + "integrity": "sha1-QpD60n8T6Jvn8zeZxrxaCr//DRk=", + "requires": { + "map-cache": "^0.2.2" + } + }, + "fresh": { + "version": "0.5.2", + "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", + "integrity": "sha1-PYyt2Q2XZWn6g1qx+OSyOhBWBac=" + }, + "from2": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/from2/-/from2-2.3.0.tgz", + "integrity": "sha1-i/tVAr3kpNNs/e6gB/zKIdfjgq8=", + "requires": { + "inherits": "^2.0.1", + "readable-stream": "^2.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "fs-extra": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-8.1.0.tgz", + "integrity": "sha512-yhlQgA6mnOJUKOsRUFsgJdQCvkKhcz8tlZG5HBQfReYZy46OwLcY+Zia0mtdHsOo9y/hP+CxMN0TU9QxoOtG4g==", + "requires": { + "graceful-fs": "^4.2.0", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + }, + "fs-minipass": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-2.1.0.tgz", + "integrity": "sha512-V/JgOLFCS+R6Vcq0slCuaeWEdNC3ouDlJMNIsacH2VtALiu9mV4LPrHc5cDl8k5aw6J8jwgWWpiTo5RYhmIzvg==", + "requires": { + "minipass": "^3.0.0" + } + }, + "fs-write-stream-atomic": { + "version": "1.0.10", + "resolved": "https://registry.npmjs.org/fs-write-stream-atomic/-/fs-write-stream-atomic-1.0.10.tgz", + "integrity": "sha1-tH31NJPvkR33VzHnCp3tAYnbQMk=", + "requires": { + "graceful-fs": "^4.1.2", + "iferr": "^0.1.5", + "imurmurhash": "^0.1.4", + "readable-stream": "1 || 2" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "fs.realpath": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/fs.realpath/-/fs.realpath-1.0.0.tgz", + "integrity": "sha1-FQStJSMVjKpA20onh8sBQRmU6k8=" + }, + "fsevents": { + "version": "1.2.11", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-1.2.11.tgz", + "integrity": "sha512-+ux3lx6peh0BpvY0JebGyZoiR4D+oYzdPZMKJwkZ+sFkNJzpL7tXc/wehS49gUAxg3tmMHPHZkA8JU2rhhgDHw==", + "optional": true, + "requires": { + "bindings": "^1.5.0", + "nan": "^2.12.1", + "node-pre-gyp": "*" + }, + "dependencies": { + "abbrev": { + "version": "1.1.1", + "bundled": true, + "optional": true + }, + "ansi-regex": { + "version": "2.1.1", + "bundled": true, + "optional": true + }, + "aproba": { + "version": "1.2.0", + "bundled": true, + "optional": true + }, + "are-we-there-yet": { + "version": "1.1.5", + "bundled": true, + "optional": true, + "requires": { + "delegates": "^1.0.0", + "readable-stream": "^2.0.6" + } + }, + "balanced-match": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "brace-expansion": { + "version": "1.1.11", + "bundled": true, + "optional": true, + "requires": { + "balanced-match": "^1.0.0", + "concat-map": "0.0.1" + } + }, + "chownr": { + "version": "1.1.3", + "bundled": true, + "optional": true + }, + "code-point-at": { + "version": "1.1.0", + "bundled": true, + "optional": true + }, + "concat-map": { + "version": "0.0.1", + "bundled": true, + "optional": true + }, + "console-control-strings": { + "version": "1.1.0", + "bundled": true, + "optional": true + }, + "core-util-is": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "debug": { + "version": "3.2.6", + "bundled": true, + "optional": true, + "requires": { + "ms": "^2.1.1" + } + }, + "deep-extend": { + "version": "0.6.0", + "bundled": true, + "optional": true + }, + "delegates": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "detect-libc": { + "version": "1.0.3", + "bundled": true, + "optional": true + }, + "fs-minipass": { + "version": "1.2.7", + "bundled": true, + "optional": true, + "requires": { + "minipass": "^2.6.0" + } + }, + "fs.realpath": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "gauge": { + "version": "2.7.4", + "bundled": true, + "optional": true, + "requires": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + } + }, + "glob": { + "version": "7.1.6", + "bundled": true, + "optional": true, + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "has-unicode": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "iconv-lite": { + "version": "0.4.24", + "bundled": true, + "optional": true, + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "ignore-walk": { + "version": "3.0.3", + "bundled": true, + "optional": true, + "requires": { + "minimatch": "^3.0.4" + } + }, + "inflight": { + "version": "1.0.6", + "bundled": true, + "optional": true, + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "bundled": true, + "optional": true + }, + "ini": { + "version": "1.3.5", + "bundled": true, + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "bundled": true, + "optional": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "isarray": { + "version": "1.0.0", + "bundled": true, + "optional": true + }, + "minimatch": { + "version": "3.0.4", + "bundled": true, + "optional": true, + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "0.0.8", + "bundled": true, + "optional": true + }, + "minipass": { + "version": "2.9.0", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "^5.1.2", + "yallist": "^3.0.0" + } + }, + "minizlib": { + "version": "1.3.3", + "bundled": true, + "optional": true, + "requires": { + "minipass": "^2.9.0" + } + }, + "mkdirp": { + "version": "0.5.1", + "bundled": true, + "optional": true, + "requires": { + "minimist": "0.0.8" + } + }, + "ms": { + "version": "2.1.2", + "bundled": true, + "optional": true + }, + "needle": { + "version": "2.4.0", + "bundled": true, + "optional": true, + "requires": { + "debug": "^3.2.6", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + } + }, + "node-pre-gyp": { + "version": "0.14.0", + "bundled": true, + "optional": true, + "requires": { + "detect-libc": "^1.0.2", + "mkdirp": "^0.5.1", + "needle": "^2.2.1", + "nopt": "^4.0.1", + "npm-packlist": "^1.1.6", + "npmlog": "^4.0.2", + "rc": "^1.2.7", + "rimraf": "^2.6.1", + "semver": "^5.3.0", + "tar": "^4.4.2" + } + }, + "nopt": { + "version": "4.0.1", + "bundled": true, + "optional": true, + "requires": { + "abbrev": "1", + "osenv": "^0.1.4" + } + }, + "npm-bundled": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "npm-normalize-package-bin": "^1.0.1" + } + }, + "npm-normalize-package-bin": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "npm-packlist": { + "version": "1.4.7", + "bundled": true, + "optional": true, + "requires": { + "ignore-walk": "^3.0.1", + "npm-bundled": "^1.0.1" + } + }, + "npmlog": { + "version": "4.1.2", + "bundled": true, + "optional": true, + "requires": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "number-is-nan": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "object-assign": { + "version": "4.1.1", + "bundled": true, + "optional": true + }, + "once": { + "version": "1.4.0", + "bundled": true, + "optional": true, + "requires": { + "wrappy": "1" + } + }, + "os-homedir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "os-tmpdir": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "osenv": { + "version": "0.1.5", + "bundled": true, + "optional": true, + "requires": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "path-is-absolute": { + "version": "1.0.1", + "bundled": true, + "optional": true + }, + "process-nextick-args": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "rc": { + "version": "1.2.8", + "bundled": true, + "optional": true, + "requires": { + "deep-extend": "^0.6.0", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "dependencies": { + "minimist": { + "version": "1.2.0", + "bundled": true, + "optional": true + } + } + }, + "readable-stream": { + "version": "2.3.6", + "bundled": true, + "optional": true, + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "rimraf": { + "version": "2.7.1", + "bundled": true, + "optional": true, + "requires": { + "glob": "^7.1.3" + } + }, + "safe-buffer": { + "version": "5.1.2", + "bundled": true, + "optional": true + }, + "safer-buffer": { + "version": "2.1.2", + "bundled": true, + "optional": true + }, + "sax": { + "version": "1.2.4", + "bundled": true, + "optional": true + }, + "semver": { + "version": "5.7.1", + "bundled": true, + "optional": true + }, + "set-blocking": { + "version": "2.0.0", + "bundled": true, + "optional": true + }, + "signal-exit": { + "version": "3.0.2", + "bundled": true, + "optional": true + }, + "string-width": { + "version": "1.0.2", + "bundled": true, + "optional": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "string_decoder": { + "version": "1.1.1", + "bundled": true, + "optional": true, + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "bundled": true, + "optional": true, + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "strip-json-comments": { + "version": "2.0.1", + "bundled": true, + "optional": true + }, + "tar": { + "version": "4.4.13", + "bundled": true, + "optional": true, + "requires": { + "chownr": "^1.1.1", + "fs-minipass": "^1.2.5", + "minipass": "^2.8.6", + "minizlib": "^1.2.1", + "mkdirp": "^0.5.0", + "safe-buffer": "^5.1.2", + "yallist": "^3.0.3" + } + }, + "util-deprecate": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "wide-align": { + "version": "1.1.3", + "bundled": true, + "optional": true, + "requires": { + "string-width": "^1.0.2 || 2" + } + }, + "wrappy": { + "version": "1.0.2", + "bundled": true, + "optional": true + }, + "yallist": { + "version": "3.1.1", + "bundled": true, + "optional": true + } + } + }, + "function-bind": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.1.tgz", + "integrity": "sha512-yIovAzMX49sF8Yl58fSCWJ5svSLuaibPxXQJFLmBObTuCr0Mf1KiPopGM9NiFjiYBCbfaa2Fh6breQ6ANVTI0A==" + }, + "functional-red-black-tree": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/functional-red-black-tree/-/functional-red-black-tree-1.0.1.tgz", + "integrity": "sha1-GwqzvVU7Kg1jmdKcDj6gslIHgyc=" + }, + "gauge": { + "version": "2.7.4", + "resolved": "https://registry.npmjs.org/gauge/-/gauge-2.7.4.tgz", + "integrity": "sha1-LANAXHU4w51+s3sxcCLjJfsBi/c=", + "optional": true, + "requires": { + "aproba": "^1.0.3", + "console-control-strings": "^1.0.0", + "has-unicode": "^2.0.0", + "object-assign": "^4.1.0", + "signal-exit": "^3.0.0", + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1", + "wide-align": "^1.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=", + "optional": true + }, + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "optional": true, + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "optional": true, + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "optional": true, + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "gensync": { + "version": "1.0.0-beta.1", + "resolved": "https://registry.npmjs.org/gensync/-/gensync-1.0.0-beta.1.tgz", + "integrity": "sha512-r8EC6NO1sngH/zdD9fiRDLdcgnbayXah+mLgManTaIZJqEC1MZstmnox8KpnI2/fxQwrp5OpCOYWLp4rBl4Jcg==" + }, + "get-caller-file": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-2.0.5.tgz", + "integrity": "sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==" + }, + "get-own-enumerable-property-symbols": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/get-own-enumerable-property-symbols/-/get-own-enumerable-property-symbols-3.0.2.tgz", + "integrity": "sha512-I0UBV/XOz1XkIJHEUDMZAbzCThU/H8DxmSfmdGcKPnVhu2VfFqr34jr9777IyaTYvxjedWhqVIilEDsCdP5G6g==" + }, + "get-stream": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/get-stream/-/get-stream-4.1.0.tgz", + "integrity": "sha512-GMat4EJ5161kIy2HevLlr4luNjBgvmj413KaQA7jt4V8B4RDsfpHk7WQ9GVqfYyyx8OS/L66Kox+rJRNklLK7w==", + "requires": { + "pump": "^3.0.0" + } + }, + "get-value": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/get-value/-/get-value-2.0.6.tgz", + "integrity": "sha1-3BXKHGcjh8p2vTesCjlbogQqLCg=" + }, + "getpass": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/getpass/-/getpass-0.1.7.tgz", + "integrity": "sha1-Xv+OPmhNVprkyysSgmBOi6YhSfo=", + "requires": { + "assert-plus": "^1.0.0" + } + }, + "glob": { + "version": "7.1.6", + "resolved": "https://registry.npmjs.org/glob/-/glob-7.1.6.tgz", + "integrity": "sha512-LwaxwyZ72Lk7vZINtNNrywX0ZuLyStrdDtabefZKAY5ZGJhVtgdznluResxNmPitE0SAO+O26sWTHeKSI2wMBA==", + "requires": { + "fs.realpath": "^1.0.0", + "inflight": "^1.0.4", + "inherits": "2", + "minimatch": "^3.0.4", + "once": "^1.3.0", + "path-is-absolute": "^1.0.0" + } + }, + "glob-parent": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.0.tgz", + "integrity": "sha512-qjtRgnIVmOfnKUE3NJAQEdk+lKrxfw8t5ke7SXtfMTHcjsBfOfWXCQfdb30zfDoZQ2IRSIiidmjtbHZPZ++Ihw==", + "requires": { + "is-glob": "^4.0.1" + } + }, + "glob-to-regexp": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/glob-to-regexp/-/glob-to-regexp-0.3.0.tgz", + "integrity": "sha1-jFoUlNIGbFcMw7/kSWF1rMTVAqs=" + }, + "global-modules": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/global-modules/-/global-modules-2.0.0.tgz", + "integrity": "sha512-NGbfmJBp9x8IxyJSd1P+otYK8vonoJactOogrVfFRIAEY1ukil8RSKDz2Yo7wh1oihl51l/r6W4epkeKJHqL8A==", + "requires": { + "global-prefix": "^3.0.0" + } + }, + "global-prefix": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/global-prefix/-/global-prefix-3.0.0.tgz", + "integrity": "sha512-awConJSVCHVGND6x3tmMaKcQvwXLhjdkmomy2W+Goaui8YPgYgXJZewhg3fWC+DlfqqQuWg8AwqjGTD2nAPVWg==", + "requires": { + "ini": "^1.3.5", + "kind-of": "^6.0.2", + "which": "^1.3.1" + }, + "dependencies": { + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "globals": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/globals/-/globals-11.12.0.tgz", + "integrity": "sha512-WOBp/EEGUiIsJSp7wcv/y6MO+lV9UoncWqxuFfm8eBwzWNgyfBd6Gz+IeKQ9jCmyhoH99g15M3T+QaVHFjizVA==" + }, + "globby": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/globby/-/globby-8.0.2.tgz", + "integrity": "sha512-yTzMmKygLp8RUpG1Ymu2VXPSJQZjNAZPD4ywgYEaG7e4tBJeUQBO8OpXrf1RCNcEs5alsoJYPAMiIHP0cmeC7w==", + "requires": { + "array-union": "^1.0.1", + "dir-glob": "2.0.0", + "fast-glob": "^2.0.2", + "glob": "^7.1.2", + "ignore": "^3.3.5", + "pify": "^3.0.0", + "slash": "^1.0.0" + }, + "dependencies": { + "ignore": { + "version": "3.3.10", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-3.3.10.tgz", + "integrity": "sha512-Pgs951kaMm5GXP7MOvxERINe3gsaVjUWFm+UZPSq9xYriQAksyhg0csnS0KXSNRD5NmNdapXEpjxG49+AKh/ug==" + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + }, + "slash": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-1.0.0.tgz", + "integrity": "sha1-xB8vbDn8FtHNF61LXYlhFK5HDVU=" + } + } + }, + "graceful-fs": { + "version": "4.2.3", + "resolved": "https://registry.npmjs.org/graceful-fs/-/graceful-fs-4.2.3.tgz", + "integrity": "sha512-a30VEBm4PEdx1dRB7MFK7BejejvCvBronbLjht+sHuGYj8PHs7M/5Z+rt5lw551vZ7yfTCj4Vuyy3mSJytDWRQ==" + }, + "growly": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/growly/-/growly-1.3.0.tgz", + "integrity": "sha1-8QdIy+dq+WS3yWyTxrzCivEgwIE=" + }, + "gzip-size": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/gzip-size/-/gzip-size-5.1.1.tgz", + "integrity": "sha512-FNHi6mmoHvs1mxZAds4PpdCS6QG8B4C1krxJsMutgxl5t3+GlRTzzI3NEkifXx2pVsOvJdOGSmIgDhQ55FwdPA==", + "requires": { + "duplexer": "^0.1.1", + "pify": "^4.0.1" + } + }, + "handle-thing": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/handle-thing/-/handle-thing-2.0.0.tgz", + "integrity": "sha512-d4sze1JNC454Wdo2fkuyzCr6aHcbL6PGGuFAz0Li/NcOm1tCHGnWDRmJP85dh9IhQErTc2svWFEX5xHIOo//kQ==" + }, + "har-schema": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/har-schema/-/har-schema-2.0.0.tgz", + "integrity": "sha1-qUwiJOvKwEeCoNkDVSHyRzW37JI=" + }, + "har-validator": { + "version": "5.1.3", + "resolved": "https://registry.npmjs.org/har-validator/-/har-validator-5.1.3.tgz", + "integrity": "sha512-sNvOCzEQNr/qrvJgc3UG/kD4QtlHycrzwS+6mfTrrSq97BvaYcPZZI1ZSqGSPR73Cxn4LKTD4PttRwfU7jWq5g==", + "requires": { + "ajv": "^6.5.5", + "har-schema": "^2.0.0" + } + }, + "harmony-reflect": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/harmony-reflect/-/harmony-reflect-1.6.1.tgz", + "integrity": "sha512-WJTeyp0JzGtHcuMsi7rw2VwtkvLa+JyfEKJCFyfcS0+CDkjQ5lHPu7zEhFZP+PDSRrEgXa5Ah0l1MbgbE41XjA==" + }, + "has": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/has/-/has-1.0.3.tgz", + "integrity": "sha512-f2dvO0VU6Oej7RkWJGrehjbzMAjFp5/VKPp5tTpWIV4JHHZK1/BxbFRtf/siA2SWTe09caDmVtYYzWEIbBS4zw==", + "requires": { + "function-bind": "^1.1.1" + } + }, + "has-ansi": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/has-ansi/-/has-ansi-2.0.0.tgz", + "integrity": "sha1-NPUEnOHs3ysGSa8+8k5F7TVBbZE=", + "requires": { + "ansi-regex": "^2.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + } + } + }, + "has-flag": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", + "integrity": "sha1-tdRU3CGZriJWmfNGfloH87lVuv0=" + }, + "has-symbols": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.1.tgz", + "integrity": "sha512-PLcsoqu++dmEIZB+6totNFKq/7Do+Z0u4oT0zKOJNl3lYK6vGwwu2hjHs+68OEZbTjiUE9bgOABXbP/GvrS0Kg==" + }, + "has-unicode": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/has-unicode/-/has-unicode-2.0.1.tgz", + "integrity": "sha1-4Ob+aijPUROIVeCG0Wkedx3iqLk=", + "optional": true + }, + "has-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-1.0.0.tgz", + "integrity": "sha1-GLKB2lhbHFxR3vJMkw7SmgvmsXc=", + "requires": { + "get-value": "^2.0.6", + "has-values": "^1.0.0", + "isobject": "^3.0.0" + } + }, + "has-values": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-1.0.0.tgz", + "integrity": "sha1-lbC2P+whRmGab+V/51Yo1aOe/k8=", + "requires": { + "is-number": "^3.0.0", + "kind-of": "^4.0.0" + }, + "dependencies": { + "kind-of": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-4.0.0.tgz", + "integrity": "sha1-IIE989cSkosgc3hpGkUGb65y3Vc=", + "requires": { + "is-buffer": "^1.1.5" + } + } + } + }, + "hash-base": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/hash-base/-/hash-base-3.0.4.tgz", + "integrity": "sha1-X8hoaEfs1zSZQDMZprCj8/auSRg=", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "hash.js": { + "version": "1.1.7", + "resolved": "https://registry.npmjs.org/hash.js/-/hash.js-1.1.7.tgz", + "integrity": "sha512-taOaskGt4z4SOANNseOviYDvjEJinIkRgmp7LbKP2YTTmVxWBl87s/uzK9r+44BclBSp2X7K1hqeNfz9JbBeXA==", + "requires": { + "inherits": "^2.0.3", + "minimalistic-assert": "^1.0.1" + } + }, + "he": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/he/-/he-1.2.0.tgz", + "integrity": "sha512-F/1DnUGPopORZi0ni+CvrCgHQ5FyEAHRLSApuYWMmrbSwoN2Mn/7k+Gl38gJnR7yyDZk6WLXwiGod1JOWNDKGw==" + }, + "hex-color-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/hex-color-regex/-/hex-color-regex-1.1.0.tgz", + "integrity": "sha512-l9sfDFsuqtOqKDsQdqrMRk0U85RZc0RtOR9yPI7mRVOa4FsR/BVnZ0shmQRM96Ji99kYZP/7hn1cedc1+ApsTQ==" + }, + "hmac-drbg": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/hmac-drbg/-/hmac-drbg-1.0.1.tgz", + "integrity": "sha1-0nRXAQJabHdabFRXk+1QL8DGSaE=", + "requires": { + "hash.js": "^1.0.3", + "minimalistic-assert": "^1.0.0", + "minimalistic-crypto-utils": "^1.0.1" + } + }, + "hosted-git-info": { + "version": "2.8.5", + "resolved": "https://registry.npmjs.org/hosted-git-info/-/hosted-git-info-2.8.5.tgz", + "integrity": "sha512-kssjab8CvdXfcXMXVcvsXum4Hwdq9XGtRD3TteMEvEbq0LXyiNQr6AprqKqfeaDXze7SxWvRxdpwE6ku7ikLkg==" + }, + "hpack.js": { + "version": "2.1.6", + "resolved": "https://registry.npmjs.org/hpack.js/-/hpack.js-2.1.6.tgz", + "integrity": "sha1-h3dMCUnlE/QuhFdbPEVoH63ioLI=", + "requires": { + "inherits": "^2.0.1", + "obuf": "^1.0.0", + "readable-stream": "^2.0.1", + "wbuf": "^1.1.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "hsl-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsl-regex/-/hsl-regex-1.0.0.tgz", + "integrity": "sha1-1JMwx4ntgZ4nakwNJy3/owsY/m4=" + }, + "hsla-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/hsla-regex/-/hsla-regex-1.0.0.tgz", + "integrity": "sha1-wc56MWjIxmFAM6S194d/OyJfnDg=" + }, + "html-comment-regex": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/html-comment-regex/-/html-comment-regex-1.1.2.tgz", + "integrity": "sha512-P+M65QY2JQ5Y0G9KKdlDpo0zK+/OHptU5AaBwUfAIDJZk1MYf32Frm84EcOytfJE0t5JvkAnKlmjsXDnWzCJmQ==" + }, + "html-encoding-sniffer": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/html-encoding-sniffer/-/html-encoding-sniffer-1.0.2.tgz", + "integrity": "sha512-71lZziiDnsuabfdYiUeWdCVyKuqwWi23L8YeIgV9jSSZHCtb6wB1BKWooH7L3tn4/FuZJMVWyNaIDr4RGmaSYw==", + "requires": { + "whatwg-encoding": "^1.0.1" + } + }, + "html-entities": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/html-entities/-/html-entities-1.2.1.tgz", + "integrity": "sha1-DfKTUfByEWNRXfueVUPl9u7VFi8=" + }, + "html-escaper": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/html-escaper/-/html-escaper-2.0.0.tgz", + "integrity": "sha512-a4u9BeERWGu/S8JiWEAQcdrg9v4QArtP9keViQjGMdff20fBdd8waotXaNmODqBe6uZ3Nafi7K/ho4gCQHV3Ig==" + }, + "html-minifier-terser": { + "version": "5.0.4", + "resolved": "https://registry.npmjs.org/html-minifier-terser/-/html-minifier-terser-5.0.4.tgz", + "integrity": "sha512-fHwmKQ+GzhlqdxEtwrqLT7MSuheiA+rif5/dZgbz3GjoMXJzcRzy1L9NXoiiyxrnap+q5guSiv8Tz5lrh9g42g==", + "requires": { + "camel-case": "^4.1.1", + "clean-css": "^4.2.3", + "commander": "^4.1.1", + "he": "^1.2.0", + "param-case": "^3.0.3", + "relateurl": "^0.2.7", + "terser": "^4.6.3" + }, + "dependencies": { + "commander": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/commander/-/commander-4.1.1.tgz", + "integrity": "sha512-NOKm8xhkzAjzFx8B2v5OAHT+u5pRQc2UCa2Vq9jYL/31o2wi9mxBA7LIFs3sV5VSC49z6pEhfbMULvShKj26WA==" + } + } + }, + "html-webpack-plugin": { + "version": "4.0.0-beta.11", + "resolved": "https://registry.npmjs.org/html-webpack-plugin/-/html-webpack-plugin-4.0.0-beta.11.tgz", + "integrity": "sha512-4Xzepf0qWxf8CGg7/WQM5qBB2Lc/NFI7MhU59eUDTkuQp3skZczH4UA1d6oQyDEIoMDgERVhRyTdtUPZ5s5HBg==", + "requires": { + "html-minifier-terser": "^5.0.1", + "loader-utils": "^1.2.3", + "lodash": "^4.17.15", + "pretty-error": "^2.1.1", + "tapable": "^1.1.3", + "util.promisify": "1.0.0" + }, + "dependencies": { + "util.promisify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.0.tgz", + "integrity": "sha512-i+6qA2MPhvoKLuxnJNpXAGhg7HphQOSUq2LKMZD0m15EiskXUkMvKdF4Uui0WYeCUGea+o2cw/ZuwehtfsrNkA==", + "requires": { + "define-properties": "^1.1.2", + "object.getownpropertydescriptors": "^2.0.3" + } + } + } + }, + "htmlparser2": { + "version": "3.10.1", + "resolved": "https://registry.npmjs.org/htmlparser2/-/htmlparser2-3.10.1.tgz", + "integrity": "sha512-IgieNijUMbkDovyoKObU1DUhm1iwNYE/fuifEoEHfd1oZKZDaONBSkal7Y01shxsM49R4XaMdGez3WnF9UfiCQ==", + "requires": { + "domelementtype": "^1.3.1", + "domhandler": "^2.3.0", + "domutils": "^1.5.1", + "entities": "^1.1.1", + "inherits": "^2.0.1", + "readable-stream": "^3.1.1" + }, + "dependencies": { + "entities": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/entities/-/entities-1.1.2.tgz", + "integrity": "sha512-f2LZMYl1Fzu7YSBKg+RoROelpOaNrcGmE9AZubeDfrCEia483oW4MI4VyFd5VNHIgQ/7qm1I0wUHK1eJnn2y2w==" + } + } + }, + "http-deceiver": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/http-deceiver/-/http-deceiver-1.2.7.tgz", + "integrity": "sha1-+nFolEq5pRnTN8sL7HKE3D5yPYc=" + }, + "http-errors": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.7.2.tgz", + "integrity": "sha512-uUQBt3H/cSIVfch6i1EuPNy/YsRSOUBXTVfZ+yR7Zjez3qjBz6i9+i4zjNaoqcoFVI4lQJ5plg63TvGfRSDCRg==", + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.1", + "statuses": ">= 1.5.0 < 2", + "toidentifier": "1.0.0" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + } + } + }, + "http-parser-js": { + "version": "0.4.10", + "resolved": "https://registry.npmjs.org/http-parser-js/-/http-parser-js-0.4.10.tgz", + "integrity": "sha1-ksnBN0w1CF912zWexWzCV8u5P6Q=" + }, + "http-proxy": { + "version": "1.18.0", + "resolved": "https://registry.npmjs.org/http-proxy/-/http-proxy-1.18.0.tgz", + "integrity": "sha512-84I2iJM/n1d4Hdgc6y2+qY5mDaz2PUVjlg9znE9byl+q0uC3DeByqBGReQu5tpLK0TAqTIXScRUV+dg7+bUPpQ==", + "requires": { + "eventemitter3": "^4.0.0", + "follow-redirects": "^1.0.0", + "requires-port": "^1.0.0" + } + }, + "http-proxy-middleware": { + "version": "0.19.1", + "resolved": "https://registry.npmjs.org/http-proxy-middleware/-/http-proxy-middleware-0.19.1.tgz", + "integrity": "sha512-yHYTgWMQO8VvwNS22eLLloAkvungsKdKTLO8AJlftYIKNfJr3GK3zK0ZCfzDDGUBttdGc8xFy1mCitvNKQtC3Q==", + "requires": { + "http-proxy": "^1.17.0", + "is-glob": "^4.0.0", + "lodash": "^4.17.11", + "micromatch": "^3.1.10" + } + }, + "http-signature": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/http-signature/-/http-signature-1.2.0.tgz", + "integrity": "sha1-muzZJRFHcvPZW2WmCruPfBj7rOE=", + "requires": { + "assert-plus": "^1.0.0", + "jsprim": "^1.2.2", + "sshpk": "^1.7.0" + } + }, + "https-browserify": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/https-browserify/-/https-browserify-1.0.0.tgz", + "integrity": "sha1-7AbBDgo0wPL68Zn3/X/Hj//QPHM=" + }, + "iconv-lite": { + "version": "0.4.24", + "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", + "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", + "requires": { + "safer-buffer": ">= 2.1.2 < 3" + } + }, + "icss-utils": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/icss-utils/-/icss-utils-4.1.1.tgz", + "integrity": "sha512-4aFq7wvWyMHKgxsH8QQtGpvbASCf+eM3wPRLI6R+MgAnTCZ6STYsRvttLvRWK0Nfif5piF394St3HeJDaljGPA==", + "requires": { + "postcss": "^7.0.14" + } + }, + "identity-obj-proxy": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/identity-obj-proxy/-/identity-obj-proxy-3.0.0.tgz", + "integrity": "sha1-lNK9qWCERT7zb7xarsN+D3nx/BQ=", + "requires": { + "harmony-reflect": "^1.4.6" + } + }, + "ieee754": { + "version": "1.1.13", + "resolved": "https://registry.npmjs.org/ieee754/-/ieee754-1.1.13.tgz", + "integrity": "sha512-4vf7I2LYV/HaWerSo3XmlMkp5eZ83i+/CDluXi/IGTs/O1sejBNhTtnxzmRZfvOUqj7lZjqHkeTvpgSFDlWZTg==" + }, + "iferr": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/iferr/-/iferr-0.1.5.tgz", + "integrity": "sha1-xg7taebY/bazEEofy8ocGS3FtQE=" + }, + "ignore": { + "version": "4.0.6", + "resolved": "https://registry.npmjs.org/ignore/-/ignore-4.0.6.tgz", + "integrity": "sha512-cyFDKrqc/YdcWFniJhzI42+AzS+gNwmUzOSFcRCQYwySuBBBy/KjuxWLZ/FHEH6Moq1NizMOBWyTcv8O4OZIMg==" + }, + "ignore-walk": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/ignore-walk/-/ignore-walk-3.0.3.tgz", + "integrity": "sha512-m7o6xuOaT1aqheYHKf8W6J5pYH85ZI9w077erOzLje3JsB1gkafkAhHHY19dqjulgIZHFm32Cp5uNZgcQqdJKw==", + "optional": true, + "requires": { + "minimatch": "^3.0.4" + } + }, + "immer": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/immer/-/immer-1.10.0.tgz", + "integrity": "sha512-O3sR1/opvCDGLEVcvrGTMtLac8GJ5IwZC4puPrLuRj3l7ICKvkmA0vGuU9OW8mV9WIBRnaxp5GJh9IEAaNOoYg==" + }, + "import-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-cwd/-/import-cwd-2.1.0.tgz", + "integrity": "sha1-qmzzbnInYShcs3HsZRn1PiQ1sKk=", + "requires": { + "import-from": "^2.1.0" + } + }, + "import-fresh": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-fresh/-/import-fresh-2.0.0.tgz", + "integrity": "sha1-2BNVwVYS04bGH53dOSLUMEgipUY=", + "requires": { + "caller-path": "^2.0.0", + "resolve-from": "^3.0.0" + } + }, + "import-from": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/import-from/-/import-from-2.1.0.tgz", + "integrity": "sha1-M1238qev/VOqpHHUuAId7ja387E=", + "requires": { + "resolve-from": "^3.0.0" + } + }, + "import-local": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/import-local/-/import-local-2.0.0.tgz", + "integrity": "sha512-b6s04m3O+s3CGSbqDIyP4R6aAwAeYlVq9+WUWep6iHa8ETRf9yei1U48C5MmfJmV9AiLYYBKPMq/W+/WRpQmCQ==", + "requires": { + "pkg-dir": "^3.0.0", + "resolve-cwd": "^2.0.0" + } + }, + "imurmurhash": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/imurmurhash/-/imurmurhash-0.1.4.tgz", + "integrity": "sha1-khi5srkoojixPcT7a21XbyMUU+o=" + }, + "indent-string": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/indent-string/-/indent-string-4.0.0.tgz", + "integrity": "sha512-EdDDZu4A2OyIK7Lr/2zG+w5jmbuk1DVBnEwREQvBzspBJkCEbRa8GxU1lghYcaGJCnRWibjDXlq779X1/y5xwg==" + }, + "indexes-of": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/indexes-of/-/indexes-of-1.0.1.tgz", + "integrity": "sha1-8w9xbI4r00bHtn0985FVZqfAVgc=" + }, + "infer-owner": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/infer-owner/-/infer-owner-1.0.4.tgz", + "integrity": "sha512-IClj+Xz94+d7irH5qRyfJonOdfTzuDaifE6ZPWfx0N0+/ATZCbuTPq2prFl526urkQd90WyUKIh1DfBQ2hMz9A==" + }, + "inflight": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/inflight/-/inflight-1.0.6.tgz", + "integrity": "sha1-Sb1jMdfQLQwJvJEKEHW6gWW1bfk=", + "requires": { + "once": "^1.3.0", + "wrappy": "1" + } + }, + "inherits": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", + "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" + }, + "ini": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/ini/-/ini-1.3.5.tgz", + "integrity": "sha512-RZY5huIKCMRWDUqZlEi72f/lmXKMvuszcMBduliQ3nnWbx9X/ZBQO7DijMEYS9EhHBb2qacRUMtC7svLwe0lcw==" + }, + "inquirer": { + "version": "7.0.4", + "resolved": "https://registry.npmjs.org/inquirer/-/inquirer-7.0.4.tgz", + "integrity": "sha512-Bu5Td5+j11sCkqfqmUTiwv+tWisMtP0L7Q8WrqA2C/BbBhy1YTdFrvjjlrKq8oagA/tLQBski2Gcx/Sqyi2qSQ==", + "requires": { + "ansi-escapes": "^4.2.1", + "chalk": "^2.4.2", + "cli-cursor": "^3.1.0", + "cli-width": "^2.0.0", + "external-editor": "^3.0.3", + "figures": "^3.0.0", + "lodash": "^4.17.15", + "mute-stream": "0.0.8", + "run-async": "^2.2.0", + "rxjs": "^6.5.3", + "string-width": "^4.1.0", + "strip-ansi": "^5.1.0", + "through": "^2.3.6" + } + }, + "internal-ip": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/internal-ip/-/internal-ip-4.3.0.tgz", + "integrity": "sha512-S1zBo1D6zcsyuC6PMmY5+55YMILQ9av8lotMx447Bq6SAgo/sDK6y6uUKmuYhW7eacnIhFfsPmCNYdDzsnnDCg==", + "requires": { + "default-gateway": "^4.2.0", + "ipaddr.js": "^1.9.0" + } + }, + "invariant": { + "version": "2.2.4", + "resolved": "https://registry.npmjs.org/invariant/-/invariant-2.2.4.tgz", + "integrity": "sha512-phJfQVBuaJM5raOpJjSfkiD6BpbCE4Ns//LaXl6wGYtUBY83nWS6Rf9tXm2e8VaK60JEjYldbPif/A2B1C2gNA==", + "requires": { + "loose-envify": "^1.0.0" + } + }, + "invert-kv": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/invert-kv/-/invert-kv-2.0.0.tgz", + "integrity": "sha512-wPVv/y/QQ/Uiirj/vh3oP+1Ww+AWehmi1g5fFWGPF6IpCBCDVrhgHRMvrLfdYcwDh3QJbGXDW4JAuzxElLSqKA==" + }, + "ip": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/ip/-/ip-1.1.5.tgz", + "integrity": "sha1-vd7XARQpCCjAoDnnLvJfWq7ENUo=" + }, + "ip-regex": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/ip-regex/-/ip-regex-2.1.0.tgz", + "integrity": "sha1-+ni/XS5pE8kRzp+BnuUUa7bYROk=" + }, + "ipaddr.js": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", + "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==" + }, + "is-absolute-url": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-2.1.0.tgz", + "integrity": "sha1-UFMN+4T8yap9vnhS6Do3uTufKqY=" + }, + "is-accessor-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-0.1.6.tgz", + "integrity": "sha1-qeEss66Nh2cn7u84Q/igiXtcmNY=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-arguments": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/is-arguments/-/is-arguments-1.0.4.tgz", + "integrity": "sha512-xPh0Rmt8NE65sNzvyUmWgI1tz3mKq74lGA0mL8LYZcoIzKOzDh6HmrYm3d18k60nHerC8A9Km8kYu87zfSFnLA==" + }, + "is-arrayish": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.2.1.tgz", + "integrity": "sha1-d8mYQFJ6qOyxqLppe4BkWnqSap0=" + }, + "is-binary-path": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", + "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", + "requires": { + "binary-extensions": "^2.0.0" + } + }, + "is-buffer": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/is-buffer/-/is-buffer-1.1.6.tgz", + "integrity": "sha512-NcdALwpXkTm5Zvvbk7owOUSvVvBKDgKP5/ewfXEznmQFfs4ZRmanOeKBTjRVjka3QFoN6XJ+9F3USqfHqTaU5w==" + }, + "is-callable": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/is-callable/-/is-callable-1.1.5.tgz", + "integrity": "sha512-ESKv5sMCJB2jnHTWZ3O5itG+O128Hsus4K4Qh1h2/cgn2vbgnLSVqfV46AeJA9D5EeeLa9w81KUXMtn34zhX+Q==" + }, + "is-ci": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-ci/-/is-ci-2.0.0.tgz", + "integrity": "sha512-YfJT7rkpQB0updsdHLGWrvhBJfcfzNNawYDNIyQXJz0IViGf75O8EBPKSdvw2rF+LGCsX4FZ8tcr3b19LcZq4w==", + "requires": { + "ci-info": "^2.0.0" + } + }, + "is-color-stop": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-color-stop/-/is-color-stop-1.1.0.tgz", + "integrity": "sha1-z/9HGu5N1cnhWFmPvhKWe1za00U=", + "requires": { + "css-color-names": "^0.0.4", + "hex-color-regex": "^1.1.0", + "hsl-regex": "^1.0.0", + "hsla-regex": "^1.0.0", + "rgb-regex": "^1.0.1", + "rgba-regex": "^1.0.0" + } + }, + "is-data-descriptor": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-0.1.4.tgz", + "integrity": "sha1-C17mSDiOLIYCgueT8YVv7D8wG1Y=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-date-object": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-date-object/-/is-date-object-1.0.2.tgz", + "integrity": "sha512-USlDT524woQ08aoZFzh3/Z6ch9Y/EWXEHQ/AaRN0SkKq4t2Jw2R2339tSXmwuVoY7LLlBCbOIlx2myP/L5zk0g==" + }, + "is-descriptor": { + "version": "0.1.6", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-0.1.6.tgz", + "integrity": "sha512-avDYr0SB3DwO9zsMov0gKCESFYqCnE4hq/4z3TdUlukEy5t9C0YRq7HLrsN52NAcqXKaepeCD0n+B0arnVG3Hg==", + "requires": { + "is-accessor-descriptor": "^0.1.6", + "is-data-descriptor": "^0.1.4", + "kind-of": "^5.0.0" + }, + "dependencies": { + "kind-of": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-5.1.0.tgz", + "integrity": "sha512-NGEErnH6F2vUuXDh+OlbcKW7/wOcfdRHaZ7VWtqCztfHri/++YKmP51OdWeGPuqCOba6kk2OTe5d02VmTB80Pw==" + } + } + }, + "is-directory": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/is-directory/-/is-directory-0.3.1.tgz", + "integrity": "sha1-YTObbyR1/Hcv2cnYP1yFddwVSuE=" + }, + "is-docker": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-docker/-/is-docker-2.0.0.tgz", + "integrity": "sha512-pJEdRugimx4fBMra5z2/5iRdZ63OhYV0vr0Dwm5+xtW4D1FvRkB8hamMIhnWfyJeDdyr/aa7BDyNbtG38VxgoQ==" + }, + "is-extendable": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-0.1.1.tgz", + "integrity": "sha1-YrEQ4omkcUGOPsNqYX1HLjAd/Ik=" + }, + "is-extglob": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", + "integrity": "sha1-qIwCU1eR8C7TfHahueqXc8gz+MI=" + }, + "is-fullwidth-code-point": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-3.0.0.tgz", + "integrity": "sha512-zymm5+u+sCsSWyD9qNaejV3DFvhCKclKdizYaJUuHA83RLjb7nSuGnddCHGv0hk+KY7BMAlsWeK4Ueg6EV6XQg==" + }, + "is-generator-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-generator-fn/-/is-generator-fn-2.1.0.tgz", + "integrity": "sha512-cTIB4yPYL/Grw0EaSzASzg6bBy9gqCofvWN8okThAYIxKJZC+udlRAmGbM0XLeniEJSs8uEgHPGuHSe1XsOLSQ==" + }, + "is-glob": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.1.tgz", + "integrity": "sha512-5G0tKtBTFImOqDnLB2hG6Bp2qcKEFduo4tZu9MT/H6NQv/ghhy30o55ufafxJ/LdH79LLs2Kfrn85TLKyA7BUg==", + "requires": { + "is-extglob": "^2.1.1" + } + }, + "is-number": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-number/-/is-number-3.0.0.tgz", + "integrity": "sha1-JP1iAaR4LPUFYcgQJ2r8fRLXEZU=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "is-obj": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-2.0.0.tgz", + "integrity": "sha512-drqDG3cbczxxEJRoOXcOjtdp1J/lyp1mNn0xaznRs8+muBhgQcrnbspox5X5fOw0HnMnbfDzvnEMEtqDEJEo8w==" + }, + "is-path-cwd": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/is-path-cwd/-/is-path-cwd-2.2.0.tgz", + "integrity": "sha512-w942bTcih8fdJPJmQHFzkS76NEP8Kzzvmw92cXsazb8intwLqPibPPdXf4ANdKV3rYMuuQYGIWtvz9JilB3NFQ==" + }, + "is-path-in-cwd": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-in-cwd/-/is-path-in-cwd-2.1.0.tgz", + "integrity": "sha512-rNocXHgipO+rvnP6dk3zI20RpOtrAM/kzbB258Uw5BWr3TpXi861yzjo16Dn4hUox07iw5AyeMLHWsujkjzvRQ==", + "requires": { + "is-path-inside": "^2.1.0" + } + }, + "is-path-inside": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-path-inside/-/is-path-inside-2.1.0.tgz", + "integrity": "sha512-wiyhTzfDWsvwAW53OBWF5zuvaOGlZ6PwYxAbPVDhpm+gM09xKQGjBq/8uYN12aDvMxnAnq3dxTyoSoRNmg5YFg==", + "requires": { + "path-is-inside": "^1.0.2" + } + }, + "is-plain-obj": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-plain-obj/-/is-plain-obj-1.1.0.tgz", + "integrity": "sha1-caUMhCnfync8kqOQpKA7OfzVHT4=" + }, + "is-plain-object": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/is-plain-object/-/is-plain-object-2.0.4.tgz", + "integrity": "sha512-h5PpgXkWitc38BBMYawTYMWJHFZJVnBquFE57xFpjB8pJFiF6gZ+bU+WyI/yqXiFR5mdLsgYNaPe8uao6Uv9Og==", + "requires": { + "isobject": "^3.0.1" + } + }, + "is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-promise/-/is-promise-2.1.0.tgz", + "integrity": "sha1-eaKp7OfwlugPNtKy87wWwf9L8/o=" + }, + "is-regex": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-regex/-/is-regex-1.0.5.tgz", + "integrity": "sha512-vlKW17SNq44owv5AQR3Cq0bQPEb8+kF3UKZ2fiZNOWtztYE5i0CzCZxFDwO58qAOWtxdBRVO/V5Qin1wjCqFYQ==", + "requires": { + "has": "^1.0.3" + } + }, + "is-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-regexp/-/is-regexp-1.0.0.tgz", + "integrity": "sha1-/S2INUXEa6xaYz57mgnof6LLUGk=" + }, + "is-resolvable": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-resolvable/-/is-resolvable-1.1.0.tgz", + "integrity": "sha512-qgDYXFSR5WvEfuS5dMj6oTMEbrrSaM0CrFk2Yiq/gXnBvD9pMa2jGXxyhGLfvhZpuMZe18CJpFxAt3CRs42NMg==" + }, + "is-root": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/is-root/-/is-root-2.1.0.tgz", + "integrity": "sha512-AGOriNp96vNBd3HtU+RzFEc75FfR5ymiYv8E553I71SCeXBiMsVDUtdio1OEFvrPyLIQ9tVR5RxXIFe5PUFjMg==" + }, + "is-stream": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-stream/-/is-stream-1.1.0.tgz", + "integrity": "sha1-EtSj3U5o4Lec6428hBc66A2RykQ=" + }, + "is-string": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/is-string/-/is-string-1.0.5.tgz", + "integrity": "sha512-buY6VNRjhQMiF1qWDouloZlQbRhDPCebwxSjxMjxgemYT46YMd2NR0/H+fBhEfWX4A/w9TBJ+ol+okqJKFE6vQ==" + }, + "is-svg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/is-svg/-/is-svg-3.0.0.tgz", + "integrity": "sha512-gi4iHK53LR2ujhLVVj+37Ykh9GLqYHX6JOVXbLAucaG/Cqw9xwdFOjDM2qeifLs1sF1npXXFvDu0r5HNgCMrzQ==", + "requires": { + "html-comment-regex": "^1.1.0" + } + }, + "is-symbol": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/is-symbol/-/is-symbol-1.0.3.tgz", + "integrity": "sha512-OwijhaRSgqvhm/0ZdAcXNZt9lYdKFpcRDT5ULUuYXPoT794UNOdU+gpT6Rzo7b4V2HUl/op6GqY894AZwv9faQ==", + "requires": { + "has-symbols": "^1.0.1" + } + }, + "is-typedarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-typedarray/-/is-typedarray-1.0.0.tgz", + "integrity": "sha1-5HnICFjfDBsR3dppQPlgEfzaSpo=" + }, + "is-windows": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-windows/-/is-windows-1.0.2.tgz", + "integrity": "sha512-eXK1UInq2bPmjyX6e3VHIzMLobc4J94i4AWn+Hpq3OU5KkrRC96OAcR3PRJ/pGu6m8TRnBHP9dkXQVsT/COVIA==" + }, + "is-wsl": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-1.1.0.tgz", + "integrity": "sha1-HxbkqiKwTRM2tmGIpmrzxgDDpm0=" + }, + "isarray": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/isarray/-/isarray-1.0.0.tgz", + "integrity": "sha1-u5NdSFgsuhaMBoNJV6VKPgcSTxE=" + }, + "isexe": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/isexe/-/isexe-2.0.0.tgz", + "integrity": "sha1-6PvzdNxVb/iUehDcsFctYz8s+hA=" + }, + "isobject": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-3.0.1.tgz", + "integrity": "sha1-TkMekrEalzFjaqH5yNHMvP2reN8=" + }, + "isstream": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/isstream/-/isstream-0.1.2.tgz", + "integrity": "sha1-R+Y/evVa+m+S4VAOaQ64uFKcCZo=" + }, + "istanbul-lib-coverage": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/istanbul-lib-coverage/-/istanbul-lib-coverage-2.0.5.tgz", + "integrity": "sha512-8aXznuEPCJvGnMSRft4udDRDtb1V3pkQkMMI5LI+6HuQz5oQ4J2UFn1H82raA3qJtyOLkkwVqICBQkjnGtn5mA==" + }, + "istanbul-lib-instrument": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/istanbul-lib-instrument/-/istanbul-lib-instrument-3.3.0.tgz", + "integrity": "sha512-5nnIN4vo5xQZHdXno/YDXJ0G+I3dAm4XgzfSVTPLQpj/zAV2dV6Juy0yaf10/zrJOJeHoN3fraFe+XRq2bFVZA==", + "requires": { + "@babel/generator": "^7.4.0", + "@babel/parser": "^7.4.3", + "@babel/template": "^7.4.0", + "@babel/traverse": "^7.4.3", + "@babel/types": "^7.4.0", + "istanbul-lib-coverage": "^2.0.5", + "semver": "^6.0.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "istanbul-lib-report": { + "version": "2.0.8", + "resolved": "https://registry.npmjs.org/istanbul-lib-report/-/istanbul-lib-report-2.0.8.tgz", + "integrity": "sha512-fHBeG573EIihhAblwgxrSenp0Dby6tJMFR/HvlerBsrCTD5bkUuoNtn3gVh29ZCS824cGGBPn7Sg7cNk+2xUsQ==", + "requires": { + "istanbul-lib-coverage": "^2.0.5", + "make-dir": "^2.1.0", + "supports-color": "^6.1.0" + } + }, + "istanbul-lib-source-maps": { + "version": "3.0.6", + "resolved": "https://registry.npmjs.org/istanbul-lib-source-maps/-/istanbul-lib-source-maps-3.0.6.tgz", + "integrity": "sha512-R47KzMtDJH6X4/YW9XTx+jrLnZnscW4VpNN+1PViSYTejLVPWv7oov+Duf8YQSPyVRUvueQqz1TcsC6mooZTXw==", + "requires": { + "debug": "^4.1.1", + "istanbul-lib-coverage": "^2.0.5", + "make-dir": "^2.1.0", + "rimraf": "^2.6.3", + "source-map": "^0.6.1" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "istanbul-reports": { + "version": "2.2.7", + "resolved": "https://registry.npmjs.org/istanbul-reports/-/istanbul-reports-2.2.7.tgz", + "integrity": "sha512-uu1F/L1o5Y6LzPVSVZXNOoD/KXpJue9aeLRd0sM9uMXfZvzomB0WxVamWb5ue8kA2vVWEmW7EG+A5n3f1kqHKg==", + "requires": { + "html-escaper": "^2.0.0" + } + }, + "jest": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest/-/jest-24.9.0.tgz", + "integrity": "sha512-YvkBL1Zm7d2B1+h5fHEOdyjCG+sGMz4f8D86/0HiqJ6MB4MnDc8FgP5vdWsGnemOQro7lnYo8UakZ3+5A0jxGw==", + "requires": { + "import-local": "^2.0.0", + "jest-cli": "^24.9.0" + }, + "dependencies": { + "jest-cli": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-cli/-/jest-cli-24.9.0.tgz", + "integrity": "sha512-+VLRKyitT3BWoMeSUIHRxV/2g8y9gw91Jh5z2UmXZzkZKpbC08CSehVxgHUwTpy+HwGcns/tqafQDJW7imYvGg==", + "requires": { + "@jest/core": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "import-local": "^2.0.0", + "is-ci": "^2.0.0", + "jest-config": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "prompts": "^2.0.1", + "realpath-native": "^1.1.0", + "yargs": "^13.3.0" + } + } + } + }, + "jest-changed-files": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-changed-files/-/jest-changed-files-24.9.0.tgz", + "integrity": "sha512-6aTWpe2mHF0DhL28WjdkO8LyGjs3zItPET4bMSeXU6T3ub4FPMw+mcOcbdGXQOAfmLcxofD23/5Bl9Z4AkFwqg==", + "requires": { + "@jest/types": "^24.9.0", + "execa": "^1.0.0", + "throat": "^4.0.0" + } + }, + "jest-config": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-config/-/jest-config-24.9.0.tgz", + "integrity": "sha512-RATtQJtVYQrp7fvWg6f5y3pEFj9I+H8sWw4aKxnDZ96mob5i5SD6ZEGWgMLXQ4LE8UurrjbdlLWdUeo+28QpfQ==", + "requires": { + "@babel/core": "^7.1.0", + "@jest/test-sequencer": "^24.9.0", + "@jest/types": "^24.9.0", + "babel-jest": "^24.9.0", + "chalk": "^2.0.1", + "glob": "^7.1.1", + "jest-environment-jsdom": "^24.9.0", + "jest-environment-node": "^24.9.0", + "jest-get-type": "^24.9.0", + "jest-jasmine2": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-resolve": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "micromatch": "^3.1.10", + "pretty-format": "^24.9.0", + "realpath-native": "^1.1.0" + } + }, + "jest-diff": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-diff/-/jest-diff-24.9.0.tgz", + "integrity": "sha512-qMfrTs8AdJE2iqrTp0hzh7kTd2PQWrsFyj9tORoKmu32xjPjeE4NyjVRDz8ybYwqS2ik8N4hsIpiVTyFeo2lBQ==", + "requires": { + "chalk": "^2.0.1", + "diff-sequences": "^24.9.0", + "jest-get-type": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-docblock": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-docblock/-/jest-docblock-24.9.0.tgz", + "integrity": "sha512-F1DjdpDMJMA1cN6He0FNYNZlo3yYmOtRUnktrT9Q37njYzC5WEaDdmbynIgy0L/IvXvvgsG8OsqhLPXTpfmZAA==", + "requires": { + "detect-newline": "^2.1.0" + } + }, + "jest-each": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-each/-/jest-each-24.9.0.tgz", + "integrity": "sha512-ONi0R4BvW45cw8s2Lrx8YgbeXL1oCQ/wIDwmsM3CqM/nlblNCPmnC3IPQlMbRFZu3wKdQ2U8BqM6lh3LJ5Bsog==", + "requires": { + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "jest-get-type": "^24.9.0", + "jest-util": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-environment-jsdom": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom/-/jest-environment-jsdom-24.9.0.tgz", + "integrity": "sha512-Zv9FV9NBRzLuALXjvRijO2351DRQeLYXtpD4xNvfoVFw21IOKNhZAEUKcbiEtjTkm2GsJ3boMVgkaR7rN8qetA==", + "requires": { + "@jest/environment": "^24.9.0", + "@jest/fake-timers": "^24.9.0", + "@jest/types": "^24.9.0", + "jest-mock": "^24.9.0", + "jest-util": "^24.9.0", + "jsdom": "^11.5.1" + } + }, + "jest-environment-jsdom-fourteen": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/jest-environment-jsdom-fourteen/-/jest-environment-jsdom-fourteen-1.0.1.tgz", + "integrity": "sha512-DojMX1sY+at5Ep+O9yME34CdidZnO3/zfPh8UW+918C5fIZET5vCjfkegixmsi7AtdYfkr4bPlIzmWnlvQkP7Q==", + "requires": { + "@jest/environment": "^24.3.0", + "@jest/fake-timers": "^24.3.0", + "@jest/types": "^24.3.0", + "jest-mock": "^24.0.0", + "jest-util": "^24.0.0", + "jsdom": "^14.1.0" + }, + "dependencies": { + "acorn": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz", + "integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==" + }, + "jsdom": { + "version": "14.1.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-14.1.0.tgz", + "integrity": "sha512-O901mfJSuTdwU2w3Sn+74T+RnDVP+FuV5fH8tcPWyqrseRAb0s5xOtPgCFiPOtLcyK7CLIJwPyD83ZqQWvA5ng==", + "requires": { + "abab": "^2.0.0", + "acorn": "^6.0.4", + "acorn-globals": "^4.3.0", + "array-equal": "^1.0.0", + "cssom": "^0.3.4", + "cssstyle": "^1.1.1", + "data-urls": "^1.1.0", + "domexception": "^1.0.1", + "escodegen": "^1.11.0", + "html-encoding-sniffer": "^1.0.2", + "nwsapi": "^2.1.3", + "parse5": "5.1.0", + "pn": "^1.1.0", + "request": "^2.88.0", + "request-promise-native": "^1.0.5", + "saxes": "^3.1.9", + "symbol-tree": "^3.2.2", + "tough-cookie": "^2.5.0", + "w3c-hr-time": "^1.0.1", + "w3c-xmlserializer": "^1.1.2", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^7.0.0", + "ws": "^6.1.2", + "xml-name-validator": "^3.0.0" + } + }, + "parse5": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.0.tgz", + "integrity": "sha512-fxNG2sQjHvlVAYmzBZS9YlDp6PTSSDwa98vkD4QgVDDCAo84z5X1t5XyJQ62ImdLXx5NdIIfihey6xpum9/gRQ==" + }, + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "ws": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.1.tgz", + "integrity": "sha512-GIyAXC2cB7LjvpgMt9EKS2ldqr0MTrORaleiOno6TweZ6r3TKtoFQWay/2PceJ3RuBasOHzXNn5Lrw1X0bEjqA==", + "requires": { + "async-limiter": "~1.0.0" + } + } + } + }, + "jest-environment-node": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-environment-node/-/jest-environment-node-24.9.0.tgz", + "integrity": "sha512-6d4V2f4nxzIzwendo27Tr0aFm+IXWa0XEUnaH6nU0FMaozxovt+sfRvh4J47wL1OvF83I3SSTu0XK+i4Bqe7uA==", + "requires": { + "@jest/environment": "^24.9.0", + "@jest/fake-timers": "^24.9.0", + "@jest/types": "^24.9.0", + "jest-mock": "^24.9.0", + "jest-util": "^24.9.0" + } + }, + "jest-get-type": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-get-type/-/jest-get-type-24.9.0.tgz", + "integrity": "sha512-lUseMzAley4LhIcpSP9Jf+fTrQ4a1yHQwLNeeVa2cEmbCGeoZAtYPOIv8JaxLD/sUpKxetKGP+gsHl8f8TSj8Q==" + }, + "jest-haste-map": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-haste-map/-/jest-haste-map-24.9.0.tgz", + "integrity": "sha512-kfVFmsuWui2Sj1Rp1AJ4D9HqJwE4uwTlS/vO+eRUaMmd54BFpli2XhMQnPC2k4cHFVbB2Q2C+jtI1AGLgEnCjQ==", + "requires": { + "@jest/types": "^24.9.0", + "anymatch": "^2.0.0", + "fb-watchman": "^2.0.0", + "fsevents": "^1.2.7", + "graceful-fs": "^4.1.15", + "invariant": "^2.2.4", + "jest-serializer": "^24.9.0", + "jest-util": "^24.9.0", + "jest-worker": "^24.9.0", + "micromatch": "^3.1.10", + "sane": "^4.0.3", + "walker": "^1.0.7" + } + }, + "jest-jasmine2": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-jasmine2/-/jest-jasmine2-24.9.0.tgz", + "integrity": "sha512-Cq7vkAgaYKp+PsX+2/JbTarrk0DmNhsEtqBXNwUHkdlbrTBLtMJINADf2mf5FkowNsq8evbPc07/qFO0AdKTzw==", + "requires": { + "@babel/traverse": "^7.1.0", + "@jest/environment": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "co": "^4.6.0", + "expect": "^24.9.0", + "is-generator-fn": "^2.0.0", + "jest-each": "^24.9.0", + "jest-matcher-utils": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-snapshot": "^24.9.0", + "jest-util": "^24.9.0", + "pretty-format": "^24.9.0", + "throat": "^4.0.0" + } + }, + "jest-leak-detector": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-leak-detector/-/jest-leak-detector-24.9.0.tgz", + "integrity": "sha512-tYkFIDsiKTGwb2FG1w8hX9V0aUb2ot8zY/2nFg087dUageonw1zrLMP4W6zsRO59dPkTSKie+D4rhMuP9nRmrA==", + "requires": { + "jest-get-type": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-matcher-utils": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-matcher-utils/-/jest-matcher-utils-24.9.0.tgz", + "integrity": "sha512-OZz2IXsu6eaiMAwe67c1T+5tUAtQyQx27/EMEkbFAGiw52tB9em+uGbzpcgYVpA8wl0hlxKPZxrly4CXU/GjHA==", + "requires": { + "chalk": "^2.0.1", + "jest-diff": "^24.9.0", + "jest-get-type": "^24.9.0", + "pretty-format": "^24.9.0" + } + }, + "jest-message-util": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-message-util/-/jest-message-util-24.9.0.tgz", + "integrity": "sha512-oCj8FiZ3U0hTP4aSui87P4L4jC37BtQwUMqk+zk/b11FR19BJDeZsZAvIHutWnmtw7r85UmR3CEWZ0HWU2mAlw==", + "requires": { + "@babel/code-frame": "^7.0.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/stack-utils": "^1.0.1", + "chalk": "^2.0.1", + "micromatch": "^3.1.10", + "slash": "^2.0.0", + "stack-utils": "^1.0.1" + } + }, + "jest-mock": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-mock/-/jest-mock-24.9.0.tgz", + "integrity": "sha512-3BEYN5WbSq9wd+SyLDES7AHnjH9A/ROBwmz7l2y+ol+NtSFO8DYiEBzoO1CeFc9a8DYy10EO4dDFVv/wN3zl1w==", + "requires": { + "@jest/types": "^24.9.0" + } + }, + "jest-pnp-resolver": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/jest-pnp-resolver/-/jest-pnp-resolver-1.2.1.tgz", + "integrity": "sha512-pgFw2tm54fzgYvc/OHrnysABEObZCUNFnhjoRjaVOCN8NYc032/gVjPaHD4Aq6ApkSieWtfKAFQtmDKAmhupnQ==" + }, + "jest-regex-util": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-regex-util/-/jest-regex-util-24.9.0.tgz", + "integrity": "sha512-05Cmb6CuxaA+Ys6fjr3PhvV3bGQmO+2p2La4hFbU+W5uOc479f7FdLXUWXw4pYMAhhSZIuKHwSXSu6CsSBAXQA==" + }, + "jest-resolve": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-resolve/-/jest-resolve-24.9.0.tgz", + "integrity": "sha512-TaLeLVL1l08YFZAt3zaPtjiVvyy4oSA6CRe+0AFPPVX3Q/VI0giIWWoAvoS5L96vj9Dqxj4fB5p2qrHCmTU/MQ==", + "requires": { + "@jest/types": "^24.9.0", + "browser-resolve": "^1.11.3", + "chalk": "^2.0.1", + "jest-pnp-resolver": "^1.2.1", + "realpath-native": "^1.1.0" + } + }, + "jest-resolve-dependencies": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-resolve-dependencies/-/jest-resolve-dependencies-24.9.0.tgz", + "integrity": "sha512-Fm7b6AlWnYhT0BXy4hXpactHIqER7erNgIsIozDXWl5dVm+k8XdGVe1oTg1JyaFnOxarMEbax3wyRJqGP2Pq+g==", + "requires": { + "@jest/types": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-snapshot": "^24.9.0" + } + }, + "jest-runner": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-runner/-/jest-runner-24.9.0.tgz", + "integrity": "sha512-KksJQyI3/0mhcfspnxxEOBueGrd5E4vV7ADQLT9ESaCzz02WnbdbKWIf5Mkaucoaj7obQckYPVX6JJhgUcoWWg==", + "requires": { + "@jest/console": "^24.7.1", + "@jest/environment": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "chalk": "^2.4.2", + "exit": "^0.1.2", + "graceful-fs": "^4.1.15", + "jest-config": "^24.9.0", + "jest-docblock": "^24.3.0", + "jest-haste-map": "^24.9.0", + "jest-jasmine2": "^24.9.0", + "jest-leak-detector": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-resolve": "^24.9.0", + "jest-runtime": "^24.9.0", + "jest-util": "^24.9.0", + "jest-worker": "^24.6.0", + "source-map-support": "^0.5.6", + "throat": "^4.0.0" + } + }, + "jest-runtime": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-runtime/-/jest-runtime-24.9.0.tgz", + "integrity": "sha512-8oNqgnmF3v2J6PVRM2Jfuj8oX3syKmaynlDMMKQ4iyzbQzIG6th5ub/lM2bCMTmoTKM3ykcUYI2Pw9xwNtjMnw==", + "requires": { + "@jest/console": "^24.7.1", + "@jest/environment": "^24.9.0", + "@jest/source-map": "^24.3.0", + "@jest/transform": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/yargs": "^13.0.0", + "chalk": "^2.0.1", + "exit": "^0.1.2", + "glob": "^7.1.3", + "graceful-fs": "^4.1.15", + "jest-config": "^24.9.0", + "jest-haste-map": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-mock": "^24.9.0", + "jest-regex-util": "^24.3.0", + "jest-resolve": "^24.9.0", + "jest-snapshot": "^24.9.0", + "jest-util": "^24.9.0", + "jest-validate": "^24.9.0", + "realpath-native": "^1.1.0", + "slash": "^2.0.0", + "strip-bom": "^3.0.0", + "yargs": "^13.3.0" + } + }, + "jest-serializer": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-serializer/-/jest-serializer-24.9.0.tgz", + "integrity": "sha512-DxYipDr8OvfrKH3Kel6NdED3OXxjvxXZ1uIY2I9OFbGg+vUkkg7AGvi65qbhbWNPvDckXmzMPbK3u3HaDO49bQ==" + }, + "jest-snapshot": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-snapshot/-/jest-snapshot-24.9.0.tgz", + "integrity": "sha512-uI/rszGSs73xCM0l+up7O7a40o90cnrk429LOiK3aeTvfC0HHmldbd81/B7Ix81KSFe1lwkbl7GnBGG4UfuDew==", + "requires": { + "@babel/types": "^7.0.0", + "@jest/types": "^24.9.0", + "chalk": "^2.0.1", + "expect": "^24.9.0", + "jest-diff": "^24.9.0", + "jest-get-type": "^24.9.0", + "jest-matcher-utils": "^24.9.0", + "jest-message-util": "^24.9.0", + "jest-resolve": "^24.9.0", + "mkdirp": "^0.5.1", + "natural-compare": "^1.4.0", + "pretty-format": "^24.9.0", + "semver": "^6.2.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "jest-util": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-util/-/jest-util-24.9.0.tgz", + "integrity": "sha512-x+cZU8VRmOJxbA1K5oDBdxQmdq0OIdADarLxk0Mq+3XS4jgvhG/oKGWcIDCtPG0HgjxOYvF+ilPJQsAyXfbNOg==", + "requires": { + "@jest/console": "^24.9.0", + "@jest/fake-timers": "^24.9.0", + "@jest/source-map": "^24.9.0", + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "callsites": "^3.0.0", + "chalk": "^2.0.1", + "graceful-fs": "^4.1.15", + "is-ci": "^2.0.0", + "mkdirp": "^0.5.1", + "slash": "^2.0.0", + "source-map": "^0.6.0" + } + }, + "jest-validate": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-validate/-/jest-validate-24.9.0.tgz", + "integrity": "sha512-HPIt6C5ACwiqSiwi+OfSSHbK8sG7akG8eATl+IPKaeIjtPOeBUd/g3J7DghugzxrGjI93qS/+RPKe1H6PqvhRQ==", + "requires": { + "@jest/types": "^24.9.0", + "camelcase": "^5.3.1", + "chalk": "^2.0.1", + "jest-get-type": "^24.9.0", + "leven": "^3.1.0", + "pretty-format": "^24.9.0" + } + }, + "jest-watch-typeahead": { + "version": "0.4.2", + "resolved": "https://registry.npmjs.org/jest-watch-typeahead/-/jest-watch-typeahead-0.4.2.tgz", + "integrity": "sha512-f7VpLebTdaXs81rg/oj4Vg/ObZy2QtGzAmGLNsqUS5G5KtSN68tFcIsbvNODfNyQxU78g7D8x77o3bgfBTR+2Q==", + "requires": { + "ansi-escapes": "^4.2.1", + "chalk": "^2.4.1", + "jest-regex-util": "^24.9.0", + "jest-watcher": "^24.3.0", + "slash": "^3.0.0", + "string-length": "^3.1.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "slash": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-3.0.0.tgz", + "integrity": "sha512-g9Q1haeby36OSStwb4ntCGGGaKsaVSjQ68fBxoQcutl5fS1vuY18H3wSt3jFyFtrkx+Kz0V1G85A4MyAdDMi2Q==" + }, + "string-length": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-3.1.0.tgz", + "integrity": "sha512-Ttp5YvkGm5v9Ijagtaz1BnN+k9ObpvS0eIBblPMp2YWL8FBmi9qblQ9fexc2k/CXFgrTIteU3jAw3payCnwSTA==", + "requires": { + "astral-regex": "^1.0.0", + "strip-ansi": "^5.2.0" + } + } + } + }, + "jest-watcher": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-watcher/-/jest-watcher-24.9.0.tgz", + "integrity": "sha512-+/fLOfKPXXYJDYlks62/4R4GoT+GU1tYZed99JSCOsmzkkF7727RqKrjNAxtfO4YpGv11wybgRvCjR73lK2GZw==", + "requires": { + "@jest/test-result": "^24.9.0", + "@jest/types": "^24.9.0", + "@types/yargs": "^13.0.0", + "ansi-escapes": "^3.0.0", + "chalk": "^2.0.1", + "jest-util": "^24.9.0", + "string-length": "^2.0.0" + }, + "dependencies": { + "ansi-escapes": { + "version": "3.2.0", + "resolved": "https://registry.npmjs.org/ansi-escapes/-/ansi-escapes-3.2.0.tgz", + "integrity": "sha512-cBhpre4ma+U0T1oM5fXg7Dy1Jw7zzwv7lt/GoCpr+hDQJoYnKVPLL4dCvSEFMmQurOQvSrwT7SL/DAlhBI97RQ==" + } + } + }, + "jest-worker": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-24.9.0.tgz", + "integrity": "sha512-51PE4haMSXcHohnSMdM42anbvZANYTqMrr52tVKPqqsPJMzoP6FYYDVqahX/HrAoKEKz3uUPzSvKs9A3qR4iVw==", + "requires": { + "merge-stream": "^2.0.0", + "supports-color": "^6.1.0" + } + }, + "js-tokens": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/js-tokens/-/js-tokens-4.0.0.tgz", + "integrity": "sha512-RdJUflcE3cUzKiMqQgsCu06FPu9UdIJO0beYbPhHN4k6apgJtifcoCtT9bcxOpYBtpD2kCM6Sbzg4CausW/PKQ==" + }, + "js-yaml": { + "version": "3.13.1", + "resolved": "https://registry.npmjs.org/js-yaml/-/js-yaml-3.13.1.tgz", + "integrity": "sha512-YfbcO7jXDdyj0DGxYVSlSeQNHbD7XPWvrVWeVUujrQEoZzWJIRrCPoyk6kL6IAjAG2IolMK4T0hNUe0HOUs5Jw==", + "requires": { + "argparse": "^1.0.7", + "esprima": "^4.0.0" + } + }, + "jsbn": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/jsbn/-/jsbn-0.1.1.tgz", + "integrity": "sha1-peZUwuWi3rXyAdls77yoDA7y9RM=" + }, + "jsdom": { + "version": "11.12.0", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-11.12.0.tgz", + "integrity": "sha512-y8Px43oyiBM13Zc1z780FrfNLJCXTL40EWlty/LXUtcjykRBNgLlCjWXpfSPBl2iv+N7koQN+dvqszHZgT/Fjw==", + "requires": { + "abab": "^2.0.0", + "acorn": "^5.5.3", + "acorn-globals": "^4.1.0", + "array-equal": "^1.0.0", + "cssom": ">= 0.3.2 < 0.4.0", + "cssstyle": "^1.0.0", + "data-urls": "^1.0.0", + "domexception": "^1.0.1", + "escodegen": "^1.9.1", + "html-encoding-sniffer": "^1.0.2", + "left-pad": "^1.3.0", + "nwsapi": "^2.0.7", + "parse5": "4.0.0", + "pn": "^1.1.0", + "request": "^2.87.0", + "request-promise-native": "^1.0.5", + "sax": "^1.2.4", + "symbol-tree": "^3.2.2", + "tough-cookie": "^2.3.4", + "w3c-hr-time": "^1.0.1", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.3", + "whatwg-mimetype": "^2.1.0", + "whatwg-url": "^6.4.1", + "ws": "^5.2.0", + "xml-name-validator": "^3.0.0" + }, + "dependencies": { + "acorn": { + "version": "5.7.3", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-5.7.3.tgz", + "integrity": "sha512-T/zvzYRfbVojPWahDsE5evJdHb3oJoQfFbsrKM7w5Zcs++Tr257tia3BmMP8XYVjp1S9RZXQMh7gao96BlqZOw==" + } + } + }, + "jsesc": { + "version": "2.5.2", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-2.5.2.tgz", + "integrity": "sha512-OYu7XEzjkCQ3C5Ps3QIZsQfNpqoJyZZA99wd9aWd05NCtC5pWOkShK2mkL6HXQR6/Cy2lbNdPlZBpuQHXE63gA==" + }, + "json-parse-better-errors": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/json-parse-better-errors/-/json-parse-better-errors-1.0.2.tgz", + "integrity": "sha512-mrqyZKfX5EhL7hvqcV6WG1yYjnjeuYDzDhhcAAUrq8Po85NBQBJP+ZDUT75qZQ98IkUoBqdkExkukOU7Ts2wrw==" + }, + "json-schema": { + "version": "0.2.3", + "resolved": "https://registry.npmjs.org/json-schema/-/json-schema-0.2.3.tgz", + "integrity": "sha1-tIDIkuWaLwWVTOcnvT8qTogvnhM=" + }, + "json-schema-traverse": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/json-schema-traverse/-/json-schema-traverse-0.4.1.tgz", + "integrity": "sha512-xbbCH5dCYU5T8LcEhhuh7HJ88HXuW3qsI3Y0zOZFKfZEHcpWiHU/Jxzk629Brsab/mMiHQti9wMP+845RPe3Vg==" + }, + "json-stable-stringify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify/-/json-stable-stringify-1.0.1.tgz", + "integrity": "sha1-mnWdOcXy/1A/1TAGRu1EX4jE+a8=", + "requires": { + "jsonify": "~0.0.0" + } + }, + "json-stable-stringify-without-jsonify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json-stable-stringify-without-jsonify/-/json-stable-stringify-without-jsonify-1.0.1.tgz", + "integrity": "sha1-nbe1lJatPzz+8wp1FC0tkwrXJlE=" + }, + "json-stringify-safe": { + "version": "5.0.1", + "resolved": "https://registry.npmjs.org/json-stringify-safe/-/json-stringify-safe-5.0.1.tgz", + "integrity": "sha1-Epai1Y/UXxmg9s4B1lcB4sc1tus=" + }, + "json3": { + "version": "3.3.3", + "resolved": "https://registry.npmjs.org/json3/-/json3-3.3.3.tgz", + "integrity": "sha512-c7/8mbUsKigAbLkD5B010BK4D9LZm7A1pNItkEwiUZRpIN66exu/e7YQWysGun+TRKaJp8MhemM+VkfWv42aCA==" + }, + "json5": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-2.1.1.tgz", + "integrity": "sha512-l+3HXD0GEI3huGq1njuqtzYK8OYJyXMkOLtQ53pjWh89tvWS2h6l+1zMkYWqlb57+SiQodKZyvMEFb2X+KrFhQ==", + "requires": { + "minimist": "^1.2.0" + } + }, + "jsonfile": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz", + "integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=", + "requires": { + "graceful-fs": "^4.1.6" + } + }, + "jsonify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/jsonify/-/jsonify-0.0.0.tgz", + "integrity": "sha1-LHS27kHZPKUbe1qu6PUDYx0lKnM=" + }, + "jsprim": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/jsprim/-/jsprim-1.4.1.tgz", + "integrity": "sha1-MT5mvB5cwG5Di8G3SZwuXFastqI=", + "requires": { + "assert-plus": "1.0.0", + "extsprintf": "1.3.0", + "json-schema": "0.2.3", + "verror": "1.10.0" + } + }, + "jsx-ast-utils": { + "version": "2.2.3", + "resolved": "https://registry.npmjs.org/jsx-ast-utils/-/jsx-ast-utils-2.2.3.tgz", + "integrity": "sha512-EdIHFMm+1BPynpKOpdPqiOsvnIrInRGJD7bzPZdPkjitQEqpdpUuFpq4T0npZFKTiB3RhWFdGN+oqOJIdhDhQA==", + "requires": { + "array-includes": "^3.0.3", + "object.assign": "^4.1.0" + } + }, + "killable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/killable/-/killable-1.0.1.tgz", + "integrity": "sha512-LzqtLKlUwirEUyl/nicirVmNiPvYs7l5n8wOPP7fyJVpUPkvCnW/vuiXGpylGUlnPDnB7311rARzAt3Mhswpjg==" + }, + "kind-of": { + "version": "3.2.2", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-3.2.2.tgz", + "integrity": "sha1-MeohpzS6ubuw8yRm2JOupR5KPGQ=", + "requires": { + "is-buffer": "^1.1.5" + } + }, + "kleur": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/kleur/-/kleur-3.0.3.tgz", + "integrity": "sha512-eTIzlVOSUR+JxdDFepEYcBMtZ9Qqdef+rnzWdRZuMbOywu5tO2w2N7rqjoANZ5k9vywhL6Br1VRjUIgTQx4E8w==" + }, + "last-call-webpack-plugin": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/last-call-webpack-plugin/-/last-call-webpack-plugin-3.0.0.tgz", + "integrity": "sha512-7KI2l2GIZa9p2spzPIVZBYyNKkN+e/SQPpnjlTiPhdbDW3F86tdKKELxKpzJ5sgU19wQWsACULZmpTPYHeWO5w==", + "requires": { + "lodash": "^4.17.5", + "webpack-sources": "^1.1.0" + } + }, + "lazy-cache": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-1.0.4.tgz", + "integrity": "sha1-odePw6UEdMuAhF07O24dpJpEbo4=" + }, + "lcid": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/lcid/-/lcid-2.0.0.tgz", + "integrity": "sha512-avPEb8P8EGnwXKClwsNUgryVjllcRqtMYa49NTsbQagYuT1DcXnl1915oxWjoyGrXR6zH/Y0Zc96xWsPcoDKeA==", + "requires": { + "invert-kv": "^2.0.0" + } + }, + "left-pad": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/left-pad/-/left-pad-1.3.0.tgz", + "integrity": "sha512-XI5MPzVNApjAyhQzphX8BkmKsKUxD4LdyK24iZeQGinBN9yTQT3bFlCBy/aVx2HrNcqQGsdot8ghrjyrvMCoEA==" + }, + "leven": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/leven/-/leven-3.1.0.tgz", + "integrity": "sha512-qsda+H8jTaUaN/x5vzW2rzc+8Rw4TAQ/4KjB46IwK5VH+IlVeeeje/EoZRpiXvIqjFgK84QffqPztGI3VBLG1A==" + }, + "levenary": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/levenary/-/levenary-1.1.1.tgz", + "integrity": "sha512-mkAdOIt79FD6irqjYSs4rdbnlT5vRonMEvBVPVb3XmevfS8kgRXwfes0dhPdEtzTWD/1eNE/Bm/G1iRt6DcnQQ==", + "requires": { + "leven": "^3.1.0" + } + }, + "levn": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/levn/-/levn-0.3.0.tgz", + "integrity": "sha1-OwmSTt+fCDwEkP3UwLxEIeBHZO4=", + "requires": { + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2" + } + }, + "lines-and-columns": { + "version": "1.1.6", + "resolved": "https://registry.npmjs.org/lines-and-columns/-/lines-and-columns-1.1.6.tgz", + "integrity": "sha1-HADHQ7QzzQpOgHWPe2SldEDZ/wA=" + }, + "load-json-file": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-2.0.0.tgz", + "integrity": "sha1-eUfkIUmvgNaWy/eXvKq8/h/inKg=", + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^2.2.0", + "pify": "^2.0.0", + "strip-bom": "^3.0.0" + }, + "dependencies": { + "parse-json": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-2.2.0.tgz", + "integrity": "sha1-9ID0BDTvgHQfhGkJn43qGPVaTck=", + "requires": { + "error-ex": "^1.2.0" + } + }, + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + } + } + }, + "loader-fs-cache": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/loader-fs-cache/-/loader-fs-cache-1.0.2.tgz", + "integrity": "sha512-70IzT/0/L+M20jUlEqZhZyArTU6VKLRTYRDAYN26g4jfzpJqjipLL3/hgYpySqI9PwsVRHHFja0LfEmsx9X2Cw==", + "requires": { + "find-cache-dir": "^0.1.1", + "mkdirp": "0.5.1" + }, + "dependencies": { + "find-cache-dir": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-0.1.1.tgz", + "integrity": "sha1-yN765XyKUqinhPnjHFfHQumToLk=", + "requires": { + "commondir": "^1.0.1", + "mkdirp": "^0.5.1", + "pkg-dir": "^1.0.0" + } + }, + "find-up": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-1.1.2.tgz", + "integrity": "sha1-ay6YIrGizgpgq2TWEOzK1TyyTQ8=", + "requires": { + "path-exists": "^2.0.0", + "pinkie-promise": "^2.0.0" + } + }, + "path-exists": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-2.1.0.tgz", + "integrity": "sha1-D+tsZPD8UY2adU3V77YscCJ2H0s=", + "requires": { + "pinkie-promise": "^2.0.0" + } + }, + "pkg-dir": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-1.0.0.tgz", + "integrity": "sha1-ektQio1bstYp1EcFb/TpyTFM89Q=", + "requires": { + "find-up": "^1.0.0" + } + } + } + }, + "loader-runner": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/loader-runner/-/loader-runner-2.4.0.tgz", + "integrity": "sha512-Jsmr89RcXGIwivFY21FcRrisYZfvLMTWx5kOLc+JTxtpBOG6xML0vzbc6SEQG2FO9/4Fc3wW4LVcB5DmGflaRw==" + }, + "loader-utils": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.4.0.tgz", + "integrity": "sha512-qH0WSMBtn/oHuwjy/NucEgbx5dbxxnxup9s4PVXJUDHZBQY+s0NWA9rJf53RBnQZxfch7euUui7hpoAPvALZdA==", + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^3.0.0", + "json5": "^1.0.1" + }, + "dependencies": { + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", + "requires": { + "minimist": "^1.2.0" + } + } + } + }, + "locate-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-3.0.0.tgz", + "integrity": "sha512-7AO748wWnIhNqAuaty2ZWHkQHRSNfPVIsPIfwEOWO22AmaoVrWavlOcMR5nzTLNYvp36X220/maaRsrec1G65A==", + "requires": { + "p-locate": "^3.0.0", + "path-exists": "^3.0.0" + } + }, + "lodash": { + "version": "4.17.15", + "resolved": "https://registry.npmjs.org/lodash/-/lodash-4.17.15.tgz", + "integrity": "sha512-8xOcRHvCjnocdS5cpwXQXVzmmh5e5+saE2QGoeQmbKmRS6J3VQppPOIt0MnmE+4xlZoumy0GPG0D0MVIQbNA1A==" + }, + "lodash._reinterpolate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/lodash._reinterpolate/-/lodash._reinterpolate-3.0.0.tgz", + "integrity": "sha1-DM8tiRZq8Ds2Y8eWU4t1rG4RTZ0=" + }, + "lodash.memoize": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/lodash.memoize/-/lodash.memoize-4.1.2.tgz", + "integrity": "sha1-vMbEmkKihA7Zl/Mj6tpezRguC/4=" + }, + "lodash.sortby": { + "version": "4.7.0", + "resolved": "https://registry.npmjs.org/lodash.sortby/-/lodash.sortby-4.7.0.tgz", + "integrity": "sha1-7dFMgk4sycHgsKG0K7UhBRakJDg=" + }, + "lodash.template": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.template/-/lodash.template-4.5.0.tgz", + "integrity": "sha512-84vYFxIkmidUiFxidA/KjjH9pAycqW+h980j7Fuz5qxRtO9pgB7MDFTdys1N7A5mcucRiDyEq4fusljItR1T/A==", + "requires": { + "lodash._reinterpolate": "^3.0.0", + "lodash.templatesettings": "^4.0.0" + } + }, + "lodash.templatesettings": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/lodash.templatesettings/-/lodash.templatesettings-4.2.0.tgz", + "integrity": "sha512-stgLz+i3Aa9mZgnjr/O+v9ruKZsPsndy7qPZOchbqk2cnTU1ZaldKK+v7m54WoKIyxiuMZTKT2H81F8BeAc3ZQ==", + "requires": { + "lodash._reinterpolate": "^3.0.0" + } + }, + "lodash.uniq": { + "version": "4.5.0", + "resolved": "https://registry.npmjs.org/lodash.uniq/-/lodash.uniq-4.5.0.tgz", + "integrity": "sha1-0CJTc662Uq3BvILklFM5qEJ1R3M=" + }, + "loglevel": { + "version": "1.6.7", + "resolved": "https://registry.npmjs.org/loglevel/-/loglevel-1.6.7.tgz", + "integrity": "sha512-cY2eLFrQSAfVPhCgH1s7JI73tMbg9YC3v3+ZHVW67sBS7UxWzNEk/ZBbSfLykBWHp33dqqtOv82gjhKEi81T/A==" + }, + "loose-envify": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/loose-envify/-/loose-envify-1.4.0.tgz", + "integrity": "sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==", + "requires": { + "js-tokens": "^3.0.0 || ^4.0.0" + } + }, + "lower-case": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/lower-case/-/lower-case-2.0.1.tgz", + "integrity": "sha512-LiWgfDLLb1dwbFQZsSglpRj+1ctGnayXz3Uv0/WO8n558JycT5fg6zkNcnW0G68Nn0aEldTFeEfmjCfmqry/rQ==", + "requires": { + "tslib": "^1.10.0" + } + }, + "lru-cache": { + "version": "5.1.1", + "resolved": "https://registry.npmjs.org/lru-cache/-/lru-cache-5.1.1.tgz", + "integrity": "sha512-KpNARQA3Iwv+jTA0utUVVbrh+Jlrr1Fv0e56GGzAFOXN7dk/FviaDW8LHmK52DlcH4WP2n6gI8vN1aesBFgo9w==", + "requires": { + "yallist": "^3.0.2" + }, + "dependencies": { + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==" + } + } + }, + "make-dir": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-2.1.0.tgz", + "integrity": "sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==", + "requires": { + "pify": "^4.0.1", + "semver": "^5.6.0" + } + }, + "makeerror": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/makeerror/-/makeerror-1.0.11.tgz", + "integrity": "sha1-4BpckQnyr3lmDk6LlYd5AYT1qWw=", + "requires": { + "tmpl": "1.0.x" + } + }, + "mamacro": { + "version": "0.0.3", + "resolved": "https://registry.npmjs.org/mamacro/-/mamacro-0.0.3.tgz", + "integrity": "sha512-qMEwh+UujcQ+kbz3T6V+wAmO2U8veoq2w+3wY8MquqwVA3jChfwY+Tk52GZKDfACEPjuZ7r2oJLejwpt8jtwTA==" + }, + "map-age-cleaner": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/map-age-cleaner/-/map-age-cleaner-0.1.3.tgz", + "integrity": "sha512-bJzx6nMoP6PDLPBFmg7+xRKeFZvFboMrGlxmNj9ClvX53KrmvM5bXFXEWjbz4cz1AFn+jWJ9z/DJSz7hrs0w3w==", + "requires": { + "p-defer": "^1.0.0" + } + }, + "map-cache": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/map-cache/-/map-cache-0.2.2.tgz", + "integrity": "sha1-wyq9C9ZSXZsFFkW7TyasXcmKDb8=" + }, + "map-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/map-visit/-/map-visit-1.0.0.tgz", + "integrity": "sha1-7Nyo8TFE5mDxtb1B8S80edmN+48=", + "requires": { + "object-visit": "^1.0.0" + } + }, + "md5.js": { + "version": "1.3.5", + "resolved": "https://registry.npmjs.org/md5.js/-/md5.js-1.3.5.tgz", + "integrity": "sha512-xitP+WxNPcTTOgnTJcrhM0xvdPepipPSf3I8EIpGKeFLjt3PlJLIDG3u8EX53ZIubkb+5U2+3rELYpEhHhzdkg==", + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "mdn-data": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/mdn-data/-/mdn-data-2.0.4.tgz", + "integrity": "sha512-iV3XNKw06j5Q7mi6h+9vbx23Tv7JkjEVgKHW4pimwyDGWm0OIQntJJ+u1C6mg6mK1EaTv42XQ7w76yuzH7M2cA==" + }, + "media-typer": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", + "integrity": "sha1-hxDXrwqmJvj/+hzgAWhUUmMlV0g=" + }, + "mem": { + "version": "4.3.0", + "resolved": "https://registry.npmjs.org/mem/-/mem-4.3.0.tgz", + "integrity": "sha512-qX2bG48pTqYRVmDB37rn/6PT7LcR8T7oAX3bf99u1Tt1nzxYfxkgqDwUwolPlXweM0XzBOBFzSx4kfp7KP1s/w==", + "requires": { + "map-age-cleaner": "^0.1.1", + "mimic-fn": "^2.0.0", + "p-is-promise": "^2.0.0" + } + }, + "memory-fs": { + "version": "0.4.1", + "resolved": "https://registry.npmjs.org/memory-fs/-/memory-fs-0.4.1.tgz", + "integrity": "sha1-OpoguEYlI+RHz7x+i7gO1me/xVI=", + "requires": { + "errno": "^0.1.3", + "readable-stream": "^2.0.1" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "merge-deep": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/merge-deep/-/merge-deep-3.0.2.tgz", + "integrity": "sha512-T7qC8kg4Zoti1cFd8Cr0M+qaZfOwjlPDEdZIIPPB2JZctjaPM4fX+i7HOId69tAti2fvO6X5ldfYUONDODsrkA==", + "requires": { + "arr-union": "^3.1.0", + "clone-deep": "^0.2.4", + "kind-of": "^3.0.2" + } + }, + "merge-descriptors": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", + "integrity": "sha1-sAqqVW3YtEVoFQ7J0blT8/kMu2E=" + }, + "merge-stream": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/merge-stream/-/merge-stream-2.0.0.tgz", + "integrity": "sha512-abv/qOcuPfk3URPfDzmZU1LKmuw8kT+0nIHvKrKgFrwifol/doWcdA4ZqsWQ8ENrFKkd67Mfpo/LovbIUsbt3w==" + }, + "merge2": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/merge2/-/merge2-1.3.0.tgz", + "integrity": "sha512-2j4DAdlBOkiSZIsaXk4mTE3sRS02yBHAtfy127xRV3bQUFqXkjHCHLW6Scv7DwNRbIWNHH8zpnz9zMaKXIdvYw==" + }, + "methods": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", + "integrity": "sha1-VSmk1nZUE07cxSZmVoNbD4Ua/O4=" + }, + "microevent.ts": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/microevent.ts/-/microevent.ts-0.1.1.tgz", + "integrity": "sha512-jo1OfR4TaEwd5HOrt5+tAZ9mqT4jmpNAusXtyfNzqVm9uiSYFZlKM1wYL4oU7azZW/PxQW53wM0S6OR1JHNa2g==" + }, + "micromatch": { + "version": "3.1.10", + "resolved": "https://registry.npmjs.org/micromatch/-/micromatch-3.1.10.tgz", + "integrity": "sha512-MWikgl9n9M3w+bpsY3He8L+w9eF9338xRl8IAO5viDizwSzziFEyUzo2xrrloB64ADbTf8uA8vRqqttDTOmccg==", + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "braces": "^2.3.1", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "extglob": "^2.0.4", + "fragment-cache": "^0.2.1", + "kind-of": "^6.0.2", + "nanomatch": "^1.2.9", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.2" + }, + "dependencies": { + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "miller-rabin": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/miller-rabin/-/miller-rabin-4.0.1.tgz", + "integrity": "sha512-115fLhvZVqWwHPbClyntxEVfVDfl9DLLTuJvq3g2O/Oxi8AiNouAHvDSzHS0viUJc+V5vm3eq91Xwqn9dp4jRA==", + "requires": { + "bn.js": "^4.0.0", + "brorand": "^1.0.1" + } + }, + "mime": { + "version": "2.4.4", + "resolved": "https://registry.npmjs.org/mime/-/mime-2.4.4.tgz", + "integrity": "sha512-LRxmNwziLPT828z+4YkNzloCFC2YM4wrB99k+AV5ZbEyfGNWfG8SO1FUXLmLDBSo89NrJZ4DIWeLjy1CHGhMGA==" + }, + "mime-db": { + "version": "1.43.0", + "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.43.0.tgz", + "integrity": "sha512-+5dsGEEovYbT8UY9yD7eE4XTc4UwJ1jBYlgaQQF38ENsKR3wj/8q8RFZrF9WIZpB2V1ArTVFUva8sAul1NzRzQ==" + }, + "mime-types": { + "version": "2.1.26", + "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.26.tgz", + "integrity": "sha512-01paPWYgLrkqAyrlDorC1uDwl2p3qZT7yl806vW7DvDoxwXi46jsjFbg+WdwotBIk6/MbEhO/dh5aZ5sNj/dWQ==", + "requires": { + "mime-db": "1.43.0" + } + }, + "mimic-fn": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-fn/-/mimic-fn-2.1.0.tgz", + "integrity": "sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==" + }, + "mimic-response": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/mimic-response/-/mimic-response-2.1.0.tgz", + "integrity": "sha512-wXqjST+SLt7R009ySCglWBCFpjUygmCIfD790/kVbiGmUgfYGuB14PiTd5DwVxSV4NcYHjzMkoj5LjQZwTQLEA==", + "optional": true + }, + "min-indent": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/min-indent/-/min-indent-1.0.0.tgz", + "integrity": "sha1-z8RcN+nsDY8KDsPdTvf3w6vjklY=" + }, + "mini-css-extract-plugin": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/mini-css-extract-plugin/-/mini-css-extract-plugin-0.9.0.tgz", + "integrity": "sha512-lp3GeY7ygcgAmVIcRPBVhIkf8Us7FZjA+ILpal44qLdSu11wmjKQ3d9k15lfD7pO4esu9eUIAW7qiYIBppv40A==", + "requires": { + "loader-utils": "^1.1.0", + "normalize-url": "1.9.1", + "schema-utils": "^1.0.0", + "webpack-sources": "^1.1.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "minimalistic-assert": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-assert/-/minimalistic-assert-1.0.1.tgz", + "integrity": "sha512-UtJcAD4yEaGtjPezWuO9wC4nwUnVH/8/Im3yEHQP4b67cXlD/Qr9hdITCU1xDbSEXg2XKNaP8jsReV7vQd00/A==" + }, + "minimalistic-crypto-utils": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/minimalistic-crypto-utils/-/minimalistic-crypto-utils-1.0.1.tgz", + "integrity": "sha1-9sAMHAsIIkblxNmd+4x8CDsrWCo=" + }, + "minimatch": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.0.4.tgz", + "integrity": "sha512-yJHVQEhyqPLUTgt9B83PXu6W3rx4MvvHvSUvToogpwoGDOUQ+yDrR0HRot+yOCdCO7u4hX3pWft6kWBBcqh0UA==", + "requires": { + "brace-expansion": "^1.1.7" + } + }, + "minimist": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-1.2.0.tgz", + "integrity": "sha1-o1AIsg9BOD7sH7kU9M1d95omQoQ=" + }, + "minipass": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-3.1.1.tgz", + "integrity": "sha512-UFqVihv6PQgwj8/yTGvl9kPz7xIAY+R5z6XYjRInD3Gk3qx6QGSD6zEcpeG4Dy/lQnv1J6zv8ejV90hyYIKf3w==", + "requires": { + "yallist": "^4.0.0" + } + }, + "minipass-collect": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/minipass-collect/-/minipass-collect-1.0.2.tgz", + "integrity": "sha512-6T6lH0H8OG9kITm/Jm6tdooIbogG9e0tLgpY6mphXSm/A9u8Nq1ryBG+Qspiub9LjWlBPsPS3tWQ/Botq4FdxA==", + "requires": { + "minipass": "^3.0.0" + } + }, + "minipass-flush": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/minipass-flush/-/minipass-flush-1.0.5.tgz", + "integrity": "sha512-JmQSYYpPUqX5Jyn1mXaRwOda1uQ8HP5KAT/oDSLCzt1BYRhQU0/hDtsB1ufZfEEzMZ9aAVmsBw8+FWsIXlClWw==", + "requires": { + "minipass": "^3.0.0" + } + }, + "minipass-pipeline": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/minipass-pipeline/-/minipass-pipeline-1.2.2.tgz", + "integrity": "sha512-3JS5A2DKhD2g0Gg8x3yamO0pj7YeKGwVlDS90pF++kxptwx/F+B//roxf9SqYil5tQo65bijy+dAuAFZmYOouA==", + "requires": { + "minipass": "^3.0.0" + } + }, + "minizlib": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/minizlib/-/minizlib-1.3.3.tgz", + "integrity": "sha512-6ZYMOEnmVsdCeTJVE0W9ZD+pVnE8h9Hma/iOwwRDsdQoePpoX56/8B6z3P9VNwppJuBKNRuFDRNRqRWexT9G9Q==", + "optional": true, + "requires": { + "minipass": "^2.9.0" + }, + "dependencies": { + "minipass": { + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", + "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", + "optional": true, + "requires": { + "safe-buffer": "^5.1.2", + "yallist": "^3.0.0" + } + }, + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "optional": true + } + } + }, + "mississippi": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/mississippi/-/mississippi-3.0.0.tgz", + "integrity": "sha512-x471SsVjUtBRtcvd4BzKE9kFC+/2TeWgKCgw0bZcw1b9l2X3QX5vCWgF+KaZaYm87Ss//rHnWryupDrgLvmSkA==", + "requires": { + "concat-stream": "^1.5.0", + "duplexify": "^3.4.2", + "end-of-stream": "^1.1.0", + "flush-write-stream": "^1.0.0", + "from2": "^2.1.0", + "parallel-transform": "^1.1.0", + "pump": "^3.0.0", + "pumpify": "^1.3.3", + "stream-each": "^1.1.0", + "through2": "^2.0.0" + } + }, + "mixin-deep": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/mixin-deep/-/mixin-deep-1.3.2.tgz", + "integrity": "sha512-WRoDn//mXBiJ1H40rqa3vH0toePwSsGb45iInWlTySa+Uu4k3tYUSxa2v1KqAiLtvlrSzaExqS1gtk96A9zvEA==", + "requires": { + "for-in": "^1.0.2", + "is-extendable": "^1.0.1" + }, + "dependencies": { + "is-extendable": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-extendable/-/is-extendable-1.0.1.tgz", + "integrity": "sha512-arnXMxT1hhoKo9k1LZdmlNyJdDDfy2v0fXjFlmok4+i8ul/6WlbVge9bhM74OpNPQPMGUToDtz+KXa1PneJxOA==", + "requires": { + "is-plain-object": "^2.0.4" + } + } + } + }, + "mixin-object": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mixin-object/-/mixin-object-2.0.1.tgz", + "integrity": "sha1-T7lJRB2rGCVA8f4DW6YOGUel5X4=", + "requires": { + "for-in": "^0.1.3", + "is-extendable": "^0.1.1" + }, + "dependencies": { + "for-in": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/for-in/-/for-in-0.1.8.tgz", + "integrity": "sha1-2Hc5COMSVhCZUrH9ubP6hn0ndeE=" + } + } + }, + "mkdirp": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/mkdirp/-/mkdirp-0.5.1.tgz", + "integrity": "sha1-MAV0OOrGz3+MR2fzhkjWaX11yQM=", + "requires": { + "minimist": "0.0.8" + }, + "dependencies": { + "minimist": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/minimist/-/minimist-0.0.8.tgz", + "integrity": "sha1-hX/Kv8M5fSYluCKCYuhqp6ARsF0=" + } + } + }, + "move-concurrently": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/move-concurrently/-/move-concurrently-1.0.1.tgz", + "integrity": "sha1-viwAX9oy4LKa8fBdfEszIUxwH5I=", + "requires": { + "aproba": "^1.1.1", + "copy-concurrently": "^1.0.0", + "fs-write-stream-atomic": "^1.0.8", + "mkdirp": "^0.5.1", + "rimraf": "^2.5.4", + "run-queue": "^1.0.3" + } + }, + "ms": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", + "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" + }, + "multicast-dns": { + "version": "6.2.3", + "resolved": "https://registry.npmjs.org/multicast-dns/-/multicast-dns-6.2.3.tgz", + "integrity": "sha512-ji6J5enbMyGRHIAkAOu3WdV8nggqviKCEKtXcOqfphZZtQrmHKycfynJ2V7eVPUA4NhJ6V7Wf4TmGbTwKE9B6g==", + "requires": { + "dns-packet": "^1.3.1", + "thunky": "^1.0.2" + } + }, + "multicast-dns-service-types": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/multicast-dns-service-types/-/multicast-dns-service-types-1.1.0.tgz", + "integrity": "sha1-iZ8R2WhuXgXLkbNdXw5jt3PPyQE=" + }, + "mute-stream": { + "version": "0.0.8", + "resolved": "https://registry.npmjs.org/mute-stream/-/mute-stream-0.0.8.tgz", + "integrity": "sha512-nnbWWOkoWyUsTjKrhgD0dcz22mdkSnpYqbEjIm2nhwhuxlSkpywJmBo8h0ZqJdkp73mb90SssHkN4rsRaBAfAA==" + }, + "nan": { + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/nan/-/nan-2.14.0.tgz", + "integrity": "sha512-INOFj37C7k3AfaNTtX8RhsTw7qRy7eLET14cROi9+5HAVbbHuIWUHEauBv5qT4Av2tWasiTY1Jw6puUNqRJXQg==", + "optional": true + }, + "nanomatch": { + "version": "1.2.13", + "resolved": "https://registry.npmjs.org/nanomatch/-/nanomatch-1.2.13.tgz", + "integrity": "sha512-fpoe2T0RbHwBTBUOftAfBPaDEi06ufaUai0mE6Yn1kacc3SnTErfb/h+X94VXzI64rKFHYImXSvdwGGCmwOqCA==", + "requires": { + "arr-diff": "^4.0.0", + "array-unique": "^0.3.2", + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "fragment-cache": "^0.2.1", + "is-windows": "^1.0.2", + "kind-of": "^6.0.2", + "object.pick": "^1.3.0", + "regex-not": "^1.0.0", + "snapdragon": "^0.8.1", + "to-regex": "^3.0.1" + }, + "dependencies": { + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "natural-compare": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/natural-compare/-/natural-compare-1.4.0.tgz", + "integrity": "sha1-Sr6/7tdUHywnrPspvbvRXI1bpPc=" + }, + "needle": { + "version": "2.3.2", + "resolved": "https://registry.npmjs.org/needle/-/needle-2.3.2.tgz", + "integrity": "sha512-DUzITvPVDUy6vczKKYTnWc/pBZ0EnjMJnQ3y+Jo5zfKFimJs7S3HFCxCRZYB9FUZcrzUQr3WsmvZgddMEIZv6w==", + "optional": true, + "requires": { + "debug": "^3.2.6", + "iconv-lite": "^0.4.4", + "sax": "^1.2.4" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "optional": true, + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "negotiator": { + "version": "0.6.2", + "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.2.tgz", + "integrity": "sha512-hZXc7K2e+PgeI1eDBe/10Ard4ekbfrrqG8Ep+8Jmf4JID2bNg7NvCPOZN+kfF574pFQI7mum2AUqDidoKqcTOw==" + }, + "neo-async": { + "version": "2.6.1", + "resolved": "https://registry.npmjs.org/neo-async/-/neo-async-2.6.1.tgz", + "integrity": "sha512-iyam8fBuCUpWeKPGpaNMetEocMt364qkCsfL9JuhjXX6dRnguRVOfk2GZaDpPjcOKiiXCPINZC1GczQ7iTq3Zw==" + }, + "next-tick": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/next-tick/-/next-tick-1.0.0.tgz", + "integrity": "sha1-yobR/ogoFpsBICCOPchCS524NCw=" + }, + "nice-try": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/nice-try/-/nice-try-1.0.5.tgz", + "integrity": "sha512-1nh45deeb5olNY7eX82BkPO7SSxR5SSYJiPTrTdFUVYwAl8CKMA5N9PjTYkHiRjisVcxcQ1HXdLhx2qxxJzLNQ==" + }, + "no-case": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/no-case/-/no-case-3.0.3.tgz", + "integrity": "sha512-ehY/mVQCf9BL0gKfsJBvFJen+1V//U+0HQMPrWct40ixE4jnv0bfvxDbWtAHL9EcaPEOJHVVYKoQn1TlZUB8Tw==", + "requires": { + "lower-case": "^2.0.1", + "tslib": "^1.10.0" + } + }, + "node-forge": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/node-forge/-/node-forge-0.9.0.tgz", + "integrity": "sha512-7ASaDa3pD+lJ3WvXFsxekJQelBKRpne+GOVbLbtHYdd7pFspyeuJHnWfLplGf3SwKGbfs/aYl5V/JCIaHVUKKQ==" + }, + "node-int64": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/node-int64/-/node-int64-0.4.0.tgz", + "integrity": "sha1-h6kGXNs1XTGC2PlM4RGIuCXGijs=" + }, + "node-libs-browser": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/node-libs-browser/-/node-libs-browser-2.2.1.tgz", + "integrity": "sha512-h/zcD8H9kaDZ9ALUWwlBUDo6TKF8a7qBSCSEGfjTVIYeqsioSKaAX+BN7NgiMGp6iSIXZ3PxgCu8KS3b71YK5Q==", + "requires": { + "assert": "^1.1.1", + "browserify-zlib": "^0.2.0", + "buffer": "^4.3.0", + "console-browserify": "^1.1.0", + "constants-browserify": "^1.0.0", + "crypto-browserify": "^3.11.0", + "domain-browser": "^1.1.1", + "events": "^3.0.0", + "https-browserify": "^1.0.0", + "os-browserify": "^0.3.0", + "path-browserify": "0.0.1", + "process": "^0.11.10", + "punycode": "^1.2.4", + "querystring-es3": "^0.2.0", + "readable-stream": "^2.3.3", + "stream-browserify": "^2.0.1", + "stream-http": "^2.7.2", + "string_decoder": "^1.0.0", + "timers-browserify": "^2.0.4", + "tty-browserify": "0.0.0", + "url": "^0.11.0", + "util": "^0.11.0", + "vm-browserify": "^1.0.1" + }, + "dependencies": { + "punycode": { + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.4.1.tgz", + "integrity": "sha1-wNWmOycYgArY4esPpSachN1BhF4=" + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + }, + "dependencies": { + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "util": { + "version": "0.11.1", + "resolved": "https://registry.npmjs.org/util/-/util-0.11.1.tgz", + "integrity": "sha512-HShAsny+zS2TZfaXxD9tYj4HQGlBezXZMZuM/S5PKLLoZkShZiGk9o5CzukI1LVHZvjdvZ2Sj1aW/Ndn2NB/HQ==", + "requires": { + "inherits": "2.0.3" + }, + "dependencies": { + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + } + } + } + } + }, + "node-modules-regexp": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/node-modules-regexp/-/node-modules-regexp-1.0.0.tgz", + "integrity": "sha1-jZ2+KJZKSsVxLpExZCEHxx6Q7EA=" + }, + "node-notifier": { + "version": "5.4.3", + "resolved": "https://registry.npmjs.org/node-notifier/-/node-notifier-5.4.3.tgz", + "integrity": "sha512-M4UBGcs4jeOK9CjTsYwkvH6/MzuUmGCyTW+kCY7uO+1ZVr0+FHGdPdIf5CCLqAaxnRrWidyoQlNkMIIVwbKB8Q==", + "requires": { + "growly": "^1.3.0", + "is-wsl": "^1.1.0", + "semver": "^5.5.0", + "shellwords": "^0.1.1", + "which": "^1.3.0" + } + }, + "node-pre-gyp": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/node-pre-gyp/-/node-pre-gyp-0.11.0.tgz", + "integrity": "sha512-TwWAOZb0j7e9eGaf9esRx3ZcLaE5tQ2lvYy1pb5IAaG1a2e2Kv5Lms1Y4hpj+ciXJRofIxxlt5haeQ/2ANeE0Q==", + "optional": true, + "requires": { + "detect-libc": "^1.0.2", + "mkdirp": "^0.5.1", + "needle": "^2.2.1", + "nopt": "^4.0.1", + "npm-packlist": "^1.1.6", + "npmlog": "^4.0.2", + "rc": "^1.2.7", + "rimraf": "^2.6.1", + "semver": "^5.3.0", + "tar": "^4" + } + }, + "node-releases": { + "version": "1.1.50", + "resolved": "https://registry.npmjs.org/node-releases/-/node-releases-1.1.50.tgz", + "integrity": "sha512-lgAmPv9eYZ0bGwUYAKlr8MG6K4CvWliWqnkcT2P8mMAgVrH3lqfBPorFlxiG1pHQnqmavJZ9vbMXUTNyMLbrgQ==", + "requires": { + "semver": "^6.3.0" + }, + "dependencies": { + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "nopt": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/nopt/-/nopt-4.0.1.tgz", + "integrity": "sha1-0NRoWv1UFRk8jHUFYC0NF81kR00=", + "optional": true, + "requires": { + "abbrev": "1", + "osenv": "^0.1.4" + } + }, + "normalize-package-data": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/normalize-package-data/-/normalize-package-data-2.5.0.tgz", + "integrity": "sha512-/5CMN3T0R4XTj4DcGaexo+roZSdSFW/0AOOTROrjxzCG1wrWXEsGbRKevjlIL+ZDE4sZlJr5ED4YW0yqmkK+eA==", + "requires": { + "hosted-git-info": "^2.1.4", + "resolve": "^1.10.0", + "semver": "2 || 3 || 4 || 5", + "validate-npm-package-license": "^3.0.1" + } + }, + "normalize-path": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", + "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==" + }, + "normalize-range": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/normalize-range/-/normalize-range-0.1.2.tgz", + "integrity": "sha1-LRDAa9/TEuqXd2laTShDlFa3WUI=" + }, + "normalize-url": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-1.9.1.tgz", + "integrity": "sha1-LMDWazHqIwNkWENuNiDYWVTGbDw=", + "requires": { + "object-assign": "^4.0.1", + "prepend-http": "^1.0.0", + "query-string": "^4.1.0", + "sort-keys": "^1.0.0" + } + }, + "npm-bundled": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/npm-bundled/-/npm-bundled-1.1.1.tgz", + "integrity": "sha512-gqkfgGePhTpAEgUsGEgcq1rqPXA+tv/aVBlgEzfXwA1yiUJF7xtEt3CtVwOjNYQOVknDk0F20w58Fnm3EtG0fA==", + "optional": true, + "requires": { + "npm-normalize-package-bin": "^1.0.1" + } + }, + "npm-normalize-package-bin": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/npm-normalize-package-bin/-/npm-normalize-package-bin-1.0.1.tgz", + "integrity": "sha512-EPfafl6JL5/rU+ot6P3gRSCpPDW5VmIzX959Ob1+ySFUuuYHWHekXpwdUZcKP5C+DS4GEtdJluwBjnsNDl+fSA==", + "optional": true + }, + "npm-packlist": { + "version": "1.4.8", + "resolved": "https://registry.npmjs.org/npm-packlist/-/npm-packlist-1.4.8.tgz", + "integrity": "sha512-5+AZgwru5IevF5ZdnFglB5wNlHG1AOOuw28WhUq8/8emhBmLv6jX5by4WJCh7lW0uSYZYS6DXqIsyZVIXRZU9A==", + "optional": true, + "requires": { + "ignore-walk": "^3.0.1", + "npm-bundled": "^1.0.1", + "npm-normalize-package-bin": "^1.0.1" + } + }, + "npm-run-path": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/npm-run-path/-/npm-run-path-2.0.2.tgz", + "integrity": "sha1-NakjLfo11wZ7TLLd8jV7GHFTbF8=", + "requires": { + "path-key": "^2.0.0" + } + }, + "npmlog": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/npmlog/-/npmlog-4.1.2.tgz", + "integrity": "sha512-2uUqazuKlTaSI/dC8AzicUck7+IrEaOnN/e0jd3Xtt1KcGpwx30v50mL7oPyr/h9bL3E4aZccVwpwP+5W9Vjkg==", + "optional": true, + "requires": { + "are-we-there-yet": "~1.1.2", + "console-control-strings": "~1.1.0", + "gauge": "~2.7.3", + "set-blocking": "~2.0.0" + } + }, + "nth-check": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/nth-check/-/nth-check-1.0.2.tgz", + "integrity": "sha512-WeBOdju8SnzPN5vTUJYxYUxLeXpCaVP5i5e0LF8fg7WORF2Wd7wFX/pk0tYZk7s8T+J7VLy0Da6J1+wCT0AtHg==", + "requires": { + "boolbase": "~1.0.0" + } + }, + "num2fraction": { + "version": "1.2.2", + "resolved": "https://registry.npmjs.org/num2fraction/-/num2fraction-1.2.2.tgz", + "integrity": "sha1-b2gragJ6Tp3fpFZM0lidHU5mnt4=" + }, + "number-is-nan": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/number-is-nan/-/number-is-nan-1.0.1.tgz", + "integrity": "sha1-CXtgK1NCKlIsGvuHkDGDNpQaAR0=" + }, + "nwsapi": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/nwsapi/-/nwsapi-2.2.0.tgz", + "integrity": "sha512-h2AatdwYH+JHiZpv7pt/gSX1XoRGb7L/qSIeuqA6GwYoF9w1vP1cw42TO0aI2pNyshRK5893hNSl+1//vHK7hQ==" + }, + "oauth-sign": { + "version": "0.9.0", + "resolved": "https://registry.npmjs.org/oauth-sign/-/oauth-sign-0.9.0.tgz", + "integrity": "sha512-fexhUFFPTGV8ybAtSIGbV6gOkSv8UtRbDBnAyLQw4QPKkgNlsH2ByPGtMUqdWkos6YCRmAqViwgZrJc/mRDzZQ==" + }, + "object-assign": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", + "integrity": "sha1-IQmtx5ZYh8/AXLvUQsrIv7s2CGM=" + }, + "object-copy": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/object-copy/-/object-copy-0.1.0.tgz", + "integrity": "sha1-fn2Fi3gb18mRpBupde04EnVOmYw=", + "requires": { + "copy-descriptor": "^0.1.0", + "define-property": "^0.2.5", + "kind-of": "^3.0.3" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "object-hash": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/object-hash/-/object-hash-2.0.3.tgz", + "integrity": "sha512-JPKn0GMu+Fa3zt3Bmr66JhokJU5BaNBIh4ZeTlaCBzrBsOeXzwcKKAK1tbLiPKgvwmPXsDvvLHoWh5Bm7ofIYg==" + }, + "object-inspect": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.7.0.tgz", + "integrity": "sha512-a7pEHdh1xKIAgTySUGgLMx/xwDZskN1Ud6egYYN3EdRW4ZMPNEDUTF+hwy2LUC+Bl+SyLXANnwz/jyh/qutKUw==" + }, + "object-is": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/object-is/-/object-is-1.0.2.tgz", + "integrity": "sha512-Epah+btZd5wrrfjkJZq1AOB9O6OxUQto45hzFd7lXGrpHPGE0W1k+426yrZV+k6NJOzLNNW/nVsmZdIWsAqoOQ==" + }, + "object-keys": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object-keys/-/object-keys-1.1.1.tgz", + "integrity": "sha512-NuAESUOUMrlIXOfHKzD6bpPu3tYt3xvjNdRIQ+FeT0lNb4K8WR70CaDxhuNguS2XG+GjkyMwOzsN5ZktImfhLA==" + }, + "object-path": { + "version": "0.11.4", + "resolved": "https://registry.npmjs.org/object-path/-/object-path-0.11.4.tgz", + "integrity": "sha1-NwrnUvvzfePqcKhhwju6iRVpGUk=" + }, + "object-visit": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/object-visit/-/object-visit-1.0.1.tgz", + "integrity": "sha1-95xEk68MU3e1n+OdOV5BBC3QRbs=", + "requires": { + "isobject": "^3.0.0" + } + }, + "object.assign": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/object.assign/-/object.assign-4.1.0.tgz", + "integrity": "sha512-exHJeq6kBKj58mqGyTQ9DFvrZC/eR6OwxzoM9YRoGBqrXYonaFyGiFMuc9VZrXf7DarreEwMpurG3dd+CNyW5w==", + "requires": { + "define-properties": "^1.1.2", + "function-bind": "^1.1.1", + "has-symbols": "^1.0.0", + "object-keys": "^1.0.11" + } + }, + "object.entries": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object.entries/-/object.entries-1.1.1.tgz", + "integrity": "sha512-ilqR7BgdyZetJutmDPfXCDffGa0/Yzl2ivVNpbx/g4UeWrCdRnFDUBrKJGLhGieRHDATnyZXWBeCb29k9CJysQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, + "object.fromentries": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/object.fromentries/-/object.fromentries-2.0.2.tgz", + "integrity": "sha512-r3ZiBH7MQppDJVLx6fhD618GKNG40CZYH9wgwdhKxBDDbQgjeWGGd4AtkZad84d291YxvWe7bJGuE65Anh0dxQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, + "object.getownpropertydescriptors": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/object.getownpropertydescriptors/-/object.getownpropertydescriptors-2.1.0.tgz", + "integrity": "sha512-Z53Oah9A3TdLoblT7VKJaTDdXdT+lQO+cNpKVnya5JDe9uLvzu1YyY1yFDFrcxrlRgWrEFH0jJtD/IbuwjcEVg==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1" + } + }, + "object.pick": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/object.pick/-/object.pick-1.3.0.tgz", + "integrity": "sha1-h6EKxMFpS9Lhy/U1kaZhQftd10c=", + "requires": { + "isobject": "^3.0.1" + } + }, + "object.values": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/object.values/-/object.values-1.1.1.tgz", + "integrity": "sha512-WTa54g2K8iu0kmS/us18jEmdv1a4Wi//BZ/DTVYEcH0XhLM5NYdpDHja3gt57VrZLcNAO2WGA+KpWsDBaHt6eA==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1", + "function-bind": "^1.1.1", + "has": "^1.0.3" + } + }, + "obuf": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/obuf/-/obuf-1.1.2.tgz", + "integrity": "sha512-PX1wu0AmAdPqOL1mWhqmlOd8kOIZQwGZw6rh7uby9fTc5lhaOWFLX3I6R1hrF9k3zUY40e6igsLGkDXK92LJNg==" + }, + "on-finished": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.3.0.tgz", + "integrity": "sha1-IPEzZIGwg811M3mSoWlxqi2QaUc=", + "requires": { + "ee-first": "1.1.1" + } + }, + "on-headers": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/on-headers/-/on-headers-1.0.2.tgz", + "integrity": "sha512-pZAE+FJLoyITytdqK0U5s+FIpjN0JP3OzFi/u8Rx+EV5/W+JTWGXG8xFzevE7AjBfDqHv/8vL8qQsIhHnqRkrA==" + }, + "once": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/once/-/once-1.4.0.tgz", + "integrity": "sha1-WDsap3WWHUsROsF9nFC6753Xa9E=", + "requires": { + "wrappy": "1" + } + }, + "onetime": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/onetime/-/onetime-5.1.0.tgz", + "integrity": "sha512-5NcSkPHhwTVFIQN+TUqXoS5+dlElHXdpAWu9I0HP20YOtIi+aZ0Ct82jdlILDxjLEAWwvm+qj1m6aEtsDVmm6Q==", + "requires": { + "mimic-fn": "^2.1.0" + } + }, + "open": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/open/-/open-7.0.2.tgz", + "integrity": "sha512-70E/pFTPr7nZ9nLDPNTcj3IVqnNvKuP4VsBmoKV9YGTnChe0mlS3C4qM7qKarhZ8rGaHKLfo+vBTHXDp6ZSyLQ==", + "requires": { + "is-docker": "^2.0.0", + "is-wsl": "^2.1.1" + }, + "dependencies": { + "is-wsl": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/is-wsl/-/is-wsl-2.1.1.tgz", + "integrity": "sha512-umZHcSrwlDHo2TGMXv0DZ8dIUGunZ2Iv68YZnrmCiBPkZ4aaOhtv7pXJKeki9k3qJ3RJr0cDyitcl5wEH3AYog==" + } + } + }, + "opn": { + "version": "5.5.0", + "resolved": "https://registry.npmjs.org/opn/-/opn-5.5.0.tgz", + "integrity": "sha512-PqHpggC9bLV0VeWcdKhkpxY+3JTzetLSqTCWL/z/tFIbI6G8JCjondXklT1JinczLz2Xib62sSp0T/gKT4KksA==", + "requires": { + "is-wsl": "^1.1.0" + } + }, + "optimize-css-assets-webpack-plugin": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/optimize-css-assets-webpack-plugin/-/optimize-css-assets-webpack-plugin-5.0.3.tgz", + "integrity": "sha512-q9fbvCRS6EYtUKKSwI87qm2IxlyJK5b4dygW1rKUBT6mMDhdG5e5bZT63v6tnJR9F9FB/H5a0HTmtw+laUBxKA==", + "requires": { + "cssnano": "^4.1.10", + "last-call-webpack-plugin": "^3.0.0" + } + }, + "optionator": { + "version": "0.8.3", + "resolved": "https://registry.npmjs.org/optionator/-/optionator-0.8.3.tgz", + "integrity": "sha512-+IW9pACdk3XWmmTXG8m3upGUJst5XRGzxMRjXzAuJ1XnIFNvfhjjIuYkDvysnPQ7qzqVzLt78BCruntqRhWQbA==", + "requires": { + "deep-is": "~0.1.3", + "fast-levenshtein": "~2.0.6", + "levn": "~0.3.0", + "prelude-ls": "~1.1.2", + "type-check": "~0.3.2", + "word-wrap": "~1.2.3" + } + }, + "original": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/original/-/original-1.0.2.tgz", + "integrity": "sha512-hyBVl6iqqUOJ8FqRe+l/gS8H+kKYjrEndd5Pm1MfBtsEKA038HkkdbAl/72EAXGyonD/PFsvmVG+EvcIpliMBg==", + "requires": { + "url-parse": "^1.4.3" + } + }, + "os-browserify": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/os-browserify/-/os-browserify-0.3.0.tgz", + "integrity": "sha1-hUNzx/XCMVkU/Jv8a9gjj92h7Cc=" + }, + "os-homedir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-homedir/-/os-homedir-1.0.2.tgz", + "integrity": "sha1-/7xJiDNuDoM94MFox+8VISGqf7M=", + "optional": true + }, + "os-locale": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/os-locale/-/os-locale-3.1.0.tgz", + "integrity": "sha512-Z8l3R4wYWM40/52Z+S265okfFj8Kt2cC2MKY+xNi3kFs+XGI7WXu/I309QQQYbRW4ijiZ+yxs9pqEhJh0DqW3Q==", + "requires": { + "execa": "^1.0.0", + "lcid": "^2.0.0", + "mem": "^4.0.0" + } + }, + "os-tmpdir": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/os-tmpdir/-/os-tmpdir-1.0.2.tgz", + "integrity": "sha1-u+Z0BseaqFxc/sdm/lc0VV36EnQ=" + }, + "osenv": { + "version": "0.1.5", + "resolved": "https://registry.npmjs.org/osenv/-/osenv-0.1.5.tgz", + "integrity": "sha512-0CWcCECdMVc2Rw3U5w9ZjqX6ga6ubk1xDVKxtBQPK7wis/0F2r9T6k4ydGYhecl7YUBxBVxhL5oisPsNxAPe2g==", + "optional": true, + "requires": { + "os-homedir": "^1.0.0", + "os-tmpdir": "^1.0.0" + } + }, + "p-defer": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-defer/-/p-defer-1.0.0.tgz", + "integrity": "sha1-n26xgvbJqozXQwBKfU+WsZaw+ww=" + }, + "p-each-series": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-each-series/-/p-each-series-1.0.0.tgz", + "integrity": "sha1-kw89Et0fUOdDRFeiLNbwSsatf3E=", + "requires": { + "p-reduce": "^1.0.0" + } + }, + "p-finally": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-finally/-/p-finally-1.0.0.tgz", + "integrity": "sha1-P7z7FbiZpEEjs0ttzBi3JDNqLK4=" + }, + "p-is-promise": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/p-is-promise/-/p-is-promise-2.1.0.tgz", + "integrity": "sha512-Y3W0wlRPK8ZMRbNq97l4M5otioeA5lm1z7bkNkxCka8HSPjR0xRWmpCmc9utiaLP9Jb1eD8BgeIxTW4AIF45Pg==" + }, + "p-limit": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-2.2.2.tgz", + "integrity": "sha512-WGR+xHecKTr7EbUEhyLSh5Dube9JtdiG78ufaeLxTgpudf/20KqyMioIUZJAezlTIi6evxuoUs9YXc11cU+yzQ==", + "requires": { + "p-try": "^2.0.0" + } + }, + "p-locate": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-3.0.0.tgz", + "integrity": "sha512-x+12w/To+4GFfgJhBEpiDcLozRJGegY+Ei7/z0tSLkMmxGZNybVMSfWj9aJn8Z5Fc7dBUNJOOVgPv2H7IwulSQ==", + "requires": { + "p-limit": "^2.0.0" + } + }, + "p-map": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/p-map/-/p-map-3.0.0.tgz", + "integrity": "sha512-d3qXVTF/s+W+CdJ5A29wywV2n8CQQYahlgz2bFiA+4eVNJbHJodPZ+/gXwPGh0bOqA+j8S+6+ckmvLGPk1QpxQ==", + "requires": { + "aggregate-error": "^3.0.0" + } + }, + "p-reduce": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-reduce/-/p-reduce-1.0.0.tgz", + "integrity": "sha1-GMKw3ZNqRpClKfgjH1ig/bakffo=" + }, + "p-retry": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/p-retry/-/p-retry-3.0.1.tgz", + "integrity": "sha512-XE6G4+YTTkT2a0UWb2kjZe8xNwf8bIbnqpc/IS/idOBVhyves0mK5OJgeocjx7q5pvX/6m23xuzVPYT1uGM73w==", + "requires": { + "retry": "^0.12.0" + } + }, + "p-try": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-2.2.0.tgz", + "integrity": "sha512-R4nPAVTAU0B9D35/Gk3uJf/7XYbQcyohSKdvAxIRSNghFl4e71hVoGnBNQz9cWaXxO2I10KTC+3jMdvvoKw6dQ==" + }, + "pako": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/pako/-/pako-1.0.11.tgz", + "integrity": "sha512-4hLB8Py4zZce5s4yd9XzopqwVv/yGNhV1Bl8NTmCq1763HeK2+EwVTv+leGeL13Dnh2wfbqowVPXCIO0z4taYw==" + }, + "parallel-transform": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/parallel-transform/-/parallel-transform-1.2.0.tgz", + "integrity": "sha512-P2vSmIu38uIlvdcU7fDkyrxj33gTUy/ABO5ZUbGowxNCopBq/OoD42bP4UmMrJoPyk4Uqf0mu3mtWBhHCZD8yg==", + "requires": { + "cyclist": "^1.0.1", + "inherits": "^2.0.3", + "readable-stream": "^2.1.5" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "param-case": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/param-case/-/param-case-3.0.3.tgz", + "integrity": "sha512-VWBVyimc1+QrzappRs7waeN2YmoZFCGXWASRYX1/rGHtXqEcrGEIDm+jqIwFa2fRXNgQEwrxaYuIrX0WcAguTA==", + "requires": { + "dot-case": "^3.0.3", + "tslib": "^1.10.0" + } + }, + "parent-module": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/parent-module/-/parent-module-1.0.1.tgz", + "integrity": "sha512-GQ2EWRpQV8/o+Aw8YqtfZZPfNRWZYkbidE9k5rpl/hC3vtHHBfGm2Ifi6qWV+coDGkrUKZAxE3Lot5kcsRlh+g==", + "requires": { + "callsites": "^3.0.0" + } + }, + "parse-asn1": { + "version": "5.1.5", + "resolved": "https://registry.npmjs.org/parse-asn1/-/parse-asn1-5.1.5.tgz", + "integrity": "sha512-jkMYn1dcJqF6d5CpU689bq7w/b5ALS9ROVSpQDPrZsqqesUJii9qutvoT5ltGedNXMO2e16YUWIghG9KxaViTQ==", + "requires": { + "asn1.js": "^4.0.0", + "browserify-aes": "^1.0.0", + "create-hash": "^1.1.0", + "evp_bytestokey": "^1.0.0", + "pbkdf2": "^3.0.3", + "safe-buffer": "^5.1.1" + } + }, + "parse-json": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse-json/-/parse-json-4.0.0.tgz", + "integrity": "sha1-vjX1Qlvh9/bHRxhPmKeIy5lHfuA=", + "requires": { + "error-ex": "^1.3.1", + "json-parse-better-errors": "^1.0.1" + } + }, + "parse5": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-4.0.0.tgz", + "integrity": "sha512-VrZ7eOd3T1Fk4XWNXMgiGBK/z0MG48BWG2uQNU4I72fkQuKUTZpl+u9k+CxEG0twMVzSmXEEz12z5Fnw1jIQFA==" + }, + "parseurl": { + "version": "1.3.3", + "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", + "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==" + }, + "pascal-case": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/pascal-case/-/pascal-case-3.1.1.tgz", + "integrity": "sha512-XIeHKqIrsquVTQL2crjq3NfJUxmdLasn3TYOU0VBM+UX2a6ztAWBlJQBePLGY7VHW8+2dRadeIPK5+KImwTxQA==", + "requires": { + "no-case": "^3.0.3", + "tslib": "^1.10.0" + } + }, + "pascalcase": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/pascalcase/-/pascalcase-0.1.1.tgz", + "integrity": "sha1-s2PlXoAGym/iF4TS2yK9FdeRfxQ=" + }, + "path-browserify": { + "version": "0.0.1", + "resolved": "https://registry.npmjs.org/path-browserify/-/path-browserify-0.0.1.tgz", + "integrity": "sha512-BapA40NHICOS+USX9SN4tyhq+A2RrN/Ws5F0Z5aMHDp98Fl86lX8Oti8B7uN93L4Ifv4fHOEA+pQw87gmMO/lQ==" + }, + "path-dirname": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-dirname/-/path-dirname-1.0.2.tgz", + "integrity": "sha1-zDPSTVJeCZpTiMAzbG4yuRYGCeA=" + }, + "path-exists": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-3.0.0.tgz", + "integrity": "sha1-zg6+ql94yxiSXqfYENe1mwEP1RU=" + }, + "path-is-absolute": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/path-is-absolute/-/path-is-absolute-1.0.1.tgz", + "integrity": "sha1-F0uSaHNVNP+8es5r9TpanhtcX18=" + }, + "path-is-inside": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/path-is-inside/-/path-is-inside-1.0.2.tgz", + "integrity": "sha1-NlQX3t5EQw0cEa9hAn+s8HS9/FM=" + }, + "path-key": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-2.0.1.tgz", + "integrity": "sha1-QRyttXTFoUDTpLGRDUDYDMn0C0A=" + }, + "path-parse": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/path-parse/-/path-parse-1.0.6.tgz", + "integrity": "sha512-GSmOT2EbHrINBf9SR7CDELwlJ8AENk3Qn7OikK4nFYAu3Ote2+JYNVvkpAEQm3/TLNEJFD/xZJjzyxg3KBWOzw==" + }, + "path-to-regexp": { + "version": "0.1.7", + "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", + "integrity": "sha1-32BBeABfUi8V60SQ5yR6G/qmf4w=" + }, + "path-type": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-3.0.0.tgz", + "integrity": "sha512-T2ZUsdZFHgA3u4e5PfPbjd7HDDpxPnQb5jN0SrDsjNSuVXHJqtwTnWqG0B1jZrgmJ/7lj1EmVIByWt1gxGkWvg==", + "requires": { + "pify": "^3.0.0" + }, + "dependencies": { + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + } + } + }, + "pbkdf2": { + "version": "3.0.17", + "resolved": "https://registry.npmjs.org/pbkdf2/-/pbkdf2-3.0.17.tgz", + "integrity": "sha512-U/il5MsrZp7mGg3mSQfn742na2T+1/vHDCG5/iTI3X9MKUuYUZVLQhyRsg06mCgDBTd57TxzgZt7P+fYfjRLtA==", + "requires": { + "create-hash": "^1.1.2", + "create-hmac": "^1.1.4", + "ripemd160": "^2.0.1", + "safe-buffer": "^5.0.1", + "sha.js": "^2.4.8" + } + }, + "performance-now": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/performance-now/-/performance-now-2.1.0.tgz", + "integrity": "sha1-Ywn04OX6kT7BxpMHrjZLSzd8nns=" + }, + "picomatch": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.2.1.tgz", + "integrity": "sha512-ISBaA8xQNmwELC7eOjqFKMESB2VIqt4PPDD0nsS95b/9dZXvVKOlz9keMSnoGGKcOHXfTvDD6WMaRoSc9UuhRA==" + }, + "pify": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pify/-/pify-4.0.1.tgz", + "integrity": "sha512-uB80kBFb/tfd68bVleG9T5GGsGPjJrLAUpR5PZIrhBnIaRTQRjqdJSsIKkOP6OAIFbj7GOrcudc5pNjZ+geV2g==" + }, + "pinkie": { + "version": "2.0.4", + "resolved": "https://registry.npmjs.org/pinkie/-/pinkie-2.0.4.tgz", + "integrity": "sha1-clVrgM+g1IqXToDnckjoDtT3+HA=" + }, + "pinkie-promise": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pinkie-promise/-/pinkie-promise-2.0.1.tgz", + "integrity": "sha1-ITXW36ejWMBprJsXh3YogihFD/o=", + "requires": { + "pinkie": "^2.0.0" + } + }, + "pirates": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/pirates/-/pirates-4.0.1.tgz", + "integrity": "sha512-WuNqLTbMI3tmfef2TKxlQmAiLHKtFhlsCZnPIpuv2Ow0RDVO8lfy1Opf4NUzlMXLjPl+Men7AuVdX6TA+s+uGA==", + "requires": { + "node-modules-regexp": "^1.0.0" + } + }, + "pkg-dir": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-3.0.0.tgz", + "integrity": "sha512-/E57AYkoeQ25qkxMj5PBOVgF8Kiu/h7cYS30Z5+R7WaiCCBfLq58ZI/dSeaEKb9WVJV5n/03QwrN3IeWIFllvw==", + "requires": { + "find-up": "^3.0.0" + } + }, + "pkg-up": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/pkg-up/-/pkg-up-3.1.0.tgz", + "integrity": "sha512-nDywThFk1i4BQK4twPQ6TA4RT8bDY96yeuCVBWL3ePARCiEKDRSrNGbFIgUJpLp+XeIR65v8ra7WuJOFUBtkMA==", + "requires": { + "find-up": "^3.0.0" + } + }, + "pn": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/pn/-/pn-1.1.0.tgz", + "integrity": "sha512-2qHaIQr2VLRFoxe2nASzsV6ef4yOOH+Fi9FBOVH6cqeSgUnoyySPZkxzLuzd+RYOQTRpROA0ztTMqxROKSb/nA==" + }, + "pnp-webpack-plugin": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/pnp-webpack-plugin/-/pnp-webpack-plugin-1.6.0.tgz", + "integrity": "sha512-ZcMGn/xF/fCOq+9kWMP9vVVxjIkMCja72oy3lziR7UHy0hHFZ57iVpQ71OtveVbmzeCmphBg8pxNdk/hlK99aQ==", + "requires": { + "ts-pnp": "^1.1.2" + } + }, + "portfinder": { + "version": "1.0.25", + "resolved": "https://registry.npmjs.org/portfinder/-/portfinder-1.0.25.tgz", + "integrity": "sha512-6ElJnHBbxVA1XSLgBp7G1FiCkQdlqGzuF7DswL5tcea+E8UpuvPU7beVAjjRwCioTS9ZluNbu+ZyRvgTsmqEBg==", + "requires": { + "async": "^2.6.2", + "debug": "^3.1.1", + "mkdirp": "^0.5.1" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "posix-character-classes": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/posix-character-classes/-/posix-character-classes-0.1.1.tgz", + "integrity": "sha1-AerA/jta9xoqbAL+q7jB/vfgDqs=" + }, + "postcss": { + "version": "7.0.27", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.27.tgz", + "integrity": "sha512-WuQETPMcW9Uf1/22HWUWP9lgsIC+KEHg2kozMflKjbeUtw9ujvFX6QmIfozaErDkmLWS9WEnEdEe6Uo9/BNTdQ==", + "requires": { + "chalk": "^2.4.2", + "source-map": "^0.6.1", + "supports-color": "^6.1.0" + } + }, + "postcss-attribute-case-insensitive": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-attribute-case-insensitive/-/postcss-attribute-case-insensitive-4.0.2.tgz", + "integrity": "sha512-clkFxk/9pcdb4Vkn0hAHq3YnxBQ2p0CGD1dy24jN+reBck+EWxMbxSUqN4Yj7t0w8csl87K6p0gxBe1utkJsYA==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^6.0.2" + } + }, + "postcss-browser-comments": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-browser-comments/-/postcss-browser-comments-3.0.0.tgz", + "integrity": "sha512-qfVjLfq7HFd2e0HW4s1dvU8X080OZdG46fFbIBFjW7US7YPDcWfRvdElvwMJr2LI6hMmD+7LnH2HcmXTs+uOig==", + "requires": { + "postcss": "^7" + } + }, + "postcss-calc": { + "version": "7.0.2", + "resolved": "https://registry.npmjs.org/postcss-calc/-/postcss-calc-7.0.2.tgz", + "integrity": "sha512-rofZFHUg6ZIrvRwPeFktv06GdbDYLcGqh9EwiMutZg+a0oePCCw1zHOEiji6LCpyRcjTREtPASuUqeAvYlEVvQ==", + "requires": { + "postcss": "^7.0.27", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.0.2" + } + }, + "postcss-color-functional-notation": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/postcss-color-functional-notation/-/postcss-color-functional-notation-2.0.1.tgz", + "integrity": "sha512-ZBARCypjEDofW4P6IdPVTLhDNXPRn8T2s1zHbZidW6rPaaZvcnCS2soYFIQJrMZSxiePJ2XIYTlcb2ztr/eT2g==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-color-gray": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-color-gray/-/postcss-color-gray-5.0.0.tgz", + "integrity": "sha512-q6BuRnAGKM/ZRpfDascZlIZPjvwsRye7UDNalqVz3s7GDxMtqPY6+Q871liNxsonUw8oC61OG+PSaysYpl1bnw==", + "requires": { + "@csstools/convert-colors": "^1.4.0", + "postcss": "^7.0.5", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-color-hex-alpha": { + "version": "5.0.3", + "resolved": "https://registry.npmjs.org/postcss-color-hex-alpha/-/postcss-color-hex-alpha-5.0.3.tgz", + "integrity": "sha512-PF4GDel8q3kkreVXKLAGNpHKilXsZ6xuu+mOQMHWHLPNyjiUBOr75sp5ZKJfmv1MCus5/DWUGcK9hm6qHEnXYw==", + "requires": { + "postcss": "^7.0.14", + "postcss-values-parser": "^2.0.1" + } + }, + "postcss-color-mod-function": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/postcss-color-mod-function/-/postcss-color-mod-function-3.0.3.tgz", + "integrity": "sha512-YP4VG+xufxaVtzV6ZmhEtc+/aTXH3d0JLpnYfxqTvwZPbJhWqp8bSY3nfNzNRFLgB4XSaBA82OE4VjOOKpCdVQ==", + "requires": { + "@csstools/convert-colors": "^1.4.0", + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-color-rebeccapurple": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-color-rebeccapurple/-/postcss-color-rebeccapurple-4.0.1.tgz", + "integrity": "sha512-aAe3OhkS6qJXBbqzvZth2Au4V3KieR5sRQ4ptb2b2O8wgvB3SJBsdG+jsn2BZbbwekDG8nTfcCNKcSfe/lEy8g==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-colormin": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-colormin/-/postcss-colormin-4.0.3.tgz", + "integrity": "sha512-WyQFAdDZpExQh32j0U0feWisZ0dmOtPl44qYmJKkq9xFWY3p+4qnRzCHeNrkeRhwPHz9bQ3mo0/yVkaply0MNw==", + "requires": { + "browserslist": "^4.0.0", + "color": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-convert-values": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-convert-values/-/postcss-convert-values-4.0.1.tgz", + "integrity": "sha512-Kisdo1y77KUC0Jmn0OXU/COOJbzM8cImvw1ZFsBgBgMgb1iL23Zs/LXRe3r+EZqM3vGYKdQ2YJVQ5VkJI+zEJQ==", + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-custom-media": { + "version": "7.0.8", + "resolved": "https://registry.npmjs.org/postcss-custom-media/-/postcss-custom-media-7.0.8.tgz", + "integrity": "sha512-c9s5iX0Ge15o00HKbuRuTqNndsJUbaXdiNsksnVH8H4gdc+zbLzr/UasOwNG6CTDpLFekVY4672eWdiiWu2GUg==", + "requires": { + "postcss": "^7.0.14" + } + }, + "postcss-custom-properties": { + "version": "8.0.11", + "resolved": "https://registry.npmjs.org/postcss-custom-properties/-/postcss-custom-properties-8.0.11.tgz", + "integrity": "sha512-nm+o0eLdYqdnJ5abAJeXp4CEU1c1k+eB2yMCvhgzsds/e0umabFrN6HoTy/8Q4K5ilxERdl/JD1LO5ANoYBeMA==", + "requires": { + "postcss": "^7.0.17", + "postcss-values-parser": "^2.0.1" + } + }, + "postcss-custom-selectors": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/postcss-custom-selectors/-/postcss-custom-selectors-5.1.2.tgz", + "integrity": "sha512-DSGDhqinCqXqlS4R7KGxL1OSycd1lydugJ1ky4iRXPHdBRiozyMHrdu0H3o7qNOCiZwySZTUI5MV0T8QhCLu+w==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0-rc.3" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-dir-pseudo-class": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-dir-pseudo-class/-/postcss-dir-pseudo-class-5.0.0.tgz", + "integrity": "sha512-3pm4oq8HYWMZePJY+5ANriPs3P07q+LW6FAdTlkFH2XqDdP4HeeJYMOzn0HYLhRSjBO3fhiqSwwU9xEULSrPgw==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0-rc.3" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-discard-comments": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-comments/-/postcss-discard-comments-4.0.2.tgz", + "integrity": "sha512-RJutN259iuRf3IW7GZyLM5Sw4GLTOH8FmsXBnv8Ab/Tc2k4SR4qbV4DNbyyY4+Sjo362SyDmW2DQ7lBSChrpkg==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-duplicates": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-discard-duplicates/-/postcss-discard-duplicates-4.0.2.tgz", + "integrity": "sha512-ZNQfR1gPNAiXZhgENFfEglF93pciw0WxMkJeVmw8eF+JZBbMD7jp6C67GqJAXVZP2BWbOztKfbsdmMp/k8c6oQ==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-empty": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-empty/-/postcss-discard-empty-4.0.1.tgz", + "integrity": "sha512-B9miTzbznhDjTfjvipfHoqbWKwd0Mj+/fL5s1QOz06wufguil+Xheo4XpOnc4NqKYBCNqqEzgPv2aPBIJLox0w==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-discard-overridden": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-discard-overridden/-/postcss-discard-overridden-4.0.1.tgz", + "integrity": "sha512-IYY2bEDD7g1XM1IDEsUT4//iEYCxAmP5oDSFMVU/JVvT7gh+l4fmjciLqGgwjdWpQIdb0Che2VX00QObS5+cTg==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-double-position-gradients": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/postcss-double-position-gradients/-/postcss-double-position-gradients-1.0.0.tgz", + "integrity": "sha512-G+nV8EnQq25fOI8CH/B6krEohGWnF5+3A6H/+JEpOncu5dCnkS1QQ6+ct3Jkaepw1NGVqqOZH6lqrm244mCftA==", + "requires": { + "postcss": "^7.0.5", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-env-function": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/postcss-env-function/-/postcss-env-function-2.0.2.tgz", + "integrity": "sha512-rwac4BuZlITeUbiBq60h/xbLzXY43qOsIErngWa4l7Mt+RaSkT7QBjXVGTcBHupykkblHMDrBFh30zchYPaOUw==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-flexbugs-fixes": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/postcss-flexbugs-fixes/-/postcss-flexbugs-fixes-4.1.0.tgz", + "integrity": "sha512-jr1LHxQvStNNAHlgco6PzY308zvLklh7SJVYuWUwyUQncofaAlD2l+P/gxKHOdqWKe7xJSkVLFF/2Tp+JqMSZA==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-focus-visible": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-focus-visible/-/postcss-focus-visible-4.0.0.tgz", + "integrity": "sha512-Z5CkWBw0+idJHSV6+Bgf2peDOFf/x4o+vX/pwcNYrWpXFrSfTkQ3JQ1ojrq9yS+upnAlNRHeg8uEwFTgorjI8g==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-focus-within": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-focus-within/-/postcss-focus-within-3.0.0.tgz", + "integrity": "sha512-W0APui8jQeBKbCGZudW37EeMCjDeVxKgiYfIIEo8Bdh5SpB9sxds/Iq8SEuzS0Q4YFOlG7EPFulbbxujpkrV2w==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-font-variant": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-font-variant/-/postcss-font-variant-4.0.0.tgz", + "integrity": "sha512-M8BFYKOvCrI2aITzDad7kWuXXTm0YhGdP9Q8HanmN4EF1Hmcgs1KK5rSHylt/lUJe8yLxiSwWAHdScoEiIxztg==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-gap-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-gap-properties/-/postcss-gap-properties-2.0.0.tgz", + "integrity": "sha512-QZSqDaMgXCHuHTEzMsS2KfVDOq7ZFiknSpkrPJY6jmxbugUPTuSzs/vuE5I3zv0WAS+3vhrlqhijiprnuQfzmg==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-image-set-function": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/postcss-image-set-function/-/postcss-image-set-function-3.0.1.tgz", + "integrity": "sha512-oPTcFFip5LZy8Y/whto91L9xdRHCWEMs3e1MdJxhgt4jy2WYXfhkng59fH5qLXSCPN8k4n94p1Czrfe5IOkKUw==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-initial": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/postcss-initial/-/postcss-initial-3.0.2.tgz", + "integrity": "sha512-ugA2wKonC0xeNHgirR4D3VWHs2JcU08WAi1KFLVcnb7IN89phID6Qtg2RIctWbnvp1TM2BOmDtX8GGLCKdR8YA==", + "requires": { + "lodash.template": "^4.5.0", + "postcss": "^7.0.2" + } + }, + "postcss-lab-function": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/postcss-lab-function/-/postcss-lab-function-2.0.1.tgz", + "integrity": "sha512-whLy1IeZKY+3fYdqQFuDBf8Auw+qFuVnChWjmxm/UhHWqNHZx+B99EwxTvGYmUBqe3Fjxs4L1BoZTJmPu6usVg==", + "requires": { + "@csstools/convert-colors": "^1.4.0", + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-load-config": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/postcss-load-config/-/postcss-load-config-2.1.0.tgz", + "integrity": "sha512-4pV3JJVPLd5+RueiVVB+gFOAa7GWc25XQcMp86Zexzke69mKf6Nx9LRcQywdz7yZI9n1udOxmLuAwTBypypF8Q==", + "requires": { + "cosmiconfig": "^5.0.0", + "import-cwd": "^2.0.0" + } + }, + "postcss-loader": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-loader/-/postcss-loader-3.0.0.tgz", + "integrity": "sha512-cLWoDEY5OwHcAjDnkyRQzAXfs2jrKjXpO/HQFcc5b5u/r7aa471wdmChmwfnv7x2u840iat/wi0lQ5nbRgSkUA==", + "requires": { + "loader-utils": "^1.1.0", + "postcss": "^7.0.0", + "postcss-load-config": "^2.0.0", + "schema-utils": "^1.0.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "postcss-logical": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-logical/-/postcss-logical-3.0.0.tgz", + "integrity": "sha512-1SUKdJc2vuMOmeItqGuNaC+N8MzBWFWEkAnRnLpFYj1tGGa7NqyVBujfRtgNa2gXR+6RkGUiB2O5Vmh7E2RmiA==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-media-minmax": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-media-minmax/-/postcss-media-minmax-4.0.0.tgz", + "integrity": "sha512-fo9moya6qyxsjbFAYl97qKO9gyre3qvbMnkOZeZwlsW6XYFsvs2DMGDlchVLfAd8LHPZDxivu/+qW2SMQeTHBw==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-merge-longhand": { + "version": "4.0.11", + "resolved": "https://registry.npmjs.org/postcss-merge-longhand/-/postcss-merge-longhand-4.0.11.tgz", + "integrity": "sha512-alx/zmoeXvJjp7L4mxEMjh8lxVlDFX1gqWHzaaQewwMZiVhLo42TEClKaeHbRf6J7j82ZOdTJ808RtN0ZOZwvw==", + "requires": { + "css-color-names": "0.0.4", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "stylehacks": "^4.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-merge-rules": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-merge-rules/-/postcss-merge-rules-4.0.3.tgz", + "integrity": "sha512-U7e3r1SbvYzO0Jr3UT/zKBVgYYyhAz0aitvGIYOYK5CPmkNih+WDSsS5tvPrJ8YMQYlEMvsZIiqmn7HdFUaeEQ==", + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "cssnano-util-same-parent": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0", + "vendors": "^1.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-minify-font-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-font-values/-/postcss-minify-font-values-4.0.2.tgz", + "integrity": "sha512-j85oO6OnRU9zPf04+PZv1LYIYOprWm6IA6zkXkrJXyRveDEuQggG6tvoy8ir8ZwjLxLuGfNkCZEQG7zan+Hbtg==", + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-minify-gradients": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-gradients/-/postcss-minify-gradients-4.0.2.tgz", + "integrity": "sha512-qKPfwlONdcf/AndP1U8SJ/uzIJtowHlMaSioKzebAXSG4iJthlWC9iSWznQcX4f66gIWX44RSA841HTHj3wK+Q==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "is-color-stop": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-minify-params": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-params/-/postcss-minify-params-4.0.2.tgz", + "integrity": "sha512-G7eWyzEx0xL4/wiBBJxJOz48zAKV2WG3iZOqVhPet/9geefm/Px5uo1fzlHu+DOjT+m0Mmiz3jkQzVHe6wxAWg==", + "requires": { + "alphanum-sort": "^1.0.0", + "browserslist": "^4.0.0", + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "uniqs": "^2.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-minify-selectors": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-minify-selectors/-/postcss-minify-selectors-4.0.2.tgz", + "integrity": "sha512-D5S1iViljXBj9kflQo4YutWnJmwm8VvIsU1GeXJGiG9j8CIg9zs4voPMdQDUmIxetUOh60VilsNzCiAFTOqu3g==", + "requires": { + "alphanum-sort": "^1.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-modules-extract-imports": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-extract-imports/-/postcss-modules-extract-imports-2.0.0.tgz", + "integrity": "sha512-LaYLDNS4SG8Q5WAWqIJgdHPJrDDr/Lv775rMBFUbgjTz6j34lUznACHcdRWroPvXANP2Vj7yNK57vp9eFqzLWQ==", + "requires": { + "postcss": "^7.0.5" + } + }, + "postcss-modules-local-by-default": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/postcss-modules-local-by-default/-/postcss-modules-local-by-default-3.0.2.tgz", + "integrity": "sha512-jM/V8eqM4oJ/22j0gx4jrp63GSvDH6v86OqyTHHUvk4/k1vceipZsaymiZ5PvocqZOl5SFHiFJqjs3la0wnfIQ==", + "requires": { + "icss-utils": "^4.1.1", + "postcss": "^7.0.16", + "postcss-selector-parser": "^6.0.2", + "postcss-value-parser": "^4.0.0" + } + }, + "postcss-modules-scope": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/postcss-modules-scope/-/postcss-modules-scope-2.1.1.tgz", + "integrity": "sha512-OXRUPecnHCg8b9xWvldG/jUpRIGPNRka0r4D4j0ESUU2/5IOnpsjfPPmDprM3Ih8CgZ8FXjWqaniK5v4rWt3oQ==", + "requires": { + "postcss": "^7.0.6", + "postcss-selector-parser": "^6.0.0" + } + }, + "postcss-modules-values": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-modules-values/-/postcss-modules-values-3.0.0.tgz", + "integrity": "sha512-1//E5jCBrZ9DmRX+zCtmQtRSV6PV42Ix7Bzj9GbwJceduuf7IqP8MgeTXuRDHOWj2m0VzZD5+roFWDuU8RQjcg==", + "requires": { + "icss-utils": "^4.0.0", + "postcss": "^7.0.6" + } + }, + "postcss-nesting": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/postcss-nesting/-/postcss-nesting-7.0.1.tgz", + "integrity": "sha512-FrorPb0H3nuVq0Sff7W2rnc3SmIcruVC6YwpcS+k687VxyxO33iE1amna7wHuRVzM8vfiYofXSBHNAZ3QhLvYg==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-normalize": { + "version": "8.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize/-/postcss-normalize-8.0.1.tgz", + "integrity": "sha512-rt9JMS/m9FHIRroDDBGSMsyW1c0fkvOJPy62ggxSHUldJO7B195TqFMqIf+lY5ezpDcYOV4j86aUp3/XbxzCCQ==", + "requires": { + "@csstools/normalize.css": "^10.1.0", + "browserslist": "^4.6.2", + "postcss": "^7.0.17", + "postcss-browser-comments": "^3.0.0", + "sanitize.css": "^10.0.0" + } + }, + "postcss-normalize-charset": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-charset/-/postcss-normalize-charset-4.0.1.tgz", + "integrity": "sha512-gMXCrrlWh6G27U0hF3vNvR3w8I1s2wOBILvA87iNXaPvSNo5uZAMYsZG7XjCUf1eVxuPfyL4TJ7++SGZLc9A3g==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-normalize-display-values": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-display-values/-/postcss-normalize-display-values-4.0.2.tgz", + "integrity": "sha512-3F2jcsaMW7+VtRMAqf/3m4cPFhPD3EFRgNs18u+k3lTJJlVe7d0YPO+bnwqo2xg8YiRpDXJI2u8A0wqJxMsQuQ==", + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-positions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-positions/-/postcss-normalize-positions-4.0.2.tgz", + "integrity": "sha512-Dlf3/9AxpxE+NF1fJxYDeggi5WwV35MXGFnnoccP/9qDtFrTArZ0D0R+iKcg5WsUd8nUYMIl8yXDCtcrT8JrdA==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-repeat-style": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-repeat-style/-/postcss-normalize-repeat-style-4.0.2.tgz", + "integrity": "sha512-qvigdYYMpSuoFs3Is/f5nHdRLJN/ITA7huIoCyqqENJe9PvPmLhNLMu7QTjPdtnVf6OcYYO5SHonx4+fbJE1+Q==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-string": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-string/-/postcss-normalize-string-4.0.2.tgz", + "integrity": "sha512-RrERod97Dnwqq49WNz8qo66ps0swYZDSb6rM57kN2J+aoyEAJfZ6bMx0sx/F9TIEX0xthPGCmeyiam/jXif0eA==", + "requires": { + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-timing-functions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-timing-functions/-/postcss-normalize-timing-functions-4.0.2.tgz", + "integrity": "sha512-acwJY95edP762e++00Ehq9L4sZCEcOPyaHwoaFOhIwWCDfik6YvqsYNxckee65JHLKzuNSSmAdxwD2Cud1Z54A==", + "requires": { + "cssnano-util-get-match": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-unicode": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-unicode/-/postcss-normalize-unicode-4.0.1.tgz", + "integrity": "sha512-od18Uq2wCYn+vZ/qCOeutvHjB5jm57ToxRaMeNuf0nWVHaP9Hua56QyMF6fs/4FSUnVIw0CBPsU0K4LnBPwYwg==", + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-url": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-normalize-url/-/postcss-normalize-url-4.0.1.tgz", + "integrity": "sha512-p5oVaF4+IHwu7VpMan/SSpmpYxcJMtkGppYf0VbdH5B6hN8YNmVyJLuY9FmLQTzY3fag5ESUUHDqM+heid0UVA==", + "requires": { + "is-absolute-url": "^2.0.0", + "normalize-url": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "normalize-url": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/normalize-url/-/normalize-url-3.3.0.tgz", + "integrity": "sha512-U+JJi7duF1o+u2pynbp2zXDW2/PADgC30f0GsHZtRh+HOcXHnw137TrNlyxxRvWW5fjKd3bcLHPxofWuCjaeZg==" + }, + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-normalize-whitespace": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-normalize-whitespace/-/postcss-normalize-whitespace-4.0.2.tgz", + "integrity": "sha512-tO8QIgrsI3p95r8fyqKV+ufKlSHh9hMJqACqbv2XknufqEDhDvbguXGBBqxw9nsQoXWf0qOqppziKJKHMD4GtA==", + "requires": { + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-ordered-values": { + "version": "4.1.2", + "resolved": "https://registry.npmjs.org/postcss-ordered-values/-/postcss-ordered-values-4.1.2.tgz", + "integrity": "sha512-2fCObh5UanxvSxeXrtLtlwVThBvHn6MQcu4ksNT2tsaV2Fg76R2CV98W7wNSlX+5/pFwEyaDwKLLoEV7uRybAw==", + "requires": { + "cssnano-util-get-arguments": "^4.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-overflow-shorthand": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-overflow-shorthand/-/postcss-overflow-shorthand-2.0.0.tgz", + "integrity": "sha512-aK0fHc9CBNx8jbzMYhshZcEv8LtYnBIRYQD5i7w/K/wS9c2+0NSR6B3OVMu5y0hBHYLcMGjfU+dmWYNKH0I85g==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-page-break": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/postcss-page-break/-/postcss-page-break-2.0.0.tgz", + "integrity": "sha512-tkpTSrLpfLfD9HvgOlJuigLuk39wVTbbd8RKcy8/ugV2bNBUW3xU+AIqyxhDrQr1VUj1RmyJrBn1YWrqUm9zAQ==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-place": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-place/-/postcss-place-4.0.1.tgz", + "integrity": "sha512-Zb6byCSLkgRKLODj/5mQugyuj9bvAAw9LqJJjgwz5cYryGeXfFZfSXoP1UfveccFmeq0b/2xxwcTEVScnqGxBg==", + "requires": { + "postcss": "^7.0.2", + "postcss-values-parser": "^2.0.0" + } + }, + "postcss-preset-env": { + "version": "6.7.0", + "resolved": "https://registry.npmjs.org/postcss-preset-env/-/postcss-preset-env-6.7.0.tgz", + "integrity": "sha512-eU4/K5xzSFwUFJ8hTdTQzo2RBLbDVt83QZrAvI07TULOkmyQlnYlpwep+2yIK+K+0KlZO4BvFcleOCCcUtwchg==", + "requires": { + "autoprefixer": "^9.6.1", + "browserslist": "^4.6.4", + "caniuse-lite": "^1.0.30000981", + "css-blank-pseudo": "^0.1.4", + "css-has-pseudo": "^0.10.0", + "css-prefers-color-scheme": "^3.1.1", + "cssdb": "^4.4.0", + "postcss": "^7.0.17", + "postcss-attribute-case-insensitive": "^4.0.1", + "postcss-color-functional-notation": "^2.0.1", + "postcss-color-gray": "^5.0.0", + "postcss-color-hex-alpha": "^5.0.3", + "postcss-color-mod-function": "^3.0.3", + "postcss-color-rebeccapurple": "^4.0.1", + "postcss-custom-media": "^7.0.8", + "postcss-custom-properties": "^8.0.11", + "postcss-custom-selectors": "^5.1.2", + "postcss-dir-pseudo-class": "^5.0.0", + "postcss-double-position-gradients": "^1.0.0", + "postcss-env-function": "^2.0.2", + "postcss-focus-visible": "^4.0.0", + "postcss-focus-within": "^3.0.0", + "postcss-font-variant": "^4.0.0", + "postcss-gap-properties": "^2.0.0", + "postcss-image-set-function": "^3.0.1", + "postcss-initial": "^3.0.0", + "postcss-lab-function": "^2.0.1", + "postcss-logical": "^3.0.0", + "postcss-media-minmax": "^4.0.0", + "postcss-nesting": "^7.0.0", + "postcss-overflow-shorthand": "^2.0.0", + "postcss-page-break": "^2.0.0", + "postcss-place": "^4.0.1", + "postcss-pseudo-class-any-link": "^6.0.0", + "postcss-replace-overflow-wrap": "^3.0.0", + "postcss-selector-matches": "^4.0.0", + "postcss-selector-not": "^4.0.0" + } + }, + "postcss-pseudo-class-any-link": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/postcss-pseudo-class-any-link/-/postcss-pseudo-class-any-link-6.0.0.tgz", + "integrity": "sha512-lgXW9sYJdLqtmw23otOzrtbDXofUdfYzNm4PIpNE322/swES3VU9XlXHeJS46zT2onFO7V1QFdD4Q9LiZj8mew==", + "requires": { + "postcss": "^7.0.2", + "postcss-selector-parser": "^5.0.0-rc.3" + }, + "dependencies": { + "cssesc": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/cssesc/-/cssesc-2.0.0.tgz", + "integrity": "sha512-MsCAG1z9lPdoO/IUMLSBWBSVxVtJ1395VGIQ+Fc2gNdkQ1hNDnQdw3YhA71WJCBW1vdwA0cAnk/DnW6bqoEUYg==" + }, + "postcss-selector-parser": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-5.0.0.tgz", + "integrity": "sha512-w+zLE5Jhg6Liz8+rQOWEAwtwkyqpfnmsinXjXg6cY7YIONZZtgvE0v2O0uhQBs0peNomOJwWRKt6JBfTdTd3OQ==", + "requires": { + "cssesc": "^2.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "postcss-reduce-initial": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-reduce-initial/-/postcss-reduce-initial-4.0.3.tgz", + "integrity": "sha512-gKWmR5aUulSjbzOfD9AlJiHCGH6AEVLaM0AV+aSioxUDd16qXP1PCh8d1/BGVvpdWn8k/HiK7n6TjeoXN1F7DA==", + "requires": { + "browserslist": "^4.0.0", + "caniuse-api": "^3.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0" + } + }, + "postcss-reduce-transforms": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-reduce-transforms/-/postcss-reduce-transforms-4.0.2.tgz", + "integrity": "sha512-EEVig1Q2QJ4ELpJXMZR8Vt5DQx8/mo+dGWSR7vWXqcob2gQLyQGsionYcGKATXvQzMPn6DSN1vTN7yFximdIAg==", + "requires": { + "cssnano-util-get-match": "^4.0.0", + "has": "^1.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-replace-overflow-wrap": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/postcss-replace-overflow-wrap/-/postcss-replace-overflow-wrap-3.0.0.tgz", + "integrity": "sha512-2T5hcEHArDT6X9+9dVSPQdo7QHzG4XKclFT8rU5TzJPDN7RIRTbO9c4drUISOVemLj03aezStHCR2AIcr8XLpw==", + "requires": { + "postcss": "^7.0.2" + } + }, + "postcss-safe-parser": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-safe-parser/-/postcss-safe-parser-4.0.1.tgz", + "integrity": "sha512-xZsFA3uX8MO3yAda03QrG3/Eg1LN3EPfjjf07vke/46HERLZyHrTsQ9E1r1w1W//fWEhtYNndo2hQplN2cVpCQ==", + "requires": { + "postcss": "^7.0.0" + } + }, + "postcss-selector-matches": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-matches/-/postcss-selector-matches-4.0.0.tgz", + "integrity": "sha512-LgsHwQR/EsRYSqlwdGzeaPKVT0Ml7LAT6E75T8W8xLJY62CE4S/l03BWIt3jT8Taq22kXP08s2SfTSzaraoPww==", + "requires": { + "balanced-match": "^1.0.0", + "postcss": "^7.0.2" + } + }, + "postcss-selector-not": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/postcss-selector-not/-/postcss-selector-not-4.0.0.tgz", + "integrity": "sha512-W+bkBZRhqJaYN8XAnbbZPLWMvZD1wKTu0UxtFKdhtGjWYmxhkUneoeOhRJKdAE5V7ZTlnbHfCR+6bNwK9e1dTQ==", + "requires": { + "balanced-match": "^1.0.0", + "postcss": "^7.0.2" + } + }, + "postcss-selector-parser": { + "version": "6.0.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-6.0.2.tgz", + "integrity": "sha512-36P2QR59jDTOAiIkqEprfJDsoNrvwFei3eCqKd1Y0tUsBimsq39BLp7RD+JWny3WgB1zGhJX8XVePwm9k4wdBg==", + "requires": { + "cssesc": "^3.0.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + }, + "postcss-svgo": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/postcss-svgo/-/postcss-svgo-4.0.2.tgz", + "integrity": "sha512-C6wyjo3VwFm0QgBy+Fu7gCYOkCmgmClghO+pjcxvrcBKtiKt0uCF+hvbMO1fyv5BMImRK90SMb+dwUnfbGd+jw==", + "requires": { + "is-svg": "^3.0.0", + "postcss": "^7.0.0", + "postcss-value-parser": "^3.0.0", + "svgo": "^1.0.0" + }, + "dependencies": { + "postcss-value-parser": { + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-3.3.1.tgz", + "integrity": "sha512-pISE66AbVkp4fDQ7VHBwRNXzAAKJjw4Vw7nWI/+Q3vuly7SNfgYXvm6i5IgFylHGK5sP/xHAbB7N49OS4gWNyQ==" + } + } + }, + "postcss-unique-selectors": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/postcss-unique-selectors/-/postcss-unique-selectors-4.0.1.tgz", + "integrity": "sha512-+JanVaryLo9QwZjKrmJgkI4Fn8SBgRO6WXQBJi7KiAVPlmxikB5Jzc4EvXMT2H0/m0RjrVVm9rGNhZddm/8Spg==", + "requires": { + "alphanum-sort": "^1.0.0", + "postcss": "^7.0.0", + "uniqs": "^2.0.0" + } + }, + "postcss-value-parser": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/postcss-value-parser/-/postcss-value-parser-4.0.3.tgz", + "integrity": "sha512-N7h4pG+Nnu5BEIzyeaaIYWs0LI5XC40OrRh5L60z0QjFsqGWcHcbkBvpe1WYpcIS9yQ8sOi/vIPt1ejQCrMVrg==" + }, + "postcss-values-parser": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/postcss-values-parser/-/postcss-values-parser-2.0.1.tgz", + "integrity": "sha512-2tLuBsA6P4rYTNKCXYG/71C7j1pU6pK503suYOmn4xYrQIzW+opD+7FAFNuGSdZC/3Qfy334QbeMu7MEb8gOxg==", + "requires": { + "flatten": "^1.0.2", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + }, + "prelude-ls": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/prelude-ls/-/prelude-ls-1.1.2.tgz", + "integrity": "sha1-IZMqVJ9eUv/ZqCf1cOBL5iqX2lQ=" + }, + "prepend-http": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/prepend-http/-/prepend-http-1.0.4.tgz", + "integrity": "sha1-1PRWKwzjaW5BrFLQ4ALlemNdxtw=" + }, + "pretty-bytes": { + "version": "5.3.0", + "resolved": "https://registry.npmjs.org/pretty-bytes/-/pretty-bytes-5.3.0.tgz", + "integrity": "sha512-hjGrh+P926p4R4WbaB6OckyRtO0F0/lQBiT+0gnxjV+5kjPBrfVBFCsCLbMqVQeydvIoouYTCmmEURiH3R1Bdg==" + }, + "pretty-error": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/pretty-error/-/pretty-error-2.1.1.tgz", + "integrity": "sha1-X0+HyPkeWuPzuoerTPXgOxoX8aM=", + "requires": { + "renderkid": "^2.0.1", + "utila": "~0.4" + } + }, + "pretty-format": { + "version": "24.9.0", + "resolved": "https://registry.npmjs.org/pretty-format/-/pretty-format-24.9.0.tgz", + "integrity": "sha512-00ZMZUiHaJrNfk33guavqgvfJS30sLYf0f8+Srklv0AMPodGGHcoHgksZ3OThYnIvOd+8yMCn0YiEOogjlgsnA==", + "requires": { + "@jest/types": "^24.9.0", + "ansi-regex": "^4.0.0", + "ansi-styles": "^3.2.0", + "react-is": "^16.8.4" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" + } + } + }, + "private": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/private/-/private-0.1.8.tgz", + "integrity": "sha512-VvivMrbvd2nKkiG38qjULzlc+4Vx4wm/whI9pQD35YrARNnhxeiRktSOhSukRLFNlzg6Br/cJPet5J/u19r/mg==" + }, + "process": { + "version": "0.11.10", + "resolved": "https://registry.npmjs.org/process/-/process-0.11.10.tgz", + "integrity": "sha1-czIwDoQBYb2j5podHZGn1LwW8YI=" + }, + "process-nextick-args": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/process-nextick-args/-/process-nextick-args-2.0.1.tgz", + "integrity": "sha512-3ouUOpQhtgrbOa17J7+uxOTpITYWaGP7/AhoR3+A+/1e9skrzelGi/dXzEYyvbxubEF6Wn2ypscTKiKJFFn1ag==" + }, + "progress": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/progress/-/progress-2.0.3.tgz", + "integrity": "sha512-7PiHtLll5LdnKIMw100I+8xJXR5gW2QwWYkT6iJva0bXitZKa/XMrSbdmg3r2Xnaidz9Qumd0VPaMrZlF9V9sA==" + }, + "promise": { + "version": "8.0.3", + "resolved": "https://registry.npmjs.org/promise/-/promise-8.0.3.tgz", + "integrity": "sha512-HeRDUL1RJiLhyA0/grn+PTShlBAcLuh/1BJGtrvjwbvRDCTLLMEz9rOGCV+R3vHY4MixIuoMEd9Yq/XvsTPcjw==", + "requires": { + "asap": "~2.0.6" + } + }, + "promise-inflight": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/promise-inflight/-/promise-inflight-1.0.1.tgz", + "integrity": "sha1-mEcocL8igTL8vdhoEputEsPAKeM=" + }, + "prompts": { + "version": "2.3.1", + "resolved": "https://registry.npmjs.org/prompts/-/prompts-2.3.1.tgz", + "integrity": "sha512-qIP2lQyCwYbdzcqHIUi2HAxiWixhoM9OdLCWf8txXsapC/X9YdsCoeyRIXE/GP+Q0J37Q7+XN/MFqbUa7IzXNA==", + "requires": { + "kleur": "^3.0.3", + "sisteransi": "^1.0.4" + } + }, + "prop-types": { + "version": "15.7.2", + "resolved": "https://registry.npmjs.org/prop-types/-/prop-types-15.7.2.tgz", + "integrity": "sha512-8QQikdH7//R2vurIJSutZ1smHYTcLpRWEOlHnzcWHmBYrOGUysKwSsrC89BCiFj3CbrfJ/nXFdJepOVrY1GCHQ==", + "requires": { + "loose-envify": "^1.4.0", + "object-assign": "^4.1.1", + "react-is": "^16.8.1" + } + }, + "proxy-addr": { + "version": "2.0.6", + "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.6.tgz", + "integrity": "sha512-dh/frvCBVmSsDYzw6n926jv974gddhkFPfiN8hPOi30Wax25QZyZEGveluCgliBnqmuM+UJmBErbAUFIoDbjOw==", + "requires": { + "forwarded": "~0.1.2", + "ipaddr.js": "1.9.1" + } + }, + "prr": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/prr/-/prr-1.0.1.tgz", + "integrity": "sha1-0/wRS6BplaRexok/SEzrHXj19HY=" + }, + "psl": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/psl/-/psl-1.7.0.tgz", + "integrity": "sha512-5NsSEDv8zY70ScRnOTn7bK7eanl2MvFrOrS/R6x+dBt5g1ghnj9Zv90kO8GwT8gxcu2ANyFprnFYB85IogIJOQ==" + }, + "public-encrypt": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/public-encrypt/-/public-encrypt-4.0.3.tgz", + "integrity": "sha512-zVpa8oKZSz5bTMTFClc1fQOnyyEzpl5ozpi1B5YcvBrdohMjH2rfsBtyXcuNuwjsDIXmBYlF2N5FlJYhR29t8Q==", + "requires": { + "bn.js": "^4.1.0", + "browserify-rsa": "^4.0.0", + "create-hash": "^1.1.0", + "parse-asn1": "^5.0.0", + "randombytes": "^2.0.1", + "safe-buffer": "^5.1.2" + } + }, + "pump": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pump/-/pump-3.0.0.tgz", + "integrity": "sha512-LwZy+p3SFs1Pytd/jYct4wpv49HiYCqd9Rlc5ZVdk0V+8Yzv6jR5Blk3TRmPL1ft69TxP0IMZGJ+WPFU2BFhww==", + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + }, + "pumpify": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/pumpify/-/pumpify-1.5.1.tgz", + "integrity": "sha512-oClZI37HvuUJJxSKKrC17bZ9Cu0ZYhEAGPsPUy9KlMUmv9dKX2o77RUmq7f3XjIxbwyGwYzbzQ1L2Ks8sIradQ==", + "requires": { + "duplexify": "^3.6.0", + "inherits": "^2.0.3", + "pump": "^2.0.0" + }, + "dependencies": { + "pump": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/pump/-/pump-2.0.1.tgz", + "integrity": "sha512-ruPMNRkN3MHP1cWJc9OWr+T/xDP0jhXYCLfJcBuX54hhfIBnaQmAUMfDcG4DM5UMWByBbJY69QSphm3jtDKIkA==", + "requires": { + "end-of-stream": "^1.1.0", + "once": "^1.3.1" + } + } + } + }, + "punycode": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.1.1.tgz", + "integrity": "sha512-XRsRjdf+j5ml+y/6GKHPZbrF/8p2Yga0JPtdqTIY2Xe5ohJPD9saDJJLPvp9+NSBprVvevdXZybnj2cv8OEd0A==" + }, + "q": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/q/-/q-1.5.1.tgz", + "integrity": "sha1-fjL3W0E4EpHQRhHxvxQQmsAGUdc=" + }, + "qs": { + "version": "6.5.2", + "resolved": "https://registry.npmjs.org/qs/-/qs-6.5.2.tgz", + "integrity": "sha512-N5ZAX4/LxJmF+7wN74pUD6qAh9/wnvdQcjq9TZjevvXzSUo7bfmw91saqMjzGS2xq91/odN2dW/WOl7qQHNDGA==" + }, + "query-string": { + "version": "4.3.4", + "resolved": "https://registry.npmjs.org/query-string/-/query-string-4.3.4.tgz", + "integrity": "sha1-u7aTucqRXCMlFbIosaArYJBD2+s=", + "requires": { + "object-assign": "^4.1.0", + "strict-uri-encode": "^1.0.0" + } + }, + "querystring": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/querystring/-/querystring-0.2.0.tgz", + "integrity": "sha1-sgmEkgO7Jd+CDadW50cAWHhSFiA=" + }, + "querystring-es3": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/querystring-es3/-/querystring-es3-0.2.1.tgz", + "integrity": "sha1-nsYfeQSYdXB9aUFFlv2Qek1xHnM=" + }, + "querystringify": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/querystringify/-/querystringify-2.1.1.tgz", + "integrity": "sha512-w7fLxIRCRT7U8Qu53jQnJyPkYZIaR4n5151KMfcJlO/A9397Wxb1amJvROTK6TOnp7PfoAmg/qXiNHI+08jRfA==" + }, + "raf": { + "version": "3.4.1", + "resolved": "https://registry.npmjs.org/raf/-/raf-3.4.1.tgz", + "integrity": "sha512-Sq4CW4QhwOHE8ucn6J34MqtZCeWFP2aQSmrlroYgqAV1PjStIhJXxYuTgUIfkEk7zTLjmIjLmU5q+fbD1NnOJA==", + "requires": { + "performance-now": "^2.1.0" + } + }, + "randombytes": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/randombytes/-/randombytes-2.1.0.tgz", + "integrity": "sha512-vYl3iOX+4CKUWuxGi9Ukhie6fsqXqS9FE2Zaic4tNFD2N2QQaXOMFbuKK4QmDHC0JO6B1Zp41J0LpT0oR68amQ==", + "requires": { + "safe-buffer": "^5.1.0" + } + }, + "randomfill": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/randomfill/-/randomfill-1.0.4.tgz", + "integrity": "sha512-87lcbR8+MhcWcUiQ+9e+Rwx8MyR2P7qnt15ynUlbm3TU/fjbgz4GsvfSUDTemtCCtVCqb4ZcEFlyPNTh9bBTLw==", + "requires": { + "randombytes": "^2.0.5", + "safe-buffer": "^5.1.0" + } + }, + "range-parser": { + "version": "1.2.1", + "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", + "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==" + }, + "raw-body": { + "version": "2.4.0", + "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.4.0.tgz", + "integrity": "sha512-4Oz8DUIwdvoa5qMJelxipzi/iJIi40O5cGV1wNYp5hvZP8ZN0T+jiNkL0QepXs+EsQ9XJ8ipEDoiH70ySUJP3Q==", + "requires": { + "bytes": "3.1.0", + "http-errors": "1.7.2", + "iconv-lite": "0.4.24", + "unpipe": "1.0.0" + }, + "dependencies": { + "bytes": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.0.tgz", + "integrity": "sha512-zauLjrfCG+xvoyaqLoV8bLVXXNGC4JqlxFCutSDWA6fJrTo2ZuvLYTqZ7aHBLZSMOopbzwv8f+wZcVzfVTI2Dg==" + } + } + }, + "rc": { + "version": "1.2.8", + "resolved": "https://registry.npmjs.org/rc/-/rc-1.2.8.tgz", + "integrity": "sha512-y3bGgqKj3QBdxLbLkomlohkvsA8gdAiUQlSBJnBhfn+BPxg4bc62d8TcBW15wavDfgexCgccckhcZvywyQYPOw==", + "optional": true, + "requires": { + "deep-extend": "^0.6.0", + "ini": "~1.3.0", + "minimist": "^1.2.0", + "strip-json-comments": "~2.0.1" + }, + "dependencies": { + "strip-json-comments": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-2.0.1.tgz", + "integrity": "sha1-PFMZQukIwml8DsNEhYwobHygpgo=", + "optional": true + } + } + }, + "react": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react/-/react-16.12.0.tgz", + "integrity": "sha512-fglqy3k5E+81pA8s+7K0/T3DBCF0ZDOher1elBFzF7O6arXJgzyu/FW+COxFvAWXJoJN9KIZbT2LXlukwphYTA==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1", + "prop-types": "^15.6.2" + } + }, + "react-app-polyfill": { + "version": "1.0.6", + "resolved": "https://registry.npmjs.org/react-app-polyfill/-/react-app-polyfill-1.0.6.tgz", + "integrity": "sha512-OfBnObtnGgLGfweORmdZbyEz+3dgVePQBb3zipiaDsMHV1NpWm0rDFYIVXFV/AK+x4VIIfWHhrdMIeoTLyRr2g==", + "requires": { + "core-js": "^3.5.0", + "object-assign": "^4.1.1", + "promise": "^8.0.3", + "raf": "^3.4.1", + "regenerator-runtime": "^0.13.3", + "whatwg-fetch": "^3.0.0" + } + }, + "react-dev-utils": { + "version": "10.2.0", + "resolved": "https://registry.npmjs.org/react-dev-utils/-/react-dev-utils-10.2.0.tgz", + "integrity": "sha512-MwrvQW2TFjLblhqpDNeqCXHBkz3G5vc7k4wntgutAJZX4ia3o07eGKo6uYGhUOeJ0hfOxcpJFNFk7+4XCc1S8g==", + "requires": { + "@babel/code-frame": "7.8.3", + "address": "1.1.2", + "browserslist": "4.8.6", + "chalk": "2.4.2", + "cross-spawn": "7.0.1", + "detect-port-alt": "1.1.6", + "escape-string-regexp": "2.0.0", + "filesize": "6.0.1", + "find-up": "4.1.0", + "fork-ts-checker-webpack-plugin": "3.1.1", + "global-modules": "2.0.0", + "globby": "8.0.2", + "gzip-size": "5.1.1", + "immer": "1.10.0", + "inquirer": "7.0.4", + "is-root": "2.1.0", + "loader-utils": "1.2.3", + "open": "^7.0.2", + "pkg-up": "3.1.0", + "react-error-overlay": "^6.0.6", + "recursive-readdir": "2.2.2", + "shell-quote": "1.7.2", + "strip-ansi": "6.0.0", + "text-table": "0.2.0" + }, + "dependencies": { + "browserslist": { + "version": "4.8.6", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.8.6.tgz", + "integrity": "sha512-ZHao85gf0eZ0ESxLfCp73GG9O/VTytYDIkIiZDlURppLTI9wErSM/5yAKEq6rcUdxBLjMELmrYUJGg5sxGKMHg==", + "requires": { + "caniuse-lite": "^1.0.30001023", + "electron-to-chromium": "^1.3.341", + "node-releases": "^1.1.47" + } + }, + "cross-spawn": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/cross-spawn/-/cross-spawn-7.0.1.tgz", + "integrity": "sha512-u7v4o84SwFpD32Z8IIcPZ6z1/ie24O6RU3RbtL5Y316l3KuHVPx9ItBgWQ6VlfAFnRnTtMUrsQ9MUUTuEZjogg==", + "requires": { + "path-key": "^3.1.0", + "shebang-command": "^2.0.0", + "which": "^2.0.1" + } + }, + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=" + }, + "escape-string-regexp": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/escape-string-regexp/-/escape-string-regexp-2.0.0.tgz", + "integrity": "sha512-UpzcLCXolUWcNu5HtVMHYdXJjArjsF9C0aNnquZYY4uW/Vu0miy5YoWvbV345HauVvcAUnpRuhMMcqTcGOY2+w==" + }, + "find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "requires": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + } + }, + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", + "requires": { + "minimist": "^1.2.0" + } + }, + "loader-utils": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.2.3.tgz", + "integrity": "sha512-fkpz8ejdnEMG3s37wGL07iSBDg99O9D5yflE9RGNH3hRdx9SOwYfnGYdZOUIZitN8E+E2vkq3MUMYMvPYl5ZZA==", + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^2.0.0", + "json5": "^1.0.1" + } + }, + "locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "requires": { + "p-locate": "^4.1.0" + } + }, + "p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "requires": { + "p-limit": "^2.2.0" + } + }, + "path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" + }, + "path-key": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/path-key/-/path-key-3.1.1.tgz", + "integrity": "sha512-ojmeN0qd+y0jszEtoY48r0Peq5dwMEkIlCOu6Q5f41lfkswXuKtYrhgoTpLnyIcHm24Uhqx+5Tqm2InSwLhE6Q==" + }, + "shebang-command": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-2.0.0.tgz", + "integrity": "sha512-kHxr2zZpYtdmrN1qDjrrX/Z1rR1kG8Dx+gkpK1G4eXmvXswmcE1hTWBWYUzlraYw1/yZp6YuDY77YtvbN0dmDA==", + "requires": { + "shebang-regex": "^3.0.0" + } + }, + "shebang-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-3.0.0.tgz", + "integrity": "sha512-7++dFhtcx3353uBaq8DDR4NuxBetBzC7ZQOhmTQInHEd6bSrXdiEyzCvG07Z44UYdLShWUyXt5M/yhz8ekcb1A==" + }, + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", + "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", + "requires": { + "ansi-regex": "^5.0.0" + } + }, + "which": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/which/-/which-2.0.2.tgz", + "integrity": "sha512-BLI3Tl1TW3Pvl70l3yq3Y64i+awpwXqsGBYWkkqMtnbXgrMD+yj7rhW0kuEDxzJaYXGjEW5ogapKNMEKNMjibA==", + "requires": { + "isexe": "^2.0.0" + } + } + } + }, + "react-dom": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react-dom/-/react-dom-16.12.0.tgz", + "integrity": "sha512-LMxFfAGrcS3kETtQaCkTKjMiifahaMySFDn71fZUNpPHZQEzmk/GiAeIT8JSOrHB23fnuCOMruL2a8NYlw+8Gw==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1", + "prop-types": "^15.6.2", + "scheduler": "^0.18.0" + } + }, + "react-error-overlay": { + "version": "6.0.6", + "resolved": "https://registry.npmjs.org/react-error-overlay/-/react-error-overlay-6.0.6.tgz", + "integrity": "sha512-Yzpno3enVzSrSCnnljmr4b/2KUQSMZaPuqmS26t9k4nW7uwJk6STWmH9heNjPuvqUTO3jOSPkHoKgO4+Dw7uIw==" + }, + "react-image-markup": { + "version": "1.0.11", + "resolved": "https://registry.npmjs.org/react-image-markup/-/react-image-markup-1.0.11.tgz", + "integrity": "sha512-Bcg2If0g9GF8I/48mgP/WM23VKsKxw3catFGOh4tUQYNcxTjhSO0UMNXF6IZfQzHjE40qhHv9s/QBThzXoO1Rw==", + "requires": { + "fabric": "^3.4.0" + }, + "dependencies": { + "cssom": { + "version": "0.4.4", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.4.4.tgz", + "integrity": "sha512-p3pvU7r1MyyqbTk+WbNJIgJjG2VmTIaB10rI93LzVPrmDJKkzKYMtxxyAvQXR/NS6otuzveI7+7BBq3SjBS2mw==", + "optional": true + }, + "cssstyle": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/cssstyle/-/cssstyle-2.2.0.tgz", + "integrity": "sha512-sEb3XFPx3jNnCAMtqrXPDeSgQr+jojtCeNf8cvMNMh1cG970+lljssvQDzPq6lmmJu2Vhqood/gtEomBiHOGnA==", + "optional": true, + "requires": { + "cssom": "~0.3.6" + }, + "dependencies": { + "cssom": { + "version": "0.3.8", + "resolved": "https://registry.npmjs.org/cssom/-/cssom-0.3.8.tgz", + "integrity": "sha512-b0tGHbfegbhPJpxpiBPU2sCkigAqtM9O121le6bbOlgyV+NyGyCmVfJ6QW9eRjz8CpNfWEOYBIMIGRYkLwsIYg==", + "optional": true + } + } + }, + "fabric": { + "version": "3.6.2", + "resolved": "https://registry.npmjs.org/fabric/-/fabric-3.6.2.tgz", + "integrity": "sha512-LGj/oLg55lYozasrVHHq0prR2cbdKy7TXSByTqCJZ7JgAhJwx7/BbUUZwdlfFXOEDGjb2dBh6Wqv2y/5jFvBEQ==", + "requires": { + "canvas": "^2.6.1", + "jsdom": "^15.1.0" + } + }, + "jsdom": { + "version": "15.2.1", + "resolved": "https://registry.npmjs.org/jsdom/-/jsdom-15.2.1.tgz", + "integrity": "sha512-fAl1W0/7T2G5vURSyxBzrJ1LSdQn6Tr5UX/xD4PXDx/PDgwygedfW6El/KIj3xJ7FU61TTYnc/l/B7P49Eqt6g==", + "optional": true, + "requires": { + "abab": "^2.0.0", + "acorn": "^7.1.0", + "acorn-globals": "^4.3.2", + "array-equal": "^1.0.0", + "cssom": "^0.4.1", + "cssstyle": "^2.0.0", + "data-urls": "^1.1.0", + "domexception": "^1.0.1", + "escodegen": "^1.11.1", + "html-encoding-sniffer": "^1.0.2", + "nwsapi": "^2.2.0", + "parse5": "5.1.0", + "pn": "^1.1.0", + "request": "^2.88.0", + "request-promise-native": "^1.0.7", + "saxes": "^3.1.9", + "symbol-tree": "^3.2.2", + "tough-cookie": "^3.0.1", + "w3c-hr-time": "^1.0.1", + "w3c-xmlserializer": "^1.1.2", + "webidl-conversions": "^4.0.2", + "whatwg-encoding": "^1.0.5", + "whatwg-mimetype": "^2.3.0", + "whatwg-url": "^7.0.0", + "ws": "^7.0.0", + "xml-name-validator": "^3.0.0" + } + }, + "parse5": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/parse5/-/parse5-5.1.0.tgz", + "integrity": "sha512-fxNG2sQjHvlVAYmzBZS9YlDp6PTSSDwa98vkD4QgVDDCAo84z5X1t5XyJQ62ImdLXx5NdIIfihey6xpum9/gRQ==", + "optional": true + }, + "tough-cookie": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-3.0.1.tgz", + "integrity": "sha512-yQyJ0u4pZsv9D4clxO69OEjLWYw+jbgspjTue4lTQZLfV0c5l1VmK2y1JK8E9ahdpltPOaAThPcp5nKPUgSnsg==", + "optional": true, + "requires": { + "ip-regex": "^2.1.0", + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + }, + "whatwg-url": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-7.1.0.tgz", + "integrity": "sha512-WUu7Rg1DroM7oQvGWfOiAK21n74Gg+T4elXEQYkOhtyLeWiJFoOGLXPKI/9gzIie9CtwVLm8wtw6YJdKyxSjeg==", + "optional": true, + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "ws": { + "version": "7.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.2.1.tgz", + "integrity": "sha512-sucePNSafamSKoOqoNfBd8V0StlkzJKL2ZAhGQinCfNQ+oacw+Pk7lcdAElecBF2VkLNZRiIb5Oi1Q5lVUVt2A==", + "optional": true + } + } + }, + "react-is": { + "version": "16.12.0", + "resolved": "https://registry.npmjs.org/react-is/-/react-is-16.12.0.tgz", + "integrity": "sha512-rPCkf/mWBtKc97aLL9/txD8DZdemK0vkA3JMLShjlJB3Pj3s+lpf1KaBzMfQrAmhMQB0n1cU/SUGgKKBCe837Q==" + }, + "react-scripts": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/react-scripts/-/react-scripts-3.4.0.tgz", + "integrity": "sha512-pBqaAroFoHnFAkuX+uSK9Th1uEh2GYdGY2IG1I9/7HmuEf+ls3lLCk1p2GFYRSrLMz6ieQR/SyN6TLIGK3hKRg==", + "requires": { + "@babel/core": "7.8.4", + "@svgr/webpack": "4.3.3", + "@typescript-eslint/eslint-plugin": "^2.10.0", + "@typescript-eslint/parser": "^2.10.0", + "babel-eslint": "10.0.3", + "babel-jest": "^24.9.0", + "babel-loader": "8.0.6", + "babel-plugin-named-asset-import": "^0.3.6", + "babel-preset-react-app": "^9.1.1", + "camelcase": "^5.3.1", + "case-sensitive-paths-webpack-plugin": "2.3.0", + "css-loader": "3.4.2", + "dotenv": "8.2.0", + "dotenv-expand": "5.1.0", + "eslint": "^6.6.0", + "eslint-config-react-app": "^5.2.0", + "eslint-loader": "3.0.3", + "eslint-plugin-flowtype": "4.6.0", + "eslint-plugin-import": "2.20.0", + "eslint-plugin-jsx-a11y": "6.2.3", + "eslint-plugin-react": "7.18.0", + "eslint-plugin-react-hooks": "^1.6.1", + "file-loader": "4.3.0", + "fs-extra": "^8.1.0", + "fsevents": "2.1.2", + "html-webpack-plugin": "4.0.0-beta.11", + "identity-obj-proxy": "3.0.0", + "jest": "24.9.0", + "jest-environment-jsdom-fourteen": "1.0.1", + "jest-resolve": "24.9.0", + "jest-watch-typeahead": "0.4.2", + "mini-css-extract-plugin": "0.9.0", + "optimize-css-assets-webpack-plugin": "5.0.3", + "pnp-webpack-plugin": "1.6.0", + "postcss-flexbugs-fixes": "4.1.0", + "postcss-loader": "3.0.0", + "postcss-normalize": "8.0.1", + "postcss-preset-env": "6.7.0", + "postcss-safe-parser": "4.0.1", + "react-app-polyfill": "^1.0.6", + "react-dev-utils": "^10.2.0", + "resolve": "1.15.0", + "resolve-url-loader": "3.1.1", + "sass-loader": "8.0.2", + "semver": "6.3.0", + "style-loader": "0.23.1", + "terser-webpack-plugin": "2.3.4", + "ts-pnp": "1.1.5", + "url-loader": "2.3.0", + "webpack": "4.41.5", + "webpack-dev-server": "3.10.2", + "webpack-manifest-plugin": "2.2.0", + "workbox-webpack-plugin": "4.3.1" + }, + "dependencies": { + "fsevents": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.1.2.tgz", + "integrity": "sha512-R4wDiBwZ0KzpgOWetKDug1FZcYhqYnUYKtfZYt4mD5SBz76q0KR4Q9o7GIPamsVPGmW3EYPPJ0dOOjvx32ldZA==", + "optional": true + }, + "resolve": { + "version": "1.15.0", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.15.0.tgz", + "integrity": "sha512-+hTmAldEGE80U2wJJDC1lebb5jWqvTYAfm3YZ1ckk1gBr0MnCqUKlwK1e+anaFljIl+F5tR5IoZcm4ZDA1zMQw==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + } + } + }, + "read-pkg": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-2.0.0.tgz", + "integrity": "sha1-jvHAYjxqbbDcZxPEv6xGMysjaPg=", + "requires": { + "load-json-file": "^2.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^2.0.0" + }, + "dependencies": { + "path-type": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/path-type/-/path-type-2.0.0.tgz", + "integrity": "sha1-8BLMuEFbcJb8LaoQVMPXI4lZTHM=", + "requires": { + "pify": "^2.0.0" + } + }, + "pify": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-2.3.0.tgz", + "integrity": "sha1-7RQaasBDqEnqWISY59yosVMw6Qw=" + } + } + }, + "read-pkg-up": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-2.0.0.tgz", + "integrity": "sha1-a3KoBImE4MQeeVEP1en6mbO1Sb4=", + "requires": { + "find-up": "^2.0.0", + "read-pkg": "^2.0.0" + }, + "dependencies": { + "find-up": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-2.1.0.tgz", + "integrity": "sha1-RdG35QbHF93UgndaK3eSCjwMV6c=", + "requires": { + "locate-path": "^2.0.0" + } + }, + "locate-path": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-2.0.0.tgz", + "integrity": "sha1-K1aLJl7slExtnA3pw9u7ygNUzY4=", + "requires": { + "p-locate": "^2.0.0", + "path-exists": "^3.0.0" + } + }, + "p-limit": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/p-limit/-/p-limit-1.3.0.tgz", + "integrity": "sha512-vvcXsLAJ9Dr5rQOPk7toZQZJApBl2K4J6dANSsEuh6QI41JYcsS/qhTGa9ErIUUgK3WNQoJYvylxvjqmiqEA9Q==", + "requires": { + "p-try": "^1.0.0" + } + }, + "p-locate": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-2.0.0.tgz", + "integrity": "sha1-IKAQOyIqcMj9OcwuWAaA893l7EM=", + "requires": { + "p-limit": "^1.1.0" + } + }, + "p-try": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/p-try/-/p-try-1.0.0.tgz", + "integrity": "sha1-y8ec26+P1CKOE/Yh8rGiN8GyB7M=" + } + } + }, + "readable-stream": { + "version": "3.6.0", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.0.tgz", + "integrity": "sha512-BViHy7LKeTz4oNnkcLJ+lVSL6vpiFeX6/d3oSH8zCW7UxP2onchk+vTGB143xuFjHS3deTgkKoXXymXqymiIdA==", + "requires": { + "inherits": "^2.0.3", + "string_decoder": "^1.1.1", + "util-deprecate": "^1.0.1" + } + }, + "readdirp": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.3.0.tgz", + "integrity": "sha512-zz0pAkSPOXXm1viEwygWIPSPkcBYjW1xU5j/JBh5t9bGCJwa6f9+BJa6VaB2g+b55yVrmXzqkyLf4xaWYM0IkQ==", + "requires": { + "picomatch": "^2.0.7" + } + }, + "realpath-native": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/realpath-native/-/realpath-native-1.1.0.tgz", + "integrity": "sha512-wlgPA6cCIIg9gKz0fgAPjnzh4yR/LnXovwuo9hvyGvx3h8nX4+/iLZplfUWasXpqD8BdnGnP5njOFjkUwPzvjA==", + "requires": { + "util.promisify": "^1.0.0" + } + }, + "recursive-readdir": { + "version": "2.2.2", + "resolved": "https://registry.npmjs.org/recursive-readdir/-/recursive-readdir-2.2.2.tgz", + "integrity": "sha512-nRCcW9Sj7NuZwa2XvH9co8NPeXUBhZP7CRKJtU+cS6PW9FpCIFoI5ib0NT1ZrbNuPoRy0ylyCaUL8Gih4LSyFg==", + "requires": { + "minimatch": "3.0.4" + } + }, + "redent": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/redent/-/redent-3.0.0.tgz", + "integrity": "sha512-6tDA8g98We0zd0GvVeMT9arEOnTw9qM03L9cJXaCjrip1OO764RDBLBfrB4cwzNGDj5OA5ioymC9GkizgWJDUg==", + "requires": { + "indent-string": "^4.0.0", + "strip-indent": "^3.0.0" + } + }, + "regenerate": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/regenerate/-/regenerate-1.4.0.tgz", + "integrity": "sha512-1G6jJVDWrt0rK99kBjvEtziZNCICAuvIPkSiUFIQxVP06RCVpq3dmDo2oi6ABpYaDYaTRr67BEhL8r1wgEZZKg==" + }, + "regenerate-unicode-properties": { + "version": "8.1.0", + "resolved": "https://registry.npmjs.org/regenerate-unicode-properties/-/regenerate-unicode-properties-8.1.0.tgz", + "integrity": "sha512-LGZzkgtLY79GeXLm8Dp0BVLdQlWICzBnJz/ipWUgo59qBaZ+BHtq51P2q1uVZlppMuUAT37SDk39qUbjTWB7bA==", + "requires": { + "regenerate": "^1.4.0" + } + }, + "regenerator-runtime": { + "version": "0.13.3", + "resolved": "https://registry.npmjs.org/regenerator-runtime/-/regenerator-runtime-0.13.3.tgz", + "integrity": "sha512-naKIZz2GQ8JWh///G7L3X6LaQUAMp2lvb1rvwwsURe/VXwD6VMfr+/1NuNw3ag8v2kY1aQ/go5SNn79O9JU7yw==" + }, + "regenerator-transform": { + "version": "0.14.1", + "resolved": "https://registry.npmjs.org/regenerator-transform/-/regenerator-transform-0.14.1.tgz", + "integrity": "sha512-flVuee02C3FKRISbxhXl9mGzdbWUVHubl1SMaknjxkFB1/iqpJhArQUvRxOOPEc/9tAiX0BaQ28FJH10E4isSQ==", + "requires": { + "private": "^0.1.6" + } + }, + "regex-not": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/regex-not/-/regex-not-1.0.2.tgz", + "integrity": "sha512-J6SDjUgDxQj5NusnOtdFxDwN/+HWykR8GELwctJ7mdqhcyy1xEc4SRFHUXvxTp661YaVKAjfRLZ9cCqS6tn32A==", + "requires": { + "extend-shallow": "^3.0.2", + "safe-regex": "^1.1.0" + } + }, + "regex-parser": { + "version": "2.2.10", + "resolved": "https://registry.npmjs.org/regex-parser/-/regex-parser-2.2.10.tgz", + "integrity": "sha512-8t6074A68gHfU8Neftl0Le6KTDwfGAj7IyjPIMSfikI2wJUTHDMaIq42bUsfVnj8mhx0R+45rdUXHGpN164avA==" + }, + "regexp.prototype.flags": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/regexp.prototype.flags/-/regexp.prototype.flags-1.3.0.tgz", + "integrity": "sha512-2+Q0C5g951OlYlJz6yu5/M33IcsESLlLfsyIaLJaG4FA2r4yP8MvVMJUUP/fVBkSpbbbZlS5gynbEWLipiiXiQ==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.0-next.1" + } + }, + "regexpp": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/regexpp/-/regexpp-3.0.0.tgz", + "integrity": "sha512-Z+hNr7RAVWxznLPuA7DIh8UNX1j9CDrUQxskw9IrBE1Dxue2lyXT+shqEIeLUjrokxIP8CMy1WkjgG3rTsd5/g==" + }, + "regexpu-core": { + "version": "4.6.0", + "resolved": "https://registry.npmjs.org/regexpu-core/-/regexpu-core-4.6.0.tgz", + "integrity": "sha512-YlVaefl8P5BnFYOITTNzDvan1ulLOiXJzCNZxduTIosN17b87h3bvG9yHMoHaRuo88H4mQ06Aodj5VtYGGGiTg==", + "requires": { + "regenerate": "^1.4.0", + "regenerate-unicode-properties": "^8.1.0", + "regjsgen": "^0.5.0", + "regjsparser": "^0.6.0", + "unicode-match-property-ecmascript": "^1.0.4", + "unicode-match-property-value-ecmascript": "^1.1.0" + } + }, + "regjsgen": { + "version": "0.5.1", + "resolved": "https://registry.npmjs.org/regjsgen/-/regjsgen-0.5.1.tgz", + "integrity": "sha512-5qxzGZjDs9w4tzT3TPhCJqWdCc3RLYwy9J2NB0nm5Lz+S273lvWcpjaTGHsT1dc6Hhfq41uSEOw8wBmxrKOuyg==" + }, + "regjsparser": { + "version": "0.6.3", + "resolved": "https://registry.npmjs.org/regjsparser/-/regjsparser-0.6.3.tgz", + "integrity": "sha512-8uZvYbnfAtEm9Ab8NTb3hdLwL4g/LQzEYP7Xs27T96abJCCE2d6r3cPZPQEsLKy0vRSGVNG+/zVGtLr86HQduA==", + "requires": { + "jsesc": "~0.5.0" + }, + "dependencies": { + "jsesc": { + "version": "0.5.0", + "resolved": "https://registry.npmjs.org/jsesc/-/jsesc-0.5.0.tgz", + "integrity": "sha1-597mbjXW/Bb3EP6R1c9p9w8IkR0=" + } + } + }, + "relateurl": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/relateurl/-/relateurl-0.2.7.tgz", + "integrity": "sha1-VNvzd+UUQKypCkzSdGANP/LYiKk=" + }, + "remove-trailing-separator": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/remove-trailing-separator/-/remove-trailing-separator-1.1.0.tgz", + "integrity": "sha1-wkvOKig62tW8P1jg1IJJuSN52O8=" + }, + "renderkid": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/renderkid/-/renderkid-2.0.3.tgz", + "integrity": "sha512-z8CLQp7EZBPCwCnncgf9C4XAi3WR0dv+uWu/PjIyhhAb5d6IJ/QZqlHFprHeKT+59//V6BNUsLbvN8+2LarxGA==", + "requires": { + "css-select": "^1.1.0", + "dom-converter": "^0.2", + "htmlparser2": "^3.3.0", + "strip-ansi": "^3.0.0", + "utila": "^0.4.0" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + }, + "css-select": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/css-select/-/css-select-1.2.0.tgz", + "integrity": "sha1-KzoRBTnFNV8c2NMUYj6HCxIeyFg=", + "requires": { + "boolbase": "~1.0.0", + "css-what": "2.1", + "domutils": "1.5.1", + "nth-check": "~1.0.1" + } + }, + "css-what": { + "version": "2.1.3", + "resolved": "https://registry.npmjs.org/css-what/-/css-what-2.1.3.tgz", + "integrity": "sha512-a+EPoD+uZiNfh+5fxw2nO9QwFa6nJe2Or35fGY6Ipw1R3R4AGz1d1TEZrCegvw2YTmZ0jXirGYlzxxpYSHwpEg==" + }, + "domutils": { + "version": "1.5.1", + "resolved": "https://registry.npmjs.org/domutils/-/domutils-1.5.1.tgz", + "integrity": "sha1-3NhIiib1Y9YQeeSMn3t+Mjc2gs8=", + "requires": { + "dom-serializer": "0", + "domelementtype": "1" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "requires": { + "ansi-regex": "^2.0.0" + } + } + } + }, + "repeat-element": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/repeat-element/-/repeat-element-1.1.3.tgz", + "integrity": "sha512-ahGq0ZnV5m5XtZLMb+vP76kcAM5nkLqk0lpqAuojSKGgQtn4eRi4ZZGm2olo2zKFH+sMsWaqOCW1dqAnOru72g==" + }, + "repeat-string": { + "version": "1.6.1", + "resolved": "https://registry.npmjs.org/repeat-string/-/repeat-string-1.6.1.tgz", + "integrity": "sha1-jcrkcOHIirwtYA//Sndihtp15jc=" + }, + "request": { + "version": "2.88.2", + "resolved": "https://registry.npmjs.org/request/-/request-2.88.2.tgz", + "integrity": "sha512-MsvtOrfG9ZcrOwAW+Qi+F6HbD0CWXEh9ou77uOb7FM2WPhwT7smM833PzanhJLsgXjN89Ir6V2PczXNnMpwKhw==", + "requires": { + "aws-sign2": "~0.7.0", + "aws4": "^1.8.0", + "caseless": "~0.12.0", + "combined-stream": "~1.0.6", + "extend": "~3.0.2", + "forever-agent": "~0.6.1", + "form-data": "~2.3.2", + "har-validator": "~5.1.3", + "http-signature": "~1.2.0", + "is-typedarray": "~1.0.0", + "isstream": "~0.1.2", + "json-stringify-safe": "~5.0.1", + "mime-types": "~2.1.19", + "oauth-sign": "~0.9.0", + "performance-now": "^2.1.0", + "qs": "~6.5.2", + "safe-buffer": "^5.1.2", + "tough-cookie": "~2.5.0", + "tunnel-agent": "^0.6.0", + "uuid": "^3.3.2" + } + }, + "request-promise-core": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/request-promise-core/-/request-promise-core-1.1.3.tgz", + "integrity": "sha512-QIs2+ArIGQVp5ZYbWD5ZLCY29D5CfWizP8eWnm8FoGD1TX61veauETVQbrV60662V0oFBkrDOuaBI8XgtuyYAQ==", + "requires": { + "lodash": "^4.17.15" + } + }, + "request-promise-native": { + "version": "1.0.8", + "resolved": "https://registry.npmjs.org/request-promise-native/-/request-promise-native-1.0.8.tgz", + "integrity": "sha512-dapwLGqkHtwL5AEbfenuzjTYg35Jd6KPytsC2/TLkVMz8rm+tNt72MGUWT1RP/aYawMpN6HqbNGBQaRcBtjQMQ==", + "requires": { + "request-promise-core": "1.1.3", + "stealthy-require": "^1.1.1", + "tough-cookie": "^2.3.3" + } + }, + "require-directory": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/require-directory/-/require-directory-2.1.1.tgz", + "integrity": "sha1-jGStX9MNqxyXbiNE/+f3kqam30I=" + }, + "require-main-filename": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-2.0.0.tgz", + "integrity": "sha512-NKN5kMDylKuldxYLSUfrbo5Tuzh4hd+2E8NPPX02mZtn1VuREQToYe/ZdlJy+J3uCpfaiGF05e7B8W0iXbQHmg==" + }, + "requires-port": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/requires-port/-/requires-port-1.0.0.tgz", + "integrity": "sha1-kl0mAdOaxIXgkc8NpcbmlNw9yv8=" + }, + "resolve": { + "version": "1.15.1", + "resolved": "https://registry.npmjs.org/resolve/-/resolve-1.15.1.tgz", + "integrity": "sha512-84oo6ZTtoTUpjgNEr5SJyzQhzL72gaRodsSfyxC/AXRvwu0Yse9H8eF9IpGo7b8YetZhlI6v7ZQ6bKBFV/6S7w==", + "requires": { + "path-parse": "^1.0.6" + } + }, + "resolve-cwd": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/resolve-cwd/-/resolve-cwd-2.0.0.tgz", + "integrity": "sha1-AKn3OHVW4nA46uIyyqNypqWbZlo=", + "requires": { + "resolve-from": "^3.0.0" + } + }, + "resolve-from": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/resolve-from/-/resolve-from-3.0.0.tgz", + "integrity": "sha1-six699nWiBvItuZTM17rywoYh0g=" + }, + "resolve-url": { + "version": "0.2.1", + "resolved": "https://registry.npmjs.org/resolve-url/-/resolve-url-0.2.1.tgz", + "integrity": "sha1-LGN/53yJOv0qZj/iGqkIAGjiBSo=" + }, + "resolve-url-loader": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/resolve-url-loader/-/resolve-url-loader-3.1.1.tgz", + "integrity": "sha512-K1N5xUjj7v0l2j/3Sgs5b8CjrrgtC70SmdCuZiJ8tSyb5J+uk3FoeZ4b7yTnH6j7ngI+Bc5bldHJIa8hYdu2gQ==", + "requires": { + "adjust-sourcemap-loader": "2.0.0", + "camelcase": "5.3.1", + "compose-function": "3.0.3", + "convert-source-map": "1.7.0", + "es6-iterator": "2.0.3", + "loader-utils": "1.2.3", + "postcss": "7.0.21", + "rework": "1.0.1", + "rework-visit": "1.0.0", + "source-map": "0.6.1" + }, + "dependencies": { + "emojis-list": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/emojis-list/-/emojis-list-2.1.0.tgz", + "integrity": "sha1-TapNnbAPmBmIDHn6RXrlsJof04k=" + }, + "json5": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/json5/-/json5-1.0.1.tgz", + "integrity": "sha512-aKS4WQjPenRxiQsC93MNfjx+nbF4PAdYzmd/1JIj8HYzqfbu86beTuNgXDzPknWk0n0uARlyewZo4s++ES36Ow==", + "requires": { + "minimist": "^1.2.0" + } + }, + "loader-utils": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-1.2.3.tgz", + "integrity": "sha512-fkpz8ejdnEMG3s37wGL07iSBDg99O9D5yflE9RGNH3hRdx9SOwYfnGYdZOUIZitN8E+E2vkq3MUMYMvPYl5ZZA==", + "requires": { + "big.js": "^5.2.2", + "emojis-list": "^2.0.0", + "json5": "^1.0.1" + } + }, + "postcss": { + "version": "7.0.21", + "resolved": "https://registry.npmjs.org/postcss/-/postcss-7.0.21.tgz", + "integrity": "sha512-uIFtJElxJo29QC753JzhidoAhvp/e/Exezkdhfmt8AymWT6/5B7W1WmponYWkHk2eg6sONyTch0A3nkMPun3SQ==", + "requires": { + "chalk": "^2.4.2", + "source-map": "^0.6.1", + "supports-color": "^6.1.0" + } + } + } + }, + "restore-cursor": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/restore-cursor/-/restore-cursor-3.1.0.tgz", + "integrity": "sha512-l+sSefzHpj5qimhFSE5a8nufZYAM3sBSVMAPtYkmC+4EH2anSGaEMXSD0izRQbu9nfyQ9y5JrVmp7E8oZrUjvA==", + "requires": { + "onetime": "^5.1.0", + "signal-exit": "^3.0.2" + } + }, + "ret": { + "version": "0.1.15", + "resolved": "https://registry.npmjs.org/ret/-/ret-0.1.15.tgz", + "integrity": "sha512-TTlYpa+OL+vMMNG24xSlQGEJ3B/RzEfUlLct7b5G/ytav+wPrplCpVMFuwzXbkecJrb6IYo1iFb0S9v37754mg==" + }, + "retry": { + "version": "0.12.0", + "resolved": "https://registry.npmjs.org/retry/-/retry-0.12.0.tgz", + "integrity": "sha1-G0KmJmoh8HQh0bC1S33BZ7AcATs=" + }, + "rework": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/rework/-/rework-1.0.1.tgz", + "integrity": "sha1-MIBqhBNCtUUQqkEQhQzUhTQUSqc=", + "requires": { + "convert-source-map": "^0.3.3", + "css": "^2.0.0" + }, + "dependencies": { + "convert-source-map": { + "version": "0.3.5", + "resolved": "https://registry.npmjs.org/convert-source-map/-/convert-source-map-0.3.5.tgz", + "integrity": "sha1-8dgClQr33SYxof6+BZZVDIarMZA=" + } + } + }, + "rework-visit": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/rework-visit/-/rework-visit-1.0.0.tgz", + "integrity": "sha1-mUWygD8hni96ygCtuLyfZA+ELJo=" + }, + "rgb-regex": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/rgb-regex/-/rgb-regex-1.0.1.tgz", + "integrity": "sha1-wODWiC3w4jviVKR16O3UGRX+rrE=" + }, + "rgba-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/rgba-regex/-/rgba-regex-1.0.0.tgz", + "integrity": "sha1-QzdOLiyglosO8VI0YLfXMP8i7rM=" + }, + "rimraf": { + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/rimraf/-/rimraf-2.6.3.tgz", + "integrity": "sha512-mwqeW5XsA2qAejG46gYdENaxXjx9onRNCfn7L0duuP4hCuTIi/QO7PDK07KJfp1d+izWPrzEJDcSqBa0OZQriA==", + "requires": { + "glob": "^7.1.3" + } + }, + "ripemd160": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/ripemd160/-/ripemd160-2.0.2.tgz", + "integrity": "sha512-ii4iagi25WusVoiC4B4lq7pbXfAp3D9v5CwfkY33vffw2+pkDjY1D8GaN7spsxvCSx8dkPqOZCEZyfxcmJG2IA==", + "requires": { + "hash-base": "^3.0.0", + "inherits": "^2.0.1" + } + }, + "rsvp": { + "version": "4.8.5", + "resolved": "https://registry.npmjs.org/rsvp/-/rsvp-4.8.5.tgz", + "integrity": "sha512-nfMOlASu9OnRJo1mbEk2cz0D56a1MBNrJ7orjRZQG10XDyuvwksKbuXNp6qa+kbn839HwjwhBzhFmdsaEAfauA==" + }, + "run-async": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/run-async/-/run-async-2.3.0.tgz", + "integrity": "sha1-A3GrSuC91yDUFm19/aZP96RFpsA=", + "requires": { + "is-promise": "^2.1.0" + } + }, + "run-queue": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/run-queue/-/run-queue-1.0.3.tgz", + "integrity": "sha1-6Eg5bwV9Ij8kOGkkYY4laUFh7Ec=", + "requires": { + "aproba": "^1.1.1" + } + }, + "rxjs": { + "version": "6.5.4", + "resolved": "https://registry.npmjs.org/rxjs/-/rxjs-6.5.4.tgz", + "integrity": "sha512-naMQXcgEo3csAEGvw/NydRA0fuS2nDZJiw1YUWFKU7aPPAPGZEsD4Iimit96qwCieH6y614MCLYwdkrWx7z/7Q==", + "requires": { + "tslib": "^1.9.0" + } + }, + "safe-buffer": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.0.tgz", + "integrity": "sha512-fZEwUGbVl7kouZs1jCdMLdt95hdIv0ZeHg6L7qPeciMZhZ+/gdesW4wgTARkrFWEpspjEATAzUGPG8N2jJiwbg==" + }, + "safe-regex": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/safe-regex/-/safe-regex-1.1.0.tgz", + "integrity": "sha1-QKNmnzsHfR6UPURinhV91IAjvy4=", + "requires": { + "ret": "~0.1.10" + } + }, + "safer-buffer": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", + "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" + }, + "sane": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/sane/-/sane-4.1.0.tgz", + "integrity": "sha512-hhbzAgTIX8O7SHfp2c8/kREfEn4qO/9q8C9beyY6+tvZ87EpoZ3i1RIEvp27YBswnNbY9mWd6paKVmKbAgLfZA==", + "requires": { + "@cnakazawa/watch": "^1.0.3", + "anymatch": "^2.0.0", + "capture-exit": "^2.0.0", + "exec-sh": "^0.3.2", + "execa": "^1.0.0", + "fb-watchman": "^2.0.0", + "micromatch": "^3.1.4", + "minimist": "^1.1.1", + "walker": "~1.0.5" + } + }, + "sanitize.css": { + "version": "10.0.0", + "resolved": "https://registry.npmjs.org/sanitize.css/-/sanitize.css-10.0.0.tgz", + "integrity": "sha512-vTxrZz4dX5W86M6oVWVdOVe72ZiPs41Oi7Z6Km4W5Turyz28mrXSJhhEBZoRtzJWIv3833WKVwLSDWWkEfupMg==" + }, + "sass-loader": { + "version": "8.0.2", + "resolved": "https://registry.npmjs.org/sass-loader/-/sass-loader-8.0.2.tgz", + "integrity": "sha512-7o4dbSK8/Ol2KflEmSco4jTjQoV988bM82P9CZdmo9hR3RLnvNc0ufMNdMrB0caq38JQ/FgF4/7RcbcfKzxoFQ==", + "requires": { + "clone-deep": "^4.0.1", + "loader-utils": "^1.2.3", + "neo-async": "^2.6.1", + "schema-utils": "^2.6.1", + "semver": "^6.3.0" + }, + "dependencies": { + "clone-deep": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/clone-deep/-/clone-deep-4.0.1.tgz", + "integrity": "sha512-neHB9xuzh/wk0dIHweyAXv2aPGZIVk3pLMe+/RNzINf17fe0OG96QroktYAUm7SM1PBnzTabaLboqqxDyMU+SQ==", + "requires": { + "is-plain-object": "^2.0.4", + "kind-of": "^6.0.2", + "shallow-clone": "^3.0.0" + } + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + }, + "shallow-clone": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-3.0.1.tgz", + "integrity": "sha512-/6KqX+GVUdqPuPPd2LxDDxzX6CAbjJehAAOKlNpqqUpAqPM6HeL8f+o3a+JsyGjn2lv0WY8UsTgUJjU9Ok55NA==", + "requires": { + "kind-of": "^6.0.2" + } + } + } + }, + "sax": { + "version": "1.2.4", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.2.4.tgz", + "integrity": "sha512-NqVDv9TpANUjFm0N8uM5GxL36UgKi9/atZw+x7YFnQ8ckwFGKrl4xX4yWtrey3UJm5nP1kUbnYgLopqWNSRhWw==" + }, + "saxes": { + "version": "3.1.11", + "resolved": "https://registry.npmjs.org/saxes/-/saxes-3.1.11.tgz", + "integrity": "sha512-Ydydq3zC+WYDJK1+gRxRapLIED9PWeSuuS41wqyoRmzvhhh9nc+QQrVMKJYzJFULazeGhzSV0QleN2wD3boh2g==", + "requires": { + "xmlchars": "^2.1.1" + } + }, + "scheduler": { + "version": "0.18.0", + "resolved": "https://registry.npmjs.org/scheduler/-/scheduler-0.18.0.tgz", + "integrity": "sha512-agTSHR1Nbfi6ulI0kYNK0203joW2Y5W4po4l+v03tOoiJKpTBbxpNhWDvqc/4IcOw+KLmSiQLTasZ4cab2/UWQ==", + "requires": { + "loose-envify": "^1.1.0", + "object-assign": "^4.1.1" + } + }, + "schema-utils": { + "version": "2.6.4", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-2.6.4.tgz", + "integrity": "sha512-VNjcaUxVnEeun6B2fiiUDjXXBtD4ZSH7pdbfIu1pOFwgptDPLMo/z9jr4sUfsjFVPqDCEin/F7IYlq7/E6yDbQ==", + "requires": { + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1" + } + }, + "select-hose": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", + "integrity": "sha1-Yl2GWPhlr0Psliv8N2o3NZpJlMo=" + }, + "selfsigned": { + "version": "1.10.7", + "resolved": "https://registry.npmjs.org/selfsigned/-/selfsigned-1.10.7.tgz", + "integrity": "sha512-8M3wBCzeWIJnQfl43IKwOmC4H/RAp50S8DF60znzjW5GVqTcSe2vWclt7hmYVPkKPlHWOu5EaWOMZ2Y6W8ZXTA==", + "requires": { + "node-forge": "0.9.0" + } + }, + "semver": { + "version": "5.7.1", + "resolved": "https://registry.npmjs.org/semver/-/semver-5.7.1.tgz", + "integrity": "sha512-sauaDf/PZdVgrLTNYHRtpXa1iRiKcaebiKQ1BJdpQlWH2lCvexQdX55snPFyK7QzpudqbCI0qXFfOasHdyNDGQ==" + }, + "send": { + "version": "0.17.1", + "resolved": "https://registry.npmjs.org/send/-/send-0.17.1.tgz", + "integrity": "sha512-BsVKsiGcQMFwT8UxypobUKyv7irCNRHk1T0G680vk88yf6LBByGcZJOTJCrTP2xVN6yI+XjPJcNuE3V4fT9sAg==", + "requires": { + "debug": "2.6.9", + "depd": "~1.1.2", + "destroy": "~1.0.4", + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "etag": "~1.8.1", + "fresh": "0.5.2", + "http-errors": "~1.7.2", + "mime": "1.6.0", + "ms": "2.1.1", + "on-finished": "~2.3.0", + "range-parser": "~1.2.1", + "statuses": "~1.5.0" + }, + "dependencies": { + "mime": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", + "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==" + }, + "ms": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.1.tgz", + "integrity": "sha512-tgp+dl5cGk28utYktBsrFqA7HKgrhgPsg6Z/EfhWI4gl1Hwq8B/GmY/0oXZ6nF8hDVesS/FpnYaD/kOWhYQvyg==" + } + } + }, + "serialize-javascript": { + "version": "2.1.2", + "resolved": "https://registry.npmjs.org/serialize-javascript/-/serialize-javascript-2.1.2.tgz", + "integrity": "sha512-rs9OggEUF0V4jUSecXazOYsLfu7OGK2qIn3c7IPBiffz32XniEp/TX9Xmc9LQfK2nQ2QKHvZ2oygKUGU0lG4jQ==" + }, + "serve-index": { + "version": "1.9.1", + "resolved": "https://registry.npmjs.org/serve-index/-/serve-index-1.9.1.tgz", + "integrity": "sha1-03aNabHn2C5c4FD/9bRTvqEqkjk=", + "requires": { + "accepts": "~1.3.4", + "batch": "0.6.1", + "debug": "2.6.9", + "escape-html": "~1.0.3", + "http-errors": "~1.6.2", + "mime-types": "~2.1.17", + "parseurl": "~1.3.2" + }, + "dependencies": { + "http-errors": { + "version": "1.6.3", + "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-1.6.3.tgz", + "integrity": "sha1-i1VoC7S+KDoLW/TqLjhYC+HZMg0=", + "requires": { + "depd": "~1.1.2", + "inherits": "2.0.3", + "setprototypeof": "1.1.0", + "statuses": ">= 1.4.0 < 2" + } + }, + "inherits": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.3.tgz", + "integrity": "sha1-Yzwsg+PaQqUC9SRmAiSA9CCCYd4=" + }, + "setprototypeof": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.0.tgz", + "integrity": "sha512-BvE/TwpZX4FXExxOxZyRGQQv651MSwmWKZGqvmPcRIjDqWub67kTKuIMx43cZZrS/cBBzwBcNDWoFxt2XEFIpQ==" + } + } + }, + "serve-static": { + "version": "1.14.1", + "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.14.1.tgz", + "integrity": "sha512-JMrvUwE54emCYWlTI+hGrGv5I8dEwmco/00EvkzIIsR7MqrHonbD9pO2MOfFnpFntl7ecpZs+3mW+XbQZu9QCg==", + "requires": { + "encodeurl": "~1.0.2", + "escape-html": "~1.0.3", + "parseurl": "~1.3.3", + "send": "0.17.1" + } + }, + "set-blocking": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/set-blocking/-/set-blocking-2.0.0.tgz", + "integrity": "sha1-BF+XgtARrppoA93TgrJDkrPYkPc=" + }, + "set-value": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/set-value/-/set-value-2.0.1.tgz", + "integrity": "sha512-JxHc1weCN68wRY0fhCoXpyK55m/XPHafOmK4UWD7m2CI14GMcFypt4w/0+NV5f/ZMby2F6S2wwA7fgynh9gWSw==", + "requires": { + "extend-shallow": "^2.0.1", + "is-extendable": "^0.1.1", + "is-plain-object": "^2.0.3", + "split-string": "^3.0.1" + }, + "dependencies": { + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + } + } + }, + "setimmediate": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/setimmediate/-/setimmediate-1.0.5.tgz", + "integrity": "sha1-KQy7Iy4waULX1+qbg3Mqt4VvgoU=" + }, + "setprototypeof": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.1.1.tgz", + "integrity": "sha512-JvdAWfbXeIGaZ9cILp38HntZSFSo3mWg6xGcJJsd+d4aRMOqauag1C63dJfDw7OaMYwEbHMOxEZ1lqVRYP2OAw==" + }, + "sha.js": { + "version": "2.4.11", + "resolved": "https://registry.npmjs.org/sha.js/-/sha.js-2.4.11.tgz", + "integrity": "sha512-QMEp5B7cftE7APOjk5Y6xgrbWu+WkLVQwk8JNjZ8nKRciZaByEW6MubieAiToS7+dwvrjGhH8jRXz3MVd0AYqQ==", + "requires": { + "inherits": "^2.0.1", + "safe-buffer": "^5.0.1" + } + }, + "shallow-clone": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/shallow-clone/-/shallow-clone-0.1.2.tgz", + "integrity": "sha1-WQnodLp3EG1zrEFM/sH/yofZcGA=", + "requires": { + "is-extendable": "^0.1.1", + "kind-of": "^2.0.1", + "lazy-cache": "^0.2.3", + "mixin-object": "^2.0.1" + }, + "dependencies": { + "kind-of": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-2.0.1.tgz", + "integrity": "sha1-AY7HpM5+OobLkUG+UZ0kyPqpgbU=", + "requires": { + "is-buffer": "^1.0.2" + } + }, + "lazy-cache": { + "version": "0.2.7", + "resolved": "https://registry.npmjs.org/lazy-cache/-/lazy-cache-0.2.7.tgz", + "integrity": "sha1-f+3fLctu23fRHvHRF6tf/fCrG2U=" + } + } + }, + "shebang-command": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/shebang-command/-/shebang-command-1.2.0.tgz", + "integrity": "sha1-RKrGW2lbAzmJaMOfNj/uXer98eo=", + "requires": { + "shebang-regex": "^1.0.0" + } + }, + "shebang-regex": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/shebang-regex/-/shebang-regex-1.0.0.tgz", + "integrity": "sha1-2kL0l0DAtC2yypcoVxyxkMmO/qM=" + }, + "shell-quote": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/shell-quote/-/shell-quote-1.7.2.tgz", + "integrity": "sha512-mRz/m/JVscCrkMyPqHc/bczi3OQHkLTqXHEFu0zDhK/qfv3UcOA4SVmRCLmos4bhjr9ekVQubj/R7waKapmiQg==" + }, + "shellwords": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/shellwords/-/shellwords-0.1.1.tgz", + "integrity": "sha512-vFwSUfQvqybiICwZY5+DAWIPLKsWO31Q91JSKl3UYv+K5c2QRPzn0qzec6QPu1Qc9eHYItiP3NdJqNVqetYAww==" + }, + "signal-exit": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/signal-exit/-/signal-exit-3.0.2.tgz", + "integrity": "sha1-tf3AjxKH6hF4Yo5BXiUTK3NkbG0=" + }, + "simple-concat": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/simple-concat/-/simple-concat-1.0.0.tgz", + "integrity": "sha1-c0TLuLbib7J9ZrL8hvn21Zl1IcY=", + "optional": true + }, + "simple-get": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/simple-get/-/simple-get-3.1.0.tgz", + "integrity": "sha512-bCR6cP+aTdScaQCnQKbPKtJOKDp/hj9EDLJo3Nw4y1QksqaovlW/bnptB6/c1e+qmNIDHRK+oXFDdEqBT8WzUA==", + "optional": true, + "requires": { + "decompress-response": "^4.2.0", + "once": "^1.3.1", + "simple-concat": "^1.0.0" + } + }, + "simple-swizzle": { + "version": "0.2.2", + "resolved": "https://registry.npmjs.org/simple-swizzle/-/simple-swizzle-0.2.2.tgz", + "integrity": "sha1-pNprY1/8zMoz9w0Xy5JZLeleVXo=", + "requires": { + "is-arrayish": "^0.3.1" + }, + "dependencies": { + "is-arrayish": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/is-arrayish/-/is-arrayish-0.3.2.tgz", + "integrity": "sha512-eVRqCvVlZbuw3GrM63ovNSNAeA1K16kaR/LRY/92w0zxQ5/1YzwblUX652i4Xs9RwAGjW9d9y6X88t8OaAJfWQ==" + } + } + }, + "sisteransi": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/sisteransi/-/sisteransi-1.0.4.tgz", + "integrity": "sha512-/ekMoM4NJ59ivGSfKapeG+FWtrmWvA1p6FBZwXrqojw90vJu8lBmrTxCMuBCydKtkaUe2zt4PlxeTKpjwMbyig==" + }, + "slash": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/slash/-/slash-2.0.0.tgz", + "integrity": "sha512-ZYKh3Wh2z1PpEXWr0MpSBZ0V6mZHAQfYevttO11c51CaWjGTaadiKZ+wVt1PbMlDV5qhMFslpZCemhwOK7C89A==" + }, + "slice-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/slice-ansi/-/slice-ansi-2.1.0.tgz", + "integrity": "sha512-Qu+VC3EwYLldKa1fCxuuvULvSJOKEgk9pi8dZeCVK7TqBfUNTH4sFkk4joj8afVSfAYgJoSOetjx9QWOJ5mYoQ==", + "requires": { + "ansi-styles": "^3.2.0", + "astral-regex": "^1.0.0", + "is-fullwidth-code-point": "^2.0.0" + }, + "dependencies": { + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + } + } + }, + "snapdragon": { + "version": "0.8.2", + "resolved": "https://registry.npmjs.org/snapdragon/-/snapdragon-0.8.2.tgz", + "integrity": "sha512-FtyOnWN/wCHTVXOMwvSv26d+ko5vWlIDD6zoUJ7LW8vh+ZBC8QdljveRP+crNrtBwioEUWy/4dMtbBjA4ioNlg==", + "requires": { + "base": "^0.11.1", + "debug": "^2.2.0", + "define-property": "^0.2.5", + "extend-shallow": "^2.0.1", + "map-cache": "^0.2.2", + "source-map": "^0.5.6", + "source-map-resolve": "^0.5.0", + "use": "^3.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + }, + "extend-shallow": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/extend-shallow/-/extend-shallow-2.0.1.tgz", + "integrity": "sha1-Ua99YUrZqfYQ6huvu5idaxxWiQ8=", + "requires": { + "is-extendable": "^0.1.0" + } + }, + "source-map": { + "version": "0.5.7", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.5.7.tgz", + "integrity": "sha1-igOdLRAh0i0eoUyA2OpGi6LvP8w=" + } + } + }, + "snapdragon-node": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/snapdragon-node/-/snapdragon-node-2.1.1.tgz", + "integrity": "sha512-O27l4xaMYt/RSQ5TR3vpWCAB5Kb/czIcqUFOM/C4fYcLnbZUc1PkjTAMjof2pBWaSTwOUd6qUHcFGVGj7aIwnw==", + "requires": { + "define-property": "^1.0.0", + "isobject": "^3.0.0", + "snapdragon-util": "^3.0.1" + }, + "dependencies": { + "define-property": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-1.0.0.tgz", + "integrity": "sha1-dp66rz9KY6rTr56NMEybvnm/sOY=", + "requires": { + "is-descriptor": "^1.0.0" + } + }, + "is-accessor-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-accessor-descriptor/-/is-accessor-descriptor-1.0.0.tgz", + "integrity": "sha512-m5hnHTkcVsPfqx3AKlyttIPb7J+XykHvJP2B9bZDjlhLIoEq4XoK64Vg7boZlVWYK6LUY94dYPEE7Lh0ZkZKcQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-data-descriptor": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-data-descriptor/-/is-data-descriptor-1.0.0.tgz", + "integrity": "sha512-jbRXy1FmtAoCjQkVmIVYwuuqDFUbaOeDjmed1tOGPrsMhtJA4rD9tkgA0F1qJ3gRFRXcHYVkdeaP50Q5rE/jLQ==", + "requires": { + "kind-of": "^6.0.0" + } + }, + "is-descriptor": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/is-descriptor/-/is-descriptor-1.0.2.tgz", + "integrity": "sha512-2eis5WqQGV7peooDyLmNEPUrps9+SXX5c9pL3xEB+4e9HnGuDa7mB7kHxHw4CbqS9k1T2hOH3miL8n8WtiYVtg==", + "requires": { + "is-accessor-descriptor": "^1.0.0", + "is-data-descriptor": "^1.0.0", + "kind-of": "^6.0.2" + } + }, + "kind-of": { + "version": "6.0.3", + "resolved": "https://registry.npmjs.org/kind-of/-/kind-of-6.0.3.tgz", + "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==" + } + } + }, + "snapdragon-util": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/snapdragon-util/-/snapdragon-util-3.0.1.tgz", + "integrity": "sha512-mbKkMdQKsjX4BAL4bRYTj21edOf8cN7XHdYUJEe+Zn99hVEYcMvKPct1IqNe7+AZPirn8BCDOQBHQZknqmKlZQ==", + "requires": { + "kind-of": "^3.2.0" + } + }, + "sockjs": { + "version": "0.3.19", + "resolved": "https://registry.npmjs.org/sockjs/-/sockjs-0.3.19.tgz", + "integrity": "sha512-V48klKZl8T6MzatbLlzzRNhMepEys9Y4oGFpypBFFn1gLI/QQ9HtLLyWJNbPlwGLelOVOEijUbTTJeLLI59jLw==", + "requires": { + "faye-websocket": "^0.10.0", + "uuid": "^3.0.1" + } + }, + "sockjs-client": { + "version": "1.4.0", + "resolved": "https://registry.npmjs.org/sockjs-client/-/sockjs-client-1.4.0.tgz", + "integrity": "sha512-5zaLyO8/nri5cua0VtOrFXBPK1jbL4+1cebT/mmKA1E1ZXOvJrII75bPu0l0k843G/+iAbhEqzyKr0w/eCCj7g==", + "requires": { + "debug": "^3.2.5", + "eventsource": "^1.0.7", + "faye-websocket": "~0.11.1", + "inherits": "^2.0.3", + "json3": "^3.3.2", + "url-parse": "^1.4.3" + }, + "dependencies": { + "debug": { + "version": "3.2.6", + "resolved": "https://registry.npmjs.org/debug/-/debug-3.2.6.tgz", + "integrity": "sha512-mel+jf7nrtEl5Pn1Qx46zARXKDpBbvzezse7p7LqINmdoIk8PYP5SySaxEmYv6TZ0JyEKA1hsCId6DIhgITtWQ==", + "requires": { + "ms": "^2.1.1" + } + }, + "faye-websocket": { + "version": "0.11.3", + "resolved": "https://registry.npmjs.org/faye-websocket/-/faye-websocket-0.11.3.tgz", + "integrity": "sha512-D2y4bovYpzziGgbHYtGCMjlJM36vAl/y+xUyn1C+FVx8szd1E+86KwVw6XvYSzOP8iMpm1X0I4xJD+QtUb36OA==", + "requires": { + "websocket-driver": ">=0.5.1" + } + } + } + }, + "sort-keys": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/sort-keys/-/sort-keys-1.1.2.tgz", + "integrity": "sha1-RBttTTRnmPG05J6JIK37oOVD+a0=", + "requires": { + "is-plain-obj": "^1.0.0" + } + }, + "source-list-map": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/source-list-map/-/source-list-map-2.0.1.tgz", + "integrity": "sha512-qnQ7gVMxGNxsiL4lEuJwe/To8UnK7fAnmbGEEH8RpLouuKbeEm0lhbQVFIrNSuB+G7tVrAlVsZgETT5nljf+Iw==" + }, + "source-map": { + "version": "0.6.1", + "resolved": "https://registry.npmjs.org/source-map/-/source-map-0.6.1.tgz", + "integrity": "sha512-UjgapumWlbMhkBgzT7Ykc5YXUT46F0iKu8SGXq0bcwP5dz/h0Plj6enJqjz1Zbq2l5WaqYnrVbwWOWMyF3F47g==" + }, + "source-map-resolve": { + "version": "0.5.3", + "resolved": "https://registry.npmjs.org/source-map-resolve/-/source-map-resolve-0.5.3.tgz", + "integrity": "sha512-Htz+RnsXWk5+P2slx5Jh3Q66vhQj1Cllm0zvnaY98+NFx+Dv2CF/f5O/t8x+KaNdrdIAsruNzoh/KpialbqAnw==", + "requires": { + "atob": "^2.1.2", + "decode-uri-component": "^0.2.0", + "resolve-url": "^0.2.1", + "source-map-url": "^0.4.0", + "urix": "^0.1.0" + } + }, + "source-map-support": { + "version": "0.5.16", + "resolved": "https://registry.npmjs.org/source-map-support/-/source-map-support-0.5.16.tgz", + "integrity": "sha512-efyLRJDr68D9hBBNIPWFjhpFzURh+KJykQwvMyW5UiZzYwoF6l4YMMDIJJEyFWxWCqfyxLzz6tSfUFR+kXXsVQ==", + "requires": { + "buffer-from": "^1.0.0", + "source-map": "^0.6.0" + } + }, + "source-map-url": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/source-map-url/-/source-map-url-0.4.0.tgz", + "integrity": "sha1-PpNdfd1zYxuXZZlW1VEo6HtQhKM=" + }, + "spdx-correct": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/spdx-correct/-/spdx-correct-3.1.0.tgz", + "integrity": "sha512-lr2EZCctC2BNR7j7WzJ2FpDznxky1sjfxvvYEyzxNyb6lZXHODmEoJeFu4JupYlkfha1KZpJyoqiJ7pgA1qq8Q==", + "requires": { + "spdx-expression-parse": "^3.0.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-exceptions": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/spdx-exceptions/-/spdx-exceptions-2.2.0.tgz", + "integrity": "sha512-2XQACfElKi9SlVb1CYadKDXvoajPgBVPn/gOQLrTvHdElaVhr7ZEbqJaRnJLVNeaI4cMEAgVCeBMKF6MWRDCRA==" + }, + "spdx-expression-parse": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdx-expression-parse/-/spdx-expression-parse-3.0.0.tgz", + "integrity": "sha512-Yg6D3XpRD4kkOmTpdgbUiEJFKghJH03fiC1OPll5h/0sO6neh2jqRDVHOQ4o/LMea0tgCkbMgea5ip/e+MkWyg==", + "requires": { + "spdx-exceptions": "^2.1.0", + "spdx-license-ids": "^3.0.0" + } + }, + "spdx-license-ids": { + "version": "3.0.5", + "resolved": "https://registry.npmjs.org/spdx-license-ids/-/spdx-license-ids-3.0.5.tgz", + "integrity": "sha512-J+FWzZoynJEXGphVIS+XEh3kFSjZX/1i9gFBaWQcB+/tmpe2qUsSBABpcxqxnAxFdiUFEgAX1bjYGQvIZmoz9Q==" + }, + "spdy": { + "version": "4.0.1", + "resolved": "https://registry.npmjs.org/spdy/-/spdy-4.0.1.tgz", + "integrity": "sha512-HeZS3PBdMA+sZSu0qwpCxl3DeALD5ASx8pAX0jZdKXSpPWbQ6SYGnlg3BBmYLx5LtiZrmkAZfErCm2oECBcioA==", + "requires": { + "debug": "^4.1.0", + "handle-thing": "^2.0.0", + "http-deceiver": "^1.2.7", + "select-hose": "^2.0.0", + "spdy-transport": "^3.0.0" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "spdy-transport": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/spdy-transport/-/spdy-transport-3.0.0.tgz", + "integrity": "sha512-hsLVFE5SjA6TCisWeJXFKniGGOpBgMLmerfO2aCyCU5s7nJ/rpAepqmFifv/GCbSbueEeAJJnmSQ2rKC/g8Fcw==", + "requires": { + "debug": "^4.1.0", + "detect-node": "^2.0.4", + "hpack.js": "^2.1.6", + "obuf": "^1.1.2", + "readable-stream": "^3.0.6", + "wbuf": "^1.7.3" + }, + "dependencies": { + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + } + } + }, + "split-string": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/split-string/-/split-string-3.1.0.tgz", + "integrity": "sha512-NzNVhJDYpwceVVii8/Hu6DKfD2G+NrQHlS/V/qgv763EYudVwEcMQNxd2lh+0VrUByXN/oJkl5grOhYWvQUYiw==", + "requires": { + "extend-shallow": "^3.0.0" + } + }, + "sprintf-js": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/sprintf-js/-/sprintf-js-1.0.3.tgz", + "integrity": "sha1-BOaSb2YolTVPPdAVIDYzuFcpfiw=" + }, + "sshpk": { + "version": "1.16.1", + "resolved": "https://registry.npmjs.org/sshpk/-/sshpk-1.16.1.tgz", + "integrity": "sha512-HXXqVUq7+pcKeLqqZj6mHFUMvXtOJt1uoUx09pFW6011inTMxqI8BA8PM95myrIyyKwdnzjdFjLiE6KBPVtJIg==", + "requires": { + "asn1": "~0.2.3", + "assert-plus": "^1.0.0", + "bcrypt-pbkdf": "^1.0.0", + "dashdash": "^1.12.0", + "ecc-jsbn": "~0.1.1", + "getpass": "^0.1.1", + "jsbn": "~0.1.0", + "safer-buffer": "^2.0.2", + "tweetnacl": "~0.14.0" + } + }, + "ssri": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-7.1.0.tgz", + "integrity": "sha512-77/WrDZUWocK0mvA5NTRQyveUf+wsrIc6vyrxpS8tVvYBcX215QbafrJR3KtkpskIzoFLqqNuuYQvxaMjXJ/0g==", + "requires": { + "figgy-pudding": "^3.5.1", + "minipass": "^3.1.1" + } + }, + "stable": { + "version": "0.1.8", + "resolved": "https://registry.npmjs.org/stable/-/stable-0.1.8.tgz", + "integrity": "sha512-ji9qxRnOVfcuLDySj9qzhGSEFVobyt1kIOSkj1qZzYLzq7Tos/oUUWvotUPQLlrsidqsK6tBH89Bc9kL5zHA6w==" + }, + "stack-utils": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/stack-utils/-/stack-utils-1.0.2.tgz", + "integrity": "sha512-MTX+MeG5U994cazkjd/9KNAapsHnibjMLnfXodlkXw76JEea0UiNzrqidzo1emMwk7w5Qhc9jd4Bn9TBb1MFwA==" + }, + "static-extend": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/static-extend/-/static-extend-0.1.2.tgz", + "integrity": "sha1-YICcOcv/VTNyJv1eC1IPNB8ftcY=", + "requires": { + "define-property": "^0.2.5", + "object-copy": "^0.1.0" + }, + "dependencies": { + "define-property": { + "version": "0.2.5", + "resolved": "https://registry.npmjs.org/define-property/-/define-property-0.2.5.tgz", + "integrity": "sha1-w1se+RjsPJkPmlvFe+BKrOxcgRY=", + "requires": { + "is-descriptor": "^0.1.0" + } + } + } + }, + "statuses": { + "version": "1.5.0", + "resolved": "https://registry.npmjs.org/statuses/-/statuses-1.5.0.tgz", + "integrity": "sha1-Fhx9rBd2Wf2YEfQ3cfqZOBR4Yow=" + }, + "stealthy-require": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/stealthy-require/-/stealthy-require-1.1.1.tgz", + "integrity": "sha1-NbCYdbT/SfJqd35QmzCQoyJr8ks=" + }, + "stream-browserify": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/stream-browserify/-/stream-browserify-2.0.2.tgz", + "integrity": "sha512-nX6hmklHs/gr2FuxYDltq8fJA1GDlxKQCz8O/IM4atRqBH8OORmBNgfvW5gG10GT/qQ9u0CzIvr2X5Pkt6ntqg==", + "requires": { + "inherits": "~2.0.1", + "readable-stream": "^2.0.2" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "stream-each": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/stream-each/-/stream-each-1.2.3.tgz", + "integrity": "sha512-vlMC2f8I2u/bZGqkdfLQW/13Zihpej/7PmSiMQsbYddxuTsJp8vRe2x2FvVExZg7FaOds43ROAuFJwPR4MTZLw==", + "requires": { + "end-of-stream": "^1.1.0", + "stream-shift": "^1.0.0" + } + }, + "stream-http": { + "version": "2.8.3", + "resolved": "https://registry.npmjs.org/stream-http/-/stream-http-2.8.3.tgz", + "integrity": "sha512-+TSkfINHDo4J+ZobQLWiMouQYB+UVYFttRA94FpEzzJ7ZdqcL4uUUQ7WkdkI4DSozGmgBUE/a47L+38PenXhUw==", + "requires": { + "builtin-status-codes": "^3.0.0", + "inherits": "^2.0.1", + "readable-stream": "^2.3.6", + "to-arraybuffer": "^1.0.0", + "xtend": "^4.0.0" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "stream-shift": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/stream-shift/-/stream-shift-1.0.1.tgz", + "integrity": "sha512-AiisoFqQ0vbGcZgQPY1cdP2I76glaVA/RauYR4G4thNFgkTqr90yXTo4LYX60Jl+sIlPNHHdGSwo01AvbKUSVQ==" + }, + "strict-uri-encode": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/strict-uri-encode/-/strict-uri-encode-1.1.0.tgz", + "integrity": "sha1-J5siXfHVgrH1TmWt3UNS4Y+qBxM=" + }, + "string-length": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/string-length/-/string-length-2.0.0.tgz", + "integrity": "sha1-1A27aGo6zpYMHP/KVivyxF+DY+0=", + "requires": { + "astral-regex": "^1.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "string-width": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-4.2.0.tgz", + "integrity": "sha512-zUz5JD+tgqtuDjMhwIg5uFVV3dtqZ9yQJlZVfq4I01/K5Paj5UHj7VyrQOJvzawSVlKpObApbfD0Ed6yJc+1eg==", + "requires": { + "emoji-regex": "^8.0.0", + "is-fullwidth-code-point": "^3.0.0", + "strip-ansi": "^6.0.0" + }, + "dependencies": { + "strip-ansi": { + "version": "6.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-6.0.0.tgz", + "integrity": "sha512-AuvKTrTfQNYNIctbR1K/YGTR1756GycPsg7b9bdV9Duqur4gv6aKqHXah67Z8ImS7WEz5QVcOtlfW2rZEugt6w==", + "requires": { + "ansi-regex": "^5.0.0" + } + } + } + }, + "string.prototype.trimleft": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string.prototype.trimleft/-/string.prototype.trimleft-2.1.1.tgz", + "integrity": "sha512-iu2AGd3PuP5Rp7x2kEZCrB2Nf41ehzh+goo8TV7z8/XDBbsvc6HQIlUl9RjkZ4oyrW1XM5UwlGl1oVEaDjg6Ag==", + "requires": { + "define-properties": "^1.1.3", + "function-bind": "^1.1.1" + } + }, + "string.prototype.trimright": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string.prototype.trimright/-/string.prototype.trimright-2.1.1.tgz", + "integrity": "sha512-qFvWL3/+QIgZXVmJBfpHmxLB7xsUXz6HsUmP8+5dRaC3Q7oKUv9Vo6aMCRZC1smrtyECFsIT30PqBJ1gTjAs+g==", + "requires": { + "define-properties": "^1.1.3", + "function-bind": "^1.1.1" + } + }, + "string_decoder": { + "version": "1.3.0", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.3.0.tgz", + "integrity": "sha512-hkRX8U1WjJFd8LsDJ2yQ/wWWxaopEsABU1XfkM8A+j0+85JAGppt16cr1Whg6KIbb4okU6Mql6BOj+uup/wKeA==", + "requires": { + "safe-buffer": "~5.2.0" + } + }, + "stringify-object": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/stringify-object/-/stringify-object-3.3.0.tgz", + "integrity": "sha512-rHqiFh1elqCQ9WPLIC8I0Q/g/wj5J1eMkyoiD6eoQApWHP0FtlK7rqnhmabL5VUY9JQCcqwwvlOaSuutekgyrw==", + "requires": { + "get-own-enumerable-property-symbols": "^3.0.0", + "is-obj": "^1.0.1", + "is-regexp": "^1.0.0" + }, + "dependencies": { + "is-obj": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-obj/-/is-obj-1.0.1.tgz", + "integrity": "sha1-PkcprB9f3gJc19g6iW2rn09n2w8=" + } + } + }, + "strip-ansi": { + "version": "5.2.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-5.2.0.tgz", + "integrity": "sha512-DuRs1gKbBqsMKIZlrffwlug8MHkcnpjs5VPmL1PAh+mA30U0DTotfDZ0d2UUsXpPmPmMMJ6W773MaA3J+lbiWA==", + "requires": { + "ansi-regex": "^4.1.0" + }, + "dependencies": { + "ansi-regex": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-4.1.0.tgz", + "integrity": "sha512-1apePfXM1UOSqw0o9IiFAovVz9M5S1Dg+4TrDwfMewQ6p/rmMueb7tWZjQ1rx4Loy1ArBggoqGpfqqdI4rondg==" + } + } + }, + "strip-bom": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-bom/-/strip-bom-3.0.0.tgz", + "integrity": "sha1-IzTBjpx1n3vdVv3vfprj1YjmjtM=" + }, + "strip-comments": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/strip-comments/-/strip-comments-1.0.2.tgz", + "integrity": "sha512-kL97alc47hoyIQSV165tTt9rG5dn4w1dNnBhOQ3bOU1Nc1hel09jnXANaHJ7vzHLd4Ju8kseDGzlev96pghLFw==", + "requires": { + "babel-extract-comments": "^1.0.0", + "babel-plugin-transform-object-rest-spread": "^6.26.0" + } + }, + "strip-eof": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/strip-eof/-/strip-eof-1.0.0.tgz", + "integrity": "sha1-u0P/VZim6wXYm1n80SnJgzE2Br8=" + }, + "strip-indent": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/strip-indent/-/strip-indent-3.0.0.tgz", + "integrity": "sha512-laJTa3Jb+VQpaC6DseHhF7dXVqHTfJPCRDaEbid/drOhgitgYku/letMUqOXFoWV0zIIUbjpdH2t+tYj4bQMRQ==", + "requires": { + "min-indent": "^1.0.0" + } + }, + "strip-json-comments": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-json-comments/-/strip-json-comments-3.0.1.tgz", + "integrity": "sha512-VTyMAUfdm047mwKl+u79WIdrZxtFtn+nBxHeb844XBQ9uMNTuTHdx2hc5RiAJYqwTj3wc/xe5HLSdJSkJ+WfZw==" + }, + "style-loader": { + "version": "0.23.1", + "resolved": "https://registry.npmjs.org/style-loader/-/style-loader-0.23.1.tgz", + "integrity": "sha512-XK+uv9kWwhZMZ1y7mysB+zoihsEj4wneFWAS5qoiLwzW0WzSqMrrsIy+a3zkQJq0ipFtBpX5W3MqyRIBF/WFGg==", + "requires": { + "loader-utils": "^1.1.0", + "schema-utils": "^1.0.0" + }, + "dependencies": { + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + } + } + }, + "stylehacks": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/stylehacks/-/stylehacks-4.0.3.tgz", + "integrity": "sha512-7GlLk9JwlElY4Y6a/rmbH2MhVlTyVmiJd1PfTCqFaIBEGMYNsrO/v3SeGTdhBThLg4Z+NbOk/qFMwCa+J+3p/g==", + "requires": { + "browserslist": "^4.0.0", + "postcss": "^7.0.0", + "postcss-selector-parser": "^3.0.0" + }, + "dependencies": { + "postcss-selector-parser": { + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/postcss-selector-parser/-/postcss-selector-parser-3.1.2.tgz", + "integrity": "sha512-h7fJ/5uWuRVyOtkO45pnt1Ih40CEleeyCHzipqAZO2e5H20g25Y48uYnFUiShvY4rZWNJ/Bib/KVPmanaCtOhA==", + "requires": { + "dot-prop": "^5.2.0", + "indexes-of": "^1.0.1", + "uniq": "^1.0.1" + } + } + } + }, + "supports-color": { + "version": "6.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-6.1.0.tgz", + "integrity": "sha512-qe1jfm1Mg7Nq/NSh6XE24gPXROEVsWHxC1LIx//XNlD9iw7YZQGjZNjYN7xGaEG6iKdA8EtNFW6R0gjnVXp+wQ==", + "requires": { + "has-flag": "^3.0.0" + } + }, + "svg-parser": { + "version": "2.0.3", + "resolved": "https://registry.npmjs.org/svg-parser/-/svg-parser-2.0.3.tgz", + "integrity": "sha512-fnCWiifNhK8i2Z7b9R5tbNahpxrRdAaQbnoxKlT2KrSCj9Kq/yBSgulCRgBJRhy1dPnSY5slg5ehPUnzpEcHlg==" + }, + "svgo": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/svgo/-/svgo-1.3.2.tgz", + "integrity": "sha512-yhy/sQYxR5BkC98CY7o31VGsg014AKLEPxdfhora76l36hD9Rdy5NZA/Ocn6yayNPgSamYdtX2rFJdcv07AYVw==", + "requires": { + "chalk": "^2.4.1", + "coa": "^2.0.2", + "css-select": "^2.0.0", + "css-select-base-adapter": "^0.1.1", + "css-tree": "1.0.0-alpha.37", + "csso": "^4.0.2", + "js-yaml": "^3.13.1", + "mkdirp": "~0.5.1", + "object.values": "^1.1.0", + "sax": "~1.2.4", + "stable": "^0.1.8", + "unquote": "~1.1.1", + "util.promisify": "~1.0.0" + } + }, + "symbol-tree": { + "version": "3.2.4", + "resolved": "https://registry.npmjs.org/symbol-tree/-/symbol-tree-3.2.4.tgz", + "integrity": "sha512-9QNk5KwDF+Bvz+PyObkmSYjI5ksVUYtjW7AU22r2NKcfLJcXp96hkDWU3+XndOsUb+AQ9QhfzfCT2O+CNWT5Tw==" + }, + "table": { + "version": "5.4.6", + "resolved": "https://registry.npmjs.org/table/-/table-5.4.6.tgz", + "integrity": "sha512-wmEc8m4fjnob4gt5riFRtTu/6+4rSe12TpAELNSqHMfF3IqnA+CH37USM6/YR3qRZv7e56kAEAtd6nKZaxe0Ug==", + "requires": { + "ajv": "^6.10.2", + "lodash": "^4.17.14", + "slice-ansi": "^2.1.0", + "string-width": "^3.0.0" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "tapable": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/tapable/-/tapable-1.1.3.tgz", + "integrity": "sha512-4WK/bYZmj8xLr+HUCODHGF1ZFzsYffasLUgEiMBY4fgtltdO6B4WJtlSbPaDTLpYTcGVwM2qLnFTICEcNxs3kA==" + }, + "tar": { + "version": "4.4.13", + "resolved": "https://registry.npmjs.org/tar/-/tar-4.4.13.tgz", + "integrity": "sha512-w2VwSrBoHa5BsSyH+KxEqeQBAllHhccyMFVHtGtdMpF4W7IRWfZjFiQceJPChOeTsSDVUpER2T8FA93pr0L+QA==", + "optional": true, + "requires": { + "chownr": "^1.1.1", + "fs-minipass": "^1.2.5", + "minipass": "^2.8.6", + "minizlib": "^1.2.1", + "mkdirp": "^0.5.0", + "safe-buffer": "^5.1.2", + "yallist": "^3.0.3" + }, + "dependencies": { + "fs-minipass": { + "version": "1.2.7", + "resolved": "https://registry.npmjs.org/fs-minipass/-/fs-minipass-1.2.7.tgz", + "integrity": "sha512-GWSSJGFy4e9GUeCcbIkED+bgAoFyj7XF1mV8rma3QW4NIqX9Kyx79N/PF61H5udOV3aY1IaMLs6pGbH71nlCTA==", + "optional": true, + "requires": { + "minipass": "^2.6.0" + } + }, + "minipass": { + "version": "2.9.0", + "resolved": "https://registry.npmjs.org/minipass/-/minipass-2.9.0.tgz", + "integrity": "sha512-wxfUjg9WebH+CUDX/CdbRlh5SmfZiy/hpkxaRI16Y9W56Pa75sWgd/rvFilSgrauD9NyFymP/+JFV3KwzIsJeg==", + "optional": true, + "requires": { + "safe-buffer": "^5.1.2", + "yallist": "^3.0.0" + } + }, + "yallist": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-3.1.1.tgz", + "integrity": "sha512-a4UGQaWPH59mOXUYnAG2ewncQS4i4F43Tv3JoAM+s2VDAmS9NsK8GpDMLrCHPksFT7h3K6TOoUNn2pb7RoXx4g==", + "optional": true + } + } + }, + "terser": { + "version": "4.6.3", + "resolved": "https://registry.npmjs.org/terser/-/terser-4.6.3.tgz", + "integrity": "sha512-Lw+ieAXmY69d09IIc/yqeBqXpEQIpDGZqT34ui1QWXIUpR2RjbqEkT8X7Lgex19hslSqcWM5iMN2kM11eMsESQ==", + "requires": { + "commander": "^2.20.0", + "source-map": "~0.6.1", + "source-map-support": "~0.5.12" + } + }, + "terser-webpack-plugin": { + "version": "2.3.4", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-2.3.4.tgz", + "integrity": "sha512-Nv96Nws2R2nrFOpbzF6IxRDpIkkIfmhvOws+IqMvYdFLO7o6wAILWFKONFgaYy8+T4LVz77DQW0f7wOeDEAjrg==", + "requires": { + "cacache": "^13.0.1", + "find-cache-dir": "^3.2.0", + "jest-worker": "^25.1.0", + "p-limit": "^2.2.2", + "schema-utils": "^2.6.4", + "serialize-javascript": "^2.1.2", + "source-map": "^0.6.1", + "terser": "^4.4.3", + "webpack-sources": "^1.4.3" + }, + "dependencies": { + "find-cache-dir": { + "version": "3.3.0", + "resolved": "https://registry.npmjs.org/find-cache-dir/-/find-cache-dir-3.3.0.tgz", + "integrity": "sha512-PtXtQb7IrD8O+h6Cq1dbpJH5NzD8+9keN1zZ0YlpDzl1PwXEJEBj6u1Xa92t1Hwluoozd9TNKul5Hi2iqpsWwg==", + "requires": { + "commondir": "^1.0.1", + "make-dir": "^3.0.2", + "pkg-dir": "^4.1.0" + } + }, + "find-up": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/find-up/-/find-up-4.1.0.tgz", + "integrity": "sha512-PpOwAdQ/YlXQ2vj8a3h8IipDuYRi3wceVQQGYWxNINccq40Anw7BlsEXCMbt1Zt+OLA6Fq9suIpIWD0OsnISlw==", + "requires": { + "locate-path": "^5.0.0", + "path-exists": "^4.0.0" + } + }, + "has-flag": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz", + "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==" + }, + "jest-worker": { + "version": "25.1.0", + "resolved": "https://registry.npmjs.org/jest-worker/-/jest-worker-25.1.0.tgz", + "integrity": "sha512-ZHhHtlxOWSxCoNOKHGbiLzXnl42ga9CxDr27H36Qn+15pQZd3R/F24jrmjDelw9j/iHUIWMWs08/u2QN50HHOg==", + "requires": { + "merge-stream": "^2.0.0", + "supports-color": "^7.0.0" + } + }, + "locate-path": { + "version": "5.0.0", + "resolved": "https://registry.npmjs.org/locate-path/-/locate-path-5.0.0.tgz", + "integrity": "sha512-t7hw9pI+WvuwNJXwk5zVHpyhIqzg2qTlklJOf0mVxGSbe3Fp2VieZcduNYjaLDoy6p9uGpQEGWG87WpMKlNq8g==", + "requires": { + "p-locate": "^4.1.0" + } + }, + "make-dir": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/make-dir/-/make-dir-3.0.2.tgz", + "integrity": "sha512-rYKABKutXa6vXTXhoV18cBE7PaewPXHe/Bdq4v+ZLMhxbWApkFFplT0LcbMW+6BbjnQXzZ/sAvSE/JdguApG5w==", + "requires": { + "semver": "^6.0.0" + } + }, + "p-locate": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/p-locate/-/p-locate-4.1.0.tgz", + "integrity": "sha512-R79ZZ/0wAxKGu3oYMlz8jy/kbhsNrS7SKZ7PxEHBgJ5+F2mtFW2fK2cOtBh1cHYkQsbzFV7I+EoRKe6Yt0oK7A==", + "requires": { + "p-limit": "^2.2.0" + } + }, + "path-exists": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/path-exists/-/path-exists-4.0.0.tgz", + "integrity": "sha512-ak9Qy5Q7jYb2Wwcey5Fpvg2KoAc/ZIhLSLOSBmRmygPsGwkVVt0fZa0qrtMz+m6tJTAHfZQ8FnmB4MG4LWy7/w==" + }, + "pkg-dir": { + "version": "4.2.0", + "resolved": "https://registry.npmjs.org/pkg-dir/-/pkg-dir-4.2.0.tgz", + "integrity": "sha512-HRDzbaKjC+AOWVXxAU/x54COGeIv9eb+6CkDSQoNTt4XyWoIJvuPsXizxu/Fr23EiekbtZwmh1IcIG/l/a10GQ==", + "requires": { + "find-up": "^4.0.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + }, + "supports-color": { + "version": "7.1.0", + "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.1.0.tgz", + "integrity": "sha512-oRSIpR8pxT1Wr2FquTNnGet79b3BWljqOuoW/h4oBhxJ/HUbX5nX6JSruTkvXDCFMwDPvsaTTbvMLKZWSy0R5g==", + "requires": { + "has-flag": "^4.0.0" + } + } + } + }, + "test-exclude": { + "version": "5.2.3", + "resolved": "https://registry.npmjs.org/test-exclude/-/test-exclude-5.2.3.tgz", + "integrity": "sha512-M+oxtseCFO3EDtAaGH7iiej3CBkzXqFMbzqYAACdzKui4eZA+pq3tZEwChvOdNfa7xxy8BfbmgJSIr43cC/+2g==", + "requires": { + "glob": "^7.1.3", + "minimatch": "^3.0.4", + "read-pkg-up": "^4.0.0", + "require-main-filename": "^2.0.0" + }, + "dependencies": { + "load-json-file": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/load-json-file/-/load-json-file-4.0.0.tgz", + "integrity": "sha1-L19Fq5HjMhYjT9U62rZo607AmTs=", + "requires": { + "graceful-fs": "^4.1.2", + "parse-json": "^4.0.0", + "pify": "^3.0.0", + "strip-bom": "^3.0.0" + } + }, + "pify": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/pify/-/pify-3.0.0.tgz", + "integrity": "sha1-5aSs0sEB/fPZpNB/DbxNtJ3SgXY=" + }, + "read-pkg": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/read-pkg/-/read-pkg-3.0.0.tgz", + "integrity": "sha1-nLxoaXj+5l0WwA4rGcI3/Pbjg4k=", + "requires": { + "load-json-file": "^4.0.0", + "normalize-package-data": "^2.3.2", + "path-type": "^3.0.0" + } + }, + "read-pkg-up": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/read-pkg-up/-/read-pkg-up-4.0.0.tgz", + "integrity": "sha512-6etQSH7nJGsK0RbG/2TeDzZFa8shjQ1um+SwQQ5cwKy0dhSXdOncEhb1CPpvQG4h7FyOV6EB6YlV0yJvZQNAkA==", + "requires": { + "find-up": "^3.0.0", + "read-pkg": "^3.0.0" + } + } + } + }, + "text-table": { + "version": "0.2.0", + "resolved": "https://registry.npmjs.org/text-table/-/text-table-0.2.0.tgz", + "integrity": "sha1-f17oI66AUgfACvLfSoTsP8+lcLQ=" + }, + "throat": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/throat/-/throat-4.1.0.tgz", + "integrity": "sha1-iQN8vJLFarGJJua6TLsgDhVnKmo=" + }, + "through": { + "version": "2.3.8", + "resolved": "https://registry.npmjs.org/through/-/through-2.3.8.tgz", + "integrity": "sha1-DdTJ/6q8NXlgsbckEV1+Doai4fU=" + }, + "through2": { + "version": "2.0.5", + "resolved": "https://registry.npmjs.org/through2/-/through2-2.0.5.tgz", + "integrity": "sha512-/mrRod8xqpA+IHSLyGCQ2s8SPHiCDEeQJSep1jqLYeEUClOFG2Qsh+4FU6G9VeqpZnGW/Su8LQGc4YKni5rYSQ==", + "requires": { + "readable-stream": "~2.3.6", + "xtend": "~4.0.1" + }, + "dependencies": { + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "thunky": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/thunky/-/thunky-1.1.0.tgz", + "integrity": "sha512-eHY7nBftgThBqOyHGVN+l8gF0BucP09fMo0oO/Lb0w1OF80dJv+lDVpXG60WMQvkcxAkNybKsrEIE3ZtKGmPrA==" + }, + "timers-browserify": { + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/timers-browserify/-/timers-browserify-2.0.11.tgz", + "integrity": "sha512-60aV6sgJ5YEbzUdn9c8kYGIqOubPoUdqQCul3SBAsRCZ40s6Y5cMcrW4dt3/k/EsbLVJNl9n6Vz3fTc+k2GeKQ==", + "requires": { + "setimmediate": "^1.0.4" + } + }, + "timsort": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/timsort/-/timsort-0.3.0.tgz", + "integrity": "sha1-QFQRqOfmM5/mTbmiNN4R3DHgK9Q=" + }, + "tmp": { + "version": "0.0.33", + "resolved": "https://registry.npmjs.org/tmp/-/tmp-0.0.33.tgz", + "integrity": "sha512-jRCJlojKnZ3addtTOjdIqoRuPEKBvNXcGYqzO6zWZX8KfKEpnGY5jfggJQ3EjKuu8D4bJRr0y+cYJFmYbImXGw==", + "requires": { + "os-tmpdir": "~1.0.2" + } + }, + "tmpl": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/tmpl/-/tmpl-1.0.4.tgz", + "integrity": "sha1-I2QN17QtAEM5ERQIIOXPRA5SHdE=" + }, + "to-arraybuffer": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/to-arraybuffer/-/to-arraybuffer-1.0.1.tgz", + "integrity": "sha1-fSKbH8xjfkZsoIEYCDanqr/4P0M=" + }, + "to-fast-properties": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/to-fast-properties/-/to-fast-properties-2.0.0.tgz", + "integrity": "sha1-3F5pjL0HkmW8c+A3doGk5Og/YW4=" + }, + "to-object-path": { + "version": "0.3.0", + "resolved": "https://registry.npmjs.org/to-object-path/-/to-object-path-0.3.0.tgz", + "integrity": "sha1-KXWIt7Dn4KwI4E5nL4XB9JmeF68=", + "requires": { + "kind-of": "^3.0.2" + } + }, + "to-regex": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/to-regex/-/to-regex-3.0.2.tgz", + "integrity": "sha512-FWtleNAtZ/Ki2qtqej2CXTOayOH9bHDQF+Q48VpWyDXjbYxA4Yz8iDB31zXOBUlOHHKidDbqGVrTUvQMPmBGBw==", + "requires": { + "define-property": "^2.0.2", + "extend-shallow": "^3.0.2", + "regex-not": "^1.0.2", + "safe-regex": "^1.1.0" + } + }, + "to-regex-range": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-2.1.1.tgz", + "integrity": "sha1-fIDBe53+vlmeJzZ+DU3VWQFB2zg=", + "requires": { + "is-number": "^3.0.0", + "repeat-string": "^1.6.1" + } + }, + "toidentifier": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.0.tgz", + "integrity": "sha512-yaOH/Pk/VEhBWWTlhI+qXxDFXlejDGcQipMlyxda9nthulaxLZUNcUqFxokp0vcYnvteJln5FNQDRrxj3YcbVw==" + }, + "tough-cookie": { + "version": "2.5.0", + "resolved": "https://registry.npmjs.org/tough-cookie/-/tough-cookie-2.5.0.tgz", + "integrity": "sha512-nlLsUzgm1kfLXSXfRZMc1KLAugd4hqJHDTvc2hDIwS3mZAfMEuMbc03SujMF+GEcpaX/qboeycw6iO8JwVv2+g==", + "requires": { + "psl": "^1.1.28", + "punycode": "^2.1.1" + } + }, + "tr46": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/tr46/-/tr46-1.0.1.tgz", + "integrity": "sha1-qLE/1r/SSJUZZ0zN5VujaTtwbQk=", + "requires": { + "punycode": "^2.1.0" + } + }, + "ts-pnp": { + "version": "1.1.5", + "resolved": "https://registry.npmjs.org/ts-pnp/-/ts-pnp-1.1.5.tgz", + "integrity": "sha512-ti7OGMOUOzo66wLF3liskw6YQIaSsBgc4GOAlWRnIEj8htCxJUxskanMUoJOD6MDCRAXo36goXJZch+nOS0VMA==" + }, + "tslib": { + "version": "1.11.0", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-1.11.0.tgz", + "integrity": "sha512-BmndXUtiTn/VDDrJzQE7Mm22Ix3PxgLltW9bSNLoeCY31gnG2OPx0QqJnuc9oMIKioYrz487i6K9o4Pdn0j+Kg==" + }, + "tsutils": { + "version": "3.17.1", + "resolved": "https://registry.npmjs.org/tsutils/-/tsutils-3.17.1.tgz", + "integrity": "sha512-kzeQ5B8H3w60nFY2g8cJIuH7JDpsALXySGtwGJ0p2LSjLgay3NdIpqq5SoOBe46bKDW2iq25irHCr8wjomUS2g==", + "requires": { + "tslib": "^1.8.1" + } + }, + "tty-browserify": { + "version": "0.0.0", + "resolved": "https://registry.npmjs.org/tty-browserify/-/tty-browserify-0.0.0.tgz", + "integrity": "sha1-oVe6QC2iTpv5V/mqadUk7tQpAaY=" + }, + "tunnel-agent": { + "version": "0.6.0", + "resolved": "https://registry.npmjs.org/tunnel-agent/-/tunnel-agent-0.6.0.tgz", + "integrity": "sha1-J6XeoGs2sEoKmWZ3SykIaPD8QP0=", + "requires": { + "safe-buffer": "^5.0.1" + } + }, + "tweetnacl": { + "version": "0.14.5", + "resolved": "https://registry.npmjs.org/tweetnacl/-/tweetnacl-0.14.5.tgz", + "integrity": "sha1-WuaBd/GS1EViadEIr6k/+HQ/T2Q=" + }, + "type": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/type/-/type-1.2.0.tgz", + "integrity": "sha512-+5nt5AAniqsCnu2cEQQdpzCAh33kVx8n0VoFidKpB1dVVLAN/F+bgVOqOJqOnEnrhp222clB5p3vUlD+1QAnfg==" + }, + "type-check": { + "version": "0.3.2", + "resolved": "https://registry.npmjs.org/type-check/-/type-check-0.3.2.tgz", + "integrity": "sha1-WITKtRLPHTVeP7eE8wgEsrUg23I=", + "requires": { + "prelude-ls": "~1.1.2" + } + }, + "type-fest": { + "version": "0.8.1", + "resolved": "https://registry.npmjs.org/type-fest/-/type-fest-0.8.1.tgz", + "integrity": "sha512-4dbzIzqvjtgiM5rw1k5rEHtBANKmdudhGyBEajN01fEyhaAIhsoKNy6y7+IN93IfpFtwY9iqi7kD+xwKhQsNJA==" + }, + "type-is": { + "version": "1.6.18", + "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", + "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", + "requires": { + "media-typer": "0.3.0", + "mime-types": "~2.1.24" + } + }, + "typedarray": { + "version": "0.0.6", + "resolved": "https://registry.npmjs.org/typedarray/-/typedarray-0.0.6.tgz", + "integrity": "sha1-hnrHTjhkGHsdPUfZlqeOxciDB3c=" + }, + "unicode-canonical-property-names-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-canonical-property-names-ecmascript/-/unicode-canonical-property-names-ecmascript-1.0.4.tgz", + "integrity": "sha512-jDrNnXWHd4oHiTZnx/ZG7gtUTVp+gCcTTKr8L0HjlwphROEW3+Him+IpvC+xcJEFegapiMZyZe02CyuOnRmbnQ==" + }, + "unicode-match-property-ecmascript": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/unicode-match-property-ecmascript/-/unicode-match-property-ecmascript-1.0.4.tgz", + "integrity": "sha512-L4Qoh15vTfntsn4P1zqnHulG0LdXgjSO035fEpdtp6YxXhMT51Q6vgM5lYdG/5X3MjS+k/Y9Xw4SFCY9IkR0rg==", + "requires": { + "unicode-canonical-property-names-ecmascript": "^1.0.4", + "unicode-property-aliases-ecmascript": "^1.0.4" + } + }, + "unicode-match-property-value-ecmascript": { + "version": "1.1.0", + "resolved": "https://registry.npmjs.org/unicode-match-property-value-ecmascript/-/unicode-match-property-value-ecmascript-1.1.0.tgz", + "integrity": "sha512-hDTHvaBk3RmFzvSl0UVrUmC3PuW9wKVnpoUDYH0JDkSIovzw+J5viQmeYHxVSBptubnr7PbH2e0fnpDRQnQl5g==" + }, + "unicode-property-aliases-ecmascript": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/unicode-property-aliases-ecmascript/-/unicode-property-aliases-ecmascript-1.0.5.tgz", + "integrity": "sha512-L5RAqCfXqAwR3RriF8pM0lU0w4Ryf/GgzONwi6KnL1taJQa7x1TCxdJnILX59WIGOwR57IVxn7Nej0fz1Ny6fw==" + }, + "union-value": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/union-value/-/union-value-1.0.1.tgz", + "integrity": "sha512-tJfXmxMeWYnczCVs7XAEvIV7ieppALdyepWMkHkwciRpZraG/xwT+s2JN8+pr1+8jCRf80FFzvr+MpQeeoF4Xg==", + "requires": { + "arr-union": "^3.1.0", + "get-value": "^2.0.6", + "is-extendable": "^0.1.1", + "set-value": "^2.0.1" + } + }, + "uniq": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/uniq/-/uniq-1.0.1.tgz", + "integrity": "sha1-sxxa6CVIRKOoKBVBzisEuGWnNP8=" + }, + "uniqs": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/uniqs/-/uniqs-2.0.0.tgz", + "integrity": "sha1-/+3ks2slKQaW5uFl1KWe25mOawI=" + }, + "unique-filename": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unique-filename/-/unique-filename-1.1.1.tgz", + "integrity": "sha512-Vmp0jIp2ln35UTXuryvjzkjGdRyf9b2lTXuSYUiPmzRcl3FDtYqAwOnTJkAngD9SWhnoJzDbTKwaOrZ+STtxNQ==", + "requires": { + "unique-slug": "^2.0.0" + } + }, + "unique-slug": { + "version": "2.0.2", + "resolved": "https://registry.npmjs.org/unique-slug/-/unique-slug-2.0.2.tgz", + "integrity": "sha512-zoWr9ObaxALD3DOPfjPSqxt4fnZiWblxHIgeWqW8x7UqDzEtHEQLzji2cuJYQFCU6KmoJikOYAZlrTHHebjx2w==", + "requires": { + "imurmurhash": "^0.1.4" + } + }, + "universalify": { + "version": "0.1.2", + "resolved": "https://registry.npmjs.org/universalify/-/universalify-0.1.2.tgz", + "integrity": "sha512-rBJeI5CXAlmy1pV+617WB9J63U6XcazHHF2f2dbJix4XzpUF0RS3Zbj0FGIOCAva5P/d/GBOYaACQ1w+0azUkg==" + }, + "unpipe": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", + "integrity": "sha1-sr9O6FFKrmFltIF4KdIbLvSZBOw=" + }, + "unquote": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/unquote/-/unquote-1.1.1.tgz", + "integrity": "sha1-j97XMk7G6IoP+LkF58CYzcCG1UQ=" + }, + "unset-value": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/unset-value/-/unset-value-1.0.0.tgz", + "integrity": "sha1-g3aHP30jNRef+x5vw6jtDfyKtVk=", + "requires": { + "has-value": "^0.3.1", + "isobject": "^3.0.0" + }, + "dependencies": { + "has-value": { + "version": "0.3.1", + "resolved": "https://registry.npmjs.org/has-value/-/has-value-0.3.1.tgz", + "integrity": "sha1-ex9YutpiyoJ+wKIHgCVlSEWZXh8=", + "requires": { + "get-value": "^2.0.3", + "has-values": "^0.1.4", + "isobject": "^2.0.0" + }, + "dependencies": { + "isobject": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/isobject/-/isobject-2.1.0.tgz", + "integrity": "sha1-8GVWEJaj8dou9GJy+BXIQNh+DIk=", + "requires": { + "isarray": "1.0.0" + } + } + } + }, + "has-values": { + "version": "0.1.4", + "resolved": "https://registry.npmjs.org/has-values/-/has-values-0.1.4.tgz", + "integrity": "sha1-bWHeldkd/Km5oCCJrThL/49it3E=" + } + } + }, + "upath": { + "version": "1.2.0", + "resolved": "https://registry.npmjs.org/upath/-/upath-1.2.0.tgz", + "integrity": "sha512-aZwGpamFO61g3OlfT7OQCHqhGnW43ieH9WZeP7QxN/G/jS4jfqUkZxoryvJgVPEcrl5NL/ggHsSmLMHuH64Lhg==" + }, + "uri-js": { + "version": "4.2.2", + "resolved": "https://registry.npmjs.org/uri-js/-/uri-js-4.2.2.tgz", + "integrity": "sha512-KY9Frmirql91X2Qgjry0Wd4Y+YTdrdZheS8TFwvkbLWf/G5KNJDCh6pKL5OZctEW4+0Baa5idK2ZQuELRwPznQ==", + "requires": { + "punycode": "^2.1.0" + } + }, + "urix": { + "version": "0.1.0", + "resolved": "https://registry.npmjs.org/urix/-/urix-0.1.0.tgz", + "integrity": "sha1-2pN/emLiH+wf0Y1Js1wpNQZ6bHI=" + }, + "url": { + "version": "0.11.0", + "resolved": "https://registry.npmjs.org/url/-/url-0.11.0.tgz", + "integrity": "sha1-ODjpfPxgUh63PFJajlW/3Z4uKPE=", + "requires": { + "punycode": "1.3.2", + "querystring": "0.2.0" + }, + "dependencies": { + "punycode": { + "version": "1.3.2", + "resolved": "https://registry.npmjs.org/punycode/-/punycode-1.3.2.tgz", + "integrity": "sha1-llOgNvt8HuQjQvIyXM7v6jkmxI0=" + } + } + }, + "url-loader": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/url-loader/-/url-loader-2.3.0.tgz", + "integrity": "sha512-goSdg8VY+7nPZKUEChZSEtW5gjbS66USIGCeSJ1OVOJ7Yfuh/36YxCwMi5HVEJh6mqUYOoy3NJ0vlOMrWsSHog==", + "requires": { + "loader-utils": "^1.2.3", + "mime": "^2.4.4", + "schema-utils": "^2.5.0" + } + }, + "url-parse": { + "version": "1.4.7", + "resolved": "https://registry.npmjs.org/url-parse/-/url-parse-1.4.7.tgz", + "integrity": "sha512-d3uaVyzDB9tQoSXFvuSUNFibTd9zxd2bkVrDRvF5TmvWWQwqE4lgYJ5m+x1DbecWkw+LK4RNl2CU1hHuOKPVlg==", + "requires": { + "querystringify": "^2.1.1", + "requires-port": "^1.0.0" + } + }, + "use": { + "version": "3.1.1", + "resolved": "https://registry.npmjs.org/use/-/use-3.1.1.tgz", + "integrity": "sha512-cwESVXlO3url9YWlFW/TA9cshCEhtu7IKJ/p5soJ/gGpj7vbvFrAY/eIioQ6Dw23KjZhYgiIo8HOs1nQ2vr/oQ==" + }, + "util": { + "version": "0.10.3", + "resolved": "https://registry.npmjs.org/util/-/util-0.10.3.tgz", + "integrity": "sha1-evsa/lCAUkZInj23/g7TeTNqwPk=", + "requires": { + "inherits": "2.0.1" + }, + "dependencies": { + "inherits": { + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.1.tgz", + "integrity": "sha1-sX0I0ya0Qj5Wjv9xn5GwscvfafE=" + } + } + }, + "util-deprecate": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/util-deprecate/-/util-deprecate-1.0.2.tgz", + "integrity": "sha1-RQ1Nyfpw3nMnYvvS1KKJgUGaDM8=" + }, + "util.promisify": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/util.promisify/-/util.promisify-1.0.1.tgz", + "integrity": "sha512-g9JpC/3He3bm38zsLupWryXHoEcS22YHthuPQSJdMy6KNrzIRzWqcsHzD/WUnqe45whVou4VIsPew37DoXWNrA==", + "requires": { + "define-properties": "^1.1.3", + "es-abstract": "^1.17.2", + "has-symbols": "^1.0.1", + "object.getownpropertydescriptors": "^2.1.0" + } + }, + "utila": { + "version": "0.4.0", + "resolved": "https://registry.npmjs.org/utila/-/utila-0.4.0.tgz", + "integrity": "sha1-ihagXURWV6Oupe7MWxKk+lN5dyw=" + }, + "utils-merge": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", + "integrity": "sha1-n5VxD1CiZ5R7LMwSR0HBAoQn5xM=" + }, + "uuid": { + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/uuid/-/uuid-3.4.0.tgz", + "integrity": "sha512-HjSDRw6gZE5JMggctHBcjVak08+KEVhSIiDzFnT9S9aegmp85S/bReBVTb4QTFaRNptJ9kuYaNhnbNEOkbKb/A==" + }, + "v8-compile-cache": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/v8-compile-cache/-/v8-compile-cache-2.1.0.tgz", + "integrity": "sha512-usZBT3PW+LOjM25wbqIlZwPeJV+3OSz3M1k1Ws8snlW39dZyYL9lOGC5FgPVHfk0jKmjiDV8Z0mIbVQPiwFs7g==" + }, + "validate-npm-package-license": { + "version": "3.0.4", + "resolved": "https://registry.npmjs.org/validate-npm-package-license/-/validate-npm-package-license-3.0.4.tgz", + "integrity": "sha512-DpKm2Ui/xN7/HQKCtpZxoRWBhZ9Z0kqtygG8XCgNQ8ZlDnxuQmWhj566j8fN4Cu3/JmbhsDo7fcAJq4s9h27Ew==", + "requires": { + "spdx-correct": "^3.0.0", + "spdx-expression-parse": "^3.0.0" + } + }, + "vary": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", + "integrity": "sha1-IpnwLG3tMNSllhsLn3RSShj2NPw=" + }, + "vendors": { + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/vendors/-/vendors-1.0.4.tgz", + "integrity": "sha512-/juG65kTL4Cy2su4P8HjtkTxk6VmJDiOPBufWniqQ6wknac6jNiXS9vU+hO3wgusiyqWlzTbVHi0dyJqRONg3w==" + }, + "verror": { + "version": "1.10.0", + "resolved": "https://registry.npmjs.org/verror/-/verror-1.10.0.tgz", + "integrity": "sha1-OhBcoXBTr1XW4nDB+CiGguGNpAA=", + "requires": { + "assert-plus": "^1.0.0", + "core-util-is": "1.0.2", + "extsprintf": "^1.2.0" + } + }, + "vm-browserify": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/vm-browserify/-/vm-browserify-1.1.2.tgz", + "integrity": "sha512-2ham8XPWTONajOR0ohOKOHXkm3+gaBmGut3SRuu75xLd/RRaY6vqgh8NBYYk7+RW3u5AtzPQZG8F10LHkl0lAQ==" + }, + "w3c-hr-time": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/w3c-hr-time/-/w3c-hr-time-1.0.1.tgz", + "integrity": "sha1-gqwr/2PZUOqeMYmlimViX+3xkEU=", + "requires": { + "browser-process-hrtime": "^0.1.2" + } + }, + "w3c-xmlserializer": { + "version": "1.1.2", + "resolved": "https://registry.npmjs.org/w3c-xmlserializer/-/w3c-xmlserializer-1.1.2.tgz", + "integrity": "sha512-p10l/ayESzrBMYWRID6xbuCKh2Fp77+sA0doRuGn4tTIMrrZVeqfpKjXHY+oDh3K4nLdPgNwMTVP6Vp4pvqbNg==", + "requires": { + "domexception": "^1.0.1", + "webidl-conversions": "^4.0.2", + "xml-name-validator": "^3.0.0" + } + }, + "wait-for-expect": { + "version": "3.0.2", + "resolved": "https://registry.npmjs.org/wait-for-expect/-/wait-for-expect-3.0.2.tgz", + "integrity": "sha512-cfS1+DZxuav1aBYbaO/kE06EOS8yRw7qOFoD3XtjTkYvCvh3zUvNST8DXK/nPaeqIzIv3P3kL3lRJn8iwOiSag==" + }, + "walker": { + "version": "1.0.7", + "resolved": "https://registry.npmjs.org/walker/-/walker-1.0.7.tgz", + "integrity": "sha1-L3+bj9ENZ3JisYqITijRlhjgKPs=", + "requires": { + "makeerror": "1.0.x" + } + }, + "watchpack": { + "version": "1.6.0", + "resolved": "https://registry.npmjs.org/watchpack/-/watchpack-1.6.0.tgz", + "integrity": "sha512-i6dHe3EyLjMmDlU1/bGQpEw25XSjkJULPuAVKCbNRefQVq48yXKUpwg538F7AZTf9kyr57zj++pQFltUa5H7yA==", + "requires": { + "chokidar": "^2.0.2", + "graceful-fs": "^4.1.2", + "neo-async": "^2.5.0" + }, + "dependencies": { + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==" + }, + "chokidar": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", + "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + } + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + } + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + } + } + }, + "wbuf": { + "version": "1.7.3", + "resolved": "https://registry.npmjs.org/wbuf/-/wbuf-1.7.3.tgz", + "integrity": "sha512-O84QOnr0icsbFGLS0O3bI5FswxzRr8/gHwWkDlQFskhSPryQXvrTMxjxGP4+iWYoauLoBvfDpkrOauZ+0iZpDA==", + "requires": { + "minimalistic-assert": "^1.0.0" + } + }, + "webidl-conversions": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-4.0.2.tgz", + "integrity": "sha512-YQ+BmxuTgd6UXZW3+ICGfyqRyHXVlD5GtQr5+qjiNW7bF0cqrzX500HVXPBOvgXb5YnzDd+h0zqyv61KUD7+Sg==" + }, + "webpack": { + "version": "4.41.5", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-4.41.5.tgz", + "integrity": "sha512-wp0Co4vpyumnp3KlkmpM5LWuzvZYayDwM2n17EHFr4qxBBbRokC7DJawPJC7TfSFZ9HZ6GsdH40EBj4UV0nmpw==", + "requires": { + "@webassemblyjs/ast": "1.8.5", + "@webassemblyjs/helper-module-context": "1.8.5", + "@webassemblyjs/wasm-edit": "1.8.5", + "@webassemblyjs/wasm-parser": "1.8.5", + "acorn": "^6.2.1", + "ajv": "^6.10.2", + "ajv-keywords": "^3.4.1", + "chrome-trace-event": "^1.0.2", + "enhanced-resolve": "^4.1.0", + "eslint-scope": "^4.0.3", + "json-parse-better-errors": "^1.0.2", + "loader-runner": "^2.4.0", + "loader-utils": "^1.2.3", + "memory-fs": "^0.4.1", + "micromatch": "^3.1.10", + "mkdirp": "^0.5.1", + "neo-async": "^2.6.1", + "node-libs-browser": "^2.2.1", + "schema-utils": "^1.0.0", + "tapable": "^1.1.3", + "terser-webpack-plugin": "^1.4.3", + "watchpack": "^1.6.0", + "webpack-sources": "^1.4.1" + }, + "dependencies": { + "acorn": { + "version": "6.4.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-6.4.0.tgz", + "integrity": "sha512-gac8OEcQ2Li1dxIEWGZzsp2BitJxwkwcOm0zHAJLcPJaVvm58FRnk6RkuLRpU1EujipU2ZFODv2P9DLMfnV8mw==" + }, + "cacache": { + "version": "12.0.3", + "resolved": "https://registry.npmjs.org/cacache/-/cacache-12.0.3.tgz", + "integrity": "sha512-kqdmfXEGFepesTuROHMs3MpFLWrPkSSpRqOw80RCflZXy/khxaArvFrQ7uJxSUduzAufc6G0g1VUCOZXxWavPw==", + "requires": { + "bluebird": "^3.5.5", + "chownr": "^1.1.1", + "figgy-pudding": "^3.5.1", + "glob": "^7.1.4", + "graceful-fs": "^4.1.15", + "infer-owner": "^1.0.3", + "lru-cache": "^5.1.1", + "mississippi": "^3.0.0", + "mkdirp": "^0.5.1", + "move-concurrently": "^1.0.1", + "promise-inflight": "^1.0.1", + "rimraf": "^2.6.3", + "ssri": "^6.0.1", + "unique-filename": "^1.1.1", + "y18n": "^4.0.0" + } + }, + "eslint-scope": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/eslint-scope/-/eslint-scope-4.0.3.tgz", + "integrity": "sha512-p7VutNr1O/QrxysMo3E45FjYDTeXBy0iTltPFNSqKAIfjDSXC+4dj+qfyuD8bfAXrW/y6lW3O76VaYNPKfpKrg==", + "requires": { + "esrecurse": "^4.1.0", + "estraverse": "^4.1.1" + } + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "ssri": { + "version": "6.0.1", + "resolved": "https://registry.npmjs.org/ssri/-/ssri-6.0.1.tgz", + "integrity": "sha512-3Wge10hNcT1Kur4PDFwEieXSCMCJs/7WvSACcrMYrNp+b8kDL1/0wJch5Ni2WrtwEa2IO8OsVfeKIciKCDx/QA==", + "requires": { + "figgy-pudding": "^3.5.1" + } + }, + "terser-webpack-plugin": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/terser-webpack-plugin/-/terser-webpack-plugin-1.4.3.tgz", + "integrity": "sha512-QMxecFz/gHQwteWwSo5nTc6UaICqN1bMedC5sMtUc7y3Ha3Q8y6ZO0iCR8pq4RJC8Hjf0FEPEHZqcMB/+DFCrA==", + "requires": { + "cacache": "^12.0.2", + "find-cache-dir": "^2.1.0", + "is-wsl": "^1.1.0", + "schema-utils": "^1.0.0", + "serialize-javascript": "^2.1.2", + "source-map": "^0.6.1", + "terser": "^4.1.2", + "webpack-sources": "^1.4.0", + "worker-farm": "^1.7.0" + } + } + } + }, + "webpack-dev-middleware": { + "version": "3.7.2", + "resolved": "https://registry.npmjs.org/webpack-dev-middleware/-/webpack-dev-middleware-3.7.2.tgz", + "integrity": "sha512-1xC42LxbYoqLNAhV6YzTYacicgMZQTqRd27Sim9wn5hJrX3I5nxYy1SxSd4+gjUFsz1dQFj+yEe6zEVmSkeJjw==", + "requires": { + "memory-fs": "^0.4.1", + "mime": "^2.4.4", + "mkdirp": "^0.5.1", + "range-parser": "^1.2.1", + "webpack-log": "^2.0.0" + } + }, + "webpack-dev-server": { + "version": "3.10.2", + "resolved": "https://registry.npmjs.org/webpack-dev-server/-/webpack-dev-server-3.10.2.tgz", + "integrity": "sha512-pxZKPYb+n77UN8u9YxXT4IaIrGcNtijh/mi8TXbErHmczw0DtPnMTTjHj+eNjkqLOaAZM/qD7V59j/qJsEiaZA==", + "requires": { + "ansi-html": "0.0.7", + "bonjour": "^3.5.0", + "chokidar": "^2.1.8", + "compression": "^1.7.4", + "connect-history-api-fallback": "^1.6.0", + "debug": "^4.1.1", + "del": "^4.1.1", + "express": "^4.17.1", + "html-entities": "^1.2.1", + "http-proxy-middleware": "0.19.1", + "import-local": "^2.0.0", + "internal-ip": "^4.3.0", + "ip": "^1.1.5", + "is-absolute-url": "^3.0.3", + "killable": "^1.0.1", + "loglevel": "^1.6.6", + "opn": "^5.5.0", + "p-retry": "^3.0.1", + "portfinder": "^1.0.25", + "schema-utils": "^1.0.0", + "selfsigned": "^1.10.7", + "semver": "^6.3.0", + "serve-index": "^1.9.1", + "sockjs": "0.3.19", + "sockjs-client": "1.4.0", + "spdy": "^4.0.1", + "strip-ansi": "^3.0.1", + "supports-color": "^6.1.0", + "url": "^0.11.0", + "webpack-dev-middleware": "^3.7.2", + "webpack-log": "^2.0.0", + "ws": "^6.2.1", + "yargs": "12.0.5" + }, + "dependencies": { + "ansi-regex": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-2.1.1.tgz", + "integrity": "sha1-w7M6te42DYbg5ijwRorn7yfWVN8=" + }, + "binary-extensions": { + "version": "1.13.1", + "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-1.13.1.tgz", + "integrity": "sha512-Un7MIEDdUC5gNpcGDV97op1Ywk748MpHcFTHoYs6qnj1Z3j7I53VG3nwZhKzoBZmbdRNnb6WRdFlwl7tSDuZGw==" + }, + "chokidar": { + "version": "2.1.8", + "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-2.1.8.tgz", + "integrity": "sha512-ZmZUazfOzf0Nve7duiCKD23PFSCs4JPoYyccjUFF3aQkQadqBhfzhjkwBH2mNOG9cTBwhamM37EIsIkZw3nRgg==", + "requires": { + "anymatch": "^2.0.0", + "async-each": "^1.0.1", + "braces": "^2.3.2", + "fsevents": "^1.2.7", + "glob-parent": "^3.1.0", + "inherits": "^2.0.3", + "is-binary-path": "^1.0.0", + "is-glob": "^4.0.0", + "normalize-path": "^3.0.0", + "path-is-absolute": "^1.0.0", + "readdirp": "^2.2.1", + "upath": "^1.1.1" + } + }, + "cliui": { + "version": "4.1.0", + "resolved": "https://registry.npmjs.org/cliui/-/cliui-4.1.0.tgz", + "integrity": "sha512-4FG+RSG9DL7uEwRUZXZn3SS34DiDPfzP0VOiEwtUWlE+AR2EIg+hSyvrIgUUfhdgR/UkAeW2QHgeP+hWrXs7jQ==", + "requires": { + "string-width": "^2.1.1", + "strip-ansi": "^4.0.0", + "wrap-ansi": "^2.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "debug": { + "version": "4.1.1", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.1.1.tgz", + "integrity": "sha512-pYAIzeRo8J6KPEaJ0VWOh5Pzkbw/RetuzehGM7QRRX5he4fPHx2rdKMB256ehJCkX+XRQm16eZLqLNS8RSZXZw==", + "requires": { + "ms": "^2.1.1" + } + }, + "get-caller-file": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/get-caller-file/-/get-caller-file-1.0.3.tgz", + "integrity": "sha512-3t6rVToeoZfYSGd8YoLFR2DJkiQrIiUrGcjvFX2mDw3bn6k2OtwHN0TNCLbBO+w8qTvimhDkv+LSscbJY1vE6w==" + }, + "glob-parent": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-3.1.0.tgz", + "integrity": "sha1-nmr2KZ2NO9K9QEMIMr0RPfkGxa4=", + "requires": { + "is-glob": "^3.1.0", + "path-dirname": "^1.0.0" + }, + "dependencies": { + "is-glob": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-3.1.0.tgz", + "integrity": "sha1-e6WuJCF4BKxwcHuWkiVnSGzD6Eo=", + "requires": { + "is-extglob": "^2.1.0" + } + } + } + }, + "is-absolute-url": { + "version": "3.0.3", + "resolved": "https://registry.npmjs.org/is-absolute-url/-/is-absolute-url-3.0.3.tgz", + "integrity": "sha512-opmNIX7uFnS96NtPmhWQgQx6/NYFgsUXYMllcfzwWKUMwfo8kku1TvE6hkNcH+Q1ts5cMVrsY7j0bxXQDciu9Q==" + }, + "is-binary-path": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-1.0.1.tgz", + "integrity": "sha1-dfFmQrSA8YenEcgUFh/TpKdlWJg=", + "requires": { + "binary-extensions": "^1.0.0" + } + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "readable-stream": { + "version": "2.3.7", + "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-2.3.7.tgz", + "integrity": "sha512-Ebho8K4jIbHAxnuxi7o42OrZgF/ZTNcsZj6nRKyUmkhLFq8CHItp/fy6hQZuZmP/n3yZ9VBUbp4zz/mX8hmYPw==", + "requires": { + "core-util-is": "~1.0.0", + "inherits": "~2.0.3", + "isarray": "~1.0.0", + "process-nextick-args": "~2.0.0", + "safe-buffer": "~5.1.1", + "string_decoder": "~1.1.1", + "util-deprecate": "~1.0.1" + } + }, + "readdirp": { + "version": "2.2.1", + "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-2.2.1.tgz", + "integrity": "sha512-1JU/8q+VgFZyxwrJ+SVIOsh+KywWGpds3NTqikiKpDMZWScmAYyKIgqkO+ARvNWJfXeXR1zxz7aHF4u4CyH6vQ==", + "requires": { + "graceful-fs": "^4.1.11", + "micromatch": "^3.1.10", + "readable-stream": "^2.0.2" + } + }, + "require-main-filename": { + "version": "1.0.1", + "resolved": "https://registry.npmjs.org/require-main-filename/-/require-main-filename-1.0.1.tgz", + "integrity": "sha1-l/cXtp1IeE9fUmpsWqj/3aBVpNE=" + }, + "safe-buffer": { + "version": "5.1.2", + "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.1.2.tgz", + "integrity": "sha512-Gd2UZBJDkXlY7GbJxfsE8/nvKkUEU1G38c1siN6QP6a9PT9MmHB8GnpscSmMJSoF8LOIrt8ud/wPtojys4G6+g==" + }, + "schema-utils": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/schema-utils/-/schema-utils-1.0.0.tgz", + "integrity": "sha512-i27Mic4KovM/lnGsy8whRCHhc7VicJajAjTrYg11K9zfZXnYIt4k5F+kZkwjnrhKzLic/HLU4j11mjsz2G/75g==", + "requires": { + "ajv": "^6.1.0", + "ajv-errors": "^1.0.0", + "ajv-keywords": "^3.1.0" + } + }, + "semver": { + "version": "6.3.0", + "resolved": "https://registry.npmjs.org/semver/-/semver-6.3.0.tgz", + "integrity": "sha512-b39TBaTSfV6yBrapU89p5fKekE2m/NwnDocOVruQFS1/veMgdzuPcnOM34M6CwxW8jH/lxEa5rBoDeUwu5HHTw==" + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=" + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "string_decoder": { + "version": "1.1.1", + "resolved": "https://registry.npmjs.org/string_decoder/-/string_decoder-1.1.1.tgz", + "integrity": "sha512-n/ShnvDi6FHbbVfviro+WojiFzv+s8MPMHBczVePfUpDJLwoLT0ht1l4YwBCbi8pJAveEEdnkHyPyTP/mzRfwg==", + "requires": { + "safe-buffer": "~5.1.0" + } + }, + "strip-ansi": { + "version": "3.0.1", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-3.0.1.tgz", + "integrity": "sha1-ajhfuIU9lS1f8F0Oiq+UJ43GPc8=", + "requires": { + "ansi-regex": "^2.0.0" + } + }, + "wrap-ansi": { + "version": "2.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-2.1.0.tgz", + "integrity": "sha1-2Pw9KE3QV5T+hJc8rs3Rz4JP3YU=", + "requires": { + "string-width": "^1.0.1", + "strip-ansi": "^3.0.1" + }, + "dependencies": { + "is-fullwidth-code-point": { + "version": "1.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-1.0.0.tgz", + "integrity": "sha1-754xOG8DGn8NZDr4L95QxFfvAMs=", + "requires": { + "number-is-nan": "^1.0.0" + } + }, + "string-width": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-1.0.2.tgz", + "integrity": "sha1-EYvfW4zcUaKn5w0hHgfisLmxB9M=", + "requires": { + "code-point-at": "^1.0.0", + "is-fullwidth-code-point": "^1.0.0", + "strip-ansi": "^3.0.0" + } + } + } + }, + "ws": { + "version": "6.2.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-6.2.1.tgz", + "integrity": "sha512-GIyAXC2cB7LjvpgMt9EKS2ldqr0MTrORaleiOno6TweZ6r3TKtoFQWay/2PceJ3RuBasOHzXNn5Lrw1X0bEjqA==", + "requires": { + "async-limiter": "~1.0.0" + } + }, + "yargs": { + "version": "12.0.5", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-12.0.5.tgz", + "integrity": "sha512-Lhz8TLaYnxq/2ObqHDql8dX8CJi97oHxrjUcYtzKbbykPtVW9WB+poxI+NM2UIzsMgNCZTIf0AQwsjK5yMAqZw==", + "requires": { + "cliui": "^4.0.0", + "decamelize": "^1.2.0", + "find-up": "^3.0.0", + "get-caller-file": "^1.0.1", + "os-locale": "^3.0.0", + "require-directory": "^2.1.1", + "require-main-filename": "^1.0.1", + "set-blocking": "^2.0.0", + "string-width": "^2.0.0", + "which-module": "^2.0.0", + "y18n": "^3.2.1 || ^4.0.0", + "yargs-parser": "^11.1.1" + } + }, + "yargs-parser": { + "version": "11.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-11.1.1.tgz", + "integrity": "sha512-C6kB/WJDiaxONLJQnF8ccx9SEeoTTLek8RVbaOIsrAUS8VrBEXfmeSnCZxygc+XC2sNMBIwOOnfcxiynjHsVSQ==", + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + } + } + }, + "webpack-log": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/webpack-log/-/webpack-log-2.0.0.tgz", + "integrity": "sha512-cX8G2vR/85UYG59FgkoMamwHUIkSSlV3bBMRsbxVXVUk2j6NleCKjQ/WE9eYg9WY4w25O9w8wKP4rzNZFmUcUg==", + "requires": { + "ansi-colors": "^3.0.0", + "uuid": "^3.3.2" + } + }, + "webpack-manifest-plugin": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/webpack-manifest-plugin/-/webpack-manifest-plugin-2.2.0.tgz", + "integrity": "sha512-9S6YyKKKh/Oz/eryM1RyLVDVmy3NSPV0JXMRhZ18fJsq+AwGxUY34X54VNwkzYcEmEkDwNxuEOboCZEebJXBAQ==", + "requires": { + "fs-extra": "^7.0.0", + "lodash": ">=3.5 <5", + "object.entries": "^1.1.0", + "tapable": "^1.0.0" + }, + "dependencies": { + "fs-extra": { + "version": "7.0.1", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz", + "integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==", + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + } + } + }, + "webpack-sources": { + "version": "1.4.3", + "resolved": "https://registry.npmjs.org/webpack-sources/-/webpack-sources-1.4.3.tgz", + "integrity": "sha512-lgTS3Xhv1lCOKo7SA5TjKXMjpSM4sBjNV5+q2bqesbSPs5FjGmU6jjtBSkX9b4qW87vDIsCIlUPOEhbZrMdjeQ==", + "requires": { + "source-list-map": "^2.0.0", + "source-map": "~0.6.1" + } + }, + "websocket-driver": { + "version": "0.7.3", + "resolved": "https://registry.npmjs.org/websocket-driver/-/websocket-driver-0.7.3.tgz", + "integrity": "sha512-bpxWlvbbB459Mlipc5GBzzZwhoZgGEZLuqPaR0INBGnPAY1vdBX6hPnoFXiw+3yWxDuHyQjO2oXTMyS8A5haFg==", + "requires": { + "http-parser-js": ">=0.4.0 <0.4.11", + "safe-buffer": ">=5.1.0", + "websocket-extensions": ">=0.1.1" + } + }, + "websocket-extensions": { + "version": "0.1.3", + "resolved": "https://registry.npmjs.org/websocket-extensions/-/websocket-extensions-0.1.3.tgz", + "integrity": "sha512-nqHUnMXmBzT0w570r2JpJxfiSD1IzoI+HGVdd3aZ0yNi3ngvQ4jv1dtHt5VGxfI2yj5yqImPhOK4vmIh2xMbGg==" + }, + "whatwg-encoding": { + "version": "1.0.5", + "resolved": "https://registry.npmjs.org/whatwg-encoding/-/whatwg-encoding-1.0.5.tgz", + "integrity": "sha512-b5lim54JOPN9HtzvK9HFXvBma/rnfFeqsic0hSpjtDbVxR3dJKLc+KB4V6GgiGOvl7CY/KNh8rxSo9DKQrnUEw==", + "requires": { + "iconv-lite": "0.4.24" + } + }, + "whatwg-fetch": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/whatwg-fetch/-/whatwg-fetch-3.0.0.tgz", + "integrity": "sha512-9GSJUgz1D4MfyKU7KRqwOjXCXTqWdFNvEr7eUBYchQiVc744mqK/MzXPNR2WsPkmkOa4ywfg8C2n8h+13Bey1Q==" + }, + "whatwg-mimetype": { + "version": "2.3.0", + "resolved": "https://registry.npmjs.org/whatwg-mimetype/-/whatwg-mimetype-2.3.0.tgz", + "integrity": "sha512-M4yMwr6mAnQz76TbJm914+gPpB/nCwvZbJU28cUD6dR004SAxDLOOSUaB1JDRqLtaOV/vi0IC5lEAGFgrjGv/g==" + }, + "whatwg-url": { + "version": "6.5.0", + "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-6.5.0.tgz", + "integrity": "sha512-rhRZRqx/TLJQWUpQ6bmrt2UV4f0HCQ463yQuONJqC6fO2VoEb1pTYddbe59SkYq87aoM5A3bdhMZiUiVws+fzQ==", + "requires": { + "lodash.sortby": "^4.7.0", + "tr46": "^1.0.1", + "webidl-conversions": "^4.0.2" + } + }, + "which": { + "version": "1.3.1", + "resolved": "https://registry.npmjs.org/which/-/which-1.3.1.tgz", + "integrity": "sha512-HxJdYWq1MTIQbJ3nw0cqssHoTNU267KlrDuGZ1WYlxDStUtKUhOaJmh112/TZmHxxUfuJqPXSOm7tDyas0OSIQ==", + "requires": { + "isexe": "^2.0.0" + } + }, + "which-module": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/which-module/-/which-module-2.0.0.tgz", + "integrity": "sha1-2e8H3Od7mQK4o6j6SzHD4/fm6Ho=" + }, + "wide-align": { + "version": "1.1.3", + "resolved": "https://registry.npmjs.org/wide-align/-/wide-align-1.1.3.tgz", + "integrity": "sha512-QGkOQc8XL6Bt5PwnsExKBPuMKBxnGxWWW3fU55Xt4feHozMUhdUMaBCk290qpm/wG5u/RSKzwdAC4i51YigihA==", + "optional": true, + "requires": { + "string-width": "^1.0.2 || 2" + }, + "dependencies": { + "ansi-regex": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/ansi-regex/-/ansi-regex-3.0.0.tgz", + "integrity": "sha1-7QMXwyIGT3lGbAKWa922Bas32Zg=", + "optional": true + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=", + "optional": true + }, + "string-width": { + "version": "2.1.1", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-2.1.1.tgz", + "integrity": "sha512-nOqH59deCq9SRHlxq1Aw85Jnt4w6KvLKqWVik6oA9ZklXLNIOlqg4F2yrT1MVaTjAqvVwdfeZ7w7aCvJD7ugkw==", + "optional": true, + "requires": { + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^4.0.0" + } + }, + "strip-ansi": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/strip-ansi/-/strip-ansi-4.0.0.tgz", + "integrity": "sha1-qEeQIusaw2iocTibY1JixQXuNo8=", + "optional": true, + "requires": { + "ansi-regex": "^3.0.0" + } + } + } + }, + "word-wrap": { + "version": "1.2.3", + "resolved": "https://registry.npmjs.org/word-wrap/-/word-wrap-1.2.3.tgz", + "integrity": "sha512-Hz/mrNwitNRh/HUAtM/VT/5VH+ygD6DV7mYKZAtHOrbs8U7lvPS6xf7EJKMF0uW1KJCl0H701g3ZGus+muE5vQ==" + }, + "workbox-background-sync": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-background-sync/-/workbox-background-sync-4.3.1.tgz", + "integrity": "sha512-1uFkvU8JXi7L7fCHVBEEnc3asPpiAL33kO495UMcD5+arew9IbKW2rV5lpzhoWcm/qhGB89YfO4PmB/0hQwPRg==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-broadcast-update": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-broadcast-update/-/workbox-broadcast-update-4.3.1.tgz", + "integrity": "sha512-MTSfgzIljpKLTBPROo4IpKjESD86pPFlZwlvVG32Kb70hW+aob4Jxpblud8EhNb1/L5m43DUM4q7C+W6eQMMbA==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-build": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-build/-/workbox-build-4.3.1.tgz", + "integrity": "sha512-UHdwrN3FrDvicM3AqJS/J07X0KXj67R8Cg0waq1MKEOqzo89ap6zh6LmaLnRAjpB+bDIz+7OlPye9iii9KBnxw==", + "requires": { + "@babel/runtime": "^7.3.4", + "@hapi/joi": "^15.0.0", + "common-tags": "^1.8.0", + "fs-extra": "^4.0.2", + "glob": "^7.1.3", + "lodash.template": "^4.4.0", + "pretty-bytes": "^5.1.0", + "stringify-object": "^3.3.0", + "strip-comments": "^1.0.2", + "workbox-background-sync": "^4.3.1", + "workbox-broadcast-update": "^4.3.1", + "workbox-cacheable-response": "^4.3.1", + "workbox-core": "^4.3.1", + "workbox-expiration": "^4.3.1", + "workbox-google-analytics": "^4.3.1", + "workbox-navigation-preload": "^4.3.1", + "workbox-precaching": "^4.3.1", + "workbox-range-requests": "^4.3.1", + "workbox-routing": "^4.3.1", + "workbox-strategies": "^4.3.1", + "workbox-streams": "^4.3.1", + "workbox-sw": "^4.3.1", + "workbox-window": "^4.3.1" + }, + "dependencies": { + "fs-extra": { + "version": "4.0.3", + "resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-4.0.3.tgz", + "integrity": "sha512-q6rbdDd1o2mAnQreO7YADIxf/Whx4AHBiRf6d+/cVT8h44ss+lHgxf1FemcqDnQt9X3ct4McHr+JMGlYSsK7Cg==", + "requires": { + "graceful-fs": "^4.1.2", + "jsonfile": "^4.0.0", + "universalify": "^0.1.0" + } + } + } + }, + "workbox-cacheable-response": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-cacheable-response/-/workbox-cacheable-response-4.3.1.tgz", + "integrity": "sha512-Rp5qlzm6z8IOvnQNkCdO9qrDgDpoPNguovs0H8C+wswLuPgSzSp9p2afb5maUt9R1uTIwOXrVQMmPfPypv+npw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-core": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-core/-/workbox-core-4.3.1.tgz", + "integrity": "sha512-I3C9jlLmMKPxAC1t0ExCq+QoAMd0vAAHULEgRZ7kieCdUd919n53WC0AfvokHNwqRhGn+tIIj7vcb5duCjs2Kg==" + }, + "workbox-expiration": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-expiration/-/workbox-expiration-4.3.1.tgz", + "integrity": "sha512-vsJLhgQsQouv9m0rpbXubT5jw0jMQdjpkum0uT+d9tTwhXcEZks7qLfQ9dGSaufTD2eimxbUOJfWLbNQpIDMPw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-google-analytics": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-google-analytics/-/workbox-google-analytics-4.3.1.tgz", + "integrity": "sha512-xzCjAoKuOb55CBSwQrbyWBKqp35yg1vw9ohIlU2wTy06ZrYfJ8rKochb1MSGlnoBfXGWss3UPzxR5QL5guIFdg==", + "requires": { + "workbox-background-sync": "^4.3.1", + "workbox-core": "^4.3.1", + "workbox-routing": "^4.3.1", + "workbox-strategies": "^4.3.1" + } + }, + "workbox-navigation-preload": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-navigation-preload/-/workbox-navigation-preload-4.3.1.tgz", + "integrity": "sha512-K076n3oFHYp16/C+F8CwrRqD25GitA6Rkd6+qAmLmMv1QHPI2jfDwYqrytOfKfYq42bYtW8Pr21ejZX7GvALOw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-precaching": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-precaching/-/workbox-precaching-4.3.1.tgz", + "integrity": "sha512-piSg/2csPoIi/vPpp48t1q5JLYjMkmg5gsXBQkh/QYapCdVwwmKlU9mHdmy52KsDGIjVaqEUMFvEzn2LRaigqQ==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-range-requests": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-range-requests/-/workbox-range-requests-4.3.1.tgz", + "integrity": "sha512-S+HhL9+iTFypJZ/yQSl/x2Bf5pWnbXdd3j57xnb0V60FW1LVn9LRZkPtneODklzYuFZv7qK6riZ5BNyc0R0jZA==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-routing": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-routing/-/workbox-routing-4.3.1.tgz", + "integrity": "sha512-FkbtrODA4Imsi0p7TW9u9MXuQ5P4pVs1sWHK4dJMMChVROsbEltuE79fBoIk/BCztvOJ7yUpErMKa4z3uQLX+g==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-strategies": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-strategies/-/workbox-strategies-4.3.1.tgz", + "integrity": "sha512-F/+E57BmVG8dX6dCCopBlkDvvhg/zj6VDs0PigYwSN23L8hseSRwljrceU2WzTvk/+BSYICsWmRq5qHS2UYzhw==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-streams": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-streams/-/workbox-streams-4.3.1.tgz", + "integrity": "sha512-4Kisis1f/y0ihf4l3u/+ndMkJkIT4/6UOacU3A4BwZSAC9pQ9vSvJpIi/WFGQRH/uPXvuVjF5c2RfIPQFSS2uA==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "workbox-sw": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-sw/-/workbox-sw-4.3.1.tgz", + "integrity": "sha512-0jXdusCL2uC5gM3yYFT6QMBzKfBr2XTk0g5TPAV4y8IZDyVNDyj1a8uSXy3/XrvkVTmQvLN4O5k3JawGReXr9w==" + }, + "workbox-webpack-plugin": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-webpack-plugin/-/workbox-webpack-plugin-4.3.1.tgz", + "integrity": "sha512-gJ9jd8Mb8wHLbRz9ZvGN57IAmknOipD3W4XNE/Lk/4lqs5Htw4WOQgakQy/o/4CoXQlMCYldaqUg+EJ35l9MEQ==", + "requires": { + "@babel/runtime": "^7.0.0", + "json-stable-stringify": "^1.0.1", + "workbox-build": "^4.3.1" + } + }, + "workbox-window": { + "version": "4.3.1", + "resolved": "https://registry.npmjs.org/workbox-window/-/workbox-window-4.3.1.tgz", + "integrity": "sha512-C5gWKh6I58w3GeSc0wp2Ne+rqVw8qwcmZnQGpjiek8A2wpbxSJb1FdCoQVO+jDJs35bFgo/WETgl1fqgsxN0Hg==", + "requires": { + "workbox-core": "^4.3.1" + } + }, + "worker-farm": { + "version": "1.7.0", + "resolved": "https://registry.npmjs.org/worker-farm/-/worker-farm-1.7.0.tgz", + "integrity": "sha512-rvw3QTZc8lAxyVrqcSGVm5yP/IJ2UcB3U0graE3LCFoZ0Yn2x4EoVSqJKdB/T5M+FLcRPjz4TDacRf3OCfNUzw==", + "requires": { + "errno": "~0.1.7" + } + }, + "worker-rpc": { + "version": "0.1.1", + "resolved": "https://registry.npmjs.org/worker-rpc/-/worker-rpc-0.1.1.tgz", + "integrity": "sha512-P1WjMrUB3qgJNI9jfmpZ/htmBEjFh//6l/5y8SD9hg1Ef5zTTVVoRjTrTEzPrNBQvmhMxkoTsjOXN10GWU7aCg==", + "requires": { + "microevent.ts": "~0.1.1" + } + }, + "wrap-ansi": { + "version": "5.1.0", + "resolved": "https://registry.npmjs.org/wrap-ansi/-/wrap-ansi-5.1.0.tgz", + "integrity": "sha512-QC1/iN/2/RPVJ5jYK8BGttj5z83LmSKmvbvrXPNCLZSEb32KKVDJDl/MOt2N01qU2H/FkzEa9PKto1BqDjtd7Q==", + "requires": { + "ansi-styles": "^3.2.0", + "string-width": "^3.0.0", + "strip-ansi": "^5.0.0" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "wrappy": { + "version": "1.0.2", + "resolved": "https://registry.npmjs.org/wrappy/-/wrappy-1.0.2.tgz", + "integrity": "sha1-tSQ9jz7BqjXxNkYFvA0QNuMKtp8=" + }, + "write": { + "version": "1.0.3", + "resolved": "https://registry.npmjs.org/write/-/write-1.0.3.tgz", + "integrity": "sha512-/lg70HAjtkUgWPVZhZcm+T4hkL8Zbtp1nFNOn3lRrxnlv50SRBv7cR7RqR+GMsd3hUXy9hWBo4CHTbFTcOYwig==", + "requires": { + "mkdirp": "^0.5.1" + } + }, + "write-file-atomic": { + "version": "2.4.1", + "resolved": "https://registry.npmjs.org/write-file-atomic/-/write-file-atomic-2.4.1.tgz", + "integrity": "sha512-TGHFeZEZMnv+gBFRfjAcxL5bPHrsGKtnb4qsFAws7/vlh+QfwAaySIw4AXP9ZskTTh5GWu3FLuJhsWVdiJPGvg==", + "requires": { + "graceful-fs": "^4.1.11", + "imurmurhash": "^0.1.4", + "signal-exit": "^3.0.2" + } + }, + "ws": { + "version": "5.2.2", + "resolved": "https://registry.npmjs.org/ws/-/ws-5.2.2.tgz", + "integrity": "sha512-jaHFD6PFv6UgoIVda6qZllptQsMlDEJkTQcybzzXDYM1XO9Y8em691FGMPmM46WGyLU4z9KMgQN+qrux/nhlHA==", + "requires": { + "async-limiter": "~1.0.0" + } + }, + "xml-name-validator": { + "version": "3.0.0", + "resolved": "https://registry.npmjs.org/xml-name-validator/-/xml-name-validator-3.0.0.tgz", + "integrity": "sha512-A5CUptxDsvxKJEU3yO6DuWBSJz/qizqzJKOMIfUJHETbBw/sFaDxgd6fxm1ewUaM0jZ444Fc5vC5ROYurg/4Pw==" + }, + "xmlchars": { + "version": "2.2.0", + "resolved": "https://registry.npmjs.org/xmlchars/-/xmlchars-2.2.0.tgz", + "integrity": "sha512-JZnDKK8B0RCDw84FNdDAIpZK+JuJw+s7Lz8nksI7SIuU3UXJJslUthsi+uWBUYOwPFwW7W7PRLRfUKpxjtjFCw==" + }, + "xtend": { + "version": "4.0.2", + "resolved": "https://registry.npmjs.org/xtend/-/xtend-4.0.2.tgz", + "integrity": "sha512-LKYU1iAXJXUgAXn9URjiu+MWhyUXHsvfp7mcuYm9dSUKK0/CjtrUwFAxD82/mCWbtLsGjFIad0wIsod4zrTAEQ==" + }, + "y18n": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/y18n/-/y18n-4.0.0.tgz", + "integrity": "sha512-r9S/ZyXu/Xu9q1tYlpsLIsa3EeLXXk0VwlxqTcFRfg9EhMW+17kbt9G0NrgCmhGb5vT2hyhJZLfDGx+7+5Uj/w==" + }, + "yallist": { + "version": "4.0.0", + "resolved": "https://registry.npmjs.org/yallist/-/yallist-4.0.0.tgz", + "integrity": "sha512-3wdGidZyq5PB084XLES5TpOSRA3wjXAlIWMhum2kRcv/41Sn2emQ0dycQW4uZXLejwKvg6EsvbdlVL+FYEct7A==" + }, + "yaml": { + "version": "1.7.2", + "resolved": "https://registry.npmjs.org/yaml/-/yaml-1.7.2.tgz", + "integrity": "sha512-qXROVp90sb83XtAoqE8bP9RwAkTTZbugRUTm5YeFCBfNRPEp2YzTeqWiz7m5OORHzEvrA/qcGS8hp/E+MMROYw==", + "requires": { + "@babel/runtime": "^7.6.3" + } + }, + "yargs": { + "version": "13.3.0", + "resolved": "https://registry.npmjs.org/yargs/-/yargs-13.3.0.tgz", + "integrity": "sha512-2eehun/8ALW8TLoIl7MVaRUrg+yCnenu8B4kBlRxj3GJGDKU1Og7sMXPNm1BYyM1DOJmTZ4YeN/Nwxv+8XJsUA==", + "requires": { + "cliui": "^5.0.0", + "find-up": "^3.0.0", + "get-caller-file": "^2.0.1", + "require-directory": "^2.1.1", + "require-main-filename": "^2.0.0", + "set-blocking": "^2.0.0", + "string-width": "^3.0.0", + "which-module": "^2.0.0", + "y18n": "^4.0.0", + "yargs-parser": "^13.1.1" + }, + "dependencies": { + "emoji-regex": { + "version": "7.0.3", + "resolved": "https://registry.npmjs.org/emoji-regex/-/emoji-regex-7.0.3.tgz", + "integrity": "sha512-CwBLREIQ7LvYFB0WyRvwhq5N5qPhc6PMjD6bYggFlI5YyDgl+0vxq5VHbMOFqLg7hfWzmu8T5Z1QofhmTIhItA==" + }, + "is-fullwidth-code-point": { + "version": "2.0.0", + "resolved": "https://registry.npmjs.org/is-fullwidth-code-point/-/is-fullwidth-code-point-2.0.0.tgz", + "integrity": "sha1-o7MKXE8ZkYMWeqq5O+764937ZU8=" + }, + "string-width": { + "version": "3.1.0", + "resolved": "https://registry.npmjs.org/string-width/-/string-width-3.1.0.tgz", + "integrity": "sha512-vafcv6KjVZKSgz06oM/H6GDBrAtz8vdhQakGjFIvNrHA6y3HCF1CInLy+QLq8dTJPQ1b+KDUqDFctkdRW44e1w==", + "requires": { + "emoji-regex": "^7.0.1", + "is-fullwidth-code-point": "^2.0.0", + "strip-ansi": "^5.1.0" + } + } + } + }, + "yargs-parser": { + "version": "13.1.1", + "resolved": "https://registry.npmjs.org/yargs-parser/-/yargs-parser-13.1.1.tgz", + "integrity": "sha512-oVAVsHz6uFrg3XQheFII8ESO2ssAf9luWuAd6Wexsu4F3OtIW0o8IribPXYrD4WC24LWtPrJlGy87y5udK+dxQ==", + "requires": { + "camelcase": "^5.0.0", + "decamelize": "^1.2.0" + } + } + } +} diff --git a/package.json b/package.json index 4e19ca1..4099ca4 100644 --- a/package.json +++ b/package.json @@ -3,11 +3,14 @@ "version": "0.1.0", "private": true, "dependencies": { + "@fortawesome/fontawesome-free": "^5.12.1", "@testing-library/jest-dom": "^4.2.4", "@testing-library/react": "^9.3.2", "@testing-library/user-event": "^7.1.2", + "fabric": "^4.0.0-beta.7", "react": "^16.12.0", "react-dom": "^16.12.0", + "react-image-markup": "^1.0.11", "react-scripts": "3.4.0" }, "scripts": { diff --git a/src/App.css b/src/App.css index 74b5e05..6b95fb2 100644 --- a/src/App.css +++ b/src/App.css @@ -1,38 +1,38 @@ -.App { - text-align: center; -} -.App-logo { - height: 40vmin; - pointer-events: none; +.app{ + margin-top:60px; + flex-direction: column; + display: flex; } - -@media (prefers-reduced-motion: no-preference) { - .App-logo { - animation: App-logo-spin infinite 20s linear; - } +.container{ + display: flex; } - -.App-header { - background-color: #282c34; - min-height: 100vh; +.upload-image{ + max-height: 32px; + max-width: 60px; +} +.header{ + padding: 10px; + display: flex; + border-top-left-radius: 10px; + border-top-right-radius: 10px; + justify-content: flex-end; + background-color: #504d58; + margin-right: -2px; +} +#root{ display: flex; + justify-content: center; +} +.tools{ + padding: 10px; flex-direction: column; align-items: center; justify-content: center; - font-size: calc(10px + 2vmin); - color: white; -} - -.App-link { - color: #61dafb; -} - -@keyframes App-logo-spin { - from { - transform: rotate(0deg); - } - to { - transform: rotate(360deg); - } + display: flex; + background-color: #504d58; + margin-bottom: -2px; } +canvas{ + border: 1px solid #504d58; +} \ No newline at end of file diff --git a/src/App.js b/src/App.js index ce9cbd2..6fc3880 100644 --- a/src/App.js +++ b/src/App.js @@ -1,26 +1,26 @@ import React from 'react'; -import logo from './logo.svg'; import './App.css'; +import { Editor } from 'react-image-markup'; -function App() { - return ( -
-
- logo -

- Edit src/App.js and save to reload. -

- - Learn React - -
-
- ); +import '@fortawesome/fontawesome-free/css/all.css' +import VerticalToolbar from './components/VerticalToolbar/VerticalToolbar'; +import HorizontalToolbar from './components/HorizontalToolbar/HorizontalToolbar'; +class App extends React.Component { + constructor(props) { + super(props); + this.editor = React.createRef(); + } + render() { + return ( +
+ +
+ +
+ +
+
+
) + } } - export default App; diff --git a/src/components/ColorPanel/ColorPanel.jsx b/src/components/ColorPanel/ColorPanel.jsx new file mode 100644 index 0000000..4cafbc0 --- /dev/null +++ b/src/components/ColorPanel/ColorPanel.jsx @@ -0,0 +1,45 @@ +import React from 'react'; +import ColorPicker from './ColorPicker/ColorPicker'; +import style from './ColorPanel.module.css'; + + +class ColorPanel extends React.Component { + constructor(props) { + super(props) + this.state = { + currentColor: '#000', + isOpened: false + } + this.updateColor = this.updateColor.bind(this) + } + togglePanel() { + this.setState(prev => ({ + isOpened: !prev.isOpened + }), + ) + } + updateColor(color) { + this.setState({ currentColor: color }) + } + colors() { + if (this.state.isOpened && this.props.colors) { + return ( +
+ {this.props.colors.map((color, i) => )} +
+ ) + } + } + render() { + return ( +
this.togglePanel()} onMouseLeave={() => this.togglePanel()}> +
+
+ {this.colors()} +
+ ); + } + + +} +export default ColorPanel; diff --git a/src/components/ColorPanel/ColorPanel.module.css b/src/components/ColorPanel/ColorPanel.module.css new file mode 100644 index 0000000..49605ed --- /dev/null +++ b/src/components/ColorPanel/ColorPanel.module.css @@ -0,0 +1,20 @@ +.colorPanel{ + display: flex; + position: relative; +} +.currentColor{ + padding: 15px; + margin: 15px 0; + cursor: pointer; + position: relative; + z-index: 2; + border-radius: 15px; +} +.colorPicker{ + position: absolute; + border-top-right-radius: 5px; + border-bottom-right-radius: 5px; + padding: 10px 10px 10px 55px; + z-index: 1; + background-color: #504d58a3; +} \ No newline at end of file diff --git a/src/components/ColorPanel/ColorPicker/ColorPicker.jsx b/src/components/ColorPanel/ColorPicker/ColorPicker.jsx new file mode 100644 index 0000000..4b30a40 --- /dev/null +++ b/src/components/ColorPanel/ColorPicker/ColorPicker.jsx @@ -0,0 +1,13 @@ +import React from 'react'; +import style from './ColorPicker.module.css'; +const ColorPicker = (props) => { + let chooseColor = () => { + props.editor.current.changeColor(props.color) + props.updateColor(props.color); + } + return ( +
chooseColor()} className={style.picker} style={(props.color) ? { backgroundColor: props.color } : {}}>
+ ); + +} +export default ColorPicker; diff --git a/src/components/ColorPanel/ColorPicker/ColorPicker.module.css b/src/components/ColorPanel/ColorPicker/ColorPicker.module.css new file mode 100644 index 0000000..1dd91f6 --- /dev/null +++ b/src/components/ColorPanel/ColorPicker/ColorPicker.module.css @@ -0,0 +1,6 @@ +.picker{ + padding:10px; + border-radius: 2px; + margin:10px 5px; + cursor: pointer; +} \ No newline at end of file diff --git a/src/components/HorizontalToolbar/HorizontalToolbar.jsx b/src/components/HorizontalToolbar/HorizontalToolbar.jsx new file mode 100644 index 0000000..a563d86 --- /dev/null +++ b/src/components/HorizontalToolbar/HorizontalToolbar.jsx @@ -0,0 +1,21 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +class HorizontalToolbar extends React.Component { + render() { + return ( +
+ this.props.editor.current.undo()} /> + this.props.editor.current.redo()} /> + this.props.editor.current.clear()} /> +
+ + this.props.editor.current.uploadImage(e)} accept="image/*" /> +
+ this.props.editor.current.saveImageAsFile()} /> +
+ ); + } + + +} +export default HorizontalToolbar; diff --git a/src/components/HorizontalToolbar/horizontalToolbar.module.css b/src/components/HorizontalToolbar/horizontalToolbar.module.css new file mode 100644 index 0000000..e69de29 diff --git a/src/components/Tools/Tool.jsx b/src/components/Tools/Tool.jsx new file mode 100644 index 0000000..a2bd5c2 --- /dev/null +++ b/src/components/Tools/Tool.jsx @@ -0,0 +1,11 @@ +import React from 'react'; +import style from './Tool.module.css'; +const Tool = (props) => { + return ( +
+ +
+ ); +} + +export default Tool; diff --git a/src/components/Tools/Tool.module.css b/src/components/Tools/Tool.module.css new file mode 100644 index 0000000..0919a8b --- /dev/null +++ b/src/components/Tools/Tool.module.css @@ -0,0 +1,14 @@ +.tool{ + padding:10px; + cursor: pointer; + text-align: center; + position: relative; + z-index: 2; +} +i{ + color:white; +} +i:hover{ + color:#000 +} + \ No newline at end of file diff --git a/src/components/VerticalToolbar/VerticalToolbar.jsx b/src/components/VerticalToolbar/VerticalToolbar.jsx new file mode 100644 index 0000000..9979198 --- /dev/null +++ b/src/components/VerticalToolbar/VerticalToolbar.jsx @@ -0,0 +1,46 @@ +import React from 'react'; +import Tool from '../Tools/Tool'; +import ColorPanel from '../ColorPanel/ColorPanel'; + +class VerticalToolbar extends React.Component { + constructor(props) { + super(props); + console.log(props) + this.state = { + colors: ['black', 'red', 'green', 'yellow', 'blue', 'pink', 'orange', 'purple', 'crimson'], + croppingImage: false, + } + } + applyCrop = () => { + this.props.editor.current.applyCropping() + this.setState({ + croppingImage: false + }); + } + cropImage() { + this.props.editor.current.set('crop') + this.setState({ + croppingImage: true + }); + } + render(){ + return ( +
+ + this.props.editor.current.set('text')} /> + this.props.editor.current.set('freeDrawing')} /> + this.props.editor.current.set('circle')} /> + this.props.editor.current.set('rect')} /> + this.props.editor.current.set('arrow')} /> + this.props.editor.current.set('selectMode')} /> + {this.state.croppingImage ? + this.applyCrop()} /> : + this.cropImage()} /> + } +
+ ); + } + + +} +export default VerticalToolbar; diff --git a/src/components/VerticalToolbar/verticalToolbar.module.css b/src/components/VerticalToolbar/verticalToolbar.module.css new file mode 100644 index 0000000..e69de29 diff --git a/src/index.js b/src/index.js index 87d1be5..739e678 100644 --- a/src/index.js +++ b/src/index.js @@ -3,7 +3,6 @@ import ReactDOM from 'react-dom'; import './index.css'; import App from './App'; import * as serviceWorker from './serviceWorker'; - ReactDOM.render(, document.getElementById('root')); // If you want your app to work offline and load faster, you can change diff --git a/src/logo.svg b/src/logo.svg deleted file mode 100644 index 6b60c10..0000000 --- a/src/logo.svg +++ /dev/null @@ -1,7 +0,0 @@ - - - - - - -