From f9049b225b381c0cb89afff717225cae14403f05 Mon Sep 17 00:00:00 2001 From: CodedThemes <77041536+phoenixcoded20@users.noreply.github.com> Date: Sat, 10 Feb 2024 15:05:33 +0530 Subject: [PATCH] Upgrade to React 18 (#15) * React 18 (#14) * react 18 upgrade complete * unUse content remove * bug fix * update readme file * update banner image * buy now link set and add license file * Update prod.yml * Update README.md --------- Co-authored-by: Dikshit Moradiya <106728438+ct-dixit@users.noreply.github.com> --- .env | 5 + .env.development | 5 + .env.qa | 5 + .eslintrc | 96 + .github/workflows/prod.yml | 16 +- template/.gitignore => .gitignore | 0 template/.prettierignore => .prettierignore | 2 - .prettierrc | 8 + LICENSE | 21 + README.md | 201 +- package.json | 81 + {template/public => public}/favicon.ico | Bin public/index.html | 47 + {template/public => public}/robots.txt | 0 src/App.js | 16 + src/assets/images/logo-dark.png | Bin 0 -> 5561 bytes src/assets/images/logo.png | Bin 0 -> 5561 bytes src/assets/images/sidebar.png | Bin 0 -> 17390 bytes .../assets/images/user/avatar-1.jpg | Bin .../assets/images/user/avatar-2.jpg | Bin .../assets/images/user/avatar-3.jpg | Bin .../assets/images/user/avatar-4.jpg | Bin .../assets/images/user/avatar-5.jpg | Bin .../assets/scss/partials/_general.scss | 169 +- .../assets/scss/partials/_generic.scss | 0 .../assets/scss/partials/_variables.scss | 11 +- .../scss/partials/font/_cryptofont.scss | 0 .../scss/partials/font/_datta-icon.scss | 0 .../assets/scss/partials/font/_feather.scss | 0 .../assets/scss/partials/font/_flaticon.scss | 0 .../scss/partials/font/_fontawesome.scss | 0 .../assets/scss/partials/font/_next-icon.scss | 0 .../scss/partials/font/_theme-font.scss | 0 .../scss/partials/font/fonts/Flaticon.eot | Bin .../scss/partials/font/fonts/Flaticon.svg | 0 .../scss/partials/font/fonts/Flaticon.ttf | Bin .../scss/partials/font/fonts/Flaticon.woff | Bin .../scss/partials/font/fonts/Flaticon.woff2 | Bin .../scss/partials/font/fonts/cryptocoins.ttf | Bin .../scss/partials/font/fonts/cryptocoins.woff | Bin .../partials/font/fonts/cryptocoins.woff2 | Bin .../partials/font/fonts/fa-brands-400.eot | Bin .../partials/font/fonts/fa-brands-400.svg | 0 .../partials/font/fonts/fa-brands-400.ttf | Bin .../partials/font/fonts/fa-brands-400.woff | Bin .../partials/font/fonts/fa-brands-400.woff2 | Bin .../partials/font/fonts/fa-regular-400.eot | Bin .../partials/font/fonts/fa-regular-400.svg | 0 .../partials/font/fonts/fa-regular-400.ttf | Bin .../partials/font/fonts/fa-regular-400.woff | Bin .../partials/font/fonts/fa-regular-400.woff2 | Bin .../scss/partials/font/fonts/fa-solid-900.eot | Bin .../scss/partials/font/fonts/fa-solid-900.svg | 0 .../scss/partials/font/fonts/fa-solid-900.ttf | Bin .../partials/font/fonts/fa-solid-900.woff | Bin .../partials/font/fonts/fa-solid-900.woff2 | Bin .../scss/partials/font/fonts/feather.eot | Bin .../scss/partials/font/fonts/feather.svg | 0 .../scss/partials/font/fonts/feather.ttf | Bin .../scss/partials/font/fonts/feather.woff | Bin .../assets/scss/partials/font/fonts/pct.eot | Bin .../assets/scss/partials/font/fonts/pct.svg | 0 .../assets/scss/partials/font/fonts/pct.ttf | Bin .../assets/scss/partials/font/fonts/pct.woff | Bin .../pxiByp8kv8JHgFVrLEj6Z11lFc-K.woff2 | Bin .../pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2 | Bin .../poppins/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2 | Bin .../pxiByp8kv8JHgFVrLGT9Z11lFc-K.woff2 | Bin .../pxiByp8kv8JHgFVrLGT9Z1JlFc-K.woff2 | Bin .../poppins/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 | Bin .../poppins/pxiEyp8kv8JHgFVrJJfecg.woff2 | Bin .../poppins/pxiEyp8kv8JHgFVrJJnecmNE.woff2 | Bin src/assets/scss/partials/menu/_menu-lite.scss | 1536 + .../assets/scss/partials/mixins/_buttons.scss | 0 .../scss/partials/mixins/_function.scss | 2 +- .../scss/partials/mixins/_pagination.scss | 0 src/assets/scss/partials/other/_chart.scss | 8 + .../assets/scss/partials/other/_chat.scss | 60 +- .../theme-elements/_authentication.scss | 1 - .../_breadcrumb-pagination.scss | 3 - .../scss/partials/theme-elements/_button.scss | 0 .../partials/theme-elements/_data-tables.scss | 7 - .../scss/partials/theme-elements/_form.scss | 0 .../theme-elements/_labels-badges.scss | 0 .../scss/partials/theme-elements/_nav.scss | 0 .../partials/theme-elements/_progress.scss | 50 + .../theme-elements/_radiobox-checkbox.scss | 0 .../partials/third-party/_datatables.scss | 3 + .../partials/third-party/_google-map.scss | 0 .../third-party/_ngx-perfect-scrollbar.scss | 0 .../partials/third-party/_third-party.scss | 40 + .../third-party/react-bootstrap/_header.scss | 3 +- .../react-bootstrap/react-bootstrap.scss | 0 src/assets/scss/partials/widget/_widget.scss | 71 + {template/src => src}/assets/scss/style.scss | 4 +- .../src => src}/components/Card/MainCard.js | 11 +- .../src => src}/components/Loader/Bar.js | 6 + .../components/Loader/Container.js | 7 + .../src => src}/components/Loader/Loader.js | 0 .../src => src}/components/Loader/Progress.js | 7 + .../src => src}/components/Loader/Spinner.js | 0 .../components/Widgets/Statistic/IcoCard.js | 12 + .../Widgets/Statistic/Notification.js | 6 + .../Widgets/Statistic/NotificationCard.js | 9 + .../components/Widgets/Statistic/OrderCard.js | 11 + .../Widgets/Statistic/ProductCard.js | 11 + .../Widgets/Statistic/ProductOrderCard.js | 15 +- .../Widgets/Statistic/SocialCard.js | 12 + src/config/constant.js | 8 + src/contexts/ConfigContext.js | 103 + src/data/countryData.js | 253 + {template/src => src}/data/tableData.js | 9 +- .../src => src}/hooks/useOutsideClick.js | 0 {template/src => src}/hooks/useScriptRef.js | 0 {template/src => src}/hooks/useWindowSize.js | 0 {template/src => src}/index.js | 11 +- {template/src => src}/index.scss | 165 +- .../layouts/AdminLayout/Breadcrumb/index.js | 8 +- .../NavBar/NavLeft/NavSearch/index.js | 14 +- .../AdminLayout/NavBar/NavLeft/index.js | 12 +- .../ChatList/Friends/Chat/Messages/index.js | 25 +- .../NavRight/ChatList/Friends/Chat/chat.js | 0 .../NavRight/ChatList/Friends/Chat/index.js | 28 +- .../NavRight/ChatList/Friends/Friend/index.js | 33 +- .../NavRight/ChatList/Friends/friends.js | 0 .../NavBar/NavRight/ChatList/Friends/index.js | 5 + .../NavBar/NavRight/ChatList/index.js | 6 + .../AdminLayout/NavBar/NavRight/index.js | 130 +- .../layouts/AdminLayout/NavBar/index.js | 34 +- .../Navigation/NavContent/NavBadge/index.js | 8 + .../Navigation/NavContent/NavCard.js | 32 + .../NavContent/NavCollapse/index.js | 43 +- .../Navigation/NavContent/NavGroup/index.js | 9 + .../Navigation/NavContent/NavIcon/index.js | 6 + .../Navigation/NavContent/NavItem/index.js | 38 +- .../Navigation/NavContent/index.js | 39 + .../AdminLayout/Navigation/NavLogo/index.js | 0 src/layouts/AdminLayout/Navigation/index.js | 48 + .../src => src}/layouts/AdminLayout/index.js | 39 +- {template/src => src}/menu-items.js | 34 +- {template/src => src}/reportWebVitals.js | 0 src/routes.js | 132 + src/services/chat.js | 832 + src/services/index.js | 1 + src/store/accountReducer.js | 45 + {template/src => src}/store/actions.js | 1 + {template/src => src}/store/index.js | 0 {template/src => src}/store/reducers.js | 0 {template/src => src}/utils/axios.js | 0 {template/src => src}/utils/services.js | 0 .../auth/reset-password/ResetPassword1.js | 47 + .../views/auth/signin/FirebaseLogin.js | 48 +- .../src => src}/views/auth/signin/SignIn1.js | 16 +- .../src => src}/views/auth/signup/SignUp1.js | 6 +- .../nvd3-chart/chart/BarDiscreteChart.js | 0 .../charts/nvd3-chart/chart/LineChart.js | 0 .../charts/nvd3-chart/chart/MultiBarChart.js | 0 .../charts/nvd3-chart/chart/PieBasicChart.js | 0 .../charts/nvd3-chart/chart/PieDonutChart.js | 0 .../views/charts/nvd3-chart/index.js | 0 .../views/dashboard}/index.js | 321 +- src/views/extra/SamplePage.js | 25 + src/views/forms/FormsElements.js | 875 + .../src => src}/views/maps/GoogleMaps.js | 0 .../views/maps/google-maps/InfoBox.js | 0 .../views/maps/google-maps/Marker.js | 2 +- .../views/maps/google-maps/MarkerClusterer.js | 0 .../maps/google-maps/StreetViewPanorma.js | 0 .../maps/google-maps/fancy-map-styles.json | 0 src/views/tables/BootstrapTable.js | 559 + .../views/ui-elements/basic/BasicBadges.js | 38 +- .../ui-elements/basic/BasicBreadcrumb.js | 29 +- src/views/ui-elements/basic/BasicButton.js | 545 + .../views/ui-elements/basic/BasicCollapse.js | 6 +- .../ui-elements/basic/BasicPagination.js | 25 +- .../views/ui-elements/basic/BasicTabsPills.js | 77 +- .../ui-elements/basic/BasicTypography.js | 22 +- template/.prettierrc | 8 - template/README.md | 26 - template/package-lock.json | 40279 ---------------- template/package.json | 69 - template/public/index.html | 32 - template/src/App.js | 19 - .../src/assets/scss/partials/_mixins.scss | 0 .../assets/scss/partials/menu/_menu-lite.scss | 4304 -- .../assets/scss/partials/other/_chart.scss | 148 - .../partials/third-party/_datatables.scss | 108 - .../partials/third-party/_third-party.scss | 15 - .../assets/scss/partials/widget/_widget.scss | 1586 - template/src/config/constant.js | 36 - template/src/contexts/ConfigContext.js | 211 - template/src/contexts/FirebaseContext.js | 96 - template/src/data/userListData.js | 112 - template/src/firebase/lib.js | 10 - template/src/hooks/useAuth.js | 7 - .../AdminLayout/Configuration/Layout/index.js | 84 - .../Configuration/PreBuiltLayout/index.js | 53 - .../AdminLayout/Configuration/index.js | 64 - .../Navigation/NavContent/index.js | 120 - .../layouts/AdminLayout/Navigation/index.js | 158 - template/src/routes.js | 118 - template/src/store/accountReducer.js | 35 - template/src/views/extra/SamplePage.js | 25 - template/src/views/forms/FormsElements.js | 369 - template/src/views/tables/BootstrapTable.js | 135 - .../views/ui-elements/basic/BasicButton.js | 126 - template/yarn.lock | 13703 ------ yarn.lock | 10244 ++++ 208 files changed, 16764 insertions(+), 62906 deletions(-) create mode 100644 .env create mode 100644 .env.development create mode 100644 .env.qa create mode 100644 .eslintrc rename template/.gitignore => .gitignore (100%) rename template/.prettierignore => .prettierignore (95%) create mode 100644 .prettierrc create mode 100644 LICENSE create mode 100644 package.json rename {template/public => public}/favicon.ico (100%) create mode 100644 public/index.html rename {template/public => public}/robots.txt (100%) create mode 100644 src/App.js create mode 100644 src/assets/images/logo-dark.png create mode 100644 src/assets/images/logo.png create mode 100644 src/assets/images/sidebar.png rename {template/src => src}/assets/images/user/avatar-1.jpg (100%) rename {template/src => src}/assets/images/user/avatar-2.jpg (100%) rename {template/src => src}/assets/images/user/avatar-3.jpg (100%) rename {template/src => src}/assets/images/user/avatar-4.jpg (100%) rename {template/src => src}/assets/images/user/avatar-5.jpg (100%) rename {template/src => src}/assets/scss/partials/_general.scss (89%) rename {template/src => src}/assets/scss/partials/_generic.scss (100%) rename {template/src => src}/assets/scss/partials/_variables.scss (96%) rename {template/src => src}/assets/scss/partials/font/_cryptofont.scss (100%) rename {template/src => src}/assets/scss/partials/font/_datta-icon.scss (100%) rename {template/src => src}/assets/scss/partials/font/_feather.scss (100%) rename {template/src => src}/assets/scss/partials/font/_flaticon.scss (100%) rename {template/src => src}/assets/scss/partials/font/_fontawesome.scss (100%) rename {template/src => src}/assets/scss/partials/font/_next-icon.scss (100%) rename {template/src => src}/assets/scss/partials/font/_theme-font.scss (100%) rename {template/src => src}/assets/scss/partials/font/fonts/Flaticon.eot (100%) rename {template/src => src}/assets/scss/partials/font/fonts/Flaticon.svg (100%) rename {template/src => src}/assets/scss/partials/font/fonts/Flaticon.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/Flaticon.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/Flaticon.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/cryptocoins.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/cryptocoins.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/cryptocoins.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-brands-400.eot (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-brands-400.svg (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-brands-400.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-brands-400.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-brands-400.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-regular-400.eot (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-regular-400.svg (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-regular-400.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-regular-400.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-regular-400.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-solid-900.eot (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-solid-900.svg (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-solid-900.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-solid-900.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/fa-solid-900.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/feather.eot (100%) rename {template/src => src}/assets/scss/partials/font/fonts/feather.svg (100%) rename {template/src => src}/assets/scss/partials/font/fonts/feather.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/feather.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/pct.eot (100%) rename {template/src => src}/assets/scss/partials/font/fonts/pct.svg (100%) rename {template/src => src}/assets/scss/partials/font/fonts/pct.ttf (100%) rename {template/src => src}/assets/scss/partials/font/fonts/pct.woff (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z11lFc-K.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z11lFc-K.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1JlFc-K.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJfecg.woff2 (100%) rename {template/src => src}/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJnecmNE.woff2 (100%) create mode 100644 src/assets/scss/partials/menu/_menu-lite.scss rename {template/src => src}/assets/scss/partials/mixins/_buttons.scss (100%) rename {template/src => src}/assets/scss/partials/mixins/_function.scss (90%) rename {template/src => src}/assets/scss/partials/mixins/_pagination.scss (100%) create mode 100644 src/assets/scss/partials/other/_chart.scss rename {template/src => src}/assets/scss/partials/other/_chat.scss (87%) rename {template/src => src}/assets/scss/partials/theme-elements/_authentication.scss (97%) rename {template/src => src}/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss (89%) rename {template/src => src}/assets/scss/partials/theme-elements/_button.scss (100%) rename {template/src => src}/assets/scss/partials/theme-elements/_data-tables.scss (94%) rename {template/src => src}/assets/scss/partials/theme-elements/_form.scss (100%) rename {template/src => src}/assets/scss/partials/theme-elements/_labels-badges.scss (100%) rename {template/src => src}/assets/scss/partials/theme-elements/_nav.scss (100%) create mode 100644 src/assets/scss/partials/theme-elements/_progress.scss rename {template/src => src}/assets/scss/partials/theme-elements/_radiobox-checkbox.scss (100%) create mode 100644 src/assets/scss/partials/third-party/_datatables.scss rename {template/src => src}/assets/scss/partials/third-party/_google-map.scss (100%) rename {template/src => src}/assets/scss/partials/third-party/_ngx-perfect-scrollbar.scss (100%) create mode 100644 src/assets/scss/partials/third-party/_third-party.scss rename {template/src => src}/assets/scss/partials/third-party/react-bootstrap/_header.scss (90%) rename {template/src => src}/assets/scss/partials/third-party/react-bootstrap/react-bootstrap.scss (100%) create mode 100644 src/assets/scss/partials/widget/_widget.scss rename {template/src => src}/assets/scss/style.scss (95%) rename {template/src => src}/components/Card/MainCard.js (92%) rename {template/src => src}/components/Loader/Bar.js (85%) rename {template/src => src}/components/Loader/Container.js (67%) rename {template/src => src}/components/Loader/Loader.js (100%) rename {template/src => src}/components/Loader/Progress.js (75%) rename {template/src => src}/components/Loader/Spinner.js (100%) rename {template/src => src}/components/Widgets/Statistic/IcoCard.js (84%) rename {template/src => src}/components/Widgets/Statistic/Notification.js (76%) rename {template/src => src}/components/Widgets/Statistic/NotificationCard.js (76%) rename {template/src => src}/components/Widgets/Statistic/OrderCard.js (74%) rename {template/src => src}/components/Widgets/Statistic/ProductCard.js (78%) rename {template/src => src}/components/Widgets/Statistic/ProductOrderCard.js (90%) rename {template/src => src}/components/Widgets/Statistic/SocialCard.js (72%) create mode 100644 src/config/constant.js create mode 100644 src/contexts/ConfigContext.js create mode 100644 src/data/countryData.js rename {template/src => src}/data/tableData.js (80%) rename {template/src => src}/hooks/useOutsideClick.js (100%) rename {template/src => src}/hooks/useScriptRef.js (100%) rename {template/src => src}/hooks/useWindowSize.js (100%) rename {template/src => src}/index.js (70%) rename {template/src => src}/index.scss (59%) rename {template/src => src}/layouts/AdminLayout/Breadcrumb/index.js (92%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js (79%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavLeft/index.js (81%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js (58%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/chat.js (100%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js (73%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Friend/index.js (51%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/friends.js (100%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/index.js (90%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/ChatList/index.js (91%) rename {template/src => src}/layouts/AdminLayout/NavBar/NavRight/index.js (59%) rename {template/src => src}/layouts/AdminLayout/NavBar/index.js (63%) rename {template/src => src}/layouts/AdminLayout/Navigation/NavContent/NavBadge/index.js (67%) create mode 100644 src/layouts/AdminLayout/Navigation/NavContent/NavCard.js rename {template/src => src}/layouts/AdminLayout/Navigation/NavContent/NavCollapse/index.js (76%) rename {template/src => src}/layouts/AdminLayout/Navigation/NavContent/NavGroup/index.js (82%) rename {template/src => src}/layouts/AdminLayout/Navigation/NavContent/NavIcon/index.js (72%) rename {template/src => src}/layouts/AdminLayout/Navigation/NavContent/NavItem/index.js (65%) create mode 100644 src/layouts/AdminLayout/Navigation/NavContent/index.js rename {template/src => src}/layouts/AdminLayout/Navigation/NavLogo/index.js (100%) create mode 100644 src/layouts/AdminLayout/Navigation/index.js rename {template/src => src}/layouts/AdminLayout/index.js (78%) rename {template/src => src}/menu-items.js (90%) rename {template/src => src}/reportWebVitals.js (100%) create mode 100644 src/routes.js create mode 100644 src/services/chat.js create mode 100644 src/services/index.js create mode 100644 src/store/accountReducer.js rename {template/src => src}/store/actions.js (97%) rename {template/src => src}/store/index.js (100%) rename {template/src => src}/store/reducers.js (100%) rename {template/src => src}/utils/axios.js (100%) rename {template/src => src}/utils/services.js (100%) create mode 100644 src/views/auth/reset-password/ResetPassword1.js rename {template/src => src}/views/auth/signin/FirebaseLogin.js (66%) rename {template/src => src}/views/auth/signin/SignIn1.js (81%) rename {template/src => src}/views/auth/signup/SignUp1.js (87%) rename {template/src => src}/views/charts/nvd3-chart/chart/BarDiscreteChart.js (100%) rename {template/src => src}/views/charts/nvd3-chart/chart/LineChart.js (100%) rename {template/src => src}/views/charts/nvd3-chart/chart/MultiBarChart.js (100%) rename {template/src => src}/views/charts/nvd3-chart/chart/PieBasicChart.js (100%) rename {template/src => src}/views/charts/nvd3-chart/chart/PieDonutChart.js (100%) rename {template/src => src}/views/charts/nvd3-chart/index.js (100%) rename {template/src/views/dashboard/DashDefault => src/views/dashboard}/index.js (73%) create mode 100644 src/views/extra/SamplePage.js create mode 100644 src/views/forms/FormsElements.js rename {template/src => src}/views/maps/GoogleMaps.js (100%) rename {template/src => src}/views/maps/google-maps/InfoBox.js (100%) rename {template/src => src}/views/maps/google-maps/Marker.js (96%) rename {template/src => src}/views/maps/google-maps/MarkerClusterer.js (100%) rename {template/src => src}/views/maps/google-maps/StreetViewPanorma.js (100%) rename {template/src => src}/views/maps/google-maps/fancy-map-styles.json (100%) create mode 100644 src/views/tables/BootstrapTable.js rename {template/src => src}/views/ui-elements/basic/BasicBadges.js (50%) rename {template/src => src}/views/ui-elements/basic/BasicBreadcrumb.js (74%) create mode 100644 src/views/ui-elements/basic/BasicButton.js rename {template/src => src}/views/ui-elements/basic/BasicCollapse.js (97%) rename {template/src => src}/views/ui-elements/basic/BasicPagination.js (79%) rename {template/src => src}/views/ui-elements/basic/BasicTabsPills.js (52%) rename {template/src => src}/views/ui-elements/basic/BasicTypography.js (96%) delete mode 100644 template/.prettierrc delete mode 100644 template/README.md delete mode 100644 template/package-lock.json delete mode 100644 template/package.json delete mode 100644 template/public/index.html delete mode 100644 template/src/App.js delete mode 100644 template/src/assets/scss/partials/_mixins.scss delete mode 100644 template/src/assets/scss/partials/menu/_menu-lite.scss delete mode 100644 template/src/assets/scss/partials/other/_chart.scss delete mode 100644 template/src/assets/scss/partials/third-party/_datatables.scss delete mode 100644 template/src/assets/scss/partials/third-party/_third-party.scss delete mode 100644 template/src/assets/scss/partials/widget/_widget.scss delete mode 100644 template/src/config/constant.js delete mode 100644 template/src/contexts/ConfigContext.js delete mode 100644 template/src/contexts/FirebaseContext.js delete mode 100644 template/src/data/userListData.js delete mode 100644 template/src/firebase/lib.js delete mode 100644 template/src/hooks/useAuth.js delete mode 100644 template/src/layouts/AdminLayout/Configuration/Layout/index.js delete mode 100644 template/src/layouts/AdminLayout/Configuration/PreBuiltLayout/index.js delete mode 100644 template/src/layouts/AdminLayout/Configuration/index.js delete mode 100644 template/src/layouts/AdminLayout/Navigation/NavContent/index.js delete mode 100644 template/src/layouts/AdminLayout/Navigation/index.js delete mode 100644 template/src/routes.js delete mode 100644 template/src/store/accountReducer.js delete mode 100644 template/src/views/extra/SamplePage.js delete mode 100644 template/src/views/forms/FormsElements.js delete mode 100644 template/src/views/tables/BootstrapTable.js delete mode 100644 template/src/views/ui-elements/basic/BasicButton.js delete mode 100644 template/yarn.lock create mode 100644 yarn.lock diff --git a/.env b/.env new file mode 100644 index 0000000..cf96c47 --- /dev/null +++ b/.env @@ -0,0 +1,5 @@ +REACT_APP_VERSION = v2.0.0 +GENERATE_SOURCEMAP = false + +## Public URL +PUBLIC_URL = https://codedthemes.com/demos/admin-templates/datta-able/react/free/ \ No newline at end of file diff --git a/.env.development b/.env.development new file mode 100644 index 0000000..886a6fc --- /dev/null +++ b/.env.development @@ -0,0 +1,5 @@ +REACT_APP_VERSION = v2.0.0 +GENERATE_SOURCEMAP = false + +## Public URL +PUBLIC_URL \ No newline at end of file diff --git a/.env.qa b/.env.qa new file mode 100644 index 0000000..83667ff --- /dev/null +++ b/.env.qa @@ -0,0 +1,5 @@ +REACT_APP_VERSION = v2.0.0 +GENERATE_SOURCEMAP = false + +## Public URL +PUBLIC_URL = https://codedthemes.com/demos/admin-templates/datta-able/react/free \ No newline at end of file diff --git a/.eslintrc b/.eslintrc new file mode 100644 index 0000000..c14a995 --- /dev/null +++ b/.eslintrc @@ -0,0 +1,96 @@ +{ + "root": true, + "env": { + "browser": true, + "es2021": true + }, + "extends": [ + "react-app", + "prettier", + "plugin:react/jsx-runtime", + "plugin:jsx-a11y/recommended", + "plugin:react-hooks/recommended", + "eslint:recommended", + "plugin:react/recommended" + ], + "settings": { + "react": { + "createClass": "createReactClass", // Regex for Component Factory to use, + // default to "createReactClass" + "pragma": "React", // Pragma to use, default to "React" + "fragment": "Fragment", // Fragment to use (may be a property of ), default to "Fragment" + "version": "detect", // React version. "detect" automatically picks the version you have installed. + // You can also use `16.0`, `16.3`, etc, if you want to override the detected value. + // It will default to "latest" and warn if missing, and to "detect" in the future + "flowVersion": "0.53" // Flow version + }, + "import/resolver": { + "node": { + "moduleDirectory": ["node_modules", "src/"] + } + } + }, + "parser": "@babel/eslint-parser", + "parserOptions": { + "requireConfigFile": false, + "ecmaFeatures": { + "experimentalObjectRestSpread": true, + "impliedStrict": true, + "jsx": true + }, + "babelOptions": { + "presets": ["@babel/preset-react"] + }, + "ecmaVersion": 12 + }, + "plugins": ["prettier", "react", "react-hooks"], + "rules": { + "react/jsx-uses-react": "error", + "react/jsx-uses-vars": "error", + "react/react-in-jsx-scope": "off", + "no-undef": "off", + "react/display-name": "off", + "react/jsx-filename-extension": "off", + "no-param-reassign": "off", + "react/prop-types": "error", + "react/require-default-props": "off", + "react/no-array-index-key": "off", + "react/jsx-props-no-spreading": "off", + "react/forbid-prop-types": "off", + "import/order": "off", + "import/no-cycle": "off", + "no-console": "off", + "jsx-a11y/anchor-is-valid": "off", + "jsx-a11y/label-has-for": "off", + "jsx-a11y/label-has-associated-control": "off", + "prefer-destructuring": "off", + "no-shadow": "off", + "import/no-named-as-default": "off", + "import/no-extraneous-dependencies": "off", + "jsx-a11y/no-autofocus": "off", + "no-restricted-imports": [ + "error", + { + "patterns": ["@mui/*/*/*", "!@mui/material/test-utils/*"] + } + ], + "no-unused-vars": [ + "error", + { + "ignoreRestSiblings": false + } + ], + "prettier/prettier": [ + "warn", + { + "bracketSpacing": true, + "printWidth": 140, + "singleQuote": true, + "trailingComma": "none", + "tabWidth": 2, + "useTabs": false, + "endOfLine": "auto" + } + ] + } +} diff --git a/.github/workflows/prod.yml b/.github/workflows/prod.yml index d088dea..f5171f6 100644 --- a/.github/workflows/prod.yml +++ b/.github/workflows/prod.yml @@ -20,12 +20,12 @@ jobs: steps: - name: 🚚 Get latest code - uses: actions/checkout@v2 + uses: actions/checkout@v3 - - name: Use Node.js 16 - uses: actions/setup-node@v2-beta + - name: Use Node.js 18 + uses: actions/setup-node@v3 with: - node-version: "16" + node-version: '18' - name: 🔨 Build Project run: | @@ -34,13 +34,13 @@ jobs: CI=false yarn build - name: 📂 Deploy to Server - uses: easingthemes/ssh-deploy@v2.1.5 + uses: easingthemes/ssh-deploy@main env: SSH_PRIVATE_KEY: ${{ secrets.SERVER_SSH_KEY }} # ARGS: "-rltgoDzvO --delete" - SOURCE: "template/build/" + SOURCE: 'template/build/' REMOTE_HOST: 217.21.92.35 REMOTE_USER: u778408432 - REMOTE_PORT: "65002" + REMOTE_PORT: '65002' TARGET: domains/codedthemes.com/public_html/demos/admin-templates/datta-able/react/free - EXCLUDE: "/template/dist/, /template/node_modules/" + EXCLUDE: '/template/dist/, /template/node_modules/' diff --git a/template/.gitignore b/.gitignore similarity index 100% rename from template/.gitignore rename to .gitignore diff --git a/template/.prettierignore b/.prettierignore similarity index 95% rename from template/.prettierignore rename to .prettierignore index 4d29575..f491785 100644 --- a/template/.prettierignore +++ b/.prettierignore @@ -2,8 +2,6 @@ # dependencies /node_modules -/.pnp -.pnp.js # testing /coverage diff --git a/.prettierrc b/.prettierrc new file mode 100644 index 0000000..d5fba07 --- /dev/null +++ b/.prettierrc @@ -0,0 +1,8 @@ +{ + "bracketSpacing": true, + "printWidth": 140, + "singleQuote": true, + "trailingComma": "none", + "tabWidth": 2, + "useTabs": false +} diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..9e77a41 --- /dev/null +++ b/LICENSE @@ -0,0 +1,21 @@ +MIT License + +Copyright (c) 2022 CodedThemes + +Permission is hereby granted, free of charge, to any person obtaining a copy +of this software and associated documentation files (the "Software"), to deal +in the Software without restriction, including without limitation the rights +to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +copies of the Software, and to permit persons to whom the Software is +furnished to do so, subject to the following conditions: + +The above copyright notice and this permission notice shall be included in all +copies or substantial portions of the Software. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE +SOFTWARE. diff --git a/README.md b/README.md index f0e1a5d..74c4fa5 100644 --- a/README.md +++ b/README.md @@ -1,146 +1,157 @@ -# Datta Able React Free Admin Template +# Datta Able React Free Admin Template [![Tweet](https://img.shields.io/twitter/url/http/shields.io.svg?style=social)](https://twitter.com/intent/tweet?text=Download%20Datta%20Able%20-%20The%20professional%20Bootstrap%20designed%20React%20Admin%20Dashboard%20Template%20&url=https://codedthemes.com/demos/admin-templates/datta-able/react/default&via=codedthemes&hashtags=reactjs,webdev,developers,javascript) -Datta Able React Free Admin Template made using Bootstrap 4 framework, It is a free lite version of [Datta Able Pro](https://codedthemes.com/item/datta-able-react-admin-template/) Dashboard Template that makes you fulfill your Dashboard needs. - -![Datta Able React Free Admin Template Preview Image](https://codedthemes.com/wp-content/uploads/edd/2019/05/datta-bootstrap-free.jpg) +[![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) +[![Price](https://img.shields.io/badge/price-FREE-0098f7.svg)](https://github.com/codedthemes/datta-able-free-react-admin-template/blob/main/LICENSE) +[![GitHub package version](https://img.shields.io/github/package-json/v/codedthemes/datta-able-free-react-admin-template)](https://github.com/codedthemes/datta-able-free-react-admin-template) Datta Able React Free Admin Template comes with variety of components like Button, Badges, Tabs, Breadcrumb, Icons, Form elements, Table, Charts & Authentication pages. -The code structure is high flexible to use and modify. +The code structure is high flexible to use and modify. Its design adapt any screen size easily even if retina screens. It is modern concept dashboard design with eye catchy colors. Wish you happy to use our product in your project. -## Free Version Preview & Download +:star: :star: :star: Support us by giving star (Top right of this page) if you like the theme :star: :star: :star: + +![Datta Able React Free Admin Template Preview Image](https://org-public-assets.s3.us-west-2.amazonaws.com/Free-Version-Banners/GITHUB-FREE-REACT-REPO%20-%20Datta%20able.jpg) + +The [Pro version](https://codedthemes.com/demos/admin-templates/datta-able/react/default) of Datta able react template includes features such as TypeScript, apps, authentication methods (i.e. JWT, Auth0, Firebase), advance components, form plugins, layouts, widgets, and more. + +| [Datta Able Free](https://codedthemes.com/demos/admin-templates/datta-able/react/free) | [Datta able Pro](https://codedthemes.com/demos/admin-templates/datta-able/react/default) | +| ---------------------------------------------- | :------------------------------------------------------------------------------- | +| **7+** Demo pages | **85+** Demo pages | +| - | ✓ Multi-Layout | +| - | ✓ Dark/Light Mode 🌓 | +| - | ✓ TypeScript version | +| - | ✓ Multiple color options | +| - | ✓ RTL | +| - | ✓ JWT, Firebase, Auth0, AWS authentication | +| - | ✓ [More components](https://codedthemes.com/demos/admin-templates/datta-able/react/default/basic/alert) | +| ✓ MIT License | ✓ [Pro License](https://codedthemes.com/item/datta-able-react-admin-template/) | + +## Why Datta Able? + +Datta Able offers everything needed to build an advanced dashboard application. In the initial release, we included following high-end features, + +- Support React18. +- Professional user interface. +- Bootstrap React components. +- Fully responsive, all modern browser supported. +- Easy to use code structure +- Flexible & high-Performance code +- Simple documentation -Check out live preview of Datta Able lite version & download it. +## Free Datta Able React version #### Preview - - [Demo](https://codedthemes.com/demos/admin-templates/datta-able/react/free) +- [Demo](https://codedthemes.com/demos/admin-templates/datta-able/react/free) #### Download - - [Download from Github](https://github.com/codedthemes/datta-able-free-react-admin-template) - - [Download from CodedThemes](https://codedthemes.com/item/datta-able-react-free-admin-template/) & receive important notification instantly in your maiL. - - ## Premium Version Preview & Download +- [Download from GitHub](https://github.com/codedthemes/datta-able-free-react-admin-template) + +## Datta Able Pro version + +#### Preview + +- [Demo](https://codedthemes.com/demos/admin-templates/datta-able/react/default) + +#### Purchase + +- [Buy now](https://codedthemes.com/item/datta-able-react-admin-template/) + +## Premium Version Preview & Download Datta Able Pro Admin Template is available to purchase. Visit its numerous demos and make your purchase decision. #### Preview - - [Demo](https://codedthemes.com/demos/admin-templates/datta-able/react/default/dashboard/default) +- [Demo](https://codedthemes.com/demos/admin-templates/datta-able/react/default/dashboard/default) #### Download - - [Purchase from CodedThemes](https://codedthemes.com/item/datta-able-react-admin-template/) +- [Purchase from CodedThemes](https://codedthemes.com/item/datta-able-react-admin-template/) ## Table of contents - * [Getting Started](#getting-started) - * [Online Documentation](#online-documentation) - * [Build With](#build-with) - * [Directory-structure](#directory-structure) - * [RoadMap](#roadmap) - * [Author](#author) - * [Contributing](#contributing) - * [Issues?](#issues) - * [License](#license) - * [Other Dashboard Products](#other-dashboard-products) - * [Social Profiles](#social-profiles) - +- [Getting started](#getting-started) +- [Documentation](#documentation) +- [Technology stack](#technology-stack) +- [Author](#author) +- [Issues?](#issues) +- [License](#license) +- [More Free React Templates](#more-free-react-material-admin-dashboard-templates) +- [More Pro React Templates](#more-premium-react-material-admin-dashboard-templates) +- [Follow us](#follow-us) + ## Getting Started -Clone from Github +1. Clone from Github + ``` git clone https://github.com/codedthemes/datta-able-bootstrap-dashboard.git ``` -*no other dependencies required to run the Datta Able Template* - -## Online Documentation -Datta Able Lite version documentation cover in its Pro version documentation - check our [website.](https://codedthemes.com/demos/admin-templates/datta-able/react/docs/) +2. Install packages -## Build With +``` +yarn +``` - - [Bootstrap 4](https://getbootstrap.com/) - - [SASS](https://sass-lang.com/) - SCSS file not included in lite version v1.0 - -## Directory Structure +3. Run project ``` -template/ -├── public/ -│ ├── index.html -│ ├── ... -├── src/ -│ ├── assets -│ ├── components -│ ├── config -│ ├── contexts -│ ├── data -│ ├── firebase -│ ├── hooks -│ ├── layouts -│ ├── store -│ ├── utils -│ ├── views -│ ├── app.js -│ ├── index.js -│ ├── index.scss -│ ├── menu-items.js -│ ├── routes.js -│ ├── .... -├── package.json -├── ... +yarn start ``` -## RoadMap - -We are continuously working in Datta Able Project and going to make it a awesome dashboard template via your support. Give us the ideas, suggestion for include more components, pages, plugins. Few of future release pages are - -#### Layouts - - Horizontal version - - Sidebar Image version - - Introduce Live Customizer (i.e. only for demo) +## Documentation -#### Pages - - Pricing - - Login/Register pages version 2 - - User profile - - Maintenance Pages like 404, Error Pages, Coming Soon +[Datta Able documentation](https://codedthemes.com/demos/admin-templates/datta-able/react/docs/) helps you out in all aspects from Installation to deployment. -#### Basic & Advance Components - - Alert, Cards, Progress, Modal - - Datepicker, Notification, Slider +## Technology stack -*All above pages already included in Pro version. We need your support to include those pages in lite version too.* +- [Bootstrap V5](https://react-bootstrap.netlify.app/) +- Built with React Hooks API. +- Redux & React context API for state management. +- Redux toolkit. +- React Router for navigation routing. +- Support for react-script. +- Code splitting. +- CSS-in-JS. ## Author -Design and code is completely written by CodedThemes's design and development team. We are happy to welcome the contributors work for our all repositories. +Datta Able is managed by team [CodedThemes](https://codedthemes.com). ## Issues -Please generate Github issue if you found bug in any version. We are try to be responsive to resolve the issue. +Please generate a [GitHub issue](https://github.com/codedthemes/datta-able-free-react-admin-template/issues) if you found a bug in any version. We are try our best to resolve the issue. ## License - - Design and Code is Copyright © [CodedThemes](https://www.codedthemes.com) - - Licensed cover under [MIT](https://github.com/codedthemes/datta-able-bootstrap-dashboard/blob/master/LICENSE) - -## Other Dashboard Products - - - [Free Bootstrap 4 Admin Template](https://codedthemes.com/item/category/free-templates/free-bootstrap-admin-templates) - - [Free React Dashboard Template](https://codedthemes.com/item/category/free-templates/free-react-admin-templates) - - [Free Angular Dashboard Template](https://codedthemes.com/item/category/free-templates/free-angular-admin-templates) - - [Premium Bootstrap & Angular Admin Template](https://codedthemes.com/item/category/templates/admin-templates/) - -## Social Profiles - - Dribbble [https://dribbble.com/codedthemes](https://dribbble.com/codedthemes) - - Behance [https://www.behance.net/codedthemes](https://www.behance.net/codedthemes) - - Facebook [https://www.facebook.com/codedthemes](https://www.facebook.com/codedthemes) - - Twitter [https://twitter.com/codedthemes](https://twitter.com/codedthemes) - - Instagram [https://www.instagram.com/codedthemes/](https://www.instagram.com/codedthemes/) +- Licensed under [MIT](https://github.com/codedthemes/datta-able-bootstrap-dashboard/blob/master/LICENSE) + +## More Free React Material Admin Dashboard Templates + +- [Free Mantis](https://github.com/codedthemes/mantis-free-react-admin-template) +- [Free Materially](https://codedthemes.com/item/materially-free-reactjs-admin-template/) +- [Free Berry](https://mui.com/store/items/berry-react-material-admin-free/) +- [Free Gradient](https://github.com/codedthemes/gradient-able-free-admin-template/tree/main/react) + +## More premium React Material Admin Dashboard Templates + +- [Mantis](https://codedthemes.com/item/mantis-mui-react-dashboard-template/) +- [Materially](https://codedthemes.com/item/materially-reactjs-admin-dashboard/) +- [Berry](https://mui.com/store/items/berry-react-material-admin/) +- [Gradient](https://codedthemes.com/item/gradient-able-reactjs-admin-dashboard/) + +## Follow us + +- Website [https://codedthemes.com/demos/admin-templates/datta-able/react/default/dashboard/default](https://codedthemes.com/demos/admin-templates/datta-able/react/default/dashboard/default) +- Blog [https://blog.codedthemes.com/](https://blog.codedthemes.com/) +- CodedThemes [https://codedthemes.com](https://codedthemes.com) +- Dribbble [https://dribbble.com/codedthemes](https://dribbble.com/codedthemes) +- Facebook [https://www.facebook.com/codedthemes](https://www.facebook.com/codedthemes) +- Twitter [https://twitter.com/codedthemes](https://twitter.com/codedthemes) diff --git a/package.json b/package.json new file mode 100644 index 0000000..8b5f9be --- /dev/null +++ b/package.json @@ -0,0 +1,81 @@ +{ + "name": "datta-able-free-react-admin-template", + "version": "2.0.0", + "private": false, + "homepage": "https://codedthemes.com/demos/admin-templates/datta-able/react/free/", + "license": "MIT", + "dependencies": { + "@reduxjs/toolkit": "^1.9.5", + "@tanem/react-nprogress": "^5.0.42", + "@testing-library/jest-dom": "^5.16.5", + "@testing-library/react": "^14.0.0", + "@testing-library/user-event": "^14.4.3", + "axios": "^1.4.0", + "axios-mock-adapter": "^1.21.4", + "bootstrap": "^5.3.0", + "chance": "^1.1.11", + "formik": "^2.4.1", + "jquery": "^3.7.0", + "jsonwebtoken": "^9.0.0", + "process": "^0.11.10", + "react": "^18.2.0", + "react-app-polyfill": "^3.0.0", + "react-bootstrap": "^2.7.4", + "react-copy-to-clipboard": "^5.1.0", + "react-dom": "^18.2.0", + "react-google-maps": "^9.4.5", + "react-icons": "^4.9.0", + "react-nvd3": "^0.5.7", + "react-perfect-scrollbar": "^1.5.8", + "react-redux": "^8.1.0", + "react-router-dom": "^6.12.1", + "react-scripts": "5.0.1", + "redux": "^4.2.1", + "redux-form": "^8.3.10", + "rodal": "^2.0.1", + "sass": "^1.63.3", + "styled-components": "^5.3.11", + "web-vitals": "^3.3.2", + "yup": "^1.2.0" + }, + "scripts": { + "start": "react-scripts start", + "build": "react-scripts build", + "test": "react-scripts test", + "eject": "react-scripts eject" + }, + "overrides": { + "autoprefixer": "10.4.5" + }, + "browserslist": { + "production": [ + ">0.2%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 1 chrome version", + "last 1 firefox version", + "last 1 safari version" + ] + }, + "devDependencies": { + "@babel/core": "^7.21.4", + "@babel/eslint-parser": "^7.21.3", + "@babel/plugin-proposal-private-property-in-object": "^7.21.11", + "@babel/preset-react": "^7.18.6", + "env-cmd": "^10.1.0", + "eslint": "^8.38.0", + "eslint-config-prettier": "^8.8.0", + "eslint-config-react-app": "^7.0.1", + "eslint-plugin-flowtype": "^8.0.3", + "eslint-plugin-import": "^2.27.5", + "eslint-plugin-jsx-a11y": "^6.7.1", + "eslint-plugin-prettier": "^4.2.1", + "eslint-plugin-react": "^7.32.2", + "eslint-plugin-react-hooks": "^4.6.0", + "immutable": "^4.3.0", + "prettier": "2.8.8", + "react-error-overlay": "6.0.11" + } +} diff --git a/template/public/favicon.ico b/public/favicon.ico similarity index 100% rename from template/public/favicon.ico rename to public/favicon.ico diff --git a/public/index.html b/public/index.html new file mode 100644 index 0000000..d891d7d --- /dev/null +++ b/public/index.html @@ -0,0 +1,47 @@ + + + + + Welcome | Datta Able Free + + + + + + + + + + + + + + + + + + +
+ + + + + diff --git a/template/public/robots.txt b/public/robots.txt similarity index 100% rename from template/public/robots.txt rename to public/robots.txt diff --git a/src/App.js b/src/App.js new file mode 100644 index 0000000..eb78023 --- /dev/null +++ b/src/App.js @@ -0,0 +1,16 @@ +import React from 'react'; +import { BrowserRouter } from 'react-router-dom'; + +// auth provider + +import routes, { renderRoutes } from './routes'; + +const App = () => { + return ( + + {renderRoutes(routes)} + + ); +}; + +export default App; diff --git a/src/assets/images/logo-dark.png b/src/assets/images/logo-dark.png new file mode 100644 index 0000000000000000000000000000000000000000..eccece07df8896b4eb2b65f756a49b8c59f411e9 GIT binary patch literal 5561 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 literal 0 HcmV?d00001 diff --git a/src/assets/images/logo.png b/src/assets/images/logo.png new file mode 100644 index 0000000000000000000000000000000000000000..eccece07df8896b4eb2b65f756a49b8c59f411e9 GIT binary patch literal 5561 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 literal 0 HcmV?d00001 diff --git a/src/assets/images/sidebar.png b/src/assets/images/sidebar.png new file mode 100644 index 0000000000000000000000000000000000000000..fbe644e477ca258e475331049c7e01434644fe9e GIT binary patch literal 17390 zcmb?hQ+p*$vrTq(k{#RT#I|isFtM$Pv18lD#J25ZVw)4&nrMRae*fWIR9AOj)kW3Q zYxP=@DoWBw@c8f$5D-YRG7_r)<>>zf2D7L{)94Tz972u&(>fFCpLAS4A#$^wx_`C2cv#My-i7uUdmf zGs4f9V#qXM#wDr!@=50SnN02~(}BHkqGTI;URvT-6a@+Lu2B0bD*RT{R#Y-g(3uxN z4n1Fm#sQaTQXqv9yZ38t0d|F<>+Kx=a(@9rUc+W%KS3NBj_6^S`7-&^PPp9d_~$o? zgNER2^oG#81ftg4v1UPJu8=*AZ!ln>%(i#{sSKTJ&cp~6!>tG{-SzF7{Q-q;pXZR% zXly?dga4TkoKT-uy^-kYQCYHhWCQ;wk|>)xD8r2IQRR+>V8OpfC5x$xUC4Il&z>(>*r>&VF>lk5q? zJS5%)%c=SBzS(AA4Kc^X03ID664xU%83QhV!6lsko@Py;_^9uwgD~X1)u9Q)_>3K% zII4cwASio({H2x~rmrA&dqTnaeh`A8RR8q$GHN-aS3kOUH}izTtVFFWBQZoYCafin zi3SH{g~-;< zR~0q#UKW#RD-i#NC{ogp5`hOC4V}m_`N@ABsRt({0^kerHGqMK99guG@n$dMM-dh1 zA|?QyF}v3=pwW!wg5@w|TaY#ooWFNo%nKGUeVhJe8xak)t=ui<0->$`fEJK6R zHjQx-uY#cYhqL&-ug7%};&Rf{PS=~y!m7TGfBAekRsE=$$nkwz|CpC?txIcdMM1`- zb7skYWd)e?Dx~f9{6d%$IJtc$x=^&`Kd*m!a#5`~d^cN*n&a2K6=23a~Yjr#R^zJHgU z_x8ef=6HSMVJ)U}ok|W;*f5B=J+8M>h#L73O5hQBY9;nT%ypih*creF@c<$o$DMV3 z7fXM-EVvR`2ID7M zcFJb1J$kGTU71ZYh;||&qs@lz07~TcZM*66X zq|89a=0C(eUW};w(4n}COQr-9i0}9Bp0B*mwaZAgt^@T&J~Qx=aDIU;glqpbEY4h9 zU+0cZV}I-Z`ba;SXaobVJQ(n$PV&jiT3U{bVGr4b-;E2ed>>{(9`1Ur4r=!=>YzOt zCzs29V+o+M^b)C+383GIodSzT<|ufN@SQRS;5KAuQygywjryHR3}2?%f>A6d#-gOm z9>#~?6_1ej7T{C-PD4rl@(g^N1ruoCZD$78vIFEp#I~x*9)sd`?m@0?gkvXdbmesn z=H*LNs1cs*4Lwiqz+SB9{mruh%=ETHK0_kU1o_%dO81N9s1)DhN|F(76r?tuy(O$Q zS9*$80RfZHPa!nrn^=E8yzNrGr^O51&1c=mJ1yzWGPS$4PuZ!N0vsq_0O-gtBUmLs zp`2T-uEgC*HY4MWP~w^27S9(5B^@Y^rd1<*dh+C1;BE{Et$4pS!-{WzRVeIWpu<3KOcp;AWYDrWWi1m>)VJp`u02LGbZ3 zh42Gw5q;8D_M(R9e%}&NTr6x+ekB?NOaFFq;6L_Vs0Zkm!;bPBRVmQ9l*|Sjkfk(g z)10{M7F6)Iys-Ij+|lHA0hIhc$@S|*S?1%v4kGkOFKq~im@WroHBaJXJJIDaXb8RHeAEt zHot#O(tO%zP~0!@WczzOf;5Ru;&mEzm2(nORSTcN!I77|1I<7hgH5lYV-L&GjI*6OHXMqMTD3xCi@x9FJvT(@ zGdMqA2m0U}81c^uY<^2dxN=(8Ucn&Qt;oH4cLw=1Fb!4GGO>mi6k&KA7nF91?`iZF z$&!!@O;!}iFkLWqx#n4xR#ITEUa0b1mqHYrxQKZ62z_Gs{7|>`w*#S(Me@i#n2H$L z`|*@a)S@uxOLvQv3emQ1hYyAVJbLw~c`uJi@UDFRD(Ap(M&K1=dV1P0qOfzUi2q;= z6+l+3gWq3PRobMjZOc}PjOr+1CYTk3#FFHV-mAfjkdp-T=KXx`wm}RH*(boX|HI!6 z9T++_I!P~*w0S`am|KbfJgGSWgMT9bIv13%!Mt|hMR{Z-*3{|2{R81z5XUY~T7y=aU^Nq03Y>OmY7t6%#S| zU3eza9Ska7p0%y0A^aUVyG|w@fi19qaBeTZv4F-TYsRaz@WgaT{B?^_u8&;r-O$7e z^MiPZ63Od@3K*@s*XMGYtDx8sF?zVSv=Dqd&)7!lsZKZyAG*egeM+WnW|9!CH4n1M zVOg7}u_X!o2h1cRpG@;gj3H~B`hdITO@!otL9*|vxk_TM?VyHNQ{PUr0N)P4Zk8(N zJ;`pAa+4eOi|9f2Kmy@L`Ssca>cK-ewe3bu#@;6p9wox*3MCe)DuyYjgvJp@>>F!Z zs^JG3{ZSh5u!||S@}y{lozJ^6wn)w2)JQ8N^38?{FBcuXoP{1ar-P>pF{JXf-Ozn; z_}7c7nd=ghL*CRMYwfDqHW94r=LnSWOfH20*wi2@gA0}$*??)}Ev_q7J4OJ6HEam$ zu$oo!RQ8h{PrJ154K0b@eFK**RzYMtY8oJ#D_)O|s^wVrH;PRzmkZga`F-I|GK~Ws z1E!+j%bfVva%)X3Th_17L_{;z3{+Wa(xmzZeZlWzmR)sU8yZz#W7Z6KQMqD3uK4!> zbhH&E^~1}`nCh8(I+wu`$b1fY03i?88~l{~q0x_s2q@x2JZZ)N5mYCho)?y}C0kEN z&`R95-H~JY3``d!cu45FbobE$q!BdSQ%E@Yv(OZ9QmsXP@#O8W6yvw=lL>9&|4_m$ zQCWz$7XHFrEx%MyU?=miP=`Z6>Uf_LA;Li6Zy%lY=c(tN2~D;VMVIOdMU;7?Q42$M z4c(^=G)lv3wX9#i5HX%YP$HlEboC+sW*C-qtm0bQ*N|<^M2!Wx&De zow6jzrJ9TthU$*kkwBdwWztO;??T(}@M1aqC*woXoh6Ri*hj?N7r{LB3@f7wk1+sO z8~W%DjV6W*^4Ftg6e@;_R+T5q5dPro>5A85PXZYVJVSTjKZYe&w(5Wb>(nrRemxsL^+CLmcNR^q~)Mr6u;&fNXwld)Two-h<~Thm_%5!sn&m2IOWD=$gMmTr(q zrVE}qvD-DzW#;wR_IW!yke1p3j^TO7-`{n{z}vsVa`ILSt_9BhXUK&3t-aM?nO&R- zJ&&1Car*YxmJ4J1-3Z)l)8>@5erUq7l!F(dMn{cmJs*x~VO>~p&<*swF8A6WSoT8~ zToVUqyla&^jBC$vBKb@cX3cXhqC+SR0(_F{CaGgf<`0Liw!uY%}qgQAJ)~oxp{zkKL z^pk;ang;uP!HJfd)nh{|HN#b1U4L#EwHI9PBQ4+M$rHO7EH>wVp)%$fHWoMcJb2=g zFw>U=O&F9TAN7GgV4^F(QDPdBP45-Ly`DYBi=L*6t}#F1uT7t}6uZODVcBDbqrIeA zvN%4uUUF#l%VNk-wBw zo4#C0>IN~-VzC*D!|5+3vK};MCF?prA0m0uU|VisE7yxDckz-FDiK_oSs{7Ws?62) zk4N5l#H2P1MV8xgRb=OvcB;o}y+c(j1)BXx zT;kweS|o~EF+DliEQKEvm3ojk8>Ku*7C3kG=1X2oht5pJjlnFrmnsISOnC{^LX@u7 zmSb_l9y`8p*PXu*&ZiC3CYGQ>wWh4cSTyIWZU9RBGpw z-iJ%QJV*$+MnyMI5`aNJvgme{=nH&FpJzWsIJn{o=|27=zN3v@y*UAD|q&Tt?tfF_)i4{y_-+icB0l}JIWu=3n3Z3 z6&a#qUlfD`ZFf2?F9R>yf4v_lxc7s5*0rVaO9g4ignq`6^K8p9$tD48MJ}O1)G6Y5Q5+1{eRk=#`$P*PDkRl09@?0)qT2=W8&WnLt z&TPW%hx5Q#9F`aLW+NVw;A|Xy$joCV^&c73pzsU=rw*#q4D=z@;ZPZV$)=8fFrT+w z57-BJ6;m28BY*n6^Nro#NZAo1dSaBl)4W(q;2&Hp<-hJE|N3g=DKdq2!%#LZ0Hx*$ z64jlQ2_?JwqgcFHm|L;ZTx-K#Yw%(wf8WYlk_If`r-GsYQqJ$GY?nhAaCZ*U|W@fD%DYkIg%Nk)5qoeneNp$sMK zh>Wa0vgy9$V4)GF)CJA26Mym|>gZ{wZ!j?f(=$sf{6q|?cE%;k3lmv|CK{H6ERymq zEed>nru_r!dh&m`euhUVvmMe2tU`kYy(Oh~r_QQSDa&cealayr7=GIvl~>awhqHwd zFM(_ls{uNh99ZY|ja6e6WiU~+;l!>o29>H%OcS+18DE#Q3Gi3oM5#inhUjSVbb8&4 zs%B%23$dINw$FyLq;xX1JCpV-u+|m^d|NRNu`Bs?Y0yu67*kJ#1LzF7$PEH7oFjY7 z91nFm3h_T-6W>*$u+^rpW11iW44wNo^M^3R(D0tbco=H{#@{KcNG?2)nev`#rf#N! zWK4jZLO5SSv7`DT7WCA_tEM^-+N@rb2_(>ov!qt{zsyU2lf_eWB)m)yOf+R63sJXOHseD2DRkEDyh3T>(y1Ho@ z!uhmpiUT{PKKl7!n~QL`S0_O)2i` zb4t#h;XxT;AGc@2p+t5rNRF#8+CcD&Sy#bG{n~IC+Lmxp;|iccPkx=^ml z(~Gi@6`EyWnX#N~SCtC5o>IS}B2X4oS{jlS$01)3L`}n%J&N;vKGb~hBNtJi<1uetj#ho~uSl8Tc5!D(Xi}CjB7vXOhVa^5^A;AYM8COy#JDmU=ILh_rHLLL_ph9~L-`j>Fd`&>xQ9d2uv1&Pz8(6Q2t@RtvlGzS~|T5TZ{F}v;4 zWi)z&)@Jp(w;slv2tOr%PLsfGKUB%2TnP>-arSJf4D7MM6S<;_k_Q}jA@NC(z8v~f z)UA9?LMRn`m`d_xMLQ!FZR$Lb3@1_jbwpA@!bmn4f}caZ4v<>;L&c4a&v>}yNh9GU zc<=>EJvE90Q*YF+nLz2A%REpc;WQ17rd;F4Zyck_!pJHHEK!QKn=>ACd(pTV{Ic24kY|LwcucfB4siD)~K7%Z-P7~`fz|s zLhE$J=-sQgR(!1UofU0^EBfiD&Gldg(e0}0k7?MYcgesQXF;lCM!722vSUp_Uip`U zimIJuFst>LJ*UFx3Opp1T**@?_@P=HnU~U2JU`ft9Kz;Pmkyhs7aeXIu8J^ad3*cy z@3$YdLIf>INc^NX&{}3rR+9*H#OD=cWvU(Xsu^fQ%a`mBOLp?g*`z+f>FUHl-goN$ zTd#l`83SpqUCS-vv!g7WG4w>LSxdcPHJJkyn(bvUvHwybSz{-&SpaLMeNJj^XN4%e z(Y^p6hd@J4R$P;7eX)RfyJP{7Mu(fKqg#2A8Ls-t4LQmNwIfo(f2z?~)G%apwejYT zxe=NcI9BWPHjHyJo7Xm)eimF3J#>{I!?a}?-&NOjRVtn5?RLb=-1}mJ&g0Hd`?r@K0AI!(*~`rn#ykOGlgbE65Cu-BaYKZ01>mknk>^X<{BnCdHQ6nXAqC(LEo%RM z)6Q9dybwJ&MWz_?GDDq%$gDGQ8iOY8H`KbqokJ`mq6!R5;3O|~;A)c-S$)cP{cAGV zJqSypYNe~Xq{4IfFyf2JtnaCfI@}ET_(a$OXU5&OJAx?vM7|(+k?s8ljJKJqww-P8 zgm#(X;?|ZAvQ0A2j_`1U6**ZM=->d^Aw99{J459mkN&!z-)WLOlM_?VqpD}seQv-} zE&a%^*9B*P+~~5%bb~`6OeMjJc^yr!{MZ>mG=^r3$*kf$>c?93x(rCh!>4w*6ip2* znOZn;u9^c?CjJkSI{@uMzQhDTJAjsexO`h^^>l9_vX#m8?{0wt^^nN?hNKxq;*wA} z@jD4c$AY%$dd(fY#wHmH4NF8Nux%2AENF-doBqdbXsF2F_lb6tF}RJEU&3>{Lx39j z-;_DK1bIWq27d?$Bwqk)gGXKgW$-p#^+vPN)~Zf)NjEQ9L6nhwcH+oCyYu6FZk%(Z z;D7wTQSJL?%0mG;bx`@Wk?|C207(f}ZxfR*Gbo?$4J`z8OJ}dDkn*G5=k-TsFz1Q^ z3%0fK^bncfLJW2K5soWtuJQwSZ|4b{bTrS=JeKg+jkm>A2HC&2H>175&|>4m4J>*& z<)3&yMgvpecv4ic40~w|pz+jFv<$k*$~9z%rM(r(|Hz?+5qqk5U-Y+aD-0c;lUaB5>>-sr12=Tf%)E zIl2kfmq}B}C}dGLzFOwJg->EXKR#ygA@s6Y;{syU1Ig}$<B%2ITGv!s|bX{{Qu?F}!$^Urz z{oJNv3}x__u;-OUtbe9RLq}nUp-q-F%*|>buX`YiRfy;!6q&OiKvWyZ*5T zng8^QK=gf@YWA2@Ob5rPPhIJ-|0`nFxcI_;6bwNk-rlAbR~2v)92Awu zAx-i+GLvdH4f$+P1iQpqb%EyKwu}ts9?yv+r(_1lY{7KRm&k&@OaVsn#$PpM`^dP% zLW(TKO_Qn6Rm}O4zpJ%f)^Ty?a+QJGY|Uq7acVwU*8?@}ndx~tcf$3-_df$evk$8b zKPn-SY9t&*e=wUfJ>v#sVJ2+fL~(J$vv`53^0ca9nk1%m%OR6x#1Na-$K#Ydo!-dX z8(wiew{pTQ^6>^1LVSsaA1d!e^n8`^fzy!7b0#u5whAIHps$bB@9SREg+V?xWAsjx zEJf&e(p>8Fmv$w1^S_AHy+YZyT#-|S5vdveeo@Dn!W84J8g$H6n6)Rd*l#W^nJJ+9 zgU5O0fAW0P3ArWybZ{D=EsLo!?7P01<3qxMf8DI@zIPZgf;Cs|A*<-d`)XOzRyE9? z)2%le0LcDB`yl_j)Z}p^kL z==BHPCZfchka%V)s41uA)~^cX87F}{CG|#1)F>}pT3m`et&%K zo154GIc3GM%HB%JcjB};4Hv+Dd#@lyI8I~E?d%WkeJG3=ATB_fC(IXLdK&%5bropp z#AGayi9i3<-r5o08p~O6Il;19S`fm(`3K%RuYQa+`Mzyn<#bNw4p8u{r)o=5S%%Wb zLFT1f?r20nKd?-1PljQBF@|4eAisKzs9^SE!2%TzA? z?xu6UI`%I5UXQIu3H^{1k`$uwl3JWV_GSaODZ65cQZD+oSM0MXe|$c9ZAiJqF+W!a z+RtTM^|Mhv6@Z<=R%uW=VrXpga1o?;v0P=~vv{}NE<6pjz=GF67Mns;NGkYc(Tn_U zB0p;71tg6w`(gz_El1%GnIJw`9MBPN` zpp-kMKQ%aI3^87_s?(L#21popJ8}(yGsjG*ry|qjmNUQBT^E^eK4mROo0(Hw@E#FI zjVDKhZ1X)_G{25NaU8nu941&I*=Vzd9as4j2mhU~n)z9oZg+z-uC?f+dU__&7fU}F zY2%_)7OfKh*~vrfNy{S516eExn|T-Z^uL5o6)n|{B}p;k1H*yoNpW~vnwYFIiJLaw zbSgMev?$an8b$l`SyQSxOw*+SKUoy9q#$UE;9d3I^nkKX8Q8knV#cLw^*r2%a^hfh zWE-#A_({6;-|H&A6bc8ZB9AnR<~Ai!c8eUOq1|d@G4^n+|Mo0>jNVF-vRCZa+s!o? z@O2|<8#O9ZoIgGYX8VlBlSYk_%o{l-B_Q^M3#j25J^V%U>vM4RJ{Ra5f3YI}GoAbq zVneDt%K6T#6Z1uCQ%AHlI!dMmV!>9v!h+_{6`A{;2plz{Oi?dRdx@%X5y@rp+V9Un z-oDdgq~e@M0hAU7s?vbF4+&B9T~O}ZF$r-5ndl0Bvv_p?lp?XiPiAYZl84~|*))h$ z5$)g-5uY|)!7`5jeq?J{l<#@Eltcs0MX0M4gmYJ+o+M!N^AofRK~`QA_{6rsfWj75 zc$#Y2`EwW>TZe8V6UQapQaYwS8o2=qiO1v=jk}|jfMB6x6cH&1SQ}BPB5zEqG2DUA zCKx|TVVbQKach6iRDiR_oKiobt=DjNy7NR-X{AJC$XJt#PG($am6(%(QBDl^-?aoH zDZ1$}c!S8tU0^g&A&e0>GCTFv2FDN51U@ofzDuq`QLG67>0pkE`S}{{{t|h-h)1;G z{B}xX_C2d>YSVx2sWX=v`8kbq?*WZaa4LEIYu?qsQgii6KF`N_I}TG!F%1v>Z`YKL zrQ9ofCQ*4%=xR|>5qVq1^R>G4$$Uy&)oBI-%yH%^%yMF$UUBlP8`JVx>w9;SJXE_F zVUHUeL$NVA)#+ayuuAtnnp`psMgdH;tma2=4&9-9dr?F>CK?Se41i^Xp(1B|eW-;i z8bD1G^?~0|6?&AW;uCT`TSCV02!-Jp6O6dsV5)J?;N~@0`I(lO#W{GO%?d7;=Yloh zVpq{>JKhoLOZojTXgk5rz0Pe`klEq-v>eZJo4x*Z(ADLEdo()rw~))zo9jcz$#%fD z6-qZ$CSv_dLkfh2kDnaL+#gdIVcQjk2B!n5`T2QcBqSuKFVpURoqtXI{@%BK2rj8s zlt(5-YGk@&YU7gZ*q!)os@IK})Nk6c{#oAnjhIpSon$4(A-UUCo4GIo@&Mn!KYNV} z8Umxg%IMDMax1+>8_yG7MUh1DsdUi=Djll{gMA=PxjYlK#)gJNd8m;na4V2Dnc}^g zt8FB50dYQZX4iize9;)3K$)2YV?x?6+{D?&oNW1s#7R~hf(t|>e<)WS-X0q->UQ!s zQ@4&Gh@NhMok(HoI4UPlms5<4Av6ka)EmfDnPXF@;`~P zNfzipn1Le3O^eIRR4_0wrz(R1^GxpKi4i_8-0`0*jsLDK*KzL^c85migCkU((RkuY z8|%y_LSZWj)wtQDH5IXOeHe=xHXd9KH0^JZi91@V)~--2vBLnF_wnJ-UqSD zKVO%bHH&_5rL6~0TG=2XC1AMCaC&Ub``LRy48t1-E5=o|}PqXkgKTQaAS zCR606pwR?~pw)M5!FaUg0y`Wr!tWG);SICEaVOHpw8{40lM*_Tvl8aS)M%`N2CdYm z*)6Mf^bXJFt*X(oh)@R3j?RKI{Tu`y{%)st`mgw|)^OCoL4}&o>r`dP!><0_{7e4% zd*`cIAq>yNNX;sbyy>q%0-{fo6l;)Xgs*VivBJQeHu}6 zfET_!(uTDOx=@D)2&o8gt0@rHBEy=%!Ch!euyu`A(h7(aWLj}2+T~@fa253?I`qYi zvhqUZkuZ=gLQKut&9yEQWnBrnZp@5S1@2tgsIPZ(X9>%~BcCI(f5jkq^Meu^4>O`K zY|wRSWD+Oi$L13WMt3}~MlXoH%4b{c4U_Y^;r<@OR{B71%Lxx4Pas=kvnQe3fXin! zNO%9vb=K5OJL|7X#TFK6^zy<>7R`@^q6qldTg~<;64z)tUg#b{gIqjNNUZl_4VS#hdiVp@dD$196Wl0I1u}C+&5$r+ zeTXZcs&#Kg{>(q|i2w9*{d+#2n3xD}V~S$P)~c%Fmj0@G2s!VFD)^b%Wnvkl@C$K< z9KcJ4zbZy%h43mD8;z)8lo2Xq3ZneE_dL!JievbiigDuezHhr#PgFAT$iu|~1+&Cl zUuC$Yvb%dHrMk*J&{{eM@<8n@ME1fO-r~VT%S?moexck%MKp(gD1NWclyxLtYs_8C1G8md2~cjizuqR!8VNlegy*XC2-tU!sD| z8IvX%Cmqgv9wK%9-gy9F{%n!RoAzygx_f(jNu}=q@dw!?d2=_#cQeUZZngB3$TqkJ zWs7H|0k{&OVgq#8(X9tOEBDzB1_pQp7e^T>#XIPaJQ((k^J%#^BVPsbzR-KCEMt|r zjIq`#P0|~zOYnOjkGDD_$k{ykzDQ})SX>%hy~(0iym9$MTI}lNuAv_GnJ}?RMa761 z1Z(VE1Wj*EAYqF=wcL;2%S}u1YAQGB0{E^!2JA$Lw;EVApHQk@4E#R~xrJW(*ZVr| zNraz&x9k{}2JRQ6kM)b>zmSSPU>s6ce}9KrF_@cyfFDP8!VbRNokm7RhOg0p(4e)_ z)V9*hET*18*9-I7ab>Hk^`r59Wc3EC{wJu9OYSpbtJD8b6#E`wGpv)t3`b3Na`q0f zTqMP6D3NN3(goWOS5zmGo-MkqD#d=}OzF-Lj!%UXwlj(ne6ooW3V$3YR{b4Q1eazo zrs;>ya9t*rg$}Cb^ti%d77tu!A6s%w`+@0Xqpe|I(a9cc-i2n~#Tc4y zngsEQF~Oaw(d~k6RhSzjdAne4XP14j28KQ_j383FeY?Va&dGlb~F5HV_J z*viX`r%bZWkhYiwk(Bix|F0Q#hu#C6xul<^g9S7l^M_b)1GO9)7~l=XW0^WGX*yom zUFC3_%Ka%ZJ;-r-uoRYSfo>zz?NQ(bnd(MVqK0!kboc3W;AnPyXzw9IZ8}wg%7zFP ziN;@{Q<9%7z!k)E?rY|FnPL{EEwC66CYDNVqK!qG@P2utdr20eD>GRD`?^ph%RQlE8q9#9muSdv$p72` zGL#{+#Dl-&PQ|}Inr694oE}HZm1v`KFfg)C&w&(9I0=<4aKgvmw3nKV086)=bG$fi z*vE>nC?gBPxBbIgHt?{5@r*253Mg56 zX#lvRq&euB<8Hg>N?pUwqtVs)zklbMeNj;-#^$&9>T&yDL_`-43f#FYq|ZA^c|~_! z$|j0Ov`;lR6j_jmsq6DUT4by8vs%svf{0Z>9q{&QC8)t+&67W230bZVN&dK(ttKfg zfcikNXAGnZ@~}F7F~gqtjpumQ+!Au8#6b137_~$-K+FlIhF)-ZTbf(7MCk6cquKyo8&R)!eK<11JuRjr!0nwZn&C*1iPRkv40pSQRgh^6=grtExewR zVBn#LJatsD?zt=E0 zmmu~BB9k;0+MRo*MeqDS!?yvqXHW593cbv*9IboxK+M=jdfPZ7jxa>6CnM3spXU1L z)}_D8%VksMV@nB5_nh{C?r)4ICWJi*B%EPC=*vkVMc@gurSl(zH z!NKhH=c%!-U?05q8D^DTMa4|*IzdthOfEr{N$nuco14r_RIPJCGDguy7PV2*JsaWDf&->w_ESgU z>6pd7lko#>&-#s7G+ldUryH_Mkw8Gz1(Gf$dLgY4AYuwYflS#>*iQu zRk3kX0ET(Y`~_|Pv-pL;J!oUbe3X=*3w}M(cq}GP#MnoVvAr(hwJ1rv&r@vI_4OC= z2{^?aE-`F=&u@W2!B4#POI+Q;6{6r9ru;gZ^J>xehs)0(>dZXNSt+J@;BxbKqiY@v zMX%XFvHz9HoA`5y3eE>)krl``y(R)sO#IS7{Cx+*RX%4Sqw0pISfM15DD+&X$J_lm zVE9Mi8H(f${Tk!FiE$n@V!(g}cmlp0OlvolSFDapTCAo{#n!sIbO;p}x68q~!J>cv zTxL_1t^L++x7ZpIPQf-;OUs&%Z4wRRo+|ZLy~BrSFJ{)x!a6nZTDSD-KRHS>nQPP zifoNqYI82BHkc}@2hTZF{}5En3A9BS{d>P&Q<9jN+kn(lC1v34X7B$z;U`cMPB>E2 z^|iymb9eZB1wKDZ4`X>y#Gp~*^v5geeJry6T|Zc^BcNOE8Ov0t${vDXUdvz~mvFEC zpHeEaC!Ub!bQ{Bg02ubScD0YMX5Snb2bZQO$Z3}#W6uxaIm!^#rr{DE%5jHeQdnXrPX8`g00n9)9Fn+^TvLvAgt7xKi?4R{~SeMdH>If zR_!Q<7O7VjBhejE%oS7I8VNN<_5?l?h2u!0UKR*!BCeA-=MX!VO4OY*GTucsgv&U{ zvOwILO@V?RFJ5W_j=;X=7<>Lln#&)kjs-=yQ}a~(dR7JXbczm{Tf64X zza0f{_FX@_da1`)F{3me z2=i$_WQNfbP%B?5#I8Bxkt*xE6dMSfhoUc5dhU12n0rvwJ^REGb%8N?2x7`(l0lPB zxQFgP^Ltx`ocT-4*v_?!BU=*YHbup;WQK6l6BN*DSf$N+F%YG|VW7cQaFP-6aP^0j zbd7lQdN`U#dfMB;d}f1w&#@`sgmvfPaVJw{@vd&mBs6bXM0ry*;s5h{)d=wV3HxP(V z-hl`JDzdoUKm`UA;50*E!Gs=jn16VXP^!RYy*-@TYX*-Y*;QTEU-0#PUANVxu1`TA zIkb#(j^fHT1bjE{ZWgB=bNe8~ghgVVQNtsl$jdNg;H&u#71P?vrL!DPNWGD(%9aU2 z?ku#}oE1ry7SBZOltG}-?H$?QlrD|e`oJ2#ewPosyhazU_S+Q7048wSZ03jd0iSrPCjjY#G#$;pwO;~1 z!A7ZU@emTa525qHW}9t-04+UV9U@BF3HMRN%J?D7c0-z;iMVp}xKG?38lTy#Z$}o> ztLz~tich{LKAu3o?=4^Y$nL{#PaYiolcf?YJlWJR8hC9YxVK!86mx% zL7--qp!=nOJ4{1E3tCo6Q`y}6S$_bv>lkcA-v3|8@SewAjmQF=0p#o5`$w@?>>eaP zb2%SCgNbigUK$hqXH;3dkiniMfxVjPU$<}BBEyjpYImI0I?PcNfiMVn=|(hxVPN2< z4c$bsG6u}s6$p6lNiv2(!q%5Xw zu=NDaSdp@@KT83ewp8T7W&P)=z{8L{j*x)DCH}YFcFjwMd0$H6wT4Bm9(g;vInRRL zT^mjd6GJ?C$L*aaMtT((9e%hH^7`?V$!VLmbPyymn}y`IlkLn_Auc+_qr-kjdOAYR zD1Hot9LhtZ;dJ21Dke?*`^TI^Q$0?L`kvs0|47dh^7HRblCp_Y_EY+;j(JlU#Jc33 z?+AY(G~~Xwig{=ysguQh%;>Ep-xJEt*OOpRpYO}ppr-}>hI(^@sR|xZ==~{3y%q84 zukgbZR6eLH+!|?xk{7?NS`1dm=#gexUyd4!L8q0>nnMsctZ%gm5%wvCAJ$rP-V8Oc z7S)GpMY=nV>a=v|M3A2OWDAkWSwYlfAu=D7&-%0F^&b}#x4Ni>$nXjH>6k>g@jaYd zPw$Mx6F$>xc!TYvi2_Qhn?pi z>N(%0xERZQL#Wq%1lg<~$&4mqDh}+EFFA&FA|>Q$SZ$>mZD%gy6#vkBwN~p&YrGre z2lWZ{(-`YAM?jWTy_DHKrkO1apd)@|8`oHv?DVssp&MMFL5N-(&5ud)#Vd6#cO3@t zKvX{A*T@`YrHrox1oeBo+auLyxmZIiLujt%178y$V=Z6M)cKdp7;U$V*+e}_n9y~J zWu&w{e8}_^%Dp(^GN&*Dm2CC&p)2<__`L<@bW=SZ;vP?P?fJd=^Ioq?=c7-}S+u4K zVHXxp1wM(fP%>{4`QvgWZ#(}o2`uT)LQKGh!yrPzrdXJf+SE`eKw>P7IND&tUnHLe z^354REQrtj(+O22IV>Twyt5RfRHosn@yb6ml^gE@r1guu?z;IToLbku*q4&iqI1Z* z->#8b&2cP4#q4wBi(+B|QXtjp8+b>=3GlW4k{9PTi#{qV~z z`~m`(-y0K_xEWDzGf-)W%^gI!JE;?JV`pz!M~2vJfwH04K8wC}Q3^ny0Luj8#U+bn zloM;>s$73C8=Ch0ir)UWH;2E!^g`UwOw&teVCleP+5_KD z>+`4d^%MHu%`=7ZC86guc`?&Y^>YeODS5Zd5NnqpNz*LfXZ^tu001?GKcsDH@+jzX z(=13n9|&%1E#&Goe(;t8w;(2JUA=7Re84u7WF7c^~ryw(!@cbzRa=8P9K zbw*3k5RV#{IPe@&^D{O_X5hPN9;oF=f3XrYMJ9JtGcOC&&IV=EFNx9u6Kfq_^qWZm zkO+b)qPL@F-vrAx+DdC5)>5R6Kx-T{Wvq43e6iL+0HhH(Ewl!uf#_q4-ZuNp@kW~@ zwFZpoC93b)uLv~lFqH#w@0E!9#h5Ah6Ts0wUR^UqM*vVk5b@`_{WZr-04xU2T=gqq z#=Ip1ONzjw0W{GPG;K)@x`Z*Cs7->avpai46^;&5gQy2J7u!DkHY8%t0f#aJjt#x=E&_G5Dna}2L{5^dRK4%al z1nfF9+|VfRK>nCIt^rb=jrTo??R;k@RFLhMxd{n2)M|xL{Zi+( z)r@rtnnI&hAi&LnLueW@g~gb&34jwcQ`UAmyoOYp?Rqm)x9xK&bKM3|c3la2W%PL) zPC*?#0TAo}kc>8A?V*7&5ii*u&uYl7A_4ErNKNNLoqHefv}(4YmaNu$d=2??l)A_> z)N_qGGgbq(;C^TX-5S!6hBTxh4QWV28q$!4G-MZ+{||x!Am}*$Z#4h_002ovPDHLk FV1ku2wG;pV literal 0 HcmV?d00001 diff --git a/template/src/assets/images/user/avatar-1.jpg b/src/assets/images/user/avatar-1.jpg similarity index 100% rename from template/src/assets/images/user/avatar-1.jpg rename to src/assets/images/user/avatar-1.jpg diff --git a/template/src/assets/images/user/avatar-2.jpg b/src/assets/images/user/avatar-2.jpg similarity index 100% rename from template/src/assets/images/user/avatar-2.jpg rename to src/assets/images/user/avatar-2.jpg diff --git a/template/src/assets/images/user/avatar-3.jpg b/src/assets/images/user/avatar-3.jpg similarity index 100% rename from template/src/assets/images/user/avatar-3.jpg rename to src/assets/images/user/avatar-3.jpg diff --git a/template/src/assets/images/user/avatar-4.jpg b/src/assets/images/user/avatar-4.jpg similarity index 100% rename from template/src/assets/images/user/avatar-4.jpg rename to src/assets/images/user/avatar-4.jpg diff --git a/template/src/assets/images/user/avatar-5.jpg b/src/assets/images/user/avatar-5.jpg similarity index 100% rename from template/src/assets/images/user/avatar-5.jpg rename to src/assets/images/user/avatar-5.jpg diff --git a/template/src/assets/scss/partials/_general.scss b/src/assets/scss/partials/_general.scss similarity index 89% rename from template/src/assets/scss/partials/_general.scss rename to src/assets/scss/partials/_general.scss index 002779c..b5f5236 100644 --- a/template/src/assets/scss/partials/_general.scss +++ b/src/assets/scss/partials/_general.scss @@ -19,8 +19,9 @@ body { a { &:hover { outline: none; - text-decoration: none; } + + text-decoration: none; } h1, @@ -65,6 +66,10 @@ strong { font-weight: 400; } +label { + margin-bottom: 0.5rem; +} + .img-radius { border-radius: 50%; } @@ -92,11 +97,13 @@ strong { .theme-bg2 { background: $theme-color2; } + /* ========== card css start =========== */ .anim-rotate { animation: anim-rotate 1s linear infinite; } + @keyframes anim-rotate { 100% { transform: rotate(360deg); @@ -106,6 +113,7 @@ strong { .anim-close-card { animation: anim-close-card 1.4s linear; } + @keyframes anim-close-card { 100% { opacity: 0.3; @@ -123,17 +131,13 @@ p.text-muted { border: none; margin-bottom: 30px; transition: all 0.5s ease-in-out; - + --bs-card-title-color: #111; .card-header { background-color: transparent; border-bottom: 1px solid #f1f1f1; padding: 20px 25px; position: relative; - + .card-block, - + .card-body { - } - h5 { margin-bottom: 0; color: #000; @@ -170,6 +174,7 @@ p.text-muted { float: right; padding: 0; position: absolute; + @media only screen and (max-width: 575px) { display: none; } @@ -248,11 +253,13 @@ p.text-muted { border-radius: 0; } } + /* ========== scrollbar End =========== */ .scroll-y { z-index: 1027; } + /* ========== scrollbar End =========== ========== card css End =========== ================================ Dropdown Start ===================== */ @@ -268,7 +275,7 @@ p.text-muted { content: '\63'; font-family: 'pct'; position: absolute; - left: 15px; + left: 115px; top: -5px; z-index: 1001; font-size: 40px; @@ -328,17 +335,20 @@ p.text-muted { } } } + /* ================================ Dropdown End ===================== */ @media (min-width: 1600px) { .container { max-width: 1540px; } } + @media (max-width: 992px) { .container { max-width: 100%; } } + /* ======================================================== =============== document ====================== ======================================================== @@ -386,6 +396,7 @@ p.text-muted { margin: 1rem; border: solid #ddd; border-width: 0.2rem 0 0; + @media only screen and (max-height: 575px) { padding: 1.5rem; margin-right: 0; @@ -393,6 +404,7 @@ p.text-muted { border-width: 0.2rem; } } + /* Example modals */ .modal { @@ -427,6 +439,7 @@ p.text-muted { margin-left: auto; } } + /* Example tabbable tabs */ .bd-example-tabs .nav-tabs { @@ -441,6 +454,7 @@ p.text-muted { margin-bottom: 1rem; background-color: #f3f2fb; -ms-overflow-style: -ms-autohiding-scrollbar; + @media only screen and (max-height: 575px) { padding: 1.5rem; } @@ -449,6 +463,7 @@ p.text-muted { .bd-content .highlight { margin-right: 15px; margin-left: 15px; + @media only screen and (max-height: 575px) { margin-right: 0; margin-left: 0; @@ -518,6 +533,7 @@ p.text-muted { opacity: 1; } } + /* Modal */ .datta-example-modal { @@ -548,6 +564,7 @@ p.text-muted { padding: 50px; height: 100vh; overflow: auto; + > pre { overflow: hidden; width: fit-content; @@ -614,10 +631,12 @@ p.text-muted { opacity: 0.9; } } + /* Code */ .cui-bottom-spacer { height: 12rem; } + /* editor style for model */ .hljs { padding: 0.5em; @@ -693,11 +712,13 @@ p.text-muted { .hljs-link { text-decoration: underline; } + /* ================================ md animated mode start ===================== */ .md-show.md-effect-12 ~ .md-overlay { background: $theme-color; } + /* ================================ md animated mode End ===================== */ /* ================================ range slider Start ===================== */ @@ -728,22 +749,7 @@ p.text-muted { } } /* ================================ range slider End ===================== */ -/* ================================ owl-carousel slider Start ===================== */ - -.owl-carousel { - .owl-nav { - button { - &.owl-next, - &.owl-prev { - padding: 3px 9px; - } - } - } - button.owl-dot { - } -} -/* ================================ owl-carousel slider End ===================== */ /* ================================ Bootstrap tags input Start ===================== */ .bootstrap-tagsinput { @@ -770,12 +776,14 @@ p.text-muted { } } } + /* ================================ Bootstrap tags input End ===================== */ /* ================================ Multi-Select Start ===================== */ .ms-container { width: 100%; } + /* ================================ Multi-Select End ===================== */ /* ================================ Blockquote Start ===================== */ @@ -788,6 +796,7 @@ p.text-muted { border-right: 0.25rem solid $theme-border; } } + /* ================================ Blockquote End ===================== */ /* ================================ animation start ===================== */ @@ -797,6 +806,7 @@ p.text-muted { margin-bottom: 30px; box-shadow: 0 10px 20px 0 rgba(0, 0, 0, 0.2); } + /* ================================ animation End ===================== */ /* ================================ browser warning Start ===================== */ @@ -857,6 +867,7 @@ p.text-muted { } } } + /* ================================ browser warning End ===================== */ /* material icon for material datetime picker */ /* fallback */ @@ -882,4 +893,118 @@ p.text-muted { -webkit-font-feature-settings: 'liga'; -webkit-font-smoothing: antialiased; } + /* material icon for material datetime picker */ +.btn-link { + text-decoration: none; +} + +.react-datepicker-wrapper { + display: block !important; +} + +.table-dark { + --bs-table-bg: #37474f; +} + +.table-info, +.table-info > td, +.table-info > th { + --bs-table-bg: #bee5eb; + background-color: #bee5eb; +} + +.table { + --bs-table-striped-bg: rgba(4, 169, 245, 0.05); +} + +.table-hover tbody tr:hover { + color: #212529; + background: rgba(4, 169, 245, 0.05); + + > * { + --bs-table-color-state: #212529; + } +} + +.table-hover > tbody > tr:hover > * { + --bs-table-bg-state: rgba(4, 169, 245, 0.05); +} + +.btn-check:checked + .btn:not([class*='btn-']), +:not(.btn-check) + .btn:active, +.btn:first-child:active, +.btn.active, +.btn.show { + --bs-btn-active-bg: #04a9f5; + --bs-btn-active-border-color: #04a9f5; +} + +.invoice-table.table tr td { + background: transparent; +} + +.recent-users { + tr { + td { + &:first-child { + width: 60px; + padding-left: 20px; + padding-right: 0; + } + + &:last-child { + text-align: center; + } + } + } +} + +.blockquote-footer { + margin-top: 0; +} + +.adv-task-board { + header { + display: flex; + align-items: center; + + span { + span { + margin-right: 8px; + } + } + } +} + +.swatches-picker, +.photoshop-picker, +.hue-picker, +.alpha-picker { + width: 100% !important; +} + +.grid figure.effect-moses figcaption { + @media (max-width: 575px) { + padding: 8px !important; + + h2 { + font-size: 20px; + } + } +} + +.btn.text-secondary.btn-link { + &:active, + &.active, + &.show { + color: #fff !important; + } +} + +.alert-inverse { + .btn-close { + color: $yiq-light-color !important; + filter: invert(1) grayscale(100%) brightness(200%) !important; + } +} diff --git a/template/src/assets/scss/partials/_generic.scss b/src/assets/scss/partials/_generic.scss similarity index 100% rename from template/src/assets/scss/partials/_generic.scss rename to src/assets/scss/partials/_generic.scss diff --git a/template/src/assets/scss/partials/_variables.scss b/src/assets/scss/partials/_variables.scss similarity index 96% rename from template/src/assets/scss/partials/_variables.scss rename to src/assets/scss/partials/_variables.scss index d1dd39a..c1600ee 100644 --- a/template/src/assets/scss/partials/_variables.scss +++ b/src/assets/scss/partials/_variables.scss @@ -40,7 +40,7 @@ $warning-color: #f4c22b; $danger-color: #f44236; $success-color: #1de9b6; $purple-color: #a389d4; -$info-color: #3ebfea; +$info-color: #17a2b8; $secondary-color: #748892; $default-color: #d6d6d6; $light-color: #f2f2f2; @@ -120,3 +120,12 @@ $theme-color-interval: 8% !default; $alert-bg-level: -10 !default; $alert-border-level: -9 !default; $alert-color-level: 6 !default; + +:root { + --bs-body-color: #888; +} + +.breadcrumb { + --bs-breadcrumb-padding-x: 1rem; + --bs-breadcrumb-padding-y: 0.75rem; +} diff --git a/template/src/assets/scss/partials/font/_cryptofont.scss b/src/assets/scss/partials/font/_cryptofont.scss similarity index 100% rename from template/src/assets/scss/partials/font/_cryptofont.scss rename to src/assets/scss/partials/font/_cryptofont.scss diff --git a/template/src/assets/scss/partials/font/_datta-icon.scss b/src/assets/scss/partials/font/_datta-icon.scss similarity index 100% rename from template/src/assets/scss/partials/font/_datta-icon.scss rename to src/assets/scss/partials/font/_datta-icon.scss diff --git a/template/src/assets/scss/partials/font/_feather.scss b/src/assets/scss/partials/font/_feather.scss similarity index 100% rename from template/src/assets/scss/partials/font/_feather.scss rename to src/assets/scss/partials/font/_feather.scss diff --git a/template/src/assets/scss/partials/font/_flaticon.scss b/src/assets/scss/partials/font/_flaticon.scss similarity index 100% rename from template/src/assets/scss/partials/font/_flaticon.scss rename to src/assets/scss/partials/font/_flaticon.scss diff --git a/template/src/assets/scss/partials/font/_fontawesome.scss b/src/assets/scss/partials/font/_fontawesome.scss similarity index 100% rename from template/src/assets/scss/partials/font/_fontawesome.scss rename to src/assets/scss/partials/font/_fontawesome.scss diff --git a/template/src/assets/scss/partials/font/_next-icon.scss b/src/assets/scss/partials/font/_next-icon.scss similarity index 100% rename from template/src/assets/scss/partials/font/_next-icon.scss rename to src/assets/scss/partials/font/_next-icon.scss diff --git a/template/src/assets/scss/partials/font/_theme-font.scss b/src/assets/scss/partials/font/_theme-font.scss similarity index 100% rename from template/src/assets/scss/partials/font/_theme-font.scss rename to src/assets/scss/partials/font/_theme-font.scss diff --git a/template/src/assets/scss/partials/font/fonts/Flaticon.eot b/src/assets/scss/partials/font/fonts/Flaticon.eot similarity index 100% rename from template/src/assets/scss/partials/font/fonts/Flaticon.eot rename to src/assets/scss/partials/font/fonts/Flaticon.eot diff --git a/template/src/assets/scss/partials/font/fonts/Flaticon.svg b/src/assets/scss/partials/font/fonts/Flaticon.svg similarity index 100% rename from template/src/assets/scss/partials/font/fonts/Flaticon.svg rename to src/assets/scss/partials/font/fonts/Flaticon.svg diff --git a/template/src/assets/scss/partials/font/fonts/Flaticon.ttf b/src/assets/scss/partials/font/fonts/Flaticon.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/Flaticon.ttf rename to src/assets/scss/partials/font/fonts/Flaticon.ttf diff --git a/template/src/assets/scss/partials/font/fonts/Flaticon.woff b/src/assets/scss/partials/font/fonts/Flaticon.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/Flaticon.woff rename to src/assets/scss/partials/font/fonts/Flaticon.woff diff --git a/template/src/assets/scss/partials/font/fonts/Flaticon.woff2 b/src/assets/scss/partials/font/fonts/Flaticon.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/Flaticon.woff2 rename to src/assets/scss/partials/font/fonts/Flaticon.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/cryptocoins.ttf b/src/assets/scss/partials/font/fonts/cryptocoins.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/cryptocoins.ttf rename to src/assets/scss/partials/font/fonts/cryptocoins.ttf diff --git a/template/src/assets/scss/partials/font/fonts/cryptocoins.woff b/src/assets/scss/partials/font/fonts/cryptocoins.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/cryptocoins.woff rename to src/assets/scss/partials/font/fonts/cryptocoins.woff diff --git a/template/src/assets/scss/partials/font/fonts/cryptocoins.woff2 b/src/assets/scss/partials/font/fonts/cryptocoins.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/cryptocoins.woff2 rename to src/assets/scss/partials/font/fonts/cryptocoins.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/fa-brands-400.eot b/src/assets/scss/partials/font/fonts/fa-brands-400.eot similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-brands-400.eot rename to src/assets/scss/partials/font/fonts/fa-brands-400.eot diff --git a/template/src/assets/scss/partials/font/fonts/fa-brands-400.svg b/src/assets/scss/partials/font/fonts/fa-brands-400.svg similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-brands-400.svg rename to src/assets/scss/partials/font/fonts/fa-brands-400.svg diff --git a/template/src/assets/scss/partials/font/fonts/fa-brands-400.ttf b/src/assets/scss/partials/font/fonts/fa-brands-400.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-brands-400.ttf rename to src/assets/scss/partials/font/fonts/fa-brands-400.ttf diff --git a/template/src/assets/scss/partials/font/fonts/fa-brands-400.woff b/src/assets/scss/partials/font/fonts/fa-brands-400.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-brands-400.woff rename to src/assets/scss/partials/font/fonts/fa-brands-400.woff diff --git a/template/src/assets/scss/partials/font/fonts/fa-brands-400.woff2 b/src/assets/scss/partials/font/fonts/fa-brands-400.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-brands-400.woff2 rename to src/assets/scss/partials/font/fonts/fa-brands-400.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/fa-regular-400.eot b/src/assets/scss/partials/font/fonts/fa-regular-400.eot similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-regular-400.eot rename to src/assets/scss/partials/font/fonts/fa-regular-400.eot diff --git a/template/src/assets/scss/partials/font/fonts/fa-regular-400.svg b/src/assets/scss/partials/font/fonts/fa-regular-400.svg similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-regular-400.svg rename to src/assets/scss/partials/font/fonts/fa-regular-400.svg diff --git a/template/src/assets/scss/partials/font/fonts/fa-regular-400.ttf b/src/assets/scss/partials/font/fonts/fa-regular-400.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-regular-400.ttf rename to src/assets/scss/partials/font/fonts/fa-regular-400.ttf diff --git a/template/src/assets/scss/partials/font/fonts/fa-regular-400.woff b/src/assets/scss/partials/font/fonts/fa-regular-400.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-regular-400.woff rename to src/assets/scss/partials/font/fonts/fa-regular-400.woff diff --git a/template/src/assets/scss/partials/font/fonts/fa-regular-400.woff2 b/src/assets/scss/partials/font/fonts/fa-regular-400.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-regular-400.woff2 rename to src/assets/scss/partials/font/fonts/fa-regular-400.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/fa-solid-900.eot b/src/assets/scss/partials/font/fonts/fa-solid-900.eot similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-solid-900.eot rename to src/assets/scss/partials/font/fonts/fa-solid-900.eot diff --git a/template/src/assets/scss/partials/font/fonts/fa-solid-900.svg b/src/assets/scss/partials/font/fonts/fa-solid-900.svg similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-solid-900.svg rename to src/assets/scss/partials/font/fonts/fa-solid-900.svg diff --git a/template/src/assets/scss/partials/font/fonts/fa-solid-900.ttf b/src/assets/scss/partials/font/fonts/fa-solid-900.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-solid-900.ttf rename to src/assets/scss/partials/font/fonts/fa-solid-900.ttf diff --git a/template/src/assets/scss/partials/font/fonts/fa-solid-900.woff b/src/assets/scss/partials/font/fonts/fa-solid-900.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-solid-900.woff rename to src/assets/scss/partials/font/fonts/fa-solid-900.woff diff --git a/template/src/assets/scss/partials/font/fonts/fa-solid-900.woff2 b/src/assets/scss/partials/font/fonts/fa-solid-900.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/fa-solid-900.woff2 rename to src/assets/scss/partials/font/fonts/fa-solid-900.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/feather.eot b/src/assets/scss/partials/font/fonts/feather.eot similarity index 100% rename from template/src/assets/scss/partials/font/fonts/feather.eot rename to src/assets/scss/partials/font/fonts/feather.eot diff --git a/template/src/assets/scss/partials/font/fonts/feather.svg b/src/assets/scss/partials/font/fonts/feather.svg similarity index 100% rename from template/src/assets/scss/partials/font/fonts/feather.svg rename to src/assets/scss/partials/font/fonts/feather.svg diff --git a/template/src/assets/scss/partials/font/fonts/feather.ttf b/src/assets/scss/partials/font/fonts/feather.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/feather.ttf rename to src/assets/scss/partials/font/fonts/feather.ttf diff --git a/template/src/assets/scss/partials/font/fonts/feather.woff b/src/assets/scss/partials/font/fonts/feather.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/feather.woff rename to src/assets/scss/partials/font/fonts/feather.woff diff --git a/template/src/assets/scss/partials/font/fonts/pct.eot b/src/assets/scss/partials/font/fonts/pct.eot similarity index 100% rename from template/src/assets/scss/partials/font/fonts/pct.eot rename to src/assets/scss/partials/font/fonts/pct.eot diff --git a/template/src/assets/scss/partials/font/fonts/pct.svg b/src/assets/scss/partials/font/fonts/pct.svg similarity index 100% rename from template/src/assets/scss/partials/font/fonts/pct.svg rename to src/assets/scss/partials/font/fonts/pct.svg diff --git a/template/src/assets/scss/partials/font/fonts/pct.ttf b/src/assets/scss/partials/font/fonts/pct.ttf similarity index 100% rename from template/src/assets/scss/partials/font/fonts/pct.ttf rename to src/assets/scss/partials/font/fonts/pct.ttf diff --git a/template/src/assets/scss/partials/font/fonts/pct.woff b/src/assets/scss/partials/font/fonts/pct.woff similarity index 100% rename from template/src/assets/scss/partials/font/fonts/pct.woff rename to src/assets/scss/partials/font/fonts/pct.woff diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z11lFc-K.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z11lFc-K.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z11lFc-K.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z11lFc-K.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1JlFc-K.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLEj6Z1xlFQ.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z11lFc-K.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z11lFc-K.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z11lFc-K.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z11lFc-K.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1JlFc-K.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1JlFc-K.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1JlFc-K.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1JlFc-K.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiByp8kv8JHgFVrLGT9Z1xlFQ.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJfecg.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJfecg.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJfecg.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJfecg.woff2 diff --git a/template/src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJnecmNE.woff2 b/src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJnecmNE.woff2 similarity index 100% rename from template/src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJnecmNE.woff2 rename to src/assets/scss/partials/font/fonts/poppins/pxiEyp8kv8JHgFVrJJnecmNE.woff2 diff --git a/src/assets/scss/partials/menu/_menu-lite.scss b/src/assets/scss/partials/menu/_menu-lite.scss new file mode 100644 index 0000000..dcbd88b --- /dev/null +++ b/src/assets/scss/partials/menu/_menu-lite.scss @@ -0,0 +1,1536 @@ +/* new logo start */ + +.b-brand { + display: flex; + align-items: center; + + .b-bg { + background: $theme-color; + border-radius: 10px; + width: 35px; + height: 35px; + display: inline-flex; + align-items: center; + justify-content: center; + + i { + color: #fff; + } + } + + .b-title { + margin-left: 10px; + font-weight: 100; + color: #fff; + font-size: 18px; + } +} + +.navbar-collapsed { + .b-brand .b-title { + transform: rotateY(-90deg); + transform-origin: 0 0; + opacity: 0; + transition: all 0.3s ease-in-out; + } + + .mobile-menu { + transform: rotateY(-90deg); + transform-origin: 0 0; + opacity: 0; + transition: all 0.3s ease-in-out; + } + + &:hover { + .b-brand .b-title { + transform: rotateY(0deg); + opacity: 1; + } + + .mobile-menu { + transition-delay: 0.3s; + transform: rotateY(0deg); + opacity: 1; + } + } +} + +/* header css start */ +.pcoded-header { + z-index: 1028; + position: relative; + display: flex; + min-height: $header-height; + padding: 0; + position: relative; + top: 0; + background: transparent; + color: $header-light-text-color; + width: calc(100% - #{$Menu-width}); + margin-left: $Menu-width; + transition: all 0.3s ease-in-out; + + .m-header { + display: none; + + .logo-dark, + .logo-thumb { + display: none; + } + } + + .input-group { + background: transparent; + + .input-group-text { + margin-right: 0; + } + } + + .input-group { + background: transparent; + } + + .input-group .input-group-text, + a, + .btn, + &.dropdown-toggle { + color: $header-light-text-color; + + &:hover { + color: $primary-color; + } + } + + .navbar-nav { + padding-left: 0; + list-style: none; + margin-bottom: 0; + display: inline-block; + + > li { + line-height: $header-height; + display: inline-block; + padding: 0 12px; + + .nav-link { + padding: 0; + } + + &:first-child { + padding-left: 25px; + } + + &:last-child { + padding-right: 40px; + } + } + } + + .mr-auto { + .dropdown-menu { + margin-left: -20px; + } + } + + .ml-auto { + float: right; + } + + .main-search { + .input-group { + border-radius: 20px; + padding: 0; + display: flex; + align-items: center; + + .form-control, + .input-group-text { + background: transparent; + border: none; + border-radius: 0; + padding: 0; + } + + .search-close { + display: none; + } + + .search-btn { + border-radius: 50%; + padding: 0; + background: transparent; + border-color: transparent; + box-shadow: none; + } + + .form-control { + transition: all 0.3s ease-in-out; + width: 0; + font-size: 14px; + } + + .form-control, + .search-btn { + &:active, + &:focus, + &:hover { + outline: none; + box-shadow: none; + } + } + } + + &.open { + .input-group { + background: #fff; + border: 1px solid #f1f1f1; + box-shadow: 0 6px 12px -5px rgba(65, 76, 78, 0.08); + padding: 5px 5px 5px 20px; + + .search-close { + display: flex; + } + + .search-btn { + padding: 5px; + margin-left: 5px; + background: $primary-color; + border-color: $primary-color; + + .input-group-text { + color: #fff; + } + } + + .form-control { + transition: all 0.3s ease-in-out; + width: 0; + } + + .form-control, + .search-btn { + &:active, + &:focus, + &:hover { + outline: none; + box-shadow: none; + } + } + } + } + } + + .dropdown { + .dropdown-toggle { + line-height: $header-height; + display: inline-block; + padding-right: 15px; + + &.show, + &:active { + background: transparent; + } + + &:after { + content: '\e842'; + font-family: 'feather'; + font-size: 15px; + border: none; + position: absolute; + top: 0; + right: 0; + } + } + + .dropdown-menu { + position: absolute; + border: none; + margin-top: -6px; + min-width: 290px; + + &.show { + &:before { + display: none; + } + } + + li { + line-height: 1.2; + + a { + padding: 10px; + font-size: 14px; + } + + &.active, + &:active, + &:focus, + &:hover { + a { + color: $theme-font-color; + } + } + } + } + + &.show { + &:before { + content: '\63'; + font-family: 'pct'; + position: absolute; + left: -9px; + top: $header-height - 8; + z-index: 1001; + font-size: 40px; + line-height: 0; + color: #fff; + text-shadow: 0 -2px 2px rgba(65, 76, 78, 0.12); + } + } + + .notification { + width: 350px; + padding: 0; + line-height: 1.4; + overflow: hidden; + + .noti-head { + border-bottom: 1px solid #f1f1f1; + padding: 15px 20px; + + a { + text-decoration: underline; + font-size: 13px; + } + } + + .noti-body { + padding: 0; + + img { + width: 40px; + margin-right: 20px; + } + + li { + padding: 15px 20px; + transition: all 0.3s ease-in-out; + + &.n-title { + padding-bottom: 0; + + p { + margin-bottom: 5px; + } + } + + &.notification:hover { + background: transparentize($primary-color, 0.9); + } + + p { + margin-bottom: 5px; + font-size: 13px; + + strong { + color: #222; + } + } + + .n-time { + font-size: 80%; + float: right; + } + } + } + + .noti-footer { + border-top: 1px solid #f1f1f1; + padding: 15px 20px; + text-align: center; + + a { + text-decoration: underline; + font-size: 13px; + } + } + + ul { + padding-left: 0; + margin-bottom: 0; + list-style: none; + + li { + padding: 20px 15px; + } + } + } + + .profile-notification { + padding: 0; + line-height: 1.4; + overflow: hidden; + + .pro-head { + color: #fff; + border-radius: 0.25rem 0.25rem 0 0; + padding: 15px; + position: relative; + background: $primary-color; + + img { + width: 40px; + margin-right: 10px; + } + + .dud-logout { + color: #fff; + padding-right: 0; + position: absolute; + right: 0; + top: 0; + height: 100%; + width: 40px; + display: flex; + align-items: center; + justify-content: center; + } + } + + .pro-body { + padding: 20px 0; + margin-bottom: 0; + list-style: none; + + li { + a { + color: $theme-font-color; + font-size: 14px; + padding: 10px 20px; + + i { + margin-right: 10px; + } + } + + &.active, + &:active, + &:focus, + &:hover { + background: transparentize($primary-color, 0.9); + + > a { + background: transparent; + } + } + } + } + } + + &.drp-user.show { + &:before { + color: $primary-color; + } + } + } +} + +/* header css end */ +/* menu[ vertical ] css start */ +.mobile-menu { + display: flex; + align-items: center; + justify-content: center; + width: 37px; + height: $header-height; + position: absolute; + right: 0; + top: 0; + padding: 0 10px; + + span { + position: relative; + display: block; + width: 100%; + height: 2.8px; + background-color: #fff; + transition: all 0.3s ease-in-out; + backface-visibility: hidden; + border-radius: 2px; + + &:after, + &:before { + content: ''; + position: absolute; + left: 0; + height: 2.8px; + background-color: #fff; + transition: all 0.3s; + backface-visibility: hidden; + border-radius: 2px; + } + + &:after { + top: 5px; + width: 70%; + } + + &:before { + top: -5px; + width: 40%; + } + } + + &.on { + span { + background-color: transparent; + + &:after, + &:before { + height: 2px; + width: 100%; + } + + &:before { + transform: rotate(45deg) translate(4px, 4px); + } + + &:after { + transform: rotate(-45deg) translate(3px, -3px); + } + } + } +} + +.navbar-brand { + background: $menu-dark-background; + font-size: 1.25rem; +} + +.pcoded-header, +.pcoded-main-container { + &:before { + content: ''; + transition: all 0.3s ease-in-out; + } + + @media screen and (max-width: 991px) { + .pcoded-content .pcoded-inner-content { + margin-top: 70px; + } + } +} + +.pcoded-navbar { + display: block; + z-index: 1029; + position: fixed; + transition: all 0.3s ease-in-out; + box-shadow: 1px 0 20px 0 rgb(63, 77, 103); + + ul { + padding-left: 0; + list-style: none; + margin-bottom: 0; + } + + .datta-scroll.navbar-content { + height: calc(100vh - #{$header-height}); + } + + .header-logo { + position: relative; + align-items: center; + display: inline-flex; + float: left; + height: $header-height; + text-align: center; + width: $Menu-width; + margin-right: 0; + padding: 10px 20px; + transition: all 0.3s ease-in-out; + + .logo-dark { + display: none; + } + + .logo-thumb { + transform: rotateY(-90deg); + opacity: 0; + position: absolute; + transition: unset; + } + + + .datta-scroll { + float: left; + display: inline-block; + } + } + + .mobile-menu { + display: flex; + align-items: center; + justify-content: center; + width: 37px; + height: $header-height; + position: absolute; + right: 10px; + top: 0; + padding: 0 10px; + transition: all 0.3s ease-in-out; + + span { + position: relative; + display: block; + width: 100%; + height: 2.8px; + background-color: $menu-dark-text-color; + transition: all 0.3s ease-in-out; + backface-visibility: hidden; + border-radius: 2px; + + &:after, + &:before { + content: ''; + position: absolute; + left: 0; + height: 2.8px; + background-color: $menu-dark-text-color; + transition: all 0.3s; + backface-visibility: hidden; + border-radius: 2px; + } + + &:after { + top: 5px; + width: 70%; + } + + &:before { + top: -5px; + width: 40%; + } + } + + &.on { + span { + background-color: transparent; + + &:after, + &:before { + height: 2px; + width: 100%; + } + + &:before { + transform: rotate(45deg) translate(4px, 4px); + } + + &:after { + transform: rotate(-45deg) translate(3px, -3px); + } + } + } + } + + .pcoded-badge { + color: #fff; + font-size: 75%; + position: absolute; + right: 30px; + top: 8px; + padding: 2px 7px; + border-radius: 2px; + } + + .pcoded-inner-navbar { + flex-direction: column; + + > li { + > a { + .pcoded-badge { + top: 12px; + } + } + } + + li { + position: relative; + + > a { + text-align: left; + padding: 7px 15px; + margin: 5px 0 0; + display: block; + border-radius: 0; + position: relative; + + .pcoded-mtext { + position: relative; + } + + > .pcoded-micon { + font-size: 1rem; + padding: 4px 7px; + margin-right: 7px; + border-radius: 4px; + width: 30px; + display: inline-flex; + align-items: center; + height: 30px; + text-align: center; + + + .pcoded-mtext { + position: absolute; + top: 11px; + } + } + } + + &.pcoded-hasmenu { + > a { + &:after { + content: '\e844'; + font-family: 'feather'; + font-size: 15px; + border: none; + position: absolute; + top: 11px; + right: 20px; + transition: 0.3s ease-in-out; + } + } + + .pcoded-hasmenu { + > a { + &:after { + top: 6px; + } + } + } + + &.pcoded-trigger { + > a { + &:after { + transform: rotate(90deg); + } + } + } + + .pcoded-submenu { + display: none; + } + + &.pcoded-trigger { + > .pcoded-submenu { + display: block; + } + + > a { + position: relative; + } + } + + .pcoded-submenu { + li { + > a { + text-align: left; + padding: 7px 7px 7px 60px; + margin: 0; + display: block; + + &:before { + content: ''; + border-radius: 50%; + position: absolute; + top: 16px; + left: 35px; + width: 5px; + height: 5px; + } + } + + .pcoded-submenu { + > li { + > a { + padding: 7px 7px 7px 80px; + + &:before { + left: 55px; + } + } + } + } + } + } + } + + &.pcoded-menu-caption { + font-size: 10px; + font-weight: 600; + padding: 25px 20px 5px; + text-transform: uppercase; + position: relative; + } + + &.disabled { + > a { + cursor: default; + opacity: 0.5; + } + } + } + } + + width: $Menu-width; + height: 100vh; + top: 0; + background: $menu-dark-background; + color: $menu-dark-text-color; + + .pcoded-submenu { + background: darken($header-dark-background, 3%); + padding: 15px 0; + } + + a { + color: $menu-dark-text-color; + } + + .navbar-content, + .navbar-wrapper { + width: 100%; + height: 100%; + } + + &.navbar-collapsed { + width: $Menu-collapsed-width; + height: 100%; + transition: all 0.3s ease-in-out; + + .header-logo { + width: $Menu-collapsed-width; + + img { + transform: rotateY(-90deg); + transform-origin: 0 0; + opacity: 0; + transition: unset; + } + + .logo-thumb { + transform: rotateY(0deg); + transform-origin: 0 0; + opacity: 1; + left: calc((#{$Menu-collapsed-width} / 2) - 20px); + } + + .mobile-menu { + transform: rotateY(-90deg); + transform-origin: 0 0; + opacity: 0; + } + } + + .navbar-content { + &.ps { + overflow: visible; + } + } + + .pcoded-menu-caption { + position: relative; + width: 100%; + height: auto; + white-space: nowrap; + overflow: hidden; + + > label { + transform: rotateY(-90deg); + transform-origin: 0 0; + opacity: 0; + transition: all 0.3s ease-in-out; + } + + &:after { + content: ''; + position: absolute; + top: 25px; + left: 15px; + width: calc(100% - 30px); + height: 1px; + background: rgba(0, 0, 0, 0.1); + } + } + + .pcoded-inner-navbar { + > li { + > a { + z-index: 1026; + padding: 7px 25px; + + > .pcoded-mtext { + transform: rotateY(-90deg); + transform-origin: 0 0; + opacity: 0; + transition: all 0.3s ease-in-out; + } + } + + &.pcoded-hasmenu { + > a { + &:after { + right: 12px; + } + } + } + } + + > li { + &.pcoded-trigger { + .pcoded-submenu { + &:after { + content: ''; + position: absolute; + top: 49px; + left: calc(calc(#{$Menu-collapsed-width} / 2) - 3px); + width: 1px; + height: calc(100% - 49px); + background: transparentize($menu-dark-text-color, 0.8); + } + + li { + a { + color: transparent; + white-space: nowrap; + } + } + + .pcoded-submenu { + li { + a:before { + opacity: 0; + } + } + } + } + } + } + } + + ~ .pcoded-header { + width: calc(100% - #{$Menu-collapsed-width}); + } + + ~ .pcoded-header, + ~ .pcoded-main-container { + margin-left: $Menu-collapsed-width; + } + + .pcoded-badge { + transform: rotateX(-90deg); + transform-origin: 50% 50%; + opacity: 0; + transition: all 0.15s ease-in-out; + } + + &:hover { + width: $Menu-width !important; + + .pcoded-badge { + transition-delay: 0.3s; + transform: rotateX(0deg); + opacity: 1; + } + + .header-logo { + width: $Menu-width; + + img { + transform: rotateY(0deg); + opacity: 1; + } + + .logo-thumb { + transform: rotateY(-90deg); + opacity: 0; + } + + .mobile-menu { + display: flex; + right: 10px; + } + } + + .pcoded-menu-caption { + > label { + transform: rotateY(0deg); + opacity: 1; + } + + &:after { + background: transparent; + } + } + + .mobile-menu { + transform: rotateY(0deg); + opacity: 1; + } + + .pcoded-inner-navbar { + > li { + > a { + > .pcoded-mtext { + transform: rotateY(0deg); + opacity: 1; + + &:after { + opacity: 1; + visibility: visible; + } + } + } + + &.pcoded-hasmenu { + > a { + &:after { + transform: rotateX(0deg); + } + } + + &.pcoded-trigger { + > a { + &:after { + transform: rotateX(0deg) rotate(90deg); + } + } + } + } + } + + > li { + &.pcoded-trigger { + .pcoded-submenu { + &:after { + display: none; + } + + li { + a { + color: inherit; + } + } + + .pcoded-submenu { + li { + a:before { + opacity: 1; + } + } + } + } + } + } + } + } + } + + .pcoded-menu-caption { + color: #e8edf7; + } + + .pcoded-inner-navbar { + li > a { + &.active, + &:focus, + &:hover { + color: #1dc4e9; + } + + .pcoded-submenu > li { + &.active, + &:focus, + &:hover { + > a { + &:before { + background: #1dc4e9; + } + } + } + } + } + + > li { + &.active, + &.pcoded-trigger { + &:after { + content: ''; + background-color: #1dc4e9; + z-index: 1027; + position: absolute; + left: 0; + top: 5px; + width: 3px; + height: calc(100% - 5px); + } + + > a { + background: darken($menu-dark-background, 6%); + color: #fff; + } + } + } + + > .pcoded-menu-caption { + &.active, + &.pcoded-trigger { + &:after { + display: none; + } + } + } + } +} + +.pcoded-navbar { + &.mob-open, + &.navbar-collapsed:hover { + ~ .pcoded-header, + ~ .pcoded-main-container { + margin-left: $Menu-collapsed-width; + + &:before { + position: absolute; + top: 0; + left: 0; + width: 100%; + height: 100%; + background-color: rgba(0, 0, 0, 0.2); + z-index: 1; + } + } + } +} + +/* menu [ vertical ] css end */ + +/* main content start */ +.pcoded-content { + position: relative; + display: block; + padding: 30px; +} + +.pcoded-main-container { + position: relative; + margin: 0 auto; + display: block; + clear: both; + float: unset; + right: 0; + margin-left: $Menu-width; + min-height: 100vh; + transition: all 0.3s ease-in-out; +} + +/* main content end*/ +/* ========================== Rsponsive Menu start ====================== */ +.mob-toggler { + display: none; +} + +@media only screen and (max-width: 991px) { + .pcoded-header { + background: $header-dark-background; + color: $header-dark-text-color; + + .input-group-text, + a, + dropdown-toggle { + color: $header-light-text-color; + + &:hover { + color: $primary-color; + } + } + + > .collapse.show { + display: flex; + background: #fff; + box-shadow: 0 1px 20px 0 rgba(69, 90, 100, 0.08); + } + + .mob-toggler { + display: flex; + color: #fff; + position: absolute; + right: 60px; + } + + .dropdown-menu, + .dropdown-menu a, + .search-close .input-group-text { + color: $header-dark-background; + } + + .m-header { + display: flex; + justify-content: flex-start; + align-items: center; + width: 100%; + height: $header-height; + + .b-brand { + margin-left: 20px; + } + + .mobile-menu { + right: 20px; + } + } + + .full-screen { + display: none; + } + + .navbar-nav { + > li { + &:last-child { + padding-right: 60px; + } + } + } + } + + .pcoded-navbar { + margin-left: -#{$Menu-width}; + position: fixed; + height: 100%; + box-shadow: none; + + .datta-scroll.navbar-content { + height: 100%; + } + + ~ .pcoded-header, + ~ .pcoded-main-container { + margin-left: 0; + } + + ~ .pcoded-header { + width: 100%; + } + + .navbar-brand { + display: none; + } + + &.mob-open { + margin-left: 0; + + ~ .pcoded-header, + ~ .pcoded-main-container { + margin-left: 0; + } + } + } +} + +@media only screen and (max-width: 575px) { + .pcoded-header { + .navbar-nav { + > li:first-child { + padding-left: 0; + } + + > li:last-child { + padding-right: 20px; + } + } + + .navbar-nav.mr-auto { + li { + display: none; + + &.nav-item:not(.dropdown) { + display: block; + padding-right: 0; + } + } + } + + .dropdown { + &.show { + position: static; + + a:after { + display: none; + } + + &:before { + display: none; + } + } + + .notification { + width: 100%; + } + + .dropdown-menu { + width: 95%; + margin-left: auto; + margin-right: auto; + left: 0; + right: 0; + } + } + } + + .header-chat.open, + .header-user-list.open { + width: 280px; + } + + .pcoded-content { + padding: 30px 15px; + } + + .card { + margin-bottom: 15px; + } +} + +@media only screen and (max-width: 1200px) and (min-width: 768px) { + .pcoded-navbar { + .header-logo { + transition: none; + } + + &.navbar-collapsed { + transition: none; + + .header-logo { + img { + transition: none; + } + } + + .pcoded-menu-caption { + > label { + transition: none; + } + } + + .pcoded-inner-navbar { + > li { + > a { + > .pcoded-mtext { + transition: none; + } + } + + &.pcoded-hasmenu { + > a { + &:after { + transition: none; + transition-delay: unset; + } + } + } + } + } + + .pcoded-badge { + transition: none; + } + + &:hover { + .pcoded-badge { + transition-delay: unset; + } + } + } + } +} + +.pro-card { + background: #5c6a83; + border: #465673; + border-radius: 8px; +} + +/* ========================== Responsive Menu end ====================== */ + +/* =================================================================================== + ========================== Different Layout Styles Start ==================== + =================================================================================== + ====== [ light menu style start ] ======== */ +.pcoded-navbar.menu-light { + background-color: $menu-light-background; + color: $menu-light-text-color; + box-shadow: 7px 0 15px 0 rgba(69, 90, 100, 0.09); + + .header-logo { + background-color: $menu-dark-background; + + .logo-dark { + display: none; + } + + .logo-main { + display: block; + } + } + + .mobile-menu { + span { + background-color: $menu-dark-text-color; + + &:after, + &:before { + background-color: $menu-dark-text-color; + } + } + + &.on { + span { + background-color: transparent; + } + } + } + + .pcoded-submenu { + background: darken($menu-light-background, 1.5%); + } + + a { + color: $menu-light-text-color; + } + + &.navbar-collapsed { + .pcoded-menu-caption { + &:after { + background: rgba(0, 0, 0, 0.1); + } + } + + &:hover { + .pcoded-menu-caption { + &:after { + background: transparent; + } + } + } + } + + .pcoded-menu-caption { + color: $menu-light-text-color; + } + + .pcoded-inner-navbar { + > li { + &.active, + &.pcoded-trigger { + > a { + background: #f1f1f1; + color: #111; + } + } + } + } +} + +/* ====== [ light menu style end ] ======== */ + +/* ====== [ menu static start ] ======== */ +.pcoded-navbar.menupos-static { + position: absolute; + height: 100%; + min-height: 100%; + + .datta-scroll.navbar-content { + height: calc(100% - #{$header-height}); + min-height: 100vh; + } +} + +/* ====== [ menu static end ] ======== */ + +/* ========================== Different Layout Styles end ====================== */ +/* temp SCSS for document */ + +@each $value in $color-menu-name { + $i: index($color-menu-name, $value); + + .nav-link { + &.active.h-#{'' + $value} { + background: nth($color-menu-color, $i) !important; + } + } +} + +@media all and (-ms-high-contrast: none) { + .pcoded-header .dropdown.show::before { + line-height: 0.1; + } + + .pcoded-header .navbar-nav > li { + display: inline-flex; + } + + .pcoded-header .navbar-nav > li.dropdown { + display: inline-block; + } + + .dropdown-menu.show::before { + top: -2px; + } + + .pcoded-navbar.navbar-collapsed .pcoded-inner-navbar > li.pcoded-trigger .pcoded-submenu::after { + left: 40px; + } +} + +// === scroll bar ===== + +.navbar-content { + position: relative; +} + +.ps .ps__rail-x.ps--clicking, +.ps .ps__rail-x:focus, +.ps .ps__rail-x:hover, +.ps .ps__rail-y.ps--clicking, +.ps .ps__rail-y:focus, +.ps .ps__rail-y:hover { + background: transparent; +} + +.ps__thumb-y { + background: #2a3446; +} + +.ps__rail-y.ps--clicking .ps__thumb-y, +.ps__rail-y:focus > .ps__thumb-y, +.ps__rail-y:hover > .ps__thumb-y { + background: #222a38; +} + +/* nav-outside */ +.nav-outside { + position: absolute; + width: 100%; + height: 100%; +} + +// carousel-card +.carousel { + z-index: -1; +} + +// landing page nav +.landing-nav { + z-index: 1201; +} diff --git a/template/src/assets/scss/partials/mixins/_buttons.scss b/src/assets/scss/partials/mixins/_buttons.scss similarity index 100% rename from template/src/assets/scss/partials/mixins/_buttons.scss rename to src/assets/scss/partials/mixins/_buttons.scss diff --git a/template/src/assets/scss/partials/mixins/_function.scss b/src/assets/scss/partials/mixins/_function.scss similarity index 90% rename from template/src/assets/scss/partials/mixins/_function.scss rename to src/assets/scss/partials/mixins/_function.scss index a559cca..b9e08b1 100644 --- a/template/src/assets/scss/partials/mixins/_function.scss +++ b/src/assets/scss/partials/mixins/_function.scss @@ -2,7 +2,7 @@ $r: red($color); $g: green($color); $b: blue($color); - $yiq: calc((($r * 299) + ($g * 587) + ($b * 114)) / 1000); + $yiq: (($r * 299) + ($g * 587) + ($b * 114)) * 0.001; @if ($yiq >= $yiq-contrasted-threshold) { @return $yiq-dark-color; } @else { diff --git a/template/src/assets/scss/partials/mixins/_pagination.scss b/src/assets/scss/partials/mixins/_pagination.scss similarity index 100% rename from template/src/assets/scss/partials/mixins/_pagination.scss rename to src/assets/scss/partials/mixins/_pagination.scss diff --git a/src/assets/scss/partials/other/_chart.scss b/src/assets/scss/partials/other/_chart.scss new file mode 100644 index 0000000..899f9ea --- /dev/null +++ b/src/assets/scss/partials/other/_chart.scss @@ -0,0 +1,8 @@ +/** ===================== + Chart css start +========================== **/ +.nvtooltip { + position: fixed !important; +} + +/**====== Chart css end ======**/ diff --git a/template/src/assets/scss/partials/other/_chat.scss b/src/assets/scss/partials/other/_chat.scss similarity index 87% rename from template/src/assets/scss/partials/other/_chat.scss rename to src/assets/scss/partials/other/_chat.scss index 6f2a666..7a10c2a 100644 --- a/template/src/assets/scss/partials/other/_chat.scss +++ b/src/assets/scss/partials/other/_chat.scss @@ -133,7 +133,7 @@ height: 25px; width: 25px; position: absolute; - top: 35px; + top: 28px; right: 20px; border-radius: 100%; color: #fff; @@ -212,7 +212,7 @@ } .btn-attach { - border-radius: 50%; + border-radius: 50% !important; padding: 5px; margin-right: 5px; @@ -222,9 +222,9 @@ } .btn-send { - border-radius: 50%; + border-radius: 50% !important; padding: 10px; - margin-left: 5px; + margin-left: 5px !important; position: absolute; right: -45px; top: 2px; @@ -262,9 +262,9 @@ .h-list-body { .chat-messages { - padding-bottom: 20px; - padding-left: 15px; - padding-right: 15px; + padding-bottom: 20px !important; + padding-left: 15px !important; + padding-right: 15px !important; .photo-table { padding-right: 15px; @@ -368,56 +368,10 @@ } /* massage page start */ -.msg-card { - .msg-user-list { - height: calc(100vh - 300px); - } - - .msg-user-chat { - background: lighten($primary-color, 45%); - height: calc(100vh - 330px); - padding-top: 25px; - padding-bottom: 25px; - padding-left: 5px; - padding-right: 5px; - } - - .msg-block { - > .row { - > div { - &:before { - content: ''; - width: 1px; - height: 100%; - background: #f1f1f1; - position: absolute; - top: 0; - } - - &:first-child { - &:before { - right: 0; - } - } - - &:last-child { - &:before { - left: -1px; - } - } - } - } - } -} .main-friend-chat { padding-bottom: 15px; } -@media screen and (max-width: 991px) { - .msg-card .msg-block > .row > div:before { - background: none; - } -} /* massage page end */ /**====== Chat css end ======**/ diff --git a/template/src/assets/scss/partials/theme-elements/_authentication.scss b/src/assets/scss/partials/theme-elements/_authentication.scss similarity index 97% rename from template/src/assets/scss/partials/theme-elements/_authentication.scss rename to src/assets/scss/partials/theme-elements/_authentication.scss index aaba24c..df3c03a 100644 --- a/template/src/assets/scss/partials/theme-elements/_authentication.scss +++ b/src/assets/scss/partials/theme-elements/_authentication.scss @@ -126,7 +126,6 @@ /* image variant start */ .aut-bg-img { background-size: cover; - /*background-image: url('../../../images/bg-images/bg4.jpg');*/ // amit images background-repeat: no-repeat; background-position: center; } diff --git a/template/src/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss b/src/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss similarity index 89% rename from template/src/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss rename to src/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss index 89db2f3..ca3b638 100644 --- a/template/src/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss +++ b/src/assets/scss/partials/theme-elements/_breadcrumb-pagination.scss @@ -11,9 +11,6 @@ .breadcrumb-item { + .breadcrumb-item { color: $primary-color; - &::before { - /* content: $breadcrumb-divider; */ - } } &.active { diff --git a/template/src/assets/scss/partials/theme-elements/_button.scss b/src/assets/scss/partials/theme-elements/_button.scss similarity index 100% rename from template/src/assets/scss/partials/theme-elements/_button.scss rename to src/assets/scss/partials/theme-elements/_button.scss diff --git a/template/src/assets/scss/partials/theme-elements/_data-tables.scss b/src/assets/scss/partials/theme-elements/_data-tables.scss similarity index 94% rename from template/src/assets/scss/partials/theme-elements/_data-tables.scss rename to src/assets/scss/partials/theme-elements/_data-tables.scss index 3292811..a70fb47 100644 --- a/template/src/assets/scss/partials/theme-elements/_data-tables.scss +++ b/src/assets/scss/partials/theme-elements/_data-tables.scss @@ -89,13 +89,6 @@ } /* fixed header position */ -table.dataTable.fixedHeader-floating { - top: 0 !important; - @media screen and (max-width: 992px) { - display: none !important; - } -} - @media screen and (max-width: 992px) { .fixedHeader-locked { display: none !important; diff --git a/template/src/assets/scss/partials/theme-elements/_form.scss b/src/assets/scss/partials/theme-elements/_form.scss similarity index 100% rename from template/src/assets/scss/partials/theme-elements/_form.scss rename to src/assets/scss/partials/theme-elements/_form.scss diff --git a/template/src/assets/scss/partials/theme-elements/_labels-badges.scss b/src/assets/scss/partials/theme-elements/_labels-badges.scss similarity index 100% rename from template/src/assets/scss/partials/theme-elements/_labels-badges.scss rename to src/assets/scss/partials/theme-elements/_labels-badges.scss diff --git a/template/src/assets/scss/partials/theme-elements/_nav.scss b/src/assets/scss/partials/theme-elements/_nav.scss similarity index 100% rename from template/src/assets/scss/partials/theme-elements/_nav.scss rename to src/assets/scss/partials/theme-elements/_nav.scss diff --git a/src/assets/scss/partials/theme-elements/_progress.scss b/src/assets/scss/partials/theme-elements/_progress.scss new file mode 100644 index 0000000..63490db --- /dev/null +++ b/src/assets/scss/partials/theme-elements/_progress.scss @@ -0,0 +1,50 @@ +/** ===================== + Progress css start +========================== **/ +@keyframes progress-bar-stripes { + from { + background-position: 16px 0; + } + + to { + background-position: 0 0; + } +} + +.progress { + height: 12px; + font-size: 10px; + background-color: $theme-background; + border-radius: 0; + overflow: visible; + + .progress-bar { + background-color: $primary-color; + box-shadow: 0 10px 20px 0 rgba(0, 0, 0, 0.3); + + @each $value in $color-name { + $i: index($color-name, $value); + + &.progress-#{$value}, + &.bg-#{$value} { + background: nth($color-color, $i); + } + } + + &.progress-c-theme { + background: $theme-color; + } + + &.progress-c-theme2 { + background: $theme-color2; + } + + @each $color, $value in $theme-colors { + &.bg-#{$color} { + background-color: $value !important; + } + } + } +} + +/**====== Progress css end ======**/ diff --git a/template/src/assets/scss/partials/theme-elements/_radiobox-checkbox.scss b/src/assets/scss/partials/theme-elements/_radiobox-checkbox.scss similarity index 100% rename from template/src/assets/scss/partials/theme-elements/_radiobox-checkbox.scss rename to src/assets/scss/partials/theme-elements/_radiobox-checkbox.scss diff --git a/src/assets/scss/partials/third-party/_datatables.scss b/src/assets/scss/partials/third-party/_datatables.scss new file mode 100644 index 0000000..937a89d --- /dev/null +++ b/src/assets/scss/partials/third-party/_datatables.scss @@ -0,0 +1,3 @@ +.table > :not(caption) > * > * { + border-bottom-width: 0px; +} diff --git a/template/src/assets/scss/partials/third-party/_google-map.scss b/src/assets/scss/partials/third-party/_google-map.scss similarity index 100% rename from template/src/assets/scss/partials/third-party/_google-map.scss rename to src/assets/scss/partials/third-party/_google-map.scss diff --git a/template/src/assets/scss/partials/third-party/_ngx-perfect-scrollbar.scss b/src/assets/scss/partials/third-party/_ngx-perfect-scrollbar.scss similarity index 100% rename from template/src/assets/scss/partials/third-party/_ngx-perfect-scrollbar.scss rename to src/assets/scss/partials/third-party/_ngx-perfect-scrollbar.scss diff --git a/src/assets/scss/partials/third-party/_third-party.scss b/src/assets/scss/partials/third-party/_third-party.scss new file mode 100644 index 0000000..e2ddfac --- /dev/null +++ b/src/assets/scss/partials/third-party/_third-party.scss @@ -0,0 +1,40 @@ +@import '~react-perfect-scrollbar/dist/css/styles.css'; +@import '~nvd3/build/nv.d3.css'; +@import 'ngx-perfect-scrollbar'; +@import 'datatables'; +@import 'google-map'; +@import 'react-bootstrap/react-bootstrap'; + +.pcoded-header .main-search .input-group-text { + line-height: 1; +} + +.text-muted { + color: #6c757d !important; +} + +.card-event { + .label { + border-radius: 15px; + margin: 0; + padding: 5px 16px; + } + + i { + position: absolute; + bottom: 36px; + right: 27px; + } +} + +.carousel { + z-index: 1 !important; +} + +.rodal .rodal-dialog { + max-width: 100%; +} + +.page-link { + font-size: 0.9rem !important; +} diff --git a/template/src/assets/scss/partials/third-party/react-bootstrap/_header.scss b/src/assets/scss/partials/third-party/react-bootstrap/_header.scss similarity index 90% rename from template/src/assets/scss/partials/third-party/react-bootstrap/_header.scss rename to src/assets/scss/partials/third-party/react-bootstrap/_header.scss index bcea6d0..3aa4d95 100644 --- a/template/src/assets/scss/partials/third-party/react-bootstrap/_header.scss +++ b/src/assets/scss/partials/third-party/react-bootstrap/_header.scss @@ -20,9 +20,8 @@ } } .main-search { - margin-left: 5px; .input-group-text { - line-height: 1; + line-height: 1.5; } } diff --git a/template/src/assets/scss/partials/third-party/react-bootstrap/react-bootstrap.scss b/src/assets/scss/partials/third-party/react-bootstrap/react-bootstrap.scss similarity index 100% rename from template/src/assets/scss/partials/third-party/react-bootstrap/react-bootstrap.scss rename to src/assets/scss/partials/third-party/react-bootstrap/react-bootstrap.scss diff --git a/src/assets/scss/partials/widget/_widget.scss b/src/assets/scss/partials/widget/_widget.scss new file mode 100644 index 0000000..9e4d7b1 --- /dev/null +++ b/src/assets/scss/partials/widget/_widget.scss @@ -0,0 +1,71 @@ +.user-list { + .table { + td { + vertical-align: middle; + } + + thead { + th { + border: 0; + } + } + } +} + +.Recent-Users { + .table { + tr { + &:first-child { + td { + border-top: 0; + } + } + } + + td { + vertical-align: middle; + } + + .label { + border-radius: 15px; + box-shadow: 0 5px 10px 0 rgba(0, 0, 0, 0.2); + } + } +} + +.card-social { + &:hover { + i { + font-size: 40px; + transition: all 0.3s ease-in-out; + } + } + + .progress { + height: 6px; + } + + .card-active > div + div { + border-left: 1px solid $theme-border; + } +} + +.card { + .card-block, + .card-body { + code { + background-color: #eee; + margin: 5px; + display: inline-block; + border-radius: 3px; + padding: 0 3px; + } + } +} + +@media screen and (max-width: 767px) { + div.dataTables_wrapper div.dataTables_filter label { + float: none !important; + text-align: center; + } +} diff --git a/template/src/assets/scss/style.scss b/src/assets/scss/style.scss similarity index 95% rename from template/src/assets/scss/style.scss rename to src/assets/scss/style.scss index c4fdb64..072903f 100644 --- a/template/src/assets/scss/style.scss +++ b/src/assets/scss/style.scss @@ -11,7 +11,7 @@ File: style.css - Margin, Padding, Font class, text align, position, floating, overflow, background class, text color, display class, boarder class - Theme Elements - Accordion, Button, tabs, typography, buttons, box shadow, Lable & Badges, Alert, Pagination, Breadcumb, Cards, Collapse, - - Carousel, Grid, Progress, Model, tooltip, popover, Datepicker, Gridstack, lightbox, notification, Nestable, pnotify, rating, + - Carousel, Grid, Progress, Model, tooltip, popover, Datepicker, Gridstack, lightbox, notification, Nestable, rating, - Rangeslider, Slider, Syntax Highlighter, Tour, Treeview, Toolbar, Session Timeout, Session idle Timeout, offline, Animation - Forms - Forms Elements, Advance Form Control, Validation, Masking, Wizard, Picker, Select @@ -46,11 +46,11 @@ File: style.css @import 'partials/theme-elements/authentication'; @import 'partials/theme-elements/button'; @import 'partials/theme-elements/breadcrumb-pagination'; +@import 'partials/theme-elements/progress'; @import 'partials/theme-elements/nav'; // Other @import 'partials/other/chat'; @import 'partials/other/chart'; - @import 'partials/third-party/third-party'; diff --git a/template/src/components/Card/MainCard.js b/src/components/Card/MainCard.js similarity index 92% rename from template/src/components/Card/MainCard.js rename to src/components/Card/MainCard.js index 3880a11..866ab38 100644 --- a/template/src/components/Card/MainCard.js +++ b/src/components/Card/MainCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React, { useState } from 'react'; import { Dropdown, Card, Collapse } from 'react-bootstrap'; import { Link } from 'react-router-dom'; @@ -32,7 +33,7 @@ const MainCard = (props) => { if (isOption) { cardHeaderRight = (
- + @@ -103,4 +104,12 @@ const MainCard = (props) => { return {card}; }; +MainCard.propTypes = { + isOption: PropTypes.bool, + title: PropTypes.string, + children: PropTypes.node, + cardClass: PropTypes.string, + optionClass: PropTypes.string +}; + export default MainCard; diff --git a/template/src/components/Loader/Bar.js b/src/components/Loader/Bar.js similarity index 85% rename from template/src/components/Loader/Bar.js rename to src/components/Loader/Bar.js index 0b2abd3..9fdf3a8 100644 --- a/template/src/components/Loader/Bar.js +++ b/src/components/Loader/Bar.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; const Bar = ({ animationDuration, progress }) => { @@ -31,4 +32,9 @@ const Bar = ({ animationDuration, progress }) => { ); }; +Bar.propTypes = { + animationDuration: PropTypes.number, + progress: PropTypes.number +}; + export default Bar; diff --git a/template/src/components/Loader/Container.js b/src/components/Loader/Container.js similarity index 67% rename from template/src/components/Loader/Container.js rename to src/components/Loader/Container.js index f841bad..dac70a9 100644 --- a/template/src/components/Loader/Container.js +++ b/src/components/Loader/Container.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; const Container = ({ animationDuration, children, isFinished }) => { @@ -14,4 +15,10 @@ const Container = ({ animationDuration, children, isFinished }) => { ); }; +Container.propTypes = { + animationDuration: PropTypes.number, + children: PropTypes.node, + isFinished: PropTypes.bool +}; + export default Container; diff --git a/template/src/components/Loader/Loader.js b/src/components/Loader/Loader.js similarity index 100% rename from template/src/components/Loader/Loader.js rename to src/components/Loader/Loader.js diff --git a/template/src/components/Loader/Progress.js b/src/components/Loader/Progress.js similarity index 75% rename from template/src/components/Loader/Progress.js rename to src/components/Loader/Progress.js index e84fac5..0f05b22 100644 --- a/template/src/components/Loader/Progress.js +++ b/src/components/Loader/Progress.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { withNProgress } from '@tanem/react-nprogress'; @@ -14,4 +15,10 @@ const Progress = ({ isFinished, progress, animationDuration }) => { ); }; +Progress.propTypes = { + animationDuration: PropTypes.number, + progress: PropTypes.number, + isFinished: PropTypes.bool +}; + export default withNProgress(Progress); diff --git a/template/src/components/Loader/Spinner.js b/src/components/Loader/Spinner.js similarity index 100% rename from template/src/components/Loader/Spinner.js rename to src/components/Loader/Spinner.js diff --git a/template/src/components/Widgets/Statistic/IcoCard.js b/src/components/Widgets/Statistic/IcoCard.js similarity index 84% rename from template/src/components/Widgets/Statistic/IcoCard.js rename to src/components/Widgets/Statistic/IcoCard.js index d41843e..a2d16cc 100644 --- a/template/src/components/Widgets/Statistic/IcoCard.js +++ b/src/components/Widgets/Statistic/IcoCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Col, Card } from 'react-bootstrap'; import { Link } from 'react-router-dom'; @@ -49,4 +50,15 @@ const IcoCard = (props) => { ); }; +IcoCard.propTypes = { + icon: PropTypes.string, + title: PropTypes.string, + caption: PropTypes.string, + category: PropTypes.string, + totalAmount: PropTypes.number, + amount: PropTypes.number, + percentage: PropTypes.number, + time: PropTypes.string +}; + export default IcoCard; diff --git a/template/src/components/Widgets/Statistic/Notification.js b/src/components/Widgets/Statistic/Notification.js similarity index 76% rename from template/src/components/Widgets/Statistic/Notification.js rename to src/components/Widgets/Statistic/Notification.js index bfe3e4a..141bd3a 100644 --- a/template/src/components/Widgets/Statistic/Notification.js +++ b/src/components/Widgets/Statistic/Notification.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Alert } from 'react-bootstrap'; @@ -14,4 +15,9 @@ const Notification = (props) => { ); }; +Notification.propTypes = { + message: PropTypes.string, + link: PropTypes.string +}; + export default Notification; diff --git a/template/src/components/Widgets/Statistic/NotificationCard.js b/src/components/Widgets/Statistic/NotificationCard.js similarity index 76% rename from template/src/components/Widgets/Statistic/NotificationCard.js rename to src/components/Widgets/Statistic/NotificationCard.js index f3fa98c..ca36ebf 100644 --- a/template/src/components/Widgets/Statistic/NotificationCard.js +++ b/src/components/Widgets/Statistic/NotificationCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Card, Row, Col } from 'react-bootstrap'; @@ -24,4 +25,12 @@ const NotificationCard = ({ params }) => { ); }; +NotificationCard.propTypes = { + params: PropTypes.object, + class: PropTypes.string, + icon: PropTypes.string, + primaryText: PropTypes.string, + secondaryText: PropTypes.string +}; + export default NotificationCard; diff --git a/template/src/components/Widgets/Statistic/OrderCard.js b/src/components/Widgets/Statistic/OrderCard.js similarity index 74% rename from template/src/components/Widgets/Statistic/OrderCard.js rename to src/components/Widgets/Statistic/OrderCard.js index 7a22c84..895aafd 100644 --- a/template/src/components/Widgets/Statistic/OrderCard.js +++ b/src/components/Widgets/Statistic/OrderCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Card } from 'react-bootstrap'; @@ -29,4 +30,14 @@ const OrderCard = ({ params }) => { ); }; +OrderCard.propTypes = { + params: PropTypes.object, + class: PropTypes.string, + icon: PropTypes.string, + primaryText: PropTypes.string, + secondaryText: PropTypes.string, + title: PropTypes.string, + extraText: PropTypes.string +}; + export default OrderCard; diff --git a/template/src/components/Widgets/Statistic/ProductCard.js b/src/components/Widgets/Statistic/ProductCard.js similarity index 78% rename from template/src/components/Widgets/Statistic/ProductCard.js rename to src/components/Widgets/Statistic/ProductCard.js index 44fc6b9..a37b47c 100644 --- a/template/src/components/Widgets/Statistic/ProductCard.js +++ b/src/components/Widgets/Statistic/ProductCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Card, Row, Col } from 'react-bootstrap'; @@ -35,4 +36,14 @@ const ProductCard = ({ params }) => { ); }; +ProductCard.propTypes = { + params: PropTypes.object, + class: PropTypes.string, + icon: PropTypes.string, + primaryText: PropTypes.string, + secondaryText: PropTypes.string, + title: PropTypes.string, + extraText: PropTypes.string +}; + export default ProductCard; diff --git a/template/src/components/Widgets/Statistic/ProductOrderCard.js b/src/components/Widgets/Statistic/ProductOrderCard.js similarity index 90% rename from template/src/components/Widgets/Statistic/ProductOrderCard.js rename to src/components/Widgets/Statistic/ProductOrderCard.js index f7c3a1d..dd3caac 100644 --- a/template/src/components/Widgets/Statistic/ProductOrderCard.js +++ b/src/components/Widgets/Statistic/ProductOrderCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Card, Row, Col } from 'react-bootstrap'; import { Link } from 'react-router-dom'; @@ -61,7 +62,7 @@ const ProductOrderCard = (props) => {
${price}
-
+
Delivered on {delivered}
{description}
@@ -87,4 +88,16 @@ const ProductOrderCard = (props) => { ); }; +ProductOrderCard.propTypes = { + image: PropTypes.string, + orderId: PropTypes.number, + name: PropTypes.string, + rating: PropTypes.string, + price: PropTypes.number, + delivered: PropTypes.bool, + ordered: PropTypes.bool, + description: PropTypes.string, + total: PropTypes.number +}; + export default ProductOrderCard; diff --git a/template/src/components/Widgets/Statistic/SocialCard.js b/src/components/Widgets/Statistic/SocialCard.js similarity index 72% rename from template/src/components/Widgets/Statistic/SocialCard.js rename to src/components/Widgets/Statistic/SocialCard.js index f8737df..a234be1 100644 --- a/template/src/components/Widgets/Statistic/SocialCard.js +++ b/src/components/Widgets/Statistic/SocialCard.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Card, Button } from 'react-bootstrap'; @@ -26,4 +27,15 @@ const SocialCard = ({ params }) => { ); }; +SocialCard.propTypes = { + params: PropTypes.array, + class: PropTypes.string, + icon: PropTypes.string, + primaryTitle: PropTypes.string, + primaryText: PropTypes.number, + secondaryText: PropTypes.string, + variant: PropTypes.string, + label: PropTypes.string +}; + export default SocialCard; diff --git a/src/config/constant.js b/src/config/constant.js new file mode 100644 index 0000000..f6fef74 --- /dev/null +++ b/src/config/constant.js @@ -0,0 +1,8 @@ +export const BASE_URL = '/app/dashboard/default'; +export const BASE_TITLE = ' | Datta Able Premium React Hooks + Redux Admin Template'; + +export const CONFIG = { + layout: 'vertical', + collapseMenu: false, + layoutType: 'menu-dark' +}; diff --git a/src/contexts/ConfigContext.js b/src/contexts/ConfigContext.js new file mode 100644 index 0000000..75145bc --- /dev/null +++ b/src/contexts/ConfigContext.js @@ -0,0 +1,103 @@ +import PropTypes from 'prop-types'; +import React, { createContext, useReducer } from 'react'; +import * as actionType from '../store/actions'; +import { CONFIG } from '../config/constant'; + +const initialState = { + ...CONFIG, + isOpen: [], + isTrigger: [] +}; +const ConfigContext = createContext(initialState); +const { Provider } = ConfigContext; + +const ConfigProvider = ({ children }) => { + let trigger = []; + let open = []; + + const [state, dispatch] = useReducer((state, action) => { + switch (action.type) { + case actionType.CHANGE_LAYOUT: + return { + ...state, + layout: action.layout + }; + case actionType.COLLAPSE_MENU: + return { + ...state, + collapseMenu: !state.collapseMenu + }; + case actionType.COLLAPSE_TOGGLE: + if (action.menu.type === 'sub') { + open = state.isOpen; + trigger = state.isTrigger; + + const triggerIndex = trigger.indexOf(action.menu.id); + if (triggerIndex > -1) { + open = open.filter((item) => item !== action.menu.id); + trigger = trigger.filter((item) => item !== action.menu.id); + } + + if (triggerIndex === -1) { + open = [...open, action.menu.id]; + trigger = [...trigger, action.menu.id]; + } + } else { + open = state.isOpen; + const triggerIndex = state.isTrigger.indexOf(action.menu.id); + trigger = triggerIndex === -1 ? [action.menu.id] : []; + open = triggerIndex === -1 ? [action.menu.id] : []; + } + return { + ...state, + isOpen: open, + isTrigger: trigger + }; + case actionType.LAYOUT_TYPE: + return { + ...state, + layoutType: action.layoutType + }; + case actionType.NAV_COLLAPSE_LEAVE: + if (action.menu.type === 'sub') { + open = state.isOpen; + trigger = state.isTrigger; + + const triggerIndex = trigger.indexOf(action.menu.id); + if (triggerIndex > -1) { + open = open.filter((item) => item !== action.menu.id); + trigger = trigger.filter((item) => item !== action.menu.id); + } + return { + ...state, + isOpen: open, + isTrigger: trigger + }; + } + return { ...state }; + case actionType.NAV_CONTENT_LEAVE: + return { + ...state, + isOpen: open, + isTrigger: trigger + }; + case actionType.RESET: + return { + ...state, + layout: initialState.layout, + collapseMenu: initialState.collapseMenu, + layoutType: initialState.layoutType + }; + default: + throw new Error(); + } + }, initialState); + + return {children}; +}; + +ConfigProvider.propTypes = { + children: PropTypes.object +}; + +export { ConfigContext, ConfigProvider }; diff --git a/src/data/countryData.js b/src/data/countryData.js new file mode 100644 index 0000000..ef9989a --- /dev/null +++ b/src/data/countryData.js @@ -0,0 +1,253 @@ +const initialData = [ + { name: 'Afghanistan', code: 'AF' }, + { name: 'Ã…land Islands', code: 'AX' }, + { name: 'Albania', code: 'AL' }, + { name: 'Algeria', code: 'DZ' }, + { name: 'American Samoa', code: 'AS' }, + { name: 'AndorrA', code: 'AD' }, + { name: 'Angola', code: 'AO' }, + { name: 'Anguilla', code: 'AI' }, + { name: 'Antarctica', code: 'AQ' }, + { name: 'Antigua and Barbuda', code: 'AG' }, + { name: 'Argentina', code: 'AR' }, + { name: 'Armenia', code: 'AM' }, + { name: 'Aruba', code: 'AW' }, + { name: 'Australia', code: 'AU' }, + { name: 'Austria', code: 'AT' }, + { name: 'Azerbaijan', code: 'AZ' }, + { name: 'Bahamas', code: 'BS' }, + { name: 'Bahrain', code: 'BH' }, + { name: 'Bangladesh', code: 'BD' }, + { name: 'Barbados', code: 'BB' }, + { name: 'Belarus', code: 'BY' }, + { name: 'Belgium', code: 'BE' }, + { name: 'Belize', code: 'BZ' }, + { name: 'Benin', code: 'BJ' }, + { name: 'Bermuda', code: 'BM' }, + { name: 'Bhutan', code: 'BT' }, + { name: 'Bolivia', code: 'BO' }, + { name: 'Bosnia and Herzegovina', code: 'BA' }, + { name: 'Botswana', code: 'BW' }, + { name: 'Bouvet Island', code: 'BV' }, + { name: 'Brazil', code: 'BR' }, + { name: 'British Indian Ocean Territory', code: 'IO' }, + { name: 'Brunei Darussalam', code: 'BN' }, + { name: 'Bulgaria', code: 'BG' }, + { name: 'Burkina Faso', code: 'BF' }, + { name: 'Burundi', code: 'BI' }, + { name: 'Cambodia', code: 'KH' }, + { name: 'Cameroon', code: 'CM' }, + { name: 'Canada', code: 'CA' }, + { name: 'Cape Verde', code: 'CV' }, + { name: 'Cayman Islands', code: 'KY' }, + { name: 'Central African Republic', code: 'CF' }, + { name: 'Chad', code: 'TD' }, + { name: 'Chile', code: 'CL' }, + { name: 'China', code: 'CN' }, + { name: 'Christmas Island', code: 'CX' }, + { name: 'Cocos (Keeling) Islands', code: 'CC' }, + { name: 'Colombia', code: 'CO' }, + { name: 'Comoros', code: 'KM' }, + { name: 'Congo', code: 'CG' }, + { name: 'Congo, The Democratic Republic of the', code: 'CD' }, + { name: 'Cook Islands', code: 'CK' }, + { name: 'Costa Rica', code: 'CR' }, + { name: "Cote D'Ivoire", code: 'CI' }, + { name: 'Croatia', code: 'HR' }, + { name: 'Cuba', code: 'CU' }, + { name: 'Cyprus', code: 'CY' }, + { name: 'Czech Republic', code: 'CZ' }, + { name: 'Denmark', code: 'DK' }, + { name: 'Djibouti', code: 'DJ' }, + { name: 'Dominica', code: 'DM' }, + { name: 'Dominican Republic', code: 'DO' }, + { name: 'Ecuador', code: 'EC' }, + { name: 'Egypt', code: 'EG' }, + { name: 'El Salvador', code: 'SV' }, + { name: 'Equatorial Guinea', code: 'GQ' }, + { name: 'Eritrea', code: 'ER' }, + { name: 'Estonia', code: 'EE' }, + { name: 'Ethiopia', code: 'ET' }, + { name: 'Falkland Islands (Malvinas)', code: 'FK' }, + { name: 'Faroe Islands', code: 'FO' }, + { name: 'Fiji', code: 'FJ' }, + { name: 'Finland', code: 'FI' }, + { name: 'France', code: 'FR' }, + { name: 'French Guiana', code: 'GF' }, + { name: 'French Polynesia', code: 'PF' }, + { name: 'French Southern Territories', code: 'TF' }, + { name: 'Gabon', code: 'GA' }, + { name: 'Gambia', code: 'GM' }, + { name: 'Georgia', code: 'GE' }, + { name: 'Germany', code: 'DE' }, + { name: 'Ghana', code: 'GH' }, + { name: 'Gibraltar', code: 'GI' }, + { name: 'Greece', code: 'GR' }, + { name: 'Greenland', code: 'GL' }, + { name: 'Grenada', code: 'GD' }, + { name: 'Guadeloupe', code: 'GP' }, + { name: 'Guam', code: 'GU' }, + { name: 'Guatemala', code: 'GT' }, + { name: 'Guernsey', code: 'GG' }, + { name: 'Guinea', code: 'GN' }, + { name: 'Guinea-Bissau', code: 'GW' }, + { name: 'Guyana', code: 'GY' }, + { name: 'Haiti', code: 'HT' }, + { name: 'Heard Island and Mcdonald Islands', code: 'HM' }, + { name: 'Holy See (Vatican City State)', code: 'VA' }, + { name: 'Honduras', code: 'HN' }, + { name: 'Hong Kong', code: 'HK' }, + { name: 'Hungary', code: 'HU' }, + { name: 'Iceland', code: 'IS' }, + { name: 'India', code: 'IN' }, + { name: 'Indonesia', code: 'ID' }, + { name: 'Iran, Islamic Republic Of', code: 'IR' }, + { name: 'Iraq', code: 'IQ' }, + { name: 'Ireland', code: 'IE' }, + { name: 'Isle of Man', code: 'IM' }, + { name: 'Israel', code: 'IL' }, + { name: 'Italy', code: 'IT' }, + { name: 'Jamaica', code: 'JM' }, + { name: 'Japan', code: 'JP' }, + { name: 'Jersey', code: 'JE' }, + { name: 'Jordan', code: 'JO' }, + { name: 'Kazakhstan', code: 'KZ' }, + { name: 'Kenya', code: 'KE' }, + { name: 'Kiribati', code: 'KI' }, + { name: "Korea, Democratic People'S Republic of", code: 'KP' }, + { name: 'Korea, Republic of', code: 'KR' }, + { name: 'Kuwait', code: 'KW' }, + { name: 'Kyrgyzstan', code: 'KG' }, + { name: "Lao People'S Democratic Republic", code: 'LA' }, + { name: 'Latvia', code: 'LV' }, + { name: 'Lebanon', code: 'LB' }, + { name: 'Lesotho', code: 'LS' }, + { name: 'Liberia', code: 'LR' }, + { name: 'Libyan Arab Jamahiriya', code: 'LY' }, + { name: 'Liechtenstein', code: 'LI' }, + { name: 'Lithuania', code: 'LT' }, + { name: 'Luxembourg', code: 'LU' }, + { name: 'Macao', code: 'MO' }, + { name: 'Macedonia, The Former Yugoslav Republic of', code: 'MK' }, + { name: 'Madagascar', code: 'MG' }, + { name: 'Malawi', code: 'MW' }, + { name: 'Malaysia', code: 'MY' }, + { name: 'Maldives', code: 'MV' }, + { name: 'Mali', code: 'ML' }, + { name: 'Malta', code: 'MT' }, + { name: 'Marshall Islands', code: 'MH' }, + { name: 'Martinique', code: 'MQ' }, + { name: 'Mauritania', code: 'MR' }, + { name: 'Mauritius', code: 'MU' }, + { name: 'Mayotte', code: 'YT' }, + { name: 'Mexico', code: 'MX' }, + { name: 'Micronesia, Federated States of', code: 'FM' }, + { name: 'Moldova, Republic of', code: 'MD' }, + { name: 'Monaco', code: 'MC' }, + { name: 'Mongolia', code: 'MN' }, + { name: 'Montserrat', code: 'MS' }, + { name: 'Morocco', code: 'MA' }, + { name: 'Mozambique', code: 'MZ' }, + { name: 'Myanmar', code: 'MM' }, + { name: 'Namibia', code: 'NA' }, + { name: 'Nauru', code: 'NR' }, + { name: 'Nepal', code: 'NP' }, + { name: 'Netherlands', code: 'NL' }, + { name: 'Netherlands Antilles', code: 'AN' }, + { name: 'New Caledonia', code: 'NC' }, + { name: 'New Zealand', code: 'NZ' }, + { name: 'Nicaragua', code: 'NI' }, + { name: 'Niger', code: 'NE' }, + { name: 'Nigeria', code: 'NG' }, + { name: 'Niue', code: 'NU' }, + { name: 'Norfolk Island', code: 'NF' }, + { name: 'Northern Mariana Islands', code: 'MP' }, + { name: 'Norway', code: 'NO' }, + { name: 'Oman', code: 'OM' }, + { name: 'Pakistan', code: 'PK' }, + { name: 'Palau', code: 'PW' }, + { name: 'Palestinian Territory, Occupied', code: 'PS' }, + { name: 'Panama', code: 'PA' }, + { name: 'Papua New Guinea', code: 'PG' }, + { name: 'Paraguay', code: 'PY' }, + { name: 'Peru', code: 'PE' }, + { name: 'Philippines', code: 'PH' }, + { name: 'Pitcairn', code: 'PN' }, + { name: 'Poland', code: 'PL' }, + { name: 'Portugal', code: 'PT' }, + { name: 'Puerto Rico', code: 'PR' }, + { name: 'Qatar', code: 'QA' }, + { name: 'Reunion', code: 'RE' }, + { name: 'Romania', code: 'RO' }, + { name: 'Russian Federation', code: 'RU' }, + { name: 'RWANDA', code: 'RW' }, + { name: 'Saint Helena', code: 'SH' }, + { name: 'Saint Kitts and Nevis', code: 'KN' }, + { name: 'Saint Lucia', code: 'LC' }, + { name: 'Saint Pierre and Miquelon', code: 'PM' }, + { name: 'Saint Vincent and the Grenadines', code: 'VC' }, + { name: 'Samoa', code: 'WS' }, + { name: 'San Marino', code: 'SM' }, + { name: 'Sao Tome and Principe', code: 'ST' }, + { name: 'Saudi Arabia', code: 'SA' }, + { name: 'Senegal', code: 'SN' }, + { name: 'Serbia and Montenegro', code: 'CS' }, + { name: 'Seychelles', code: 'SC' }, + { name: 'Sierra Leone', code: 'SL' }, + { name: 'Singapore', code: 'SG' }, + { name: 'Slovakia', code: 'SK' }, + { name: 'Slovenia', code: 'SI' }, + { name: 'Solomon Islands', code: 'SB' }, + { name: 'Somalia', code: 'SO' }, + { name: 'South Africa', code: 'ZA' }, + { name: 'South Georgia and the South Sandwich Islands', code: 'GS' }, + { name: 'Spain', code: 'ES' }, + { name: 'Sri Lanka', code: 'LK' }, + { name: 'Sudan', code: 'SD' }, + { name: 'Suriname', code: 'SR' }, + { name: 'Svalbard and Jan Mayen', code: 'SJ' }, + { name: 'Swaziland', code: 'SZ' }, + { name: 'Sweden', code: 'SE' }, + { name: 'Switzerland', code: 'CH' }, + { name: 'Syrian Arab Republic', code: 'SY' }, + { name: 'Taiwan, Province of China', code: 'TW' }, + { name: 'Tajikistan', code: 'TJ' }, + { name: 'Tanzania, United Republic of', code: 'TZ' }, + { name: 'Thailand', code: 'TH' }, + { name: 'Timor-Leste', code: 'TL' }, + { name: 'Togo', code: 'TG' }, + { name: 'Tokelau', code: 'TK' }, + { name: 'Tonga', code: 'TO' }, + { name: 'Trinidad and Tobago', code: 'TT' }, + { name: 'Tunisia', code: 'TN' }, + { name: 'Turkey', code: 'TR' }, + { name: 'Turkmenistan', code: 'TM' }, + { name: 'Turks and Caicos Islands', code: 'TC' }, + { name: 'Tuvalu', code: 'TV' }, + { name: 'Uganda', code: 'UG' }, + { name: 'Ukraine', code: 'UA' }, + { name: 'United Arab Emirates', code: 'AE' }, + { name: 'United Kingdom', code: 'GB' }, + { name: 'United States', code: 'US' }, + { name: 'United States Minor Outlying Islands', code: 'UM' }, + { name: 'Uruguay', code: 'UY' }, + { name: 'Uzbekistan', code: 'UZ' }, + { name: 'Vanuatu', code: 'VU' }, + { name: 'Venezuela', code: 'VE' }, + { name: 'Viet Nam', code: 'VN' }, + { name: 'Virgin Islands, British', code: 'VG' }, + { name: 'Virgin Islands, U.S.', code: 'VI' }, + { name: 'Wallis and Futuna', code: 'WF' }, + { name: 'Western Sahara', code: 'EH' }, + { name: 'Yemen', code: 'YE' }, + { name: 'Zambia', code: 'ZM' }, + { name: 'Zimbabwe', code: 'ZW' } +]; + +export default function makeData() { + const makeDataLevel = () => { + return initialData; + }; + + return makeDataLevel(); +} diff --git a/template/src/data/tableData.js b/src/data/tableData.js similarity index 80% rename from template/src/data/tableData.js rename to src/data/tableData.js index d09510c..9c8aaf3 100644 --- a/template/src/data/tableData.js +++ b/src/data/tableData.js @@ -1,5 +1,6 @@ -import namor from 'namor'; +import { Chance } from 'chance'; +const chance = new Chance(); const range = (len) => { const arr = []; for (let i = 0; i < len; i++) { @@ -11,8 +12,8 @@ const range = (len) => { const newPerson = () => { const statusChance = Math.random(); return { - firstName: namor.generate({ words: 1, numbers: 0 }), - lastName: namor.generate({ words: 1, numbers: 0 }), + firstName: chance.first(), + lastName: chance.last(), age: Math.floor(Math.random() * 30), visits: Math.floor(Math.random() * 100), progress: Math.floor(Math.random() * 100), @@ -23,7 +24,7 @@ const newPerson = () => { export default function makeData(...lens) { const makeDataLevel = (depth = 0) => { const len = lens[depth]; - return range(len).map((d) => { + return range(len).map(() => { return { ...newPerson(), subRows: lens[depth + 1] ? makeDataLevel(depth + 1) : undefined diff --git a/template/src/hooks/useOutsideClick.js b/src/hooks/useOutsideClick.js similarity index 100% rename from template/src/hooks/useOutsideClick.js rename to src/hooks/useOutsideClick.js diff --git a/template/src/hooks/useScriptRef.js b/src/hooks/useScriptRef.js similarity index 100% rename from template/src/hooks/useScriptRef.js rename to src/hooks/useScriptRef.js diff --git a/template/src/hooks/useWindowSize.js b/src/hooks/useWindowSize.js similarity index 100% rename from template/src/hooks/useWindowSize.js rename to src/hooks/useWindowSize.js diff --git a/template/src/index.js b/src/index.js similarity index 70% rename from template/src/index.js rename to src/index.js index cab4f2a..c5523cf 100644 --- a/template/src/index.js +++ b/src/index.js @@ -2,7 +2,9 @@ import 'react-app-polyfill/ie11'; import 'react-app-polyfill/stable'; import React from 'react'; -import ReactDOM from 'react-dom'; +import { createRoot } from 'react-dom/client'; + +import './services'; import { Provider } from 'react-redux'; import { ConfigProvider } from './contexts/ConfigContext'; @@ -12,13 +14,14 @@ import App from './App'; import reportWebVitals from './reportWebVitals'; import store from './store'; -ReactDOM.render( +const container = document.getElementById('root'); +const root = createRoot(container); +root.render( - , - document.getElementById('root') + ); reportWebVitals(); diff --git a/template/src/index.scss b/src/index.scss similarity index 59% rename from template/src/index.scss rename to src/index.scss index 41709ad..9cae40f 100644 --- a/template/src/index.scss +++ b/src/index.scss @@ -65,25 +65,10 @@ overflow: hidden; } -.zoom-container { - position: relative; - display: flex; -} - .img-preview-section-container { display: none; } -.zoom-container:hover .img-preview-section-container { - display: block; - position: relative; - left: 50px; -} -.zoom-container:hover .img-preview-section-container { - left: 100%; - position: absolute; - background: #fff; - border: 1px solid $theme-border; -} + .carousel-inner { overflow: visible; z-index: 1050; @@ -122,77 +107,9 @@ header.navbar.pcoded-header.navbar-expand-lg.header-default .mobile-menu.on span background-color: transparent; } -body.datta-rtl .pcoded-navbar.theme-horizontal ~ .pcoded-header { - margin-right: auto; -} - -body.datta-rtl .pcoded-navbar.theme-horizontal ~ .pcoded-main-container { - margin-right: auto; -} - -body.datta-rtl .pcoded-navbar.theme-horizontal .pcoded-inner-navbar > li > a:after { - left: 0; -} - -body.datta-rtl .pcoded-navbar.theme-horizontal .pcoded-inner-navbar > li.active:after, -.pcoded-navbar.theme-horizontal .pcoded-inner-navbar > li.pcoded-trigger:after { - right: 18px; -} - -.theme-horizontal .sidenav-horizontal:after, -.theme-horizontal .sidenav-horizontal:before { - content: ''; - background: $header-dark-background; - width: 100%; - position: absolute; - top: 0; - height: 100%; - z-index: 5; -} - -.theme-horizontal.navbar-blue .sidenav-horizontal:after, -.theme-horizontal.navbar-blue .sidenav-horizontal:before { - background: $primary-color; -} - -.theme-horizontal.navbar-red .sidenav-horizontal:after, -.theme-horizontal.navbar-red .sidenav-horizontal:before { - background: $danger-color; -} - -.theme-horizontal.navbar-purple .sidenav-horizontal:after, -.theme-horizontal.navbar-purple .sidenav-horizontal:before { - background: $purple-color; -} - -.theme-horizontal.navbar-lightblue .sidenav-horizontal:after, -.theme-horizontal.navbar-lightblue .sidenav-horizontal:before { - background: $layout-6-bg-color; -} - -.theme-horizontal.navbar-dark .sidenav-horizontal:after, -.theme-horizontal.navbar-dark .sidenav-horizontal:before { - background: $dark-color; -} - -.theme-horizontal .sidenav-horizontal:before { - left: 100%; -} - -.theme-horizontal .sidenav-horizontal:after { - right: 100%; -} - @media only screen and (max-width: 991px) { .pcoded-navbar { - z-index: 1032; - } - - body.datta-rtl { - .pcoded-header, - .pcoded-main-container { - margin-right: 0; - } + z-index: 1072; } header.navbar.pcoded-header.navbar-expand-lg.header-default.headerpos-fixed { @@ -212,39 +129,26 @@ body.datta-rtl .pcoded-navbar.theme-horizontal .pcoded-inner-navbar > li.active: header.navbar.pcoded-header.navbar-expand-lg.header-default .mobile-menu.on span { background-color: transparent; } - - body.datta-dark .pcoded-header.header-dark .input-group .input-group-text, - .pcoded-header.header-dark a, - .pcoded-header.header-dark .btn, - .pcoded-header.header-dark .dropdown-toggle { - color: $dark-layout-font; - } -} -.to-do-list .checkbox-fade .cr { - float: left; - border-radius: 3px; - width: 22px; - height: 22px; -} -.to-do-list .checkbox-fade label input[type='checkbox']:checked + .cr { - background: #1dd5d2; } .user-activity .tab-content { padding-top: 5px; } -.rodal-dialog { - height: auto !important; - bottom: auto !important; - top: 50% !important; - transform: translateY(-50%); - .card { - box-shadow: none; - margin-bottom: 0px; - .card-footer { - padding-bottom: 0px; +.rodal { + .rodal-dialog { + height: auto !important; + bottom: auto; + top: 25%; + .card { + box-shadow: none; + margin-bottom: 0px; } + padding: 0; + } + .rodal-close:hover:before, + .rodal-close:hover:after { + background: $danger-color; } } @@ -358,28 +262,6 @@ td { .carousel.slide { overflow: hidden; } -.react-datepicker-popper[data-placement^='bottom'] .react-datepicker__triangle, -.react-datepicker-popper[data-placement^='top'] .react-datepicker__triangle, -.react-datepicker__year-read-view--down-arrow, -.react-datepicker__month-read-view--down-arrow, -.react-datepicker__month-year-read-view--down-arrow { - left: 18px !important; -} -.smooth-dnd-container.horizontal { - button { - border: none; - } -} -.ui-pnotify-icon { - > span { - display: inline-flex !important; - align-items: center; - justify-content: center; - border-radius: 50%; - width: 21px; - height: 21px; - } -} .table.table-bordered.table-hover { th { @@ -388,15 +270,12 @@ td { } } } -.filter-bar .navbar { - @media (max-width: 690px) { - padding: 0.5rem 1rem 1rem; - // #dropdown-basic{ - // padding-left: 10px; - // } - .f-view { - padding-left: 25px; - margin-top: 8px; - } +.photoshop-picker { + @media only screen and (max-width: 575px) { + display: none; } } + +.css-1v494f5-Wrapper { + z-index: 20 !important; +} diff --git a/template/src/layouts/AdminLayout/Breadcrumb/index.js b/src/layouts/AdminLayout/Breadcrumb/index.js similarity index 92% rename from template/src/layouts/AdminLayout/Breadcrumb/index.js rename to src/layouts/AdminLayout/Breadcrumb/index.js index 0bae10e..e87b421 100644 --- a/template/src/layouts/AdminLayout/Breadcrumb/index.js +++ b/src/layouts/AdminLayout/Breadcrumb/index.js @@ -1,11 +1,13 @@ import React, { useState, useEffect } from 'react'; import { ListGroup } from 'react-bootstrap'; -import { Link } from 'react-router-dom'; +import { Link, useLocation } from 'react-router-dom'; import navigation from '../../../menu-items'; -import { BASE_TITLE, BASENAME } from '../../../config/constant'; +import { BASE_TITLE } from '../../../config/constant'; const Breadcrumb = () => { + const location = useLocation(); + const [main, setMain] = useState([]); const [item, setItem] = useState([]); @@ -24,7 +26,7 @@ const Breadcrumb = () => { if (collapse.type && collapse.type === 'collapse') { getCollapse(collapse, index); } else if (collapse.type && collapse.type === 'item') { - if (document.location.pathname === BASENAME + collapse.url) { + if (location.pathname === collapse.url) { setMain(item); setItem(collapse); } diff --git a/template/src/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js b/src/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js similarity index 79% rename from template/src/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js rename to src/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js index 9c678dd..dbbd9ae 100644 --- a/template/src/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js +++ b/src/layouts/AdminLayout/NavBar/NavLeft/NavSearch/index.js @@ -1,3 +1,4 @@ +import PropTypes from 'prop-types'; import React, { useState } from 'react'; import { Link } from 'react-router-dom'; @@ -37,7 +38,14 @@ const NavSearch = (props) => { - +
@@ -46,4 +54,8 @@ const NavSearch = (props) => { ); }; +NavSearch.propTypes = { + windowWidth: PropTypes.number +}; + export default NavSearch; diff --git a/template/src/layouts/AdminLayout/NavBar/NavLeft/index.js b/src/layouts/AdminLayout/NavBar/NavLeft/index.js similarity index 81% rename from template/src/layouts/AdminLayout/NavBar/NavLeft/index.js rename to src/layouts/AdminLayout/NavBar/NavLeft/index.js index 81db511..f80db6d 100644 --- a/template/src/layouts/AdminLayout/NavBar/NavLeft/index.js +++ b/src/layouts/AdminLayout/NavBar/NavLeft/index.js @@ -1,20 +1,14 @@ -import React, { useContext } from 'react'; +import React from 'react'; import { ListGroup, Dropdown } from 'react-bootstrap'; import { Link } from 'react-router-dom'; import useWindowSize from '../../../../hooks/useWindowSize'; -import { ConfigContext } from '../../../../contexts/ConfigContext'; import NavSearch from './NavSearch'; const NavLeft = () => { const windowSize = useWindowSize(); - const configContext = useContext(ConfigContext); - const { rtlLayout } = configContext.state; - let dropdownRightAlign = false; - if (rtlLayout) { - dropdownRightAlign = true; - } + let dropdownAlign = 'start'; let navItemClass = ['nav-item']; if (windowSize.width <= 575) { @@ -25,7 +19,7 @@ const NavLeft = () => { - + Dropdown diff --git a/template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js b/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js similarity index 58% rename from template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js rename to src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js index 04e10c6..d12fc39 100644 --- a/template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js +++ b/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/Messages/index.js @@ -1,6 +1,7 @@ +import PropTypes from 'prop-types'; import React from 'react'; +import { Card } from 'react-bootstrap'; import { Link } from 'react-router-dom'; -import { Media } from 'react-bootstrap'; const images = require.context('../../../../../../../../assets/images/user', true); @@ -9,7 +10,7 @@ const Messages = ({ message, photo, name }) => { if (message.type) { image = ( - {name} + {name} ); } @@ -23,17 +24,29 @@ const Messages = ({ message, photo, name }) => { return ( - + {image} - +

{message.msg}

{message.time}

-
-
+ +
); }; +Messages.propTypes = { + message: PropTypes.string, + photo: PropTypes.string, + name: PropTypes.string, + type: PropTypes.string, + msg: PropTypes.string, + time: PropTypes.string +}; + export default Messages; diff --git a/template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/chat.js b/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/chat.js similarity index 100% rename from template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/chat.js rename to src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/chat.js diff --git a/template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js b/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js similarity index 73% rename from template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js rename to src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js index 1358f1a..7e481ff 100644 --- a/template/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js +++ b/src/layouts/AdminLayout/NavBar/NavRight/ChatList/Friends/Chat/index.js @@ -1,5 +1,6 @@ +import PropTypes from 'prop-types'; import React from 'react'; -import { Media, FormControl, Button, InputGroup } from 'react-bootstrap'; +import { FormControl, Button, InputGroup, Card } from 'react-bootstrap'; import { Link } from 'react-router-dom'; import PerfectScrollbar from 'react-perfect-scrollbar'; @@ -13,13 +14,13 @@ const Chat = ({ user, chatOpen, listOpen, closed }) => { } let message = ( - - + +

CHAT NOT FOUND

-
-
+ + ); chatMsg.filter((chats) => { @@ -49,11 +50,9 @@ const Chat = ({ user, chatOpen, listOpen, closed }) => {
- - - + +

+ Don’t have an account?{' '} + + Signup + +

+ + + + +
+ + + ); +}; + +export default ResetPassword1; diff --git a/template/src/views/auth/signin/FirebaseLogin.js b/src/views/auth/signin/FirebaseLogin.js similarity index 66% rename from template/src/views/auth/signin/FirebaseLogin.js rename to src/views/auth/signin/FirebaseLogin.js index b4fb9b4..4fb3ff1 100644 --- a/template/src/views/auth/signin/FirebaseLogin.js +++ b/src/views/auth/signin/FirebaseLogin.js @@ -1,29 +1,16 @@ +import PropTypes from 'prop-types'; import React from 'react'; import { Row, Col, Button, Alert } from 'react-bootstrap'; import * as Yup from 'yup'; import { Formik } from 'formik'; -import useAuth from '../../../hooks/useAuth'; -import useScriptRef from '../../../hooks/useScriptRef'; const FirebaseLogin = ({ className, ...rest }) => { - const scriptedRef = useScriptRef(); - - const { firebaseEmailPasswordSignIn, firebaseGoogleSignIn } = useAuth(); - - const googleHandler = async () => { - try { - await firebaseGoogleSignIn(); - } catch (err) { - console.error(err); - } - }; - return ( { email: Yup.string().email('Must be a valid email').max(255).required('Email is required'), password: Yup.string().max(255).required('Password is required') })} - onSubmit={async (values, { setErrors, setStatus, setSubmitting }) => { - try { - await firebaseEmailPasswordSignIn(values.email, values.password); - - if (scriptedRef.current) { - setStatus({ success: true }); - setSubmitting(true); - } - } catch (err) { - console.error(err); - if (scriptedRef.current) { - setStatus({ success: false }); - setErrors({ submit: err.message }); - setSubmitting(false); - } - } - }} > {({ errors, handleBlur, handleChange, handleSubmit, isSubmitting, touched, values }) => (
{ type="email" value={values.email} /> - {touched.email && errors.email && {errors.email}} + {touched.email && errors.email && {errors.email}}
{ type="password" value={values.password} /> - {touched.password && errors.password && {errors.password}} + {touched.password && errors.password && {errors.password}}
{errors.submit && ( @@ -84,7 +52,7 @@ const FirebaseLogin = ({ className, ...rest }) => { )} -
+