This commit is contained in:
Fergal Moran
2020-07-27 03:22:43 +01:00
commit 82d17d979d
69 changed files with 47721 additions and 0 deletions

13
dss-web/.editorconfig Normal file
View File

@@ -0,0 +1,13 @@
# Editor configuration, see http://editorconfig.org
root = true
[*]
charset = utf-8
indent_style = space
indent_size = 4
insert_final_newline = true
trim_trailing_whitespace = true
[*.md]
max_line_length = off
trim_trailing_whitespace = false

61
dss-web/.gitignore vendored Normal file
View File

@@ -0,0 +1,61 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
# Runtime data
pids
*.pid
*.seed
*.pid.lock
# Directory for instrumented libs generated by jscoverage/JSCover
lib-cov
# Coverage directory used by tools like istanbul
coverage
# nyc test coverage
.nyc_output
# Grunt intermediate storage (http://gruntjs.com/creating-plugins#storing-task-files)
.grunt
# Bower dependency directory (https://bower.io/)
bower_components
# node-waf configuration
.lock-wscript
# Compiled binary addons (http://nodejs.org/api/addons.html)
build/Release
# Dependency directories
node_modules/
jspm_packages/
# Distribution directories
dist/
# Typescript v1 declaration files
typings/
# Optional npm cache directory
.npm
# Optional eslint cache
.eslintcache
# Optional REPL history
.node_repl_history
# Output of 'npm pack'
*.tgz
# Yarn Integrity file
.yarn-integrity
# dotenv environment variables file
.env

44
dss-web/README.md Normal file
View File

@@ -0,0 +1,44 @@
This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
## Available Scripts
In the project directory, you can run:
### `yarn start`
Runs the app in the development mode.<br />
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
The page will reload if you make edits.<br />
You will also see any lint errors in the console.
### `yarn test`
Launches the test runner in the interactive watch mode.<br />
See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
### `yarn build`
Builds the app for production to the `build` folder.<br />
It correctly bundles React in production mode and optimizes the build for the best performance.
The build is minified and the filenames include the hashes.<br />
Your app is ready to be deployed!
See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
### `yarn eject`
**Note: this is a one-way operation. Once you `eject`, you cant go back!**
If you arent satisfied with the build tool and configuration choices, you can `eject` at any time. This command will remove the single build dependency from your project.
Instead, it will copy all the configuration files and the transitive dependencies (webpack, Babel, ESLint, etc) right into your project so you have full control over them. All of the commands except `eject` will still work, but they will point to the copied scripts so you can tweak them. At this point youre on your own.
You dont have to ever use `eject`. The curated feature set is suitable for small and middle deployments, and you shouldnt feel obligated to use this feature. However we understand that this tool wouldnt be useful if you couldnt customize it when you are ready for it.
## Learn More
You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
To learn React, check out the [React documentation](https://reactjs.org/).

41
dss-web/package.json Normal file
View File

@@ -0,0 +1,41 @@
{
"name": "dss-web",
"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",
"@types/jest": "^24.0.0",
"@types/node": "^12.0.0",
"@types/react": "^16.9.0",
"@types/react-dom": "^16.9.0",
"mdbreact": "^4.27.0",
"node-sass": "^4.14.1",
"react": "^16.13.1",
"react-dom": "^16.13.1",
"react-scripts": "3.4.1",
"typescript": "~3.7.2"
},
"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"
]
}
}

Binary file not shown.

After

Width:  |  Height:  |  Size: 32 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 167 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 28 KiB

File diff suppressed because it is too large Load Diff

Binary file not shown.

After

Width:  |  Height:  |  Size: 816 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.9 KiB

BIN
dss-web/public/favicon.ico Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 15 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 142 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 68 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 99 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 98 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 31 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 38 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 26 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.7 KiB

View File

@@ -0,0 +1,48 @@
<svg xmlns="http://www.w3.org/2000/svg" height="480" width="640">
<desc>
The United States of America flag, produced by Daniel McRae
</desc>
<defs>
<clipPath id="a">
<path fill-opacity=".67" d="M0 0h682.67v512H0z"/>
</clipPath>
</defs>
<g fill-rule="evenodd" clip-path="url(#a)" transform="scale(.9375)">
<g stroke-width="1pt">
<g fill="#bd3d44">
<path d="M0 0h972.81v39.385H0zM0 78.77h972.81v39.385H0zM0 157.54h972.81v39.385H0zM0 236.31h972.81v39.385H0zM0 315.08h972.81v39.385H0zM0 393.85h972.81v39.385H0zM0 472.62h972.81v39.385H0z"/>
</g>
<g fill="#fff">
<path d="M0 39.385h972.81V78.77H0zM0 118.155h972.81v39.385H0zM0 196.925h972.81v39.385H0zM0 275.695h972.81v39.385H0zM0 354.465h972.81v39.385H0zM0 433.235h972.81v39.385H0z"/>
</g>
</g>
<path fill="#192f5d" d="M0 0h389.12v275.69H0z"/>
<g fill="#fff">
<path d="M32.427 11.8l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM97.28 11.8l3.541 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735H93.74zM162.136 11.8l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.269 6.734 3.54-10.896-9.269-6.735h11.458zM226.988 11.8l3.54 10.896h11.457l-9.269 6.735 3.54 10.896-9.268-6.734-9.27 6.734 3.541-10.896-9.27-6.735h11.458zM291.843 11.8l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM356.698 11.8l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.27 6.734 3.542-10.896-9.27-6.735h11.458z"/>
<g>
<path d="M64.855 39.37l3.54 10.896h11.458L70.583 57l3.542 10.897-9.27-6.734-9.269 6.734L59.126 57l-9.269-6.734h11.458zM129.707 39.37l3.54 10.896h11.457L135.435 57l3.54 10.897-9.268-6.734-9.27 6.734L123.978 57l-9.27-6.734h11.458zM194.562 39.37l3.54 10.896h11.458L200.29 57l3.541 10.897-9.27-6.734-9.268 6.734L188.833 57l-9.269-6.734h11.457zM259.417 39.37l3.54 10.896h11.458L265.145 57l3.541 10.897-9.269-6.734-9.27 6.734L253.69 57l-9.27-6.734h11.458zM324.269 39.37l3.54 10.896h11.457L329.997 57l3.54 10.897-9.268-6.734-9.27 6.734L318.54 57l-9.27-6.734h11.458z"/>
</g>
<g>
<path d="M32.427 66.939l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM97.28 66.939l3.541 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735H93.74zM162.136 66.939l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.269 6.734 3.54-10.896-9.269-6.735h11.458zM226.988 66.939l3.54 10.896h11.457l-9.269 6.735 3.54 10.896-9.268-6.734-9.27 6.734 3.541-10.896-9.27-6.735h11.458zM291.843 66.939l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM356.698 66.939l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.27 6.734 3.542-10.896-9.27-6.735h11.458z"/>
<g>
<path d="M64.855 94.508l3.54 10.897h11.458l-9.27 6.734 3.542 10.897-9.27-6.734-9.269 6.734 3.54-10.897-9.269-6.734h11.458zM129.707 94.508l3.54 10.897h11.457l-9.269 6.734 3.54 10.897-9.268-6.734-9.27 6.734 3.541-10.897-9.27-6.734h11.458zM194.562 94.508l3.54 10.897h11.458l-9.27 6.734 3.541 10.897-9.27-6.734-9.268 6.734 3.54-10.897-9.269-6.734h11.457zM259.417 94.508l3.54 10.897h11.458l-9.27 6.734 3.541 10.897-9.269-6.734-9.27 6.734 3.542-10.897-9.27-6.734h11.458zM324.269 94.508l3.54 10.897h11.457l-9.269 6.734 3.54 10.897-9.268-6.734-9.27 6.734 3.541-10.897-9.27-6.734h11.458z"/>
</g>
</g>
<g>
<path d="M32.427 122.078l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM97.28 122.078l3.541 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735H93.74zM162.136 122.078l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.269 6.734 3.54-10.896-9.269-6.735h11.458zM226.988 122.078l3.54 10.896h11.457l-9.269 6.735 3.54 10.896-9.268-6.734-9.27 6.734 3.541-10.896-9.27-6.735h11.458zM291.843 122.078l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM356.698 122.078l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.27 6.734 3.542-10.896-9.27-6.735h11.458z"/>
<g>
<path d="M64.855 149.647l3.54 10.897h11.458l-9.27 6.734 3.542 10.897-9.27-6.734-9.269 6.734 3.54-10.897-9.269-6.734h11.458zM129.707 149.647l3.54 10.897h11.457l-9.269 6.734 3.54 10.897-9.268-6.734-9.27 6.734 3.541-10.897-9.27-6.734h11.458zM194.562 149.647l3.54 10.897h11.458l-9.27 6.734 3.541 10.897-9.27-6.734-9.268 6.734 3.54-10.897-9.269-6.734h11.457zM259.417 149.647l3.54 10.897h11.458l-9.27 6.734 3.541 10.897-9.269-6.734-9.27 6.734 3.542-10.897-9.27-6.734h11.458zM324.269 149.647l3.54 10.897h11.457l-9.269 6.734 3.54 10.897-9.268-6.734-9.27 6.734 3.541-10.897-9.27-6.734h11.458z"/>
</g>
</g>
<g>
<path d="M32.427 177.217l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM97.28 177.217l3.541 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735H93.74zM162.136 177.217l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.269 6.734 3.54-10.896-9.269-6.735h11.458zM226.988 177.217l3.54 10.896h11.457l-9.269 6.735 3.54 10.896-9.268-6.734-9.27 6.734 3.541-10.896-9.27-6.735h11.458zM291.843 177.217l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM356.698 177.217l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.27 6.734 3.542-10.896-9.27-6.735h11.458z"/>
<g>
<path d="M64.855 204.786l3.54 10.897h11.458l-9.27 6.734 3.542 10.897-9.27-6.734-9.269 6.734 3.54-10.897-9.269-6.734h11.458zM129.707 204.786l3.54 10.897h11.457l-9.269 6.734 3.54 10.897-9.268-6.734-9.27 6.734 3.541-10.897-9.27-6.734h11.458zM194.562 204.786l3.54 10.897h11.458l-9.27 6.734 3.541 10.897-9.27-6.734-9.268 6.734 3.54-10.897-9.269-6.734h11.457zM259.417 204.786l3.54 10.897h11.458l-9.27 6.734 3.541 10.897-9.269-6.734-9.27 6.734 3.542-10.897-9.27-6.734h11.458zM324.269 204.786l3.54 10.897h11.457l-9.269 6.734 3.54 10.897-9.268-6.734-9.27 6.734 3.541-10.897-9.27-6.734h11.458z"/>
</g>
</g>
<g>
<path d="M32.427 232.356l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM97.28 232.356l3.541 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735H93.74zM162.136 232.356l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.269 6.734 3.54-10.896-9.269-6.735h11.458zM226.988 232.356l3.54 10.896h11.457l-9.269 6.735 3.54 10.896-9.268-6.734-9.27 6.734 3.541-10.896-9.27-6.735h11.458zM291.843 232.356l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.27-6.734-9.268 6.734 3.54-10.896-9.269-6.735h11.457zM356.698 232.356l3.54 10.896h11.458l-9.27 6.735 3.541 10.896-9.269-6.734-9.27 6.734 3.542-10.896-9.27-6.735h11.458z"/>
</g>
</g>
</g>
</svg>

After

Width:  |  Height:  |  Size: 6.8 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 10 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 74 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 42 KiB

Binary file not shown.

After

Width:  |  Height:  |  Size: 71 KiB

61
dss-web/public/index.html Normal file
View File

@@ -0,0 +1,61 @@
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8" />
<link rel="icon"
href="%PUBLIC_URL%/favicon.ico" />
<meta name="viewport"
content="width=device-width, initial-scale=1" />
<meta name="theme-color"
content="#000000" />
<meta name="description"
content="Web site created using create-react-app" />
<link rel="apple-touch-icon"
href="%PUBLIC_URL%/logo192.png" />
<!--
manifest.json provides metadata used when your web app is installed on a
user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/
-->
<link rel="manifest"
href="%PUBLIC_URL%/manifest.json" />
<!--
Notice the use of %PUBLIC_URL% in the tags above.
It will be replaced with the URL of the `public` folder during the build.
Only files inside the `public` folder can be referenced from the HTML.
Unlike "/favicon.ico" or "favicon.ico", "%PUBLIC_URL%/favicon.ico" will
work correctly both with client-side routing and a non-root public URL.
Learn how to configure a non-root public URL by running `npm run build`.
-->
<link rel="stylesheet"
href="https://fonts.googleapis.com/icon?family=Material+Icons">
<link rel="stylesheet"
href="https://stackpath.bootstrapcdn.com/font-awesome/4.7.0/css/font-awesome.min.css">
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/simple-line-icons/2.4.1/css/simple-line-icons.min.css"
integrity="sha512-yxSQDoat2NPQ9U4mKdYra2YNenVsnRuGxVvyrirmrDKzwOdxKJVqkDEvQ17pL/PJ6B7n2n77Xm6d62bMjCBqCQ=="
crossorigin="anonymous" />
<link rel="stylesheet"
href="https://cdnjs.cloudflare.com/ajax/libs/MaterialDesign-Webfont/1.8.36/css/materialdesignicons.css" />
<link rel="stylesheet"
href="site.css">
<title>Deep South Sounds</title>
</head>
<body>
<noscript>You need to enable JavaScript to run this app.</noscript>
<div id="root"></div>
<!--
This HTML file is a template.
If you open it directly in the browser, you will see an empty page.
You can add webfonts, meta tags, or analytics to this file.
The build step will place the bundled scripts into the <body> tag.
To begin the development, run `npm start` or `yarn start`.
To create a production bundle, use `npm run build` or `yarn build`.
-->
</body>
</html>

View File

@@ -0,0 +1,3 @@
# https://www.robotstxt.org/robotstxt.html
User-agent: *
Disallow:

22447
dss-web/public/site.css Normal file

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,19 @@
{
"name": "Deep South Sounds",
"short_name": "dss-web",
"icons": [
{
"src": "/android-chrome-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "/android-chrome-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
],
"theme_color": "#ffffff",
"background_color": "#ffffff",
"display": "standalone"
}

38
dss-web/src/App.scss Normal file
View File

@@ -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);
}
}

9
dss-web/src/App.test.tsx Normal file
View File

@@ -0,0 +1,9 @@
import React from 'react';
import { render } from '@testing-library/react';
import App from './App';
test('renders learn react link', () => {
const { getByText } = render(<App />);
const linkElement = getByText(/learn react/i);
expect(linkElement).toBeInTheDocument();
});

28
dss-web/src/App.tsx Normal file
View File

@@ -0,0 +1,28 @@
import React from "react";
import "./App.scss";
import { Navbar } from "./components";
import { Sidebar } from "./components";
import { Content } from "./components";
function App() {
return (
<div className="App">
<div
id="main-wrapper"
data-theme="light"
data-layout="vertical"
data-navbarbg="skin6"
data-sidebartype="full"
data-sidebar-position="fixed"
data-header-position="fixed"
data-boxed-layout="full"
>
<Navbar />
<Sidebar />
<Content />
</div>
</div>
);
}
export default App;

View File

@@ -0,0 +1,17 @@
import React from "react";
const Content = () => {
return (
<div className="container-fluid">
<div className="row">
<div className="col-12">
<div className="card">
<div className="card-body"></div>
</div>
</div>
</div>
</div>
);
};
export default Content;

View File

@@ -0,0 +1,783 @@
import React from "react";
const Navbar = () => {
return (
<header className="topbar">
<nav className="navbar top-navbar navbar-expand-md navbar-light">
<div className="navbar-header" data-logobg="skin1">
{/* This is for the sidebar toggle which is visible on mobile only */}
<a className="nav-toggler waves-effect waves-light d-block d-md-none">
<i className="ti-menu ti-close" />
</a>
{/* ============================================================== */}
{/* Logo */}
{/* ============================================================== */}
<a className="navbar-brand" href="index.html">
{/* Logo icon */}
<b className="logo-icon">
{/*You can put here icon as well // <i className="wi wi-sunset"></i> //*/}
{/* Dark Logo icon */}
<img
src="/images/logo-icon.png"
alt="homepage"
className="dark-logo"
/>
{/* Light Logo icon */}
<img
src="/images/logo-light-icon.png"
alt="homepage"
className="light-logo"
/>
</b>
{/*End Logo icon */}
{/* Logo text */}
<span className="logo-text">
{/* dark Logo text */}
<img
src="/images/logo-text.png"
alt="homepage"
className="dark-logo"
/>
{/* Light Logo text */}
<img
src="/images/logo-light-text.png"
className="light-logo"
alt="homepage"
/>
</span>
</a>
{/* ============================================================== */}
{/* End Logo */}
{/* ============================================================== */}
{/* ============================================================== */}
{/* Toggle which is visible on mobile only */}
{/* ============================================================== */}
<a
className="topbartoggler d-block d-md-none waves-effect waves-light"
data-toggle="collapse"
data-target="#navbarSupportedContent"
aria-controls="navbarSupportedContent"
aria-expanded="false"
aria-label="Toggle navigation"
>
<i className="ti-more" />
</a>
</div>
{/* ============================================================== */}
{/* End Logo */}
{/* ============================================================== */}
<div
className="navbar-collapse collapse"
id="navbarSupportedContent"
>
{/* ============================================================== */}
{/* toggle and nav items */}
{/* ============================================================== */}
<ul className="navbar-nav mr-auto">
<li className="nav-item d-none d-md-block">
<a
className="nav-link sidebartoggler waves-effect waves-light"
data-sidebartype="mini-sidebar"
>
<i className="mdi mdi-menu font-24" />
</a>
</li>
{/* ============================================================== */}
{/* mega menu */}
{/* ============================================================== */}
<li className="nav-item dropdown mega-dropdown">
<a
className="nav-link dropdown-toggle waves-effect waves-dark"
href="#"
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded="false"
>
<span className="d-none d-md-block">
Mega <i className="fa fa-angle-down" />
</span>
<span className="d-block d-md-none">
<i className="mdi mdi-dialpad font-24" />
</span>
</a>
<div className="dropdown-menu animated bounceInDown">
<div className="mega-dropdown-menu row">
<div className="col-lg-3 col-xlg-2 mb-4">
<h4 className="mb-3">CAROUSEL</h4>
{/* CAROUSEL */}
<div
id="carouselExampleControls"
className="carousel slide"
data-ride="carousel"
>
<div
className="carousel-inner"
role="listbox"
>
<div className="carousel-item active">
<div className="container p-0">
{" "}
<img
className="d-block img-fluid"
src="/images/big/img1.jpg"
alt="First slide"
/>
</div>
</div>
<div className="carousel-item">
<div className="container p-0">
<img
className="d-block img-fluid"
src="/images/big/img2.jpg"
alt="Second slide"
/>
</div>
</div>
<div className="carousel-item">
<div className="container p-0">
<img
className="d-block img-fluid"
src="/images/big/img3.jpg"
alt="Third slide"
/>
</div>
</div>
</div>
<a
className="carousel-control-prev"
href="#carouselExampleControls"
role="button"
data-slide="prev"
>
{" "}
<span
className="carousel-control-prev-icon"
aria-hidden="true"
/>{" "}
<span className="sr-only">
Previous
</span>{" "}
</a>
<a
className="carousel-control-next"
href="#carouselExampleControls"
role="button"
data-slide="next"
>
{" "}
<span
className="carousel-control-next-icon"
aria-hidden="true"
/>{" "}
<span className="sr-only">
Next
</span>{" "}
</a>
</div>
{/* End CAROUSEL */}
</div>
<div className="col-lg-3 mb-4">
<h4 className="mb-3">ACCORDION</h4>
{/* Accordian */}
<div id="accordion">
<div className="card mb-1">
<div
className="card-header"
id="headingOne"
>
<h5 className="mb-0">
<button
className="btn btn-link"
data-toggle="collapse"
data-target="#collapseOne"
aria-expanded="true"
aria-controls="collapseOne"
>
Collapsible Group
Item #1
</button>
</h5>
</div>
<div
id="collapseOne"
className="collapse show"
aria-labelledby="headingOne"
data-parent="#accordion"
>
<div className="card-body">
Anim pariatur cliche
reprehenderit, enim
eiusmod high life
accusamus terry.
</div>
</div>
</div>
<div className="card mb-1">
<div
className="card-header"
id="headingTwo"
>
<h5 className="mb-0">
<button
className="btn btn-link collapsed"
data-toggle="collapse"
data-target="#collapseTwo"
aria-expanded="false"
aria-controls="collapseTwo"
>
Collapsible Group
Item #2
</button>
</h5>
</div>
<div
id="collapseTwo"
className="collapse"
aria-labelledby="headingTwo"
data-parent="#accordion"
>
<div className="card-body">
Anim pariatur cliche
reprehenderit, enim
eiusmod high life
accusamus terry.
</div>
</div>
</div>
<div className="card mb-1">
<div
className="card-header"
id="headingThree"
>
<h5 className="mb-0">
<button
className="btn btn-link collapsed"
data-toggle="collapse"
data-target="#collapseThree"
aria-expanded="false"
aria-controls="collapseThree"
>
Collapsible Group
Item #3
</button>
</h5>
</div>
<div
id="collapseThree"
className="collapse"
aria-labelledby="headingThree"
data-parent="#accordion"
>
<div className="card-body">
Anim pariatur cliche
reprehenderit, enim
eiusmod high life
accusamus terry.
</div>
</div>
</div>
</div>
</div>
<div className="col-lg-3 mb-4">
<h4 className="mb-3">CONTACT US</h4>
{/* Contact */}
<form>
<div className="form-group">
<input
type="text"
className="form-control"
id="exampleInputname1"
placeholder="Enter Name"
/>{" "}
</div>
<div className="form-group">
<input
type="email"
className="form-control"
placeholder="Enter email"
/>{" "}
</div>
<div className="form-group">
<textarea
className="form-control"
id="exampleTextarea"
rows={3}
placeholder="Message"
defaultValue={""}
/>
</div>
<button
type="submit"
className="btn btn-info"
>
Submit
</button>
</form>
</div>
<div className="col-lg-3 col-xlg-4 mb-4">
<h4 className="mb-3">List style</h4>
{/* List style */}
<ul className="list-style-none">
<li>
<a>
<i className="fa fa-check text-success" />{" "}
You can give link
</a>
</li>
<li>
<a>
<i className="fa fa-check text-success" />{" "}
Give link
</a>
</li>
<li>
<a>
<i className="fa fa-check text-success" />{" "}
Another Give link
</a>
</li>
<li>
<a>
<i className="fa fa-check text-success" />{" "}
Forth link
</a>
</li>
<li>
<a>
<i className="fa fa-check text-success" />{" "}
Another fifth link
</a>
</li>
</ul>
</div>
</div>
</div>
</li>
{/* ============================================================== */}
{/* End mega menu */}
{/* ============================================================== */}
{/* ============================================================== */}
{/* create new */}
{/* ============================================================== */}
<li className="nav-item dropdown">
<a
className="nav-link dropdown-toggle"
href="#"
id="navbarDropdown"
role="button"
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded="false"
>
<span className="d-none d-md-block">
Create New{" "}
<i className="fa fa-angle-down" />
</span>
<span className="d-block d-md-none">
<i className="fa fa-plus" />
</span>
</a>
<div
className="dropdown-menu"
aria-labelledby="navbarDropdown"
>
<a className="dropdown-item" href="#">
Action
</a>
<a className="dropdown-item" href="#">
Another action
</a>
<div className="dropdown-divider" />
<a className="dropdown-item" href="#">
Something else here
</a>
</div>
</li>
{/* ============================================================== */}
{/* Search */}
{/* ============================================================== */}
<li className="nav-item search-box">
{" "}
<a className="nav-link waves-effect waves-dark">
<i className="ti-search" />
</a>
<form className="app-search position-absolute">
<input
type="text"
className="form-control"
placeholder="Search & enter"
/>{" "}
<a className="srh-btn">
<i className="ti-close" />
</a>
</form>
</li>
</ul>
{/* ============================================================== */}
{/* Right side toggle and nav items */}
{/* ============================================================== */}
<ul className="navbar-nav">
{/* ============================================================== */}
{/* create new */}
{/* ============================================================== */}
<li className="nav-item dropdown">
<a
className="nav-link dropdown-toggle"
href="#"
id="navbarDropdown2"
role="button"
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded="false"
>
<i className="flag-icon flag-icon-us" />
</a>
<div
className="dropdown-menu dropdown-menu-right animated bounceInDown"
aria-labelledby="navbarDropdown2"
>
<a className="dropdown-item" href="#">
<i className="flag-icon flag-icon-us" />{" "}
English
</a>
<a className="dropdown-item" href="#">
<i className="flag-icon flag-icon-fr" />{" "}
French
</a>
<a className="dropdown-item" href="#">
<i className="flag-icon flag-icon-es" />{" "}
Spanish
</a>
<a className="dropdown-item" href="#">
<i className="flag-icon flag-icon-de" />{" "}
German
</a>
</div>
</li>
{/* ============================================================== */}
{/* Comment */}
{/* ============================================================== */}
<li className="nav-item dropdown">
<a
className="nav-link dropdown-toggle waves-effect waves-dark"
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded="false"
>
{" "}
<i className="mdi mdi-bell font-24" />
</a>
<div className="dropdown-menu dropdown-menu-right mailbox animated bounceInDown">
<span className="with-arrow">
<span className="bg-primary" />
</span>
<ul className="list-style-none">
<li>
<div className="drop-title bg-primary text-white">
<h4 className="mb-0 mt-1">4 New</h4>
<span className="font-light">
Notifications
</span>
</div>
</li>
<li>
<div className="message-center notifications">
{/* Message */}
<a className="message-item">
<span className="btn btn-danger btn-circle">
<i className="fa fa-link" />
</span>
<div className="mail-contnet">
<h5 className="message-title">
Luanch Admin
</h5>{" "}
<span className="mail-desc">
Just see the my new
admin!
</span>{" "}
<span className="time">
9:30 AM
</span>{" "}
</div>
</a>
{/* Message */}
<a className="message-item">
<span className="btn btn-success btn-circle">
<i className="ti-calendar" />
</span>
<div className="mail-contnet">
<h5 className="message-title">
Event today
</h5>{" "}
<span className="mail-desc">
Just a reminder that you
have event
</span>{" "}
<span className="time">
9:10 AM
</span>{" "}
</div>
</a>
{/* Message */}
<a className="message-item">
<span className="btn btn-info btn-circle">
<i className="ti-settings" />
</span>
<div className="mail-contnet">
<h5 className="message-title">
Settings
</h5>{" "}
<span className="mail-desc">
You can customize this
template as you want
</span>{" "}
<span className="time">
9:08 AM
</span>{" "}
</div>
</a>
{/* Message */}
<a className="message-item">
<span className="btn btn-primary btn-circle">
<i className="ti-user" />
</span>
<div className="mail-contnet">
<h5 className="message-title">
Pavan kumar
</h5>{" "}
<span className="mail-desc">
Just see the my admin!
</span>{" "}
<span className="time">
9:02 AM
</span>{" "}
</div>
</a>
</div>
</li>
<li>
<a className="nav-link text-center mb-1 text-dark">
{" "}
<strong>
Check all notifications
</strong>{" "}
<i className="fa fa-angle-right" />{" "}
</a>
</li>
</ul>
</div>
</li>
<li className="nav-item dropdown">
<a
className="nav-link dropdown-toggle waves-effect waves-dark"
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded="false"
>
<i className="font-24 mdi mdi-comment-processing" />
</a>
<div className="dropdown-menu dropdown-menu-right mailbox animated bounceInDown">
<span className="with-arrow">
<span className="bg-danger" />
</span>
<ul className="list-style-none">
<li>
<div className="drop-title text-white bg-danger">
<h4 className="mb-0 mt-1">5 New</h4>
<span className="font-light">
Messages
</span>
</div>
</li>
<li>
<div className="message-center message-body">
{/* Message */}
<a className="message-item">
<span className="user-img">
{" "}
<img
src="/images/users/1.jpg"
alt="user"
className="rounded-circle"
/>{" "}
<span className="profile-status online pull-right" />{" "}
</span>
<div className="mail-contnet">
<h5 className="message-title">
Pavan kumar
</h5>{" "}
<span className="mail-desc">
Just see the my admin!
</span>{" "}
<span className="time">
9:30 AM
</span>{" "}
</div>
</a>
{/* Message */}
<a className="message-item">
<span className="user-img">
{" "}
<img
src="/images/users/2.jpg"
alt="user"
className="rounded-circle"
/>{" "}
<span className="profile-status busy pull-right" />{" "}
</span>
<div className="mail-contnet">
<h5 className="message-title">
Sonu Nigam
</h5>{" "}
<span className="mail-desc">
I've sung a song! See
you at
</span>{" "}
<span className="time">
9:10 AM
</span>{" "}
</div>
</a>
{/* Message */}
<a className="message-item">
<span className="user-img">
{" "}
<img
src="/images/users/3.jpg"
alt="user"
className="rounded-circle"
/>{" "}
<span className="profile-status away pull-right" />{" "}
</span>
<div className="mail-contnet">
<h5 className="message-title">
Arijit Sinh
</h5>{" "}
<span className="mail-desc">
I am a singer!
</span>{" "}
<span className="time">
9:08 AM
</span>{" "}
</div>
</a>
{/* Message */}
<a className="message-item">
<span className="user-img">
{" "}
<img
src="/images/users/4.jpg"
alt="user"
className="rounded-circle"
/>{" "}
<span className="profile-status offline pull-right" />{" "}
</span>
<div className="mail-contnet">
<h5 className="message-title">
Pavan kumar
</h5>{" "}
<span className="mail-desc">
Just see the my admin!
</span>{" "}
<span className="time">
9:02 AM
</span>{" "}
</div>
</a>
</div>
</li>
<li>
<a className="nav-link text-center link text-dark">
{" "}
<b>See all e-Mails</b>{" "}
<i className="fa fa-angle-right" />{" "}
</a>
</li>
</ul>
</div>
</li>
{/* ============================================================== */}
{/* End Messages */}
{/* ============================================================== */}
{/* ============================================================== */}
{/* User profile and search */}
{/* ============================================================== */}
<li className="nav-item dropdown">
<a
className="nav-link dropdown-toggle text-muted waves-effect waves-dark pro-pic"
data-toggle="dropdown"
aria-haspopup="true"
aria-expanded="false"
>
<img
src="/images/users/1.jpg"
alt="user"
className="rounded-circle"
width={31}
/>
</a>
<div className="dropdown-menu dropdown-menu-right user-dd animated flipInY">
<span className="with-arrow">
<span className="bg-primary" />
</span>
<div className="d-flex no-block align-items-center p-15 bg-primary text-white mb-2">
<div>
<img
src="/images/users/1.jpg"
alt="user"
className="img-circle"
width={60}
/>
</div>
<div className="ml-2">
<h4 className="mb-0">Steave Jobs</h4>
<p className=" mb-0">
<a
href="/cdn-cgi/l/email-protection"
className="__cf_email__"
data-cfemail="f2849380879cb2959f939b9edc919d9f"
>
[email&nbsp;protected]
</a>
</p>
</div>
</div>
<a className="dropdown-item">
<i className="ti-user mr-1 ml-1" /> My
Profile
</a>
<a className="dropdown-item">
<i className="ti-wallet mr-1 ml-1" /> My
Balance
</a>
<a className="dropdown-item">
<i className="ti-email mr-1 ml-1" /> Inbox
</a>
<div className="dropdown-divider" />
<a className="dropdown-item">
<i className="ti-settings mr-1 ml-1" />{" "}
Account Setting
</a>
<div className="dropdown-divider" />
<a className="dropdown-item">
<i className="fa fa-power-off mr-1 ml-1" />{" "}
Logout
</a>
<div className="dropdown-divider" />
<div className="pl-4 p-10">
<a className="btn btn-sm btn-success btn-rounded">
View Profile
</a>
</div>
</div>
</li>
{/* ============================================================== */}
{/* User profile and search */}
{/* ============================================================== */}
</ul>
</div>
</nav>
</header>
);
};
export default Navbar;

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,5 @@
import Content from "./Content";
import Sidebar from "./Sidebar";
import Navbar from "./Navbar";
export { Navbar, Sidebar, Content };

13
dss-web/src/index.css Normal file
View File

@@ -0,0 +1,13 @@
body {
margin: 0;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'Roboto', 'Oxygen',
'Ubuntu', 'Cantarell', 'Fira Sans', 'Droid Sans', 'Helvetica Neue',
sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
}
code {
font-family: source-code-pro, Menlo, Monaco, Consolas, 'Courier New',
monospace;
}

17
dss-web/src/index.tsx Normal file
View File

@@ -0,0 +1,17 @@
import React from 'react';
import ReactDOM from 'react-dom';
import './index.css';
import App from './App';
import * as serviceWorker from './serviceWorker';
ReactDOM.render(
<React.StrictMode>
<App />
</React.StrictMode>,
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();

7
dss-web/src/logo.svg Normal file
View File

@@ -0,0 +1,7 @@
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 841.9 595.3">
<g fill="#61DAFB">
<path d="M666.3 296.5c0-32.5-40.7-63.3-103.1-82.4 14.4-63.6 8-114.2-20.2-130.4-6.5-3.8-14.1-5.6-22.4-5.6v22.3c4.6 0 8.3.9 11.4 2.6 13.6 7.8 19.5 37.5 14.9 75.7-1.1 9.4-2.9 19.3-5.1 29.4-19.6-4.8-41-8.5-63.5-10.9-13.5-18.5-27.5-35.3-41.6-50 32.6-30.3 63.2-46.9 84-46.9V78c-27.5 0-63.5 19.6-99.9 53.6-36.4-33.8-72.4-53.2-99.9-53.2v22.3c20.7 0 51.4 16.5 84 46.6-14 14.7-28 31.4-41.3 49.9-22.6 2.4-44 6.1-63.6 11-2.3-10-4-19.7-5.2-29-4.7-38.2 1.1-67.9 14.6-75.8 3-1.8 6.9-2.6 11.5-2.6V78.5c-8.4 0-16 1.8-22.6 5.6-28.1 16.2-34.4 66.7-19.9 130.1-62.2 19.2-102.7 49.9-102.7 82.3 0 32.5 40.7 63.3 103.1 82.4-14.4 63.6-8 114.2 20.2 130.4 6.5 3.8 14.1 5.6 22.5 5.6 27.5 0 63.5-19.6 99.9-53.6 36.4 33.8 72.4 53.2 99.9 53.2 8.4 0 16-1.8 22.6-5.6 28.1-16.2 34.4-66.7 19.9-130.1 62-19.1 102.5-49.9 102.5-82.3zm-130.2-66.7c-3.7 12.9-8.3 26.2-13.5 39.5-4.1-8-8.4-16-13.1-24-4.6-8-9.5-15.8-14.4-23.4 14.2 2.1 27.9 4.7 41 7.9zm-45.8 106.5c-7.8 13.5-15.8 26.3-24.1 38.2-14.9 1.3-30 2-45.2 2-15.1 0-30.2-.7-45-1.9-8.3-11.9-16.4-24.6-24.2-38-7.6-13.1-14.5-26.4-20.8-39.8 6.2-13.4 13.2-26.8 20.7-39.9 7.8-13.5 15.8-26.3 24.1-38.2 14.9-1.3 30-2 45.2-2 15.1 0 30.2.7 45 1.9 8.3 11.9 16.4 24.6 24.2 38 7.6 13.1 14.5 26.4 20.8 39.8-6.3 13.4-13.2 26.8-20.7 39.9zm32.3-13c5.4 13.4 10 26.8 13.8 39.8-13.1 3.2-26.9 5.9-41.2 8 4.9-7.7 9.8-15.6 14.4-23.7 4.6-8 8.9-16.1 13-24.1zM421.2 430c-9.3-9.6-18.6-20.3-27.8-32 9 .4 18.2.7 27.5.7 9.4 0 18.7-.2 27.8-.7-9 11.7-18.3 22.4-27.5 32zm-74.4-58.9c-14.2-2.1-27.9-4.7-41-7.9 3.7-12.9 8.3-26.2 13.5-39.5 4.1 8 8.4 16 13.1 24 4.7 8 9.5 15.8 14.4 23.4zM420.7 163c9.3 9.6 18.6 20.3 27.8 32-9-.4-18.2-.7-27.5-.7-9.4 0-18.7.2-27.8.7 9-11.7 18.3-22.4 27.5-32zm-74 58.9c-4.9 7.7-9.8 15.6-14.4 23.7-4.6 8-8.9 16-13 24-5.4-13.4-10-26.8-13.8-39.8 13.1-3.1 26.9-5.8 41.2-7.9zm-90.5 125.2c-35.4-15.1-58.3-34.9-58.3-50.6 0-15.7 22.9-35.6 58.3-50.6 8.6-3.7 18-7 27.7-10.1 5.7 19.6 13.2 40 22.5 60.9-9.2 20.8-16.6 41.1-22.2 60.6-9.9-3.1-19.3-6.5-28-10.2zM310 490c-13.6-7.8-19.5-37.5-14.9-75.7 1.1-9.4 2.9-19.3 5.1-29.4 19.6 4.8 41 8.5 63.5 10.9 13.5 18.5 27.5 35.3 41.6 50-32.6 30.3-63.2 46.9-84 46.9-4.5-.1-8.3-1-11.3-2.7zm237.2-76.2c4.7 38.2-1.1 67.9-14.6 75.8-3 1.8-6.9 2.6-11.5 2.6-20.7 0-51.4-16.5-84-46.6 14-14.7 28-31.4 41.3-49.9 22.6-2.4 44-6.1 63.6-11 2.3 10.1 4.1 19.8 5.2 29.1zm38.5-66.7c-8.6 3.7-18 7-27.7 10.1-5.7-19.6-13.2-40-22.5-60.9 9.2-20.8 16.6-41.1 22.2-60.6 9.9 3.1 19.3 6.5 28.1 10.2 35.4 15.1 58.3 34.9 58.3 50.6-.1 15.7-23 35.6-58.4 50.6zM320.8 78.4z"/>
<circle cx="420.9" cy="296.5" r="45.7"/>
<path d="M520.5 78.1z"/>
</g>
</svg>

After

Width:  |  Height:  |  Size: 2.6 KiB

1
dss-web/src/react-app-env.d.ts vendored Normal file
View File

@@ -0,0 +1 @@
/// <reference types="react-scripts" />

View File

@@ -0,0 +1,149 @@
// This optional code is used to register a service worker.
// register() is not called by default.
// This lets the app load faster on subsequent visits in production, and gives
// it offline capabilities. However, it also means that developers (and users)
// will only see deployed updates on subsequent visits to a page, after all the
// existing tabs open on the page have been closed, since previously cached
// resources are updated in the background.
// To learn more about the benefits of this model and instructions on how to
// opt-in, read https://bit.ly/CRA-PWA
const isLocalhost = Boolean(
window.location.hostname === 'localhost' ||
// [::1] is the IPv6 localhost address.
window.location.hostname === '[::1]' ||
// 127.0.0.0/8 are considered localhost for IPv4.
window.location.hostname.match(
/^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/
)
);
type Config = {
onSuccess?: (registration: ServiceWorkerRegistration) => void;
onUpdate?: (registration: ServiceWorkerRegistration) => void;
};
export function register(config?: Config) {
if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) {
// The URL constructor is available in all browsers that support SW.
const publicUrl = new URL(
process.env.PUBLIC_URL,
window.location.href
);
if (publicUrl.origin !== window.location.origin) {
// Our service worker won't work if PUBLIC_URL is on a different origin
// from what our page is served on. This might happen if a CDN is used to
// serve assets; see https://github.com/facebook/create-react-app/issues/2374
return;
}
window.addEventListener('load', () => {
const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`;
if (isLocalhost) {
// This is running on localhost. Let's check if a service worker still exists or not.
checkValidServiceWorker(swUrl, config);
// Add some additional logging to localhost, pointing developers to the
// service worker/PWA documentation.
navigator.serviceWorker.ready.then(() => {
console.log(
'This web app is being served cache-first by a service ' +
'worker. To learn more, visit https://bit.ly/CRA-PWA'
);
});
} else {
// Is not localhost. Just register service worker
registerValidSW(swUrl, config);
}
});
}
}
function registerValidSW(swUrl: string, config?: Config) {
navigator.serviceWorker
.register(swUrl)
.then(registration => {
registration.onupdatefound = () => {
const installingWorker = registration.installing;
if (installingWorker == null) {
return;
}
installingWorker.onstatechange = () => {
if (installingWorker.state === 'installed') {
if (navigator.serviceWorker.controller) {
// At this point, the updated precached content has been fetched,
// but the previous service worker will still serve the older
// content until all client tabs are closed.
console.log(
'New content is available and will be used when all ' +
'tabs for this page are closed. See https://bit.ly/CRA-PWA.'
);
// Execute callback
if (config && config.onUpdate) {
config.onUpdate(registration);
}
} else {
// At this point, everything has been precached.
// It's the perfect time to display a
// "Content is cached for offline use." message.
console.log('Content is cached for offline use.');
// Execute callback
if (config && config.onSuccess) {
config.onSuccess(registration);
}
}
}
};
};
})
.catch(error => {
console.error('Error during service worker registration:', error);
});
}
function checkValidServiceWorker(swUrl: string, config?: Config) {
// Check if the service worker can be found. If it can't reload the page.
fetch(swUrl, {
headers: { 'Service-Worker': 'script' }
})
.then(response => {
// Ensure service worker exists, and that we really are getting a JS file.
const contentType = response.headers.get('content-type');
if (
response.status === 404 ||
(contentType != null && contentType.indexOf('javascript') === -1)
) {
// No service worker found. Probably a different app. Reload the page.
navigator.serviceWorker.ready.then(registration => {
registration.unregister().then(() => {
window.location.reload();
});
});
} else {
// Service worker found. Proceed as normal.
registerValidSW(swUrl, config);
}
})
.catch(() => {
console.log(
'No internet connection found. App is running in offline mode.'
);
});
}
export function unregister() {
if ('serviceWorker' in navigator) {
navigator.serviceWorker.ready
.then(registration => {
registration.unregister();
})
.catch(error => {
console.error(error.message);
});
}
}

View File

@@ -0,0 +1,5 @@
// jest-dom adds custom jest matchers for asserting on DOM nodes.
// allows you to do things like:
// expect(element).toHaveTextContent(/react/i)
// learn more: https://github.com/testing-library/jest-dom
import '@testing-library/jest-dom/extend-expect';

25
dss-web/tsconfig.json Normal file
View File

@@ -0,0 +1,25 @@
{
"compilerOptions": {
"target": "es5",
"lib": [
"dom",
"dom.iterable",
"esnext"
],
"allowJs": true,
"skipLibCheck": true,
"esModuleInterop": true,
"allowSyntheticDefaultImports": true,
"strict": true,
"forceConsistentCasingInFileNames": true,
"module": "esnext",
"moduleResolution": "node",
"resolveJsonModule": true,
"isolatedModules": true,
"noEmit": true,
"jsx": "react"
},
"include": [
"src"
]
}

11954
dss-web/yarn.lock Normal file

File diff suppressed because it is too large Load Diff