Compare commits
134 Commits
fix/link-u
...
master
Author | SHA1 | Date | |
---|---|---|---|
![]() |
e9e9611f80 | ||
0c054687ba | |||
3b147e50a1 | |||
![]() |
e94514ed02 | ||
![]() |
0032e51858 | ||
8d6a9ab74c | |||
07c4ae8cbd | |||
a782930d3d | |||
4c1877caa5 | |||
e9324f6c14 | |||
![]() |
9fcee44e0c | ||
![]() |
9939b1c824 | ||
00deb05850 | |||
b8849945b9 | |||
08f5ee272b | |||
35aa957b35 | |||
472e8c2ea5 | |||
f17d5f3079 | |||
![]() |
4f9b33e5b9 | ||
![]() |
753223c7a9 | ||
![]() |
28cc9b1a71 | ||
![]() |
47472868e1 | ||
![]() |
f965eaddbc | ||
![]() |
2075426ff7 | ||
![]() |
209507833e | ||
eff20ae459 | |||
dcfe260f0e | |||
1af206c360 | |||
![]() |
932d23befa | ||
![]() |
e52026cf86 | ||
033a1f31ad | |||
9c79f449c5 | |||
24652d0908 | |||
944baced6c | |||
![]() |
01a873477b | ||
![]() |
d1b17592c3 | ||
1475d2db27 | |||
1ba9dc28b5 | |||
1817946fe6 | |||
de5b6ad60c | |||
![]() |
31706ca4e8 | ||
![]() |
969749c0c0 | ||
![]() |
5667f30a92 | ||
![]() |
d77c1c6388 | ||
![]() |
bd6fbbebfd | ||
![]() |
2ffce71e74 | ||
35900bec5d | |||
![]() |
c63c19e1c7 | ||
![]() |
b5443aa033 | ||
![]() |
18d02945f3 | ||
558a1fd5a7 | |||
![]() |
bee5499816 | ||
8a2a7f0c53 | |||
15b9ed1f20 | |||
cad2174bc5 | |||
0c0a79d81d | |||
df4b4d5c32 | |||
92dddab82a | |||
93cefd9ce3 | |||
373d55a543 | |||
![]() |
8a075e926e | ||
![]() |
705ae6471f | ||
![]() |
64a6e6ab20 | ||
![]() |
3cac7c7d04 | ||
![]() |
9154b1fb96 | ||
![]() |
b390ae7a2e | ||
![]() |
3c739247d2 | ||
904730dfd9 | |||
dcda165488 | |||
49d15e538b | |||
![]() |
da389cc337 | ||
3f9a76815e | |||
c99e9217f1 | |||
4479300027 | |||
e97d3abe96 | |||
![]() |
eff1a2a04f | ||
81faa7121e | |||
bbe6bcca51 | |||
c161606e08 | |||
5550b7c241 | |||
![]() |
86073d5718 | ||
85f227f7d9 | |||
![]() |
779b091bd5 | ||
![]() |
a26faeeb02 | ||
50a42955d6 | |||
9a3e545cf0 | |||
87ad19fa1a | |||
1d5eb72826 | |||
011f1564a0 | |||
89146993c7 | |||
a9895cc6dd | |||
![]() |
5afd4ced4d | ||
![]() |
f09cddff75 | ||
![]() |
8db96d108f | ||
![]() |
a7534b589f | ||
![]() |
bd1771e234 | ||
![]() |
6cdd4ed730 | ||
![]() |
12043e9123 | ||
![]() |
5e46d6a098 | ||
![]() |
18cc0084af | ||
![]() |
43a73bc538 | ||
![]() |
4c90885d92 | ||
![]() |
f3c6b65b57 | ||
![]() |
ae0f36c21e | ||
![]() |
0e3f08dea9 | ||
![]() |
10b501869a | ||
![]() |
6e71403869 | ||
![]() |
ffb5a428a0 | ||
![]() |
0411fed55e | ||
![]() |
8aaff6ab7b | ||
![]() |
a047f1fd91 | ||
![]() |
449b05c1a0 | ||
![]() |
ccadb58979 | ||
![]() |
00ee5788a8 | ||
![]() |
f5251fd04b | ||
![]() |
2d2e9905d3 | ||
![]() |
956109f34a | ||
![]() |
d108e88c65 | ||
![]() |
4a44157efb | ||
![]() |
57b5c229a0 | ||
![]() |
37bc27bbd6 | ||
![]() |
ea783017a7 | ||
![]() |
aaecefb462 | ||
![]() |
f49b9fee1a | ||
![]() |
b5b05cd7ae | ||
![]() |
83ff35ce4f | ||
![]() |
2581ca1d88 | ||
![]() |
94f7a3d851 | ||
![]() |
f7a5aaf90e | ||
![]() |
8a64b5f0f7 | ||
![]() |
f3ccb0523a | ||
![]() |
4a5afdf01a | ||
![]() |
6d36b774b2 | ||
![]() |
21c858b519 |
14
.dockerignore
Normal file → Executable file
@ -1,8 +1,8 @@
|
|||||||
.env*
|
.env*
|
||||||
!.env.production
|
!.env.production
|
||||||
node_modules
|
node_modules
|
||||||
build
|
build
|
||||||
.vscode
|
.vscode
|
||||||
.cache
|
.cache
|
||||||
.nvmrc
|
.nvmrc
|
||||||
README.MD
|
README.MD
|
12
.env.development
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
REACT_APP_CMS_BASE_URL=https://cms.techpal.ru/api
|
REACT_APP_CMS_BASE_URL=http://scipaper.ru
|
||||||
REACT_APP_CMS_APP_NAME=techpal
|
REACT_APP_CMS_APP_NAME=scipaper
|
||||||
REACT_APP_OPENID_PROVIDER_URL=http://auth.techpal.ru/auth/realms/master/protocol/openid-connect/auth?client_id=techpal&response_type=code
|
REACT_APP_OPENID_PROVIDER_URL=http://auth.techpal.ru/auth/realms/master/protocol/openid-connect/auth?client_id=techpal&response_type=code
|
||||||
REACT_APP_INTEGRATOR_URL=http://integrator.techpal.ru
|
REACT_APP_INTEGRATOR_URL=http://scipaper.ru
|
||||||
REACT_APP_INTEGRATOR_API_VERSION=/api/1
|
REACT_APP_INTEGRATOR_API_VERSION=/v1
|
||||||
REACT_APP_GRAPHQL_URL=/graphql
|
REACT_APP_GRAPHQL_URL=/graphql
|
||||||
|
12
.env.production
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
REACT_APP_CMS_BASE_URL=EXT_CMS_BASE_URL
|
REACT_APP_CMS_BASE_URL=http://scipaper.ru
|
||||||
REACT_APP_CMS_APP_NAME=EXT_CMS_APP_NAME
|
REACT_APP_CMS_APP_NAME=scipaper
|
||||||
REACT_APP_OPENID_PROVIDER_URL=EXT_OPENID_PROVIDER_URL
|
REACT_APP_OPENID_PROVIDER_URL=http://auth.techpal.ru/auth/realms/master/protocol/openid-connect/auth?client_id=techpal&response_type=code
|
||||||
REACT_APP_INTEGRATOR_URL=EXT_INTEGRATOR_URL
|
REACT_APP_INTEGRATOR_URL=http://scipaper.ru
|
||||||
REACT_APP_INTEGRATOR_API_VERSION=EXT_INTEGRATOR_API_VERSION
|
REACT_APP_INTEGRATOR_API_VERSION=/v1
|
||||||
REACT_APP_GRAPHQL_URL=EXT_GRAPHQL_URL
|
REACT_APP_GRAPHQL_URL=/graphql
|
||||||
|
50
.gitignore
vendored
Normal file → Executable file
@ -1,25 +1,25 @@
|
|||||||
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
|
# See https://help.github.com/articles/ignoring-files/ for more about ignoring files.
|
||||||
|
|
||||||
# dependencies
|
# dependencies
|
||||||
/node_modules
|
/node_modules
|
||||||
/.pnp
|
/.pnp
|
||||||
.pnp.js
|
.pnp.js
|
||||||
|
|
||||||
# testing
|
# testing
|
||||||
/coverage
|
/coverage
|
||||||
|
|
||||||
# production
|
# production
|
||||||
/build
|
/build
|
||||||
|
|
||||||
# misc
|
# misc
|
||||||
.DS_Store
|
.DS_Store
|
||||||
.env.local
|
.env.local
|
||||||
.env.development.local
|
.env.development.local
|
||||||
.env.test.local
|
.env.test.local
|
||||||
.env.production.local
|
.env.production.local
|
||||||
|
|
||||||
.vscode
|
.vscode
|
||||||
|
|
||||||
npm-debug.log*
|
npm-debug.log*
|
||||||
yarn-debug.log*
|
yarn-debug.log*
|
||||||
yarn-error.log*
|
yarn-error.log*
|
||||||
|
2
.npmrc
Normal file → Executable file
@ -1 +1 @@
|
|||||||
legacy-peer-deps=true
|
legacy-peer-deps=true
|
||||||
|
266
.storybook/index.css
Normal file → Executable file
@ -1,134 +1,134 @@
|
|||||||
@tailwind base;
|
@tailwind base;
|
||||||
@tailwind components;
|
@tailwind components;
|
||||||
@tailwind utilities;
|
@tailwind utilities;
|
||||||
|
|
||||||
@layer base {
|
@layer base {
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Poppins";
|
font-family: "Poppins";
|
||||||
src: url("assets/fonts/Poppins-Bold.eot");
|
src: url("assets/fonts/Poppins-Bold.eot");
|
||||||
src: url("assets/fonts/Poppins-Bold.eot?#iefix") format("embedded-opentype"),
|
src: url("assets/fonts/Poppins-Bold.eot?#iefix") format("embedded-opentype"),
|
||||||
url("assets/fonts/Poppins-Bold.woff2") format("woff2"),
|
url("assets/fonts/Poppins-Bold.woff2") format("woff2"),
|
||||||
url("assets/fonts/Poppins-Bold.ttf") format("truetype");
|
url("assets/fonts/Poppins-Bold.ttf") format("truetype");
|
||||||
font-weight: 700;
|
font-weight: 700;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-display: swap;
|
font-display: swap;
|
||||||
}
|
}
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Poppins";
|
font-family: "Poppins";
|
||||||
src: url("assets/fonts/Poppins-Medium.eot");
|
src: url("assets/fonts/Poppins-Medium.eot");
|
||||||
src: url("assets/fonts/Poppins-Medium.eot?#iefix") format("embedded-opentype"),
|
src: url("assets/fonts/Poppins-Medium.eot?#iefix") format("embedded-opentype"),
|
||||||
url("assets/fonts/Poppins-Medium.woff2") format("woff2"),
|
url("assets/fonts/Poppins-Medium.woff2") format("woff2"),
|
||||||
url("assets/fonts/Poppins-Medium.ttf") format("truetype");
|
url("assets/fonts/Poppins-Medium.ttf") format("truetype");
|
||||||
font-weight: 500;
|
font-weight: 500;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-display: swap;
|
font-display: swap;
|
||||||
}
|
}
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Poppins";
|
font-family: "Poppins";
|
||||||
src: url("assets/fonts/Poppins-Regular.eot");
|
src: url("assets/fonts/Poppins-Regular.eot");
|
||||||
src: url("assets/fonts/Poppins-Regular.eot?#iefix") format("embedded-opentype"),
|
src: url("assets/fonts/Poppins-Regular.eot?#iefix") format("embedded-opentype"),
|
||||||
url("assets/fonts/Poppins-Regular.woff2") format("woff2"),
|
url("assets/fonts/Poppins-Regular.woff2") format("woff2"),
|
||||||
url("assets/fonts/Poppins-Regular.ttf") format("truetype");
|
url("assets/fonts/Poppins-Regular.ttf") format("truetype");
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-display: swap;
|
font-display: swap;
|
||||||
}
|
}
|
||||||
|
|
||||||
@font-face {
|
@font-face {
|
||||||
font-family: "Poppins";
|
font-family: "Poppins";
|
||||||
src: url("assets/fonts/Poppins-Thin.eot");
|
src: url("assets/fonts/Poppins-Thin.eot");
|
||||||
src: url("assets/fonts/Poppins-Thin.eot?#iefix") format("embedded-opentype"),
|
src: url("assets/fonts/Poppins-Thin.eot?#iefix") format("embedded-opentype"),
|
||||||
url("assets/fonts/Poppins-Thin.woff2") format("woff2"),
|
url("assets/fonts/Poppins-Thin.woff2") format("woff2"),
|
||||||
url("assets/fonts/Poppins-Thin.ttf") format("truetype");
|
url("assets/fonts/Poppins-Thin.ttf") format("truetype");
|
||||||
font-weight: 300;
|
font-weight: 300;
|
||||||
font-style: normal;
|
font-style: normal;
|
||||||
font-display: swap;
|
font-display: swap;
|
||||||
}
|
}
|
||||||
|
|
||||||
html {
|
html {
|
||||||
font-family: "Poppins", -apple-system, "Segoe UI", system-ui, "Roboto",
|
font-family: "Poppins", -apple-system, "Segoe UI", system-ui, "Roboto",
|
||||||
"Helvetica Neue", "Arial";
|
"Helvetica Neue", "Arial";
|
||||||
color: var(--color-text);
|
color: var(--color-text);
|
||||||
}
|
}
|
||||||
|
|
||||||
*,
|
*,
|
||||||
::before,
|
::before,
|
||||||
::after,
|
::after,
|
||||||
.theme-dark *,
|
.theme-dark *,
|
||||||
.theme-dark::before,
|
.theme-dark::before,
|
||||||
.theme-dark::after {
|
.theme-dark::after {
|
||||||
/* ------------------------------- Body color ------------------------------- */
|
/* ------------------------------- Body color ------------------------------- */
|
||||||
--color-aside: #0a0e1a;
|
--color-aside: #0a0e1a;
|
||||||
--color-footer: 10 10 10;
|
--color-footer: 10 10 10;
|
||||||
--color-text: rgb(38, 38, 38);
|
--color-text: rgb(38, 38, 38);
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
--color-serv: 25 29 43;
|
--color-serv: 25 29 43;
|
||||||
--color-serv-50: 227 230 237;
|
--color-serv-50: 227 230 237;
|
||||||
--color-serv-100: 200 205 223;
|
--color-serv-100: 200 205 223;
|
||||||
--color-serv-200: 142 152 189;
|
--color-serv-200: 142 152 189;
|
||||||
--color-serv-300: 90 104 155;
|
--color-serv-300: 90 104 155;
|
||||||
--color-serv-400: 58 67 100;
|
--color-serv-400: 58 67 100;
|
||||||
--color-serv-500: 25 29 43;
|
--color-serv-500: 25 29 43;
|
||||||
--color-serv-600: 21 24 35;
|
--color-serv-600: 21 24 35;
|
||||||
--color-serv-700: 15 17 26;
|
--color-serv-700: 15 17 26;
|
||||||
--color-serv-800: 9 11 16;
|
--color-serv-800: 9 11 16;
|
||||||
--color-serv-900: 6 7 10;
|
--color-serv-900: 6 7 10;
|
||||||
/* ---------------------------------- Blue ---------------------------------- */
|
/* ---------------------------------- Blue ---------------------------------- */
|
||||||
--color-blue-50: 240 247 254;
|
--color-blue-50: 240 247 254;
|
||||||
--color-blue-100: 221 237 254;
|
--color-blue-100: 221 237 254;
|
||||||
--color-blue-200: 182 216 252;
|
--color-blue-200: 182 216 252;
|
||||||
--color-blue-300: 137 192 250;
|
--color-blue-300: 137 192 250;
|
||||||
--color-blue-400: 74 158 247;
|
--color-blue-400: 74 158 247;
|
||||||
--color-blue-500: 9 109 217;
|
--color-blue-500: 9 109 217;
|
||||||
--color-blue-600: 8 99 196;
|
--color-blue-600: 8 99 196;
|
||||||
--color-blue-700: 7 87 171;
|
--color-blue-700: 7 87 171;
|
||||||
--color-blue-800: 6 69 137;
|
--color-blue-800: 6 69 137;
|
||||||
--color-blue-900: 4 49 98;
|
--color-blue-900: 4 49 98;
|
||||||
/* ---------------------------------- Gray ---------------------------------- */
|
/* ---------------------------------- Gray ---------------------------------- */
|
||||||
--color-gray-50: 250 250 250;
|
--color-gray-50: 250 250 250;
|
||||||
--color-gray-75: 240 240 240;
|
--color-gray-75: 240 240 240;
|
||||||
--color-gray-100: 235 235 235;
|
--color-gray-100: 235 235 235;
|
||||||
;
|
;
|
||||||
--color-gray-200: 214 214 214;
|
--color-gray-200: 214 214 214;
|
||||||
--color-gray-300: 191 191 191;
|
--color-gray-300: 191 191 191;
|
||||||
--color-gray-400: 166 166 166;
|
--color-gray-400: 166 166 166;
|
||||||
--color-gray-500: 140 140 140;
|
--color-gray-500: 140 140 140;
|
||||||
--color-gray-600: 115 115 115;
|
--color-gray-600: 115 115 115;
|
||||||
--color-gray-700: 89 89 89;
|
--color-gray-700: 89 89 89;
|
||||||
--color-gray-800: 64 64 64;
|
--color-gray-800: 64 64 64;
|
||||||
--color-gray-900: 38 38 38;
|
--color-gray-900: 38 38 38;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Dark theme */
|
/* Dark theme */
|
||||||
@media (prefers-color-scheme: dark) {
|
@media (prefers-color-scheme: dark) {
|
||||||
:root {
|
:root {
|
||||||
--bg: hsl(var(--hue), 10%, 10%);
|
--bg: hsl(var(--hue), 10%, 10%);
|
||||||
--fg: hsl(var(--hue), 10%, 90%);
|
--fg: hsl(var(--hue), 10%, 90%);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@layer components {
|
@layer components {
|
||||||
/* Separate
|
/* Separate
|
||||||
======================================================================== */
|
======================================================================== */
|
||||||
|
|
||||||
.separate {
|
.separate {
|
||||||
@apply flex items-center text-center;
|
@apply flex items-center text-center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.separate::after,
|
.separate::after,
|
||||||
.separate::before {
|
.separate::before {
|
||||||
content: '';
|
content: '';
|
||||||
@apply border-b border-gray-300 flex-1;
|
@apply border-b border-gray-300 flex-1;
|
||||||
}
|
}
|
||||||
|
|
||||||
.separate:not(:empty)::after {
|
.separate:not(:empty)::after {
|
||||||
@apply ml-2;
|
@apply ml-2;
|
||||||
}
|
}
|
||||||
|
|
||||||
.separate:not(:empty)::before {
|
.separate:not(:empty)::before {
|
||||||
@apply mr-2;
|
@apply mr-2;
|
||||||
}
|
}
|
||||||
}
|
}
|
30
.storybook/main.js
Normal file → Executable file
@ -1,16 +1,16 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
"stories": [
|
"stories": [
|
||||||
"../src/**/*.stories.mdx",
|
"../src/**/*.stories.mdx",
|
||||||
"../src/**/*.stories.@(js|jsx|ts|tsx)"
|
"../src/**/*.stories.@(js|jsx|ts|tsx)"
|
||||||
],
|
],
|
||||||
"addons": [
|
"addons": [
|
||||||
"@storybook/addon-links",
|
"@storybook/addon-links",
|
||||||
"@storybook/addon-essentials",
|
"@storybook/addon-essentials",
|
||||||
"@storybook/addon-interactions",
|
"@storybook/addon-interactions",
|
||||||
"@storybook/preset-create-react-app"
|
"@storybook/preset-create-react-app"
|
||||||
],
|
],
|
||||||
"framework": "@storybook/react",
|
"framework": "@storybook/react",
|
||||||
"core": {
|
"core": {
|
||||||
"builder": "@storybook/builder-webpack5"
|
"builder": "@storybook/builder-webpack5"
|
||||||
}
|
}
|
||||||
}
|
}
|
62
.storybook/main.ts
Normal file → Executable file
@ -1,31 +1,31 @@
|
|||||||
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin');
|
const TsconfigPathsPlugin = require('tsconfig-paths-webpack-plugin');
|
||||||
const Path = require('path');
|
const Path = require('path');
|
||||||
|
|
||||||
const AppSourceDir = Path.join(__dirname, '..', 'src');
|
const AppSourceDir = Path.join(__dirname, '..', 'src');
|
||||||
|
|
||||||
|
|
||||||
module.exports = {
|
module.exports = {
|
||||||
stories: ["../src/**/*.stories.mdx", "../src/**/*.stories.@(js|jsx|ts|tsx)"],
|
stories: ["../src/**/*.stories.mdx", "../src/**/*.stories.@(js|jsx|ts|tsx)"],
|
||||||
addons: [
|
addons: [
|
||||||
"@storybook/addon-links",
|
"@storybook/addon-links",
|
||||||
"@storybook/addon-essentials",
|
"@storybook/addon-essentials",
|
||||||
"@storybook/addon-interactions",
|
"@storybook/addon-interactions",
|
||||||
"@storybook/preset-create-react-app",
|
"@storybook/preset-create-react-app",
|
||||||
"storybook-addon-pseudo-states",
|
"storybook-addon-pseudo-states",
|
||||||
],
|
],
|
||||||
framework: "@storybook/react",
|
framework: "@storybook/react",
|
||||||
core: {
|
core: {
|
||||||
builder: "@storybook/builder-webpack5",
|
builder: "@storybook/builder-webpack5",
|
||||||
},
|
},
|
||||||
webpackFinal: async (config, { configType }) => {
|
webpackFinal: async (config, { configType }) => {
|
||||||
config.resolve.plugins = [
|
config.resolve.plugins = [
|
||||||
...(config.resolve.plugins || []),
|
...(config.resolve.plugins || []),
|
||||||
new TsconfigPathsPlugin({
|
new TsconfigPathsPlugin({
|
||||||
extensions: config.resolve.extensions,
|
extensions: config.resolve.extensions,
|
||||||
}),
|
}),
|
||||||
];
|
];
|
||||||
config.resolve.alias["@assets"] = Path.resolve(__dirname, '..', 'src', 'assets')
|
config.resolve.alias["@assets"] = Path.resolve(__dirname, '..', 'src', 'assets')
|
||||||
console.log(config);
|
console.log(config);
|
||||||
return config;
|
return config;
|
||||||
},
|
},
|
||||||
};
|
};
|
||||||
|
16
.storybook/preview.js
Normal file → Executable file
@ -1,9 +1,9 @@
|
|||||||
export const parameters = {
|
export const parameters = {
|
||||||
actions: { argTypesRegex: "^on[A-Z].*" },
|
actions: { argTypesRegex: "^on[A-Z].*" },
|
||||||
controls: {
|
controls: {
|
||||||
matchers: {
|
matchers: {
|
||||||
color: /(background|color)$/i,
|
color: /(background|color)$/i,
|
||||||
date: /Date$/,
|
date: /Date$/,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
}
|
}
|
136
.storybook/preview.ts
Normal file → Executable file
@ -1,68 +1,68 @@
|
|||||||
import "./index.css";
|
import "./index.css";
|
||||||
/**
|
/**
|
||||||
* Read https://storybook.js.org/docs/react/configure/overview#configure-story-rendering
|
* Read https://storybook.js.org/docs/react/configure/overview#configure-story-rendering
|
||||||
* for more information about the purpose of this file.
|
* for more information about the purpose of this file.
|
||||||
*
|
*
|
||||||
* Use preview.js for global code (such as CSS imports or JavaScript mocks)
|
* Use preview.js for global code (such as CSS imports or JavaScript mocks)
|
||||||
* that applies to all stories. For example, `import thirdPartyCss.css`.
|
* that applies to all stories. For example, `import thirdPartyCss.css`.
|
||||||
*
|
*
|
||||||
* This file can have three exports:
|
* This file can have three exports:
|
||||||
* - decorators - an array of global decorators
|
* - decorators - an array of global decorators
|
||||||
* - parameters - an object of global parameters
|
* - parameters - an object of global parameters
|
||||||
* - globalTypes - definition of globalTypes
|
* - globalTypes - definition of globalTypes
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Decorators
|
* Decorators
|
||||||
*
|
*
|
||||||
* A decorator is a way to wrap a story in extra “rendering” functionality.
|
* A decorator is a way to wrap a story in extra “rendering” functionality.
|
||||||
*
|
*
|
||||||
* Example:
|
* Example:
|
||||||
*
|
*
|
||||||
* import React from 'react';
|
* import React from 'react';
|
||||||
* export const decorators = [(Story) => <div style={{ margin: '3em' }}><Story/></div>];
|
* export const decorators = [(Story) => <div style={{ margin: '3em' }}><Story/></div>];
|
||||||
*
|
*
|
||||||
* Each story throughout the library will be wrapped in a div with a margin of 3
|
* Each story throughout the library will be wrapped in a div with a margin of 3
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Parameters
|
* Parameters
|
||||||
*
|
*
|
||||||
* Most Storybook addons are configured via a parameter-based API.
|
* Most Storybook addons are configured via a parameter-based API.
|
||||||
* You can set global parameters in this file
|
* You can set global parameters in this file
|
||||||
*
|
*
|
||||||
* export const parameters = {
|
* export const parameters = {
|
||||||
* backgrounds: {
|
* backgrounds: {
|
||||||
* values: [
|
* values: [
|
||||||
* { name: 'red', value: '#f00' },
|
* { name: 'red', value: '#f00' },
|
||||||
* { name: 'green', value: '#0f0' },
|
* { name: 'green', value: '#0f0' },
|
||||||
* ],
|
* ],
|
||||||
* },
|
* },
|
||||||
* };
|
* };
|
||||||
*
|
*
|
||||||
* With backgrounds, you configure the list of backgrounds that every story can render in.
|
* With backgrounds, you configure the list of backgrounds that every story can render in.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Global Types
|
* Global Types
|
||||||
*
|
*
|
||||||
* Global Types allow you to add your own toolbars by creating
|
* Global Types allow you to add your own toolbars by creating
|
||||||
* globalTypes with a toolbar annotation:
|
* globalTypes with a toolbar annotation:
|
||||||
*
|
*
|
||||||
* For example:
|
* For example:
|
||||||
*
|
*
|
||||||
* export const globalTypes = {
|
* export const globalTypes = {
|
||||||
* theme: {
|
* theme: {
|
||||||
* name: 'Theme',
|
* name: 'Theme',
|
||||||
* description: 'Global theme for components',
|
* description: 'Global theme for components',
|
||||||
* defaultValue: 'light',
|
* defaultValue: 'light',
|
||||||
* toolbar: {
|
* toolbar: {
|
||||||
* icon: 'circlehollow',
|
* icon: 'circlehollow',
|
||||||
* // array of plain string values or MenuItem shape
|
* // array of plain string values or MenuItem shape
|
||||||
* items: ['light', 'dark'],
|
* items: ['light', 'dark'],
|
||||||
* },
|
* },
|
||||||
* },
|
* },
|
||||||
* };
|
* };
|
||||||
*
|
*
|
||||||
* Will add a new dropdown in your toolbar with options light and dark.
|
* Will add a new dropdown in your toolbar with options light and dark.
|
||||||
**/
|
**/
|
||||||
|
79
Dockerfile
Normal file → Executable file
@ -1,38 +1,41 @@
|
|||||||
# Install dependencies only when needed
|
# Install dependencies only when needed
|
||||||
FROM node:16-alpine AS deps
|
FROM node:16-alpine AS deps
|
||||||
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
# Check https://github.com/nodejs/docker-node/tree/b4117f9333da4138b03a546ec926ef50a31506c3#nodealpine to understand why libc6-compat might be needed.
|
||||||
RUN apk add --no-cache libc6-compat
|
RUN apk add --no-cache libc6-compat
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
COPY package.json package-lock.json ./
|
COPY package.json package-lock.json ./
|
||||||
RUN npm ci
|
RUN npm ci
|
||||||
|
|
||||||
# Rebuild the source code only when needed
|
# Rebuild the source code only when needed
|
||||||
FROM node:16-alpine AS builder
|
FROM node:16-alpine AS builder
|
||||||
ENV NODE_ENV production
|
ENV NODE_ENV production
|
||||||
WORKDIR /app
|
WORKDIR /app
|
||||||
# Copy dependencies from deps stage
|
# Copy dependencies from deps stage
|
||||||
COPY --from=deps /app/node_modules ./node_modules
|
COPY --from=deps /app/node_modules ./node_modules
|
||||||
COPY . .
|
COPY . .
|
||||||
|
|
||||||
RUN npm run build
|
RUN npm run build
|
||||||
|
|
||||||
# Bundle static assets with nginx
|
# Bundle static assets with nginx
|
||||||
FROM nginx:1.21.6 as production
|
FROM node:16-alpine as production
|
||||||
# Copy built assets from builder
|
# Copy built assets from builder
|
||||||
COPY --from=builder /app/build /usr/share/nginx/html
|
WORKDIR /app
|
||||||
# Add nginx.config
|
COPY --from=builder /app/build .
|
||||||
COPY nginx.conf /etc/nginx/conf.d/default.conf
|
|
||||||
# Expose ports
|
# Expose ports
|
||||||
EXPOSE 80
|
EXPOSE 3000
|
||||||
|
|
||||||
COPY entrypoint.sh .
|
COPY .env.production .
|
||||||
COPY .env.production .
|
|
||||||
|
ENV NODE_ENV production
|
||||||
ENV NODE_ENV production
|
ENV USER_NAME=node_user USER_UID=2000 GROUP_NAME=node_group GROUP_UID=2000
|
||||||
|
|
||||||
# Execute script
|
RUN npm i -g serve \
|
||||||
RUN ["chmod", "+x", "./entrypoint.sh"]
|
&& deluser --remove-home node \
|
||||||
ENTRYPOINT ["./entrypoint.sh"]
|
&& addgroup --g ${GROUP_UID} -S ${GROUP_NAME} \
|
||||||
|
&& adduser -D -S -s /sbin/nologin -u ${USER_UID} -G ${GROUP_NAME} ${USER_NAME}\
|
||||||
# Start serving
|
&& chown -R ${USER_NAME}:${GROUP_NAME} "/app/"
|
||||||
CMD ["nginx", "-g", "daemon off;"]
|
|
||||||
|
|
||||||
|
USER "${USER_NAME}"
|
||||||
|
CMD serve -s .
|
50
Makefile
Normal file → Executable file
@ -1,26 +1,26 @@
|
|||||||
PROJECT_NAME=freeland-frontend
|
PROJECT_NAME=scipaper-frontend
|
||||||
|
|
||||||
setup:
|
setup:
|
||||||
npm i
|
npm i
|
||||||
|
|
||||||
build: setup
|
build: setup
|
||||||
npm run build
|
npm run build
|
||||||
|
|
||||||
dev: setup
|
dev: setup
|
||||||
npm run start
|
npm run start
|
||||||
|
|
||||||
test: setup
|
test: setup
|
||||||
npm run test
|
npm run test
|
||||||
|
|
||||||
container: setup
|
container: setup
|
||||||
docker build -t ${PROJECT_NAME} .
|
docker build -t ${PROJECT_NAME} .
|
||||||
|
|
||||||
clean:
|
clean:
|
||||||
rm -rf ./build
|
rm -rf ./build
|
||||||
|
|
||||||
build-docker: build container
|
build-docker: build container
|
||||||
|
|
||||||
stories: setup
|
stories: setup
|
||||||
npm run storybook
|
npm run storybook
|
||||||
|
|
||||||
.PHONY: build dev test container
|
.PHONY: build dev test container
|
222
README.md
Normal file → Executable file
@ -1,112 +1,112 @@
|
|||||||
# Getting Started with Freeland
|
# Getting Started with Freeland
|
||||||
|
|
||||||
This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
|
This project was bootstrapped with [Create React App](https://github.com/facebook/create-react-app).
|
||||||
|
|
||||||
## Available Scripts
|
## Available Scripts
|
||||||
|
|
||||||
In the project directory, you can run:
|
In the project directory, you can run:
|
||||||
|
|
||||||
### `make stories`
|
### `make stories`
|
||||||
|
|
||||||
Runs the Storybook server for component-driven isolated development.
|
Runs the Storybook server for component-driven isolated development.
|
||||||
Open [http://localhost:6006](http://localhost:6006) to view it in the browser.
|
Open [http://localhost:6006](http://localhost:6006) to view it in the browser.
|
||||||
|
|
||||||
The page will reload on edits.\
|
The page will reload on edits.\
|
||||||
For further information about how to create stories and UI-testing, \
|
For further information about how to create stories and UI-testing, \
|
||||||
please follow [this link](https://storybook.js.org/docs/react/writing-stories/introduction).
|
please follow [this link](https://storybook.js.org/docs/react/writing-stories/introduction).
|
||||||
|
|
||||||
### `make dev`
|
### `make dev`
|
||||||
|
|
||||||
Runs the app in the development mode.\
|
Runs the app in the development mode.\
|
||||||
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
|
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
|
||||||
|
|
||||||
The page will reload if you make edits.\
|
The page will reload if you make edits.\
|
||||||
You will also see any lint errors in the console.
|
You will also see any lint errors in the console.
|
||||||
|
|
||||||
### `make test`
|
### `make test`
|
||||||
|
|
||||||
Launches the test runner in the interactive watch mode.\
|
Launches the test runner in the interactive watch mode.\
|
||||||
See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
|
See the section about [running tests](https://facebook.github.io/create-react-app/docs/running-tests) for more information.
|
||||||
|
|
||||||
### `make build`
|
### `make build`
|
||||||
|
|
||||||
Builds the app for production to the `build` folder.\
|
Builds the app for production to the `build` folder.\
|
||||||
It correctly bundles React in production mode and optimizes the build for the best performance.
|
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.\
|
The build is minified and the filenames include the hashes.\
|
||||||
Your app is ready to be deployed!
|
Your app is ready to be deployed!
|
||||||
|
|
||||||
See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
|
See the section about [deployment](https://facebook.github.io/create-react-app/docs/deployment) for more information.
|
||||||
|
|
||||||
### `make container`
|
### `make container`
|
||||||
|
|
||||||
Builds up application container for production and tags it with a `freeland-frontend` tag.\
|
Builds up application container for production and tags it with a `freeland-frontend` tag.\
|
||||||
After process completion port `80` will be exposed inside a container to access files generated by `make build`
|
After process completion port `80` will be exposed inside a container to access files generated by `make build`
|
||||||
|
|
||||||
### `make build-docker`
|
### `make build-docker`
|
||||||
|
|
||||||
Creates docker container ready for deployment
|
Creates docker container ready for deployment
|
||||||
|
|
||||||
## `make clean`
|
## `make clean`
|
||||||
|
|
||||||
Drops **build** process artifacts. It will not remove docker containers due to possible other project named\
|
Drops **build** process artifacts. It will not remove docker containers due to possible other project named\
|
||||||
containers intercections.
|
containers intercections.
|
||||||
|
|
||||||
## Learn More
|
## Learn More
|
||||||
|
|
||||||
You can learn more in the [Create React App documentation](https://facebook.github.io/create-react-app/docs/getting-started).
|
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/).
|
To learn React, check out the [React documentation](https://reactjs.org/).
|
||||||
|
|
||||||
## Code sections division
|
## Code sections division
|
||||||
We care about our code appearance in text editor. That's why we are placing some
|
We care about our code appearance in text editor. That's why we are placing some
|
||||||
additional comments to seperate code parts using next style:
|
additional comments to seperate code parts using next style:
|
||||||
|
|
||||||
/\* -------------------------------------------------------------------------- \*/
|
/\* -------------------------------------------------------------------------- \*/
|
||||||
|
|
||||||
/\* User service functions \*/
|
/\* User service functions \*/
|
||||||
|
|
||||||
/\* -------------------------------------------------------------------------- \*/
|
/\* -------------------------------------------------------------------------- \*/
|
||||||
|
|
||||||
Or
|
Or
|
||||||
|
|
||||||
/\*-------------------------------- Hello --------------------------------\*/
|
/\*-------------------------------- Hello --------------------------------\*/
|
||||||
|
|
||||||
Or
|
Or
|
||||||
|
|
||||||
/\*-----------------------------------------------------------------------\*/
|
/\*-----------------------------------------------------------------------\*/
|
||||||
|
|
||||||
|
|
||||||
To place such comments for division code sections use [this](https://marketplace.visualstudio.com/items?itemName=stackbreak.comment-divider) extention.
|
To place such comments for division code sections use [this](https://marketplace.visualstudio.com/items?itemName=stackbreak.comment-divider) extention.
|
||||||
|
|
||||||
## Domain folder structure
|
## Domain folder structure
|
||||||
|
|
||||||
Inside specific domain you can see that we have next folders structure:
|
Inside specific domain you can see that we have next folders structure:
|
||||||
|
|
||||||
- domain folder (e.g.: user)
|
- domain folder (e.g.: user)
|
||||||
- controller
|
- controller
|
||||||
- some specific or general domain models (e.g. `userViewModel.ts`)
|
- some specific or general domain models (e.g. `userViewModel.ts`)
|
||||||
- data
|
- data
|
||||||
- Data transfer objects
|
- Data transfer objects
|
||||||
- Possible actions (e.g. `userActions.ts`) and action types definitions
|
- Possible actions (e.g. `userActions.ts`) and action types definitions
|
||||||
- Reducer rules for redux (e.g. `userReducer.ts`, rules to change your Redux state on specific action type)
|
- Reducer rules for redux (e.g. `userReducer.ts`, rules to change your Redux state on specific action type)
|
||||||
- Service (e.g. `userService.ts`, API interactions)
|
- Service (e.g. `userService.ts`, API interactions)
|
||||||
- Repository/Store implementation (e.g. `userSlice.ts`)
|
- Repository/Store implementation (e.g. `userSlice.ts`)
|
||||||
- domain
|
- domain
|
||||||
- Entity definition
|
- Entity definition
|
||||||
- Domain model definition
|
- Domain model definition
|
||||||
- Repository/Store interface
|
- Repository/Store interface
|
||||||
- useCases (e.g. `getUserUseCase.ts`, use cases of domain)
|
- useCases (e.g. `getUserUseCase.ts`, use cases of domain)
|
||||||
- views
|
- views
|
||||||
- pages
|
- pages
|
||||||
- specific components
|
- specific components
|
||||||
|
|
||||||
## Network layer
|
## Network layer
|
||||||
|
|
||||||
We use [Axios](https://github.com/axios/axios) for network interactions
|
We use [Axios](https://github.com/axios/axios) for network interactions
|
||||||
|
|
||||||
## Css styles and interactive components
|
## Css styles and interactive components
|
||||||
|
|
||||||
As a CSS framework we are using [TailwindCSS](https://tailwindcss.com/)
|
As a CSS framework we are using [TailwindCSS](https://tailwindcss.com/)
|
||||||
|
|
||||||
For UI/UX elements use [HeadlessUI](https://headlessui.com/)
|
For UI/UX elements use [HeadlessUI](https://headlessui.com/)
|
@ -1,4 +1,4 @@
|
|||||||
#!/bin/bash
|
#! /bin/bash
|
||||||
# no verbose
|
# no verbose
|
||||||
set +x
|
set +x
|
||||||
# config
|
# config
|
||||||
|
28
global.d.ts
vendored
Normal file → Executable file
@ -1,15 +1,15 @@
|
|||||||
|
|
||||||
declare module '*.svg' {
|
declare module '*.svg' {
|
||||||
import React = require('react');
|
import React = require('react');
|
||||||
export const ReactComponent: React.FC<React.SVGProps<SVGSVGElement>>;
|
export const ReactComponent: React.FC<React.SVGProps<SVGSVGElement>>;
|
||||||
const src: string;
|
const src: string;
|
||||||
export default src;
|
export default src;
|
||||||
}
|
}
|
||||||
|
|
||||||
export declare global {
|
export declare global {
|
||||||
interface Window {
|
interface Window {
|
||||||
state: any & {idx: number}
|
state: any & {idx: number}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
declare module "svg-inline-react"
|
declare module "svg-inline-react"
|
40
nginx.conf
Normal file → Executable file
@ -1,21 +1,21 @@
|
|||||||
server {
|
server {
|
||||||
listen *:80;
|
listen *:80;
|
||||||
|
|
||||||
location / {
|
location / {
|
||||||
root /usr/share/nginx/html/;
|
root /usr/share/nginx/html/;
|
||||||
include /etc/nginx/mime.types;
|
include /etc/nginx/mime.types;
|
||||||
try_files $uri $uri/ /index.html;
|
try_files $uri $uri/ /index.html;
|
||||||
|
|
||||||
# Cache static assets
|
# Cache static assets
|
||||||
location ~* \.(?:jpg|jpeg|gif|png|ico|svg)$ {
|
location ~* \.(?:jpg|jpeg|gif|png|ico|svg)$ {
|
||||||
expires 7d;
|
expires 7d;
|
||||||
add_header Cache-Control "public";
|
add_header Cache-Control "public";
|
||||||
}
|
}
|
||||||
|
|
||||||
# Cache css and js bundle
|
# Cache css and js bundle
|
||||||
location ~* \.(?:css|js)$ {
|
location ~* \.(?:css|js)$ {
|
||||||
add_header Cache-Control "no-cache, public, must-revalidate, proxy-revalidate";
|
add_header Cache-Control "no-cache, public, must-revalidate, proxy-revalidate";
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
133577
package-lock.json
generated
231
package.json
Normal file → Executable file
@ -1,107 +1,124 @@
|
|||||||
{
|
{
|
||||||
"name": "freeland",
|
"name": "freeland",
|
||||||
"version": "0.1.0",
|
"version": "0.1.0",
|
||||||
"private": true,
|
"private": true,
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@headlessui/react": "^1.6.6",
|
"@fortawesome/fontawesome-svg-core": "^6.2.0",
|
||||||
"@reduxjs/toolkit": "^1.8.3",
|
"@fortawesome/free-brands-svg-icons": "^6.2.0",
|
||||||
"@types/node": "^16.11.47",
|
"@fortawesome/free-solid-svg-icons": "^6.2.0",
|
||||||
"@types/react": "^18.0.15",
|
"@fortawesome/react-fontawesome": "^0.2.0",
|
||||||
"@types/react-dom": "^18.0.6",
|
"@headlessui/react": "^1.6.6",
|
||||||
"axios": "^0.27.2",
|
"@reduxjs/toolkit": "^1.8.3",
|
||||||
"classnames": "^2.3.1",
|
"@types/node": "^16.11.47",
|
||||||
"formik": "^2.2.9",
|
"@types/react": "^18.0.15",
|
||||||
"graphql": "^16.5.0",
|
"@types/react-copy-to-clipboard": "^5.0.4",
|
||||||
"graphql-tag": "^2.12.6",
|
"@types/react-dom": "^18.0.6",
|
||||||
"i18next": "^21.8.16",
|
"@uiw/react-md-editor": "^3.18.1",
|
||||||
"i18next-browser-languagedetector": "^6.1.4",
|
"axios": "^0.27.2",
|
||||||
"i18next-http-backend": "^1.4.1",
|
"classnames": "^2.3.1",
|
||||||
"jwt-decode": "^3.1.2",
|
"formik": "^2.2.9",
|
||||||
"lodash": "^4.17.21",
|
"graphql": "^16.5.0",
|
||||||
"react": "^18.2.0",
|
"graphql-tag": "^2.12.6",
|
||||||
"react-dom": "^18.2.0",
|
"i18next": "^21.8.16",
|
||||||
"react-hotkeys": "^2.0.0",
|
"i18next-browser-languagedetector": "^6.1.4",
|
||||||
"react-i18next": "^11.18.3",
|
"i18next-http-backend": "^1.4.1",
|
||||||
"react-redux": "^8.0.2",
|
"jwt-decode": "^3.1.2",
|
||||||
"react-router-dom": "^6.3.0",
|
"lodash": "^4.17.21",
|
||||||
"react-scripts": "5.0.1",
|
"react": "^18.2.0",
|
||||||
"react-scrollbars-custom": "^4.1.0",
|
"react-copy-to-clipboard": "^5.1.0",
|
||||||
"storybook-addon-pseudo-states": "^1.15.1",
|
"react-dom": "^18.2.0",
|
||||||
"tailwindcss": "^3.1.7",
|
"react-hotkeys": "^2.0.0",
|
||||||
"tsconfig-paths-webpack-plugin": "^4.0.0",
|
"react-i18next": "^11.18.3",
|
||||||
"typescript": "^4.7.4",
|
"react-loading-skeleton": "^3.1.0",
|
||||||
"web-vitals": "^2.1.4",
|
"react-lottie": "^1.2.3",
|
||||||
"yup": "^0.32.11"
|
"react-markdown": "^8.0.3",
|
||||||
},
|
"react-redux": "^8.0.2",
|
||||||
"scripts": {
|
"react-router-dom": "^6.3.0",
|
||||||
"dev-tools": "redux-devtools --hostname=localhost --port=8000",
|
"react-scripts": "5.0.1",
|
||||||
"start": "react-scripts start",
|
"react-scrollbars-custom": "^4.1.0",
|
||||||
"build": "react-scripts build",
|
"react-syntax-highlighter": "^15.5.0",
|
||||||
"test": "react-scripts test",
|
"remark-code-blocks": "^2.0.1",
|
||||||
"eject": "react-scripts eject",
|
"remark-gfm": "^3.0.1",
|
||||||
"storybook": "start-storybook -p 6006 -s public",
|
"storybook-addon-pseudo-states": "^1.15.1",
|
||||||
"build-storybook": "build-storybook -s public"
|
"swiper": "^8.3.2",
|
||||||
},
|
"tailwindcss": "^3.1.7",
|
||||||
"eslintConfig": {
|
"tsconfig-paths-webpack-plugin": "^4.0.0",
|
||||||
"extends": [
|
"typescript": "^4.7.4",
|
||||||
"react-app",
|
"web-vitals": "^2.1.4",
|
||||||
"react-app/jest"
|
"yup": "^0.32.11"
|
||||||
],
|
},
|
||||||
"overrides": [
|
"scripts": {
|
||||||
{
|
"dev-tools": "redux-devtools --hostname=localhost --port=8000",
|
||||||
"files": [
|
"start": "react-scripts start",
|
||||||
"**/*.stories.*"
|
"build": "react-scripts build",
|
||||||
],
|
"test": "react-scripts test",
|
||||||
"rules": {
|
"eject": "react-scripts eject",
|
||||||
"import/no-anonymous-default-export": "off"
|
"storybook": "start-storybook -p 6006 -s public",
|
||||||
}
|
"build-storybook": "build-storybook -s public"
|
||||||
},
|
},
|
||||||
{
|
"eslintConfig": {
|
||||||
"files": [
|
"extends": [
|
||||||
"**/*.stories.*"
|
"react-app",
|
||||||
],
|
"react-app/jest"
|
||||||
"rules": {
|
],
|
||||||
"import/no-anonymous-default-export": "off"
|
"overrides": [
|
||||||
}
|
{
|
||||||
}
|
"files": [
|
||||||
]
|
"**/*.stories.*"
|
||||||
},
|
],
|
||||||
"browserslist": {
|
"rules": {
|
||||||
"production": [
|
"import/no-anonymous-default-export": "off"
|
||||||
">0.2%",
|
}
|
||||||
"not dead",
|
},
|
||||||
"not op_mini all"
|
{
|
||||||
],
|
"files": [
|
||||||
"development": [
|
"**/*.stories.*"
|
||||||
"last 1 chrome version",
|
],
|
||||||
"last 1 firefox version",
|
"rules": {
|
||||||
"last 1 safari version"
|
"import/no-anonymous-default-export": "off"
|
||||||
]
|
}
|
||||||
},
|
}
|
||||||
"devDependencies": {
|
]
|
||||||
"@babel/preset-typescript": "^7.18.6",
|
},
|
||||||
"@storybook/addon-actions": "^6.5.9",
|
"browserslist": {
|
||||||
"@storybook/addon-essentials": "^6.5.9",
|
"production": [
|
||||||
"@storybook/addon-interactions": "^6.5.9",
|
">0.2%",
|
||||||
"@storybook/addon-links": "^6.5.9",
|
"not dead",
|
||||||
"@storybook/builder-webpack5": "^6.5.9",
|
"not op_mini all"
|
||||||
"@storybook/manager-webpack5": "^6.5.9",
|
],
|
||||||
"@storybook/node-logger": "^6.5.9",
|
"development": [
|
||||||
"@storybook/preset-create-react-app": "^4.1.2",
|
"last 1 chrome version",
|
||||||
"@storybook/react": "^6.5.9",
|
"last 1 firefox version",
|
||||||
"@storybook/testing-library": "^0.0.13",
|
"last 1 safari version"
|
||||||
"@svgr/webpack": "^6.3.1",
|
]
|
||||||
"@tailwindcss/line-clamp": "^0.4.0",
|
},
|
||||||
"@testing-library/jest-dom": "^5.16.4",
|
"devDependencies": {
|
||||||
"@testing-library/react": "^13.3.0",
|
"@babel/preset-typescript": "^7.18.6",
|
||||||
"@testing-library/user-event": "^13.5.0",
|
"@storybook/addon-actions": "^6.5.9",
|
||||||
"@types/jest": "^27.5.2",
|
"@storybook/addon-essentials": "^6.5.9",
|
||||||
"autoprefixer": "^10.4.8",
|
"@storybook/addon-interactions": "^6.5.9",
|
||||||
"babel-plugin-named-exports-order": "^0.0.2",
|
"@storybook/addon-links": "^6.5.9",
|
||||||
"jest": "^28.1.3",
|
"@storybook/builder-webpack5": "^6.5.9",
|
||||||
"postcss": "^8.4.14",
|
"@storybook/manager-webpack5": "^6.5.9",
|
||||||
"prop-types": "^15.8.1",
|
"@storybook/node-logger": "^6.5.9",
|
||||||
"react-test-renderer": "^18.2.0",
|
"@storybook/preset-create-react-app": "^4.1.2",
|
||||||
"webpack": "^5.74.0"
|
"@storybook/react": "^6.5.9",
|
||||||
}
|
"@storybook/testing-library": "^0.0.13",
|
||||||
}
|
"@svgr/webpack": "^6.3.1",
|
||||||
|
"@tailwindcss/line-clamp": "^0.4.0",
|
||||||
|
"@testing-library/jest-dom": "^5.16.4",
|
||||||
|
"@testing-library/react": "^13.3.0",
|
||||||
|
"@testing-library/user-event": "^13.5.0",
|
||||||
|
"@types/jest": "^27.5.2",
|
||||||
|
"@types/react-lottie": "^1.2.6",
|
||||||
|
"@types/react-syntax-highlighter": "^15.5.5",
|
||||||
|
"autoprefixer": "^10.4.8",
|
||||||
|
"babel-plugin-named-exports-order": "^0.0.2",
|
||||||
|
"jest": "^28.1.3",
|
||||||
|
"postcss": "^8.4.14",
|
||||||
|
"prop-types": "^15.8.1",
|
||||||
|
"react-test-renderer": "^18.2.0",
|
||||||
|
"tailwind-scrollbar": "^2.0.1",
|
||||||
|
"webpack": "^5.74.0"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
12
postcss.config.js
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
plugins: {
|
plugins: {
|
||||||
tailwindcss: {},
|
tailwindcss: {},
|
||||||
autoprefixer: {},
|
autoprefixer: {},
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
14
public/favicon.svg
Normal file → Executable file
@ -1,7 +1,7 @@
|
|||||||
<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg width="40" height="40" viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M14.4144 23.7511C8.27781 15.6345 1.97719 21.8024 3.62218 27.4753C7.75871 36.521 18.4462 40.5011 27.4937 36.364C30.6123 34.9384 33.2592 32.6525 35.1232 29.7747C30.3791 34.2166 21.7659 33.4741 14.4144 23.7497V23.7511Z" fill="#003A8C"/>
|
<path d="M14.4144 23.7511C8.27781 15.6345 1.97719 21.8024 3.62218 27.4753C7.75871 36.521 18.4462 40.5011 27.4937 36.364C30.6123 34.9384 33.2592 32.6525 35.1232 29.7747C30.3791 34.2166 21.7659 33.4741 14.4144 23.7497V23.7511Z" fill="#003A8C"/>
|
||||||
<path d="M19.9003 18.1624C11.4604 5.36349 1.99988 12.1819 1.99988 20.0029C1.99656 22.5922 2.55489 25.1515 3.63638 27.5043C2.51332 22.2054 8.60318 18.1213 14.273 25.7253C22.5092 36.7685 30.5857 34.8254 35.1069 29.8009C36.5583 27.5725 37.4959 25.0493 37.8517 22.414V22.4487C35.9103 28.4695 27.3438 29.4488 19.9003 18.1624Z" fill="#0050B3"/>
|
<path d="M19.9003 18.1624C11.4604 5.36349 1.99988 12.1819 1.99988 20.0029C1.99656 22.5922 2.55489 25.1515 3.63638 27.5043C2.51332 22.2054 8.60318 18.1213 14.273 25.7253C22.5092 36.7685 30.5857 34.8254 35.1069 29.8009C36.5583 27.5725 37.4959 25.0493 37.8517 22.414V22.4487C35.9103 28.4695 27.3438 29.4488 19.9003 18.1624Z" fill="#0050B3"/>
|
||||||
<path d="M25.6847 12.4357C19.4173 2.09743 11.4696 3.03149 6.09469 8.56864C3.44128 11.7879 1.99328 15.8313 1.99989 20.0028C2.56566 12.4371 11.7164 7.16932 20.0007 20.0028C27.3643 31.4243 36.5384 28.4489 37.8432 22.4812V22.4239C37.9578 21.6113 38.0065 20.7908 37.9889 19.9703V19.1522C34.8 21.434 30.6062 20.5529 25.6832 12.435L25.6847 12.4357Z" fill="#096DD9"/>
|
<path d="M25.6847 12.4357C19.4173 2.09743 11.4696 3.03149 6.09469 8.56864C3.44128 11.7879 1.99328 15.8313 1.99989 20.0028C2.56566 12.4371 11.7164 7.16932 20.0007 20.0028C27.3643 31.4243 36.5384 28.4489 37.8432 22.4812V22.4239C37.9578 21.6113 38.0065 20.7908 37.9889 19.9703V19.1522C34.8 21.434 30.6062 20.5529 25.6832 12.435L25.6847 12.4357Z" fill="#096DD9"/>
|
||||||
<path d="M25.7278 14.2762C31.4676 23.5022 36.416 21.142 38.0009 19.1685C37.9371 17.7894 37.714 16.4222 37.3361 15.0943C34.6607 15.1516 34.0369 14.704 31.404 10.697C27.3806 4.53122 22.3119 0.369342 13.4568 3.23302C10.5865 4.35754 8.05111 6.19659 6.09116 8.57572C12.1761 2.97705 19.6422 4.49657 25.7278 14.2762Z" fill="#40A9FF"/>
|
<path d="M25.7278 14.2762C31.4676 23.5022 36.416 21.142 38.0009 19.1685C37.9371 17.7894 37.714 16.4222 37.3361 15.0943C34.6607 15.1516 34.0369 14.704 31.404 10.697C27.3806 4.53122 22.3119 0.369342 13.4568 3.23302C10.5865 4.35754 8.05111 6.19659 6.09116 8.57572C12.1761 2.97705 19.6422 4.49657 25.7278 14.2762Z" fill="#40A9FF"/>
|
||||||
<path d="M31.0114 11.4889C33.6359 15.5037 35.2335 15.708 37.336 15.095C34.6097 5.51969 24.6358 -0.0323048 15.0593 2.69349C14.5162 2.84763 13.982 3.02747 13.4568 3.23299C21.367 0.737706 26.9774 5.32312 31.0114 11.4889Z" fill="#91D5FF"/>
|
<path d="M31.0114 11.4889C33.6359 15.5037 35.2335 15.708 37.336 15.095C34.6097 5.51969 24.6358 -0.0323048 15.0593 2.69349C14.5162 2.84763 13.982 3.02747 13.4568 3.23299C21.367 0.737706 26.9774 5.32312 31.0114 11.4889Z" fill="#91D5FF"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
86
public/index.html
Normal file → Executable file
@ -1,43 +1,43 @@
|
|||||||
<!DOCTYPE html>
|
<!DOCTYPE html>
|
||||||
<html lang="en">
|
<html lang="en">
|
||||||
<head>
|
<head>
|
||||||
<meta charset="utf-8" />
|
<meta charset="utf-8" />
|
||||||
<link rel="icon" href="%PUBLIC_URL%/favicon.svg" />
|
<link rel="icon" href="%PUBLIC_URL%/favicon.svg" />
|
||||||
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
||||||
<meta name="theme-color" content="#000000" />
|
<meta name="theme-color" content="#000000" />
|
||||||
<meta
|
<meta
|
||||||
name="description"
|
name="description"
|
||||||
content="Web site created using create-react-app"
|
content="Web site created using create-react-app"
|
||||||
/>
|
/>
|
||||||
<link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" />
|
<link rel="apple-touch-icon" href="%PUBLIC_URL%/logo192.png" />
|
||||||
<!--
|
<!--
|
||||||
manifest.json provides metadata used when your web app is installed on a
|
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/
|
user's mobile device or desktop. See https://developers.google.com/web/fundamentals/web-app-manifest/
|
||||||
-->
|
-->
|
||||||
<link rel="manifest" href="%PUBLIC_URL%/manifest.json" />
|
<link rel="manifest" href="%PUBLIC_URL%/manifest.json" />
|
||||||
<!--
|
<!--
|
||||||
Notice the use of %PUBLIC_URL% in the tags above.
|
Notice the use of %PUBLIC_URL% in the tags above.
|
||||||
It will be replaced with the URL of the `public` folder during the build.
|
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.
|
Only files inside the `public` folder can be referenced from the HTML.
|
||||||
|
|
||||||
Unlike "/favicon.ico" or "favicon.ico", "%PUBLIC_URL%/favicon.ico" will
|
Unlike "/favicon.ico" or "favicon.ico", "%PUBLIC_URL%/favicon.ico" will
|
||||||
work correctly both with client-side routing and a non-root public URL.
|
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`.
|
Learn how to configure a non-root public URL by running `npm run build`.
|
||||||
-->
|
-->
|
||||||
<title>Freeland</title>
|
<title>Scipaper</title>
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<noscript>You need to enable JavaScript to run this app.</noscript>
|
<noscript>You need to enable JavaScript to run this app.</noscript>
|
||||||
<div id="root"></div>
|
<div id="root"></div>
|
||||||
<!--
|
<!--
|
||||||
This HTML file is a template.
|
This HTML file is a template.
|
||||||
If you open it directly in the browser, you will see an empty page.
|
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.
|
You can add webfonts, meta tags, or analytics to this file.
|
||||||
The build step will place the bundled scripts into the <body> tag.
|
The build step will place the bundled scripts into the <body> tag.
|
||||||
|
|
||||||
To begin the development, run `npm start` or `yarn start`.
|
To begin the development, run `npm start` or `yarn start`.
|
||||||
To create a production bundle, use `npm run build` or `yarn build`.
|
To create a production bundle, use `npm run build` or `yarn build`.
|
||||||
-->
|
-->
|
||||||
</body>
|
</body>
|
||||||
</html>
|
</html>
|
||||||
|
211
public/locales/en/translation.json
Normal file → Executable file
@ -1,63 +1,148 @@
|
|||||||
{
|
{
|
||||||
"serv": {
|
"serv": {
|
||||||
"goHome": "Home",
|
"goHome": "Home page",
|
||||||
"noSuchPath": "We don't have this page"
|
"noSuchPath": "We don't have such a page"
|
||||||
},
|
},
|
||||||
"sidemenu": {
|
"sidemenu": {
|
||||||
"dashboard": "Dashboard",
|
"dashboard": "Dashboard",
|
||||||
"account": "Account",
|
"account": "Account",
|
||||||
"security": "Security",
|
"security": "Security",
|
||||||
"services": "Services"
|
"services": "Services"
|
||||||
},
|
},
|
||||||
"dialogues": {
|
"dialogues": {
|
||||||
"confirmAction": {
|
"confirmAction": {
|
||||||
"title": "Confirm action",
|
"title": "Confirm action",
|
||||||
"description": "Enter your techpal account password",
|
"description": "Enter your techpal account password",
|
||||||
"confirm": "Confirm"
|
"confirm": "Confirm"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"hellousr": "Hello, {{username}}",
|
"hellousr": "Hello, {{username}}",
|
||||||
"edit": "Edit",
|
"edit": "Edit",
|
||||||
"language": "Language",
|
"language": "Language",
|
||||||
"selectLanguage": "Select language",
|
"selectLanguage": "Select a language",
|
||||||
"save": "Save",
|
"save": "Save",
|
||||||
"cancel": "Cancel",
|
"cancel": "Cancel",
|
||||||
"account": {
|
"account": {
|
||||||
"info": "Personal information",
|
"info": "Personal Information",
|
||||||
"mail": "Mail",
|
"mail": "Mail",
|
||||||
"connect": "Add account",
|
"connect": "Add Account",
|
||||||
"connectedAccounts_one": "Connected account",
|
"connectedAccounts_one": "Linked Account",
|
||||||
"connectedAccounts_other": "Connected accounts",
|
"connectedAccounts_other": "Linked Accounts",
|
||||||
"settings": "Account settings"
|
"settings": "Account Settings"
|
||||||
},
|
},
|
||||||
"security": {
|
"security": {
|
||||||
"password": {
|
"password": {
|
||||||
"caption": "Password",
|
"caption": "Password",
|
||||||
"twoFactor": "Two factor authentication (2FA)",
|
"twoFactor": "Two-factor authentication (2FA)",
|
||||||
"description": "Keep your account secure by enabling 2FA via SMS or using a temporary one-time passcode (TOTP) from an authenticator app."
|
"description": "Protect your account by enabling 2FA via SMS or using a temporary one-time password (OTP) from the authentication app."
|
||||||
},
|
},
|
||||||
"activity": {
|
"activity": {
|
||||||
"caption": "Device activity"
|
"caption": "Device activity"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"label": "Search for something.."
|
"label": "We will find something.."
|
||||||
},
|
},
|
||||||
"subscriptions": {
|
"subscriptions": {
|
||||||
"subscribed": "Service have been connected"
|
"subscribed": "The service is attached to the account"
|
||||||
},
|
},
|
||||||
"viewHistory": "View history",
|
"viewHistory": "View history",
|
||||||
"logOutEverywhere": "log out from all devices",
|
"logOutEverywhere": "Log out from all devices",
|
||||||
"back": "Back",
|
"back": "Back",
|
||||||
"logOut": "Log out",
|
"logOut": "Exit",
|
||||||
"failures": {
|
"failures": {
|
||||||
"subscriptions": {
|
"subscriptions": {
|
||||||
"failure": "Failed to connect service",
|
"failure": "Failed to attach the service to your account",
|
||||||
"exists": "Service have already been connected",
|
"exists": "The service was already attached to your account earlier",
|
||||||
"confirmation": "Invalid confirmation information provided"
|
"confirmation": "Invalid password"
|
||||||
},
|
},
|
||||||
"services": {
|
"services": {
|
||||||
"fork": "Failed to authenticate in service"
|
"fork": "Failed to perform authorization in the service"
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"articlePage": {
|
||||||
|
"abstract": "Abstract",
|
||||||
|
"keywords": "Keywords",
|
||||||
|
"interactionButtons":{
|
||||||
|
"abstract": "Abstract",
|
||||||
|
"readFile": "Read File",
|
||||||
|
"download" : "Download",
|
||||||
|
"share" : "Share",
|
||||||
|
"cite" : "Cite",
|
||||||
|
"copied": "Copied"
|
||||||
|
}
|
||||||
|
|
||||||
|
},
|
||||||
|
"navbar": {
|
||||||
|
"createNew": "Create New",
|
||||||
|
"about": {
|
||||||
|
"navTitle": "About",
|
||||||
|
"aboutProject": "About Scipaper",
|
||||||
|
"contacts": "Contacts",
|
||||||
|
"help": "Help"
|
||||||
|
},
|
||||||
|
"library": {
|
||||||
|
"navTitle": "My library",
|
||||||
|
"publications": "Publications",
|
||||||
|
"favorites": "Favorites",
|
||||||
|
"collections": "Collections",
|
||||||
|
"recentViewed": "History"
|
||||||
|
},
|
||||||
|
"auth": {
|
||||||
|
"signIn": "Sign In",
|
||||||
|
"signUp": "Sign Up"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"footer": {
|
||||||
|
"accountSettings": "Account Settings",
|
||||||
|
"about": "About Scipaper",
|
||||||
|
"help": "Help",
|
||||||
|
"contactUs": "Contacts",
|
||||||
|
"allRightsReserved": "All rights reserved",
|
||||||
|
"termsOfUse": "Terms of Use",
|
||||||
|
"privacyPolicy": "Privacy Policy",
|
||||||
|
"coockiesPolicy": "coockies Usage Policy",
|
||||||
|
"supportedBy": "Created"
|
||||||
|
},
|
||||||
|
"mainPage": {
|
||||||
|
"title": "Scientific Library with Free Access",
|
||||||
|
"search": "Search",
|
||||||
|
"article_one": "Articles",
|
||||||
|
"article_few": "Articles",
|
||||||
|
"article_many": "Articles",
|
||||||
|
"advancedSearch": "Advanced search",
|
||||||
|
"featuredArticles": {
|
||||||
|
"title": "Featured articles",
|
||||||
|
"descriptionPart1": "Select the category of science you are interested in",
|
||||||
|
"descriptionPart2": "Scientific category",
|
||||||
|
"categories": {
|
||||||
|
"Medical": "Medical",
|
||||||
|
"TechnicsAndTechlonogies": "Technics and Technology",
|
||||||
|
"Fundamental": "Fundamental",
|
||||||
|
"Humanitarian": "Humanitarian",
|
||||||
|
"Agricultural": "Agricultural",
|
||||||
|
"Social": "Social"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"featuredAuthors": "Featured authors",
|
||||||
|
"more": "See More ",
|
||||||
|
"showAll": "Show all"
|
||||||
|
},
|
||||||
|
"searchResults": {
|
||||||
|
"title": "Search results",
|
||||||
|
"totalResults":"Total results",
|
||||||
|
"nothingFound": "Nothing found"
|
||||||
|
},
|
||||||
|
"filters": {
|
||||||
|
"authors":"Authors",
|
||||||
|
"publicationsType": "Publications Type",
|
||||||
|
"content":"Content",
|
||||||
|
"publisher":"Publisher",
|
||||||
|
"publicationTopic":"Publication Topic",
|
||||||
|
"appliedFitlers":"Applied Fitlers",
|
||||||
|
"clearAll":"Clear All",
|
||||||
|
"enterAuthorsName":"Enter Author Name",
|
||||||
|
"showAll":"Show All"
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
208
public/locales/ru/translation.json
Normal file → Executable file
@ -1,63 +1,145 @@
|
|||||||
{
|
{
|
||||||
"serv": {
|
"serv": {
|
||||||
"goHome": "На главную",
|
"goHome": "На главную",
|
||||||
"noSuchPath": "Такой страницы у нас нет"
|
"noSuchPath": "Такой страницы у нас нет"
|
||||||
},
|
},
|
||||||
"sidemenu": {
|
"sidemenu": {
|
||||||
"dashboard": "Панель",
|
"dashboard": "Панель",
|
||||||
"account": "Аккаунт",
|
"account": "Аккаунт",
|
||||||
"security": "Безопасность",
|
"security": "Безопасность",
|
||||||
"services": "Сервисы"
|
"services": "Сервисы"
|
||||||
},
|
},
|
||||||
"dialogues": {
|
"dialogues": {
|
||||||
"confirmAction": {
|
"confirmAction": {
|
||||||
"title": "Подтвердите действие",
|
"title": "Подтвердите действие",
|
||||||
"description": "Введите ваш пароль от аккаунта techpal",
|
"description": "Введите ваш пароль от аккаунта techpal",
|
||||||
"confirm": "Подтвердить"
|
"confirm": "Подтвердить"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"hellousr": "Привет, {{username}}",
|
"hellousr": "Привет, {{username}}",
|
||||||
"edit": "Изменить",
|
"edit": "Изменить",
|
||||||
"language": "Язык",
|
"language": "Язык",
|
||||||
"selectLanguage": "Выберите язык",
|
"selectLanguage": "Выберите язык",
|
||||||
"save": "Сохранить",
|
"save": "Сохранить",
|
||||||
"cancel": "Отмена",
|
"cancel": "Отмена",
|
||||||
"account": {
|
"account": {
|
||||||
"info": "Личная информация",
|
"info": "Личная информация",
|
||||||
"mail": "Почта",
|
"mail": "Почта",
|
||||||
"connect": "Добавить аккаунт",
|
"connect": "Добавить аккаунт",
|
||||||
"connectedAccounts_one": "Связанный аккаунт",
|
"connectedAccounts_one": "Связанный аккаунт",
|
||||||
"connectedAccounts_other": "Связанные аккаунты",
|
"connectedAccounts_other": "Связанные аккаунты",
|
||||||
"settings": "Настройки аккаунта"
|
"settings": "Настройки аккаунта"
|
||||||
},
|
},
|
||||||
"security": {
|
"security": {
|
||||||
"password": {
|
"password": {
|
||||||
"caption": "Пароль",
|
"caption": "Пароль",
|
||||||
"twoFactor": "Двухфакторная аутентификация (2FA)",
|
"twoFactor": "Двухфакторная аутентификация (2FA)",
|
||||||
"description": "Защитите свою учетную запись, включив 2FA с помощью SMS или используя временный одноразовый пароль (OTP) из приложения для проверки подлинности."
|
"description": "Защитите свою учетную запись, включив 2FA с помощью SMS или используя временный одноразовый пароль (OTP) из приложения для проверки подлинности."
|
||||||
},
|
},
|
||||||
"activity": {
|
"activity": {
|
||||||
"caption": "Активность устройств"
|
"caption": "Активность устройств"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"label": "Найдём что-нибудь.."
|
"label": "Найдём что-нибудь.."
|
||||||
},
|
},
|
||||||
"subscriptions": {
|
"subscriptions": {
|
||||||
"subscribed": "Сервис прикреплён к аккаунту"
|
"subscribed": "Сервис прикреплён к аккаунту"
|
||||||
},
|
},
|
||||||
"viewHistory": "просмотреть историю",
|
"viewHistory": "просмотреть историю",
|
||||||
"logOutEverywhere": "выйти со всех устройств",
|
"logOutEverywhere": "выйти со всех устройств",
|
||||||
"back": "Назад",
|
"back": "Назад",
|
||||||
"logOut": "Выйти",
|
"logOut": "Выйти",
|
||||||
"failures": {
|
"failures": {
|
||||||
"subscriptions": {
|
"subscriptions": {
|
||||||
"failure": "Не удалось прикрепить сервис к аккаунту",
|
"failure": "Не удалось прикрепить сервис к аккаунту",
|
||||||
"exists": "Сервис уже был прикреплён к вашему аккаунту ранее",
|
"exists": "Сервис уже был прикреплён к вашему аккаунту ранее",
|
||||||
"confirmation": "Неверный пароль"
|
"confirmation": "Неверный пароль"
|
||||||
},
|
},
|
||||||
"services": {
|
"services": {
|
||||||
"fork": "Не удалось выполнить авторизацию в сервисе"
|
"fork": "Не удалось выполнить авторизацию в сервисе"
|
||||||
}
|
}
|
||||||
}
|
},
|
||||||
}
|
"articlePage": {
|
||||||
|
"abstract": "Введение",
|
||||||
|
"keywords": "Ключевые слова",
|
||||||
|
"interactionButtons":{
|
||||||
|
"abstract": "Развернуть",
|
||||||
|
"readFile": "Читать",
|
||||||
|
"download" : "Скачать",
|
||||||
|
"share" : "Поделиться",
|
||||||
|
"cite" : "Цитировать",
|
||||||
|
"copied": "Скопировано"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"navbar": {
|
||||||
|
"createNew": "Создать статью",
|
||||||
|
"about": {
|
||||||
|
"navTitle": "О проекте",
|
||||||
|
"aboutProject": "О Scipaper",
|
||||||
|
"contacts": "Контакты",
|
||||||
|
"help": "Помощь"
|
||||||
|
},
|
||||||
|
"library": {
|
||||||
|
"navTitle": "Моя библиотека",
|
||||||
|
"publications": "Публикации",
|
||||||
|
"favorites": "Избранное",
|
||||||
|
"collections": "Коллекции",
|
||||||
|
"recentViewed": "История"
|
||||||
|
},
|
||||||
|
"auth": {
|
||||||
|
"signIn": "Вход",
|
||||||
|
"signUp": "Регистрация"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"footer": {
|
||||||
|
"accountSettings": "Настройки аккаунта",
|
||||||
|
"about": "О scipaper",
|
||||||
|
"help": "Помощь",
|
||||||
|
"contactUs": "Контакты",
|
||||||
|
"allRightsReserved": "Все права защищены",
|
||||||
|
"termsOfUse": "Правила использования",
|
||||||
|
"privacyPolicy": "Политика конфиденциальности",
|
||||||
|
"coockiesPolicy": "Политика использования coockies",
|
||||||
|
"supportedBy": "Создано"
|
||||||
|
},
|
||||||
|
"mainPage": {
|
||||||
|
"title": "Библиотека научных статей с бесплатным доступом",
|
||||||
|
"search": "Поиск",
|
||||||
|
"article_one": "статьи",
|
||||||
|
"article_few": "статей",
|
||||||
|
"article_many": "статей",
|
||||||
|
"advancedSearch": "Расширенный поиск",
|
||||||
|
"featuredArticles": {
|
||||||
|
"title": "Популярные статьи",
|
||||||
|
"descriptionPart1": "Выберете интересующую вас ",
|
||||||
|
"descriptionPart2": "научную категорию",
|
||||||
|
"categories": {
|
||||||
|
"Medical": "Медицина",
|
||||||
|
"TechnicsAndTechlonogies": "Техника и технологии",
|
||||||
|
"Fundamental": "Естественые",
|
||||||
|
"Humanitarian": "Гуманитарные",
|
||||||
|
"Agricultural": "Аuрокультурa",
|
||||||
|
"Social": "Социальные"
|
||||||
|
}
|
||||||
|
},
|
||||||
|
"featuredAuthors": "Популярные авторы",
|
||||||
|
"more": "Больше",
|
||||||
|
"showAll": "Показать все"
|
||||||
|
},
|
||||||
|
"searchResults": {
|
||||||
|
"title": "Результаты поиска",
|
||||||
|
"totalResults":"Всего найдено",
|
||||||
|
"nothingFound": "Ничего не найдено"
|
||||||
|
},
|
||||||
|
"filters": {
|
||||||
|
"authors":"Авторы",
|
||||||
|
"publicationsType": "Публикации",
|
||||||
|
"publisher":"Издатель",
|
||||||
|
"publicationTopic":"Тема публикации",
|
||||||
|
"appliedFitlers":"Фильтры",
|
||||||
|
"clearAll":"Очистить всё",
|
||||||
|
"enterAuthorsName":"Введите имя автора",
|
||||||
|
"showAll":"Показать все"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
0
public/logo192.png
Normal file → Executable file
Before Width: | Height: | Size: 5.2 KiB After Width: | Height: | Size: 5.2 KiB |
0
public/logo512.png
Normal file → Executable file
Before Width: | Height: | Size: 9.4 KiB After Width: | Height: | Size: 9.4 KiB |
50
public/manifest.json
Normal file → Executable file
@ -1,25 +1,25 @@
|
|||||||
{
|
{
|
||||||
"short_name": "React App",
|
"short_name": "React App",
|
||||||
"name": "Create React App Sample",
|
"name": "Create React App Sample",
|
||||||
"icons": [
|
"icons": [
|
||||||
{
|
{
|
||||||
"src": "favicon.ico",
|
"src": "favicon.ico",
|
||||||
"sizes": "64x64 32x32 24x24 16x16",
|
"sizes": "64x64 32x32 24x24 16x16",
|
||||||
"type": "image/x-icon"
|
"type": "image/x-icon"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"src": "logo192.png",
|
"src": "logo192.png",
|
||||||
"type": "image/png",
|
"type": "image/png",
|
||||||
"sizes": "192x192"
|
"sizes": "192x192"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
"src": "logo512.png",
|
"src": "logo512.png",
|
||||||
"type": "image/png",
|
"type": "image/png",
|
||||||
"sizes": "512x512"
|
"sizes": "512x512"
|
||||||
}
|
}
|
||||||
],
|
],
|
||||||
"start_url": ".",
|
"start_url": ".",
|
||||||
"display": "standalone",
|
"display": "standalone",
|
||||||
"theme_color": "#000000",
|
"theme_color": "#000000",
|
||||||
"background_color": "#ffffff"
|
"background_color": "#ffffff"
|
||||||
}
|
}
|
||||||
|
6
public/robots.txt
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
# https://www.robotstxt.org/robotstxt.html
|
# https://www.robotstxt.org/robotstxt.html
|
||||||
User-agent: *
|
User-agent: *
|
||||||
Disallow:
|
Disallow:
|
||||||
|
44
src/.storybook/main.js
Normal file → Executable file
@ -1,23 +1,23 @@
|
|||||||
module.exports = {
|
module.exports = {
|
||||||
stories: ['../**/*.stories.mdx', '../**/*.stories.@(js|jsx|ts|tsx)'],
|
stories: ['../**/*.stories.mdx', '../**/*.stories.@(js|jsx|ts|tsx)'],
|
||||||
/** Expose public folder to storybook as static */
|
/** Expose public folder to storybook as static */
|
||||||
staticDirs: ['../public'],
|
staticDirs: ['../public'],
|
||||||
addons: [
|
addons: [
|
||||||
'@storybook/addon-links',
|
'@storybook/addon-links',
|
||||||
'@storybook/addon-essentials',
|
'@storybook/addon-essentials',
|
||||||
'@storybook/addon-interactions',
|
'@storybook/addon-interactions',
|
||||||
'storybook-css-modules-preset',
|
'storybook-css-modules-preset',
|
||||||
{
|
{
|
||||||
name: '@storybook/addon-postcss',
|
name: '@storybook/addon-postcss',
|
||||||
options: {
|
options: {
|
||||||
postcssLoaderOptions: {
|
postcssLoaderOptions: {
|
||||||
implementation: require('postcss'),
|
implementation: require('postcss'),
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
],
|
],
|
||||||
framework: '@storybook/react',
|
framework: '@storybook/react',
|
||||||
core: {
|
core: {
|
||||||
builder: '@storybook/builder-webpack5',
|
builder: '@storybook/builder-webpack5',
|
||||||
},
|
},
|
||||||
};
|
};
|
4
src/.storybook/preview.js
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
export const parameters = {
|
export const parameters = {
|
||||||
actions: { argTypesRegex: "^on[A-Z].*" },
|
actions: { argTypesRegex: "^on[A-Z].*" },
|
||||||
}
|
}
|
76
src/App.css
Normal file → Executable file
@ -1,38 +1,38 @@
|
|||||||
.App {
|
.App {
|
||||||
text-align: center;
|
text-align: center;
|
||||||
}
|
}
|
||||||
|
|
||||||
.App-logo {
|
.App-logo {
|
||||||
height: 40vmin;
|
height: 40vmin;
|
||||||
pointer-events: none;
|
pointer-events: none;
|
||||||
}
|
}
|
||||||
|
|
||||||
@media (prefers-reduced-motion: no-preference) {
|
@media (prefers-reduced-motion: no-preference) {
|
||||||
.App-logo {
|
.App-logo {
|
||||||
animation: App-logo-spin infinite 20s linear;
|
animation: App-logo-spin infinite 20s linear;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
.App-header {
|
.App-header {
|
||||||
background-color: #282c34;
|
background-color: #282c34;
|
||||||
min-height: 100vh;
|
min-height: 100vh;
|
||||||
display: flex;
|
display: flex;
|
||||||
flex-direction: column;
|
flex-direction: column;
|
||||||
align-items: center;
|
align-items: center;
|
||||||
justify-content: center;
|
justify-content: center;
|
||||||
font-size: calc(10px + 2vmin);
|
font-size: calc(10px + 2vmin);
|
||||||
color: white;
|
color: white;
|
||||||
}
|
}
|
||||||
|
|
||||||
.App-link {
|
.App-link {
|
||||||
color: #61dafb;
|
color: #61dafb;
|
||||||
}
|
}
|
||||||
|
|
||||||
@keyframes App-logo-spin {
|
@keyframes App-logo-spin {
|
||||||
from {
|
from {
|
||||||
transform: rotate(0deg);
|
transform: rotate(0deg);
|
||||||
}
|
}
|
||||||
to {
|
to {
|
||||||
transform: rotate(360deg);
|
transform: rotate(360deg);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
18
src/App.test.tsx
Normal file → Executable file
@ -1,9 +1,9 @@
|
|||||||
import React from 'react';
|
import React from 'react';
|
||||||
import { render, screen } from '@testing-library/react';
|
import { render, screen } from '@testing-library/react';
|
||||||
import App from './App';
|
import App from './App';
|
||||||
|
|
||||||
test('renders learn react link', () => {
|
test('renders learn react link', () => {
|
||||||
render(<App />);
|
render(<App />);
|
||||||
const linkElement = screen.getByText(/learn react/i);
|
const linkElement = screen.getByText(/learn react/i);
|
||||||
expect(linkElement).toBeInTheDocument();
|
expect(linkElement).toBeInTheDocument();
|
||||||
});
|
});
|
||||||
|
34
src/App.tsx
Normal file → Executable file
@ -1,16 +1,18 @@
|
|||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/* Libraries */
|
/* Libraries */
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
import React from "react";
|
import React from "react";
|
||||||
/* -------------------------------------------------------------------------- */
|
import MainPage from "pages/MainPage";
|
||||||
/* Application root component */
|
|
||||||
/* -------------------------------------------------------------------------- */
|
/* -------------------------------------------------------------------------- */
|
||||||
/**
|
/* Application root component */
|
||||||
* Application root component
|
/* -------------------------------------------------------------------------- */
|
||||||
* @return {JSX.Element}
|
/**
|
||||||
*/
|
* Application root component
|
||||||
function App() {
|
* @return {JSX.Element}
|
||||||
return <div>Hello world!</div>;
|
*/
|
||||||
}
|
function App() {
|
||||||
|
return <MainPage />;
|
||||||
export default App;
|
}
|
||||||
|
|
||||||
|
export default App;
|
||||||
|
24
src/article/controller/articleViewModel.ts
Normal file
@ -0,0 +1,24 @@
|
|||||||
|
import type { ArticleStore } from "../domain/articleStore";
|
||||||
|
import { getArticleUseCase } from "../useCases/getArticleUseCase";
|
||||||
|
import { useCallback, useEffect } from "react";
|
||||||
|
|
||||||
|
function useArticleViewModel(store: ArticleStore) {
|
||||||
|
const _getArticle = useCallback(
|
||||||
|
(id: string) => getArticleUseCase(store.getArticle, store.setArticle, id),
|
||||||
|
[store.getArticle, store.setArticle]
|
||||||
|
);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if (store.article != undefined) {
|
||||||
|
_getArticle(store.article.id);
|
||||||
|
}
|
||||||
|
}, [store.article?.id]);
|
||||||
|
|
||||||
|
return {
|
||||||
|
article: store.article,
|
||||||
|
shouldShowLoading: typeof store.article === "undefined" || store.isLoading,
|
||||||
|
hasError: store.hasError,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
export { useArticleViewModel };
|
36
src/article/data/articleAPIService.ts
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
import axios from "axios";
|
||||||
|
import { Article } from "../domain/articleEntity";
|
||||||
|
import { create } from "../domain/articleModel";
|
||||||
|
import { FetchArticleByIdDTO } from "./dto/fetch_article_by_id_dto";
|
||||||
|
import Failure from "core/failure";
|
||||||
|
import { integratorApiClient } from "core/httpClient";
|
||||||
|
|
||||||
|
const articleEndpoint = "/papers/"
|
||||||
|
|
||||||
|
async function getArticle(id: string): Promise<Article> {
|
||||||
|
try {
|
||||||
|
const response = await integratorApiClient.get<FetchArticleByIdDTO>(
|
||||||
|
// `https://run.mocky.io/v3/62cd4581-d864-4d46-b1d6-02b45b5d1994/${id}`
|
||||||
|
// `https://jsonplaceholder.typicode.com/posts/${id}`
|
||||||
|
// `https://run.mocky.io/v3/066be3d8-0568-439a-8b20-062deed49a97`
|
||||||
|
articleEndpoint + id
|
||||||
|
);
|
||||||
|
const dto = response.data;
|
||||||
|
return create({
|
||||||
|
id: dto.id,
|
||||||
|
topic: [dto.topic],
|
||||||
|
title: dto.title,
|
||||||
|
authors: dto.authors,
|
||||||
|
tags: dto.tags,
|
||||||
|
summary: dto.summary,
|
||||||
|
content: dto.content,
|
||||||
|
});
|
||||||
|
} catch (reason) {
|
||||||
|
if (axios.isAxiosError(reason)) {
|
||||||
|
throw Failure.fromReason(reason, "failures.services.load");
|
||||||
|
}
|
||||||
|
throw reason;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
export { getArticle };
|
4
src/article/data/articleActionTypes.ts
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
export const SET_ARTICLE = "SET_ARTICLE";
|
||||||
|
export const GET_ARTICLE = "GET_ARTICLE";
|
||||||
|
export const GET_ARTICLE_SUCCESS = "GET_ARTICLE.success";
|
||||||
|
export const GET_ARTICLE_FAILURE = "GET_ARTICLE.failure";
|
23
src/article/data/articleActions.ts
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
import type { Article } from "../domain/articleEntity";
|
||||||
|
import { getArticle as getArticleAPI } from "./articleAPIService";
|
||||||
|
import * as actionTypes from "./articleActionTypes";
|
||||||
|
import { dispatchStatus } from "../../store/index";
|
||||||
|
|
||||||
|
const setArticleAction = (article: Article) => (dispatch: any) =>
|
||||||
|
dispatch({ type: actionTypes.SET_ARTICLE, article });
|
||||||
|
|
||||||
|
const getArticleAction = (id: string) => (dispatch: any) => {
|
||||||
|
dispatch({ type: actionTypes.GET_ARTICLE });
|
||||||
|
|
||||||
|
return getArticleAPI(id)
|
||||||
|
.then((article) => {
|
||||||
|
dispatchStatus(actionTypes.GET_ARTICLE, ".success", article)(dispatch);
|
||||||
|
return article;
|
||||||
|
})
|
||||||
|
.catch((reason) => {
|
||||||
|
dispatchStatus(actionTypes.GET_ARTICLE, ".failure", reason)(dispatch);
|
||||||
|
return reason;
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
export { setArticleAction, getArticleAction };
|
39
src/article/data/articleCommonStateStore.ts
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
import React, { useCallback, useState } from "react";
|
||||||
|
import { useDispatch } from "react-redux";
|
||||||
|
import { ArticleStore } from "../domain/articleStore";
|
||||||
|
import type { Article } from "../domain/articleEntity";
|
||||||
|
import { getArticle as getArticleAPI } from "./articleAPIService";
|
||||||
|
|
||||||
|
const useArticleCommonStore = (): ArticleStore => {
|
||||||
|
const [isLoading, setLoading] = useState<boolean>(false);
|
||||||
|
const [hasError, setError] = useState<boolean>(false);
|
||||||
|
const [article, setArticleState] = useState<Article | undefined>();
|
||||||
|
|
||||||
|
const dispatch = useDispatch();
|
||||||
|
|
||||||
|
const getArticle = useCallback(
|
||||||
|
async (id: string) => {
|
||||||
|
setLoading(true);
|
||||||
|
try {
|
||||||
|
const article = await getArticleAPI(id);
|
||||||
|
setArticleState(article);
|
||||||
|
setLoading(false);
|
||||||
|
return article;
|
||||||
|
} catch (error) {
|
||||||
|
setError(true);
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
[dispatch]
|
||||||
|
);
|
||||||
|
|
||||||
|
return {
|
||||||
|
article: article,
|
||||||
|
isLoading,
|
||||||
|
hasError,
|
||||||
|
setArticle: setArticleState,
|
||||||
|
getArticle,
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
export { useArticleCommonStore };
|
32
src/article/data/articleReducer.ts
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
import { AnyAction } from "@reduxjs/toolkit";
|
||||||
|
import type { ArticleStore } from "../domain/articleStore";
|
||||||
|
import * as actionTypes from "./articleActionTypes";
|
||||||
|
|
||||||
|
type ArticleStoreState = Omit<ArticleStore, "getArticle" | "setArticle">;
|
||||||
|
|
||||||
|
const INITIAL_STATE: ArticleStoreState = {
|
||||||
|
article: undefined,
|
||||||
|
isLoading: false,
|
||||||
|
hasError: false,
|
||||||
|
};
|
||||||
|
|
||||||
|
const articleReducer = (
|
||||||
|
state: ArticleStoreState = INITIAL_STATE,
|
||||||
|
action: AnyAction
|
||||||
|
): ArticleStoreState => {
|
||||||
|
switch (action.type) {
|
||||||
|
case actionTypes.SET_ARTICLE:
|
||||||
|
return { ...state, article: action.article };
|
||||||
|
case actionTypes.GET_ARTICLE:
|
||||||
|
return { ...state, isLoading: true };
|
||||||
|
case actionTypes.GET_ARTICLE_SUCCESS:
|
||||||
|
return { ...state, isLoading: false, article: action.payload };
|
||||||
|
case actionTypes.GET_ARTICLE_FAILURE:
|
||||||
|
return { ...state, hasError: true, isLoading: false };
|
||||||
|
default:
|
||||||
|
return state;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
export { articleReducer };
|
||||||
|
export type { ArticleStoreState };
|
35
src/article/data/articleStoreImplementation.ts
Normal file
@ -0,0 +1,35 @@
|
|||||||
|
import React, { useCallback, useState } from "react";
|
||||||
|
import { useDispatch, useSelector } from "react-redux";
|
||||||
|
import { ArticleStore } from "../domain/articleStore";
|
||||||
|
import type { Article } from "../domain/articleEntity";
|
||||||
|
import type { ArticleStoreState } from "../data/articleReducer";
|
||||||
|
import { getArticleAction, setArticleAction } from "./articleActions";
|
||||||
|
import { RootState, useAppSelector } from "store";
|
||||||
|
|
||||||
|
const articleSelector = (state: RootState): ArticleStoreState => state.article;
|
||||||
|
|
||||||
|
const useArticleStore = (): ArticleStore => {
|
||||||
|
const { isLoading, article, hasError } = useAppSelector(articleSelector);
|
||||||
|
|
||||||
|
const dispatch = useDispatch();
|
||||||
|
|
||||||
|
const setArticle = useCallback(
|
||||||
|
(article: Article) => setArticleAction(article)(dispatch),
|
||||||
|
[dispatch]
|
||||||
|
);
|
||||||
|
|
||||||
|
const getArticle = useCallback(
|
||||||
|
(id: string) => getArticleAction(id)(dispatch),
|
||||||
|
[dispatch]
|
||||||
|
);
|
||||||
|
|
||||||
|
return {
|
||||||
|
article: article,
|
||||||
|
isLoading,
|
||||||
|
hasError,
|
||||||
|
setArticle,
|
||||||
|
getArticle,
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
export { useArticleStore };
|
9
src/article/data/dto/fetch_article_by_id_dto.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export interface FetchArticleByIdDTO {
|
||||||
|
id: string;
|
||||||
|
topic: string;
|
||||||
|
title: string;
|
||||||
|
authors: string[];
|
||||||
|
tags: string[];
|
||||||
|
summary: string;
|
||||||
|
content: string;
|
||||||
|
}
|
9
src/article/domain/articleEntity.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export interface Article {
|
||||||
|
id: string;
|
||||||
|
title: string;
|
||||||
|
content: string;
|
||||||
|
topic?: string[];
|
||||||
|
authors?: string[];
|
||||||
|
tags?: string[];
|
||||||
|
summary?: string;
|
||||||
|
}
|
14
src/article/domain/articleModel.ts
Normal file
@ -0,0 +1,14 @@
|
|||||||
|
import { CreateArticleParams } from "article/useCases/params/create_article_params";
|
||||||
|
import { Article } from "./articleEntity";
|
||||||
|
|
||||||
|
const create = (props: CreateArticleParams): Article => ({
|
||||||
|
id: props.id,
|
||||||
|
topic: props.topic,
|
||||||
|
title: props.title,
|
||||||
|
authors: props.authors,
|
||||||
|
tags: props.tags,
|
||||||
|
summary: props.summary,
|
||||||
|
content: props.content,
|
||||||
|
});
|
||||||
|
|
||||||
|
export { create };
|
13
src/article/domain/articleStore.ts
Normal file
@ -0,0 +1,13 @@
|
|||||||
|
import { Article } from './articleEntity';
|
||||||
|
interface ArticleStore {
|
||||||
|
// State
|
||||||
|
article: Article | undefined;
|
||||||
|
isLoading: boolean;
|
||||||
|
hasError: boolean;
|
||||||
|
|
||||||
|
// Actions
|
||||||
|
setArticle(article?: Article): void;
|
||||||
|
getArticle(identifier: string): Promise<Article | null>;
|
||||||
|
}
|
||||||
|
|
||||||
|
export type { ArticleStore };
|
16
src/article/useCases/getArticleUseCase.ts
Normal file
@ -0,0 +1,16 @@
|
|||||||
|
import { Article } from "article/domain/articleEntity";
|
||||||
|
import type { ArticleStore } from "../domain/articleStore";
|
||||||
|
|
||||||
|
const getArticleUseCase = async (
|
||||||
|
getArticle: ArticleStore["getArticle"],
|
||||||
|
setArticle: ArticleStore["setArticle"],
|
||||||
|
id: Article["id"]
|
||||||
|
): Promise<Article | null> => {
|
||||||
|
const article = await getArticle(id);
|
||||||
|
if (article) {
|
||||||
|
await setArticle(article);
|
||||||
|
}
|
||||||
|
return article;
|
||||||
|
};
|
||||||
|
|
||||||
|
export { getArticleUseCase };
|
9
src/article/useCases/params/create_article_params.ts
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
export interface CreateArticleParams {
|
||||||
|
id: string;
|
||||||
|
topic: string[];
|
||||||
|
title: string;
|
||||||
|
authors: string[];
|
||||||
|
tags: string[];
|
||||||
|
summary: string;
|
||||||
|
content: string;
|
||||||
|
}
|
0
src/assets/fonts/Inter-Black.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-Bold.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-ExtraBold.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-ExtraLight.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-Light.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-Medium.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-Regular.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-SemiBold.ttf
Normal file → Executable file
0
src/assets/fonts/Inter-Thin.ttf
Normal file → Executable file
0
src/assets/fonts/Poppins-Bold.eot
Normal file → Executable file
0
src/assets/fonts/Poppins-Bold.ttf
Normal file → Executable file
0
src/assets/fonts/Poppins-Bold.woff2
Normal file → Executable file
0
src/assets/fonts/Poppins-Medium.eot
Normal file → Executable file
0
src/assets/fonts/Poppins-Medium.ttf
Normal file → Executable file
0
src/assets/fonts/Poppins-Medium.woff2
Normal file → Executable file
0
src/assets/fonts/Poppins-Regular.eot
Normal file → Executable file
0
src/assets/fonts/Poppins-Regular.ttf
Normal file → Executable file
0
src/assets/fonts/Poppins-Regular.woff2
Normal file → Executable file
0
src/assets/fonts/Poppins-Thin.eot
Normal file → Executable file
0
src/assets/fonts/Poppins-Thin.ttf
Normal file → Executable file
0
src/assets/fonts/Poppins-Thin.woff2
Normal file → Executable file
1
src/assets/lotties/notFoundAnimation.json
Normal file
6
src/assets/svg/agricultural.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 40 40" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill-rule="evenodd" clip-rule="evenodd" d="M16.5495 18.1523C20.0358 21.1083 21.1165 25.66 19.7396 29.9152H30.4102C31.4258 26.9366 34.4857 25.2281 37.9199 26.6722L39.1536 19.4836C39.362 18.2715 38.138 17.2497 36.8978 17.2497H30.0098V11.8372C30.0098 11.415 29.668 11.0636 29.2448 11.0442V8.24616H28.1901V11.0442C27.7767 11.0733 27.4479 11.4182 27.4479 11.834V17.2497H22.0703C23.099 12.4304 21.8978 10.7831 21.2044 5.88004C20.931 5.1773 20.3939 5.01934 19.7884 5H7.25586C6.6276 5.00645 6.19141 5.31591 5.96354 5.96063L5.11393 14.068L3.42122 16.0473C2.68229 16.8951 2.89714 16.6984 3.57747 17.7106C3.69466 17.6268 3.81185 17.543 3.93229 17.4656C7.49349 15.1576 13.1966 15.5734 16.5495 18.1523ZM29.0951 6.74397C29.1439 6.69561 29.222 6.69239 29.2741 6.74074C29.3229 6.7891 29.3262 6.86646 29.2773 6.91804C29.1829 7.01475 29.2188 7.15336 29.2513 7.28231C29.3099 7.50151 29.362 7.70137 29.0951 7.85288C29.0332 7.88834 28.9583 7.86578 28.9225 7.80775C28.8867 7.74973 28.9128 7.67236 28.9714 7.6369C29.069 7.5821 29.0397 7.46928 29.0072 7.34678C28.9583 7.15336 28.903 6.94383 29.0951 6.74397ZM28.3333 6.74397C28.3822 6.69561 28.4603 6.69239 28.5124 6.74074C28.5612 6.7891 28.5645 6.86646 28.5156 6.91804C28.4212 7.01475 28.457 7.15336 28.4896 7.28231C28.5482 7.50151 28.6003 7.70137 28.3333 7.85288C28.2715 7.88834 28.1966 7.86578 28.1608 7.80775C28.125 7.7465 28.1478 7.67236 28.2064 7.6369C28.304 7.5821 28.2747 7.46928 28.2422 7.34678C28.1934 7.15336 28.138 6.94383 28.3333 6.74397ZM14.4694 7.68203V13.6618C15.8659 13.9745 17.2461 14.4032 18.6035 14.9512C19.3132 15.2381 20.1497 14.313 20 13.5683L19.0885 9.06173C18.9388 8.31708 18.4603 7.67881 17.6921 7.67881H14.4694V7.68203ZM13.0827 13.3878V7.68203H9.63216C8.86393 7.68203 8.41146 8.32353 8.23568 9.06496L7.63021 11.6503C7.45768 12.3917 8.25846 13.0203 9.02669 13.0332C10.3939 13.0461 11.7448 13.1654 13.0827 13.3878ZM35.7585 27.2428C38.099 27.2428 40 29.1222 40 31.4432C40 33.7609 38.1022 35.6403 35.7585 35.6403C33.4147 35.6403 31.5202 33.7609 31.5202 31.4432C31.5202 29.1222 33.418 27.2428 35.7585 27.2428ZM9.05925 17.8267C14.0625 17.8267 18.1185 21.8433 18.1185 26.798C18.1185 31.7526 14.0625 35.7692 9.05925 35.7692C4.05599 35.7692 0 31.7526 0 26.798C0 21.8433 4.05599 17.8267 9.05925 17.8267ZM9.05925 21.9755C11.748 21.9755 13.929 24.1353 13.929 26.798C13.929 29.4607 11.748 31.6205 9.05925 31.6205C6.37044 31.6205 4.18945 29.4607 4.18945 26.798C4.18945 24.1353 6.37044 21.9755 9.05925 21.9755ZM35.7585 29.3124C36.9466 29.3124 37.9069 30.2666 37.9069 31.4399C37.9069 32.6166 36.9434 33.5675 35.7585 33.5675C34.5703 33.5675 33.61 32.6133 33.61 31.4399C33.61 30.2666 34.5736 29.3124 35.7585 29.3124ZM29.4564 19.8737H34.8112L34.6908 20.4862H29.3522L29.4564 19.8737ZM27.5781 23.1746H34.8112L34.6908 23.7871H27.4707L27.5781 23.1746ZM28.2454 21.5242H34.8145L34.694 22.1366H28.138L28.2454 21.5242Z" fill="#8C8C8C"/>
|
<path fill-rule="evenodd" clip-rule="evenodd" d="M16.5495 18.1523C20.0358 21.1083 21.1165 25.66 19.7396 29.9152H30.4102C31.4258 26.9366 34.4857 25.2281 37.9199 26.6722L39.1536 19.4836C39.362 18.2715 38.138 17.2497 36.8978 17.2497H30.0098V11.8372C30.0098 11.415 29.668 11.0636 29.2448 11.0442V8.24616H28.1901V11.0442C27.7767 11.0733 27.4479 11.4182 27.4479 11.834V17.2497H22.0703C23.099 12.4304 21.8978 10.7831 21.2044 5.88004C20.931 5.1773 20.3939 5.01934 19.7884 5H7.25586C6.6276 5.00645 6.19141 5.31591 5.96354 5.96063L5.11393 14.068L3.42122 16.0473C2.68229 16.8951 2.89714 16.6984 3.57747 17.7106C3.69466 17.6268 3.81185 17.543 3.93229 17.4656C7.49349 15.1576 13.1966 15.5734 16.5495 18.1523ZM29.0951 6.74397C29.1439 6.69561 29.222 6.69239 29.2741 6.74074C29.3229 6.7891 29.3262 6.86646 29.2773 6.91804C29.1829 7.01475 29.2188 7.15336 29.2513 7.28231C29.3099 7.50151 29.362 7.70137 29.0951 7.85288C29.0332 7.88834 28.9583 7.86578 28.9225 7.80775C28.8867 7.74973 28.9128 7.67236 28.9714 7.6369C29.069 7.5821 29.0397 7.46928 29.0072 7.34678C28.9583 7.15336 28.903 6.94383 29.0951 6.74397ZM28.3333 6.74397C28.3822 6.69561 28.4603 6.69239 28.5124 6.74074C28.5612 6.7891 28.5645 6.86646 28.5156 6.91804C28.4212 7.01475 28.457 7.15336 28.4896 7.28231C28.5482 7.50151 28.6003 7.70137 28.3333 7.85288C28.2715 7.88834 28.1966 7.86578 28.1608 7.80775C28.125 7.7465 28.1478 7.67236 28.2064 7.6369C28.304 7.5821 28.2747 7.46928 28.2422 7.34678C28.1934 7.15336 28.138 6.94383 28.3333 6.74397ZM14.4694 7.68203V13.6618C15.8659 13.9745 17.2461 14.4032 18.6035 14.9512C19.3132 15.2381 20.1497 14.313 20 13.5683L19.0885 9.06173C18.9388 8.31708 18.4603 7.67881 17.6921 7.67881H14.4694V7.68203ZM13.0827 13.3878V7.68203H9.63216C8.86393 7.68203 8.41146 8.32353 8.23568 9.06496L7.63021 11.6503C7.45768 12.3917 8.25846 13.0203 9.02669 13.0332C10.3939 13.0461 11.7448 13.1654 13.0827 13.3878ZM35.7585 27.2428C38.099 27.2428 40 29.1222 40 31.4432C40 33.7609 38.1022 35.6403 35.7585 35.6403C33.4147 35.6403 31.5202 33.7609 31.5202 31.4432C31.5202 29.1222 33.418 27.2428 35.7585 27.2428ZM9.05925 17.8267C14.0625 17.8267 18.1185 21.8433 18.1185 26.798C18.1185 31.7526 14.0625 35.7692 9.05925 35.7692C4.05599 35.7692 0 31.7526 0 26.798C0 21.8433 4.05599 17.8267 9.05925 17.8267ZM9.05925 21.9755C11.748 21.9755 13.929 24.1353 13.929 26.798C13.929 29.4607 11.748 31.6205 9.05925 31.6205C6.37044 31.6205 4.18945 29.4607 4.18945 26.798C4.18945 24.1353 6.37044 21.9755 9.05925 21.9755ZM35.7585 29.3124C36.9466 29.3124 37.9069 30.2666 37.9069 31.4399C37.9069 32.6166 36.9434 33.5675 35.7585 33.5675C34.5703 33.5675 33.61 32.6133 33.61 31.4399C33.61 30.2666 34.5736 29.3124 35.7585 29.3124ZM29.4564 19.8737H34.8112L34.6908 20.4862H29.3522L29.4564 19.8737ZM27.5781 23.1746H34.8112L34.6908 23.7871H27.4707L27.5781 23.1746ZM28.2454 21.5242H34.8145L34.694 22.1366H28.138L28.2454 21.5242Z" fill="#8C8C8C"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 2.9 KiB After Width: | Height: | Size: 2.9 KiB |
6
src/assets/svg/arrow-big-right.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M3 10.5C2.44772 10.5 2 10.9477 2 11.5C2 12.0523 2.44772 12.5 3 12.5V10.5ZM20.7071 12.2071C21.0976 11.8166 21.0976 11.1834 20.7071 10.7929L14.3431 4.42893C13.9526 4.03841 13.3195 4.03841 12.9289 4.42893C12.5384 4.81946 12.5384 5.45262 12.9289 5.84315L18.5858 11.5L12.9289 17.1569C12.5384 17.5474 12.5384 18.1805 12.9289 18.5711C13.3195 18.9616 13.9526 18.9616 14.3431 18.5711L20.7071 12.2071ZM3 12.5H20V10.5H3V12.5Z" stroke="none" />
|
<path d="M3 10.5C2.44772 10.5 2 10.9477 2 11.5C2 12.0523 2.44772 12.5 3 12.5V10.5ZM20.7071 12.2071C21.0976 11.8166 21.0976 11.1834 20.7071 10.7929L14.3431 4.42893C13.9526 4.03841 13.3195 4.03841 12.9289 4.42893C12.5384 4.81946 12.5384 5.45262 12.9289 5.84315L18.5858 11.5L12.9289 17.1569C12.5384 17.5474 12.5384 18.1805 12.9289 18.5711C13.3195 18.9616 13.9526 18.9616 14.3431 18.5711L20.7071 12.2071ZM3 12.5H20V10.5H3V12.5Z" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 510 B After Width: | Height: | Size: 513 B |
8
src/assets/svg/arrow-down.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 10.2001 16)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 10.2001 16)" stroke="none" />
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 12 17.8)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 12 17.8)" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 341 B After Width: | Height: | Size: 345 B |
8
src/assets/svg/arrow-left.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(-0.707107 0.707107 0.707107 0.707107 8.80005 10.2001)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(-0.707107 0.707107 0.707107 0.707107 8.80005 10.2001)" stroke="none" />
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 7 12)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 7 12)" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 341 B After Width: | Height: | Size: 345 B |
8
src/assets/svg/arrow-right.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect x="16" y="10.2001" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(45 16 10.2001)" stroke="none" />
|
<rect x="16" y="10.2001" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(45 16 10.2001)" stroke="none" />
|
||||||
<rect x="17.8" y="12" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(135 17.8 12)" stroke="none" />
|
<rect x="17.8" y="12" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(135 17.8 12)" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 307 B After Width: | Height: | Size: 311 B |
8
src/assets/svg/arrow-up.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect x="10.2001" y="8.79999" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(-45 10.2001 8.79999)" stroke="none" />
|
<rect x="10.2001" y="8.79999" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(-45 10.2001 8.79999)" stroke="none" />
|
||||||
<rect x="12" y="7" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(45 12 7)" stroke="none" />
|
<rect x="12" y="7" width="2.54558" height="12.7279" rx="1.27279" transform="rotate(45 12 7)" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 311 B After Width: | Height: | Size: 315 B |
14
src/assets/svg/background.svg
Normal file → Executable file
@ -1,7 +1,7 @@
|
|||||||
<svg width="1187" height="1234" viewBox="0 0 1187 1234" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg width="1187" height="1234" viewBox="0 0 1187 1234" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M408.998 745.256C206.829 467.159 -0.745132 678.488 53.4493 872.858C189.728 1182.79 541.828 1319.16 839.898 1177.41C942.643 1128.57 1029.84 1050.24 1091.25 951.643C934.96 1103.83 651.196 1078.4 408.998 745.208V745.256Z" fill="#F0F0F0"/>
|
<path d="M408.998 745.256C206.829 467.159 -0.745132 678.488 53.4493 872.858C189.728 1182.79 541.828 1319.16 839.898 1177.41C942.643 1128.57 1029.84 1050.24 1091.25 951.643C934.96 1103.83 651.196 1078.4 408.998 745.208V745.256Z" fill="#F0F0F0"/>
|
||||||
<path d="M589.732 553.768C311.677 115.242 0.000483082 348.859 0.000483082 616.83C-0.108684 705.549 18.2856 793.237 53.9153 873.85C16.9159 692.296 217.547 552.363 404.339 812.896C675.684 1191.27 941.763 1124.69 1090.72 952.538C1138.53 876.188 1169.42 789.736 1181.14 699.443V700.63C1117.18 906.92 834.959 940.474 589.732 553.768Z" fill="#F5F5F5"/>
|
<path d="M589.732 553.768C311.677 115.242 0.000483082 348.859 0.000483082 616.83C-0.108684 705.549 18.2856 793.237 53.9153 873.85C16.9159 692.296 217.547 552.363 404.339 812.896C675.684 1191.27 941.763 1124.69 1090.72 952.538C1138.53 876.188 1169.42 789.736 1181.14 699.443V700.63C1117.18 906.92 834.959 940.474 589.732 553.768Z" fill="#F5F5F5"/>
|
||||||
<path d="M780.298 357.556C573.819 3.33809 311.98 35.3415 134.904 225.06C47.4877 335.363 -0.21692 473.901 0.000741558 616.829C18.6403 357.604 320.112 177.116 593.041 616.829C835.635 1008.16 1137.87 906.216 1180.86 701.744V699.781C1184.64 671.939 1186.24 643.826 1185.66 615.715V587.685C1080.6 665.864 942.439 635.678 780.252 357.532L780.298 357.556Z" fill="#FAFAFA"/>
|
<path d="M780.298 357.556C573.819 3.33809 311.98 35.3415 134.904 225.06C47.4877 335.363 -0.21692 473.901 0.000741558 616.829C18.6403 357.604 320.112 177.116 593.041 616.829C835.635 1008.16 1137.87 906.216 1180.86 701.744V699.781C1184.64 671.939 1186.24 643.826 1185.66 615.715V587.685C1080.6 665.864 942.439 635.678 780.252 357.532L780.298 357.556Z" fill="#FAFAFA"/>
|
||||||
<path d="M781.72 420.618C970.818 736.727 1133.84 655.859 1186.06 588.242C1183.96 540.989 1176.61 494.146 1164.16 448.648C1076.01 450.611 1055.46 435.275 968.721 297.983C836.17 86.7264 669.183 -55.8716 377.451 42.2463C282.888 80.7758 199.359 143.787 134.788 225.303C335.256 33.4762 581.228 85.5393 781.72 420.618Z" fill="white"/>
|
<path d="M781.72 420.618C970.818 736.727 1133.84 655.859 1186.06 588.242C1183.96 540.989 1176.61 494.146 1164.16 448.648C1076.01 450.611 1055.46 435.275 968.721 297.983C836.17 86.7264 669.183 -55.8716 377.451 42.2463C282.888 80.7758 199.359 143.787 134.788 225.303C335.256 33.4762 581.228 85.5393 781.72 420.618Z" fill="white"/>
|
||||||
<path d="M955.787 325.116C1042.25 462.675 1094.88 469.676 1164.15 448.672C1074.33 120.595 745.743 -69.6327 430.245 23.761C412.352 29.0424 394.753 35.204 377.449 42.2459C638.053 -43.2499 822.887 113.86 955.787 325.116Z" fill="white"/>
|
<path d="M955.787 325.116C1042.25 462.675 1094.88 469.676 1164.15 448.672C1074.33 120.595 745.743 -69.6327 430.245 23.761C412.352 29.0424 394.753 35.204 377.449 42.2459C638.053 -43.2499 822.887 113.86 955.787 325.116Z" fill="white"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 1.6 KiB After Width: | Height: | Size: 1.6 KiB |
10
src/assets/svg/bell-notification.svg
Normal file → Executable file
@ -1,5 +1,5 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M18 8C18 6.4087 17.3679 4.88258 16.2426 3.75736C15.1174 2.63214 13.5913 2 12 2C10.4087 2 8.88258 2.63214 7.75736 3.75736C6.63214 4.88258 6 6.4087 6 8C6 15 3 17 3 17H21C21 17 18 15 18 8Z" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path d="M18 8C18 6.4087 17.3679 4.88258 16.2426 3.75736C15.1174 2.63214 13.5913 2 12 2C10.4087 2 8.88258 2.63214 7.75736 3.75736C6.63214 4.88258 6 6.4087 6 8C6 15 3 17 3 17H21C21 17 18 15 18 8Z" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<path d="M13.73 21C13.5542 21.3031 13.3018 21.5547 12.9982 21.7295C12.6946 21.9044 12.3504 21.9965 12 21.9965C11.6496 21.9965 11.3054 21.9044 11.0018 21.7295C10.6981 21.5547 10.4458 21.3031 10.27 21" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path d="M13.73 21C13.5542 21.3031 13.3018 21.5547 12.9982 21.7295C12.6946 21.9044 12.3504 21.9965 12 21.9965C11.6496 21.9965 11.3054 21.9044 11.0018 21.7295C10.6981 21.5547 10.4458 21.3031 10.27 21" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<rect x="13" y="1" width="10" height="10" rx="5" stroke="white" fill="#FF4D4F" stroke-width="2"/>
|
<rect x="13" y="1" width="10" height="10" rx="5" stroke="white" fill="#FF4D4F" stroke-width="2"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 730 B After Width: | Height: | Size: 735 B |
8
src/assets/svg/bell.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M18 8C18 6.4087 17.3679 4.88258 16.2426 3.75736C15.1174 2.63214 13.5913 2 12 2C10.4087 2 8.88258 2.63214 7.75736 3.75736C6.63214 4.88258 6 6.4087 6 8C6 15 3 17 3 17H21C21 17 18 15 18 8Z" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path d="M18 8C18 6.4087 17.3679 4.88258 16.2426 3.75736C15.1174 2.63214 13.5913 2 12 2C10.4087 2 8.88258 2.63214 7.75736 3.75736C6.63214 4.88258 6 6.4087 6 8C6 15 3 17 3 17H21C21 17 18 15 18 8Z" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<path d="M13.73 21C13.5542 21.3031 13.3018 21.5547 12.9982 21.7295C12.6946 21.9044 12.3504 21.9965 12 21.9965C11.6496 21.9965 11.3054 21.9044 11.0018 21.7295C10.6981 21.5547 10.4458 21.3031 10.27 21" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path d="M13.73 21C13.5542 21.3031 13.3018 21.5547 12.9982 21.7295C12.6946 21.9044 12.3504 21.9965 12 21.9965C11.6496 21.9965 11.3054 21.9044 11.0018 21.7295C10.6981 21.5547 10.4458 21.3031 10.27 21" fill="none" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 633 B After Width: | Height: | Size: 637 B |
6
src/assets/svg/bookmark-filled.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M6 21.3242V4C6 3.44772 6.44772 3 7 3H17C17.5523 3 18 3.44771 18 4V21.3242C18 21.5563 17.7112 21.6631 17.5602 21.4869L12.7593 15.8858C12.3602 15.4202 11.6398 15.4202 11.2407 15.8858L6.43981 21.4869C6.28876 21.6631 6 21.5563 6 21.3242Z" stroke-width="2" />
|
<path d="M6 21.3242V4C6 3.44772 6.44772 3 7 3H17C17.5523 3 18 3.44771 18 4V21.3242C18 21.5563 17.7112 21.6631 17.5602 21.4869L12.7593 15.8858C12.3602 15.4202 11.6398 15.4202 11.2407 15.8858L6.43981 21.4869C6.28876 21.6631 6 21.5563 6 21.3242Z" stroke-width="2" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 344 B After Width: | Height: | Size: 347 B |
6
src/assets/svg/bookmark-outlined.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M6 21.3242V4C6 3.44772 6.44772 3 7 3H17C17.5523 3 18 3.44771 18 4V21.3242C18 21.5563 17.7112 21.6631 17.5602 21.4869L12.7593 15.8858C12.3602 15.4202 11.6398 15.4202 11.2407 15.8858L6.43981 21.4869C6.28876 21.6631 6 21.5563 6 21.3242Z" stroke-width="2" fill="none" />
|
<path d="M6 21.3242V4C6 3.44772 6.44772 3 7 3H17C17.5523 3 18 3.44771 18 4V21.3242C18 21.5563 17.7112 21.6631 17.5602 21.4869L12.7593 15.8858C12.3602 15.4202 11.6398 15.4202 11.2407 15.8858L6.43981 21.4869C6.28876 21.6631 6 21.5563 6 21.3242Z" stroke-width="2" fill="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 356 B After Width: | Height: | Size: 359 B |
6
src/assets/svg/caret-down.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M13.1315 4.6875H2.86897C2.56116 4.6875 2.38929 5.0125 2.57991 5.23438L7.71116 11.1844C7.85804 11.3547 8.14085 11.3547 8.28929 11.1844L13.4205 5.23438C13.6112 5.0125 13.4393 4.6875 13.1315 4.6875Z" stroke="none" />
|
<path d="M13.1315 4.6875H2.86897C2.56116 4.6875 2.38929 5.0125 2.57991 5.23438L7.71116 11.1844C7.85804 11.3547 8.14085 11.3547 8.28929 11.1844L13.4205 5.23438C13.6112 5.0125 13.4393 4.6875 13.1315 4.6875Z" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 303 B After Width: | Height: | Size: 306 B |
6
src/assets/svg/caret-left.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M11.3125 13.131L11.3125 2.86855C11.3125 2.56073 10.9875 2.38886 10.7657 2.57948L4.81566 7.71073C4.64534 7.85761 4.64534 8.14042 4.81566 8.28886L10.7657 13.4201C10.9875 13.6107 11.3125 13.4389 11.3125 13.131Z" stroke="none" />
|
<path d="M11.3125 13.131L11.3125 2.86855C11.3125 2.56073 10.9875 2.38886 10.7657 2.57948L4.81566 7.71073C4.64534 7.85761 4.64534 8.14042 4.81566 8.28886L10.7657 13.4201C10.9875 13.6107 11.3125 13.4389 11.3125 13.131Z" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 315 B After Width: | Height: | Size: 318 B |
6
src/assets/svg/caret-right.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M4.68793 2.86853L4.68793 13.131C4.68793 13.4388 5.01293 13.6107 5.2348 13.4201L11.1848 8.28884C11.3551 8.14196 11.3551 7.85915 11.1848 7.71071L5.2348 2.57946C5.01293 2.38884 4.68793 2.56071 4.68793 2.86853Z" stroke="none" />
|
<path d="M4.68793 2.86853L4.68793 13.131C4.68793 13.4388 5.01293 13.6107 5.2348 13.4201L11.1848 8.28884C11.3551 8.14196 11.3551 7.85915 11.1848 7.71071L5.2348 2.57946C5.01293 2.38884 4.68793 2.56071 4.68793 2.86853Z" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 314 B After Width: | Height: | Size: 317 B |
6
src/assets/svg/caret-up.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M13.1315 11.3121H2.86897C2.56116 11.3121 2.38929 10.9871 2.57991 10.7653L7.71116 4.81526C7.85804 4.64495 8.14085 4.64495 8.28929 4.81526L13.4205 10.7653C13.6112 10.9871 13.4393 11.3121 13.1315 11.3121Z" stroke="none" />
|
<path d="M13.1315 11.3121H2.86897C2.56116 11.3121 2.38929 10.9871 2.57991 10.7653L7.71116 4.81526C7.85804 4.64495 8.14085 4.64495 8.28929 4.81526L13.4205 10.7653C13.6112 10.9871 13.4393 11.3121 13.1315 11.3121Z" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 309 B After Width: | Height: | Size: 312 B |
12
src/assets/svg/chart.svg
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect x="5" y="12" width="2" height="8" rx="1" stroke="none" />
|
<rect x="5" y="12" width="2" height="8" rx="1" stroke="none" />
|
||||||
<rect x="9" y="6" width="2" height="14" rx="1" stroke="none" />
|
<rect x="9" y="6" width="2" height="14" rx="1" stroke="none" />
|
||||||
<rect x="13" y="8" width="2" height="12" rx="1" stroke="none" />
|
<rect x="13" y="8" width="2" height="12" rx="1" stroke="none" />
|
||||||
<rect x="17" y="4" width="2" height="16" rx="1" stroke="none" />
|
<rect x="17" y="4" width="2" height="16" rx="1" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 339 B After Width: | Height: | Size: 345 B |
12
src/assets/svg/chevrones-left.svg
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(-0.707107 0.707107 0.707107 0.707107 12.8 10.2001)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(-0.707107 0.707107 0.707107 0.707107 12.8 10.2001)" stroke="none" />
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 11 12)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 11 12)" stroke="none" />
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(-0.707107 0.707107 0.707107 0.707107 3.79999 10.2001)" stroke="none"/>
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(-0.707107 0.707107 0.707107 0.707107 3.79999 10.2001)" stroke="none"/>
|
||||||
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 2 12)" stroke="none" />
|
<rect width="2.54558" height="12.7279" rx="1.27279" transform="matrix(0.707107 0.707107 0.707107 -0.707107 2 12)" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 639 B After Width: | Height: | Size: 645 B |
12
src/assets/svg/chevrones-right.svg
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect width="2" height="10" rx="1" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 13.8284 9.41425)" stroke="none" />
|
<rect width="2" height="10" rx="1" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 13.8284 9.41425)" stroke="none" />
|
||||||
<rect width="2" height="10" rx="1" transform="matrix(-0.707107 -0.707107 -0.707107 0.707107 15.2426 8.00006)" stroke="none" />
|
<rect width="2" height="10" rx="1" transform="matrix(-0.707107 -0.707107 -0.707107 0.707107 15.2426 8.00006)" stroke="none" />
|
||||||
<rect width="2" height="10" rx="1" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 7.82843 9.41425)" stroke="none" />
|
<rect width="2" height="10" rx="1" transform="matrix(0.707107 -0.707107 -0.707107 -0.707107 7.82843 9.41425)" stroke="none" />
|
||||||
<rect width="2" height="10" rx="1" transform="matrix(-0.707107 -0.707107 -0.707107 0.707107 9.24265 8.00006)" stroke="none" />
|
<rect width="2" height="10" rx="1" transform="matrix(-0.707107 -0.707107 -0.707107 0.707107 9.24265 8.00006)" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 588 B After Width: | Height: | Size: 594 B |
6
src/assets/svg/circle.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<rect x="3" y="3" width="18" height="18" rx="9" stroke="none" />
|
<rect x="3" y="3" width="18" height="18" rx="9" stroke="none" />
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 145 B After Width: | Height: | Size: 148 B |
18
src/assets/svg/cite.svg
Normal file → Executable file
@ -1,9 +1,9 @@
|
|||||||
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
<svg fill="none" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M19 12V4C19 2.89543 18.1046 2 17 2H5C3.89543 2 3 2.89543 3 4V20C3 21.1046 3.89543 22 5 22H8" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M19 12V4C19 2.89543 18.1046 2 17 2H5C3.89543 2 3 2.89543 3 4V20C3 21.1046 3.89543 22 5 22H8" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path fill="none" d="M7 6H15" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M7 6H15" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path fill="none" d="M7 10H11" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M7 10H11" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M11.5 19.5H15C15.2761 19.5 15.5 19.7239 15.5 20V22C15.5 22.2761 15.2761 22.5 15 22.5H12C11.7239 22.5 11.5 22.2761 11.5 22V19.5Z"/>
|
<path d="M11.5 19.5H15C15.2761 19.5 15.5 19.7239 15.5 20V22C15.5 22.2761 15.2761 22.5 15 22.5H12C11.7239 22.5 11.5 22.2761 11.5 22V19.5Z"/>
|
||||||
<path fill="none" d="M12 20V18C12 16.8954 12.8954 16 14 16L15 16" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M12 20V18C12 16.8954 12.8954 16 14 16L15 16" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M17.5 19.5H21C21.2761 19.5 21.5 19.7239 21.5 20V22C21.5 22.2761 21.2761 22.5 21 22.5H18C17.7239 22.5 17.5 22.2761 17.5 22V19.5Z"/>
|
<path d="M17.5 19.5H21C21.2761 19.5 21.5 19.7239 21.5 20V22C21.5 22.2761 21.2761 22.5 21 22.5H18C17.7239 22.5 17.5 22.2761 17.5 22V19.5Z"/>
|
||||||
<path fill="none" d="M18 20V18C18 16.8954 18.8954 16 20 16L21 16" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M18 20V18C18 16.8954 18.8954 16 20 16L21 16" stroke-width="2" stroke-linecap="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 906 B After Width: | Height: | Size: 915 B |
8
src/assets/svg/copy.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M17 8V20C17 21.1046 16.1046 22 15 22H10H5C3.89543 22 3 21.1046 3 20V8C3 6.89543 3.89543 6 5 6H15C16.1046 6 17 6.89543 17 8Z" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M17 8V20C17 21.1046 16.1046 22 15 22H10H5C3.89543 22 3 21.1046 3 20V8C3 6.89543 3.89543 6 5 6H15C16.1046 6 17 6.89543 17 8Z" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M7 6V4C7 2.89543 7.89543 2 9 2H19C20.1046 2 21 2.89543 21 4V17C21 18.1046 20.1046 19 19 19H17" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M7 6V4C7 2.89543 7.89543 2 9 2H19C20.1046 2 21 2.89543 21 4V17C21 18.1046 20.1046 19 19 19H17" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 426 B After Width: | Height: | Size: 430 B |
10
src/assets/svg/delete.svg
Normal file → Executable file
@ -1,5 +1,5 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M17.0689 21H6.93112C6.40648 21 5.97104 20.5946 5.93366 20.0712L5.07652 8.07125C5.03517 7.49238 5.49363 7 6.07398 7H17.926C18.5064 7 18.9648 7.49238 18.9235 8.07125L18.0663 20.0712C18.029 20.5946 17.5935 21 17.0689 21Z" stroke-width="2"/>
|
<path fill="none" d="M17.0689 21H6.93112C6.40648 21 5.97104 20.5946 5.93366 20.0712L5.07652 8.07125C5.03517 7.49238 5.49363 7 6.07398 7H17.926C18.5064 7 18.9648 7.49238 18.9235 8.07125L18.0663 20.0712C18.029 20.5946 17.5935 21 17.0689 21Z" stroke-width="2"/>
|
||||||
<path fill="none" d="M3 7H21" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M3 7H21" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path fill="none" d="M7 7V4C7 3.44772 7.44772 3 8 3H16C16.5523 3 17 3.44772 17 4V7" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M7 7V4C7 3.44772 7.44772 3 8 3H16C16.5523 3 17 3.44772 17 4V7" stroke-width="2" stroke-linecap="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 537 B After Width: | Height: | Size: 542 B |
10
src/assets/svg/download.svg
Normal file → Executable file
@ -1,5 +1,5 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M4 12V18C4 19.1046 4.89543 20 6 20H18C19.1046 20 20 19.1046 20 18V12" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M4 12V18C4 19.1046 4.89543 20 6 20H18C19.1046 20 20 19.1046 20 18V12" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path fill="none" d="M12 4L12 13" stroke-width="2" stroke-linecap="round"/>
|
<path fill="none" d="M12 4L12 13" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M8.36682 12.6402C7.82405 11.9889 8.2872 11 9.13504 11H14.865C15.7128 11 16.176 11.9889 15.6332 12.6402L12.7682 16.0781C12.3684 16.5579 11.6316 16.5579 11.2318 16.0781L8.36682 12.6402Z"/>
|
<path d="M8.36682 12.6402C7.82405 11.9889 8.2872 11 9.13504 11H14.865C15.7128 11 16.176 11.9889 15.6332 12.6402L12.7682 16.0781C12.3684 16.5579 11.6316 16.5579 11.2318 16.0781L8.36682 12.6402Z"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 485 B After Width: | Height: | Size: 490 B |
12
src/assets/svg/duplicate.svg
Normal file → Executable file
@ -1,6 +1,6 @@
|
|||||||
<svg viewBox="0 0 24 25" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 25" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M8 20.5V8.5C8 7.39543 8.89543 6.5 10 6.5H15.5H18C19.1046 6.5 20 7.39543 20 8.5L20 11.3V20.5C20 21.6046 19.1046 22.5 18 22.5H10C8.89543 22.5 8 21.6046 8 20.5Z" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M8 20.5V8.5C8 7.39543 8.89543 6.5 10 6.5H15.5H18C19.1046 6.5 20 7.39543 20 8.5L20 11.3V20.5C20 21.6046 19.1046 22.5 18 22.5H10C8.89543 22.5 8 21.6046 8 20.5Z" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M11 14.5H17" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M11 14.5H17" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M11 18.5H17" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M11 18.5H17" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M16 6.3L16 4.50001C16 3.39543 15.1046 2.5 14 2.5H11.5H6C4.89543 2.5 4 3.39543 4 4.5V16.5C4 17.6046 4.89543 18.5 6 18.5H8" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M16 6.3L16 4.50001C16 3.39543 15.1046 2.5 14 2.5H11.5H6C4.89543 2.5 4 3.39543 4 4.5V16.5C4 17.6046 4.89543 18.5 6 18.5H8" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 639 B After Width: | Height: | Size: 645 B |
6
src/assets/svg/edit1.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M5 15L3.5 16.5L2 22L7.5 20.5L9 19M5 15L17 3C17.2626 2.73735 17.5744 2.52901 17.9176 2.38687C18.2608 2.24473 18.6286 2.17157 19 2.17157C19.3714 2.17157 19.7392 2.24473 20.0824 2.38687C20.4256 2.52901 20.7374 2.73735 21 3C21.2626 3.26264 21.471 3.57444 21.6131 3.9176C21.7553 4.26077 21.8284 4.62856 21.8284 5C21.8284 5.37143 21.7553 5.73923 21.6131 6.08239C21.471 6.42555 21.2626 6.73735 21 7L9 19M5 15L9 19" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M5 15L3.5 16.5L2 22L7.5 20.5L9 19M5 15L17 3C17.2626 2.73735 17.5744 2.52901 17.9176 2.38687C18.2608 2.24473 18.6286 2.17157 19 2.17157C19.3714 2.17157 19.7392 2.24473 20.0824 2.38687C20.4256 2.52901 20.7374 2.73735 21 3C21.2626 3.26264 21.471 3.57444 21.6131 3.9176C21.7553 4.26077 21.8284 4.62856 21.8284 5C21.8284 5.37143 21.7553 5.73923 21.6131 6.08239C21.471 6.42555 21.2626 6.73735 21 7L9 19M5 15L9 19" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 575 B After Width: | Height: | Size: 578 B |
8
src/assets/svg/edit2.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M11 4H4C3.46957 4 2.96086 4.21071 2.58579 4.58579C2.21071 4.96086 2 5.46957 2 6V19C2 19.5304 2.21071 20.0391 2.58579 20.4142C2.96086 20.7893 3.46957 21 4 21H18C18.5304 21 19.0391 20.7893 19.4142 20.4142C19.7893 20.0391 20 19.5304 20 19V13" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M11 4H4C3.46957 4 2.96086 4.21071 2.58579 4.58579C2.21071 4.96086 2 5.46957 2 6V19C2 19.5304 2.21071 20.0391 2.58579 20.4142C2.96086 20.7893 3.46957 21 4 21H18C18.5304 21 19.0391 20.7893 19.4142 20.4142C19.7893 20.0391 20 19.5304 20 19V13" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<path fill="none" d="M18.5 2.49998C18.8978 2.10216 19.4374 1.87866 20 1.87866C20.5626 1.87866 21.1022 2.10216 21.5 2.49998C21.8978 2.89781 22.1213 3.43737 22.1213 3.99998C22.1213 4.56259 21.8978 5.10216 21.5 5.49998L12 15L8 16L9 12L18.5 2.49998Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M18.5 2.49998C18.8978 2.10216 19.4374 1.87866 20 1.87866C20.5626 1.87866 21.1022 2.10216 21.5 2.49998C21.8978 2.89781 22.1213 3.43737 22.1213 3.99998C22.1213 4.56259 21.8978 5.10216 21.5 5.49998L12 15L8 16L9 12L18.5 2.49998Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 721 B After Width: | Height: | Size: 725 B |
10
src/assets/svg/error.svg
Normal file → Executable file
@ -1,5 +1,5 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M12 22C17.5228 22 22 17.5228 22 12C22 6.47715 17.5228 2 12 2C6.47715 2 2 6.47715 2 12C2 17.5228 6.47715 22 12 22Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<path fill="none" d="M12 8V12" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M12 8V12" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<path fill="none" d="M12 16H12.01" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M12 16H12.01" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 480 B After Width: | Height: | Size: 485 B |
8
src/assets/svg/eye.svg
Normal file → Executable file
@ -1,4 +1,4 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M1 12C1 12 5 4 12 4C19 4 23 12 23 12C23 12 19 20 12 20C5 20 1 12 1 12Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M1 12C1 12 5 4 12 4C19 4 23 12 23 12C23 12 19 20 12 20C5 20 1 12 1 12Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
<path fill="none" d="M12 15C13.6569 15 15 13.6569 15 12C15 10.3431 13.6569 9 12 9C10.3431 9 9 10.3431 9 12C9 13.6569 10.3431 15 12 15Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
<path fill="none" d="M12 15C13.6569 15 15 13.6569 15 12C15 10.3431 13.6569 9 12 9C10.3431 9 9 10.3431 9 12C9 13.6569 10.3431 15 12 15Z" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 441 B After Width: | Height: | Size: 445 B |
6
src/assets/svg/facebook.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M21.8576 1.28333H2.14328C1.66917 1.28333 1.28613 1.66636 1.28613 2.14047V21.8548C1.28613 22.3289 1.66917 22.7119 2.14328 22.7119H21.8576C22.3317 22.7119 22.7147 22.3289 22.7147 21.8548V2.14047C22.7147 1.66636 22.3317 1.28333 21.8576 1.28333ZM21.0004 20.9976H16.0692V14.4137H18.8549L19.2727 11.1806H16.0692V9.11547C16.0692 8.17797 16.329 7.54047 17.671 7.54047H19.3826V4.64761C19.0852 4.60743 18.0701 4.51904 16.8861 4.51904C14.4165 4.51904 12.7263 6.02708 12.7263 8.79404V11.178H9.93524V14.411H12.729V20.9976H3.00042V2.99761H21.0004V20.9976Z" stroke="none"/>
|
<path d="M21.8576 1.28333H2.14328C1.66917 1.28333 1.28613 1.66636 1.28613 2.14047V21.8548C1.28613 22.3289 1.66917 22.7119 2.14328 22.7119H21.8576C22.3317 22.7119 22.7147 22.3289 22.7147 21.8548V2.14047C22.7147 1.66636 22.3317 1.28333 21.8576 1.28333ZM21.0004 20.9976H16.0692V14.4137H18.8549L19.2727 11.1806H16.0692V9.11547C16.0692 8.17797 16.329 7.54047 17.671 7.54047H19.3826V4.64761C19.0852 4.60743 18.0701 4.51904 16.8861 4.51904C14.4165 4.51904 12.7263 6.02708 12.7263 8.79404V11.178H9.93524V14.411H12.729V20.9976H3.00042V2.99761H21.0004V20.9976Z" stroke="none"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 648 B After Width: | Height: | Size: 651 B |
6
src/assets/svg/favorite-filled.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M12 3L14.9048 9.50932L22 10.2574L16.7 15.0284L18.1803 22L12 18.4393L5.81966 22L7.3 15.0284L2 10.2574L9.09524 9.50932L12 3Z" stroke-width="2" stroke-linejoin="round"/>
|
<path d="M12 3L14.9048 9.50932L22 10.2574L16.7 15.0284L18.1803 22L12 18.4393L5.81966 22L7.3 15.0284L2 10.2574L9.09524 9.50932L12 3Z" stroke-width="2" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 256 B After Width: | Height: | Size: 259 B |
6
src/assets/svg/favorite-outlined.svg
Normal file → Executable file
@ -1,3 +1,3 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" stroke="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" stroke="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path fill="none" d="M12 3L14.9048 9.50932L22 10.2574L16.7 15.0284L18.1803 22L12 18.4393L5.81966 22L7.3 15.0284L2 10.2574L9.09524 9.50932L12 3Z" stroke-width="2" stroke-linejoin="round"/>
|
<path fill="none" d="M12 3L14.9048 9.50932L22 10.2574L16.7 15.0284L18.1803 22L12 18.4393L5.81966 22L7.3 15.0284L2 10.2574L9.09524 9.50932L12 3Z" stroke-width="2" stroke-linejoin="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 282 B After Width: | Height: | Size: 285 B |
10
src/assets/svg/file.svg
Normal file → Executable file
@ -1,5 +1,5 @@
|
|||||||
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
<svg viewBox="0 0 24 24" fill="none" xmlns="http://www.w3.org/2000/svg">
|
||||||
<path d="M4 20V4C4 2.89543 4.89543 2 6 2H13.1716C13.702 2 14.2107 2.21071 14.5858 2.58579L19.4142 7.41421C19.7893 7.78929 20 8.29799 20 8.82843V20C20 21.1046 19.1046 22 18 22H6C4.89543 22 4 21.1046 4 20Z" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M4 20V4C4 2.89543 4.89543 2 6 2H13.1716C13.702 2 14.2107 2.21071 14.5858 2.58579L19.4142 7.41421C19.7893 7.78929 20 8.29799 20 8.82843V20C20 21.1046 19.1046 22 18 22H6C4.89543 22 4 21.1046 4 20Z" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M14 8L19 8" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M14 8L19 8" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
<path d="M14 3V8" fill="none" stroke-width="2" stroke-linecap="round"/>
|
<path d="M14 3V8" fill="none" stroke-width="2" stroke-linecap="round"/>
|
||||||
</svg>
|
</svg>
|
||||||
|
Before Width: | Height: | Size: 486 B After Width: | Height: | Size: 491 B |