From 3955b0cc600d145a338c085858d835dcaa7078ef Mon Sep 17 00:00:00 2001 From: Farrah Mae Ochoa Date: Wed, 8 May 2024 16:48:37 +0400 Subject: [PATCH 1/3] feat: app layout --- src/App.tsx | 5 +- src/components/AppFooter/AppFooter.scss | 4 ++ src/components/AppFooter/AppFooter.tsx | 20 +++++++ .../AppFooter/__tests__/AppFooter.spec.tsx | 13 ++++ src/components/AppFooter/index.ts | 1 + src/components/AppHeader/AppHeader.scss | 8 +++ .../Header.tsx => AppHeader/AppHeader.tsx} | 23 +++++--- .../__tests__/AppHeader.spec.tsx} | 8 +-- src/components/AppHeader/index.ts | 1 + src/components/Header/Header.scss | 16 ----- src/components/Header/index.ts | 1 - .../Modals/LanguagesModal/LanguagesModal.scss | 8 +++ .../Modals/LanguagesModal/LanguagesModal.tsx | 59 +++++++++++++++++++ src/components/Modals/LanguagesModal/index.ts | 1 + src/components/Modals/index.ts | 1 + src/components/index.ts | 3 +- 16 files changed, 139 insertions(+), 33 deletions(-) create mode 100644 src/components/AppFooter/AppFooter.scss create mode 100644 src/components/AppFooter/AppFooter.tsx create mode 100644 src/components/AppFooter/__tests__/AppFooter.spec.tsx create mode 100644 src/components/AppFooter/index.ts create mode 100644 src/components/AppHeader/AppHeader.scss rename src/components/{Header/Header.tsx => AppHeader/AppHeader.tsx} (64%) rename src/components/{Header/__tests__/Header.spec.tsx => AppHeader/__tests__/AppHeader.spec.tsx} (90%) create mode 100644 src/components/AppHeader/index.ts delete mode 100644 src/components/Header/Header.scss delete mode 100644 src/components/Header/index.ts create mode 100644 src/components/Modals/LanguagesModal/LanguagesModal.scss create mode 100644 src/components/Modals/LanguagesModal/LanguagesModal.tsx create mode 100644 src/components/Modals/LanguagesModal/index.ts diff --git a/src/App.tsx b/src/App.tsx index 7bd43c23..81816de2 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -1,15 +1,16 @@ import { BrowserRouter } from 'react-router-dom'; import { QueryParamProvider } from 'use-query-params'; import { ReactRouter5Adapter } from 'use-query-params/adapters/react-router-5'; -import { Header } from '@/components'; +import { AppFooter, AppHeader } from '@/components'; import AppContent from './routes/AppContent'; const App = () => { return ( -
+ + ); diff --git a/src/components/AppFooter/AppFooter.scss b/src/components/AppFooter/AppFooter.scss new file mode 100644 index 00000000..b0fd5fe0 --- /dev/null +++ b/src/components/AppFooter/AppFooter.scss @@ -0,0 +1,4 @@ +.app-footer { + height: 3rem; + padding: 2.4rem; +} diff --git a/src/components/AppFooter/AppFooter.tsx b/src/components/AppFooter/AppFooter.tsx new file mode 100644 index 00000000..b2839d6b --- /dev/null +++ b/src/components/AppFooter/AppFooter.tsx @@ -0,0 +1,20 @@ +import { LanguagesModal } from '@/components/Modals'; +import { useModalManager } from '@/hooks/custom-hooks'; +import { useTranslations } from '@deriv-com/translations'; +import { Button, Footer } from '@deriv-com/ui'; +import './AppFooter.scss'; + +// TODO: handle local storage values not updating after changing local storage values +const AppFooter = () => { + const { currentLang } = useTranslations(); + const { hideModal, isModalOpenFor, showModal } = useModalManager({ shouldReinitializeModals: false }); + + return ( +
+ + {isModalOpenFor('LanguagesModal') && } +
+ ); +}; + +export default AppFooter; diff --git a/src/components/AppFooter/__tests__/AppFooter.spec.tsx b/src/components/AppFooter/__tests__/AppFooter.spec.tsx new file mode 100644 index 00000000..7caff16d --- /dev/null +++ b/src/components/AppFooter/__tests__/AppFooter.spec.tsx @@ -0,0 +1,13 @@ +import { render, screen } from '@testing-library/react'; +import AppFooter from '../AppFooter'; + +jest.mock('@deriv-com/translations', () => ({ + useTranslations: jest.fn(() => ({ currentLang: 'EN' })), +})); + +describe('', () => { + it('should render the footer', () => { + render(); + expect(screen.getByRole('button', { name: 'EN' })).toBeInTheDocument(); + }); +}); diff --git a/src/components/AppFooter/index.ts b/src/components/AppFooter/index.ts new file mode 100644 index 00000000..b832b24e --- /dev/null +++ b/src/components/AppFooter/index.ts @@ -0,0 +1 @@ +export { default as AppFooter } from './AppFooter'; diff --git a/src/components/AppHeader/AppHeader.scss b/src/components/AppHeader/AppHeader.scss new file mode 100644 index 00000000..d825cd1e --- /dev/null +++ b/src/components/AppHeader/AppHeader.scss @@ -0,0 +1,8 @@ +.app-header { + padding: 2.4rem; + + @include mobile { + padding: 0.8rem 2.4rem; + margin-bottom: 0; + } +} diff --git a/src/components/Header/Header.tsx b/src/components/AppHeader/AppHeader.tsx similarity index 64% rename from src/components/Header/Header.tsx rename to src/components/AppHeader/AppHeader.tsx index 38d309d3..58381554 100644 --- a/src/components/Header/Header.tsx +++ b/src/components/AppHeader/AppHeader.tsx @@ -1,11 +1,10 @@ -import { DerivProductDerivP2pBrandLightLogoWordmarkHorizontalIcon } from '@deriv/quill-icons'; import { useAuthData } from '@deriv-com/api-hooks'; -import { Button } from '@deriv-com/ui'; -import { LocalStorageConstants, LocalStorageUtils, URLUtils } from '@deriv-com/utils'; -import './Header.scss'; +import { Button, Header } from '@deriv-com/ui'; +import { LocalStorageConstants, LocalStorageUtils, URLConstants, URLUtils } from '@deriv-com/utils'; +import './AppHeader.scss'; // TODO: handle local storage values not updating after changing local storage values -const Header = () => { +const AppHeader = () => { const { activeLoginid, logout } = useAuthData(); const appId = LocalStorageUtils.getValue(LocalStorageConstants.configAppId); const serverUrl = localStorage.getItem(LocalStorageConstants.configServerURL.toString()); @@ -15,8 +14,14 @@ const Header = () => { : URLUtils.getOauthURL(); return ( -
- +
+ {activeLoginid ? ( ) : ( @@ -27,8 +32,8 @@ const Header = () => { Login )} -
+
); }; -export default Header; +export default AppHeader; diff --git a/src/components/Header/__tests__/Header.spec.tsx b/src/components/AppHeader/__tests__/AppHeader.spec.tsx similarity index 90% rename from src/components/Header/__tests__/Header.spec.tsx rename to src/components/AppHeader/__tests__/AppHeader.spec.tsx index 8fcf8b9a..85bf541d 100644 --- a/src/components/Header/__tests__/Header.spec.tsx +++ b/src/components/AppHeader/__tests__/AppHeader.spec.tsx @@ -3,7 +3,7 @@ import { useAuthData } from '@deriv-com/api-hooks'; import { URLUtils } from '@deriv-com/utils'; import { render, screen } from '@testing-library/react'; import userEvent from '@testing-library/user-event'; -import Header from '../Header'; +import AppHeader from '../AppHeader'; const mockUseAuthData = useAuthData as jest.Mock; jest.mock('@deriv-com/api-hooks', () => ({ @@ -17,14 +17,14 @@ jest.mock('@deriv-com/ui', () => ({ ), })); -describe('
', () => { +describe('', () => { it('should render the header', () => { - render(
); + render(); expect(screen.getByRole('link', { name: 'Login' })).toHaveAttribute('href', URLUtils.getOauthURL()); }); it('should handle the logout functionality if there is an active login id', async () => { mockUseAuthData.mockReturnValue({ activeLoginid: '12345', logout: jest.fn() }); - render(
); + render(); const logoutButton = screen.getByRole('button', { name: 'Logout' }); const { logout } = mockUseAuthData(); diff --git a/src/components/AppHeader/index.ts b/src/components/AppHeader/index.ts new file mode 100644 index 00000000..6b822c41 --- /dev/null +++ b/src/components/AppHeader/index.ts @@ -0,0 +1 @@ +export { default as AppHeader } from './AppHeader'; diff --git a/src/components/Header/Header.scss b/src/components/Header/Header.scss deleted file mode 100644 index 98a760f8..00000000 --- a/src/components/Header/Header.scss +++ /dev/null @@ -1,16 +0,0 @@ -.header { - height: 4rem; - display: flex; - justify-content: space-between; - align-items: center; - font-size: 1.6rem; - font-weight: 800; - border-bottom: 2px solid #f2f3f4; - padding: 2.4rem; - margin-bottom: 2.4rem; - - @include mobile { - padding: 0.8rem 2.4rem; - margin-bottom: 0; - } -} diff --git a/src/components/Header/index.ts b/src/components/Header/index.ts deleted file mode 100644 index 5653319d..00000000 --- a/src/components/Header/index.ts +++ /dev/null @@ -1 +0,0 @@ -export { default as Header } from './Header'; diff --git a/src/components/Modals/LanguagesModal/LanguagesModal.scss b/src/components/Modals/LanguagesModal/LanguagesModal.scss new file mode 100644 index 00000000..f0c095a5 --- /dev/null +++ b/src/components/Modals/LanguagesModal/LanguagesModal.scss @@ -0,0 +1,8 @@ +.languages-modal { + &__body { + display: grid; + grid-template-columns: repeat(5, 1fr); + grid-gap: 1rem; + padding: 2rem; + } +} diff --git a/src/components/Modals/LanguagesModal/LanguagesModal.tsx b/src/components/Modals/LanguagesModal/LanguagesModal.tsx new file mode 100644 index 00000000..8bac690a --- /dev/null +++ b/src/components/Modals/LanguagesModal/LanguagesModal.tsx @@ -0,0 +1,59 @@ +import { useTranslations } from '@deriv-com/translations'; +import { Button, Modal, Text } from '@deriv-com/ui'; +import './LanguagesModal.scss'; + +type TLanguagesModalProps = { + isModalOpen: boolean; + onClose: () => void; +}; + +const allowed_languages = { + AR: 'العربية', + BN: 'বাংলা', + DE: 'Deutsch', + EN: 'English', + ES: 'Español', + FR: 'Français', + IT: 'Italiano', + KO: '한국어', + PL: 'Polish', + PT: 'Português', + RU: 'Русский', + SI: 'සිංහල', + TH: 'ไทย', + TR: 'Türkçe', + VI: 'Tiếng Việt', + ZH_CN: '简体中文', + ZH_TW: '繁體中文', +}; + +const LanguagesModal = ({ isModalOpen, onClose }: TLanguagesModalProps) => { + const { switchLanguage } = useTranslations(); + + return ( + + + {'Select Language'} + + + {Object.keys(allowed_languages).map(language_key => { + return ( + + ); + })} + + + ); +}; + +export default LanguagesModal; diff --git a/src/components/Modals/LanguagesModal/index.ts b/src/components/Modals/LanguagesModal/index.ts new file mode 100644 index 00000000..0cfe8480 --- /dev/null +++ b/src/components/Modals/LanguagesModal/index.ts @@ -0,0 +1 @@ +export { default as LanguagesModal } from './LanguagesModal'; diff --git a/src/components/Modals/index.ts b/src/components/Modals/index.ts index 0000dee5..9f4bcc81 100644 --- a/src/components/Modals/index.ts +++ b/src/components/Modals/index.ts @@ -11,6 +11,7 @@ export * from './DailyLimitModal'; export * from './EmailVerificationModal'; export * from './ErrorModal'; export * from './FilterModal'; +export * from './LanguagesModal'; export * from './MyAdsDeleteModal'; export * from './NicknameModal'; export * from './OrderDetailsCancelModal'; diff --git a/src/components/index.ts b/src/components/index.ts index 7406e03c..a617e7ab 100644 --- a/src/components/index.ts +++ b/src/components/index.ts @@ -1,5 +1,7 @@ export * from './AdvertiserName'; export * from './AdvertsTableRow'; +export * from './AppFooter'; +export * from './AppHeader'; export * from './Badge'; export * from './BuySellForm'; export * from './Checklist'; @@ -9,7 +11,6 @@ export * from './FileDropzone'; export * from './FloatingRate'; export * from './FormProgress'; export * from './FullPageMobileWrapper'; -export * from './Header'; export * from './Input'; export * from './LightDivider'; export * from './MobileTabs'; From 8982341f15385b1d14de9360a24d2a036db45074 Mon Sep 17 00:00:00 2001 From: Farrah Mae Ochoa Date: Thu, 9 May 2024 15:53:37 +0400 Subject: [PATCH 2/3] fix: style issues --- package-lock.json | 28 +++---- package.json | 2 +- src/App.tsx | 5 +- src/components/AppFooter/AppFooter.scss | 11 ++- src/components/AppFooter/AppFooter.tsx | 13 +++- .../AppFooter/__tests__/AppFooter.spec.tsx | 10 +++ src/components/AppHeader/AppHeader.scss | 3 +- src/components/AppHeader/AppHeader.tsx | 74 ++++++++++++++++--- .../Modals/LanguagesModal/LanguagesModal.scss | 17 ++++- .../Modals/LanguagesModal/LanguagesModal.tsx | 40 ++++------ src/constants/index.ts | 1 + src/constants/languages.ts | 29 ++++++++ .../screens/BuySellTable/BuySellTable.scss | 1 + .../endpoint/screens/Endpoint/Endpoint.scss | 1 + src/routes/AppContent/index.scss | 5 +- src/routes/AppContent/index.tsx | 42 +++++------ 16 files changed, 201 insertions(+), 81 deletions(-) create mode 100644 src/constants/languages.ts diff --git a/package-lock.json b/package-lock.json index 65af85c4..8cc059ee 100644 --- a/package-lock.json +++ b/package-lock.json @@ -11,7 +11,7 @@ "@babel/preset-env": "^7.24.5", "@deriv-com/api-hooks": "^0.1.19", "@deriv-com/translations": "^1.2.0", - "@deriv-com/ui": "latest", + "@deriv-com/ui": "^1.21.1", "@deriv-com/utils": "latest", "@deriv/deriv-api": "^1.0.15", "@deriv/quill-design": "^1.2.24", @@ -2716,10 +2716,11 @@ } }, "node_modules/@deriv-com/ui": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/@deriv-com/ui/-/ui-1.14.1.tgz", - "integrity": "sha512-gaLopXyvYQrB0DLT/fpbU4JNd5R9u6XDnKvBqrsyRgidSPmth/Q3ar6M4qe5Q2GBisbOkcMawPmIkHJkZ71kfQ==", + "version": "1.21.1", + "resolved": "https://registry.npmjs.org/@deriv-com/ui/-/ui-1.21.1.tgz", + "integrity": "sha512-8aokCnRAQJqnpr8Kzz4qpdRoqy2EJrusfVtUSS8nb1uUvIQiMRwPMzqPt1A/OojFmTDHpES7YJPPLlu2e90LpQ==", "dependencies": { + "@deriv/quill-icons": "^1.22.5", "@types/react-modal": "^3.16.3" }, "optionalDependencies": { @@ -2763,9 +2764,9 @@ } }, "node_modules/@deriv/quill-icons": { - "version": "1.22.0", - "resolved": "https://registry.npmjs.org/@deriv/quill-icons/-/quill-icons-1.22.0.tgz", - "integrity": "sha512-q5ELpEeQT+oFF7hh9Z3qi9JDc8TyCpPDJ2MfSzKFw+bcNH1+rIxHUksjgzQjrPiLlWyb0P6U0RPZtyrBVhOm3g==", + "version": "1.22.6", + "resolved": "https://registry.npmjs.org/@deriv/quill-icons/-/quill-icons-1.22.6.tgz", + "integrity": "sha512-i5El+qnJEXgc/IAc9XweexpZX5TlqqOsE+PEX2dP2te7IcnxVTGyLxFlXbgARbwQzGV5638d5fMrw7eUtmPGAQ==", "peerDependencies": { "react": ">= 16", "react-dom": ">= 16" @@ -22683,10 +22684,11 @@ } }, "@deriv-com/ui": { - "version": "1.14.1", - "resolved": "https://registry.npmjs.org/@deriv-com/ui/-/ui-1.14.1.tgz", - "integrity": "sha512-gaLopXyvYQrB0DLT/fpbU4JNd5R9u6XDnKvBqrsyRgidSPmth/Q3ar6M4qe5Q2GBisbOkcMawPmIkHJkZ71kfQ==", + "version": "1.21.1", + "resolved": "https://registry.npmjs.org/@deriv-com/ui/-/ui-1.21.1.tgz", + "integrity": "sha512-8aokCnRAQJqnpr8Kzz4qpdRoqy2EJrusfVtUSS8nb1uUvIQiMRwPMzqPt1A/OojFmTDHpES7YJPPLlu2e90LpQ==", "requires": { + "@deriv/quill-icons": "^1.22.5", "@rollup/rollup-linux-x64-gnu": "^4.13.0", "@types/react-modal": "^3.16.3" } @@ -22718,9 +22720,9 @@ "requires": {} }, "@deriv/quill-icons": { - "version": "1.22.0", - "resolved": "https://registry.npmjs.org/@deriv/quill-icons/-/quill-icons-1.22.0.tgz", - "integrity": "sha512-q5ELpEeQT+oFF7hh9Z3qi9JDc8TyCpPDJ2MfSzKFw+bcNH1+rIxHUksjgzQjrPiLlWyb0P6U0RPZtyrBVhOm3g==", + "version": "1.22.6", + "resolved": "https://registry.npmjs.org/@deriv/quill-icons/-/quill-icons-1.22.6.tgz", + "integrity": "sha512-i5El+qnJEXgc/IAc9XweexpZX5TlqqOsE+PEX2dP2te7IcnxVTGyLxFlXbgARbwQzGV5638d5fMrw7eUtmPGAQ==", "requires": {} }, "@esbuild/aix-ppc64": { diff --git a/package.json b/package.json index 24a7a526..50f91b17 100644 --- a/package.json +++ b/package.json @@ -17,7 +17,7 @@ "@babel/preset-env": "^7.24.5", "@deriv-com/api-hooks": "^0.1.19", "@deriv-com/translations": "^1.2.0", - "@deriv-com/ui": "latest", + "@deriv-com/ui": "^1.21.1", "@deriv-com/utils": "latest", "@deriv/deriv-api": "^1.0.15", "@deriv/quill-design": "^1.2.24", diff --git a/src/App.tsx b/src/App.tsx index 442fbb56..d8604477 100644 --- a/src/App.tsx +++ b/src/App.tsx @@ -3,6 +3,7 @@ import { QueryParamProvider } from 'use-query-params'; import { ReactRouter5Adapter } from 'use-query-params/adapters/react-router-5'; import { AppFooter, AppHeader } from '@/components'; import { initializeI18n, TranslationProvider } from '@deriv-com/translations'; +import { useDevice } from '@deriv-com/ui'; import AppContent from './routes/AppContent'; //TODO: replace with ${process.env.VITE_PROJECT_NAME}/${process.env.VITE_CROWDIN_BRANCH_NAME} @@ -11,13 +12,15 @@ const i18nInstance = initializeI18n({ }); const App = () => { + const { isDesktop } = useDevice(); + return ( - + {isDesktop && } diff --git a/src/components/AppFooter/AppFooter.scss b/src/components/AppFooter/AppFooter.scss index b0fd5fe0..222db1ef 100644 --- a/src/components/AppFooter/AppFooter.scss +++ b/src/components/AppFooter/AppFooter.scss @@ -1,4 +1,13 @@ .app-footer { - height: 3rem; padding: 2.4rem; + + &__language-btn { + &:hover { + background-color: transparent !important; + + span { + color: #000 !important; + } + } + } } diff --git a/src/components/AppFooter/AppFooter.tsx b/src/components/AppFooter/AppFooter.tsx index b2839d6b..51628391 100644 --- a/src/components/AppFooter/AppFooter.tsx +++ b/src/components/AppFooter/AppFooter.tsx @@ -1,4 +1,5 @@ import { LanguagesModal } from '@/components/Modals'; +import { LANGUAGES } from '@/constants'; import { useModalManager } from '@/hooks/custom-hooks'; import { useTranslations } from '@deriv-com/translations'; import { Button, Footer } from '@deriv-com/ui'; @@ -8,10 +9,20 @@ import './AppFooter.scss'; const AppFooter = () => { const { currentLang } = useTranslations(); const { hideModal, isModalOpenFor, showModal } = useModalManager({ shouldReinitializeModals: false }); + const CountryIcon = LANGUAGES.find(lang => lang.code === currentLang)?.icon; return (
- + {isModalOpenFor('LanguagesModal') && }
); diff --git a/src/components/AppFooter/__tests__/AppFooter.spec.tsx b/src/components/AppFooter/__tests__/AppFooter.spec.tsx index 7caff16d..dfdb0b98 100644 --- a/src/components/AppFooter/__tests__/AppFooter.spec.tsx +++ b/src/components/AppFooter/__tests__/AppFooter.spec.tsx @@ -1,10 +1,20 @@ import { render, screen } from '@testing-library/react'; import AppFooter from '../AppFooter'; +jest.mock('use-query-params', () => ({ + ...jest.requireActual('use-query-params'), + useQueryParams: jest.fn().mockReturnValue([{}, jest.fn()]), +})); + jest.mock('@deriv-com/translations', () => ({ useTranslations: jest.fn(() => ({ currentLang: 'EN' })), })); +jest.mock('@deriv-com/ui', () => ({ + ...jest.requireActual('@deriv-com/ui'), + useDevice: jest.fn(() => ({ isMobile: false })), +})); + describe('', () => { it('should render the footer', () => { render(); diff --git a/src/components/AppHeader/AppHeader.scss b/src/components/AppHeader/AppHeader.scss index d825cd1e..749eeffe 100644 --- a/src/components/AppHeader/AppHeader.scss +++ b/src/components/AppHeader/AppHeader.scss @@ -2,7 +2,6 @@ padding: 2.4rem; @include mobile { - padding: 0.8rem 2.4rem; - margin-bottom: 0; + padding-left: 0; } } diff --git a/src/components/AppHeader/AppHeader.tsx b/src/components/AppHeader/AppHeader.tsx index 58381554..89208521 100644 --- a/src/components/AppHeader/AppHeader.tsx +++ b/src/components/AppHeader/AppHeader.tsx @@ -1,10 +1,18 @@ +import { useState } from 'react'; +import { + LabelPairedHouseBlankMdRegularIcon, + LegacyChevronRight2pxIcon, + LegacyMenuHamburger1pxIcon, +} from '@deriv/quill-icons'; import { useAuthData } from '@deriv-com/api-hooks'; -import { Button, Header } from '@deriv-com/ui'; -import { LocalStorageConstants, LocalStorageUtils, URLConstants, URLUtils } from '@deriv-com/utils'; +import { Button, DerivLogo, Drawer, Header, MenuItem, Text, useDevice, Wrapper } from '@deriv-com/ui'; +import { LocalStorageConstants, LocalStorageUtils, URLUtils } from '@deriv-com/utils'; import './AppHeader.scss'; // TODO: handle local storage values not updating after changing local storage values const AppHeader = () => { + const [isDrawerOpen, setIsDrawerOpen] = useState(false); + const { isDesktop } = useDevice(); const { activeLoginid, logout } = useAuthData(); const appId = LocalStorageUtils.getValue(LocalStorageConstants.configAppId); const serverUrl = localStorage.getItem(LocalStorageConstants.configServerURL.toString()); @@ -15,13 +23,59 @@ const AppHeader = () => { return (
- + {isDesktop ? ( + + + } + > + Trader's Hub + + + ) : ( + + { + setIsDrawerOpen(false); + }} + width='300px' + > + { + setIsDrawerOpen(false); + }} + > + Menu + + +
+ } + rightComponent={} + > + Trader's Hub + +
+
+
+ ) : ( @@ -29,7 +83,7 @@ const AppHeader = () => { className='bg-solid-coral-800 text-body-sm text-opacity-white-800 rounded-200 px-800 py-300 font-bold' href={oauthUrl} > - Login + Log in )}
diff --git a/src/components/Modals/LanguagesModal/LanguagesModal.scss b/src/components/Modals/LanguagesModal/LanguagesModal.scss index f0c095a5..00e89425 100644 --- a/src/components/Modals/LanguagesModal/LanguagesModal.scss +++ b/src/components/Modals/LanguagesModal/LanguagesModal.scss @@ -1,8 +1,23 @@ .languages-modal { &__body { display: grid; - grid-template-columns: repeat(5, 1fr); + grid-template-columns: repeat(4, 1fr); grid-gap: 1rem; padding: 2rem; + + &-button { + height: auto; + display: flex; + align-items: center; + flex-direction: column; + + &:hover { + background-color: transparent !important; + + span { + color: #000 !important; + } + } + } } } diff --git a/src/components/Modals/LanguagesModal/LanguagesModal.tsx b/src/components/Modals/LanguagesModal/LanguagesModal.tsx index 8bac690a..b312e768 100644 --- a/src/components/Modals/LanguagesModal/LanguagesModal.tsx +++ b/src/components/Modals/LanguagesModal/LanguagesModal.tsx @@ -1,3 +1,4 @@ +import { LANGUAGES } from '@/constants'; import { useTranslations } from '@deriv-com/translations'; import { Button, Modal, Text } from '@deriv-com/ui'; import './LanguagesModal.scss'; @@ -7,47 +8,32 @@ type TLanguagesModalProps = { onClose: () => void; }; -const allowed_languages = { - AR: 'العربية', - BN: 'বাংলা', - DE: 'Deutsch', - EN: 'English', - ES: 'Español', - FR: 'Français', - IT: 'Italiano', - KO: '한국어', - PL: 'Polish', - PT: 'Português', - RU: 'Русский', - SI: 'සිංහල', - TH: 'ไทย', - TR: 'Türkçe', - VI: 'Tiếng Việt', - ZH_CN: '简体中文', - ZH_TW: '繁體中文', -}; - const LanguagesModal = ({ isModalOpen, onClose }: TLanguagesModalProps) => { - const { switchLanguage } = useTranslations(); + const { currentLang, switchLanguage } = useTranslations(); return ( - - + + {'Select Language'} - {Object.keys(allowed_languages).map(language_key => { + {LANGUAGES.map(language => { + const LanguageIcon = language.icon; return ( ); })} diff --git a/src/constants/index.ts b/src/constants/index.ts index 1c1a6aec..38e24176 100644 --- a/src/constants/index.ts +++ b/src/constants/index.ts @@ -2,6 +2,7 @@ export * from './ad-constants'; export * from './api-error-codes'; export * from './buy-sell'; export * from './chat-constants'; +export * from './languages'; export * from './orders'; export * from './p2p-logo'; export * from './payment-methods'; diff --git a/src/constants/languages.ts b/src/constants/languages.ts new file mode 100644 index 00000000..9e5ac83b --- /dev/null +++ b/src/constants/languages.ts @@ -0,0 +1,29 @@ +import { + FlagFranceIcon, + FlagGermanyIcon, + FlagItalyIcon, + FlagPolandIcon, + FlagPortugalIcon, + FlagRussiaIcon, + FlagSpainIcon, + FlagThailandIcon, + FlagTurkeyIcon, + FlagUnitedArabEmiratesIcon, + FlagUnitedKingdomIcon, + FlagVietnamIcon, +} from '@deriv/quill-icons'; + +export const LANGUAGES = [ + { code: 'AR', display_name: 'العربية', icon: FlagUnitedArabEmiratesIcon }, + { code: 'DE', display_name: 'Deutsch', icon: FlagGermanyIcon }, + { code: 'EN', display_name: 'English', icon: FlagUnitedKingdomIcon }, + { code: 'ES', display_name: 'Español', icon: FlagSpainIcon }, + { code: 'FR', display_name: 'Français', icon: FlagFranceIcon }, + { code: 'IT', display_name: 'Italiano', icon: FlagItalyIcon }, + { code: 'PL', display_name: 'Polish', icon: FlagPolandIcon }, + { code: 'PT', display_name: 'Português', icon: FlagPortugalIcon }, + { code: 'RU', display_name: 'Русский', icon: FlagRussiaIcon }, + { code: 'TH', display_name: 'ไทย', icon: FlagThailandIcon }, + { code: 'TR', display_name: 'Türkçe', icon: FlagTurkeyIcon }, + { code: 'VI', display_name: 'Tiếng Việt', icon: FlagVietnamIcon }, +]; diff --git a/src/pages/buy-sell/screens/BuySellTable/BuySellTable.scss b/src/pages/buy-sell/screens/BuySellTable/BuySellTable.scss index 9eb5a03c..51441a5d 100644 --- a/src/pages/buy-sell/screens/BuySellTable/BuySellTable.scss +++ b/src/pages/buy-sell/screens/BuySellTable/BuySellTable.scss @@ -7,6 +7,7 @@ } &__content { overflow: auto; + padding-bottom: 2rem; @include mobile { // stylelint-disable-next-line declaration-no-important diff --git a/src/pages/endpoint/screens/Endpoint/Endpoint.scss b/src/pages/endpoint/screens/Endpoint/Endpoint.scss index b8a5391f..cdeb472a 100644 --- a/src/pages/endpoint/screens/Endpoint/Endpoint.scss +++ b/src/pages/endpoint/screens/Endpoint/Endpoint.scss @@ -1,6 +1,7 @@ .endpoint { position: absolute; top: 8rem; + left: 0; background: #fff; width: 100%; height: 60%; diff --git a/src/routes/AppContent/index.scss b/src/routes/AppContent/index.scss index af981e8a..c16458bf 100644 --- a/src/routes/AppContent/index.scss +++ b/src/routes/AppContent/index.scss @@ -1,15 +1,16 @@ .app-content { overflow: hidden; - min-height: calc(100vh - 48px - 36px - 53px - 2.4rem); + height: calc(100vh - 14rem); @include desktop { max-width: 952px; min-width: 672px; - margin: 0 auto; + margin: 2rem auto; } @include mobile { width: 100vw; + height: 100vh; } &__tabs { diff --git a/src/routes/AppContent/index.tsx b/src/routes/AppContent/index.tsx index 5ae5f674..6d1e08ca 100644 --- a/src/routes/AppContent/index.tsx +++ b/src/routes/AppContent/index.tsx @@ -59,14 +59,6 @@ const AppContent = () => { setActiveTab(getActiveTab(location.pathname)); }, [location]); - if ((isLoadingActiveAccount || !activeAccountData) && !isEndpointRoute) { - return ; - } - - // NOTE: Replace this with P2PBlocked component later and a custom hook useIsP2PEnabled, P2P is only available for USD accounts - if (activeAccountData?.currency !== 'USD' && !isEndpointRoute) - return

P2P is only available for USD accounts.

; - return ( { }} >
- { - setActiveTab(tabRoutesConfiguration[index].name); - history.push(tabRoutesConfiguration[index].path); - }} - variant='secondary' - > - {tabRoutesConfiguration.map(route => ( - - ))} - - + {(isLoadingActiveAccount || !activeAccountData) && !isEndpointRoute ? ( + + ) : ( + <> + { + setActiveTab(tabRoutesConfiguration[index].name); + history.push(tabRoutesConfiguration[index].path); + }} + variant='secondary' + > + {tabRoutesConfiguration.map(route => ( + + ))} + + + + )}
); From bc14f8de0dec837be160a908e0029750f38f325f Mon Sep 17 00:00:00 2001 From: Farrah Mae Ochoa Date: Thu, 9 May 2024 17:10:14 +0400 Subject: [PATCH 3/3] fix: types --- src/components/AppFooter/AppFooter.tsx | 5 +++-- src/components/AppHeader/AppHeader.tsx | 4 ++-- src/hooks/__tests__/useModalManager.spec.tsx | 1 + .../MyProfileCounterpartiesTable.tsx | 1 - .../__tests__/PaymentMethodsEmpty.spec.tsx | 3 +++ .../PaymentMethodsList/__test__/PaymentMethodsList.spec.tsx | 5 +++++ src/pages/orders/screens/Orders/Orders.tsx | 2 -- src/pages/orders/screens/Orders/OrdersTable/OrdersTable.tsx | 4 +--- 8 files changed, 15 insertions(+), 10 deletions(-) diff --git a/src/components/AppFooter/AppFooter.tsx b/src/components/AppFooter/AppFooter.tsx index 51628391..340e4947 100644 --- a/src/components/AppFooter/AppFooter.tsx +++ b/src/components/AppFooter/AppFooter.tsx @@ -1,6 +1,7 @@ import { LanguagesModal } from '@/components/Modals'; import { LANGUAGES } from '@/constants'; import { useModalManager } from '@/hooks/custom-hooks'; +import { IconTypes } from '@deriv/quill-icons'; import { useTranslations } from '@deriv-com/translations'; import { Button, Footer } from '@deriv-com/ui'; import './AppFooter.scss'; @@ -8,8 +9,8 @@ import './AppFooter.scss'; // TODO: handle local storage values not updating after changing local storage values const AppFooter = () => { const { currentLang } = useTranslations(); - const { hideModal, isModalOpenFor, showModal } = useModalManager({ shouldReinitializeModals: false }); - const CountryIcon = LANGUAGES.find(lang => lang.code === currentLang)?.icon; + const { hideModal, isModalOpenFor, showModal } = useModalManager(); + const CountryIcon = LANGUAGES.find(lang => lang.code === currentLang)?.icon as IconTypes; return (