diff --git a/docker/cozy-app-dev-with-app.sh b/docker/cozy-app-dev-with-app.sh index e53fc8881b7018f837bf9de7c815b75298fe17d8..45571eb6b3c450fb6ed9499f7e581cc19c447c90 100755 --- a/docker/cozy-app-dev-with-app.sh +++ b/docker/cozy-app-dev-with-app.sh @@ -211,9 +211,13 @@ do_install_app() { echo "App succesfully installed" echo "Installing konnectors" - if cozy-stack konnectors ls | grep 'enedisgrandlyon'; then - echo "Removing konnector enedisgrandlyon..." - cozy-stack konnectors uninstall --domain cozy.tools:8080 enedisgrandlyon + # if cozy-stack konnectors ls | grep 'enedisgrandlyon'; then + # echo "Removing konnector enedisgrandlyon..." + # cozy-stack konnectors uninstall --domain cozy.tools:8080 enedisgrandlyon + # fi + if cozy-stack konnectors ls | grep 'enedis-sge-grandlyon'; then + echo "Removing konnector enedis-sge-grandlyon..." + cozy-stack konnectors uninstall --domain cozy.tools:8080 enedis-sge-grandlyon fi if cozy-stack konnectors ls | grep 'grdfgrandlyon'; then echo "Removing konnector grdfgrandlyon..." @@ -223,7 +227,8 @@ do_install_app() { echo "Removing konnector eglgrandlyon..." cozy-stack konnectors uninstall --domain cozy.tools:8080 eglgrandlyon fi - cozy-stack konnectors install --domain cozy.tools:8080 enedisgrandlyon git://forge.grandlyon.com/web-et-numerique/llle_project/enedis-konnector.git#build + # cozy-stack konnectors install --domain cozy.tools:8080 enedisgrandlyon git://forge.grandlyon.com/web-et-numerique/llle_project/enedis-konnector.git#build + cozy-stack konnectors install --domain cozy.tools:8080 enedis-sge-grandlyon git://forge.grandlyon.com/web-et-numerique/llle_project/enedis-sge-konnector.git#build cozy-stack konnectors install --domain cozy.tools:8080 grdfgrandlyon git://forge.grandlyon.com/web-et-numerique/llle_project/grdf-konnector.git#build cozy-stack konnectors install --domain cozy.tools:8080 eglgrandlyon git://forge.grandlyon.com/web-et-numerique/llle_project/egl-konnector.git#build } diff --git a/docker/cozy.yaml b/docker/cozy.yaml index 525c2f3142f3f876108665b2286b42c04ba0a977..93fc6acde705ae6e934ecb9420b005877d9394bc 100644 --- a/docker/cozy.yaml +++ b/docker/cozy.yaml @@ -4,5 +4,8 @@ # You will ALWAYS have CSPs working on a real Cozy # so your final application must work with them on disable_csp: true +log: + # logger level (debug, info, warning, panic, fatal) - flags: --log-level + level: debug # You can find a complete example of the cozy-stack config file here: # https://github.com/cozy/cozy-stack/blob/master/cozy.example.yaml diff --git a/scripts/createConnections.js b/scripts/createConnections.js index ab05e05b460318901ea5bdfbcc80ec71749b65c3..55f85da6d37b21ae8de85adadb2d87e512d97de7 100644 --- a/scripts/createConnections.js +++ b/scripts/createConnections.js @@ -1,5 +1,3 @@ -/* eslint-disable @typescript-eslint/no-var-requires */ -/* eslint-disable @typescript-eslint/camelcase */ const axios = require('axios') const config = require('./config') diff --git a/src/assets/icons/visu/pdl-image.svg b/src/assets/icons/visu/pdl-image.svg new file mode 100644 index 0000000000000000000000000000000000000000..67f4644f55ec57e425c295a0f6dba654f32cda3c --- /dev/null +++ b/src/assets/icons/visu/pdl-image.svg @@ -0,0 +1,9 @@ +<svg width="237" height="385" viewBox="0 0 237 385" fill="none" xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink"> +<rect width="237" height="385" fill="url(#pattern0)"/> +<defs> +<pattern id="pattern0" patternContentUnits="objectBoundingBox" width="1" height="1"> +<use xlink:href="#image0_12639_80631" transform="translate(-0.000276683) scale(0.00380439 0.00234192)"/> +</pattern> +<image id="image0_12639_80631" width="263" height="427" xlink:href=""/> +</defs> +</svg> diff --git a/src/components/App.tsx b/src/components/App.tsx index 2877180faca003b9ef1c3cd4f465b6c49fbc3e9e..a4b354b0a8198b8e88cb157c9341022a021e6390 100644 --- a/src/components/App.tsx +++ b/src/components/App.tsx @@ -50,10 +50,7 @@ export const App = ({ tracker }: AppProps) => { )} <Main> <Content className="app-content"> - <Routes - termsStatus={termsStatus} - isProfileEcogestureCompleted={isProfileEcogestureCompleted} - /> + <Routes termsStatus={termsStatus} /> </Content> </Main> </SplashRoot> diff --git a/src/components/Connection/Connection.spec.tsx b/src/components/Connection/Connection.spec.tsx index bc417a77f2df40182fefa5590f26754f053cd15c..e3f3dca8bbc8091b8313f0d1d2b16a099094fc6b 100644 --- a/src/components/Connection/Connection.spec.tsx +++ b/src/components/Connection/Connection.spec.tsx @@ -3,6 +3,10 @@ import { mount } from 'enzyme' import toJson from 'enzyme-to-json' import Connection from 'components/Connection/Connection' import { fluidStatusConnectedData } from '../../../tests/__mocks__/fluidStatusData.mock' +import * as reactRedux from 'react-redux' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import { globalStateData } from '../../../tests/__mocks__/globalStateData.mock' jest.mock('components/Connection/ConnectionLogin', () => { return jest.fn(() => { @@ -25,23 +29,31 @@ jest.mock('cozy-ui/transpiled/react/I18n', () => { }), } }) - -const mockDispatch = jest.fn() -jest.mock('react-redux', () => ({ - useDispatch: () => mockDispatch, -})) - +const mockStore = configureStore([]) +const useDispatchSpy = jest.spyOn(reactRedux, 'useDispatch') +const useSelectorSpy = jest.spyOn(reactRedux, 'useSelector') describe('Connection component test', () => { + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) it('should call ConnectionOAuth', () => { const wrapper = mount( - <Connection fluidStatus={fluidStatusConnectedData[2]} /> + <Provider store={store}> + <Connection fluidStatus={fluidStatusConnectedData[2]} /> + </Provider> ) expect(toJson(wrapper)).toMatchSnapshot() }) it('should call ConnectionLogin', () => { + useDispatchSpy.mockReturnValue(jest.fn()) + useSelectorSpy.mockReturnValue(globalStateData) const wrapper = mount( - <Connection fluidStatus={fluidStatusConnectedData[0]} /> + <Provider store={store}> + <Connection fluidStatus={fluidStatusConnectedData[0]} /> + </Provider> ) expect(toJson(wrapper)).toMatchSnapshot() }) diff --git a/src/components/Connection/Connection.tsx b/src/components/Connection/Connection.tsx index 0fae75cc5cabba0a142d7017479c35934c00c65f..61ba7c10aa30a149bc02a0e9eb80cce352d8d966 100644 --- a/src/components/Connection/Connection.tsx +++ b/src/components/Connection/Connection.tsx @@ -6,6 +6,8 @@ import { FluidStatus, FluidConnection } from 'models' import ConnectionLogin from 'components/Connection/ConnectionLogin' import ConnectionOauth from 'components/Connection/ConnectionOAuth' import './connection.scss' +import { FluidType } from 'enum/fluid.enum' +import SgeInit from './SGEConnect/SgeInit' interface ConnectionProps { fluidStatus: FluidStatus } @@ -24,9 +26,13 @@ const Connection: React.FC<ConnectionProps> = ({ }, [dispatch, fluidStatus.fluidType, fluidStatus.connection]) return ( <div className="konnector-form"> - {!fluidStatus.connection.konnectorConfig.oauth ? ( - <ConnectionLogin fluidStatus={fluidStatus} onSuccess={handleSuccess} /> - ) : ( + {fluidStatus.fluidType === FluidType.ELECTRICITY && ( + <SgeInit fluidStatus={fluidStatus} /> + )} + {fluidStatus.fluidType === FluidType.WATER && ( + <ConnectionLogin fluidStatus={fluidStatus} /> + )} + {fluidStatus.fluidType === FluidType.GAS && ( <ConnectionOauth fluidStatus={fluidStatus} onSuccess={handleSuccess} /> )} </div> diff --git a/src/components/Connection/ConnectionLogin.tsx b/src/components/Connection/ConnectionLogin.tsx index ae572a9ebc7ab629c580e9fd61e014ec51b825ed..0a410cd12584dfba44c1e106607fb5373ec3eea6 100644 --- a/src/components/Connection/ConnectionLogin.tsx +++ b/src/components/Connection/ConnectionLogin.tsx @@ -8,12 +8,10 @@ import ConnectionLoginNoPartnerAccount from './ConnectionLoginNoPartnerAccount' interface ConnectionLoginProps { fluidStatus: FluidStatus - onSuccess: () => Promise<void> } const ConnectionLogin: React.FC<ConnectionLoginProps> = ({ fluidStatus, - onSuccess, }: ConnectionLoginProps) => { const konnectorSlug: string = fluidStatus.connection.konnectorConfig.slug const siteLink: string = fluidStatus.connection.konnectorConfig.siteLink @@ -39,14 +37,12 @@ const ConnectionLogin: React.FC<ConnectionLoginProps> = ({ <ConnectionLoginWithPartnerAccount konnectorSlug={konnectorSlug} fluidStatus={fluidStatus} - handleSuccess={onSuccess} togglePartnerConnectionModal={togglePartnerConnectionModal} /> ) : ( <ConnectionLoginNoPartnerAccount konnectorSlug={konnectorSlug} fluidStatus={fluidStatus} - handleSuccess={onSuccess} togglePartnerConnectionModal={togglePartnerConnectionModal} /> )} diff --git a/src/components/Connection/ConnectionLoginNoPartnerAccount.tsx b/src/components/Connection/ConnectionLoginNoPartnerAccount.tsx index 29b8738dad26d30e62e1844bd23e17f04cd9aca4..da6a343c089daee9610f38e2e472468bae108e44 100644 --- a/src/components/Connection/ConnectionLoginNoPartnerAccount.tsx +++ b/src/components/Connection/ConnectionLoginNoPartnerAccount.tsx @@ -8,14 +8,12 @@ import FormLogin from 'components/Connection/FormLogin' interface ConnectionLoginNoPartnerAccountProps { konnectorSlug: string fluidStatus: FluidStatus - handleSuccess: () => Promise<void> togglePartnerConnectionModal: () => void } const ConnectionLoginNoPartnerAccount = ({ konnectorSlug, fluidStatus, - handleSuccess, togglePartnerConnectionModal, }: ConnectionLoginNoPartnerAccountProps) => { const { t } = useI18n() @@ -49,11 +47,7 @@ const ConnectionLoginNoPartnerAccount = ({ {t('auth.' + `${konnectorSlug}` + '.no_account.subtitle2_info')} </div> <div className="kloginform-connect-button"> - <FormLogin - fluidStatus={fluidStatus} - highlightedStyle={false} - handleSuccess={handleSuccess} - /> + <FormLogin fluidStatus={fluidStatus} highlightedStyle={false} /> </div> </div> ) diff --git a/src/components/Connection/ConnectionLoginWithPartnerAccount.tsx b/src/components/Connection/ConnectionLoginWithPartnerAccount.tsx index 242e84c8bd860af204b80862b68b261d8d3a4652..9da0f6abcbb38b8cd22395a34cd086f57894268c 100644 --- a/src/components/Connection/ConnectionLoginWithPartnerAccount.tsx +++ b/src/components/Connection/ConnectionLoginWithPartnerAccount.tsx @@ -8,14 +8,12 @@ import FormLogin from 'components/Connection/FormLogin' interface ConnectionLoginWithPartnerAccountProps { konnectorSlug: string fluidStatus: FluidStatus - handleSuccess: () => Promise<void> togglePartnerConnectionModal: () => void } const ConnectionLoginWithPartnerAccount = ({ konnectorSlug, fluidStatus, - handleSuccess, togglePartnerConnectionModal, }: ConnectionLoginWithPartnerAccountProps) => { const { t } = useI18n() @@ -37,11 +35,7 @@ const ConnectionLoginWithPartnerAccount = ({ {t('auth.' + konnectorSlug + '.with_account.subtitle1')} </div> <div className="kloginform-connect-button"> - <FormLogin - fluidStatus={fluidStatus} - highlightedStyle={true} - handleSuccess={handleSuccess} - /> + <FormLogin fluidStatus={fluidStatus} highlightedStyle={true} /> </div> {konnectorSlug === 'grdfgrandlyon' && ( <div className="kloginform-infotext text-16-normal"> diff --git a/src/components/Connection/ConnectionNotFound.spec.tsx b/src/components/Connection/ConnectionNotFound.spec.tsx index 73dd07fae8dd3b763075bbe778c6effa1279a557..fec1c0bf1dc7f0c37812b43a5474da5a2119d514 100644 --- a/src/components/Connection/ConnectionNotFound.spec.tsx +++ b/src/components/Connection/ConnectionNotFound.spec.tsx @@ -14,7 +14,7 @@ jest.mock('cozy-ui/transpiled/react/I18n', () => { }) describe('ConnectionNotFound component test', () => { - const konnectorSlug = 'enedisgrandlyon' + const konnectorSlug = 'enedis-sge-grandlyon' it('should correctly render connection not found', () => { const result = shallow( @@ -31,7 +31,7 @@ describe('ConnectionNotFound component test', () => { submitStyledButton.simulate('click') expect(global.open).toHaveBeenCalledWith( - 'http://localhost/#/discover/enedisgrandlyon', + 'http://localhost/#/discover/enedis-sge-grandlyon', '_blank' ) }) diff --git a/src/components/Connection/FormLogin.tsx b/src/components/Connection/FormLogin.tsx index 3d2f9674e67d63f5bf8c4621194ecc0113d8b9fb..0455d1265fc143e524f7ceeadb9148d45940ff4b 100644 --- a/src/components/Connection/FormLogin.tsx +++ b/src/components/Connection/FormLogin.tsx @@ -1,13 +1,6 @@ import React, { useState, useEffect } from 'react' import { useI18n } from 'cozy-ui/transpiled/react/I18n' -import { useClient } from 'cozy-client' -import { useDispatch } from 'react-redux' - -import { Account, FluidStatus, FluidConnection, UsageEvent } from 'models' -import AccountService from 'services/account.service' -import ConnectionService from 'services/connection.service' -import UsageEventService from 'services/usageEvent.service' - +import { Account, AccountAuthData, FluidStatus } from 'models' import './formLogin.scss' import StyledIconButton from 'components/CommonKit/IconButton/StyledIconButton' import Button from '@material-ui/core/Button' @@ -15,24 +8,18 @@ import TrailingIcon from 'assets/icons/ico/trailing-icon.svg' import StyledIcon from 'components/CommonKit/Icon/StyledIcon' import { FluidType } from 'enum/fluid.enum' import { getPartnerPicto } from 'utils/picto' -import { UsageEventType } from 'enum/usageEvent.enum' -import { updatedFluidConnection } from 'store/global/global.actions' +import useKonnectorAuth from 'components/Hooks/useKonnectorAuth' interface FormLoginProps { fluidStatus: FluidStatus highlightedStyle?: boolean - handleSuccess: () => Promise<void> } const FormLogin: React.FC<FormLoginProps> = ({ fluidStatus, highlightedStyle = true, - handleSuccess, }: FormLoginProps) => { const { t } = useI18n() - const client = useClient() - const dispatch = useDispatch() - const konnectorSlug: string = fluidStatus.connection.konnectorConfig.slug const lastKnownCredentials: string | undefined = fluidStatus.connection.konnectorConfig.lastKnownCredentials @@ -45,6 +32,11 @@ const FormLogin: React.FC<FormLoginProps> = ({ const [loading, setLoading] = useState<boolean>(false) const icon = getPartnerPicto(konnectorSlug, highlightedStyle) + const [connect, update, connectError] = useKonnectorAuth( + fluidStatus, + login, + password + ) const changeLogin = (value: string) => { if ((/[0-9]/.test(value) && value.length <= 7) || value === '') { @@ -69,66 +61,6 @@ const FormLogin: React.FC<FormLoginProps> = ({ } } - const sendUsageEventError = async ( - konnectorSlug: string - ): Promise<UsageEvent> => { - return UsageEventService.addEvent(client, { - type: UsageEventType.KONNECTOR_CONNECT_EVENT, - target: konnectorSlug, - result: 'error', - }) - } - - const connect = async () => { - const connectionService = new ConnectionService(client) - try { - // If first connexion, send the usage event - await UsageEventService.addEvent(client, { - type: UsageEventType.KONNECTOR_ATTEMPT_EVENT, - target: konnectorSlug, - result: 'error', - }) - const { account: _account, trigger: _trigger } = - await connectionService.connectNewUser(konnectorSlug, login, password) - if (!_trigger) { - setError(t('konnector_form.error_account_creation')) - sendUsageEventError(konnectorSlug) - return null - } - const updatedConnection: FluidConnection = { - ...fluidStatus.connection, - account: _account, - trigger: _trigger, - } - setLoading(false) - dispatch(updatedFluidConnection(fluidStatus.fluidType, updatedConnection)) - handleSuccess() - } catch (err) { - setLoading(false) - sendUsageEventError(konnectorSlug) - console.log(err) - } - } - - const update = async () => { - if (fluidStatus.connection.account) { - const _account = fluidStatus.connection.account - const auth = { - login: login, - password: password, - } - _account.auth = auth - const accountService = new AccountService(client) - const updatedAccount = await accountService.updateAccount(_account) - const updatedConnection: FluidConnection = { - ...fluidStatus.connection, - account: updatedAccount, - } - dispatch(updatedFluidConnection(fluidStatus.fluidType, updatedConnection)) - handleSuccess() - } - } - const handleSubmit = async (e: React.FormEvent<HTMLFormElement>) => { e.preventDefault() try { @@ -141,6 +73,7 @@ const FormLogin: React.FC<FormLoginProps> = ({ } if (!account) { await connect() + setLoading(false) } else { await update() } @@ -149,10 +82,14 @@ const FormLogin: React.FC<FormLoginProps> = ({ } } + useEffect(() => { + if (connectError) setError(connectError) + }, [connectError]) + useEffect(() => { if (account?.auth) { const auth = account.auth - const authData = auth + const authData = auth as AccountAuthData if (authData.login) { setLogin(authData.login) } diff --git a/src/components/Connection/SGEConnect/SgeConnect.scss b/src/components/Connection/SGEConnect/SgeConnect.scss new file mode 100644 index 0000000000000000000000000000000000000000..f3d4efd554adb256b003656ecdbd1b6147a79d95 --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeConnect.scss @@ -0,0 +1,74 @@ +@import 'src/styles/base/color'; +@import 'src/styles/base/mixins'; +.sge-view { + // background: $dark-2; + box-sizing: border-box; + min-height: inherit; + width: inherit; + padding: 1rem; + padding-bottom: 4rem; + .sge-step-container { + color: $grey-bright; + .title, + .head { + margin-top: 1.5rem; + } + label { + display: block; + margin-top: 1rem; + margin-bottom: 0.625rem; + } + #zipCode { + max-width: 115px; + } + @include checkBox(); + input:not([type='checkbox']) { + appearance: none; + max-width: 280px; + width: 100%; + height: 45px; + border-radius: 4px; + border: 1px solid $grey-dark; + background: rgba(0, 0, 0, 0.3); + transition: all 300ms ease; + color: $grey-bright; + padding: 0 0.5rem; + &:focus, + &:focus-visible { + outline: 1px solid $gold-shadow; + } + } + /* Chrome, Safari, Edge, Opera */ + input::-webkit-outer-spin-button, + input::-webkit-inner-spin-button { + -webkit-appearance: none; + margin: 0; + } + /* Firefox */ + input[type='number'] { + -moz-appearance: textfield; + } + .pdl-hint { + cursor: pointer; + border-bottom: solid 1px $grey-bright; + text-align: center; + margin: 1rem auto; + padding: 0.2rem; + width: 175px; + } + ul { + padding: 0 1rem; + line-height: 130%; + li { + margin: 0.5rem 0; + } + } + } +} +.sgeHintModal { + text-align: center; + .title { + color: $gold-shadow; + margin: 1rem 0; + } +} diff --git a/src/components/Connection/SGEConnect/SgeConnectView.spec.tsx b/src/components/Connection/SGEConnect/SgeConnectView.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..5f768c23a1bbb35bbee5ea95f74701d92777469a --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeConnectView.spec.tsx @@ -0,0 +1,152 @@ +import React from 'react' +import { mount } from 'enzyme' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import { globalStateData } from '../../../../tests/__mocks__/globalStateData.mock' +import toJson from 'enzyme-to-json' +import SgeConnectView from './SgeConnectView' +import * as reactRedux from 'react-redux' +import { SgeStep } from 'enum/sgeStep.enum' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +jest.mock('components/Content/Content', () => 'mock-content') +jest.mock('components/FormGlobal/FormProgress', () => 'mock-formprogress') + +const mockStore = configureStore([]) +const useDispatchSpy = jest.spyOn(reactRedux, 'useDispatch') + +describe('SgeConnectView component', () => { + beforeEach(() => { + useDispatchSpy.mockReset() + }) + it('should be rendered correctly', () => { + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) + it('should render address Step', () => { + const store = mockStore({ + ecolyo: { + global: { + ...globalStateData, + sgeConnect: { + ...globalStateData.sgeConnect, + currentStep: SgeStep.Address, + }, + }, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + expect(wrapper.find('.stepAddress')).toBeTruthy() + }) + it('should render identity Step', () => { + const store = mockStore({ + ecolyo: { + global: { + ...globalStateData, + sgeConnect: { + ...globalStateData.sgeConnect, + currentStep: SgeStep.IdentityAndPDL, + }, + }, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + expect(wrapper.find('.stepIdentity')).toBeTruthy() + }) + it('should render consent Step', () => { + const store = mockStore({ + ecolyo: { + global: { + ...globalStateData, + sgeConnect: { + ...globalStateData.sgeConnect, + currentStep: SgeStep.Consent, + }, + }, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + expect(wrapper.find('.stepConsent')).toBeTruthy() + }) + it('should render default Step', () => { + const store = mockStore({ + ecolyo: { + global: { + ...globalStateData, + sgeConnect: { + ...globalStateData.sgeConnect, + currentStep: 99, + }, + }, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + expect(wrapper.find('.stepIdentity')).toBeTruthy() + }) + describe('SgeConnectView Navigation methods', () => { + beforeEach(() => { + useDispatchSpy.mockReset() + }) + it('should call nextStep method', () => { + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + wrapper.find('.profile-navigation-button').last().simulate('click') + expect(useDispatchSpy).toHaveBeenCalled() + }) + it('shouldnt call disabled nextStep method', () => { + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeConnectView /> + </Provider> + ) + wrapper.find('.profile-navigation-button').last().simulate('click') + expect(useDispatchSpy).toHaveBeenCalled() + }) + }) +}) diff --git a/src/components/Connection/SGEConnect/SgeConnectView.tsx b/src/components/Connection/SGEConnect/SgeConnectView.tsx new file mode 100644 index 0000000000000000000000000000000000000000..0aac63fb4b8e5fe8a241db77ac4e1c8a39e95bfc --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeConnectView.tsx @@ -0,0 +1,141 @@ +import React, { useCallback, useState } from 'react' +import { useDispatch, useSelector } from 'react-redux' +import { AppStore } from 'store' +import CozyBar from 'components/Header/CozyBar' +import Content from 'components/Content/Content' +import Header from 'components/Header/Header' +import { SgeStep } from 'enum/sgeStep.enum' +import StepIdentityAndPdl from './StepIdentityAndPdl' +import StepAddress from './StepAddress' +import StepConsent from './StepConsent' +import './SgeConnect.scss' +import FormNavigation from 'components/FormGlobal/FormNavigation' +import { SgeStore } from 'models/sgeStore.model' +import { updateSgeStore } from 'store/global/global.actions' +import FormProgress from 'components/FormGlobal/FormProgress' + +const SgeConnectView: React.FC = () => { + const [headerHeight, setHeaderHeight] = useState<number>(0) + const { sgeConnect } = useSelector((state: AppStore) => state.ecolyo.global) + const dispatch = useDispatch() + const [currentStep, setcurrentStep] = useState<SgeStep>( + sgeConnect.currentStep + ) + const [currentSgeState, setcurrentSgeState] = useState<SgeStore>(sgeConnect) + const defineHeaderHeight = useCallback((height: number) => { + setHeaderHeight(height) + }, []) + + const isNextValid = useCallback(() => { + switch (currentStep) { + case SgeStep.IdentityAndPDL: + return ( + currentSgeState.firstName !== '' && + currentSgeState.lastName !== '' && + currentSgeState.pdl !== null && + currentSgeState.pdl.toString().length === 14 + ) + case SgeStep.Address: + return ( + currentSgeState.address !== '' && + currentSgeState.city !== '' && + currentSgeState.zipCode !== null && + currentSgeState.zipCode.toString().length === 5 + ) + case SgeStep.Consent: + return currentSgeState.dataConsent && currentSgeState.pdlConfirm + default: + return false + } + }, [ + currentSgeState.address, + currentSgeState.city, + currentSgeState.dataConsent, + currentSgeState.firstName, + currentSgeState.lastName, + currentSgeState.pdl, + currentSgeState.pdlConfirm, + currentSgeState.zipCode, + currentStep, + ]) + + const handleNext = useCallback(() => { + if (currentStep < SgeStep.Consent && isNextValid()) { + setcurrentStep(prev => prev + 1) + dispatch(updateSgeStore(currentSgeState)) + } + if (currentStep === SgeStep.Consent && isNextValid()) { + const updatedState = { + ...currentSgeState, + shouldLaunchAccount: true, + } + setcurrentSgeState(updatedState) + dispatch(updateSgeStore(updatedState)) + } + }, [currentSgeState, currentStep, dispatch, isNextValid]) + + const handlePrev = useCallback(() => { + if (currentStep !== SgeStep.IdentityAndPDL) { + setcurrentStep(prev => prev - 1) + } + dispatch(updateSgeStore(currentSgeState)) + }, [currentSgeState, currentStep, dispatch]) + + const onChange = useCallback( + (objkey: string, value: string | boolean | number, maxLength?: number) => { + if ( + !maxLength || // optionnal ? + value === '' || + (/[0-9]/.test(value.toString()) && value.toString().length <= maxLength) + ) { + const updatedState = { + ...currentSgeState, + [objkey]: value, + } + setcurrentSgeState(updatedState) + } + }, + [currentSgeState] + ) + + const renderStep = (step: SgeStep) => { + switch (step) { + case SgeStep.Address: + return <StepAddress sgeState={currentSgeState} onChange={onChange} /> + case SgeStep.Consent: + return <StepConsent sgeState={currentSgeState} onChange={onChange} /> + case SgeStep.IdentityAndPDL: + default: + return ( + <StepIdentityAndPdl sgeState={currentSgeState} onChange={onChange} /> + ) + } + } + + return ( + <> + <CozyBar titleKey={'common.title_sge_connect'} displayBackArrow={true} /> + <Header + setHeaderHeight={defineHeaderHeight} + desktopTitleKey={'common.title_sge_connect'} + displayBackArrow={true} + ></Header> + <Content height={headerHeight}> + <div className="sge-view"> + <FormProgress step={currentStep} formType={'sge'} /> + {renderStep(currentStep)} + <FormNavigation + step={currentStep} + handlePrevious={handlePrev} + handleNext={handleNext} + disableNextButton={!isNextValid()} + isEcogesture={false} + isLastConnectStep={currentStep === SgeStep.Consent} + /> + </div> + </Content> + </> + ) +} + +export default SgeConnectView diff --git a/src/components/Connection/SGEConnect/SgeInit.spec.tsx b/src/components/Connection/SGEConnect/SgeInit.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..1b093367e95dd2fbfb4c4bc9534f9b85330b76dd --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeInit.spec.tsx @@ -0,0 +1,103 @@ +import React from 'react' +import { mount } from 'enzyme' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import SgeInit from './SgeInit' +import { + fluidStatusData, + SgeStatusWithAccout, +} from '../../../../tests/__mocks__/fluidStatusData.mock' +import { globalStateData } from '../../../../tests/__mocks__/globalStateData.mock' +import toJson from 'enzyme-to-json' +import { Button } from '@material-ui/core' +import { waitForComponentToPaint } from '../../../../tests/__mocks__/testUtils' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +const mockHistoryPush = jest.fn() +jest.mock('react-router-dom', () => ({ + ...jest.requireActual('react-router-dom'), + useHistory: () => ({ + push: mockHistoryPush, + }), +})) + +const mockConnect = jest.fn() +const mockUpdate = jest.fn() + +jest.mock('components/Hooks/useKonnectorAuth', () => + jest.fn(() => [mockConnect, mockUpdate]) +) +const mockStore = configureStore([]) + +describe('SgeInit component', () => { + it('should be rendered correctly', () => { + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeInit fluidStatus={fluidStatusData[0]} /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) + it('should go to sge connect steps', () => { + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeInit fluidStatus={fluidStatusData[0]} /> + </Provider> + ) + wrapper.find(Button).first().simulate('click') + expect(mockHistoryPush).toHaveBeenCalled() + }) + it('should launch account and trigger creation process', async () => { + const store = mockStore({ + ecolyo: { + global: { + ...globalStateData, + sgeConnect: { shouldLaunchAccount: true }, + }, + }, + }) + + const wrapper = mount( + <Provider store={store}> + <SgeInit fluidStatus={fluidStatusData[0]} /> + </Provider> + ) + await waitForComponentToPaint(wrapper) + expect(mockConnect).toHaveBeenCalled() + }) + it('should launch existing account update process', async () => { + const store = mockStore({ + ecolyo: { + global: { + ...globalStateData, + sgeConnect: { shouldLaunchAccount: true }, + }, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeInit fluidStatus={SgeStatusWithAccout} /> + </Provider> + ) + await waitForComponentToPaint(wrapper) + expect(mockUpdate).toHaveBeenCalled() + }) +}) diff --git a/src/components/Connection/SGEConnect/SgeInit.tsx b/src/components/Connection/SGEConnect/SgeInit.tsx new file mode 100644 index 0000000000000000000000000000000000000000..94b1463429e2cf4a8f814929c1dbb97bc91dc9fe --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeInit.tsx @@ -0,0 +1,69 @@ +import React, { useEffect } from 'react' + +import { Account, FluidStatus } from 'models' +import { Icon, useI18n } from 'cozy-ui/transpiled/react/I18n' +import { Button } from '@material-ui/core' +import { decoreText } from 'utils/decoreText' +import ElectricityBillIcon from 'assets/icons/visu/partnerSteps/electricity_bill.svg' +import StyledIcon from 'components/CommonKit/Icon/StyledIcon' +import { useHistory } from 'react-router-dom' +import { useDispatch, useSelector } from 'react-redux' +import { AppStore } from 'store' +import useKonnectorAuth from 'components/Hooks/useKonnectorAuth' +import { updateSgeStore } from 'store/global/global.actions' +interface SgeInitProps { + fluidStatus: FluidStatus +} + +const SgeInit: React.FC<SgeInitProps> = ({ fluidStatus }: SgeInitProps) => { + const { t } = useI18n() + const history = useHistory() + const konnectorSlug: string = fluidStatus.connection.konnectorConfig.slug + const account: Account | null = fluidStatus.connection.account + const { sgeConnect } = useSelector((state: AppStore) => state.ecolyo.global) + const dispatch = useDispatch() + const [connect, update] = useKonnectorAuth(fluidStatus) + + useEffect(() => { + async function launchConnect() { + if (sgeConnect.shouldLaunchAccount) { + dispatch(updateSgeStore({ ...sgeConnect, shouldLaunchAccount: false })) + if (!account) { + await connect() + } else { + await update() + } + } + } + launchConnect() + }, [account, connect, dispatch, sgeConnect, update]) + + return ( + <div className="kloginform sge-connect"> + <p className={`kloginform-title ${konnectorSlug} text-20-bold`}> + {t(`auth.${konnectorSlug}.title`)} + </p> + <StyledIcon icon={ElectricityBillIcon} size={180} /> + <p className={`sge-subtitle ${konnectorSlug} text-16-regular`}> + {decoreText(t('auth.' + `${konnectorSlug}` + '.bill'))} + </p> + + <div className="kloginform-button"> + <Button + aria-label={t(`auth.${konnectorSlug}.accessibility.connect`)} + onClick={() => { + history.push('/sge-connect') + }} + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + > + {t(`auth.${konnectorSlug}.connect`)} + </Button> + </div> + </div> + ) +} + +export default SgeInit diff --git a/src/components/Connection/SGEConnect/SgeModalHint.spec.tsx b/src/components/Connection/SGEConnect/SgeModalHint.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..c5513c1ef3fa9516d79d96f6f6338f8c0674d2c6 --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeModalHint.spec.tsx @@ -0,0 +1,35 @@ +import React from 'react' +import { mount } from 'enzyme' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import { globalStateData } from '../../../../tests/__mocks__/globalStateData.mock' +import toJson from 'enzyme-to-json' +import SgeModalHint from './SgeModalHint' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +const mockStore = configureStore([]) + +describe('SgeModalHint component', () => { + it('should be rendered correctly', () => { + const mockClose = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <SgeModalHint open={true} handleCloseClick={mockClose} /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) +}) diff --git a/src/components/Connection/SGEConnect/SgeModalHint.tsx b/src/components/Connection/SGEConnect/SgeModalHint.tsx new file mode 100644 index 0000000000000000000000000000000000000000..f11c911e9034570c677efb52213629112d08bb7a --- /dev/null +++ b/src/components/Connection/SGEConnect/SgeModalHint.tsx @@ -0,0 +1,65 @@ +import React from 'react' +import { useI18n } from 'cozy-ui/transpiled/react/I18n' +import Button from '@material-ui/core/Button' +import Dialog from '@material-ui/core/Dialog' +import CloseIcon from 'assets/icons/ico/close.svg' +import PdlImage from 'assets/icons/visu/pdl-image.svg' +import { IconButton } from '@material-ui/core' +import Icon from 'cozy-ui/transpiled/react/Icon' + +interface SgeModalHintProps { + open: boolean + handleCloseClick: () => void +} + +const SgeModalHint: React.FC<SgeModalHintProps> = ({ + open, + handleCloseClick, +}: SgeModalHintProps) => { + const { t } = useI18n() + + return ( + <Dialog + open={open} + disableEscapeKeyDown + onClose={handleCloseClick} + aria-labelledby={'accessibility-title'} + classes={{ + root: 'modal-root', + paper: 'modal-paper', + }} + > + <div id={'accessibility-title'}> + {t('challenge_no_fluid_modal.accessibility.window_title')} + </div> + <IconButton + aria-label={t('feedback.accessibility.button_close')} + className="modal-paper-close-button" + onClick={handleCloseClick} + > + <Icon icon={CloseIcon} size={16} /> + </IconButton> + <div className="sgeHintModal"> + <div className="title text-20-bold"> + {t('auth.enedis-sge-grandlyon.modalHint.title')} + </div> + <Icon icon={PdlImage} width={240} height={385} /> + <Button + aria-label={t( + 'auth.enedis-sge-grandlyon.modalHint.button-accessibility' + )} + onClick={handleCloseClick} + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + style={{ height: '40px' }} + > + {t('auth.enedis-sge-grandlyon.modalHint.button')} + </Button> + </div> + </Dialog> + ) +} + +export default SgeModalHint diff --git a/src/components/Connection/SGEConnect/StepAddress.spec.tsx b/src/components/Connection/SGEConnect/StepAddress.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..1feceb56978266b535db4e84d1ff66368ed4e910 --- /dev/null +++ b/src/components/Connection/SGEConnect/StepAddress.spec.tsx @@ -0,0 +1,110 @@ +import React from 'react' +import { mount } from 'enzyme' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import { globalStateData } from '../../../../tests/__mocks__/globalStateData.mock' +import toJson from 'enzyme-to-json' +import SgeModalHint from './SgeModalHint' +import StepAddress from './StepAddress' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +const mockStore = configureStore([]) + +describe('StepAddress component', () => { + it('should be rendered correctly', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepAddress + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) + it('should change address value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepAddress + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#address').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('address', '') + }) + it('should change zipCode value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepAddress + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#zipCode').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('zipCode', '', 5) + }) + it('should have an existing zipCode value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepAddress + sgeState={{ ...globalStateData.sgeConnect, zipCode: 69200 }} + onChange={mockHandleChange} + /> + </Provider> + ) + expect(wrapper.find('#zipCode').first().props().value).toBe(69200) + }) + it('should change city value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepAddress + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#city').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('city', '') + }) +}) diff --git a/src/components/Connection/SGEConnect/StepAddress.tsx b/src/components/Connection/SGEConnect/StepAddress.tsx new file mode 100644 index 0000000000000000000000000000000000000000..6bc09cad76533dd33e972baf59910f4ce25d68c9 --- /dev/null +++ b/src/components/Connection/SGEConnect/StepAddress.tsx @@ -0,0 +1,62 @@ +import React from 'react' +import { useI18n } from 'cozy-ui/transpiled/react/I18n' +import { SgeStore } from 'models/sgeStore.model' + +interface StepAddressProps { + sgeState: SgeStore + onChange: (key: string, value: string, maxLength?: number) => void +} + +const StepAddress: React.FC<StepAddressProps> = ({ + sgeState, + onChange, +}: StepAddressProps) => { + const { t } = useI18n() + return ( + <div className="sge-step-container stepAddress"> + <div className="title text-22-bold"> + {t('auth.enedis-sge-grandlyon.addressTitle')} + </div> + <label htmlFor="address" className="text-16-normal"> + {t('auth.enedis-sge-grandlyon.address')} + </label> + <input + type="text" + id="address" + name="address" + value={sgeState.address} + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('address', e.target.value) + } + /> + <label htmlFor="zipCode" className="text-16-normal"> + {t('auth.enedis-sge-grandlyon.zipCode')} + </label> + <input + type="number" + min={0} + id="zipCode" + name="zipCode" + value={sgeState.zipCode !== null ? sgeState.zipCode : undefined} + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('zipCode', e.target.value, 5) + } + /> + + <label htmlFor="city" className="text-16-normal"> + {t('auth.enedis-sge-grandlyon.city')} + </label> + <input + type="text" + id="city" + name="city" + value={sgeState.city} + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('city', e.target.value) + } + /> + </div> + ) +} + +export default StepAddress diff --git a/src/components/Connection/SGEConnect/StepConsent.spec.tsx b/src/components/Connection/SGEConnect/StepConsent.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..985082b68f6aeea772e9df4dd723cb85fac38d72 --- /dev/null +++ b/src/components/Connection/SGEConnect/StepConsent.spec.tsx @@ -0,0 +1,74 @@ +import React from 'react' +import { mount } from 'enzyme' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import { globalStateData } from '../../../../tests/__mocks__/globalStateData.mock' +import toJson from 'enzyme-to-json' +import StepConsent from './StepConsent' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +const mockStore = configureStore([]) + +describe('StepConsent component', () => { + it('should be rendered correctly', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepConsent + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) + it('should change pdlConfirm value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepConsent + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#pdlConfirm').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('pdlConfirm', false) + }) + it('should change dataConsent value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepConsent + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#dataConsent').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('dataConsent', false) + }) +}) diff --git a/src/components/Connection/SGEConnect/StepConsent.tsx b/src/components/Connection/SGEConnect/StepConsent.tsx new file mode 100644 index 0000000000000000000000000000000000000000..4386d90ff99aa1c6f9327800eb612a273ff51345 --- /dev/null +++ b/src/components/Connection/SGEConnect/StepConsent.tsx @@ -0,0 +1,68 @@ +import React from 'react' +import { useI18n } from 'cozy-ui/transpiled/react/I18n' +import { decoreText } from 'utils/decoreText' +import classNames from 'classnames' +import { SgeStore } from 'models/sgeStore.model' + +interface StepConsentProps { + sgeState: SgeStore + onChange: (key: string, value: boolean, maxLength?: number) => void +} +const StepConsent: React.FC<StepConsentProps> = ({ + sgeState, + onChange, +}: StepConsentProps) => { + const { t } = useI18n() + + return ( + <div className="sge-step-container stepConsent"> + <div className="head text-16-normal"> + {t('auth.enedis-sge-grandlyon.headConsent')} + </div> + <div className="title text-22-bold"> + {t('auth.enedis-sge-grandlyon.textConsent')} + </div> + <ul className="text-16-normal"> + <li>{t('auth.enedis-sge-grandlyon.consentLi1')}</li> + <li>{t('auth.enedis-sge-grandlyon.consentLi2')}</li> + <li>{t('auth.enedis-sge-grandlyon.consentLi3')}</li> + <li>{t('auth.enedis-sge-grandlyon.consentLi4')}</li> + </ul> + <hr /> + <label + className={classNames('checkbox', { + ['answer-checked']: sgeState.dataConsent, + })} + > + <input + id="dataConsent" + type="checkbox" + name="Data-consent-validation" + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('dataConsent', e.target.checked) + } + checked={sgeState.dataConsent} + /> + <span>{decoreText(t('auth.enedis-sge-grandlyon.consentCheck1'))}</span> + </label> + <label + className={classNames('checkbox', { + ['answer-checked']: sgeState.pdlConfirm, + })} + > + <input + id="pdlConfirm" + type="checkbox" + name="Data-consent-validation" + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('pdlConfirm', e.target.checked) + } + checked={sgeState.pdlConfirm} + /> + {decoreText(t('auth.enedis-sge-grandlyon.consentCheck2'))} + </label> + </div> + ) +} + +export default StepConsent diff --git a/src/components/Connection/SGEConnect/StepIdentityAndPdl.spec.tsx b/src/components/Connection/SGEConnect/StepIdentityAndPdl.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..4a6ffacf3c40c7e37edefbd4a17850a317ad8ee4 --- /dev/null +++ b/src/components/Connection/SGEConnect/StepIdentityAndPdl.spec.tsx @@ -0,0 +1,127 @@ +import React from 'react' +import { mount } from 'enzyme' +import configureStore from 'redux-mock-store' +import { Provider } from 'react-redux' +import { globalStateData } from '../../../../tests/__mocks__/globalStateData.mock' +import toJson from 'enzyme-to-json' +import StepIdentityAndPdl from './StepIdentityAndPdl' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +const mockStore = configureStore([]) + +describe('StepIdentityAndPdl component', () => { + it('should be rendered correctly', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepIdentityAndPdl + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) + it('should change firstName value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepIdentityAndPdl + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#firstName').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('firstName', '') + }) + it('should change lastName value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepIdentityAndPdl + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#lastName').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('lastName', '') + }) + it('should change pdl value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepIdentityAndPdl + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('#pdl').first().simulate('change') + expect(mockHandleChange).toHaveBeenCalledWith('pdl', '', 14) + }) + it('should open hint modal', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepIdentityAndPdl + sgeState={globalStateData.sgeConnect} + onChange={mockHandleChange} + /> + </Provider> + ) + wrapper.find('.pdl-hint').first().simulate('click') + expect(wrapper.find('.sgeHintModal')).toBeTruthy() + }) + it('should have an existing pdl value', () => { + const mockHandleChange = jest.fn() + const store = mockStore({ + ecolyo: { + global: globalStateData, + }, + }) + const wrapper = mount( + <Provider store={store}> + <StepIdentityAndPdl + sgeState={{ ...globalStateData.sgeConnect, pdl: 11111111111111 }} + onChange={mockHandleChange} + /> + </Provider> + ) + expect(wrapper.find('#pdl').first().props().value).toBe(11111111111111) + }) +}) diff --git a/src/components/Connection/SGEConnect/StepIdentityAndPdl.tsx b/src/components/Connection/SGEConnect/StepIdentityAndPdl.tsx new file mode 100644 index 0000000000000000000000000000000000000000..2eb3f7d8033f71c9ec49be90fc4d86e0e53154c1 --- /dev/null +++ b/src/components/Connection/SGEConnect/StepIdentityAndPdl.tsx @@ -0,0 +1,78 @@ +import React, { useCallback, useState } from 'react' +import { useI18n } from 'cozy-ui/transpiled/react/I18n' +import { SgeStore } from 'models/sgeStore.model' +import SgeModalHint from 'components/Connection/SGEConnect/SgeModalHint' + +interface StepIdentityAndPdlProps { + sgeState: SgeStore + onChange: (key: string, value: string | number, maxLength?: number) => void +} + +const StepIdentityAndPdl: React.FC<StepIdentityAndPdlProps> = ({ + sgeState, + onChange, +}: StepIdentityAndPdlProps) => { + const { t } = useI18n() + const [openHintModal, setopenHintModal] = useState<boolean>(false) + const toggleModal = useCallback(() => { + setopenHintModal(prev => !prev) + }, []) + + return ( + <div className="sge-step-container stepIdentity"> + <div className="title text-22-bold"> + {t('auth.enedis-sge-grandlyon.identityTitle')} + </div> + <label htmlFor="firstName" className="text-16-normal"> + {t('auth.enedis-sge-grandlyon.firstName')} + </label> + <input + type="text" + id="firstName" + name="firstName" + value={sgeState.firstName} + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('firstName', e.target.value) + } + required + /> + <label htmlFor="lastName" className="text-16-normal"> + {t('auth.enedis-sge-grandlyon.lastName')} + </label> + <input + type="text" + id="lastName" + name="lastName" + value={sgeState.lastName} + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('lastName', e.target.value) + } + required + /> + <div className="title text-22-bold"> + {t('auth.enedis-sge-grandlyon.pdlTitle')} + </div> + <label htmlFor="pdl" className="text-16-normal"> + {t('auth.enedis-sge-grandlyon.pdlLabel')} + </label> + <input + id="pdl" + name="pdl" + type="number" + min={0} + value={sgeState.pdl ? sgeState.pdl : undefined} + onChange={(e: React.ChangeEvent<HTMLInputElement>) => + onChange('pdl', e.target.value, 14) + } + inputMode="numeric" + required + /> + <div onClick={toggleModal} className="pdl-hint text-16-normal"> + {t('auth.enedis-sge-grandlyon.pdlHint')} + </div> + <SgeModalHint open={openHintModal} handleCloseClick={toggleModal} /> + </div> + ) +} + +export default StepIdentityAndPdl diff --git a/src/components/Connection/SGEConnect/__snapshots__/SgeConnectView.spec.tsx.snap b/src/components/Connection/SGEConnect/__snapshots__/SgeConnectView.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..0df9ef955f56ff83e3b72f8edac8304b4cc095c1 --- /dev/null +++ b/src/components/Connection/SGEConnect/__snapshots__/SgeConnectView.spec.tsx.snap @@ -0,0 +1,1318 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SgeConnectView component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <SgeConnectView> + <CozyBar + displayBackArrow={true} + titleKey="common.title_sge_connect" + > + <BarLeft> + <StyledIconButton + aria-label="header.accessibility.button_back" + className="cv-button" + icon="test-file-stub" + onClick={[Function]} + > + <WithStyles(WithStyles(ForwardRef(IconButton))) + aria-label="header.accessibility.button_back" + className="cv-button" + onClick={[Function]} + > + <WithStyles(ForwardRef(IconButton)) + aria-label="header.accessibility.button_back" + className="cv-button" + classes={ + Object { + "root": "WithStyles(ForwardRef(IconButton))-root-1", + } + } + onClick={[Function]} + > + <ForwardRef(IconButton) + aria-label="header.accessibility.button_back" + className="cv-button" + classes={ + Object { + "colorInherit": "MuiIconButton-colorInherit", + "colorPrimary": "MuiIconButton-colorPrimary", + "colorSecondary": "MuiIconButton-colorSecondary", + "disabled": "Mui-disabled", + "edgeEnd": "MuiIconButton-edgeEnd", + "edgeStart": "MuiIconButton-edgeStart", + "label": "MuiIconButton-label", + "root": "MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1", + "sizeSmall": "MuiIconButton-sizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="header.accessibility.button_back" + centerRipple={true} + className="MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1 cv-button" + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <ForwardRef(ButtonBase) + aria-label="header.accessibility.button_back" + centerRipple={true} + className="MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1 cv-button" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <button + aria-label="header.accessibility.button_back" + className="MuiButtonBase-root MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1 cv-button" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiIconButton-label" + > + <StyledIcon + icon="test-file-stub" + size={16} + > + <Icon + aria-hidden={true} + icon="test-file-stub" + size={16} + spin={false} + > + <Component + aria-hidden={true} + className="styles__icon___23x3R" + height={16} + style={Object {}} + width={16} + > + <svg + aria-hidden={true} + className="styles__icon___23x3R" + height={16} + style={Object {}} + width={16} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </StyledIcon> + </span> + <WithStyles(memo) + center={true} + > + <ForwardRef(TouchRipple) + center={true} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(IconButton)> + </WithStyles(ForwardRef(IconButton))> + </WithStyles(WithStyles(ForwardRef(IconButton)))> + </StyledIconButton> + </BarLeft> + <BarCenter> + <div + className="cozy-bar" + > + <span + className="app-title" + > + common.title_sge_connect + </span> + </div> + </BarCenter> + <BarRight> + <StyledIconButton + aria-label="header.accessibility.button_open_feedbacks" + className="cv-button" + icon="test-file-stub" + onClick={[Function]} + size={40} + > + <WithStyles(WithStyles(ForwardRef(IconButton))) + aria-label="header.accessibility.button_open_feedbacks" + className="cv-button" + onClick={[Function]} + > + <WithStyles(ForwardRef(IconButton)) + aria-label="header.accessibility.button_open_feedbacks" + className="cv-button" + classes={ + Object { + "root": "WithStyles(ForwardRef(IconButton))-root-1", + } + } + onClick={[Function]} + > + <ForwardRef(IconButton) + aria-label="header.accessibility.button_open_feedbacks" + className="cv-button" + classes={ + Object { + "colorInherit": "MuiIconButton-colorInherit", + "colorPrimary": "MuiIconButton-colorPrimary", + "colorSecondary": "MuiIconButton-colorSecondary", + "disabled": "Mui-disabled", + "edgeEnd": "MuiIconButton-edgeEnd", + "edgeStart": "MuiIconButton-edgeStart", + "label": "MuiIconButton-label", + "root": "MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1", + "sizeSmall": "MuiIconButton-sizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="header.accessibility.button_open_feedbacks" + centerRipple={true} + className="MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1 cv-button" + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <ForwardRef(ButtonBase) + aria-label="header.accessibility.button_open_feedbacks" + centerRipple={true} + className="MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1 cv-button" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <button + aria-label="header.accessibility.button_open_feedbacks" + className="MuiButtonBase-root MuiIconButton-root WithStyles(ForwardRef(IconButton))-root-1 cv-button" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiIconButton-label" + > + <StyledIcon + icon="test-file-stub" + size={40} + > + <Icon + aria-hidden={true} + icon="test-file-stub" + size={40} + spin={false} + > + <Component + aria-hidden={true} + className="styles__icon___23x3R" + height={40} + style={Object {}} + width={40} + > + <svg + aria-hidden={true} + className="styles__icon___23x3R" + height={40} + style={Object {}} + width={40} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </StyledIcon> + </span> + <WithStyles(memo) + center={true} + > + <ForwardRef(TouchRipple) + center={true} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(IconButton)> + </WithStyles(ForwardRef(IconButton))> + </WithStyles(WithStyles(ForwardRef(IconButton)))> + </StyledIconButton> + </BarRight> + </CozyBar> + <Header + desktopTitleKey="common.title_sge_connect" + displayBackArrow={true} + setHeaderHeight={[Function]} + > + <div + className="header" + > + <div + className="header-top" + > + <div + className="header-content" + > + <div + className="header-content-top" + > + <div + className="header-text-desktop text-14-normal-uppercase" + > + <WithStyles(ForwardRef(IconButton)) + aria-label="header.accessibility.button_back" + className="header-back-button" + onClick={[Function]} + > + <ForwardRef(IconButton) + aria-label="header.accessibility.button_back" + className="header-back-button" + classes={ + Object { + "colorInherit": "MuiIconButton-colorInherit", + "colorPrimary": "MuiIconButton-colorPrimary", + "colorSecondary": "MuiIconButton-colorSecondary", + "disabled": "Mui-disabled", + "edgeEnd": "MuiIconButton-edgeEnd", + "edgeStart": "MuiIconButton-edgeStart", + "label": "MuiIconButton-label", + "root": "MuiIconButton-root", + "sizeSmall": "MuiIconButton-sizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="header.accessibility.button_back" + centerRipple={true} + className="MuiIconButton-root header-back-button" + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <ForwardRef(ButtonBase) + aria-label="header.accessibility.button_back" + centerRipple={true} + className="MuiIconButton-root header-back-button" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <button + aria-label="header.accessibility.button_back" + className="MuiButtonBase-root MuiIconButton-root header-back-button" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiIconButton-label" + > + <Icon + icon="test-file-stub" + size={16} + spin={false} + > + <Component + className="styles__icon___23x3R" + height={16} + style={Object {}} + width={16} + > + <svg + className="styles__icon___23x3R" + height={16} + style={Object {}} + width={16} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </span> + <WithStyles(memo) + center={true} + > + <ForwardRef(TouchRipple) + center={true} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(IconButton)> + </WithStyles(ForwardRef(IconButton))> + <span> + common.title_sge_connect + </span> + </div> + <WithStyles(ForwardRef(IconButton)) + aria-label="header.accessibility.button_open_feedbacks" + className="header-feedbacks-button" + onClick={[Function]} + > + <ForwardRef(IconButton) + aria-label="header.accessibility.button_open_feedbacks" + className="header-feedbacks-button" + classes={ + Object { + "colorInherit": "MuiIconButton-colorInherit", + "colorPrimary": "MuiIconButton-colorPrimary", + "colorSecondary": "MuiIconButton-colorSecondary", + "disabled": "Mui-disabled", + "edgeEnd": "MuiIconButton-edgeEnd", + "edgeStart": "MuiIconButton-edgeStart", + "label": "MuiIconButton-label", + "root": "MuiIconButton-root", + "sizeSmall": "MuiIconButton-sizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="header.accessibility.button_open_feedbacks" + centerRipple={true} + className="MuiIconButton-root header-feedbacks-button" + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <ForwardRef(ButtonBase) + aria-label="header.accessibility.button_open_feedbacks" + centerRipple={true} + className="MuiIconButton-root header-feedbacks-button" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + disabled={false} + focusRipple={true} + onClick={[Function]} + > + <button + aria-label="header.accessibility.button_open_feedbacks" + className="MuiButtonBase-root MuiIconButton-root header-feedbacks-button" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiIconButton-label" + > + <Icon + icon="test-file-stub" + size={40} + spin={false} + > + <Component + className="styles__icon___23x3R" + height={40} + style={Object {}} + width={40} + > + <svg + className="styles__icon___23x3R" + height={40} + style={Object {}} + width={40} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </span> + <WithStyles(memo) + center={true} + > + <ForwardRef(TouchRipple) + center={true} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(IconButton)> + </WithStyles(ForwardRef(IconButton))> + </div> + </div> + </div> + <div + className="header-bar" + /> + </div> + </Header> + <mock-content + height={-48} + > + <div + className="sge-view" + > + <mock-formprogress + formType="sge" + step={0} + /> + <StepIdentityAndPdl + onChange={[Function]} + sgeState={ + Object { + "address": "", + "city": "", + "currentStep": 0, + "dataConsent": false, + "firstName": "", + "lastName": "", + "pdl": null, + "pdlConfirm": false, + "shouldLaunchAccount": false, + "zipCode": null, + } + } + > + <div + className="sge-step-container stepIdentity" + > + <div + className="title text-22-bold" + > + auth.enedis-sge-grandlyon.identityTitle + </div> + <label + className="text-16-normal" + htmlFor="firstName" + > + auth.enedis-sge-grandlyon.firstName + </label> + <input + id="firstName" + name="firstName" + onChange={[Function]} + required={true} + type="text" + value="" + /> + <label + className="text-16-normal" + htmlFor="lastName" + > + auth.enedis-sge-grandlyon.lastName + </label> + <input + id="lastName" + name="lastName" + onChange={[Function]} + required={true} + type="text" + value="" + /> + <div + className="title text-22-bold" + > + auth.enedis-sge-grandlyon.pdlTitle + </div> + <label + className="text-16-normal" + htmlFor="pdl" + > + auth.enedis-sge-grandlyon.pdlLabel + </label> + <input + id="pdl" + inputMode="numeric" + min={0} + name="pdl" + onChange={[Function]} + required={true} + type="number" + /> + <div + className="pdl-hint text-16-normal" + onClick={[Function]} + > + auth.enedis-sge-grandlyon.pdlHint + </div> + <SgeModalHint + handleCloseClick={[Function]} + open={false} + > + <WithStyles(ForwardRef(Dialog)) + aria-labelledby="accessibility-title" + classes={ + Object { + "paper": "modal-paper", + "root": "modal-root", + } + } + disableEscapeKeyDown={true} + onClose={[Function]} + open={false} + > + <ForwardRef(Dialog) + aria-labelledby="accessibility-title" + classes={ + Object { + "container": "MuiDialog-container", + "paper": "MuiDialog-paper modal-paper", + "paperFullScreen": "MuiDialog-paperFullScreen", + "paperFullWidth": "MuiDialog-paperFullWidth", + "paperScrollBody": "MuiDialog-paperScrollBody", + "paperScrollPaper": "MuiDialog-paperScrollPaper", + "paperWidthFalse": "MuiDialog-paperWidthFalse", + "paperWidthLg": "MuiDialog-paperWidthLg", + "paperWidthMd": "MuiDialog-paperWidthMd", + "paperWidthSm": "MuiDialog-paperWidthSm", + "paperWidthXl": "MuiDialog-paperWidthXl", + "paperWidthXs": "MuiDialog-paperWidthXs", + "root": "MuiDialog-root modal-root", + "scrollBody": "MuiDialog-scrollBody", + "scrollPaper": "MuiDialog-scrollPaper", + } + } + disableEscapeKeyDown={true} + onClose={[Function]} + open={false} + > + <ForwardRef(Modal) + BackdropComponent={ + Object { + "$$typeof": Symbol(react.forward_ref), + "Naked": Object { + "$$typeof": Symbol(react.forward_ref), + "propTypes": Object { + "children": [Function], + "className": [Function], + "classes": [Function], + "invisible": [Function], + "open": [Function], + "transitionDuration": [Function], + }, + "render": [Function], + }, + "displayName": "WithStyles(ForwardRef(Backdrop))", + "options": Object { + "defaultTheme": Object { + "breakpoints": Object { + "between": [Function], + "down": [Function], + "keys": Array [ + "xs", + "sm", + "md", + "lg", + "xl", + ], + "only": [Function], + "up": [Function], + "values": Object { + "lg": 1280, + "md": 960, + "sm": 600, + "xl": 1920, + "xs": 0, + }, + "width": [Function], + }, + "direction": "ltr", + "mixins": Object { + "gutters": [Function], + "toolbar": Object { + "@media (min-width:0px) and (orientation: landscape)": Object { + "minHeight": 48, + }, + "@media (min-width:600px)": Object { + "minHeight": 64, + }, + "minHeight": 56, + }, + }, + "overrides": Object {}, + "palette": Object { + "action": Object { + "activatedOpacity": 0.12, + "active": "rgba(0, 0, 0, 0.54)", + "disabled": "rgba(0, 0, 0, 0.26)", + "disabledBackground": "rgba(0, 0, 0, 0.12)", + "disabledOpacity": 0.38, + "focus": "rgba(0, 0, 0, 0.12)", + "focusOpacity": 0.12, + "hover": "rgba(0, 0, 0, 0.04)", + "hoverOpacity": 0.04, + "selected": "rgba(0, 0, 0, 0.08)", + "selectedOpacity": 0.08, + }, + "augmentColor": [Function], + "background": Object { + "default": "#fafafa", + "paper": "#fff", + }, + "common": Object { + "black": "#000", + "white": "#fff", + }, + "contrastThreshold": 3, + "divider": "rgba(0, 0, 0, 0.12)", + "error": Object { + "contrastText": "#fff", + "dark": "#d32f2f", + "light": "#e57373", + "main": "#f44336", + }, + "getContrastText": [Function], + "grey": Object { + "100": "#f5f5f5", + "200": "#eeeeee", + "300": "#e0e0e0", + "400": "#bdbdbd", + "50": "#fafafa", + "500": "#9e9e9e", + "600": "#757575", + "700": "#616161", + "800": "#424242", + "900": "#212121", + "A100": "#d5d5d5", + "A200": "#aaaaaa", + "A400": "#303030", + "A700": "#616161", + }, + "info": Object { + "contrastText": "#fff", + "dark": "#1976d2", + "light": "#64b5f6", + "main": "#2196f3", + }, + "primary": Object { + "contrastText": "#fff", + "dark": "#303f9f", + "light": "#7986cb", + "main": "#3f51b5", + }, + "secondary": Object { + "contrastText": "#fff", + "dark": "#c51162", + "light": "#ff4081", + "main": "#f50057", + }, + "success": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#388e3c", + "light": "#81c784", + "main": "#4caf50", + }, + "text": Object { + "disabled": "rgba(0, 0, 0, 0.38)", + "hint": "rgba(0, 0, 0, 0.38)", + "primary": "rgba(0, 0, 0, 0.87)", + "secondary": "rgba(0, 0, 0, 0.54)", + }, + "tonalOffset": 0.2, + "type": "light", + "warning": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#f57c00", + "light": "#ffb74d", + "main": "#ff9800", + }, + }, + "props": Object {}, + "shadows": Array [ + "none", + "0px 2px 1px -1px rgba(0,0,0,0.2),0px 1px 1px 0px rgba(0,0,0,0.14),0px 1px 3px 0px rgba(0,0,0,0.12)", + "0px 3px 1px -2px rgba(0,0,0,0.2),0px 2px 2px 0px rgba(0,0,0,0.14),0px 1px 5px 0px rgba(0,0,0,0.12)", + "0px 3px 3px -2px rgba(0,0,0,0.2),0px 3px 4px 0px rgba(0,0,0,0.14),0px 1px 8px 0px rgba(0,0,0,0.12)", + "0px 2px 4px -1px rgba(0,0,0,0.2),0px 4px 5px 0px rgba(0,0,0,0.14),0px 1px 10px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 5px 8px 0px rgba(0,0,0,0.14),0px 1px 14px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 6px 10px 0px rgba(0,0,0,0.14),0px 1px 18px 0px rgba(0,0,0,0.12)", + "0px 4px 5px -2px rgba(0,0,0,0.2),0px 7px 10px 1px rgba(0,0,0,0.14),0px 2px 16px 1px rgba(0,0,0,0.12)", + "0px 5px 5px -3px rgba(0,0,0,0.2),0px 8px 10px 1px rgba(0,0,0,0.14),0px 3px 14px 2px rgba(0,0,0,0.12)", + "0px 5px 6px -3px rgba(0,0,0,0.2),0px 9px 12px 1px rgba(0,0,0,0.14),0px 3px 16px 2px rgba(0,0,0,0.12)", + "0px 6px 6px -3px rgba(0,0,0,0.2),0px 10px 14px 1px rgba(0,0,0,0.14),0px 4px 18px 3px rgba(0,0,0,0.12)", + "0px 6px 7px -4px rgba(0,0,0,0.2),0px 11px 15px 1px rgba(0,0,0,0.14),0px 4px 20px 3px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 12px 17px 2px rgba(0,0,0,0.14),0px 5px 22px 4px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 13px 19px 2px rgba(0,0,0,0.14),0px 5px 24px 4px rgba(0,0,0,0.12)", + "0px 7px 9px -4px rgba(0,0,0,0.2),0px 14px 21px 2px rgba(0,0,0,0.14),0px 5px 26px 4px rgba(0,0,0,0.12)", + "0px 8px 9px -5px rgba(0,0,0,0.2),0px 15px 22px 2px rgba(0,0,0,0.14),0px 6px 28px 5px rgba(0,0,0,0.12)", + "0px 8px 10px -5px rgba(0,0,0,0.2),0px 16px 24px 2px rgba(0,0,0,0.14),0px 6px 30px 5px rgba(0,0,0,0.12)", + "0px 8px 11px -5px rgba(0,0,0,0.2),0px 17px 26px 2px rgba(0,0,0,0.14),0px 6px 32px 5px rgba(0,0,0,0.12)", + "0px 9px 11px -5px rgba(0,0,0,0.2),0px 18px 28px 2px rgba(0,0,0,0.14),0px 7px 34px 6px rgba(0,0,0,0.12)", + "0px 9px 12px -6px rgba(0,0,0,0.2),0px 19px 29px 2px rgba(0,0,0,0.14),0px 7px 36px 6px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 20px 31px 3px rgba(0,0,0,0.14),0px 8px 38px 7px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 21px 33px 3px rgba(0,0,0,0.14),0px 8px 40px 7px rgba(0,0,0,0.12)", + "0px 10px 14px -6px rgba(0,0,0,0.2),0px 22px 35px 3px rgba(0,0,0,0.14),0px 8px 42px 7px rgba(0,0,0,0.12)", + "0px 11px 14px -7px rgba(0,0,0,0.2),0px 23px 36px 3px rgba(0,0,0,0.14),0px 9px 44px 8px rgba(0,0,0,0.12)", + "0px 11px 15px -7px rgba(0,0,0,0.2),0px 24px 38px 3px rgba(0,0,0,0.14),0px 9px 46px 8px rgba(0,0,0,0.12)", + ], + "shape": Object { + "borderRadius": 4, + }, + "spacing": [Function], + "transitions": Object { + "create": [Function], + "duration": Object { + "complex": 375, + "enteringScreen": 225, + "leavingScreen": 195, + "short": 250, + "shorter": 200, + "shortest": 150, + "standard": 300, + }, + "easing": Object { + "easeIn": "cubic-bezier(0.4, 0, 1, 1)", + "easeInOut": "cubic-bezier(0.4, 0, 0.2, 1)", + "easeOut": "cubic-bezier(0.0, 0, 0.2, 1)", + "sharp": "cubic-bezier(0.4, 0, 0.6, 1)", + }, + "getAutoHeightDuration": [Function], + }, + "typography": Object { + "body1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.5, + }, + "body2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 400, + "letterSpacing": "0.01071em", + "lineHeight": 1.43, + }, + "button": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.02857em", + "lineHeight": 1.75, + "textTransform": "uppercase", + }, + "caption": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.03333em", + "lineHeight": 1.66, + }, + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": 14, + "fontWeightBold": 700, + "fontWeightLight": 300, + "fontWeightMedium": 500, + "fontWeightRegular": 400, + "h1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "6rem", + "fontWeight": 300, + "letterSpacing": "-0.01562em", + "lineHeight": 1.167, + }, + "h2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3.75rem", + "fontWeight": 300, + "letterSpacing": "-0.00833em", + "lineHeight": 1.2, + }, + "h3": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.167, + }, + "h4": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "2.125rem", + "fontWeight": 400, + "letterSpacing": "0.00735em", + "lineHeight": 1.235, + }, + "h5": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.5rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.334, + }, + "h6": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.25rem", + "fontWeight": 500, + "letterSpacing": "0.0075em", + "lineHeight": 1.6, + }, + "htmlFontSize": 16, + "overline": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.08333em", + "lineHeight": 2.66, + "textTransform": "uppercase", + }, + "pxToRem": [Function], + "round": [Function], + "subtitle1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.75, + }, + "subtitle2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.00714em", + "lineHeight": 1.57, + }, + }, + "zIndex": Object { + "appBar": 1100, + "drawer": 1200, + "mobileStepper": 1000, + "modal": 1300, + "snackbar": 1400, + "speedDial": 1050, + "tooltip": 1500, + }, + }, + "name": "MuiBackdrop", + }, + "propTypes": Object { + "classes": [Function], + "innerRef": [Function], + }, + "render": [Function], + "useStyles": [Function], + } + } + BackdropProps={ + Object { + "transitionDuration": Object { + "enter": 225, + "exit": 195, + }, + } + } + className="MuiDialog-root modal-root" + closeAfterTransition={true} + disableEscapeKeyDown={true} + onClose={[Function]} + open={false} + /> + </ForwardRef(Dialog)> + </WithStyles(ForwardRef(Dialog))> + </SgeModalHint> + </div> + </StepIdentityAndPdl> + <FormNavigation + disableNextButton={true} + handleNext={[Function]} + handlePrevious={[Function]} + isEcogesture={false} + isLastConnectStep={false} + step={0} + > + <div + className="profile-navigation" + > + <WithStyles(ForwardRef(Button)) + aria-label="profile_type.accessibility.button_previous" + className="profile-navigation-button" + classes={ + Object { + "label": "text-16-normal", + "root": "btn-profile-back", + } + } + disabled={true} + onClick={[Function]} + > + <ForwardRef(Button) + aria-label="profile_type.accessibility.button_previous" + className="profile-navigation-button" + classes={ + Object { + "colorInherit": "MuiButton-colorInherit", + "contained": "MuiButton-contained", + "containedPrimary": "MuiButton-containedPrimary", + "containedSecondary": "MuiButton-containedSecondary", + "containedSizeLarge": "MuiButton-containedSizeLarge", + "containedSizeSmall": "MuiButton-containedSizeSmall", + "disableElevation": "MuiButton-disableElevation", + "disabled": "Mui-disabled", + "endIcon": "MuiButton-endIcon", + "focusVisible": "Mui-focusVisible", + "fullWidth": "MuiButton-fullWidth", + "iconSizeLarge": "MuiButton-iconSizeLarge", + "iconSizeMedium": "MuiButton-iconSizeMedium", + "iconSizeSmall": "MuiButton-iconSizeSmall", + "label": "MuiButton-label text-16-normal", + "outlined": "MuiButton-outlined", + "outlinedPrimary": "MuiButton-outlinedPrimary", + "outlinedSecondary": "MuiButton-outlinedSecondary", + "outlinedSizeLarge": "MuiButton-outlinedSizeLarge", + "outlinedSizeSmall": "MuiButton-outlinedSizeSmall", + "root": "MuiButton-root btn-profile-back", + "sizeLarge": "MuiButton-sizeLarge", + "sizeSmall": "MuiButton-sizeSmall", + "startIcon": "MuiButton-startIcon", + "text": "MuiButton-text", + "textPrimary": "MuiButton-textPrimary", + "textSecondary": "MuiButton-textSecondary", + "textSizeLarge": "MuiButton-textSizeLarge", + "textSizeSmall": "MuiButton-textSizeSmall", + } + } + disabled={true} + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="profile_type.accessibility.button_previous" + className="MuiButton-root btn-profile-back MuiButton-text profile-navigation-button Mui-disabled" + component="button" + disabled={true} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <ForwardRef(ButtonBase) + aria-label="profile_type.accessibility.button_previous" + className="MuiButton-root btn-profile-back MuiButton-text profile-navigation-button Mui-disabled" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + component="button" + disabled={true} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <button + aria-label="profile_type.accessibility.button_previous" + className="MuiButtonBase-root MuiButton-root btn-profile-back MuiButton-text profile-navigation-button Mui-disabled Mui-disabled" + disabled={true} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={-1} + type="button" + > + <span + className="MuiButton-label text-16-normal" + > + < profile_type.form.button_previous + </span> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(Button)> + </WithStyles(ForwardRef(Button))> + <WithStyles(ForwardRef(Button)) + aria-label="profile_type.accessibility.button_next" + className="profile-navigation-button disabled" + classes={ + Object { + "label": "text-16-normal", + "root": "btn-profile-next rounded", + } + } + disabled={true} + onClick={[Function]} + > + <ForwardRef(Button) + aria-label="profile_type.accessibility.button_next" + className="profile-navigation-button disabled" + classes={ + Object { + "colorInherit": "MuiButton-colorInherit", + "contained": "MuiButton-contained", + "containedPrimary": "MuiButton-containedPrimary", + "containedSecondary": "MuiButton-containedSecondary", + "containedSizeLarge": "MuiButton-containedSizeLarge", + "containedSizeSmall": "MuiButton-containedSizeSmall", + "disableElevation": "MuiButton-disableElevation", + "disabled": "Mui-disabled", + "endIcon": "MuiButton-endIcon", + "focusVisible": "Mui-focusVisible", + "fullWidth": "MuiButton-fullWidth", + "iconSizeLarge": "MuiButton-iconSizeLarge", + "iconSizeMedium": "MuiButton-iconSizeMedium", + "iconSizeSmall": "MuiButton-iconSizeSmall", + "label": "MuiButton-label text-16-normal", + "outlined": "MuiButton-outlined", + "outlinedPrimary": "MuiButton-outlinedPrimary", + "outlinedSecondary": "MuiButton-outlinedSecondary", + "outlinedSizeLarge": "MuiButton-outlinedSizeLarge", + "outlinedSizeSmall": "MuiButton-outlinedSizeSmall", + "root": "MuiButton-root btn-profile-next rounded", + "sizeLarge": "MuiButton-sizeLarge", + "sizeSmall": "MuiButton-sizeSmall", + "startIcon": "MuiButton-startIcon", + "text": "MuiButton-text", + "textPrimary": "MuiButton-textPrimary", + "textSecondary": "MuiButton-textSecondary", + "textSizeLarge": "MuiButton-textSizeLarge", + "textSizeSmall": "MuiButton-textSizeSmall", + } + } + disabled={true} + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="profile_type.accessibility.button_next" + className="MuiButton-root btn-profile-next rounded MuiButton-text profile-navigation-button disabled Mui-disabled" + component="button" + disabled={true} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <ForwardRef(ButtonBase) + aria-label="profile_type.accessibility.button_next" + className="MuiButton-root btn-profile-next rounded MuiButton-text profile-navigation-button disabled Mui-disabled" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + component="button" + disabled={true} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <button + aria-label="profile_type.accessibility.button_next" + className="MuiButtonBase-root MuiButton-root btn-profile-next rounded MuiButton-text profile-navigation-button disabled Mui-disabled Mui-disabled" + disabled={true} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={-1} + type="button" + > + <span + className="MuiButton-label text-16-normal" + > + profile_type.form.button_next > + </span> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(Button)> + </WithStyles(ForwardRef(Button))> + </div> + </FormNavigation> + </div> + </mock-content> + </SgeConnectView> +</Provider> +`; diff --git a/src/components/Connection/SGEConnect/__snapshots__/SgeInit.spec.tsx.snap b/src/components/Connection/SGEConnect/__snapshots__/SgeInit.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..0d99d65786b86084707cb9581e5e5c31393a774d --- /dev/null +++ b/src/components/Connection/SGEConnect/__snapshots__/SgeInit.spec.tsx.snap @@ -0,0 +1,223 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SgeInit component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <SgeInit + fluidStatus={ + Object { + "connection": Object { + "account": null, + "isUpdating": false, + "konnector": null, + "konnectorConfig": Object { + "activation": "", + "name": "", + "oauth": false, + "siteLink": "", + "slug": "enedis-sge-grandlyon", + }, + "shouldLaunchKonnector": false, + "trigger": null, + "triggerState": null, + }, + "firstDataDate": "2019-09-01T00:00:00.000Z", + "fluidType": 0, + "lastDataDate": "2020-09-01T00:00:00.000Z", + "status": 0, + } + } + > + <div + className="kloginform sge-connect" + > + <p + className="kloginform-title enedis-sge-grandlyon text-20-bold" + > + auth.enedis-sge-grandlyon.title + </p> + <StyledIcon + icon="test-file-stub" + size={180} + > + <Icon + aria-hidden={true} + icon="test-file-stub" + size={180} + spin={false} + > + <Component + aria-hidden={true} + className="styles__icon___23x3R" + height={180} + style={Object {}} + width={180} + > + <svg + aria-hidden={true} + className="styles__icon___23x3R" + height={180} + style={Object {}} + width={180} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </StyledIcon> + <p + className="sge-subtitle enedis-sge-grandlyon text-16-regular" + > + auth.enedis-sge-grandlyon.bill + </p> + <div + className="kloginform-button" + > + <WithStyles(ForwardRef(Button)) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + classes={ + Object { + "label": "text-16-bold", + "root": "btn-highlight", + } + } + onClick={[Function]} + > + <ForwardRef(Button) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + classes={ + Object { + "colorInherit": "MuiButton-colorInherit", + "contained": "MuiButton-contained", + "containedPrimary": "MuiButton-containedPrimary", + "containedSecondary": "MuiButton-containedSecondary", + "containedSizeLarge": "MuiButton-containedSizeLarge", + "containedSizeSmall": "MuiButton-containedSizeSmall", + "disableElevation": "MuiButton-disableElevation", + "disabled": "Mui-disabled", + "endIcon": "MuiButton-endIcon", + "focusVisible": "Mui-focusVisible", + "fullWidth": "MuiButton-fullWidth", + "iconSizeLarge": "MuiButton-iconSizeLarge", + "iconSizeMedium": "MuiButton-iconSizeMedium", + "iconSizeSmall": "MuiButton-iconSizeSmall", + "label": "MuiButton-label text-16-bold", + "outlined": "MuiButton-outlined", + "outlinedPrimary": "MuiButton-outlinedPrimary", + "outlinedSecondary": "MuiButton-outlinedSecondary", + "outlinedSizeLarge": "MuiButton-outlinedSizeLarge", + "outlinedSizeSmall": "MuiButton-outlinedSizeSmall", + "root": "MuiButton-root btn-highlight", + "sizeLarge": "MuiButton-sizeLarge", + "sizeSmall": "MuiButton-sizeSmall", + "startIcon": "MuiButton-startIcon", + "text": "MuiButton-text", + "textPrimary": "MuiButton-textPrimary", + "textSecondary": "MuiButton-textSecondary", + "textSizeLarge": "MuiButton-textSizeLarge", + "textSizeSmall": "MuiButton-textSizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + className="MuiButton-root btn-highlight MuiButton-text" + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <ForwardRef(ButtonBase) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + className="MuiButton-root btn-highlight MuiButton-text" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <button + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + className="MuiButtonBase-root MuiButton-root btn-highlight MuiButton-text" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiButton-label text-16-bold" + > + auth.enedis-sge-grandlyon.connect + </span> + <WithStyles(memo) + center={false} + > + <ForwardRef(TouchRipple) + center={false} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(Button)> + </WithStyles(ForwardRef(Button))> + </div> + </div> + </SgeInit> +</Provider> +`; diff --git a/src/components/Connection/SGEConnect/__snapshots__/SgeModalHint.spec.tsx.snap b/src/components/Connection/SGEConnect/__snapshots__/SgeModalHint.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..322986326ee5c10286b79c6e0cd73606677f9067 --- /dev/null +++ b/src/components/Connection/SGEConnect/__snapshots__/SgeModalHint.spec.tsx.snap @@ -0,0 +1,1027 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`SgeModalHint component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <SgeModalHint + handleCloseClick={[MockFunction]} + open={true} + > + <WithStyles(ForwardRef(Dialog)) + aria-labelledby="accessibility-title" + classes={ + Object { + "paper": "modal-paper", + "root": "modal-root", + } + } + disableEscapeKeyDown={true} + onClose={[MockFunction]} + open={true} + > + <ForwardRef(Dialog) + aria-labelledby="accessibility-title" + classes={ + Object { + "container": "MuiDialog-container", + "paper": "MuiDialog-paper modal-paper", + "paperFullScreen": "MuiDialog-paperFullScreen", + "paperFullWidth": "MuiDialog-paperFullWidth", + "paperScrollBody": "MuiDialog-paperScrollBody", + "paperScrollPaper": "MuiDialog-paperScrollPaper", + "paperWidthFalse": "MuiDialog-paperWidthFalse", + "paperWidthLg": "MuiDialog-paperWidthLg", + "paperWidthMd": "MuiDialog-paperWidthMd", + "paperWidthSm": "MuiDialog-paperWidthSm", + "paperWidthXl": "MuiDialog-paperWidthXl", + "paperWidthXs": "MuiDialog-paperWidthXs", + "root": "MuiDialog-root modal-root", + "scrollBody": "MuiDialog-scrollBody", + "scrollPaper": "MuiDialog-scrollPaper", + } + } + disableEscapeKeyDown={true} + onClose={[MockFunction]} + open={true} + > + <ForwardRef(Modal) + BackdropComponent={ + Object { + "$$typeof": Symbol(react.forward_ref), + "Naked": Object { + "$$typeof": Symbol(react.forward_ref), + "propTypes": Object { + "children": [Function], + "className": [Function], + "classes": [Function], + "invisible": [Function], + "open": [Function], + "transitionDuration": [Function], + }, + "render": [Function], + }, + "displayName": "WithStyles(ForwardRef(Backdrop))", + "options": Object { + "defaultTheme": Object { + "breakpoints": Object { + "between": [Function], + "down": [Function], + "keys": Array [ + "xs", + "sm", + "md", + "lg", + "xl", + ], + "only": [Function], + "up": [Function], + "values": Object { + "lg": 1280, + "md": 960, + "sm": 600, + "xl": 1920, + "xs": 0, + }, + "width": [Function], + }, + "direction": "ltr", + "mixins": Object { + "gutters": [Function], + "toolbar": Object { + "@media (min-width:0px) and (orientation: landscape)": Object { + "minHeight": 48, + }, + "@media (min-width:600px)": Object { + "minHeight": 64, + }, + "minHeight": 56, + }, + }, + "overrides": Object {}, + "palette": Object { + "action": Object { + "activatedOpacity": 0.12, + "active": "rgba(0, 0, 0, 0.54)", + "disabled": "rgba(0, 0, 0, 0.26)", + "disabledBackground": "rgba(0, 0, 0, 0.12)", + "disabledOpacity": 0.38, + "focus": "rgba(0, 0, 0, 0.12)", + "focusOpacity": 0.12, + "hover": "rgba(0, 0, 0, 0.04)", + "hoverOpacity": 0.04, + "selected": "rgba(0, 0, 0, 0.08)", + "selectedOpacity": 0.08, + }, + "augmentColor": [Function], + "background": Object { + "default": "#fafafa", + "paper": "#fff", + }, + "common": Object { + "black": "#000", + "white": "#fff", + }, + "contrastThreshold": 3, + "divider": "rgba(0, 0, 0, 0.12)", + "error": Object { + "contrastText": "#fff", + "dark": "#d32f2f", + "light": "#e57373", + "main": "#f44336", + }, + "getContrastText": [Function], + "grey": Object { + "100": "#f5f5f5", + "200": "#eeeeee", + "300": "#e0e0e0", + "400": "#bdbdbd", + "50": "#fafafa", + "500": "#9e9e9e", + "600": "#757575", + "700": "#616161", + "800": "#424242", + "900": "#212121", + "A100": "#d5d5d5", + "A200": "#aaaaaa", + "A400": "#303030", + "A700": "#616161", + }, + "info": Object { + "contrastText": "#fff", + "dark": "#1976d2", + "light": "#64b5f6", + "main": "#2196f3", + }, + "primary": Object { + "contrastText": "#fff", + "dark": "#303f9f", + "light": "#7986cb", + "main": "#3f51b5", + }, + "secondary": Object { + "contrastText": "#fff", + "dark": "#c51162", + "light": "#ff4081", + "main": "#f50057", + }, + "success": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#388e3c", + "light": "#81c784", + "main": "#4caf50", + }, + "text": Object { + "disabled": "rgba(0, 0, 0, 0.38)", + "hint": "rgba(0, 0, 0, 0.38)", + "primary": "rgba(0, 0, 0, 0.87)", + "secondary": "rgba(0, 0, 0, 0.54)", + }, + "tonalOffset": 0.2, + "type": "light", + "warning": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#f57c00", + "light": "#ffb74d", + "main": "#ff9800", + }, + }, + "props": Object {}, + "shadows": Array [ + "none", + "0px 2px 1px -1px rgba(0,0,0,0.2),0px 1px 1px 0px rgba(0,0,0,0.14),0px 1px 3px 0px rgba(0,0,0,0.12)", + "0px 3px 1px -2px rgba(0,0,0,0.2),0px 2px 2px 0px rgba(0,0,0,0.14),0px 1px 5px 0px rgba(0,0,0,0.12)", + "0px 3px 3px -2px rgba(0,0,0,0.2),0px 3px 4px 0px rgba(0,0,0,0.14),0px 1px 8px 0px rgba(0,0,0,0.12)", + "0px 2px 4px -1px rgba(0,0,0,0.2),0px 4px 5px 0px rgba(0,0,0,0.14),0px 1px 10px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 5px 8px 0px rgba(0,0,0,0.14),0px 1px 14px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 6px 10px 0px rgba(0,0,0,0.14),0px 1px 18px 0px rgba(0,0,0,0.12)", + "0px 4px 5px -2px rgba(0,0,0,0.2),0px 7px 10px 1px rgba(0,0,0,0.14),0px 2px 16px 1px rgba(0,0,0,0.12)", + "0px 5px 5px -3px rgba(0,0,0,0.2),0px 8px 10px 1px rgba(0,0,0,0.14),0px 3px 14px 2px rgba(0,0,0,0.12)", + "0px 5px 6px -3px rgba(0,0,0,0.2),0px 9px 12px 1px rgba(0,0,0,0.14),0px 3px 16px 2px rgba(0,0,0,0.12)", + "0px 6px 6px -3px rgba(0,0,0,0.2),0px 10px 14px 1px rgba(0,0,0,0.14),0px 4px 18px 3px rgba(0,0,0,0.12)", + "0px 6px 7px -4px rgba(0,0,0,0.2),0px 11px 15px 1px rgba(0,0,0,0.14),0px 4px 20px 3px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 12px 17px 2px rgba(0,0,0,0.14),0px 5px 22px 4px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 13px 19px 2px rgba(0,0,0,0.14),0px 5px 24px 4px rgba(0,0,0,0.12)", + "0px 7px 9px -4px rgba(0,0,0,0.2),0px 14px 21px 2px rgba(0,0,0,0.14),0px 5px 26px 4px rgba(0,0,0,0.12)", + "0px 8px 9px -5px rgba(0,0,0,0.2),0px 15px 22px 2px rgba(0,0,0,0.14),0px 6px 28px 5px rgba(0,0,0,0.12)", + "0px 8px 10px -5px rgba(0,0,0,0.2),0px 16px 24px 2px rgba(0,0,0,0.14),0px 6px 30px 5px rgba(0,0,0,0.12)", + "0px 8px 11px -5px rgba(0,0,0,0.2),0px 17px 26px 2px rgba(0,0,0,0.14),0px 6px 32px 5px rgba(0,0,0,0.12)", + "0px 9px 11px -5px rgba(0,0,0,0.2),0px 18px 28px 2px rgba(0,0,0,0.14),0px 7px 34px 6px rgba(0,0,0,0.12)", + "0px 9px 12px -6px rgba(0,0,0,0.2),0px 19px 29px 2px rgba(0,0,0,0.14),0px 7px 36px 6px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 20px 31px 3px rgba(0,0,0,0.14),0px 8px 38px 7px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 21px 33px 3px rgba(0,0,0,0.14),0px 8px 40px 7px rgba(0,0,0,0.12)", + "0px 10px 14px -6px rgba(0,0,0,0.2),0px 22px 35px 3px rgba(0,0,0,0.14),0px 8px 42px 7px rgba(0,0,0,0.12)", + "0px 11px 14px -7px rgba(0,0,0,0.2),0px 23px 36px 3px rgba(0,0,0,0.14),0px 9px 44px 8px rgba(0,0,0,0.12)", + "0px 11px 15px -7px rgba(0,0,0,0.2),0px 24px 38px 3px rgba(0,0,0,0.14),0px 9px 46px 8px rgba(0,0,0,0.12)", + ], + "shape": Object { + "borderRadius": 4, + }, + "spacing": [Function], + "transitions": Object { + "create": [Function], + "duration": Object { + "complex": 375, + "enteringScreen": 225, + "leavingScreen": 195, + "short": 250, + "shorter": 200, + "shortest": 150, + "standard": 300, + }, + "easing": Object { + "easeIn": "cubic-bezier(0.4, 0, 1, 1)", + "easeInOut": "cubic-bezier(0.4, 0, 0.2, 1)", + "easeOut": "cubic-bezier(0.0, 0, 0.2, 1)", + "sharp": "cubic-bezier(0.4, 0, 0.6, 1)", + }, + "getAutoHeightDuration": [Function], + }, + "typography": Object { + "body1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.5, + }, + "body2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 400, + "letterSpacing": "0.01071em", + "lineHeight": 1.43, + }, + "button": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.02857em", + "lineHeight": 1.75, + "textTransform": "uppercase", + }, + "caption": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.03333em", + "lineHeight": 1.66, + }, + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": 14, + "fontWeightBold": 700, + "fontWeightLight": 300, + "fontWeightMedium": 500, + "fontWeightRegular": 400, + "h1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "6rem", + "fontWeight": 300, + "letterSpacing": "-0.01562em", + "lineHeight": 1.167, + }, + "h2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3.75rem", + "fontWeight": 300, + "letterSpacing": "-0.00833em", + "lineHeight": 1.2, + }, + "h3": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.167, + }, + "h4": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "2.125rem", + "fontWeight": 400, + "letterSpacing": "0.00735em", + "lineHeight": 1.235, + }, + "h5": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.5rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.334, + }, + "h6": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.25rem", + "fontWeight": 500, + "letterSpacing": "0.0075em", + "lineHeight": 1.6, + }, + "htmlFontSize": 16, + "overline": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.08333em", + "lineHeight": 2.66, + "textTransform": "uppercase", + }, + "pxToRem": [Function], + "round": [Function], + "subtitle1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.75, + }, + "subtitle2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.00714em", + "lineHeight": 1.57, + }, + }, + "zIndex": Object { + "appBar": 1100, + "drawer": 1200, + "mobileStepper": 1000, + "modal": 1300, + "snackbar": 1400, + "speedDial": 1050, + "tooltip": 1500, + }, + }, + "name": "MuiBackdrop", + }, + "propTypes": Object { + "classes": [Function], + "innerRef": [Function], + }, + "render": [Function], + "useStyles": [Function], + } + } + BackdropProps={ + Object { + "transitionDuration": Object { + "enter": 225, + "exit": 195, + }, + } + } + className="MuiDialog-root modal-root" + closeAfterTransition={true} + disableEscapeKeyDown={true} + onClose={[MockFunction]} + open={true} + > + <ForwardRef(Portal) + disablePortal={false} + > + <Portal + containerInfo={ + <body + style="padding-right: 0px; overflow: hidden;" + > + <div + class="MuiDialog-root modal-root" + role="presentation" + style="position: fixed; z-index: 1300; right: 0px; bottom: 0px; top: 0px; left: 0px;" + > + <div + aria-hidden="true" + class="MuiBackdrop-root" + style="opacity: 1; webkit-transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;" + /> + <div + data-test="sentinelStart" + tabindex="0" + /> + <div + class="MuiDialog-container MuiDialog-scrollPaper" + role="none presentation" + style="opacity: 1; webkit-transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;" + tabindex="-1" + > + <div + aria-labelledby="accessibility-title" + class="MuiPaper-root MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm MuiPaper-elevation24 MuiPaper-rounded" + role="dialog" + > + <div + id="accessibility-title" + > + challenge_no_fluid_modal.accessibility.window_title + </div> + <button + aria-label="feedback.accessibility.button_close" + class="MuiButtonBase-root MuiIconButton-root modal-paper-close-button" + tabindex="0" + type="button" + > + <span + class="MuiIconButton-label" + > + <svg + class="styles__icon___23x3R" + height="16" + width="16" + > + <use + xlink:href="#test-file-stub" + /> + </svg> + </span> + <span + class="MuiTouchRipple-root" + /> + </button> + <div + class="sgeHintModal" + > + <div + class="title text-20-bold" + > + auth.enedis-sge-grandlyon.modalHint.title + </div> + <svg + class="styles__icon___23x3R" + height="385" + width="240" + > + <use + xlink:href="#test-file-stub" + /> + </svg> + <button + aria-label="auth.enedis-sge-grandlyon.modalHint.button-accessibility" + class="MuiButtonBase-root MuiButton-root btn-highlight MuiButton-text" + style="height: 40px;" + tabindex="0" + type="button" + > + <span + class="MuiButton-label text-16-bold" + > + auth.enedis-sge-grandlyon.modalHint.button + </span> + <span + class="MuiTouchRipple-root" + /> + </button> + </div> + </div> + </div> + <div + data-test="sentinelEnd" + tabindex="0" + /> + </div> + </body> + } + > + <div + className="MuiDialog-root modal-root" + onKeyDown={[Function]} + role="presentation" + style={ + Object { + "bottom": 0, + "left": 0, + "position": "fixed", + "right": 0, + "top": 0, + "zIndex": 1300, + } + } + > + <WithStyles(ForwardRef(Backdrop)) + onClick={[Function]} + open={true} + transitionDuration={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <ForwardRef(Backdrop) + classes={ + Object { + "invisible": "MuiBackdrop-invisible", + "root": "MuiBackdrop-root", + } + } + onClick={[Function]} + open={true} + transitionDuration={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <ForwardRef(Fade) + in={true} + onClick={[Function]} + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <Transition + appear={true} + enter={true} + exit={true} + in={true} + mountOnEnter={false} + onClick={[Function]} + onEnter={[Function]} + onEntered={[Function]} + onEntering={[Function]} + onExit={[Function]} + onExited={[Function]} + onExiting={[Function]} + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + unmountOnExit={false} + > + <div + aria-hidden={true} + className="MuiBackdrop-root" + onClick={[Function]} + style={ + Object { + "opacity": 1, + "visibility": undefined, + } + } + /> + </Transition> + </ForwardRef(Fade)> + </ForwardRef(Backdrop)> + </WithStyles(ForwardRef(Backdrop))> + <Unstable_TrapFocus + disableAutoFocus={false} + disableEnforceFocus={false} + disableRestoreFocus={false} + getDoc={[Function]} + isEnabled={[Function]} + open={true} + > + <div + data-test="sentinelStart" + tabIndex={0} + /> + <ForwardRef(Fade) + appear={true} + in={true} + onEnter={[Function]} + onExited={[Function]} + role="none presentation" + tabIndex="-1" + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <Transition + appear={true} + enter={true} + exit={true} + in={true} + mountOnEnter={false} + onEnter={[Function]} + onEntered={[Function]} + onEntering={[Function]} + onExit={[Function]} + onExited={[Function]} + onExiting={[Function]} + role="none presentation" + tabIndex="-1" + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + unmountOnExit={false} + > + <div + className="MuiDialog-container MuiDialog-scrollPaper" + onMouseDown={[Function]} + onMouseUp={[Function]} + role="none presentation" + style={ + Object { + "opacity": 1, + "visibility": undefined, + } + } + tabIndex="-1" + > + <WithStyles(ForwardRef(Paper)) + aria-labelledby="accessibility-title" + className="MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm" + elevation={24} + role="dialog" + > + <ForwardRef(Paper) + aria-labelledby="accessibility-title" + className="MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm" + classes={ + Object { + "elevation0": "MuiPaper-elevation0", + "elevation1": "MuiPaper-elevation1", + "elevation10": "MuiPaper-elevation10", + "elevation11": "MuiPaper-elevation11", + "elevation12": "MuiPaper-elevation12", + "elevation13": "MuiPaper-elevation13", + "elevation14": "MuiPaper-elevation14", + "elevation15": "MuiPaper-elevation15", + "elevation16": "MuiPaper-elevation16", + "elevation17": "MuiPaper-elevation17", + "elevation18": "MuiPaper-elevation18", + "elevation19": "MuiPaper-elevation19", + "elevation2": "MuiPaper-elevation2", + "elevation20": "MuiPaper-elevation20", + "elevation21": "MuiPaper-elevation21", + "elevation22": "MuiPaper-elevation22", + "elevation23": "MuiPaper-elevation23", + "elevation24": "MuiPaper-elevation24", + "elevation3": "MuiPaper-elevation3", + "elevation4": "MuiPaper-elevation4", + "elevation5": "MuiPaper-elevation5", + "elevation6": "MuiPaper-elevation6", + "elevation7": "MuiPaper-elevation7", + "elevation8": "MuiPaper-elevation8", + "elevation9": "MuiPaper-elevation9", + "outlined": "MuiPaper-outlined", + "root": "MuiPaper-root", + "rounded": "MuiPaper-rounded", + } + } + elevation={24} + role="dialog" + > + <div + aria-labelledby="accessibility-title" + className="MuiPaper-root MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm MuiPaper-elevation24 MuiPaper-rounded" + role="dialog" + > + <div + id="accessibility-title" + > + challenge_no_fluid_modal.accessibility.window_title + </div> + <WithStyles(ForwardRef(IconButton)) + aria-label="feedback.accessibility.button_close" + className="modal-paper-close-button" + onClick={[MockFunction]} + > + <ForwardRef(IconButton) + aria-label="feedback.accessibility.button_close" + className="modal-paper-close-button" + classes={ + Object { + "colorInherit": "MuiIconButton-colorInherit", + "colorPrimary": "MuiIconButton-colorPrimary", + "colorSecondary": "MuiIconButton-colorSecondary", + "disabled": "Mui-disabled", + "edgeEnd": "MuiIconButton-edgeEnd", + "edgeStart": "MuiIconButton-edgeStart", + "label": "MuiIconButton-label", + "root": "MuiIconButton-root", + "sizeSmall": "MuiIconButton-sizeSmall", + } + } + onClick={[MockFunction]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="feedback.accessibility.button_close" + centerRipple={true} + className="MuiIconButton-root modal-paper-close-button" + disabled={false} + focusRipple={true} + onClick={[MockFunction]} + > + <ForwardRef(ButtonBase) + aria-label="feedback.accessibility.button_close" + centerRipple={true} + className="MuiIconButton-root modal-paper-close-button" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + disabled={false} + focusRipple={true} + onClick={[MockFunction]} + > + <button + aria-label="feedback.accessibility.button_close" + className="MuiButtonBase-root MuiIconButton-root modal-paper-close-button" + disabled={false} + onBlur={[Function]} + onClick={[MockFunction]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiIconButton-label" + > + <Icon + icon="test-file-stub" + size={16} + spin={false} + > + <Component + className="styles__icon___23x3R" + height={16} + style={Object {}} + width={16} + > + <svg + className="styles__icon___23x3R" + height={16} + style={Object {}} + width={16} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </span> + <WithStyles(memo) + center={true} + > + <ForwardRef(TouchRipple) + center={true} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(IconButton)> + </WithStyles(ForwardRef(IconButton))> + <div + className="sgeHintModal" + > + <div + className="title text-20-bold" + > + auth.enedis-sge-grandlyon.modalHint.title + </div> + <Icon + height={385} + icon="test-file-stub" + spin={false} + width={240} + > + <Component + className="styles__icon___23x3R" + height={385} + style={Object {}} + width={240} + > + <svg + className="styles__icon___23x3R" + height={385} + style={Object {}} + width={240} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + <WithStyles(ForwardRef(Button)) + aria-label="auth.enedis-sge-grandlyon.modalHint.button-accessibility" + classes={ + Object { + "label": "text-16-bold", + "root": "btn-highlight", + } + } + onClick={[MockFunction]} + style={ + Object { + "height": "40px", + } + } + > + <ForwardRef(Button) + aria-label="auth.enedis-sge-grandlyon.modalHint.button-accessibility" + classes={ + Object { + "colorInherit": "MuiButton-colorInherit", + "contained": "MuiButton-contained", + "containedPrimary": "MuiButton-containedPrimary", + "containedSecondary": "MuiButton-containedSecondary", + "containedSizeLarge": "MuiButton-containedSizeLarge", + "containedSizeSmall": "MuiButton-containedSizeSmall", + "disableElevation": "MuiButton-disableElevation", + "disabled": "Mui-disabled", + "endIcon": "MuiButton-endIcon", + "focusVisible": "Mui-focusVisible", + "fullWidth": "MuiButton-fullWidth", + "iconSizeLarge": "MuiButton-iconSizeLarge", + "iconSizeMedium": "MuiButton-iconSizeMedium", + "iconSizeSmall": "MuiButton-iconSizeSmall", + "label": "MuiButton-label text-16-bold", + "outlined": "MuiButton-outlined", + "outlinedPrimary": "MuiButton-outlinedPrimary", + "outlinedSecondary": "MuiButton-outlinedSecondary", + "outlinedSizeLarge": "MuiButton-outlinedSizeLarge", + "outlinedSizeSmall": "MuiButton-outlinedSizeSmall", + "root": "MuiButton-root btn-highlight", + "sizeLarge": "MuiButton-sizeLarge", + "sizeSmall": "MuiButton-sizeSmall", + "startIcon": "MuiButton-startIcon", + "text": "MuiButton-text", + "textPrimary": "MuiButton-textPrimary", + "textSecondary": "MuiButton-textSecondary", + "textSizeLarge": "MuiButton-textSizeLarge", + "textSizeSmall": "MuiButton-textSizeSmall", + } + } + onClick={[MockFunction]} + style={ + Object { + "height": "40px", + } + } + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="auth.enedis-sge-grandlyon.modalHint.button-accessibility" + className="MuiButton-root btn-highlight MuiButton-text" + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[MockFunction]} + style={ + Object { + "height": "40px", + } + } + type="button" + > + <ForwardRef(ButtonBase) + aria-label="auth.enedis-sge-grandlyon.modalHint.button-accessibility" + className="MuiButton-root btn-highlight MuiButton-text" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[MockFunction]} + style={ + Object { + "height": "40px", + } + } + type="button" + > + <button + aria-label="auth.enedis-sge-grandlyon.modalHint.button-accessibility" + className="MuiButtonBase-root MuiButton-root btn-highlight MuiButton-text" + disabled={false} + onBlur={[Function]} + onClick={[MockFunction]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + style={ + Object { + "height": "40px", + } + } + tabIndex={0} + type="button" + > + <span + className="MuiButton-label text-16-bold" + > + auth.enedis-sge-grandlyon.modalHint.button + </span> + <WithStyles(memo) + center={false} + > + <ForwardRef(TouchRipple) + center={false} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(Button)> + </WithStyles(ForwardRef(Button))> + </div> + </div> + </ForwardRef(Paper)> + </WithStyles(ForwardRef(Paper))> + </div> + </Transition> + </ForwardRef(Fade)> + <div + data-test="sentinelEnd" + tabIndex={0} + /> + </Unstable_TrapFocus> + </div> + </Portal> + </ForwardRef(Portal)> + </ForwardRef(Modal)> + </ForwardRef(Dialog)> + </WithStyles(ForwardRef(Dialog))> + </SgeModalHint> +</Provider> +`; diff --git a/src/components/Connection/SGEConnect/__snapshots__/StepAddress.spec.tsx.snap b/src/components/Connection/SGEConnect/__snapshots__/StepAddress.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..3414e107bd883a271544835f8f9e3b8394fde859 --- /dev/null +++ b/src/components/Connection/SGEConnect/__snapshots__/StepAddress.spec.tsx.snap @@ -0,0 +1,83 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`StepAddress component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <StepAddress + onChange={[MockFunction]} + sgeState={ + Object { + "address": "", + "city": "", + "currentStep": 0, + "dataConsent": false, + "firstName": "", + "lastName": "", + "pdl": null, + "pdlConfirm": false, + "shouldLaunchAccount": false, + "zipCode": null, + } + } + > + <div + className="sge-step-container stepAddress" + > + <div + className="title text-22-bold" + > + auth.enedis-sge-grandlyon.addressTitle + </div> + <label + className="text-16-normal" + htmlFor="address" + > + auth.enedis-sge-grandlyon.address + </label> + <input + id="address" + name="address" + onChange={[Function]} + type="text" + value="" + /> + <label + className="text-16-normal" + htmlFor="zipCode" + > + auth.enedis-sge-grandlyon.zipCode + </label> + <input + id="zipCode" + min={0} + name="zipCode" + onChange={[Function]} + type="number" + /> + <label + className="text-16-normal" + htmlFor="city" + > + auth.enedis-sge-grandlyon.city + </label> + <input + id="city" + name="city" + onChange={[Function]} + type="text" + value="" + /> + </div> + </StepAddress> +</Provider> +`; diff --git a/src/components/Connection/SGEConnect/__snapshots__/StepConsent.spec.tsx.snap b/src/components/Connection/SGEConnect/__snapshots__/StepConsent.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..87b0a995e47e4a216dd64121cb2f595a02117a14 --- /dev/null +++ b/src/components/Connection/SGEConnect/__snapshots__/StepConsent.spec.tsx.snap @@ -0,0 +1,92 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`StepConsent component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <StepConsent + onChange={[MockFunction]} + sgeState={ + Object { + "address": "", + "city": "", + "currentStep": 0, + "dataConsent": false, + "firstName": "", + "lastName": "", + "pdl": null, + "pdlConfirm": false, + "shouldLaunchAccount": false, + "zipCode": null, + } + } + > + <div + className="sge-step-container stepConsent" + > + <div + className="head text-16-normal" + > + auth.enedis-sge-grandlyon.headConsent + </div> + <div + className="title text-22-bold" + > + auth.enedis-sge-grandlyon.textConsent + </div> + <ul + className="text-16-normal" + > + <li> + auth.enedis-sge-grandlyon.consentLi1 + </li> + <li> + auth.enedis-sge-grandlyon.consentLi2 + </li> + <li> + auth.enedis-sge-grandlyon.consentLi3 + </li> + <li> + auth.enedis-sge-grandlyon.consentLi4 + </li> + </ul> + <hr /> + <label + className="checkbox" + > + <input + checked={false} + id="dataConsent" + name="Data-consent-validation" + onChange={[Function]} + type="checkbox" + /> + <span> + auth.enedis-sge-grandlyon.consentCheck1 + </span> + </label> + <label + className="checkbox" + > + <input + checked={false} + id="pdlConfirm" + name="Data-consent-validation" + onChange={[Function]} + type="checkbox" + /> + auth.enedis-sge-grandlyon.consentCheck2 + </label> + </div> + </StepConsent> +</Provider> +`; diff --git a/src/components/Connection/SGEConnect/__snapshots__/StepIdentityAndPdl.spec.tsx.snap b/src/components/Connection/SGEConnect/__snapshots__/StepIdentityAndPdl.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..6b069ff7f702427d9ad77b0a345bdc6560a63fd5 --- /dev/null +++ b/src/components/Connection/SGEConnect/__snapshots__/StepIdentityAndPdl.spec.tsx.snap @@ -0,0 +1,472 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`StepIdentityAndPdl component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <StepIdentityAndPdl + onChange={[MockFunction]} + sgeState={ + Object { + "address": "", + "city": "", + "currentStep": 0, + "dataConsent": false, + "firstName": "", + "lastName": "", + "pdl": null, + "pdlConfirm": false, + "shouldLaunchAccount": false, + "zipCode": null, + } + } + > + <div + className="sge-step-container stepIdentity" + > + <div + className="title text-22-bold" + > + auth.enedis-sge-grandlyon.identityTitle + </div> + <label + className="text-16-normal" + htmlFor="firstName" + > + auth.enedis-sge-grandlyon.firstName + </label> + <input + id="firstName" + name="firstName" + onChange={[Function]} + required={true} + type="text" + value="" + /> + <label + className="text-16-normal" + htmlFor="lastName" + > + auth.enedis-sge-grandlyon.lastName + </label> + <input + id="lastName" + name="lastName" + onChange={[Function]} + required={true} + type="text" + value="" + /> + <div + className="title text-22-bold" + > + auth.enedis-sge-grandlyon.pdlTitle + </div> + <label + className="text-16-normal" + htmlFor="pdl" + > + auth.enedis-sge-grandlyon.pdlLabel + </label> + <input + id="pdl" + inputMode="numeric" + min={0} + name="pdl" + onChange={[Function]} + required={true} + type="number" + /> + <div + className="pdl-hint text-16-normal" + onClick={[Function]} + > + auth.enedis-sge-grandlyon.pdlHint + </div> + <SgeModalHint + handleCloseClick={[Function]} + open={false} + > + <WithStyles(ForwardRef(Dialog)) + aria-labelledby="accessibility-title" + classes={ + Object { + "paper": "modal-paper", + "root": "modal-root", + } + } + disableEscapeKeyDown={true} + onClose={[Function]} + open={false} + > + <ForwardRef(Dialog) + aria-labelledby="accessibility-title" + classes={ + Object { + "container": "MuiDialog-container", + "paper": "MuiDialog-paper modal-paper", + "paperFullScreen": "MuiDialog-paperFullScreen", + "paperFullWidth": "MuiDialog-paperFullWidth", + "paperScrollBody": "MuiDialog-paperScrollBody", + "paperScrollPaper": "MuiDialog-paperScrollPaper", + "paperWidthFalse": "MuiDialog-paperWidthFalse", + "paperWidthLg": "MuiDialog-paperWidthLg", + "paperWidthMd": "MuiDialog-paperWidthMd", + "paperWidthSm": "MuiDialog-paperWidthSm", + "paperWidthXl": "MuiDialog-paperWidthXl", + "paperWidthXs": "MuiDialog-paperWidthXs", + "root": "MuiDialog-root modal-root", + "scrollBody": "MuiDialog-scrollBody", + "scrollPaper": "MuiDialog-scrollPaper", + } + } + disableEscapeKeyDown={true} + onClose={[Function]} + open={false} + > + <ForwardRef(Modal) + BackdropComponent={ + Object { + "$$typeof": Symbol(react.forward_ref), + "Naked": Object { + "$$typeof": Symbol(react.forward_ref), + "propTypes": Object { + "children": [Function], + "className": [Function], + "classes": [Function], + "invisible": [Function], + "open": [Function], + "transitionDuration": [Function], + }, + "render": [Function], + }, + "displayName": "WithStyles(ForwardRef(Backdrop))", + "options": Object { + "defaultTheme": Object { + "breakpoints": Object { + "between": [Function], + "down": [Function], + "keys": Array [ + "xs", + "sm", + "md", + "lg", + "xl", + ], + "only": [Function], + "up": [Function], + "values": Object { + "lg": 1280, + "md": 960, + "sm": 600, + "xl": 1920, + "xs": 0, + }, + "width": [Function], + }, + "direction": "ltr", + "mixins": Object { + "gutters": [Function], + "toolbar": Object { + "@media (min-width:0px) and (orientation: landscape)": Object { + "minHeight": 48, + }, + "@media (min-width:600px)": Object { + "minHeight": 64, + }, + "minHeight": 56, + }, + }, + "overrides": Object {}, + "palette": Object { + "action": Object { + "activatedOpacity": 0.12, + "active": "rgba(0, 0, 0, 0.54)", + "disabled": "rgba(0, 0, 0, 0.26)", + "disabledBackground": "rgba(0, 0, 0, 0.12)", + "disabledOpacity": 0.38, + "focus": "rgba(0, 0, 0, 0.12)", + "focusOpacity": 0.12, + "hover": "rgba(0, 0, 0, 0.04)", + "hoverOpacity": 0.04, + "selected": "rgba(0, 0, 0, 0.08)", + "selectedOpacity": 0.08, + }, + "augmentColor": [Function], + "background": Object { + "default": "#fafafa", + "paper": "#fff", + }, + "common": Object { + "black": "#000", + "white": "#fff", + }, + "contrastThreshold": 3, + "divider": "rgba(0, 0, 0, 0.12)", + "error": Object { + "contrastText": "#fff", + "dark": "#d32f2f", + "light": "#e57373", + "main": "#f44336", + }, + "getContrastText": [Function], + "grey": Object { + "100": "#f5f5f5", + "200": "#eeeeee", + "300": "#e0e0e0", + "400": "#bdbdbd", + "50": "#fafafa", + "500": "#9e9e9e", + "600": "#757575", + "700": "#616161", + "800": "#424242", + "900": "#212121", + "A100": "#d5d5d5", + "A200": "#aaaaaa", + "A400": "#303030", + "A700": "#616161", + }, + "info": Object { + "contrastText": "#fff", + "dark": "#1976d2", + "light": "#64b5f6", + "main": "#2196f3", + }, + "primary": Object { + "contrastText": "#fff", + "dark": "#303f9f", + "light": "#7986cb", + "main": "#3f51b5", + }, + "secondary": Object { + "contrastText": "#fff", + "dark": "#c51162", + "light": "#ff4081", + "main": "#f50057", + }, + "success": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#388e3c", + "light": "#81c784", + "main": "#4caf50", + }, + "text": Object { + "disabled": "rgba(0, 0, 0, 0.38)", + "hint": "rgba(0, 0, 0, 0.38)", + "primary": "rgba(0, 0, 0, 0.87)", + "secondary": "rgba(0, 0, 0, 0.54)", + }, + "tonalOffset": 0.2, + "type": "light", + "warning": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#f57c00", + "light": "#ffb74d", + "main": "#ff9800", + }, + }, + "props": Object {}, + "shadows": Array [ + "none", + "0px 2px 1px -1px rgba(0,0,0,0.2),0px 1px 1px 0px rgba(0,0,0,0.14),0px 1px 3px 0px rgba(0,0,0,0.12)", + "0px 3px 1px -2px rgba(0,0,0,0.2),0px 2px 2px 0px rgba(0,0,0,0.14),0px 1px 5px 0px rgba(0,0,0,0.12)", + "0px 3px 3px -2px rgba(0,0,0,0.2),0px 3px 4px 0px rgba(0,0,0,0.14),0px 1px 8px 0px rgba(0,0,0,0.12)", + "0px 2px 4px -1px rgba(0,0,0,0.2),0px 4px 5px 0px rgba(0,0,0,0.14),0px 1px 10px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 5px 8px 0px rgba(0,0,0,0.14),0px 1px 14px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 6px 10px 0px rgba(0,0,0,0.14),0px 1px 18px 0px rgba(0,0,0,0.12)", + "0px 4px 5px -2px rgba(0,0,0,0.2),0px 7px 10px 1px rgba(0,0,0,0.14),0px 2px 16px 1px rgba(0,0,0,0.12)", + "0px 5px 5px -3px rgba(0,0,0,0.2),0px 8px 10px 1px rgba(0,0,0,0.14),0px 3px 14px 2px rgba(0,0,0,0.12)", + "0px 5px 6px -3px rgba(0,0,0,0.2),0px 9px 12px 1px rgba(0,0,0,0.14),0px 3px 16px 2px rgba(0,0,0,0.12)", + "0px 6px 6px -3px rgba(0,0,0,0.2),0px 10px 14px 1px rgba(0,0,0,0.14),0px 4px 18px 3px rgba(0,0,0,0.12)", + "0px 6px 7px -4px rgba(0,0,0,0.2),0px 11px 15px 1px rgba(0,0,0,0.14),0px 4px 20px 3px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 12px 17px 2px rgba(0,0,0,0.14),0px 5px 22px 4px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 13px 19px 2px rgba(0,0,0,0.14),0px 5px 24px 4px rgba(0,0,0,0.12)", + "0px 7px 9px -4px rgba(0,0,0,0.2),0px 14px 21px 2px rgba(0,0,0,0.14),0px 5px 26px 4px rgba(0,0,0,0.12)", + "0px 8px 9px -5px rgba(0,0,0,0.2),0px 15px 22px 2px rgba(0,0,0,0.14),0px 6px 28px 5px rgba(0,0,0,0.12)", + "0px 8px 10px -5px rgba(0,0,0,0.2),0px 16px 24px 2px rgba(0,0,0,0.14),0px 6px 30px 5px rgba(0,0,0,0.12)", + "0px 8px 11px -5px rgba(0,0,0,0.2),0px 17px 26px 2px rgba(0,0,0,0.14),0px 6px 32px 5px rgba(0,0,0,0.12)", + "0px 9px 11px -5px rgba(0,0,0,0.2),0px 18px 28px 2px rgba(0,0,0,0.14),0px 7px 34px 6px rgba(0,0,0,0.12)", + "0px 9px 12px -6px rgba(0,0,0,0.2),0px 19px 29px 2px rgba(0,0,0,0.14),0px 7px 36px 6px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 20px 31px 3px rgba(0,0,0,0.14),0px 8px 38px 7px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 21px 33px 3px rgba(0,0,0,0.14),0px 8px 40px 7px rgba(0,0,0,0.12)", + "0px 10px 14px -6px rgba(0,0,0,0.2),0px 22px 35px 3px rgba(0,0,0,0.14),0px 8px 42px 7px rgba(0,0,0,0.12)", + "0px 11px 14px -7px rgba(0,0,0,0.2),0px 23px 36px 3px rgba(0,0,0,0.14),0px 9px 44px 8px rgba(0,0,0,0.12)", + "0px 11px 15px -7px rgba(0,0,0,0.2),0px 24px 38px 3px rgba(0,0,0,0.14),0px 9px 46px 8px rgba(0,0,0,0.12)", + ], + "shape": Object { + "borderRadius": 4, + }, + "spacing": [Function], + "transitions": Object { + "create": [Function], + "duration": Object { + "complex": 375, + "enteringScreen": 225, + "leavingScreen": 195, + "short": 250, + "shorter": 200, + "shortest": 150, + "standard": 300, + }, + "easing": Object { + "easeIn": "cubic-bezier(0.4, 0, 1, 1)", + "easeInOut": "cubic-bezier(0.4, 0, 0.2, 1)", + "easeOut": "cubic-bezier(0.0, 0, 0.2, 1)", + "sharp": "cubic-bezier(0.4, 0, 0.6, 1)", + }, + "getAutoHeightDuration": [Function], + }, + "typography": Object { + "body1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.5, + }, + "body2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 400, + "letterSpacing": "0.01071em", + "lineHeight": 1.43, + }, + "button": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.02857em", + "lineHeight": 1.75, + "textTransform": "uppercase", + }, + "caption": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.03333em", + "lineHeight": 1.66, + }, + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": 14, + "fontWeightBold": 700, + "fontWeightLight": 300, + "fontWeightMedium": 500, + "fontWeightRegular": 400, + "h1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "6rem", + "fontWeight": 300, + "letterSpacing": "-0.01562em", + "lineHeight": 1.167, + }, + "h2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3.75rem", + "fontWeight": 300, + "letterSpacing": "-0.00833em", + "lineHeight": 1.2, + }, + "h3": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.167, + }, + "h4": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "2.125rem", + "fontWeight": 400, + "letterSpacing": "0.00735em", + "lineHeight": 1.235, + }, + "h5": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.5rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.334, + }, + "h6": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.25rem", + "fontWeight": 500, + "letterSpacing": "0.0075em", + "lineHeight": 1.6, + }, + "htmlFontSize": 16, + "overline": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.08333em", + "lineHeight": 2.66, + "textTransform": "uppercase", + }, + "pxToRem": [Function], + "round": [Function], + "subtitle1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.75, + }, + "subtitle2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.00714em", + "lineHeight": 1.57, + }, + }, + "zIndex": Object { + "appBar": 1100, + "drawer": 1200, + "mobileStepper": 1000, + "modal": 1300, + "snackbar": 1400, + "speedDial": 1050, + "tooltip": 1500, + }, + }, + "name": "MuiBackdrop", + }, + "propTypes": Object { + "classes": [Function], + "innerRef": [Function], + }, + "render": [Function], + "useStyles": [Function], + } + } + BackdropProps={ + Object { + "transitionDuration": Object { + "enter": 225, + "exit": 195, + }, + } + } + className="MuiDialog-root modal-root" + closeAfterTransition={true} + disableEscapeKeyDown={true} + onClose={[Function]} + open={false} + /> + </ForwardRef(Dialog)> + </WithStyles(ForwardRef(Dialog))> + </SgeModalHint> + </div> + </StepIdentityAndPdl> +</Provider> +`; diff --git a/src/components/Connection/__snapshots__/Connection.spec.tsx.snap b/src/components/Connection/__snapshots__/Connection.spec.tsx.snap index 990ba1c0eea23080bf48922657c3ce3bba03515a..080b18b8e1cacca0d5fc4f4417638d0594c694ba 100644 --- a/src/components/Connection/__snapshots__/Connection.spec.tsx.snap +++ b/src/components/Connection/__snapshots__/Connection.spec.tsx.snap @@ -1,127 +1,329 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP exports[`Connection component test should call ConnectionLogin 1`] = ` -<Connection - fluidStatus={ +<Provider + store={ Object { - "connection": Object { - "account": null, - "isUpdating": false, - "konnector": null, - "konnectorConfig": Object { - "activation": "", - "name": "", - "oauth": false, - "siteLink": "", - "slug": "", - }, - "shouldLaunchKonnector": false, - "trigger": null, - "triggerState": null, - }, - "firstDataDate": "2019-09-01T00:00:00.000Z", - "fluidType": 0, - "lastDataDate": "2020-09-01T00:00:00.000Z", - "status": 200, + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], } } > - <div - className="konnector-form" - > - <mockConstructor - fluidStatus={ - Object { - "connection": Object { - "account": null, - "isUpdating": false, - "konnector": null, - "konnectorConfig": Object { - "activation": "", - "name": "", - "oauth": false, - "siteLink": "", - "slug": "", - }, - "shouldLaunchKonnector": false, - "trigger": null, - "triggerState": null, + <Connection + fluidStatus={ + Object { + "connection": Object { + "account": null, + "isUpdating": false, + "konnector": null, + "konnectorConfig": Object { + "activation": "", + "name": "", + "oauth": false, + "siteLink": "", + "slug": "enedis-sge-grandlyon", }, - "firstDataDate": "2019-09-01T00:00:00.000Z", - "fluidType": 0, - "lastDataDate": "2020-09-01T00:00:00.000Z", - "status": 200, - } + "shouldLaunchKonnector": false, + "trigger": null, + "triggerState": null, + }, + "firstDataDate": "2019-09-01T00:00:00.000Z", + "fluidType": 0, + "lastDataDate": "2020-09-01T00:00:00.000Z", + "status": 200, } - onSuccess={[Function]} + } + > + <div + className="konnector-form" > - <div - id="ConnectionLogin" - /> - </mockConstructor> - </div> -</Connection> + <SgeInit + fluidStatus={ + Object { + "connection": Object { + "account": null, + "isUpdating": false, + "konnector": null, + "konnectorConfig": Object { + "activation": "", + "name": "", + "oauth": false, + "siteLink": "", + "slug": "enedis-sge-grandlyon", + }, + "shouldLaunchKonnector": false, + "trigger": null, + "triggerState": null, + }, + "firstDataDate": "2019-09-01T00:00:00.000Z", + "fluidType": 0, + "lastDataDate": "2020-09-01T00:00:00.000Z", + "status": 200, + } + } + > + <div + className="kloginform sge-connect" + > + <p + className="kloginform-title enedis-sge-grandlyon text-20-bold" + > + auth.enedis-sge-grandlyon.title + </p> + <StyledIcon + icon="test-file-stub" + size={180} + > + <Icon + aria-hidden={true} + icon="test-file-stub" + size={180} + spin={false} + > + <Component + aria-hidden={true} + className="styles__icon___23x3R" + height={180} + style={Object {}} + width={180} + > + <svg + aria-hidden={true} + className="styles__icon___23x3R" + height={180} + style={Object {}} + width={180} + > + <use + xlinkHref="#test-file-stub" + /> + </svg> + </Component> + </Icon> + </StyledIcon> + <p + className="sge-subtitle enedis-sge-grandlyon text-16-regular" + > + auth.enedis-sge-grandlyon.bill + </p> + <div + className="kloginform-button" + > + <WithStyles(ForwardRef(Button)) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + classes={ + Object { + "label": "text-16-bold", + "root": "btn-highlight", + } + } + onClick={[Function]} + > + <ForwardRef(Button) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + classes={ + Object { + "colorInherit": "MuiButton-colorInherit", + "contained": "MuiButton-contained", + "containedPrimary": "MuiButton-containedPrimary", + "containedSecondary": "MuiButton-containedSecondary", + "containedSizeLarge": "MuiButton-containedSizeLarge", + "containedSizeSmall": "MuiButton-containedSizeSmall", + "disableElevation": "MuiButton-disableElevation", + "disabled": "Mui-disabled", + "endIcon": "MuiButton-endIcon", + "focusVisible": "Mui-focusVisible", + "fullWidth": "MuiButton-fullWidth", + "iconSizeLarge": "MuiButton-iconSizeLarge", + "iconSizeMedium": "MuiButton-iconSizeMedium", + "iconSizeSmall": "MuiButton-iconSizeSmall", + "label": "MuiButton-label text-16-bold", + "outlined": "MuiButton-outlined", + "outlinedPrimary": "MuiButton-outlinedPrimary", + "outlinedSecondary": "MuiButton-outlinedSecondary", + "outlinedSizeLarge": "MuiButton-outlinedSizeLarge", + "outlinedSizeSmall": "MuiButton-outlinedSizeSmall", + "root": "MuiButton-root btn-highlight", + "sizeLarge": "MuiButton-sizeLarge", + "sizeSmall": "MuiButton-sizeSmall", + "startIcon": "MuiButton-startIcon", + "text": "MuiButton-text", + "textPrimary": "MuiButton-textPrimary", + "textSecondary": "MuiButton-textSecondary", + "textSizeLarge": "MuiButton-textSizeLarge", + "textSizeSmall": "MuiButton-textSizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + className="MuiButton-root btn-highlight MuiButton-text" + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <ForwardRef(ButtonBase) + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + className="MuiButton-root btn-highlight MuiButton-text" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <button + aria-label="auth.enedis-sge-grandlyon.accessibility.connect" + className="MuiButtonBase-root MuiButton-root btn-highlight MuiButton-text" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiButton-label text-16-bold" + > + auth.enedis-sge-grandlyon.connect + </span> + <WithStyles(memo) + center={false} + > + <ForwardRef(TouchRipple) + center={false} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(Button)> + </WithStyles(ForwardRef(Button))> + </div> + </div> + </SgeInit> + </div> + </Connection> +</Provider> `; exports[`Connection component test should call ConnectionOAuth 1`] = ` -<Connection - fluidStatus={ +<Provider + store={ Object { - "connection": Object { - "account": null, - "isUpdating": false, - "konnector": null, - "konnectorConfig": Object { - "activation": "", - "name": "", - "oauth": true, - "siteLink": "", - "slug": "", - }, - "shouldLaunchKonnector": false, - "trigger": null, - "triggerState": null, - }, - "firstDataDate": "2019-09-01T00:00:00.000Z", - "fluidType": 2, - "lastDataDate": "2020-09-01T00:00:00.000Z", - "status": 200, + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], } } > - <div - className="konnector-form" - > - <mockConstructor - fluidStatus={ - Object { - "connection": Object { - "account": null, - "isUpdating": false, - "konnector": null, - "konnectorConfig": Object { - "activation": "", - "name": "", - "oauth": true, - "siteLink": "", - "slug": "", - }, - "shouldLaunchKonnector": false, - "trigger": null, - "triggerState": null, + <Connection + fluidStatus={ + Object { + "connection": Object { + "account": null, + "isUpdating": false, + "konnector": null, + "konnectorConfig": Object { + "activation": "", + "name": "", + "oauth": true, + "siteLink": "", + "slug": "grdfgrandlyon", }, - "firstDataDate": "2019-09-01T00:00:00.000Z", - "fluidType": 2, - "lastDataDate": "2020-09-01T00:00:00.000Z", - "status": 200, - } + "shouldLaunchKonnector": false, + "trigger": null, + "triggerState": null, + }, + "firstDataDate": "2019-09-01T00:00:00.000Z", + "fluidType": 2, + "lastDataDate": "2020-09-01T00:00:00.000Z", + "status": 200, } - onSuccess={[Function]} + } + > + <div + className="konnector-form" > - <div - id="ConnectionOAuth" - /> - </mockConstructor> - </div> -</Connection> + <mockConstructor + fluidStatus={ + Object { + "connection": Object { + "account": null, + "isUpdating": false, + "konnector": null, + "konnectorConfig": Object { + "activation": "", + "name": "", + "oauth": true, + "siteLink": "", + "slug": "grdfgrandlyon", + }, + "shouldLaunchKonnector": false, + "trigger": null, + "triggerState": null, + }, + "firstDataDate": "2019-09-01T00:00:00.000Z", + "fluidType": 2, + "lastDataDate": "2020-09-01T00:00:00.000Z", + "status": 200, + } + } + onSuccess={[Function]} + > + <div + id="ConnectionOAuth" + /> + </mockConstructor> + </div> + </Connection> +</Provider> `; diff --git a/src/components/Connection/connectionLogin.scss b/src/components/Connection/connectionLogin.scss index 9460217f553e72c77da5f388102c5336160b2b4f..7f7b8d508ba6cddaca6b97859483d1e4cd47cb8a 100644 --- a/src/components/Connection/connectionLogin.scss +++ b/src/components/Connection/connectionLogin.scss @@ -1,11 +1,14 @@ @import 'src/styles/base/color'; .kloginform { + &.sge-connect { + text-align: center; + } .kloginform-title { text-align: center; margin-bottom: 0; padding: 0 1rem; - &.enedisgrandlyon { + &.enedis-sge-grandlyon { color: $elec-color; } &.grdfgrandlyon { @@ -20,6 +23,15 @@ color: $white; margin: 2.5rem 0 0.5rem; } + + .sge-subtitle { + color: $white; + text-align: center; + span { + font-weight: bold; + color: $gold-shadow; + } + } .kloginform-infotext { text-align: center; color: $grey-bright; diff --git a/src/components/EcogestureForm/EcogestureFormEquipment.tsx b/src/components/EcogestureForm/EcogestureFormEquipment.tsx index 8f0524dbd29ef957a45f40723e1ccb4903861424..cd3fc09d24825af786ef22bb48ec32c6d4a340e4 100644 --- a/src/components/EcogestureForm/EcogestureFormEquipment.tsx +++ b/src/components/EcogestureForm/EcogestureFormEquipment.tsx @@ -1,7 +1,7 @@ import React, { useCallback, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { EcogestureStepForm } from 'enum/ecogestureForm.enum' import { ProfileEcogesture } from 'models/profileEcogesture.model' import { EquipmentType } from 'enum/ecogesture.enum' diff --git a/src/components/EcogestureForm/EcogestureFormSingleChoice.tsx b/src/components/EcogestureForm/EcogestureFormSingleChoice.tsx index 7fa2f94474fc34ced9ad17b5605e9a120fe16f28..eab64499cd3bfdfcd56ac1e0e131613a806478bb 100644 --- a/src/components/EcogestureForm/EcogestureFormSingleChoice.tsx +++ b/src/components/EcogestureForm/EcogestureFormSingleChoice.tsx @@ -2,7 +2,7 @@ import React, { useCallback, useEffect, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' import classNames from 'classnames' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { EcogestureStepForm } from 'enum/ecogestureForm.enum' import { ProfileEcogesture, diff --git a/src/components/ProfileType/FormNavigation.spec.tsx b/src/components/FormGlobal/FormNavigation.spec.tsx similarity index 95% rename from src/components/ProfileType/FormNavigation.spec.tsx rename to src/components/FormGlobal/FormNavigation.spec.tsx index fbb34ae60ebc1375821ed973657ef5e71d22a3d0..a3357ea6784be7623a981443eef48f06e4ece0f2 100644 --- a/src/components/ProfileType/FormNavigation.spec.tsx +++ b/src/components/FormGlobal/FormNavigation.spec.tsx @@ -20,7 +20,6 @@ jest.mock('cozy-ui/transpiled/react/I18n', () => { }) describe('FormNavigation component', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any let store: any beforeEach(() => { store = createMockStore(mockInitialEcolyoState) diff --git a/src/components/ProfileType/FormNavigation.tsx b/src/components/FormGlobal/FormNavigation.tsx similarity index 80% rename from src/components/ProfileType/FormNavigation.tsx rename to src/components/FormGlobal/FormNavigation.tsx index 07e9097a1c8adbb85c42d8ea0b8d9c3a2afc4b02..62dc25ad9e7f7473ffaeb76e84817d1a3aed42de 100644 --- a/src/components/ProfileType/FormNavigation.tsx +++ b/src/components/FormGlobal/FormNavigation.tsx @@ -1,17 +1,20 @@ import React from 'react' -import 'components/ProfileType/formNavigation.scss' +import 'components/FormGlobal/formNavigation.scss' import classNames from 'classnames' import { useI18n } from 'cozy-ui/transpiled/react/I18n' import Button from '@material-ui/core/Button' import { ProfileTypeStepForm } from 'enum/profileType.enum' import { EcogestureStepForm } from 'enum/ecogestureForm.enum' +import { SgeStep } from 'enum/sgeStep.enum' +import { useHistory } from 'react-router-dom' interface FormNavigationProps { - step: ProfileTypeStepForm | EcogestureStepForm + step: ProfileTypeStepForm | EcogestureStepForm | SgeStep handlePrevious: Function handleNext: Function disableNextButton: boolean isEcogesture?: boolean + isLastConnectStep?: boolean } const FormNavigation: React.FC<FormNavigationProps> = ({ @@ -20,14 +23,19 @@ const FormNavigation: React.FC<FormNavigationProps> = ({ handleNext, disableNextButton, isEcogesture, + isLastConnectStep, }: FormNavigationProps) => { const { t } = useI18n() - + const history = useHistory() const handlePreviousClick = () => { handlePrevious() } const handleNextClick = () => { handleNext() + //handle go back to connect for SGE + if (isLastConnectStep) { + history.push('/consumption/electricity') + } } return ( @@ -62,6 +70,7 @@ const FormNavigation: React.FC<FormNavigationProps> = ({ }} > {step === ProfileTypeStepForm.UPDATE_DATE || + isLastConnectStep || (step === EcogestureStepForm.EQUIPMENTS && isEcogesture) ? t('profile_type.form.button_end') : `${t('profile_type.form.button_next')} >`} diff --git a/src/components/ProfileType/ProfileTypeProgress.tsx b/src/components/FormGlobal/FormProgress.tsx similarity index 57% rename from src/components/ProfileType/ProfileTypeProgress.tsx rename to src/components/FormGlobal/FormProgress.tsx index 561c12159101e58157d4685450ad58778bfe77e3..77c7f732f4a02adc8e90678d12215b2e6f32f15a 100644 --- a/src/components/ProfileType/ProfileTypeProgress.tsx +++ b/src/components/FormGlobal/FormProgress.tsx @@ -1,16 +1,21 @@ import React from 'react' -import 'components/ProfileType/profileTypeProgress.scss' +import 'components/FormGlobal/formProgress.scss' import { ProfileTypeStepForm } from 'enum/profileType.enum' +import { SgeStep } from 'enum/sgeStep.enum' -interface ProfileTypeProgressProps { - step: ProfileTypeStepForm +interface FormProgressProps { + step: ProfileTypeStepForm | SgeStep + formType: 'sge' | 'profile' } -const ProfileTypeProgress: React.FC<ProfileTypeProgressProps> = ({ +const FormProgress: React.FC<FormProgressProps> = ({ step, -}: ProfileTypeProgressProps) => { + formType, +}: FormProgressProps) => { const getProgress = () => { - const total: number = Object.values(ProfileTypeStepForm).length / 2 + const total: number = + Object.values(formType === 'sge' ? SgeStep : ProfileTypeStepForm).length / + 2 const progress: number = Math.round((step / total) * 100) return progress } @@ -27,4 +32,4 @@ const ProfileTypeProgress: React.FC<ProfileTypeProgressProps> = ({ ) } -export default ProfileTypeProgress +export default FormProgress diff --git a/src/components/ProfileType/formNavigation.scss b/src/components/FormGlobal/formNavigation.scss similarity index 98% rename from src/components/ProfileType/formNavigation.scss rename to src/components/FormGlobal/formNavigation.scss index b3baeff5f57b2701a689aa1601dd4db2089a1a32..4ed172750c30ded9c551d1966535cc19ea7894c2 100644 --- a/src/components/ProfileType/formNavigation.scss +++ b/src/components/FormGlobal/formNavigation.scss @@ -12,6 +12,7 @@ justify-content: center; align-items: flex-start; padding: 0 0 env(safe-area-inset-bottom) 0; + left: 0; @media (min-width: $width-tablet) { background: $dark-light-2; height: 3rem; diff --git a/src/components/ProfileType/profileTypeProgress.scss b/src/components/FormGlobal/formProgress.scss similarity index 100% rename from src/components/ProfileType/profileTypeProgress.scss rename to src/components/FormGlobal/formProgress.scss diff --git a/src/components/Header/header.scss b/src/components/Header/header.scss index 325ab08bd8fd1171b56dc7dc20bbfb2fef5bb917..4cfbd9ed7448d121cc44202e0a4c239a305a980c 100644 --- a/src/components/Header/header.scss +++ b/src/components/Header/header.scss @@ -17,9 +17,9 @@ } .header-top { background: radial-gradient( - 74.83% 76.97% at 50% 13.64%, - #343641 0%, - #1b1c22 100% + circle, + rgba(52, 54, 65, 1) 0%, + rgba(27, 28, 34, 1) 100% ); width: 100%; .header-text { diff --git a/src/components/Hooks/useKonnectorAuth.tsx b/src/components/Hooks/useKonnectorAuth.tsx new file mode 100644 index 0000000000000000000000000000000000000000..96e568bf0435674cfe3f51c993602f1f270a7adb --- /dev/null +++ b/src/components/Hooks/useKonnectorAuth.tsx @@ -0,0 +1,124 @@ +import { useState, useCallback } from 'react' +import { useDispatch, useSelector } from 'react-redux' +import { Client, useClient } from 'cozy-client' +import { + AccountAuthData, + AccountSgeData, + FluidConnection, + FluidStatus, + UsageEvent, +} from 'models' +import { AppStore } from 'store' +import { UsageEventType } from 'enum/usageEvent.enum' +import AccountService from 'services/account.service' +import UsageEventService from 'services/usageEvent.service' +import { updatedFluidConnection } from 'store/global/global.actions' +import ConnectionService from 'services/connection.service' +import { setLoading } from 'store/chart/chart.actions' +import { useI18n } from 'cozy-ui/transpiled/react/I18n' +import { FluidSlugType } from 'enum/fluidSlug.enum' + +const useKonnectorAuth = ( + fluidStatus: FluidStatus, + login?: string, + password?: string +): [() => Promise<null | undefined>, () => Promise<void>, string] => { + const client: Client = useClient() + const { t } = useI18n() + const dispatch = useDispatch() + const konnectorSlug: FluidSlugType = + fluidStatus.connection.konnectorConfig.slug + const { sgeConnect } = useSelector((state: AppStore) => state.ecolyo.global) + + const [connectError, setError] = useState<string>('') + + const onSuccess = useCallback(async () => { + const updatedConnection: FluidConnection = { + ...fluidStatus.connection, + shouldLaunchKonnector: true, + } + dispatch(updatedFluidConnection(fluidStatus.fluidType, updatedConnection)) + }, [dispatch, fluidStatus.fluidType, fluidStatus.connection]) + + const sendUsageEventError = async (slug: string): Promise<UsageEvent> => { + return UsageEventService.addEvent(client, { + type: UsageEventType.KONNECTOR_CONNECT_EVENT, + target: slug, + result: 'error', + }) + } + + const connect = async () => { + const connectionService = new ConnectionService(client) + try { + // If first connexion, send the usage event + await UsageEventService.addEvent(client, { + type: UsageEventType.KONNECTOR_ATTEMPT_EVENT, + target: konnectorSlug, + result: 'error', + }) + const { account: _account, trigger: _trigger } = + konnectorSlug === FluidSlugType.WATER + ? await connectionService.connectNewUser(konnectorSlug, { + login: login ? login : '', + password: password, + }) + : await connectionService.connectNewUser( + konnectorSlug, + undefined, + sgeConnect + ) + if (!_trigger || !_account) { + setError(t('konnector_form.error_account_creation')) + sendUsageEventError(konnectorSlug) + return null + } + const updatedConnection: FluidConnection = { + ...fluidStatus.connection, + account: _account, + trigger: _trigger, + } + setLoading(false) + dispatch(updatedFluidConnection(fluidStatus.fluidType, updatedConnection)) + onSuccess() + } catch (err) { + setLoading(false) + sendUsageEventError(konnectorSlug) + console.log(err) + } + } + + const update = async () => { + if (fluidStatus.connection.account) { + const _account = fluidStatus.connection.account + let auth: AccountAuthData | AccountSgeData + if (konnectorSlug === FluidSlugType.WATER) { + auth = { + login: login, + password: password, + } as AccountAuthData + } else { + auth = { + pointId: sgeConnect.pdl ? sgeConnect.pdl.toString() : '', + firstname: sgeConnect.firstName, + lastname: sgeConnect.lastName, + address: sgeConnect.address, + postalCode: sgeConnect.zipCode ? sgeConnect.zipCode.toString() : '', + city: sgeConnect.city, + } as AccountSgeData + } + _account.auth = auth + const accountService = new AccountService(client) + const updatedAccount = await accountService.updateAccount(_account) + const updatedConnection: FluidConnection = { + ...fluidStatus.connection, + account: updatedAccount, + } + dispatch(updatedFluidConnection(fluidStatus.fluidType, updatedConnection)) + onSuccess() + } + } + return [connect, update, connectError] +} + +export default useKonnectorAuth diff --git a/src/components/Hooks/userInstanceSettings.tsx b/src/components/Hooks/userInstanceSettings.tsx index 34a0810aa55cc2dbf281c0f8eace00449f9abf10..4abb7bcf1d1d73f9c3f7549628f4cdebb3223f78 100644 --- a/src/components/Hooks/userInstanceSettings.tsx +++ b/src/components/Hooks/userInstanceSettings.tsx @@ -8,7 +8,6 @@ import { UserInstanceSettings, UserInstanceSettingsAttributes } from 'models' const userInstanceSettings = (): UserInstanceSettings => { const client = useClient() const [settings, setSettings] = useState<UserInstanceSettingsAttributes>({ - // eslint-disable-next-line @typescript-eslint/camelcase public_name: '', }) const [fetchStatus, setFetchStatus] = useState<string>('idle') diff --git a/src/components/Konnector/KonnectorModal.spec.tsx b/src/components/Konnector/KonnectorModal.spec.tsx index 5f0308da6a915afe3fb03041c4796d18691791f0..8610edb9ad736b070f86885526ed18f0604d220f 100644 --- a/src/components/Konnector/KonnectorModal.spec.tsx +++ b/src/components/Konnector/KonnectorModal.spec.tsx @@ -9,6 +9,9 @@ import { import KonnectorModal from './KonnectorModal' import { FluidType } from 'enum/fluid.enum' import { Button } from '@material-ui/core' +import toJson from 'enzyme-to-json' +import { KonnectorError } from 'enum/konnectorError.enum' +import { waitForComponentToPaint } from '../../../tests/__mocks__/testUtils' jest.mock('cozy-ui/transpiled/react/I18n', () => { return { @@ -20,11 +23,11 @@ jest.mock('cozy-ui/transpiled/react/I18n', () => { } }) -describe('KonnectroModal component', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any +describe('KonnectorModal component', () => { let store: any beforeEach(() => { store = createMockStore(mockInitialEcolyoState) + jest.clearAllMocks() }) const mockHandleCloseClick = jest.fn() it('should be rendered correctly', () => { @@ -37,10 +40,13 @@ describe('KonnectroModal component', () => { error={null} fluidType={FluidType.ELECTRICITY} handleCloseClick={mockHandleCloseClick} + isLogging={false} + account={null} + handleAccountDeletion={jest.fn()} /> </Provider> - ).getElement() - expect(wrapper).toMatchSnapshot() + ) + expect(toJson(wrapper)).toMatchSnapshot() }) it('should be with updating text', () => { const wrapper = mount( @@ -52,10 +58,13 @@ describe('KonnectroModal component', () => { error={null} fluidType={FluidType.ELECTRICITY} handleCloseClick={mockHandleCloseClick} + isLogging={false} + account={null} + handleAccountDeletion={jest.fn()} /> </Provider> ) - expect(wrapper.find('.kmodal-waiting-text')).toBeTruthy() + expect(wrapper.find('.kmodal-waiting-text').exists()).toBeTruthy() }) it('should be correctly closed', async () => { const wrapper = mount( @@ -67,6 +76,9 @@ describe('KonnectroModal component', () => { error={null} fluidType={FluidType.ELECTRICITY} handleCloseClick={mockHandleCloseClick} + isLogging={false} + account={null} + handleAccountDeletion={jest.fn()} /> </Provider> ) @@ -80,13 +92,16 @@ describe('KonnectroModal component', () => { open={true} isUpdating={false} state={'error'} - error={'LOGIN_FAILED'} + error={KonnectorError.LOGIN_FAILED} fluidType={FluidType.ELECTRICITY} handleCloseClick={mockHandleCloseClick} + isLogging={false} + account={null} + handleAccountDeletion={jest.fn()} /> </Provider> ) - expect(wrapper.find('.kce-picto-txt')).toBeTruthy() + expect(wrapper.find('.kce-picto-txt').exists()).toBeTruthy() }) it('should render unknown error', async () => { const wrapper = mount( @@ -95,12 +110,34 @@ describe('KonnectroModal component', () => { open={true} isUpdating={false} state={'error'} - error={''} + error={null} fluidType={FluidType.ELECTRICITY} handleCloseClick={mockHandleCloseClick} + isLogging={false} + account={null} + handleAccountDeletion={jest.fn()} + /> + </Provider> + ) + expect(wrapper.find('.err-data-2').exists()).toBeTruthy() + }) + it('should render update error', async () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModal + open={true} + isUpdating={true} + state={null} + error={null} + fluidType={FluidType.WATER} + handleCloseClick={mockHandleCloseClick} + isLogging={false} + account={null} + handleAccountDeletion={jest.fn()} /> </Provider> ) - expect(wrapper.find('.err-data-2')).toBeTruthy() + await waitForComponentToPaint(wrapper) + expect(wrapper.find('.waiting-text').exists()).toBeTruthy() }) }) diff --git a/src/components/Konnector/KonnectorModal.tsx b/src/components/Konnector/KonnectorModal.tsx index d2c16a07e84868ec8a7feb89f975b601455de324..7ee3ebb18605d9b363ba94ac7138073d03af244f 100644 --- a/src/components/Konnector/KonnectorModal.tsx +++ b/src/components/Konnector/KonnectorModal.tsx @@ -1,25 +1,26 @@ -import React, { useEffect, useMemo, useState } from 'react' +import React, { useCallback, useEffect, useMemo, useState } from 'react' import './konnectorModal.scss' import classNames from 'classnames' import { useI18n } from 'cozy-ui/transpiled/react/I18n' import Lottie from 'react-lottie' import * as loadingData from 'assets/anims/bounceloading.json' - import { ERROR_EVENT, SUCCESS_EVENT, - LOGIN_SUCCESS_EVENT, } from 'cozy-harvest-lib/dist/models/flowEvents' import { FluidType } from 'enum/fluid.enum' import Icon from 'cozy-ui/transpiled/react/Icon' -import Button from '@material-ui/core/Button' import Dialog from '@material-ui/core/Dialog' import errorIcon from 'assets/icons/visu/data-nok.svg' +import EnedisIcon from 'assets/icons/ico/consent-outdated-enedis.svg' import successIcon from 'assets/icons/visu/data-ok.svg' import connectionWaitingText from 'constants/connectionWaitingText.json' import firstConnectionWaitingText from 'constants/firstConnectionWaitingText.json' import { shuffle } from 'lodash' +import { KonnectorError } from 'enum/konnectorError.enum' +import KonnectorModalFooter from './KonnectorModalFooter' +import { Account } from 'models' const loadingOptions = { loop: true, @@ -33,19 +34,25 @@ const loadingOptions = { interface KonnectorModalProps { open: boolean isUpdating: boolean + isLogging: boolean state: string | null - error: string | null + error: KonnectorError | null fluidType: FluidType handleCloseClick: (isSuccess?: boolean) => void + handleAccountDeletion: () => Promise<void> + account: Account | null } const KonnectorModal: React.FC<KonnectorModalProps> = ({ open, isUpdating, + isLogging, state, error, fluidType, handleCloseClick, + handleAccountDeletion, + account, }: KonnectorModalProps) => { const { t } = useI18n() const fluidName: string = FluidType[fluidType] @@ -61,6 +68,46 @@ const KonnectorModal: React.FC<KonnectorModalProps> = ({ ...shuffledWaitingTexts ) + const getUpdatingText = useCallback((): JSX.Element => { + return ( + <div className="kmodal-waiting-text text-18-italic"> + {shuffledWaitingTexts.map((text, idx) => ( + <div + key={idx} + className={classNames('waiting-text', { + ['show']: idx === index % shuffledWaitingTexts.length, + })} + > + <p>{text.first}</p> + <p>{text.second}</p> + </div> + ))} + </div> + ) + }, [index, shuffledWaitingTexts]) + + const getConnectionText = useCallback((): JSX.Element => { + return ( + <div className="kmodal-waiting-text text-18-italic"> + {isLogging ? ( + <p className="text-18-white">{t('konnector_modal.logging_txt')}</p> + ) : ( + firstConnectionWaitingTexts.map((text, idx) => ( + <div + key={idx} + className={classNames('waiting-text', { + ['show']: idx === index % firstConnectionWaitingTexts.length, + })} + > + <p>{text.first}</p> + <p>{text.second}</p> + </div> + )) + )} + </div> + ) + }, [firstConnectionWaitingTexts, index, isLogging, t]) + useEffect(() => { const interval = setInterval(() => { if (open && !state) { @@ -94,50 +141,25 @@ const KonnectorModal: React.FC<KonnectorModalProps> = ({ {open && !state ? ( <> <Lottie options={loadingOptions} height={50} width={50} speed={2} /> - <div className="kmodal-content-text kmodal-content-text-center text-16-normal"> - <div className="kc-wait text-16-bold"> - {t( - `konnector_modal.loading_data${isUpdating ? '_update' : ''}` - )} - </div> - </div> - {isUpdating ? ( - <div className="kmodal-waiting-text text-18-italic"> - {shuffledWaitingTexts.map((text, idx) => ( - <div - key={idx} - className={classNames('waiting-text', { - ['show']: idx === index % shuffledWaitingTexts.length, - })} - > - <p>{text.first}</p> - <p>{text.second}</p> - </div> - ))} - </div> - ) : ( - <div className="kmodal-waiting-text text-18-italic"> - {firstConnectionWaitingTexts.map((text, idx) => ( - <div - key={idx} - className={classNames('waiting-text', { - ['show']: - idx === index % firstConnectionWaitingTexts.length, - })} - > - <p>{text.first}</p> - <p>{text.second}</p> - </div> - ))} + {!isLogging && ( + <div className="kmodal-content-text kmodal-content-text-center text-16-normal"> + <div className="kc-wait text-16-bold"> + {t( + `konnector_modal.loading_data${isUpdating ? '_update' : ''}` + )} + </div> </div> )} + {isUpdating && getUpdatingText()} + {!isUpdating && getConnectionText()} </> ) : ( <> <div className="kmodal-info"> {state === ERROR_EVENT && ( <> - {error === 'LOGIN_FAILED' ? ( + {error === KonnectorError.LOGIN_FAILED && ( + //LOGIN FAILED FOR ENEDIS AND EGL <div className="konnector-config"> <Icon icon={errorIcon} size={48} /> <div className="kce-picto-txt text-20-bold"> @@ -150,28 +172,76 @@ const KonnectorModal: React.FC<KonnectorModalProps> = ({ }${fluidName.toLowerCase()}` )} </div> + {fluidType === FluidType.ELECTRICITY && !isUpdating && ( + <div className="elec-fail"> + {t( + `konnector_modal.error_credentials_${fluidName.toLowerCase()}_2` + )} + </div> + )} </div> - ) : ( - <div className="konnector-config"> - <Icon icon={errorIcon} size={48} /> - <div className="kce-picto-txt text-20-bold"> - {t('konnector_modal.error_txt')} + )} + {error === KonnectorError.USER_ACTION_NEEDED && + fluidType === FluidType.ELECTRICITY && ( + //INSEE CODE ERROR ENEDIS + <div className="konnector-config"> + <Icon icon={errorIcon} size={48} /> + <div className="kce-picto-txt text-20-bold"> + {t('konnector_modal.error_txt')} + </div> + <div className="text-20-bold"> + {t('konnector_modal.no_insee_code')} + </div> + <br /> + <div>{t(`konnector_modal.no_insee_code_txt`)}</div> </div> - <div> - {t( - `konnector_modal.error_data_${ - isUpdating ? 'update_' : '' - }${fluidName.toLowerCase()}` - )} + )} + {error === KonnectorError.TERMS_VERSION_MISMATCH && + isUpdating && + fluidType === FluidType.ELECTRICITY && ( + //MISMATCH UPDATE ERROR ENEDIS + <div className="kce-picto-txt konnector-config mismatch"> + <Icon icon={EnedisIcon} width={120} height={80} /> + <div className="title text-20-bold"> + {t('konnector_modal.mismatch.title')} + </div> + <div className="text-15-white"> + {t('konnector_modal.mismatch.text1')} + </div> + <div className="text-15-white"> + {t('konnector_modal.mismatch.text2')} + </div> + <div className="info text-15-normal"> + {t('konnector_modal.mismatch.text3')} + </div> </div> - <div className="err-data-2"> - {t('konnector_modal.error_data_2')} + )} + {error !== KonnectorError.USER_ACTION_NEEDED && + error !== KonnectorError.LOGIN_FAILED && + error !== KonnectorError.TERMS_VERSION_MISMATCH && ( + //DEFAULT CASE + <div className="konnector-config"> + {console.log('errortype', error)} + <Icon icon={errorIcon} size={48} /> + <div className="kce-picto-txt text-20-bold"> + {t('konnector_modal.error_txt')} + </div> + <div> + {t( + `konnector_modal.error_data_${ + isUpdating ? 'update_' : '' + }${fluidName.toLowerCase()}` + )} + </div> + <div className="err-data-2"> + {t('konnector_modal.error_data_2')} + </div> </div> - </div> - )} + )} </> )} {state === SUCCESS_EVENT && ( + //SUCCESS CASE <div className="konnector-config"> <Icon icon={successIcon} size={48} /> <div className="kcs-picto-txt text-20-bold"> @@ -184,18 +254,15 @@ const KonnectorModal: React.FC<KonnectorModalProps> = ({ )} </div> )} - {state !== LOGIN_SUCCESS_EVENT && ( - <Button - aria-label={t('konnector_modal.accessibility.button_close')} - onClick={() => handleCloseClick(state === SUCCESS_EVENT)} - classes={{ - root: 'btn-highlight', - label: 'text-16-bold', - }} - > - <div>{t('konnector_modal.button_validate')}</div> - </Button> - )} + <KonnectorModalFooter + state={state} + error={error} + fluidType={fluidType} + handleCloseClick={handleCloseClick} + handleAccountDeletion={handleAccountDeletion} + account={account} + isUpdating={isUpdating} + /> </div> </> )} diff --git a/src/components/Konnector/KonnectorModalFooter.spec.tsx b/src/components/Konnector/KonnectorModalFooter.spec.tsx new file mode 100644 index 0000000000000000000000000000000000000000..53cb597641b9fba6a8500545a73a28420aee7031 --- /dev/null +++ b/src/components/Konnector/KonnectorModalFooter.spec.tsx @@ -0,0 +1,190 @@ +import React from 'react' +import { mount } from 'enzyme' +import { Provider } from 'react-redux' +import { + createMockStore, + mockInitialEcolyoState, +} from '../../../tests/__mocks__/store' +import { ERROR_EVENT } from 'cozy-harvest-lib/dist/models/flowEvents' +import toJson from 'enzyme-to-json' +import KonnectorModalFooter from './KonnectorModalFooter' +import { FluidType } from 'enum/fluid.enum' +import { KonnectorError } from 'enum/konnectorError.enum' +import { Button } from '@material-ui/core' +import { accountsData } from '../../../tests/__mocks__/accountsData.mock' +import { waitForComponentToPaint } from '../../../tests/__mocks__/testUtils' + +jest.mock('cozy-ui/transpiled/react/I18n', () => { + return { + useI18n: jest.fn(() => { + return { + t: (str: string) => str, + } + }), + } +}) +const mockHistoryPush = jest.fn() +jest.mock('react-router-dom', () => ({ + ...jest.requireActual('react-router-dom'), + useHistory: () => ({ + push: mockHistoryPush, + }), +})) +const mockClose = jest.fn() +const mockDelete = jest.fn() +describe('KonnectorModalFooter component', () => { + let store: any + beforeEach(() => { + store = createMockStore(mockInitialEcolyoState) + mockDelete.mockClear() + mockClose.mockClear() + mockHistoryPush.mockClear() + }) + + it('should be rendered correctly', () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={null} + error={null} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={null} + isUpdating={false} + /> + </Provider> + ) + expect(toJson(wrapper)).toMatchSnapshot() + }) + + it('should render "understood" for enedis sge when postal code not supported (USER_ACTION_NEEDED)', () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.USER_ACTION_NEEDED} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={null} + isUpdating={false} + /> + </Provider> + ) + expect(wrapper.find(Button).text()).toBe( + 'konnector_modal.button_understood' + ) + }) + + it('should render "come back later" for enedis sge when address / name / pdl are not matching (LOGIN_FAILED)', () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.LOGIN_FAILED} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={null} + isUpdating={false} + /> + </Provider> + ) + expect(wrapper.find(Button).text()).toBe( + 'konnector_modal.button_come_back_later' + ) + }) + + it('should render "later" and "Verify infos" for enedis sge encountering an error on contract (TERMS_VERSION_MISMATCH)', () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.TERMS_VERSION_MISMATCH} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={null} + isUpdating={false} + /> + </Provider> + ) + expect(wrapper.find(Button).at(0).text()).toBe('Plus tard') + expect(wrapper.find(Button).at(1).text()).toBe('Vérifier les infos') + }) + + it('should close the modal', () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.LOGIN_FAILED} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={null} + isUpdating={false} + /> + </Provider> + ) + wrapper.find(Button).first().simulate('click') + expect(mockClose).toHaveBeenCalled() + }) + it('should go back to login', async () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.TERMS_VERSION_MISMATCH} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={accountsData[0]} + isUpdating={true} + /> + </Provider> + ) + wrapper.find(Button).at(1).simulate('click') + await waitForComponentToPaint(wrapper) + expect(mockDelete).toHaveBeenCalled() + expect(mockHistoryPush).toHaveBeenCalledTimes(1) + }) + it('should reset sge account and go back to login', async () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.TERMS_VERSION_MISMATCH} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={accountsData[0]} + isUpdating={true} + /> + </Provider> + ) + wrapper.find(Button).at(1).simulate('click') + await waitForComponentToPaint(wrapper) + expect(mockDelete).toHaveBeenCalled() + expect(mockHistoryPush).toHaveBeenCalledTimes(1) + }) + it('should not reset account if no account', () => { + const wrapper = mount( + <Provider store={store}> + <KonnectorModalFooter + state={ERROR_EVENT} + error={KonnectorError.TERMS_VERSION_MISMATCH} + fluidType={FluidType.ELECTRICITY} + handleCloseClick={mockClose} + handleAccountDeletion={mockDelete} + account={null} + isUpdating={false} + /> + </Provider> + ) + wrapper.find(Button).at(1).simulate('click') + expect(mockHistoryPush).toHaveBeenCalledTimes(1) + expect(mockDelete).toHaveBeenCalledTimes(0) + }) +}) diff --git a/src/components/Konnector/KonnectorModalFooter.tsx b/src/components/Konnector/KonnectorModalFooter.tsx new file mode 100644 index 0000000000000000000000000000000000000000..799651125281f23d3617295ff5e530b7ff923313 --- /dev/null +++ b/src/components/Konnector/KonnectorModalFooter.tsx @@ -0,0 +1,157 @@ +import React, { useCallback, useState } from 'react' +import { useI18n } from 'cozy-ui/transpiled/react/I18n' +import { + ERROR_EVENT, + SUCCESS_EVENT, +} from 'cozy-harvest-lib/dist/models/flowEvents' +import { FluidType } from 'enum/fluid.enum' +import Button from '@material-ui/core/Button' +import { useHistory } from 'react-router-dom' +import { KonnectorError } from 'enum/konnectorError.enum' +import './konnectorModal.scss' +import AccountService from 'services/account.service' +import { useClient } from 'cozy-client' +import { Account } from 'models' + +interface KonnectorModalFooterProps { + state: string | null + error: KonnectorError | null + fluidType: FluidType + handleCloseClick: (isSuccess?: boolean) => void + handleAccountDeletion: () => Promise<void> + account: Account | null + isUpdating: boolean +} + +const KonnectorModalFooter: React.FC<KonnectorModalFooterProps> = ({ + state, + error, + fluidType, + handleCloseClick, + handleAccountDeletion, + account, + isUpdating, +}: KonnectorModalFooterProps) => { + const { t } = useI18n() + const history = useHistory() + const client = useClient() + const handleSGELoginRetry = useCallback(() => { + handleCloseClick(state === SUCCESS_EVENT) + history.push('/sge-connect') + }, [handleCloseClick, history, state]) + + const handleResetSGEAccount = useCallback(async () => { + if (account) { + const accountService = new AccountService(client) + await accountService.deleteAccount(account) + await handleAccountDeletion() + history.push('/sge-connect') + } + }, [account, client, handleAccountDeletion, history]) + + const errorButtons = () => { + switch (error) { + case KonnectorError.USER_ACTION_NEEDED: + //INSEE CODE ERROR ENEDIS + return ( + <Button + aria-label={t('konnector_modal.accessibility.button_close')} + onClick={() => handleCloseClick(state === SUCCESS_EVENT)} + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + style={{ height: '40px' }} + > + <div>{t('konnector_modal.button_understood')}</div> + </Button> + ) + case KonnectorError.LOGIN_FAILED: + //MISMATCH NAME / ADDRESS / PDL + return ( + <Button + aria-label={t('konnector_modal.accessibility.button_close')} + onClick={() => handleCloseClick(state === SUCCESS_EVENT)} + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + style={{ height: '40px' }} + > + <div>{t('konnector_modal.button_come_back_later')}</div> + </Button> + ) + case KonnectorError.TERMS_VERSION_MISMATCH: + return ( + <div className="buttons"> + <Button + aria-label={t('konnector_modal.accessibility.button_close')} + onClick={() => handleCloseClick(state === SUCCESS_EVENT)} + classes={{ + root: 'btn-secondary-negative', + label: 'text-16-bold', + }} + style={{ height: '40px' }} + > + <div>{'Plus tard'}</div> + </Button> + <Button + aria-label={t('konnector_modal.accessibility.button_close')} + onClick={ + !isUpdating ? handleSGELoginRetry : handleResetSGEAccount + } + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + style={{ height: '40px' }} + > + <div>{!isUpdating ? 'Vérifier les infos' : 'Jy vais'}</div> + </Button> + </div> + ) + default: + //DEFAULT FOOTER BUTTONS + //TODO change default button + return ( + <Button + aria-label={t('konnector_modal.accessibility.button_close')} + onClick={() => handleCloseClick(state === SUCCESS_EVENT)} + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + style={{ height: '40px' }} + > + <div>{t('konnector_modal.button_validate')}</div> + </Button> + ) + } + } + + const successButton = () => { + //DEFAULT FOOTER BUTTONS + return ( + <Button + aria-label={t('konnector_modal.accessibility.button_close')} + onClick={() => handleCloseClick(state === SUCCESS_EVENT)} + classes={{ + root: 'btn-highlight', + label: 'text-16-bold', + }} + > + <div>{t('konnector_modal.button_validate')}</div> + </Button> + ) + } + + return ( + <> + {state === ERROR_EVENT && fluidType === FluidType.ELECTRICITY + ? errorButtons() + : successButton()} + </> + ) +} + +export default KonnectorModalFooter diff --git a/src/components/Konnector/KonnectorViewerCard.tsx b/src/components/Konnector/KonnectorViewerCard.tsx index 470ab679a1ed35d9b47454d8d6d23191bf44b1bf..73b94b5049e94a4a388e09643b18dffdeac96ce1 100644 --- a/src/components/Konnector/KonnectorViewerCard.tsx +++ b/src/components/Konnector/KonnectorViewerCard.tsx @@ -16,6 +16,7 @@ import { FluidStatus, FluidConnection, UsageEvent, + AccountAuthData, } from 'models' import { getAddPicto, getParamPicto } from 'utils/picto' import { setChallengeConsumption } from 'store/challenge/challenge.actions' @@ -57,6 +58,8 @@ import UsageEventService from 'services/usageEvent.service' import { UsageEventType } from 'enum/usageEvent.enum' import PartnersInfoService from 'services/partnersInfo.service' import { PartnersInfo } from 'models/partnersInfo.model' +import { FluidSlugType } from 'enum/fluidSlug.enum' +import { KonnectorError } from 'enum/konnectorError.enum' interface KonnectorViewerCardProps { fluidStatus: FluidStatus @@ -90,9 +93,11 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ const [openModal, setOpenModal] = useState(false) const [isUpdating, setIsUpdating] = useState(false) - const [konnectorErrorDescription, setKonnectorErrorDescription] = useState< - string | null - >(null) + const [isLogging, setIsLogging] = useState( + fluidSlug !== FluidSlugType.GAS ? true : false + ) + const [konnectorErrorDescription, setKonnectorErrorDescription] = + useState<KonnectorError | null>(null) const [konnectorState, setKonnectorState] = useState<string | null>(null) const [updatedFluidStatus, setUpdatedFluidStatus] = useState<FluidStatus[]>( [] @@ -107,7 +112,6 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ [client] ) - /* eslint-disable @typescript-eslint/no-non-null-assertion */ const lastDataDate = fluidType !== FluidType.MULTIFLUID && statusArray[fluidType].lastDataDate ? statusArray[fluidType].lastDataDate!.toLocaleString() + fluidType @@ -131,7 +135,7 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ const refDate: DateTime = DateTime.fromISO('0001-01-01') let _lastDataDate: DateTime | null = DateTime.fromISO('0001-01-01') for (const fluid of _updatedFluidStatus) { - if (fluid?.lastDataDate > _lastDataDate) { + if (fluid && fluid?.lastDataDate && fluid?.lastDataDate > _lastDataDate) { _lastDataDate = fluid.lastDataDate } } @@ -183,20 +187,37 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ const handleConnectionEnd = useCallback( async (isSuccess?: boolean) => { if ( - account && - konnectorErrorDescription === 'LOGIN_FAILED' && - fluidStatus !== null && - fluidStatus.connection.account !== null && - fluidStatus.connection.account.auth !== undefined && - fluidStatus.connection.account.auth.login + //CASE FOR GLOBAL LOGIN FAILED + (account && + !isSuccess && + (konnectorErrorDescription === KonnectorError.LOGIN_FAILED || + konnectorErrorDescription === KonnectorError.UNKNOWN_ERROR || + konnectorErrorDescription == KonnectorError.CRITICAL) && + fluidStatus !== null && + fluidStatus.connection.account !== null && + fluidStatus.connection.account.auth !== undefined) || + //CASE FOR ENEDIS CODE INSEE ERROR + (account && + !isSuccess && + !isUpdating && + fluidType === FluidType.ELECTRICITY && + fluidStatus !== null && + fluidStatus.connection.account !== null && + fluidStatus.connection.account.auth !== undefined) ) { - fluidStatus.connection.konnectorConfig.lastKnownCredentials = - fluidStatus.connection.account.auth.login + //KEEP CREDENTIALS FOR EGL + if (fluidSlug === FluidSlugType.WATER) { + const auth = fluidStatus.connection.account.auth as AccountAuthData + fluidStatus.connection.konnectorConfig.lastKnownCredentials = + auth.login + } + //DELETE ACCOUNT const accountService = new AccountService(client) await accountService.deleteAccount(account) await handleAccountDeletion() } else { if (isSuccess && fluidStatus.lastDataDate === null) { + //UPDATE THE DACC EVENT STATUS TO SUCCESS await UsageEventService.udpateConnectionAttemptEvent( client, fluidSlug @@ -219,16 +240,18 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ }, [ account, - client, - dispatch, - fluidService, - fluidStatus, - handleAccountDeletion, konnectorErrorDescription, - partnersInfoService, + fluidStatus, + isUpdating, + fluidType, setActive, - updatedFluidStatus.length, fluidSlug, + client, + handleAccountDeletion, + updatedFluidStatus.length, + partnersInfoService, + fluidService, + dispatch, ] ) @@ -367,7 +390,6 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ return ( <span className="text-16-bold outdated"> {t('konnector_options.outdated', { - // eslint-disable-next-line @typescript-eslint/camelcase isOutdatedData: isOutdatedData, })} </span> @@ -410,8 +432,8 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ callbackResponse(ERROR_EVENT) }) connectionFlow.jobWatcher.on(LOGIN_SUCCESS_EVENT, () => { + setIsLogging(false) sendUsageEventSuccess(fluidSlug, fluidStatus.lastDataDate === null) - callbackResponse(LOGIN_SUCCESS_EVENT) }) connectionFlow.jobWatcher.on(SUCCESS_EVENT, () => { sendUsageEventSuccess(fluidSlug, fluidStatus.lastDataDate === null) @@ -512,10 +534,13 @@ const KonnectorViewerCard: React.FC<KonnectorViewerCardProps> = ({ <KonnectorModal open={openModal} isUpdating={isUpdating} + isLogging={isLogging} state={konnectorState} error={konnectorErrorDescription} fluidType={fluidStatus.fluidType} handleCloseClick={handleConnectionEnd} + handleAccountDeletion={handleAccountDeletion} + account={account} /> </> ) diff --git a/src/components/Konnector/KonnectorViewerList.spec.tsx b/src/components/Konnector/KonnectorViewerList.spec.tsx index b87e6632f3191d4c3158e0cb5ac0659408ecc138..5e71995a85e25d93277ff8b44bc31b3425f51494 100644 --- a/src/components/Konnector/KonnectorViewerList.spec.tsx +++ b/src/components/Konnector/KonnectorViewerList.spec.tsx @@ -27,7 +27,6 @@ jest.mock('react-router-dom', () => ({ })) describe('KonnectorViewerList component', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any let store: any beforeEach(() => { store = createMockStore(mockInitialEcolyoState) diff --git a/src/components/Konnector/__snapshots__/KonnectorModal.spec.tsx.snap b/src/components/Konnector/__snapshots__/KonnectorModal.spec.tsx.snap index c011bada0e60d4f97ca05b955a146ce9c49bb4d2..e44f9efdc74e909015eabdd95bee8d6d9475e47f 100644 --- a/src/components/Konnector/__snapshots__/KonnectorModal.spec.tsx.snap +++ b/src/components/Konnector/__snapshots__/KonnectorModal.spec.tsx.snap @@ -1,6 +1,6 @@ // Jest Snapshot v1, https://goo.gl/fbAQLP -exports[`KonnectroModal component should be rendered correctly 1`] = ` +exports[`KonnectorModal component should be rendered correctly 1`] = ` <Provider store={ Object { @@ -14,12 +14,5107 @@ exports[`KonnectroModal component should be rendered correctly 1`] = ` } > <KonnectorModal + account={null} error={null} fluidType={0} + handleAccountDeletion={[MockFunction]} handleCloseClick={[MockFunction]} + isLogging={false} isUpdating={false} open={true} state={null} - /> + > + <WithStyles(ForwardRef(Dialog)) + aria-labelledby="accessibility-title" + classes={ + Object { + "paper": "modal-paper", + "root": "modal-root", + } + } + disableEscapeKeyDown={true} + onClose={[Function]} + open={true} + > + <ForwardRef(Dialog) + aria-labelledby="accessibility-title" + classes={ + Object { + "container": "MuiDialog-container", + "paper": "MuiDialog-paper modal-paper", + "paperFullScreen": "MuiDialog-paperFullScreen", + "paperFullWidth": "MuiDialog-paperFullWidth", + "paperScrollBody": "MuiDialog-paperScrollBody", + "paperScrollPaper": "MuiDialog-paperScrollPaper", + "paperWidthFalse": "MuiDialog-paperWidthFalse", + "paperWidthLg": "MuiDialog-paperWidthLg", + "paperWidthMd": "MuiDialog-paperWidthMd", + "paperWidthSm": "MuiDialog-paperWidthSm", + "paperWidthXl": "MuiDialog-paperWidthXl", + "paperWidthXs": "MuiDialog-paperWidthXs", + "root": "MuiDialog-root modal-root", + "scrollBody": "MuiDialog-scrollBody", + "scrollPaper": "MuiDialog-scrollPaper", + } + } + disableEscapeKeyDown={true} + onClose={[Function]} + open={true} + > + <ForwardRef(Modal) + BackdropComponent={ + Object { + "$$typeof": Symbol(react.forward_ref), + "Naked": Object { + "$$typeof": Symbol(react.forward_ref), + "propTypes": Object { + "children": [Function], + "className": [Function], + "classes": [Function], + "invisible": [Function], + "open": [Function], + "transitionDuration": [Function], + }, + "render": [Function], + }, + "displayName": "WithStyles(ForwardRef(Backdrop))", + "options": Object { + "defaultTheme": Object { + "breakpoints": Object { + "between": [Function], + "down": [Function], + "keys": Array [ + "xs", + "sm", + "md", + "lg", + "xl", + ], + "only": [Function], + "up": [Function], + "values": Object { + "lg": 1280, + "md": 960, + "sm": 600, + "xl": 1920, + "xs": 0, + }, + "width": [Function], + }, + "direction": "ltr", + "mixins": Object { + "gutters": [Function], + "toolbar": Object { + "@media (min-width:0px) and (orientation: landscape)": Object { + "minHeight": 48, + }, + "@media (min-width:600px)": Object { + "minHeight": 64, + }, + "minHeight": 56, + }, + }, + "overrides": Object {}, + "palette": Object { + "action": Object { + "activatedOpacity": 0.12, + "active": "rgba(0, 0, 0, 0.54)", + "disabled": "rgba(0, 0, 0, 0.26)", + "disabledBackground": "rgba(0, 0, 0, 0.12)", + "disabledOpacity": 0.38, + "focus": "rgba(0, 0, 0, 0.12)", + "focusOpacity": 0.12, + "hover": "rgba(0, 0, 0, 0.04)", + "hoverOpacity": 0.04, + "selected": "rgba(0, 0, 0, 0.08)", + "selectedOpacity": 0.08, + }, + "augmentColor": [Function], + "background": Object { + "default": "#fafafa", + "paper": "#fff", + }, + "common": Object { + "black": "#000", + "white": "#fff", + }, + "contrastThreshold": 3, + "divider": "rgba(0, 0, 0, 0.12)", + "error": Object { + "contrastText": "#fff", + "dark": "#d32f2f", + "light": "#e57373", + "main": "#f44336", + }, + "getContrastText": [Function], + "grey": Object { + "100": "#f5f5f5", + "200": "#eeeeee", + "300": "#e0e0e0", + "400": "#bdbdbd", + "50": "#fafafa", + "500": "#9e9e9e", + "600": "#757575", + "700": "#616161", + "800": "#424242", + "900": "#212121", + "A100": "#d5d5d5", + "A200": "#aaaaaa", + "A400": "#303030", + "A700": "#616161", + }, + "info": Object { + "contrastText": "#fff", + "dark": "#1976d2", + "light": "#64b5f6", + "main": "#2196f3", + }, + "primary": Object { + "contrastText": "#fff", + "dark": "#303f9f", + "light": "#7986cb", + "main": "#3f51b5", + }, + "secondary": Object { + "contrastText": "#fff", + "dark": "#c51162", + "light": "#ff4081", + "main": "#f50057", + }, + "success": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#388e3c", + "light": "#81c784", + "main": "#4caf50", + }, + "text": Object { + "disabled": "rgba(0, 0, 0, 0.38)", + "hint": "rgba(0, 0, 0, 0.38)", + "primary": "rgba(0, 0, 0, 0.87)", + "secondary": "rgba(0, 0, 0, 0.54)", + }, + "tonalOffset": 0.2, + "type": "light", + "warning": Object { + "contrastText": "rgba(0, 0, 0, 0.87)", + "dark": "#f57c00", + "light": "#ffb74d", + "main": "#ff9800", + }, + }, + "props": Object {}, + "shadows": Array [ + "none", + "0px 2px 1px -1px rgba(0,0,0,0.2),0px 1px 1px 0px rgba(0,0,0,0.14),0px 1px 3px 0px rgba(0,0,0,0.12)", + "0px 3px 1px -2px rgba(0,0,0,0.2),0px 2px 2px 0px rgba(0,0,0,0.14),0px 1px 5px 0px rgba(0,0,0,0.12)", + "0px 3px 3px -2px rgba(0,0,0,0.2),0px 3px 4px 0px rgba(0,0,0,0.14),0px 1px 8px 0px rgba(0,0,0,0.12)", + "0px 2px 4px -1px rgba(0,0,0,0.2),0px 4px 5px 0px rgba(0,0,0,0.14),0px 1px 10px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 5px 8px 0px rgba(0,0,0,0.14),0px 1px 14px 0px rgba(0,0,0,0.12)", + "0px 3px 5px -1px rgba(0,0,0,0.2),0px 6px 10px 0px rgba(0,0,0,0.14),0px 1px 18px 0px rgba(0,0,0,0.12)", + "0px 4px 5px -2px rgba(0,0,0,0.2),0px 7px 10px 1px rgba(0,0,0,0.14),0px 2px 16px 1px rgba(0,0,0,0.12)", + "0px 5px 5px -3px rgba(0,0,0,0.2),0px 8px 10px 1px rgba(0,0,0,0.14),0px 3px 14px 2px rgba(0,0,0,0.12)", + "0px 5px 6px -3px rgba(0,0,0,0.2),0px 9px 12px 1px rgba(0,0,0,0.14),0px 3px 16px 2px rgba(0,0,0,0.12)", + "0px 6px 6px -3px rgba(0,0,0,0.2),0px 10px 14px 1px rgba(0,0,0,0.14),0px 4px 18px 3px rgba(0,0,0,0.12)", + "0px 6px 7px -4px rgba(0,0,0,0.2),0px 11px 15px 1px rgba(0,0,0,0.14),0px 4px 20px 3px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 12px 17px 2px rgba(0,0,0,0.14),0px 5px 22px 4px rgba(0,0,0,0.12)", + "0px 7px 8px -4px rgba(0,0,0,0.2),0px 13px 19px 2px rgba(0,0,0,0.14),0px 5px 24px 4px rgba(0,0,0,0.12)", + "0px 7px 9px -4px rgba(0,0,0,0.2),0px 14px 21px 2px rgba(0,0,0,0.14),0px 5px 26px 4px rgba(0,0,0,0.12)", + "0px 8px 9px -5px rgba(0,0,0,0.2),0px 15px 22px 2px rgba(0,0,0,0.14),0px 6px 28px 5px rgba(0,0,0,0.12)", + "0px 8px 10px -5px rgba(0,0,0,0.2),0px 16px 24px 2px rgba(0,0,0,0.14),0px 6px 30px 5px rgba(0,0,0,0.12)", + "0px 8px 11px -5px rgba(0,0,0,0.2),0px 17px 26px 2px rgba(0,0,0,0.14),0px 6px 32px 5px rgba(0,0,0,0.12)", + "0px 9px 11px -5px rgba(0,0,0,0.2),0px 18px 28px 2px rgba(0,0,0,0.14),0px 7px 34px 6px rgba(0,0,0,0.12)", + "0px 9px 12px -6px rgba(0,0,0,0.2),0px 19px 29px 2px rgba(0,0,0,0.14),0px 7px 36px 6px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 20px 31px 3px rgba(0,0,0,0.14),0px 8px 38px 7px rgba(0,0,0,0.12)", + "0px 10px 13px -6px rgba(0,0,0,0.2),0px 21px 33px 3px rgba(0,0,0,0.14),0px 8px 40px 7px rgba(0,0,0,0.12)", + "0px 10px 14px -6px rgba(0,0,0,0.2),0px 22px 35px 3px rgba(0,0,0,0.14),0px 8px 42px 7px rgba(0,0,0,0.12)", + "0px 11px 14px -7px rgba(0,0,0,0.2),0px 23px 36px 3px rgba(0,0,0,0.14),0px 9px 44px 8px rgba(0,0,0,0.12)", + "0px 11px 15px -7px rgba(0,0,0,0.2),0px 24px 38px 3px rgba(0,0,0,0.14),0px 9px 46px 8px rgba(0,0,0,0.12)", + ], + "shape": Object { + "borderRadius": 4, + }, + "spacing": [Function], + "transitions": Object { + "create": [Function], + "duration": Object { + "complex": 375, + "enteringScreen": 225, + "leavingScreen": 195, + "short": 250, + "shorter": 200, + "shortest": 150, + "standard": 300, + }, + "easing": Object { + "easeIn": "cubic-bezier(0.4, 0, 1, 1)", + "easeInOut": "cubic-bezier(0.4, 0, 0.2, 1)", + "easeOut": "cubic-bezier(0.0, 0, 0.2, 1)", + "sharp": "cubic-bezier(0.4, 0, 0.6, 1)", + }, + "getAutoHeightDuration": [Function], + }, + "typography": Object { + "body1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.5, + }, + "body2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 400, + "letterSpacing": "0.01071em", + "lineHeight": 1.43, + }, + "button": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.02857em", + "lineHeight": 1.75, + "textTransform": "uppercase", + }, + "caption": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.03333em", + "lineHeight": 1.66, + }, + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": 14, + "fontWeightBold": 700, + "fontWeightLight": 300, + "fontWeightMedium": 500, + "fontWeightRegular": 400, + "h1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "6rem", + "fontWeight": 300, + "letterSpacing": "-0.01562em", + "lineHeight": 1.167, + }, + "h2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3.75rem", + "fontWeight": 300, + "letterSpacing": "-0.00833em", + "lineHeight": 1.2, + }, + "h3": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "3rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.167, + }, + "h4": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "2.125rem", + "fontWeight": 400, + "letterSpacing": "0.00735em", + "lineHeight": 1.235, + }, + "h5": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.5rem", + "fontWeight": 400, + "letterSpacing": "0em", + "lineHeight": 1.334, + }, + "h6": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1.25rem", + "fontWeight": 500, + "letterSpacing": "0.0075em", + "lineHeight": 1.6, + }, + "htmlFontSize": 16, + "overline": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.75rem", + "fontWeight": 400, + "letterSpacing": "0.08333em", + "lineHeight": 2.66, + "textTransform": "uppercase", + }, + "pxToRem": [Function], + "round": [Function], + "subtitle1": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "1rem", + "fontWeight": 400, + "letterSpacing": "0.00938em", + "lineHeight": 1.75, + }, + "subtitle2": Object { + "fontFamily": "\\"Roboto\\", \\"Helvetica\\", \\"Arial\\", sans-serif", + "fontSize": "0.875rem", + "fontWeight": 500, + "letterSpacing": "0.00714em", + "lineHeight": 1.57, + }, + }, + "zIndex": Object { + "appBar": 1100, + "drawer": 1200, + "mobileStepper": 1000, + "modal": 1300, + "snackbar": 1400, + "speedDial": 1050, + "tooltip": 1500, + }, + }, + "name": "MuiBackdrop", + }, + "propTypes": Object { + "classes": [Function], + "innerRef": [Function], + }, + "render": [Function], + "useStyles": [Function], + } + } + BackdropProps={ + Object { + "transitionDuration": Object { + "enter": 225, + "exit": 195, + }, + } + } + className="MuiDialog-root modal-root" + closeAfterTransition={true} + disableEscapeKeyDown={true} + onClose={[Function]} + open={true} + > + <ForwardRef(Portal) + disablePortal={false} + > + <Portal + containerInfo={ + <body + style="padding-right: 0px; overflow: hidden;" + > + <div + class="MuiDialog-root modal-root" + role="presentation" + style="position: fixed; z-index: 1300; right: 0px; bottom: 0px; top: 0px; left: 0px;" + > + <div + aria-hidden="true" + class="MuiBackdrop-root" + style="opacity: 1; webkit-transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;" + /> + <div + data-test="sentinelStart" + tabindex="0" + /> + <div + class="MuiDialog-container MuiDialog-scrollPaper" + role="none presentation" + style="opacity: 1; webkit-transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms; transition: opacity 225ms cubic-bezier(0.4, 0, 0.2, 1) 0ms;" + tabindex="-1" + > + <div + aria-labelledby="accessibility-title" + class="MuiPaper-root MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm MuiPaper-elevation24 MuiPaper-rounded" + role="dialog" + > + <div + id="accessibility-title" + > + konnector_modal.accessibility.window_title + </div> + <div + class="kmodal-content" + > + <div + aria-label="animation" + role="button" + style="width: 50px; height: 50px; overflow: hidden; margin: 0px auto; outline: none;" + tabindex="0" + title="" + > + <svg + height="128" + preserveAspectRatio="xMidYMid slice" + style="width: 100%; height: 100%; transform: translate3d(0,0,0);" + viewBox="0 0 128 128" + width="128" + xmlns="http://www.w3.org/2000/svg" + > + <defs> + <clippath + id="__lottie_element_2" + > + <rect + height="128" + width="128" + x="0" + y="0" + /> + </clippath> + </defs> + <g + clip-path="url(#__lottie_element_2)" + > + <g + opacity="1" + style="display: block;" + transform="matrix(1,0,0,1,22.5,64)" + > + <path + d=" M10,29.25 C10,29.25 10,45 10,45 C10,47.76100158691406 7.761000156402588,50 5,50 C5,50 -5,50 -5,50 C-7.761000156402588,50 -10,47.76100158691406 -10,45 C-10,45 -10,29.25 -10,29.25 C-10,26.48900032043457 -7.761000156402588,24.25 -5,24.25 C-5,24.25 5,24.25 5,24.25 C7.761000156402588,24.25 10,26.48900032043457 10,29.25z" + fill="rgb(227,184,42)" + fill-opacity="1" + /> + </g> + <g + opacity="1" + style="display: block;" + transform="matrix(1,0,0,1,62.5,64)" + > + <path + d=" M10,-33 C10,-33 10,45 10,45 C10,47.76100158691406 7.761000156402588,50 5,50 C5,50 -5,50 -5,50 C-7.761000156402588,50 -10,47.76100158691406 -10,45 C-10,45 -10,-33 -10,-33 C-10,-35.76100158691406 -7.761000156402588,-38 -5,-38 C-5,-38 5,-38 5,-38 C7.761000156402588,-38 10,-35.76100158691406 10,-33z" + fill="rgb(227,184,42)" + fill-opacity="1" + /> + </g> + <g + opacity="1" + style="display: block;" + transform="matrix(1,0,0,1,102.5,64)" + > + <path + d=" M10,-8.75 C10,-8.75 10,45 10,45 C10,47.76100158691406 7.761000156402588,50 5,50 C5,50 -5,50 -5,50 C-7.761000156402588,50 -10,47.76100158691406 -10,45 C-10,45 -10,-8.75 -10,-8.75 C-10,-11.51099967956543 -7.761000156402588,-13.75 -5,-13.75 C-5,-13.75 5,-13.75 5,-13.75 C7.761000156402588,-13.75 10,-11.51099967956543 10,-8.75z" + fill="rgb(227,184,42)" + fill-opacity="1" + /> + </g> + </g> + </svg> + </div> + <div + class="kmodal-content-text kmodal-content-text-center text-16-normal" + > + <div + class="kc-wait text-16-bold" + > + konnector_modal.loading_data + </div> + </div> + <div + class="kmodal-waiting-text text-18-italic" + > + <div + class="waiting-text show" + > + <p> + La première fois cela peut prendre quelques minutes, par la suite, seulement quelques secondes. + </p> + <p /> + </div> + <div + class="waiting-text" + > + <p> + Afin de limiter le temps de ce premier chargement, un historique réduit de vos consommations va être chargé. Vous aurez tout de même accès à un an d'historique dès à présent. + </p> + <p /> + </div> + <div + class="waiting-text" + > + <p> + Demain matin, vous aurez accès à l'ensemble de vos données (jusqu'à trois ans d'historique). + </p> + <p /> + </div> + <div + class="waiting-text" + > + <p> + Le saviez-vous ? + </p> + <p> + Pour acheminer l’eau sur Lyon (Lugdunum !) l’acqueduc de Gier faisait 86 km à l’époque Romaine ! + </p> + </div> + <div + class="waiting-text" + > + <p> + Rien que de l’eau, de l’eau de pluie, de l’eau de la Métroooooo + </p> + <p> + ♪♪ + </p> + </div> + <div + class="waiting-text" + > + <p> + Le saviez-vous ? + </p> + <p> + Environ 90% de notre électricité provient de centrales de production hors de notre métropole. + </p> + </div> + <div + class="waiting-text" + > + <p> + « Il y a de l’eau dans le gaz » … + </p> + <p> + Avec Ecolyo c’est l’eau AVEC le gaz. + </p> + </div> + <div + class="waiting-text" + > + <p> + Le saviez-vous ? + </p> + <p> + La consommation énergétique résidentielle représente environ 30% de la consommation énergétique totale de notre territoire. + </p> + </div> + <div + class="waiting-text" + > + <p> + Le saviez-vous ? + </p> + <p> + La Métropole de Lyon a été territoire d’expérimentation Linky. Le compteur est présent sur notre territoire depuis plus de 10 ans ! + </p> + </div> + <div + class="waiting-text" + > + <p> + Le saviez-vous ? + </p> + <p> + 10 minutes d'aération par jour permettent à notre habitat d’être plus sain, avec un air renouvelé, moins de polluants et l’évacuation de l’humidité qui stagne et qui nous oblige à consommer plus de chauffage. + </p> + </div> + <div + class="waiting-text" + > + <p> + Le saviez-vous ? + </p> + <p> + 2°C ! C’est la différence qu’on peut mesurer dans une rue bien arborée en comparaison d’une rue vide : la végétation est donc cruciale pour le bien être en ville l’été et pour limiter l’installation des climatiseurs. + </p> + </div> + <div + class="waiting-text" + > + <p> + Il y a les bonnes pratiques de consommations énergétiques (et Ecolyo est là pour cela !) mais aussi et bien sûr, la rénovation. + </p> + <p> + Le saviez-vous ? La loi énergie climat de 2019 impose que d’ici 2025, les bâtiments privés résidentiels les plus énergivores soient tous rénovés ! + </p> + </div> + </div> + </div> + </div> + </div> + <div + data-test="sentinelEnd" + tabindex="0" + /> + </div> + </body> + } + > + <div + className="MuiDialog-root modal-root" + onKeyDown={[Function]} + role="presentation" + style={ + Object { + "bottom": 0, + "left": 0, + "position": "fixed", + "right": 0, + "top": 0, + "zIndex": 1300, + } + } + > + <WithStyles(ForwardRef(Backdrop)) + onClick={[Function]} + open={true} + transitionDuration={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <ForwardRef(Backdrop) + classes={ + Object { + "invisible": "MuiBackdrop-invisible", + "root": "MuiBackdrop-root", + } + } + onClick={[Function]} + open={true} + transitionDuration={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <ForwardRef(Fade) + in={true} + onClick={[Function]} + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <Transition + appear={true} + enter={true} + exit={true} + in={true} + mountOnEnter={false} + onClick={[Function]} + onEnter={[Function]} + onEntered={[Function]} + onEntering={[Function]} + onExit={[Function]} + onExited={[Function]} + onExiting={[Function]} + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + unmountOnExit={false} + > + <div + aria-hidden={true} + className="MuiBackdrop-root" + onClick={[Function]} + style={ + Object { + "opacity": 1, + "visibility": undefined, + } + } + /> + </Transition> + </ForwardRef(Fade)> + </ForwardRef(Backdrop)> + </WithStyles(ForwardRef(Backdrop))> + <Unstable_TrapFocus + disableAutoFocus={false} + disableEnforceFocus={false} + disableRestoreFocus={false} + getDoc={[Function]} + isEnabled={[Function]} + open={true} + > + <div + data-test="sentinelStart" + tabIndex={0} + /> + <ForwardRef(Fade) + appear={true} + in={true} + onEnter={[Function]} + onExited={[Function]} + role="none presentation" + tabIndex="-1" + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + > + <Transition + appear={true} + enter={true} + exit={true} + in={true} + mountOnEnter={false} + onEnter={[Function]} + onEntered={[Function]} + onEntering={[Function]} + onExit={[Function]} + onExited={[Function]} + onExiting={[Function]} + role="none presentation" + tabIndex="-1" + timeout={ + Object { + "enter": 225, + "exit": 195, + } + } + unmountOnExit={false} + > + <div + className="MuiDialog-container MuiDialog-scrollPaper" + onMouseDown={[Function]} + onMouseUp={[Function]} + role="none presentation" + style={ + Object { + "opacity": 1, + "visibility": undefined, + } + } + tabIndex="-1" + > + <WithStyles(ForwardRef(Paper)) + aria-labelledby="accessibility-title" + className="MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm" + elevation={24} + role="dialog" + > + <ForwardRef(Paper) + aria-labelledby="accessibility-title" + className="MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm" + classes={ + Object { + "elevation0": "MuiPaper-elevation0", + "elevation1": "MuiPaper-elevation1", + "elevation10": "MuiPaper-elevation10", + "elevation11": "MuiPaper-elevation11", + "elevation12": "MuiPaper-elevation12", + "elevation13": "MuiPaper-elevation13", + "elevation14": "MuiPaper-elevation14", + "elevation15": "MuiPaper-elevation15", + "elevation16": "MuiPaper-elevation16", + "elevation17": "MuiPaper-elevation17", + "elevation18": "MuiPaper-elevation18", + "elevation19": "MuiPaper-elevation19", + "elevation2": "MuiPaper-elevation2", + "elevation20": "MuiPaper-elevation20", + "elevation21": "MuiPaper-elevation21", + "elevation22": "MuiPaper-elevation22", + "elevation23": "MuiPaper-elevation23", + "elevation24": "MuiPaper-elevation24", + "elevation3": "MuiPaper-elevation3", + "elevation4": "MuiPaper-elevation4", + "elevation5": "MuiPaper-elevation5", + "elevation6": "MuiPaper-elevation6", + "elevation7": "MuiPaper-elevation7", + "elevation8": "MuiPaper-elevation8", + "elevation9": "MuiPaper-elevation9", + "outlined": "MuiPaper-outlined", + "root": "MuiPaper-root", + "rounded": "MuiPaper-rounded", + } + } + elevation={24} + role="dialog" + > + <div + aria-labelledby="accessibility-title" + className="MuiPaper-root MuiDialog-paper modal-paper MuiDialog-paperScrollPaper MuiDialog-paperWidthSm MuiPaper-elevation24 MuiPaper-rounded" + role="dialog" + > + <div + id="accessibility-title" + > + konnector_modal.accessibility.window_title + </div> + <div + className="kmodal-content" + > + <Lottie + ariaLabel="animation" + ariaRole="button" + eventListeners={Array []} + height={50} + isClickToPauseDisabled={false} + isPaused={false} + isStopped={false} + options={ + Object { + "animationData": Object { + "__complete": true, + "assets": Array [], + "ddd": 0, + "default": Object { + "assets": Array [], + "ddd": 0, + "fr": 30, + "h": 128, + "ip": 0, + "layers": Array [ + Object { + "ao": 0, + "bm": 0, + "completed": true, + "ddd": 0, + "ind": 1, + "ip": 0, + "ks": Object { + "a": Object { + "a": 0, + "ix": 1, + "k": Array [ + 0, + 50, + 0, + ], + }, + "o": Object { + "a": 0, + "ix": 11, + "k": 100, + }, + "p": Object { + "a": 0, + "ix": 2, + "k": Array [ + 102.5, + 114, + 0, + ], + }, + "r": Object { + "a": 0, + "ix": 10, + "k": 0, + }, + "s": Object { + "a": 0, + "ix": 6, + "k": Array [ + 100, + 100, + 100, + ], + }, + }, + "nm": "Shape Layer 2", + "op": 61, + "shapes": Array [ + Object { + "_render": true, + "hd": false, + "ind": 0, + "ix": 1, + "ks": Object { + "a": 1, + "ix": 2, + "k": Array [ + Object { + "i": Object { + "x": 0.665, + "y": 1, + }, + "o": Object { + "x": 0.088, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -11.511, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -8.75, + ], + Array [ + -7.761, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + "o": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -11.511, + ], + Array [ + -5, + -13.75, + ], + Array [ + 7.761, + -13.75, + ], + ], + "v": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -8.75, + ], + Array [ + -5, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + }, + ], + "t": 0, + }, + Object { + "i": Object { + "x": 0.888, + "y": 0.992, + }, + "o": Object { + "x": 0.315, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -32.261, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -29.5, + ], + Array [ + -7.761, + -34.5, + ], + Array [ + 5, + -34.5, + ], + ], + "o": Array [ + Array [ + 10, + -29.5, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -32.261, + ], + Array [ + -5, + -34.5, + ], + Array [ + 7.761, + -34.5, + ], + ], + "v": Array [ + Array [ + 10, + -29.5, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -29.5, + ], + Array [ + -5, + -34.5, + ], + Array [ + 5, + -34.5, + ], + ], + }, + ], + "t": 15, + }, + Object { + "i": Object { + "x": 0.777, + "y": 1, + }, + "o": Object { + "x": 0.117, + "y": 0.013, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -11.511, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -8.75, + ], + Array [ + -7.761, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + "o": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -11.511, + ], + Array [ + -5, + -13.75, + ], + Array [ + 7.761, + -13.75, + ], + ], + "v": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -8.75, + ], + Array [ + -5, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + }, + ], + "t": 30, + }, + Object { + "i": Object { + "x": 0.853, + "y": 1, + }, + "o": Object { + "x": 0.098, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 15.989, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 18.75, + ], + Array [ + -7.761, + 13.75, + ], + Array [ + 5, + 13.75, + ], + ], + "o": Array [ + Array [ + 10, + 18.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 15.989, + ], + Array [ + -5, + 13.75, + ], + Array [ + 7.761, + 13.75, + ], + ], + "v": Array [ + Array [ + 10, + 18.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 18.75, + ], + Array [ + -5, + 13.75, + ], + Array [ + 5, + 13.75, + ], + ], + }, + ], + "t": 46, + }, + Object { + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -11.511, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -8.75, + ], + Array [ + -7.761, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + "o": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -11.511, + ], + Array [ + -5, + -13.75, + ], + Array [ + 7.761, + -13.75, + ], + ], + "v": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -8.75, + ], + Array [ + -5, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + }, + ], + "t": 60, + }, + ], + }, + "mn": "ADBE Vector Shape - Group", + "nm": "Path 1", + "ty": "sh", + }, + Object { + "_render": true, + "bm": 0, + "c": Object { + "a": 0, + "ix": 4, + "k": Array [ + 0.8901960784313725, + 0.7215686274509804, + 0.16470588235294117, + 1, + ], + }, + "hd": false, + "mn": "ADBE Vector Graphic - Fill", + "nm": "Fill 1", + "o": Object { + "a": 0, + "ix": 5, + "k": 100, + }, + "r": 1, + "ty": "fl", + }, + ], + "sr": 1, + "st": 0, + "ty": 4, + }, + Object { + "ao": 0, + "bm": 0, + "completed": true, + "ddd": 0, + "ind": 2, + "ip": 0, + "ks": Object { + "a": Object { + "a": 0, + "ix": 1, + "k": Array [ + 0, + 50, + 0, + ], + }, + "o": Object { + "a": 0, + "ix": 11, + "k": 100, + }, + "p": Object { + "a": 0, + "ix": 2, + "k": Array [ + 62.5, + 114, + 0, + ], + }, + "r": Object { + "a": 0, + "ix": 10, + "k": 0, + }, + "s": Object { + "a": 0, + "ix": 6, + "k": Array [ + 100, + 100, + 100, + ], + }, + }, + "nm": "Shape Layer 3", + "op": 61, + "shapes": Array [ + Object { + "_render": true, + "hd": false, + "ind": 0, + "ix": 1, + "ks": Object { + "a": 1, + "ix": 2, + "k": Array [ + Object { + "i": Object { + "x": 0.631, + "y": 1, + }, + "o": Object { + "x": 0.167, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -35.761, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -33, + ], + Array [ + -7.761, + -38, + ], + Array [ + 5, + -38, + ], + ], + "o": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -35.761, + ], + Array [ + -5, + -38, + ], + Array [ + 7.761, + -38, + ], + ], + "v": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -33, + ], + Array [ + -5, + -38, + ], + Array [ + 5, + -38, + ], + ], + }, + ], + "t": 0, + }, + Object { + "i": Object { + "x": 0.667, + "y": 1, + }, + "o": Object { + "x": 0.391, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 1.2389999999999999, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 4, + ], + Array [ + -7.761, + -1, + ], + Array [ + 5, + -1, + ], + ], + "o": Array [ + Array [ + 10, + 4, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 1.2389999999999999, + ], + Array [ + -5, + -1, + ], + Array [ + 7.761, + -1, + ], + ], + "v": Array [ + Array [ + 10, + 4, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 4, + ], + Array [ + -5, + -1, + ], + Array [ + 5, + -1, + ], + ], + }, + ], + "t": 13.846, + }, + Object { + "i": Object { + "x": 0.88, + "y": 1, + }, + "o": Object { + "x": 0.093, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -35.761, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -33, + ], + Array [ + -7.761, + -38, + ], + Array [ + 5, + -38, + ], + ], + "o": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -35.761, + ], + Array [ + -5, + -38, + ], + Array [ + 7.761, + -38, + ], + ], + "v": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -33, + ], + Array [ + -5, + -38, + ], + Array [ + 5, + -38, + ], + ], + }, + ], + "t": 27, + }, + Object { + "i": Object { + "x": 0.873, + "y": 1, + }, + "o": Object { + "x": 0.165, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 9.114, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 11.875, + ], + Array [ + -7.761, + 6.875, + ], + Array [ + 5, + 6.875, + ], + ], + "o": Array [ + Array [ + 10, + 11.875, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 9.114, + ], + Array [ + -5, + 6.875, + ], + Array [ + 7.761, + 6.875, + ], + ], + "v": Array [ + Array [ + 10, + 11.875, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 11.875, + ], + Array [ + -5, + 6.875, + ], + Array [ + 5, + 6.875, + ], + ], + }, + ], + "t": 45, + }, + Object { + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -35.761, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -33, + ], + Array [ + -7.761, + -38, + ], + Array [ + 5, + -38, + ], + ], + "o": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -35.761, + ], + Array [ + -5, + -38, + ], + Array [ + 7.761, + -38, + ], + ], + "v": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -33, + ], + Array [ + -5, + -38, + ], + Array [ + 5, + -38, + ], + ], + }, + ], + "t": 60, + }, + ], + }, + "mn": "ADBE Vector Shape - Group", + "nm": "Path 1", + "ty": "sh", + }, + Object { + "_render": true, + "bm": 0, + "c": Object { + "a": 0, + "ix": 4, + "k": Array [ + 0.8901960784313725, + 0.7215686274509804, + 0.16470588235294117, + 1, + ], + }, + "hd": false, + "mn": "ADBE Vector Graphic - Fill", + "nm": "Fill 1", + "o": Object { + "a": 0, + "ix": 5, + "k": 100, + }, + "r": 1, + "ty": "fl", + }, + ], + "sr": 1, + "st": 0, + "ty": 4, + }, + Object { + "ao": 0, + "bm": 0, + "completed": true, + "ddd": 0, + "ind": 3, + "ip": 0, + "ks": Object { + "a": Object { + "a": 0, + "ix": 1, + "k": Array [ + 0, + 50, + 0, + ], + }, + "o": Object { + "a": 0, + "ix": 11, + "k": 100, + }, + "p": Object { + "a": 0, + "ix": 2, + "k": Array [ + 22.5, + 114, + 0, + ], + }, + "r": Object { + "a": 0, + "ix": 10, + "k": 0, + }, + "s": Object { + "a": 0, + "ix": 6, + "k": Array [ + 100, + 100, + 100, + ], + }, + }, + "nm": "Shape Layer 4", + "op": 61, + "shapes": Array [ + Object { + "_render": true, + "hd": false, + "ind": 0, + "ix": 1, + "ks": Object { + "a": 1, + "ix": 2, + "k": Array [ + Object { + "i": Object { + "x": 0.562, + "y": 1, + }, + "o": Object { + "x": 0.46, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 26.489, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 29.25, + ], + Array [ + -7.761, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + "o": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 26.489, + ], + Array [ + -5, + 24.25, + ], + Array [ + 7.761, + 24.25, + ], + ], + "v": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 29.25, + ], + Array [ + -5, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + }, + ], + "t": 0, + }, + Object { + "i": Object { + "x": 0.505, + "y": 1, + }, + "o": Object { + "x": 0.402, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 10.239, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 13, + ], + Array [ + -7.761, + 8, + ], + Array [ + 5, + 8, + ], + ], + "o": Array [ + Array [ + 10, + 13, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 10.239, + ], + Array [ + -5, + 8, + ], + Array [ + 7.761, + 8, + ], + ], + "v": Array [ + Array [ + 10, + 13, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 13, + ], + Array [ + -5, + 8, + ], + Array [ + 5, + 8, + ], + ], + }, + ], + "t": 15, + }, + Object { + "i": Object { + "x": 0.407, + "y": 1, + }, + "o": Object { + "x": 0.167, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 26.489, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 29.25, + ], + Array [ + -7.761, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + "o": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 26.489, + ], + Array [ + -5, + 24.25, + ], + Array [ + 7.761, + 24.25, + ], + ], + "v": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 29.25, + ], + Array [ + -5, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + }, + ], + "t": 32, + }, + Object { + "i": Object { + "x": 0.599, + "y": 1, + }, + "o": Object { + "x": 0.526, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 0.23899999999999988, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 3, + ], + Array [ + -7.761, + -2, + ], + Array [ + 5, + -2, + ], + ], + "o": Array [ + Array [ + 10, + 3, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 0.23899999999999988, + ], + Array [ + -5, + -2, + ], + Array [ + 7.761, + -2, + ], + ], + "v": Array [ + Array [ + 10, + 3, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 3, + ], + Array [ + -5, + -2, + ], + Array [ + 5, + -2, + ], + ], + }, + ], + "t": 47, + }, + Object { + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 26.489, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 29.25, + ], + Array [ + -7.761, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + "o": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 26.489, + ], + Array [ + -5, + 24.25, + ], + Array [ + 7.761, + 24.25, + ], + ], + "v": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 29.25, + ], + Array [ + -5, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + }, + ], + "t": 60, + }, + ], + }, + "mn": "ADBE Vector Shape - Group", + "nm": "Path 1", + "ty": "sh", + }, + Object { + "_render": true, + "bm": 0, + "c": Object { + "a": 0, + "ix": 4, + "k": Array [ + 0.8901960784313725, + 0.7215686274509804, + 0.16470588235294117, + 1, + ], + }, + "hd": false, + "mn": "ADBE Vector Graphic - Fill", + "nm": "Fill 1", + "o": Object { + "a": 0, + "ix": 5, + "k": 100, + }, + "r": 1, + "ty": "fl", + }, + ], + "sr": 1, + "st": 0, + "ty": 4, + }, + ], + "markers": Array [], + "nm": "Comp 1", + "op": 60, + "v": "5.5.8", + "w": 128, + }, + "fr": 30, + "h": 128, + "ip": 0, + "layers": Array [ + Object { + "ao": 0, + "bm": 0, + "completed": true, + "ddd": 0, + "ind": 1, + "ip": 0, + "ks": Object { + "a": Object { + "a": 0, + "ix": 1, + "k": Array [ + 0, + 50, + 0, + ], + }, + "o": Object { + "a": 0, + "ix": 11, + "k": 100, + }, + "p": Object { + "a": 0, + "ix": 2, + "k": Array [ + 102.5, + 114, + 0, + ], + }, + "r": Object { + "a": 0, + "ix": 10, + "k": 0, + }, + "s": Object { + "a": 0, + "ix": 6, + "k": Array [ + 100, + 100, + 100, + ], + }, + }, + "nm": "Shape Layer 2", + "op": 61, + "shapes": Array [ + Object { + "_render": true, + "hd": false, + "ind": 0, + "ix": 1, + "ks": Object { + "a": 1, + "ix": 2, + "k": Array [ + Object { + "i": Object { + "x": 0.665, + "y": 1, + }, + "o": Object { + "x": 0.088, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -11.511, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -8.75, + ], + Array [ + -7.761, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + "o": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -11.511, + ], + Array [ + -5, + -13.75, + ], + Array [ + 7.761, + -13.75, + ], + ], + "v": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -8.75, + ], + Array [ + -5, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + }, + ], + "t": 0, + }, + Object { + "i": Object { + "x": 0.888, + "y": 0.992, + }, + "o": Object { + "x": 0.315, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -32.261, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -29.5, + ], + Array [ + -7.761, + -34.5, + ], + Array [ + 5, + -34.5, + ], + ], + "o": Array [ + Array [ + 10, + -29.5, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -32.261, + ], + Array [ + -5, + -34.5, + ], + Array [ + 7.761, + -34.5, + ], + ], + "v": Array [ + Array [ + 10, + -29.5, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -29.5, + ], + Array [ + -5, + -34.5, + ], + Array [ + 5, + -34.5, + ], + ], + }, + ], + "t": 15, + }, + Object { + "i": Object { + "x": 0.777, + "y": 1, + }, + "o": Object { + "x": 0.117, + "y": 0.013, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -11.511, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -8.75, + ], + Array [ + -7.761, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + "o": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -11.511, + ], + Array [ + -5, + -13.75, + ], + Array [ + 7.761, + -13.75, + ], + ], + "v": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -8.75, + ], + Array [ + -5, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + }, + ], + "t": 30, + }, + Object { + "i": Object { + "x": 0.853, + "y": 1, + }, + "o": Object { + "x": 0.098, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 15.989, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 18.75, + ], + Array [ + -7.761, + 13.75, + ], + Array [ + 5, + 13.75, + ], + ], + "o": Array [ + Array [ + 10, + 18.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 15.989, + ], + Array [ + -5, + 13.75, + ], + Array [ + 7.761, + 13.75, + ], + ], + "v": Array [ + Array [ + 10, + 18.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 18.75, + ], + Array [ + -5, + 13.75, + ], + Array [ + 5, + 13.75, + ], + ], + }, + ], + "t": 46, + }, + Object { + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -11.511, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -8.75, + ], + Array [ + -7.761, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + "o": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -11.511, + ], + Array [ + -5, + -13.75, + ], + Array [ + 7.761, + -13.75, + ], + ], + "v": Array [ + Array [ + 10, + -8.75, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -8.75, + ], + Array [ + -5, + -13.75, + ], + Array [ + 5, + -13.75, + ], + ], + }, + ], + "t": 60, + }, + ], + }, + "mn": "ADBE Vector Shape - Group", + "nm": "Path 1", + "ty": "sh", + }, + Object { + "_render": true, + "bm": 0, + "c": Object { + "a": 0, + "ix": 4, + "k": Array [ + 0.8901960784313725, + 0.7215686274509804, + 0.16470588235294117, + 1, + ], + }, + "hd": false, + "mn": "ADBE Vector Graphic - Fill", + "nm": "Fill 1", + "o": Object { + "a": 0, + "ix": 5, + "k": 100, + }, + "r": 1, + "ty": "fl", + }, + ], + "sr": 1, + "st": 0, + "ty": 4, + }, + Object { + "ao": 0, + "bm": 0, + "completed": true, + "ddd": 0, + "ind": 2, + "ip": 0, + "ks": Object { + "a": Object { + "a": 0, + "ix": 1, + "k": Array [ + 0, + 50, + 0, + ], + }, + "o": Object { + "a": 0, + "ix": 11, + "k": 100, + }, + "p": Object { + "a": 0, + "ix": 2, + "k": Array [ + 62.5, + 114, + 0, + ], + }, + "r": Object { + "a": 0, + "ix": 10, + "k": 0, + }, + "s": Object { + "a": 0, + "ix": 6, + "k": Array [ + 100, + 100, + 100, + ], + }, + }, + "nm": "Shape Layer 3", + "op": 61, + "shapes": Array [ + Object { + "_render": true, + "hd": false, + "ind": 0, + "ix": 1, + "ks": Object { + "a": 1, + "ix": 2, + "k": Array [ + Object { + "i": Object { + "x": 0.631, + "y": 1, + }, + "o": Object { + "x": 0.167, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -35.761, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -33, + ], + Array [ + -7.761, + -38, + ], + Array [ + 5, + -38, + ], + ], + "o": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -35.761, + ], + Array [ + -5, + -38, + ], + Array [ + 7.761, + -38, + ], + ], + "v": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -33, + ], + Array [ + -5, + -38, + ], + Array [ + 5, + -38, + ], + ], + }, + ], + "t": 0, + }, + Object { + "i": Object { + "x": 0.667, + "y": 1, + }, + "o": Object { + "x": 0.391, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 1.2389999999999999, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 4, + ], + Array [ + -7.761, + -1, + ], + Array [ + 5, + -1, + ], + ], + "o": Array [ + Array [ + 10, + 4, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 1.2389999999999999, + ], + Array [ + -5, + -1, + ], + Array [ + 7.761, + -1, + ], + ], + "v": Array [ + Array [ + 10, + 4, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 4, + ], + Array [ + -5, + -1, + ], + Array [ + 5, + -1, + ], + ], + }, + ], + "t": 13.846, + }, + Object { + "i": Object { + "x": 0.88, + "y": 1, + }, + "o": Object { + "x": 0.093, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -35.761, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -33, + ], + Array [ + -7.761, + -38, + ], + Array [ + 5, + -38, + ], + ], + "o": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -35.761, + ], + Array [ + -5, + -38, + ], + Array [ + 7.761, + -38, + ], + ], + "v": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -33, + ], + Array [ + -5, + -38, + ], + Array [ + 5, + -38, + ], + ], + }, + ], + "t": 27, + }, + Object { + "i": Object { + "x": 0.873, + "y": 1, + }, + "o": Object { + "x": 0.165, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 9.114, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 11.875, + ], + Array [ + -7.761, + 6.875, + ], + Array [ + 5, + 6.875, + ], + ], + "o": Array [ + Array [ + 10, + 11.875, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 9.114, + ], + Array [ + -5, + 6.875, + ], + Array [ + 7.761, + 6.875, + ], + ], + "v": Array [ + Array [ + 10, + 11.875, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 11.875, + ], + Array [ + -5, + 6.875, + ], + Array [ + 5, + 6.875, + ], + ], + }, + ], + "t": 45, + }, + Object { + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + -35.761, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + -33, + ], + Array [ + -7.761, + -38, + ], + Array [ + 5, + -38, + ], + ], + "o": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -35.761, + ], + Array [ + -5, + -38, + ], + Array [ + 7.761, + -38, + ], + ], + "v": Array [ + Array [ + 10, + -33, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + -33, + ], + Array [ + -5, + -38, + ], + Array [ + 5, + -38, + ], + ], + }, + ], + "t": 60, + }, + ], + }, + "mn": "ADBE Vector Shape - Group", + "nm": "Path 1", + "ty": "sh", + }, + Object { + "_render": true, + "bm": 0, + "c": Object { + "a": 0, + "ix": 4, + "k": Array [ + 0.8901960784313725, + 0.7215686274509804, + 0.16470588235294117, + 1, + ], + }, + "hd": false, + "mn": "ADBE Vector Graphic - Fill", + "nm": "Fill 1", + "o": Object { + "a": 0, + "ix": 5, + "k": 100, + }, + "r": 1, + "ty": "fl", + }, + ], + "sr": 1, + "st": 0, + "ty": 4, + }, + Object { + "ao": 0, + "bm": 0, + "completed": true, + "ddd": 0, + "ind": 3, + "ip": 0, + "ks": Object { + "a": Object { + "a": 0, + "ix": 1, + "k": Array [ + 0, + 50, + 0, + ], + }, + "o": Object { + "a": 0, + "ix": 11, + "k": 100, + }, + "p": Object { + "a": 0, + "ix": 2, + "k": Array [ + 22.5, + 114, + 0, + ], + }, + "r": Object { + "a": 0, + "ix": 10, + "k": 0, + }, + "s": Object { + "a": 0, + "ix": 6, + "k": Array [ + 100, + 100, + 100, + ], + }, + }, + "nm": "Shape Layer 4", + "op": 61, + "shapes": Array [ + Object { + "_render": true, + "hd": false, + "ind": 0, + "ix": 1, + "ks": Object { + "a": 1, + "ix": 2, + "k": Array [ + Object { + "i": Object { + "x": 0.562, + "y": 1, + }, + "o": Object { + "x": 0.46, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 26.489, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 29.25, + ], + Array [ + -7.761, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + "o": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 26.489, + ], + Array [ + -5, + 24.25, + ], + Array [ + 7.761, + 24.25, + ], + ], + "v": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 29.25, + ], + Array [ + -5, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + }, + ], + "t": 0, + }, + Object { + "i": Object { + "x": 0.505, + "y": 1, + }, + "o": Object { + "x": 0.402, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 10.239, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 13, + ], + Array [ + -7.761, + 8, + ], + Array [ + 5, + 8, + ], + ], + "o": Array [ + Array [ + 10, + 13, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 10.239, + ], + Array [ + -5, + 8, + ], + Array [ + 7.761, + 8, + ], + ], + "v": Array [ + Array [ + 10, + 13, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 13, + ], + Array [ + -5, + 8, + ], + Array [ + 5, + 8, + ], + ], + }, + ], + "t": 15, + }, + Object { + "i": Object { + "x": 0.407, + "y": 1, + }, + "o": Object { + "x": 0.167, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 26.489, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 29.25, + ], + Array [ + -7.761, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + "o": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 26.489, + ], + Array [ + -5, + 24.25, + ], + Array [ + 7.761, + 24.25, + ], + ], + "v": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 29.25, + ], + Array [ + -5, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + }, + ], + "t": 32, + }, + Object { + "i": Object { + "x": 0.599, + "y": 1, + }, + "o": Object { + "x": 0.526, + "y": 0, + }, + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 0.23899999999999988, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 3, + ], + Array [ + -7.761, + -2, + ], + Array [ + 5, + -2, + ], + ], + "o": Array [ + Array [ + 10, + 3, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 0.23899999999999988, + ], + Array [ + -5, + -2, + ], + Array [ + 7.761, + -2, + ], + ], + "v": Array [ + Array [ + 10, + 3, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 3, + ], + Array [ + -5, + -2, + ], + Array [ + 5, + -2, + ], + ], + }, + ], + "t": 47, + }, + Object { + "s": Array [ + Object { + "c": true, + "i": Array [ + Array [ + 10, + 26.489, + ], + Array [ + 10, + 45, + ], + Array [ + 7.761, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 47.761, + ], + Array [ + -10, + 29.25, + ], + Array [ + -7.761, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + "o": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 47.761, + ], + Array [ + 5, + 50, + ], + Array [ + -7.761, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 26.489, + ], + Array [ + -5, + 24.25, + ], + Array [ + 7.761, + 24.25, + ], + ], + "v": Array [ + Array [ + 10, + 29.25, + ], + Array [ + 10, + 45, + ], + Array [ + 5, + 50, + ], + Array [ + -5, + 50, + ], + Array [ + -10, + 45, + ], + Array [ + -10, + 29.25, + ], + Array [ + -5, + 24.25, + ], + Array [ + 5, + 24.25, + ], + ], + }, + ], + "t": 60, + }, + ], + }, + "mn": "ADBE Vector Shape - Group", + "nm": "Path 1", + "ty": "sh", + }, + Object { + "_render": true, + "bm": 0, + "c": Object { + "a": 0, + "ix": 4, + "k": Array [ + 0.8901960784313725, + 0.7215686274509804, + 0.16470588235294117, + 1, + ], + }, + "hd": false, + "mn": "ADBE Vector Graphic - Fill", + "nm": "Fill 1", + "o": Object { + "a": 0, + "ix": 5, + "k": 100, + }, + "r": 1, + "ty": "fl", + }, + ], + "sr": 1, + "st": 0, + "ty": 4, + }, + ], + "markers": Array [], + "nm": "Comp 1", + "op": 60, + "v": "5.5.8", + "w": 128, + }, + "autoplay": true, + "loop": true, + "rendererSettings": Object { + "preserveAspectRatio": "xMidYMid slice", + }, + } + } + speed={2} + title="" + width={50} + > + <div + aria-label="animation" + onClick={[Function]} + role="button" + style={ + Object { + "height": "50px", + "margin": "0 auto", + "outline": "none", + "overflow": "hidden", + "width": "50px", + } + } + tabIndex="0" + title="" + /> + </Lottie> + <div + className="kmodal-content-text kmodal-content-text-center text-16-normal" + > + <div + className="kc-wait text-16-bold" + > + konnector_modal.loading_data + </div> + </div> + <div + className="kmodal-waiting-text text-18-italic" + > + <div + className="waiting-text show" + key="0" + > + <p> + La première fois cela peut prendre quelques minutes, par la suite, seulement quelques secondes. + </p> + <p /> + </div> + <div + className="waiting-text" + key="1" + > + <p> + Afin de limiter le temps de ce premier chargement, un historique réduit de vos consommations va être chargé. Vous aurez tout de même accès à un an d'historique dès à présent. + </p> + <p /> + </div> + <div + className="waiting-text" + key="2" + > + <p> + Demain matin, vous aurez accès à l'ensemble de vos données (jusqu'à trois ans d'historique). + </p> + <p /> + </div> + <div + className="waiting-text" + key="3" + > + <p> + Le saviez-vous ? + </p> + <p> + Pour acheminer l’eau sur Lyon (Lugdunum !) l’acqueduc de Gier faisait 86 km à l’époque Romaine ! + </p> + </div> + <div + className="waiting-text" + key="4" + > + <p> + Rien que de l’eau, de l’eau de pluie, de l’eau de la Métroooooo + </p> + <p> + ♪♪ + </p> + </div> + <div + className="waiting-text" + key="5" + > + <p> + Le saviez-vous ? + </p> + <p> + Environ 90% de notre électricité provient de centrales de production hors de notre métropole. + </p> + </div> + <div + className="waiting-text" + key="6" + > + <p> + « Il y a de l’eau dans le gaz » … + </p> + <p> + Avec Ecolyo c’est l’eau AVEC le gaz. + </p> + </div> + <div + className="waiting-text" + key="7" + > + <p> + Le saviez-vous ? + </p> + <p> + La consommation énergétique résidentielle représente environ 30% de la consommation énergétique totale de notre territoire. + </p> + </div> + <div + className="waiting-text" + key="8" + > + <p> + Le saviez-vous ? + </p> + <p> + La Métropole de Lyon a été territoire d’expérimentation Linky. Le compteur est présent sur notre territoire depuis plus de 10 ans ! + </p> + </div> + <div + className="waiting-text" + key="9" + > + <p> + Le saviez-vous ? + </p> + <p> + 10 minutes d'aération par jour permettent à notre habitat d’être plus sain, avec un air renouvelé, moins de polluants et l’évacuation de l’humidité qui stagne et qui nous oblige à consommer plus de chauffage. + </p> + </div> + <div + className="waiting-text" + key="10" + > + <p> + Le saviez-vous ? + </p> + <p> + 2°C ! C’est la différence qu’on peut mesurer dans une rue bien arborée en comparaison d’une rue vide : la végétation est donc cruciale pour le bien être en ville l’été et pour limiter l’installation des climatiseurs. + </p> + </div> + <div + className="waiting-text" + key="11" + > + <p> + Il y a les bonnes pratiques de consommations énergétiques (et Ecolyo est là pour cela !) mais aussi et bien sûr, la rénovation. + </p> + <p> + Le saviez-vous ? La loi énergie climat de 2019 impose que d’ici 2025, les bâtiments privés résidentiels les plus énergivores soient tous rénovés ! + </p> + </div> + </div> + </div> + </div> + </ForwardRef(Paper)> + </WithStyles(ForwardRef(Paper))> + </div> + </Transition> + </ForwardRef(Fade)> + <div + data-test="sentinelEnd" + tabIndex={0} + /> + </Unstable_TrapFocus> + </div> + </Portal> + </ForwardRef(Portal)> + </ForwardRef(Modal)> + </ForwardRef(Dialog)> + </WithStyles(ForwardRef(Dialog))> + </KonnectorModal> </Provider> `; diff --git a/src/components/Konnector/__snapshots__/KonnectorModalFooter.spec.tsx.snap b/src/components/Konnector/__snapshots__/KonnectorModalFooter.spec.tsx.snap new file mode 100644 index 0000000000000000000000000000000000000000..527aa6f28cc29dd6db93240fe135b592d52877e6 --- /dev/null +++ b/src/components/Konnector/__snapshots__/KonnectorModalFooter.spec.tsx.snap @@ -0,0 +1,160 @@ +// Jest Snapshot v1, https://goo.gl/fbAQLP + +exports[`KonnectorModalFooter component should be rendered correctly 1`] = ` +<Provider + store={ + Object { + "clearActions": [Function], + "dispatch": [Function], + "getActions": [Function], + "getState": [Function], + "replaceReducer": [Function], + "subscribe": [Function], + } + } +> + <KonnectorModalFooter + account={null} + error={null} + fluidType={0} + handleAccountDeletion={[MockFunction]} + handleCloseClick={[MockFunction]} + isUpdating={false} + state={null} + > + <WithStyles(ForwardRef(Button)) + aria-label="konnector_modal.accessibility.button_close" + classes={ + Object { + "label": "text-16-bold", + "root": "btn-highlight", + } + } + onClick={[Function]} + > + <ForwardRef(Button) + aria-label="konnector_modal.accessibility.button_close" + classes={ + Object { + "colorInherit": "MuiButton-colorInherit", + "contained": "MuiButton-contained", + "containedPrimary": "MuiButton-containedPrimary", + "containedSecondary": "MuiButton-containedSecondary", + "containedSizeLarge": "MuiButton-containedSizeLarge", + "containedSizeSmall": "MuiButton-containedSizeSmall", + "disableElevation": "MuiButton-disableElevation", + "disabled": "Mui-disabled", + "endIcon": "MuiButton-endIcon", + "focusVisible": "Mui-focusVisible", + "fullWidth": "MuiButton-fullWidth", + "iconSizeLarge": "MuiButton-iconSizeLarge", + "iconSizeMedium": "MuiButton-iconSizeMedium", + "iconSizeSmall": "MuiButton-iconSizeSmall", + "label": "MuiButton-label text-16-bold", + "outlined": "MuiButton-outlined", + "outlinedPrimary": "MuiButton-outlinedPrimary", + "outlinedSecondary": "MuiButton-outlinedSecondary", + "outlinedSizeLarge": "MuiButton-outlinedSizeLarge", + "outlinedSizeSmall": "MuiButton-outlinedSizeSmall", + "root": "MuiButton-root btn-highlight", + "sizeLarge": "MuiButton-sizeLarge", + "sizeSmall": "MuiButton-sizeSmall", + "startIcon": "MuiButton-startIcon", + "text": "MuiButton-text", + "textPrimary": "MuiButton-textPrimary", + "textSecondary": "MuiButton-textSecondary", + "textSizeLarge": "MuiButton-textSizeLarge", + "textSizeSmall": "MuiButton-textSizeSmall", + } + } + onClick={[Function]} + > + <WithStyles(ForwardRef(ButtonBase)) + aria-label="konnector_modal.accessibility.button_close" + className="MuiButton-root btn-highlight MuiButton-text" + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <ForwardRef(ButtonBase) + aria-label="konnector_modal.accessibility.button_close" + className="MuiButton-root btn-highlight MuiButton-text" + classes={ + Object { + "disabled": "Mui-disabled", + "focusVisible": "Mui-focusVisible", + "root": "MuiButtonBase-root", + } + } + component="button" + disabled={false} + focusRipple={true} + focusVisibleClassName="Mui-focusVisible" + onClick={[Function]} + type="button" + > + <button + aria-label="konnector_modal.accessibility.button_close" + className="MuiButtonBase-root MuiButton-root btn-highlight MuiButton-text" + disabled={false} + onBlur={[Function]} + onClick={[Function]} + onDragLeave={[Function]} + onFocus={[Function]} + onKeyDown={[Function]} + onKeyUp={[Function]} + onMouseDown={[Function]} + onMouseLeave={[Function]} + onMouseUp={[Function]} + onTouchEnd={[Function]} + onTouchMove={[Function]} + onTouchStart={[Function]} + tabIndex={0} + type="button" + > + <span + className="MuiButton-label text-16-bold" + > + <div> + konnector_modal.button_validate + </div> + </span> + <WithStyles(memo) + center={false} + > + <ForwardRef(TouchRipple) + center={false} + classes={ + Object { + "child": "MuiTouchRipple-child", + "childLeaving": "MuiTouchRipple-childLeaving", + "childPulsate": "MuiTouchRipple-childPulsate", + "ripple": "MuiTouchRipple-ripple", + "ripplePulsate": "MuiTouchRipple-ripplePulsate", + "rippleVisible": "MuiTouchRipple-rippleVisible", + "root": "MuiTouchRipple-root", + } + } + > + <span + className="MuiTouchRipple-root" + > + <TransitionGroup + childFactory={[Function]} + component={null} + exit={true} + /> + </span> + </ForwardRef(TouchRipple)> + </WithStyles(memo)> + </button> + </ForwardRef(ButtonBase)> + </WithStyles(ForwardRef(ButtonBase))> + </ForwardRef(Button)> + </WithStyles(ForwardRef(Button))> + </KonnectorModalFooter> +</Provider> +`; diff --git a/src/components/Konnector/konnectorModal.scss b/src/components/Konnector/konnectorModal.scss index 670a58bb1cf76da2b12a2c1c6ee2a711fb5497e2..8b054b37a5a872fa25da6a6508bc5101b0f8e9ed 100644 --- a/src/components/Konnector/konnectorModal.scss +++ b/src/components/Konnector/konnectorModal.scss @@ -43,16 +43,33 @@ } .kmodal-info { - margin: 1.5rem; + margin: 1rem; text-align: center; - + .buttons { + display: flex; + gap: 0.825rem; + } .konnector-config { align-items: center; display: flex; flex-direction: column; justify-content: center; text-align: center; - + .elec-fail { + color: $grey-bright; + margin-top: 1rem; + } + &.mismatch { + .title { + color: $orange; + } + div { + margin-bottom: 1rem; + } + .info { + color: $grey-bright; + } + } .kce-picto-txt { color: $red-primary; margin: 1.25rem; diff --git a/src/components/Navbar/navBar.scss b/src/components/Navbar/navBar.scss index d9b924b35db71101867b68dbe59387a300f817b6..d324820e81ed9f86a44cf9ddff6caa300b84ab2e 100644 --- a/src/components/Navbar/navBar.scss +++ b/src/components/Navbar/navBar.scss @@ -3,7 +3,7 @@ @import 'src/styles/base/z-index'; .o-sidebar { - background-color: $dark-light; + background-color: $bottom-bar-grey; box-shadow: 0px 5px 5px rgba(0, 0, 0, 0.2), 0px 3px 14px rgba(0, 0, 0, 0.12), 0px 8px 10px rgba(0, 0, 0, 0.14); border-top: unset; diff --git a/src/components/PartnersIssue/__snapshots__/PartnersIssueModal.spec.tsx.snap b/src/components/PartnersIssue/__snapshots__/PartnersIssueModal.spec.tsx.snap index 6c4bfa3e7818464f168fba11ce330ff0bfee6ba0..34b0a12811a6dd85b4f9704552f139c334371c06 100644 --- a/src/components/PartnersIssue/__snapshots__/PartnersIssueModal.spec.tsx.snap +++ b/src/components/PartnersIssue/__snapshots__/PartnersIssueModal.spec.tsx.snap @@ -26,7 +26,7 @@ exports[`PartnersIssueModal component should render correctly 1`] = ` "name": "", "oauth": false, "siteLink": "", - "slug": "", + "slug": "enedis-sge-grandlyon", }, "shouldLaunchKonnector": false, "trigger": null, @@ -47,7 +47,7 @@ exports[`PartnersIssueModal component should render correctly 1`] = ` "name": "", "oauth": false, "siteLink": "", - "slug": "", + "slug": "eglgrandlyon", }, "shouldLaunchKonnector": false, "trigger": null, @@ -68,7 +68,7 @@ exports[`PartnersIssueModal component should render correctly 1`] = ` "name": "", "oauth": false, "siteLink": "", - "slug": "", + "slug": "grdfgrandlyon", }, "shouldLaunchKonnector": false, "trigger": null, diff --git a/src/components/ProfileType/ProfileTypeFormDateSelection.tsx b/src/components/ProfileType/ProfileTypeFormDateSelection.tsx index 9b85807d035ec1d65d5ecee9f225a95a8d867620..fcdebab17dacde7581fd5202857905db27993499 100644 --- a/src/components/ProfileType/ProfileTypeFormDateSelection.tsx +++ b/src/components/ProfileType/ProfileTypeFormDateSelection.tsx @@ -1,10 +1,8 @@ -/* eslint-disable @typescript-eslint/no-explicit-any */ - import React, { useCallback, useEffect, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' -import ProfileTypeProgress from 'components/ProfileType/ProfileTypeProgress' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormProgress from 'components/FormGlobal/FormProgress' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { ProfileTypeStepForm } from 'enum/profileType.enum' import { ProfileType, @@ -181,7 +179,7 @@ const ProfileTypeFormDateSelection: React.FC< return ( <> <div className={'profile-form-container'}> - <ProfileTypeProgress step={step} /> + <FormProgress step={step} formType={'profile'} /> <div className={'profile-question-label'}> {t( `profile_type.${ProfileTypeStepForm[step].toLowerCase()}.question` diff --git a/src/components/ProfileType/ProfileTypeFormMultiChoice.tsx b/src/components/ProfileType/ProfileTypeFormMultiChoice.tsx index 57ea92b703bba66b17ba70319281aed606736593..1df12766cb42d6b4a3b1b95dd6d8711e87df24ca 100644 --- a/src/components/ProfileType/ProfileTypeFormMultiChoice.tsx +++ b/src/components/ProfileType/ProfileTypeFormMultiChoice.tsx @@ -2,8 +2,8 @@ import React, { useCallback, useEffect, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' import classNames from 'classnames' -import ProfileTypeProgress from 'components/ProfileType/ProfileTypeProgress' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormProgress from 'components/FormGlobal/FormProgress' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { remove } from 'lodash' import { IndividualInsulationWork, @@ -83,7 +83,7 @@ const ProfileTypeFormMultiChoice: React.FC<ProfileTypeFormMultiChoiceProps> = ({ return ( <> <div className={'profile-form-container'}> - <ProfileTypeProgress step={step} /> + <FormProgress step={step} formType={'profile'} /> <div className={'profile-question-label'}> {t( `profile_type.${ProfileTypeStepForm[step].toLowerCase()}.question` diff --git a/src/components/ProfileType/ProfileTypeFormNumber.tsx b/src/components/ProfileType/ProfileTypeFormNumber.tsx index 18f54f4c4a9e24e30a7fa945aa506625cbd3d685..cdb31f505c0486f66038d2f306191fa189fb69ad 100644 --- a/src/components/ProfileType/ProfileTypeFormNumber.tsx +++ b/src/components/ProfileType/ProfileTypeFormNumber.tsx @@ -1,8 +1,8 @@ import React, { useCallback, useEffect, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' -import ProfileTypeProgress from 'components/ProfileType/ProfileTypeProgress' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormProgress from 'components/FormGlobal/FormProgress' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { ProfileTypeStepForm } from 'enum/profileType.enum' import { ProfileType, @@ -50,7 +50,7 @@ const ProfileTypeFormNumber: React.FC<ProfileTypeFormNumberProps> = ({ return ( <> <div className={'profile-form-container'}> - <ProfileTypeProgress step={step} /> + <FormProgress step={step} formType={'profile'} /> <div className={'profile-question-label'}> {t( `profile_type.${ProfileTypeStepForm[step].toLowerCase()}.question` diff --git a/src/components/ProfileType/ProfileTypeFormNumberSelection.tsx b/src/components/ProfileType/ProfileTypeFormNumberSelection.tsx index 2979bb1723adb28a352f9b91c58f07acaf327500..8996894ac4a871f2d4d3b3a7653edbe4f4dd07a2 100644 --- a/src/components/ProfileType/ProfileTypeFormNumberSelection.tsx +++ b/src/components/ProfileType/ProfileTypeFormNumberSelection.tsx @@ -1,8 +1,8 @@ import React, { useCallback, useEffect, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' -import ProfileTypeProgress from 'components/ProfileType/ProfileTypeProgress' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormProgress from 'components/FormGlobal/FormProgress' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { ProfileTypeStepForm } from 'enum/profileType.enum' import { ProfileType, @@ -69,7 +69,7 @@ const ProfileTypeFormNumberSelection: React.FC< return ( <> <div className={'profile-form-container'}> - <ProfileTypeProgress step={step} /> + <FormProgress step={step} formType={'profile'} /> <div className={'profile-question-label'}> {t( `profile_type.${ProfileTypeStepForm[step].toLowerCase()}.question` diff --git a/src/components/ProfileType/ProfileTypeFormSingleChoice.tsx b/src/components/ProfileType/ProfileTypeFormSingleChoice.tsx index d39461b166bd3daaa16cc94b1ad251a615a9b90b..f1ddbe33c72c1367d83a46cc5ea65404655176fa 100644 --- a/src/components/ProfileType/ProfileTypeFormSingleChoice.tsx +++ b/src/components/ProfileType/ProfileTypeFormSingleChoice.tsx @@ -2,8 +2,8 @@ import React, { useCallback, useEffect, useState } from 'react' import 'components/ProfileType/profileTypeForm.scss' import { useI18n } from 'cozy-ui/transpiled/react/I18n' import classNames from 'classnames' -import ProfileTypeProgress from 'components/ProfileType/ProfileTypeProgress' -import FormNavigation from 'components/ProfileType/FormNavigation' +import FormProgress from 'components/FormGlobal/FormProgress' +import FormNavigation from 'components/FormGlobal/FormNavigation' import { ProfileTypeStepForm } from 'enum/profileType.enum' import { ProfileType, @@ -53,7 +53,7 @@ const ProfileTypeFormSingleChoice: React.FC< return ( <> <div className={'profile-form-container'}> - <ProfileTypeProgress step={step} /> + <FormProgress step={step} formType={'profile'} /> <div className={'profile-question-label'}> {t( `profile_type.${ProfileTypeStepForm[step].toLowerCase()}.question` diff --git a/src/components/Routes/Routes.tsx b/src/components/Routes/Routes.tsx index 0df72fa29592f663f831c2fd2a2e6a36f54200cf..de8fee76c7dfc1aa21095784ac787a7c6714117a 100644 --- a/src/components/Routes/Routes.tsx +++ b/src/components/Routes/Routes.tsx @@ -11,6 +11,7 @@ import TermsView from 'components/Terms/TermsView' import { TermsStatus } from 'models' import EcogestureFormView from 'components/EcogestureForm/EcogestureFormView' import EcogestureSelection from 'components/EcogestureSelection/EcogestureSelection' +import SgeConnectView from 'components/Connection/SGEConnect/SgeConnectView' const ConsumptionView = lazy(() => import('components/Home/ConsumptionView')) @@ -59,6 +60,7 @@ const Routes: React.FC<RouteProps> = ({ termsStatus }: RouteProps) => { <ConsumptionView fluidType={FluidType.MULTIFLUID} /> </Route> + <Route path={`/sge-connect`} component={SgeConnectView} /> <Route path={`/challenges/duel`} component={DuelView} /> <Route path={`/challenges/quiz`} component={QuizView} /> <Route path={`/challenges/exploration`} component={ExplorationView} /> diff --git a/src/components/Terms/termsView.scss b/src/components/Terms/termsView.scss index 580e95b0505d7a383ec832c13459ffe26d29a151..e7ccf1b1656d98024398c8d07b2d8ac48e969a5e 100644 --- a/src/components/Terms/termsView.scss +++ b/src/components/Terms/termsView.scss @@ -1,4 +1,5 @@ @import 'src/styles/base/color'; +@import 'src/styles/base/mixins'; .terms-wrapper { padding: 0rem 1.5rem 0 1.5rem; @@ -25,55 +26,8 @@ .dataShare-content-root { width: inherit; } +@include checkBox(); -.checkbox { - margin: 0.5rem 0; - display: flex; - align-items: center; - &:first-of-type { - margin-top: 1.5rem; - } - input { - margin: 0.5rem 1rem 0.5rem 0.5rem; - appearance: none; - -moz-appearance: none; - -webkit-appearance: none; - width: 1.45rem; - height: 1.45rem; - min-width: 1.45rem; - min-height: 1.45rem; - background: $dark-background; - position: relative; - border: solid 2px $gold-shadow; - cursor: pointer; - } -} -.answer-checked { - input { - &:before, - &:after { - content: ''; - position: absolute; - display: inline-block; - background: $gold-shadow; - border-radius: 0.5rem; - } - &:before { - width: 3px; - height: 12px; - left: 10px; - top: 4px; - transform: rotate(41deg); - } - &:after { - width: 3px; - height: 6px; - left: 5px; - top: 8px; - transform: rotate(133deg); - } - } -} .terms-footer { max-width: 45rem; width: 100%; diff --git a/src/constants/config.json b/src/constants/config.json index 490b05a52c0c8270376e9b449a0806e47d8b17a4..581709801bba25a1ea6ed4c852a5c231c656e56f 100644 --- a/src/constants/config.json +++ b/src/constants/config.json @@ -4,13 +4,12 @@ "fluidTypeId": 0, "name": "enedis", "coefficient": 0.174, - "startDate": "2021-08-01T00:00:00.000", "dataDelayOffset": 3, "konnectorConfig": { "name": "Enedis", - "oauth": true, - "slug": "enedisgrandlyon", + "oauth": false, + "slug": "enedis-sge-grandlyon", "siteLink": "https://mon-compte-client.enedis.fr/", "activation": "https://mon-compte-particulier.enedis.fr/donnees/" } diff --git a/src/enum/fluidSlug.enum.ts b/src/enum/fluidSlug.enum.ts index 33db5dcd220a3fba1853921169d00c72e481b614..46404243550a7dde4574bf97b3e9ad2ee944f553 100644 --- a/src/enum/fluidSlug.enum.ts +++ b/src/enum/fluidSlug.enum.ts @@ -1,5 +1,5 @@ export enum FluidSlugType { - ELECTRICITY = 'enedisgrandlyon', + ELECTRICITY = 'enedis-sge-grandlyon', WATER = 'eglgrandlyon', GAS = 'grdfgrandlyon', } diff --git a/src/enum/konnectorError.enum.ts b/src/enum/konnectorError.enum.ts new file mode 100644 index 0000000000000000000000000000000000000000..17411d2a0e1933974511cc809049cd73329631f8 --- /dev/null +++ b/src/enum/konnectorError.enum.ts @@ -0,0 +1,7 @@ +export enum KonnectorError { + LOGIN_FAILED = 'LOGIN_FAILED', + USER_ACTION_NEEDED = 'USER_ACTION_NEEDED', + TERMS_VERSION_MISMATCH = 'TERMS_VERSION_MISMATCH', + UNKNOWN_ERROR = 'UNKNOWN_ERROR', + CRITICAL = 'exit status 1', +} diff --git a/src/enum/sgeStep.enum.ts b/src/enum/sgeStep.enum.ts new file mode 100644 index 0000000000000000000000000000000000000000..393a577799812b4824c8245511559f6ae0d8e30d --- /dev/null +++ b/src/enum/sgeStep.enum.ts @@ -0,0 +1,5 @@ +export enum SgeStep { + IdentityAndPDL, + Address, + Consent, +} diff --git a/src/locales/fr.json b/src/locales/fr.json index 3388e838944e6fcda861a5bbfdae63b34709061c..b73b925db867521b7d72095bb4a632f69d3d88be 100644 --- a/src/locales/fr.json +++ b/src/locales/fr.json @@ -15,6 +15,7 @@ "title_faq": "FAQ", "title_legal_notice": "Mentions légales", "title_gcu": "CGU", + "title_sge_connect": "Connexion à l'électricité", "accessibility": { "loading": "Chargement" } @@ -135,27 +136,36 @@ "text5": "Cette puissance varie d'un mois à l'autre, regardez cette valeur sur l'ensemble de l'année pour vérifier si votre puissance souscrite correspond bien à votre usage." }, "auth": { - "enedisgrandlyon": { - "connect": { - "label1": "Je me connecte à mon", - "label2": "compte Enedis" - }, - "no_account": { - "title": "Ecolyo doit se connecter à votre compte Enedis", - "subtitle1": "Si vous n’avez pas de compte Enedis", - "button_create_account": "Je crée mon compte Enedis", - "subtitle2": "Si vous avez déjà un compte Enedis,", - "subtitle2_info": "votre accord est nécessaire pour connecter Enedis et Ecolyo", - "info": "Enedis est responsable de votre compteur Linky et en charge de relever vos consommations." + "enedis-sge-grandlyon": { + "title": "Ecolyo doit se connecter à votre compte Enedis", + "bill": "Munissez-vous d’une <span>facture d’électricité</span> pour valider la connexion", + "connect": "Je me connecte à l'électricité", + "accessibility": { + "connect": "Se connecter" }, - "title_with_account": "Votre compte Enedis a bien été créé ?", - "with_account": { - "title": "Votre compte Enedis a bien été créé ?", - "subtitle1": "Plus qu’à donner votre accord pour connecter Enedis et Ecolyo !", - "subtitle2": "Si vous n’avez pas de compte Enedis", - "button_create_account": "Je crée mon compte", - "subtitle2_info": "En cas de soucis pour créer votre compte ou pour vous y connecter, un guide en pas-à -pas est disponible pour vous y aider.", - "button_goto_guide": "Voir le guide" + "identityTitle": "Nom inscrit sur la facture", + "firstName": "Prénom", + "lastName": "Nom", + "pdlTitle": "Numéro de votre compteur électrique (PDL)", + "pdlLabel": "N° (14 chiffes)", + "pdlHint": "Où trouver le n° de PDL ?", + "addressTitle": "Adresse du titulaire", + "address": "Numéro et voie", + "zipCode": "Code postal", + "city": "Ville", + "headConsent": "Vous allez partager vos données à la Métropole de Lyon. Elles seront directement transférées à Ecolyo à l'intérieur de votre cloud personnel, sans que la Métropole n'y accède ni ne les visualise.", + "textConsent": "Afin de vous offrir des fonctionnalités de visualisation et d'analyse, Ecolyo a besoin des données suivantes : ", + "consentLi1": "L'historique et le relevé de vos consommations quotidiennes en kWh", + "consentLi2": "L'historique et le relevé de vos consommations au pas de temps 30 minutes", + "consentLi3": "Les puissances maximales atteintes quotidiennement", + "consentLi4": "Les données contractuelles (début de contrat et puissance souscrite)", + "consentCheck1": "Je consens à partager les données personnelles ci-dessus pour une durée d'<span>un an</span>", + "consentCheck2": "J’atteste être le titulaire du point de livraison (PDL) renseigné à l’étape précédente", + "modalHint": { + "accessibility": "Titre de la modale", + "title": "Où trouver le n° de PDL ?", + "button": "J'ai compris", + "button-accessibility": "Bouton valider" } }, "grdfgrandlyon": { @@ -354,10 +364,10 @@ } }, "last_duel_modal": { - "title": "Félicitations !", - "subtitle": "Vous avez terminé tous les défis !", - "message1": "Nous travaillons actuellement à vous proposer de nouveaux défis.", - "message2": "Vous pouvez donner votre avis sur ce que vous aimeriez en cliquant sur la bulle jaune." + "title": "Félicitations !", + "subtitle": "Vous avez terminé tous les défis !", + "message1": "Nous travaillons actuellement à vous proposer de nouveaux défis.", + "message2": "Vous pouvez donner votre avis sur ce que vous aimeriez en cliquant sur la bulle jaune." }, "duel_empty_value_modal": { "title": "Oups !", @@ -737,6 +747,7 @@ "konnector_modal": { "loading_data": "Veuillez patienter, vos données sont en cours de chargement.", "loading_data_update": "Veuillez patienter, vos données sont en cours de mise à jour.", + "logging_txt": "Nous vérifions vos informations d'identité", "success_txt": "Félicitations !", "success_data_electricity": "Vos données de consommation d'électricité sont maintenant connectées à Ecolyo.", "success_data_water": "Vos données de consommation d'eau sont maintenant connectées à Ecolyo.", @@ -745,9 +756,19 @@ "success_data_update_water": "Vos données de consommation d'eau sont maintenant à jour dans Ecolyo.", "success_data_update_gas": "Vos données de consommation de gaz sont maintenant à jour dans Ecolyo.", "error_txt": "Aïe !", + "no_insee_code": "Il semblerait que votre code postal ne soit pas pris en compte par Ecolyo.", + "no_insee_code_txt": "Ecolyo est un service créé par la Métropole de Lyon et n’est aujourd’hui utilisable que par les habitants du territoire de la Métropôle de Lyon.", + "mismatch": { + "title": "Vos données n'ont pas pu être récupérées.", + "text1": "Vos nom et numéro de compteur ne correspondent plus. Merci de reconfigurer votre connecteur.", + "text2": "Reconfigurer mon connecteur ?", + "text3": "La reconfiguration de votre connecteur passe par sa suppression et sa nouvelle installation. Vos données seront conservées." + }, "error_data_electricity": "Un problème est survenu. Vos données de consommation d’électricité ne seront pas chargées.", "error_data_water": "Un problème est survenu. Vos données de consommation d’eau ne seront pas chargées.", "error_credentials_water": "Une erreur s'est glissée dans vos identifiants de connexion. Veuillez vérifier ces éléments et tenter de vous reconnecter. L'identifiant est un numéro à 7 chiffres (différent de votre numéro de contrat).", + "error_credentials_electricity": "Vos nom et adresse ne concordent pas avec le numéro de votre compteur.", + "error_credentials_electricity_2": "Nous ne pouvons vous donner accès aux données de consommation.", "error_credentials_update_water": "Une erreur s'est glissée dans vos identifiants de connexion. Veuillez vérifier ces éléments et tenter de vous reconnecter.", "error_credentials_update_electricity": "Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.", "error_credentials_update_gas": "Un problème a lieu lors de la récupération de vos données. Merci de supprimer votre connecteur et vous reconnecter.", @@ -757,6 +778,8 @@ "error_data_update_gas": "Un problème est survenu. Vos données de consommation de gaz n’ont pas été mises à jour.", "error_data_2": "Merci de réessayer plus tard.", "button_validate": "Ok", + "button_understood": "J'ai compris", + "button_come_back_later": "Revenir plus tard", "accessibility": { "window_title": "Fenêtre d'attente de connexion", "button_close": "Fermer la fenêtre" @@ -893,21 +916,6 @@ } }, "partner_connection_steps": { - "electricity": { - "step1": { - "info1": "Munissez-vous d’une <span>facture d’électricité</span> et d’un zeste de patience.", - "info2": "" - }, - "step2": { - "info1": "Si le contrat d’électricité est à votre nom, privilégiez l’identification <span>France connect.</span>", - "info2": "Sinon, munissez-vous de la <span>pièce d’identité du titulaire du contrat.</span>" - }, - "step3": { - "info1": "Une fois votre compte créé, <span>revenez sur Ecolyo</span> pour finaliser la connexion.", - "info2": "" - }, - "button_validate": "Aller sur Enedis" - }, "water": { "step1": { "info1": "Munissez-vous d’une <span>facture d'eau</span> et d’un zeste de patience.", diff --git a/src/migrations/migration.spec.ts b/src/migrations/migration.spec.ts index 3da001c93bff29afdb2c9af86276bb1bfcbd35bb..6bd3a670c4cfdc13c4328222b1eb0c0bf2a47069 100644 --- a/src/migrations/migration.spec.ts +++ b/src/migrations/migration.spec.ts @@ -19,6 +19,7 @@ describe('migration logger', () => { appVersion: '1.2.4', description: 'Removing mailToken from profil', docTypes: PROFILE_DOCTYPE, + releaseNotes: null, run: async (mockClient, docs: any[]): Promise<Profile[]> => { return docs.map(doc => { if (doc.mailToken) { @@ -61,6 +62,7 @@ describe('migration', () => { appVersion: '1.2.4', description: 'Removing mailToken from profil', docTypes: PROFILE_DOCTYPE, + releaseNotes: null, run: async (mockClient, docs: any[]): Promise<Profile[]> => { return docs.map(doc => { if (doc.GCUApprovalDate) { @@ -155,6 +157,7 @@ describe('migration', () => { appVersion: '1.2.4', description: 'Removing mailToken from profil', docTypes: PROFILE_DOCTYPE, + releaseNotes: null, run: async (mockClient, docs: any[]): Promise<Profile[]> => { return [] }, diff --git a/src/migrations/migration.ts b/src/migrations/migration.ts index d3f8b76da7d415214f6cc26360d32b436d03bcca..bf0ee97ec3cb664a4276d2e5e388729bf49bda97 100644 --- a/src/migrations/migration.ts +++ b/src/migrations/migration.ts @@ -168,7 +168,7 @@ export async function migrate( await updateSchemaVersion(_client, migration.targetSchemaVersion) break } - } catch (err) { + } catch (err: any) { console.error(err) result = { type: MIGRATION_RESULT_FAILED, diff --git a/src/migrations/migration.type.ts b/src/migrations/migration.type.ts index 505363b2f1ec2dc3a33e373f3473742fcd48478e..c5d87f581a0c47d93f38cf89f0b9a94fe45b9b79 100644 --- a/src/migrations/migration.type.ts +++ b/src/migrations/migration.type.ts @@ -4,7 +4,7 @@ import { Notes } from 'models/releaseNotes.model' type SchemaVersion = number export type MigrationData = { - errors: string[] + errors: any[] } export interface MigrationNoop extends MigrationData { type: 'MigrationNoop' diff --git a/src/models/account.model.ts b/src/models/account.model.ts index 0e6ede6d7865eb4c45c99eca0d0e4dd1a64966bf..d3905a953e9915e7022d6705684976f07d190310 100644 --- a/src/models/account.model.ts +++ b/src/models/account.model.ts @@ -3,18 +3,16 @@ export interface Account extends AccountAttributes { id?: string _rev?: string _type?: string - // eslint-disable-next-line @typescript-eslint/no-explicit-any cozyMetadata?: Record<string, any> } export interface AccountAttributes { account_type: string - auth?: AccountAuthData + auth?: AccountAuthData | AccountSgeData oauth?: AccountOAuthData identifier?: string state?: string | null name?: string - // eslint-disable-next-line @typescript-eslint/no-explicit-any oauth_callback_results?: Record<string, any> } @@ -30,3 +28,13 @@ export interface AccountOAuthData { expires_at?: string token_type?: string } + +//Temporary model +export interface AccountSgeData { + pointId: string + address: string + firstname: string + lastname: string + postalCode: string + city: string +} diff --git a/src/models/config.model.ts b/src/models/config.model.ts index 1a20aca95a1aead43e3caa664458385198b2089a..121b79ed624ddec8625dde974c258685585d19d0 100644 --- a/src/models/config.model.ts +++ b/src/models/config.model.ts @@ -1,7 +1,9 @@ +import { FluidSlugType } from 'enum/fluidSlug.enum' + export interface KonnectorConfig { name: string oauth: boolean - slug: string + slug: FluidSlugType cron?: string lastKnownCredentials?: string siteLink: string diff --git a/src/models/global.model.ts b/src/models/global.model.ts index afc5f92b5d4d8e15b44f06699755fa5c901afd3a..71d5bb8dd1935886b3083824457374b47ffbaa61 100644 --- a/src/models/global.model.ts +++ b/src/models/global.model.ts @@ -3,6 +3,7 @@ import { ScreenType } from 'enum/screen.enum' import { TermsStatus } from 'models' import { FluidStatus } from './fluid.model' import { ReleaseNotes } from './releaseNotes.model' +import { SgeStore } from './sgeStore.model' export interface GlobalState { screenType: ScreenType @@ -16,4 +17,5 @@ export interface GlobalState { fluidTypes: FluidType[] openPartnersIssueModal: boolean shouldRefreshConsent: boolean + sgeConnect: SgeStore } diff --git a/src/models/sgeStore.model.ts b/src/models/sgeStore.model.ts new file mode 100644 index 0000000000000000000000000000000000000000..59b30d9f42f3b5e912b4ad5b43838ce240e8f84e --- /dev/null +++ b/src/models/sgeStore.model.ts @@ -0,0 +1,12 @@ +export interface SgeStore { + currentStep: number + firstName: string + lastName: string + pdl: number | null + address: string + zipCode: number | null + city: string + dataConsent: boolean + pdlConfirm: boolean + shouldLaunchAccount: boolean +} diff --git a/src/models/trigger.model.ts b/src/models/trigger.model.ts index a8066eb4d9b971cb526c72eca3fa75b4a6beb064..04b54376c2c37c7cba6d8782745e80078504845f 100644 --- a/src/models/trigger.model.ts +++ b/src/models/trigger.model.ts @@ -4,7 +4,6 @@ export interface Trigger extends TriggerAttributes { prefix?: string debounce?: string options?: string | null - // eslint-disable-next-line @typescript-eslint/no-explicit-any cozyMetadata?: Record<string, any> } diff --git a/src/services/account.service.spec.ts b/src/services/account.service.spec.ts index b2bb202c90164bc13b905d4c0c0cc0a27e7048c0..26eb9eee1f200e121b0641297fced61dc99cb879 100644 --- a/src/services/account.service.spec.ts +++ b/src/services/account.service.spec.ts @@ -86,7 +86,7 @@ describe('Account service', () => { expect(result).toBe(null) }) it('should return the account linked to oldest trigger when several account', async () => { - const mockType = 'enedisgrandlyon' + const mockType = 'enedis-sge-grandlyon' const mockAccounts = accountsData mockAccounts[1].account_type = mockType mockAccounts[2].account_type = mockType @@ -107,7 +107,7 @@ describe('Account service', () => { describe('getAccountsByType method', () => { it('should return all accounts for a type when several account', async () => { - const mockType = 'enedisgrandlyon' + const mockType = 'enedis-sge-grandlyon' const mockAccounts = accountsData mockAccounts[1].account_type = mockType mockAccounts[2].account_type = mockType diff --git a/src/services/account.service.ts b/src/services/account.service.ts index f813c6dfe11a40a5e81f47569dce5b0748224382..4535ba52fa88efc4fb891b4bf29de15c0dee2fba 100644 --- a/src/services/account.service.ts +++ b/src/services/account.service.ts @@ -3,6 +3,7 @@ import { Account, AccountAttributes, AccountAuthData, + AccountSgeData, Konnector, Trigger, } from 'models' @@ -26,14 +27,14 @@ export default class AccountService { private buildAccountAttributes( konnector: Konnector, - authData: AccountAuthData + authData: AccountAuthData | AccountSgeData ): AccountAttributes { return build(konnector, authData) } public async createAccount( konnector: Konnector, - accountAuthData: AccountAuthData + accountAuthData: AccountAuthData | AccountSgeData ): Promise<Account> { const accountAttributes = this.buildAccountAttributes( konnector, @@ -54,9 +55,9 @@ export default class AccountService { public async getAccountByType(type: string): Promise<Account | null> { try { - const query: QueryDefinition = Q(ACCOUNTS_DOCTYPE) - // eslint-disable-next-line @typescript-eslint/camelcase - .where({ account_type: type }) + const query: QueryDefinition = Q(ACCOUNTS_DOCTYPE).where({ + account_type: type, + }) // .indexFields(['account_type']) const { data: accounts }: QueryResult<Account[]> = await this._client.query(query) @@ -100,9 +101,9 @@ export default class AccountService { public async getAccountsByType(type: string): Promise<Account[]> { try { - const query: QueryDefinition = Q(ACCOUNTS_DOCTYPE) - // eslint-disable-next-line @typescript-eslint/camelcase - .where({ account_type: type }) + const query: QueryDefinition = Q(ACCOUNTS_DOCTYPE).where({ + account_type: type, + }) // .indexFields(['account_type']) const { data: accounts }: QueryResult<Account[]> = await this._client.query(query) @@ -135,7 +136,6 @@ export default class AccountService { public async createIndexAccount(): Promise<[]> { const query: QueryDefinition = Q(ACCOUNTS_DOCTYPE) - // eslint-disable-next-line @typescript-eslint/camelcase .where({ account_type: 'index' }) // .indexFields(['account_type']) .limitBy(1) diff --git a/src/services/connection.service.ts b/src/services/connection.service.ts index 5c9a4829dee9dd1e0c090e04f82929c137958605..fb8563366c2a10cc75539b2c8a7b226a5cbd1200 100644 --- a/src/services/connection.service.ts +++ b/src/services/connection.service.ts @@ -1,8 +1,15 @@ import { Client } from 'cozy-client' -import { Account, AccountAuthData, Konnector, Trigger } from 'models' +import { + Account, + AccountAuthData, + AccountSgeData, + Konnector, + Trigger, +} from 'models' import AccountService from 'services/account.service' import TriggerService from 'services/triggers.service' import KonnectorService from 'services/konnector.service' +import { SgeStore } from 'models/sgeStore.model' export default class ConnectionService { private _client: Client @@ -13,8 +20,8 @@ export default class ConnectionService { public async connectNewUser( konnectorId: string, - login: string, - password: string + eglAuthData?: AccountAuthData, + sgeAuthData?: SgeStore ): Promise<{ account: Account; trigger: Trigger }> { // Retrieve konnector const konnectorService = new KonnectorService(this._client) @@ -25,9 +32,22 @@ export default class ConnectionService { throw new Error(`Could not find konnector for ${konnectorId}`) } // Creation of the account linked to the konnector retrieved - const accountAuthData: AccountAuthData = { - login: login, - password: password, + let accountAuthData: AccountAuthData | AccountSgeData + if (eglAuthData) { + accountAuthData = { + login: eglAuthData.login, + password: eglAuthData.password, + } as AccountAuthData + } else { + // No login and password for Sge account + accountAuthData = { + pointId: sgeAuthData?.pdl ? sgeAuthData.pdl.toString() : '', + firstname: sgeAuthData?.firstName, + lastname: sgeAuthData?.lastName, + address: sgeAuthData?.address, + postalCode: sgeAuthData?.zipCode ? sgeAuthData.zipCode.toString() : '', + city: sgeAuthData?.city, + } as AccountSgeData } const accountService = new AccountService(this._client) const account: Account = await accountService.createAccount( diff --git a/src/services/fluid.service.spec.ts b/src/services/fluid.service.spec.ts index 062014b5cbe5f7212079f08311af489529e39fb9..e20c2f3fec6fe82f5afa41a1e64ab84f916a3f38 100644 --- a/src/services/fluid.service.spec.ts +++ b/src/services/fluid.service.spec.ts @@ -93,8 +93,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -179,8 +179,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -265,8 +265,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -351,8 +351,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -438,8 +438,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -533,8 +533,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -567,8 +567,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -601,8 +601,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -635,8 +635,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -673,8 +673,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, @@ -730,8 +730,8 @@ describe('FLuid service', () => { isUpdating: false, konnectorConfig: { name: 'Enedis', - oauth: true, - slug: 'enedisgrandlyon', + oauth: false, + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, diff --git a/src/services/konnector.service.spec.ts b/src/services/konnector.service.spec.ts index f5c683ac4c29066aa7441d0065f97c33a9e29797..053c06e2de7a3aef9287170768d20050d16f08e9 100644 --- a/src/services/konnector.service.spec.ts +++ b/src/services/konnector.service.spec.ts @@ -30,7 +30,7 @@ describe('KonnectorService service', () => { skip: 0, } mockClient.query.mockResolvedValueOnce(mockQueryResult) - const result = await konnectorService.getKonnector('enedisgrandlyon') + const result = await konnectorService.getKonnector('enedis-sge-grandlyon') expect(result).toEqual(konnectorsData[0]) }) @@ -42,7 +42,7 @@ describe('KonnectorService service', () => { skip: 0, } mockClient.query.mockResolvedValueOnce(mockQueryResult) - const result = await konnectorService.getKonnector('enedisgrandlyon') + const result = await konnectorService.getKonnector('enedis-sge-grandlyon') expect(result).toBeNull() }) }) diff --git a/src/store/global/global.actions.ts b/src/store/global/global.actions.ts index 294d00f0a458c5eb7156ac7377d99f8cc3799b5a..838a477930a5ea6ad08b7b29749b96cb9a46e87b 100644 --- a/src/store/global/global.actions.ts +++ b/src/store/global/global.actions.ts @@ -2,6 +2,7 @@ import { FluidType } from 'enum/fluid.enum' import { ScreenType } from 'enum/screen.enum' import { FluidConnection, FluidStatus, TermsStatus } from 'models' import { Notes } from 'models/releaseNotes.model' +import { SgeStore } from 'models/sgeStore.model' export const CHANGE_SCREEN_TYPE = 'CHANGE_SCREEN_TYPE' export const SHOW_RELEASE_NOTES = 'SHOW_RELEASE_NOTES' @@ -17,6 +18,7 @@ export const UPDATE_FLUID_CONNECTION = 'UPDATE_FLUID_CONNECTION' export const UPDATE_TERMS_VALIDATION = 'UPDATE_TERMS_VALIDATION' export const SET_PARTNERS_ISSUE = 'SET_PARTNERS_ISSUE' export const SET_SHOULD_REFRESH_CONSENT = 'SET_SHOULD_REFRESH_CONSENT' +export const UPDATE_SGE_CONNECT = 'UPDATE_SGE_CONNECT' interface ChangeScreenType { type: typeof CHANGE_SCREEN_TYPE payload?: ScreenType @@ -71,6 +73,10 @@ interface SetShouldRefreshConsent { type: typeof SET_SHOULD_REFRESH_CONSENT payload?: boolean } +interface UpdateSGEConnect { + type: typeof UPDATE_SGE_CONNECT + payload?: SgeStore +} export type GlobalActionTypes = | ChangeScreenType @@ -84,6 +90,7 @@ export type GlobalActionTypes = | ShowReleaseNotes | SetPartnersIssue | SetShouldRefreshConsent + | UpdateSGEConnect export function changeScreenType(screenType: ScreenType): GlobalActionTypes { return { @@ -177,3 +184,10 @@ export function setShouldRefreshConsent( payload: shouldRefreshConsent, } } + +export function updateSgeStore(sgeStore: SgeStore): GlobalActionTypes { + return { + type: UPDATE_SGE_CONNECT, + payload: sgeStore, + } +} diff --git a/src/store/global/global.reducer.spec.ts b/src/store/global/global.reducer.spec.ts index 23cb3d1d1343eef67f175990ec2a368c0bfa059c..03b3919361f0927ecb5b6d82bcdd148bed325d98 100644 --- a/src/store/global/global.reducer.spec.ts +++ b/src/store/global/global.reducer.spec.ts @@ -30,7 +30,6 @@ const mockDataDates: (DateTime | null)[] = [ describe('global reducer', () => { it('should return the initial state', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any const result = globalReducer(undefined as any, { type: 'default' }) expect(result).toEqual(mockInitialGlobalState) }) @@ -142,7 +141,7 @@ describe('global reducer', () => { konnectorConfig: { name: 'Enedis', oauth: true, - slug: 'enedisgrandlyon', + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-particulier.enedis.fr/donnees/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, diff --git a/src/store/global/global.reducer.ts b/src/store/global/global.reducer.ts index 143410b6af1e659743062bf72b53a20353230365..8f897c2380eede3d1c162ed551cdc301f1bfb854 100644 --- a/src/store/global/global.reducer.ts +++ b/src/store/global/global.reducer.ts @@ -12,10 +12,12 @@ import { SHOW_RELEASE_NOTES, SET_PARTNERS_ISSUE, SET_SHOULD_REFRESH_CONSENT, + UPDATE_SGE_CONNECT, } from 'store/global/global.actions' import { FluidStatus, GlobalState } from 'models' import { ScreenType } from 'enum/screen.enum' import { FluidState, FluidType } from 'enum/fluid.enum' +import { FluidSlugType } from 'enum/fluidSlug.enum' const initialState: GlobalState = { screenType: ScreenType.MOBILE, @@ -52,7 +54,7 @@ const initialState: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.ELECTRICITY, siteLink: '', activation: '', }, @@ -73,7 +75,7 @@ const initialState: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.WATER, siteLink: '', activation: '', }, @@ -94,7 +96,7 @@ const initialState: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.GAS, siteLink: '', activation: '', }, @@ -104,6 +106,18 @@ const initialState: GlobalState = { fluidTypes: [], openPartnersIssueModal: false, shouldRefreshConsent: false, + sgeConnect: { + currentStep: 0, + firstName: '', + lastName: '', + pdl: null, + address: '', + zipCode: null, + city: '', + dataConsent: false, + pdlConfirm: false, + shouldLaunchAccount: false, + }, } const getFluidTypesFromStatus = (fluidStatus: FluidStatus[]): FluidType[] => { @@ -215,7 +229,13 @@ export const globalReducer: Reducer<GlobalState> = ( } else { return state } - + case UPDATE_SGE_CONNECT: + if (action.payload != undefined) + return { + ...state, + sgeConnect: action.payload, + } + return state default: return state } diff --git a/src/store/index.ts b/src/store/index.ts index 670d74d464eb86d305f3c090be9a50072285d95c..b8b4b1e9bab40858d111966aa65880d517a4dee8 100644 --- a/src/store/index.ts +++ b/src/store/index.ts @@ -1,4 +1,3 @@ -/* eslint-disable @typescript-eslint/no-explicit-any */ import { createStore, combineReducers, diff --git a/src/store/profileType/profileType.reducer.spec.ts b/src/store/profileType/profileType.reducer.spec.ts index 243bcce57f6be41cbc2aa8e6622ad4435352d7c8..ac723528428d2b3d828d14536b6b01b63b518976 100644 --- a/src/store/profileType/profileType.reducer.spec.ts +++ b/src/store/profileType/profileType.reducer.spec.ts @@ -5,7 +5,6 @@ import { profileTypeData } from '../../../tests/__mocks__/profileType.mock' describe('profile reducer', () => { it('should return the initial state', () => { - // eslint-disable-next-line @typescript-eslint/no-explicit-any const result = profileTypeReducer(undefined as any, { type: 'default' }) expect(result).toEqual(mockInitialProfileTypeState) }) diff --git a/src/store/profileType/profileType.reducer.ts b/src/store/profileType/profileType.reducer.ts index 95a0dc1937eda85ef6ec8edc0b8295ca2478409c..a5debb195e059fabf8567d50e406887ea45b5c43 100644 --- a/src/store/profileType/profileType.reducer.ts +++ b/src/store/profileType/profileType.reducer.ts @@ -40,6 +40,7 @@ const initialState: ProfileType = { hotWaterFluid: FluidType.ELECTRICITY, cookingFluid: FluidType.ELECTRICITY, updateDate: DateTime.fromISO('0000-01-01T00:00:00.000Z'), + equipments: [], } export const profileTypeReducer: Reducer<ProfileType> = ( diff --git a/src/styles/base/_color.scss b/src/styles/base/_color.scss index 8e6b7a884acf9aa1f24c963438205008fb903821..354840a88344a0acb36fdd70c1f98a31b8ab0b8b 100644 --- a/src/styles/base/_color.scss +++ b/src/styles/base/_color.scss @@ -9,7 +9,7 @@ $dark-background: radial-gradient( #2a2b30 0%, #1b1c22 100% ); - +$bottom-bar-grey: #32343d; /** RED **/ $red-primary: #d25959; diff --git a/src/styles/base/_layout.scss b/src/styles/base/_layout.scss index 78f6fb950cceaa5783949454e1b89d4cc1458004..67222d599313dd7193c972075ffd55534f62c78d 100644 --- a/src/styles/base/_layout.scss +++ b/src/styles/base/_layout.scss @@ -3,11 +3,11 @@ @import '../base/z-index'; html { - background: $dark-2; + background: $dark-light-2; } body { - background: $dark-2; + background: $dark-light-2; overflow: unset !important; } @@ -35,7 +35,7 @@ body { [role='banner'] .coz-bar-container { background-color: $white; @media #{$large-phone} { - padding: 0 0 0 0; + padding: 0.6rem 0 0 0; background-color: unset; } } @@ -66,9 +66,9 @@ body { } .header-top { background: radial-gradient( - 74.83% 76.97% at 50% 13.64%, - #343641 0%, - #1b1c22 100% + circle, + rgba(52, 54, 65, 1) 0%, + rgba(27, 28, 34, 1) 100% ); width: 100%; .header-text { diff --git a/src/styles/base/_mixins.scss b/src/styles/base/_mixins.scss index ebfefb8f4bfdc81ef48abd3c0f21ef652aeddc3b..40c36f8691099ad1bba4bcf60d374f515e290a9c 100644 --- a/src/styles/base/_mixins.scss +++ b/src/styles/base/_mixins.scss @@ -25,3 +25,53 @@ cursor: not-allowed; } } +@mixin checkBox() { + .checkbox { + margin: 0.5rem 0; + display: flex; + align-items: center; + &:first-of-type { + margin-top: 1.5rem; + } + input { + margin: 0.5rem 1rem 0.5rem 0.5rem; + appearance: none; + -moz-appearance: none; + -webkit-appearance: none; + width: 1.45rem; + height: 1.45rem; + min-width: 1.45rem; + min-height: 1.45rem; + background: $dark-background; + position: relative; + border: solid 2px $gold-shadow; + cursor: pointer; + } + } + .answer-checked { + input { + &:before, + &:after { + content: ''; + position: absolute; + display: inline-block; + background: $gold-shadow; + border-radius: 0.5rem; + } + &:before { + width: 3px; + height: 12px; + left: 10px; + top: 4px; + transform: rotate(41deg); + } + &:after { + width: 3px; + height: 6px; + left: 5px; + top: 8px; + transform: rotate(133deg); + } + } + } +} diff --git a/src/styles/index.css b/src/styles/index.css index 12bc8275f8f7f3920e5f52331cefe9b3d1f9c663..44d1191d8c9a323742926a9cb4039508ea1c66e3 100644 --- a/src/styles/index.css +++ b/src/styles/index.css @@ -14,13 +14,13 @@ /** App colors **/ /** TABS GRADIENT **/ /** SCROLLBAR **/ -@import url('https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap'); +@import url("https://fonts.googleapis.com/css2?family=Lato:wght@400;700&display=swap"); html { - background: #1b1c22; + background: #121212; } body { - background: #1b1c22; + background: #121212; overflow: unset !important; } @@ -41,18 +41,18 @@ body { justify-content: center; margin-left: 0; } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { .cozy-bar { margin-left: 1.25rem; } } -[role='banner'] .coz-bar-container { +[role=banner] .coz-bar-container { background-color: #ffffff; } -@media only screen and (max-width: 768px) { - [role='banner'] .coz-bar-container { - padding: 0 0 0 0; +@media only screen and (max-width : 768px) { + [role=banner] .coz-bar-container { + padding: 0.6rem 0 0 0; background-color: unset; } } @@ -81,17 +81,13 @@ body { top: 48px; left: 0; } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { .header { top: 0; } } .header .header-top { - background: radial-gradient( - 74.83% 76.97% at 50% 13.64%, - #343641 0%, - #1b1c22 100% - ); + background: radial-gradient(circle, rgb(52, 54, 65) 0%, rgb(27, 28, 34) 100%); width: 100%; } .header .header-top .header-text { @@ -103,12 +99,12 @@ body { display: flex; flex-direction: column; } -@media only screen and (max-width: 1023px) { +@media only screen and (max-width : 1023px) { .header .header-content { margin: 0; } } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { .header .header-content { margin: 60px 0 0 0; } @@ -133,7 +129,7 @@ body { .header .header-content .header-content-top .header-back-button { padding: 0 0.75rem; } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { .header .header-content .header-content-top .header-text { padding: 0 1rem 1rem 1rem; color: #e0e0e0; @@ -165,18 +161,18 @@ body { margin-top: 1rem; } -[role='main'] { +[role=main] { /* width */ /* Track */ /* Handle */ } -[role='main']::-webkit-scrollbar { +[role=main]::-webkit-scrollbar { width: 10px; } -[role='main']::-webkit-scrollbar-track { +[role=main]::-webkit-scrollbar-track { background: #3e4045; } -[role='main']::-webkit-scrollbar-thumb { +[role=main]::-webkit-scrollbar-thumb { background: #6f7074; } @@ -244,21 +240,12 @@ p { margin-right: 0.8rem; } -.text-10, -.text-10-italic, -.text-10-bold, -.text-10-bold-capitalize, -.text-10-bold-uppercase, -.text-10-normal, -.text-10-normal-150, -.text-10-normal-uppercase { +.text-10, .text-10-italic, .text-10-bold, .text-10-bold-capitalize, .text-10-bold-uppercase, .text-10-normal, .text-10-normal-150, .text-10-normal-uppercase { font-style: normal; font-size: 0.625rem; line-height: 120%; } -.text-10-normal, -.text-10-normal-150, -.text-10-normal-uppercase { +.text-10-normal, .text-10-normal-150, .text-10-normal-uppercase { font-weight: normal; } .text-10-normal-uppercase { @@ -267,9 +254,7 @@ p { .text-10-normal-150 { line-height: 150%; } -.text-10-bold, -.text-10-bold-capitalize, -.text-10-bold-uppercase { +.text-10-bold, .text-10-bold-capitalize, .text-10-bold-uppercase { font-weight: 700; } .text-10-bold-uppercase { @@ -283,21 +268,12 @@ p { font-weight: normal; } -.text-14, -.text-14-italic, -.text-14-bold, -.text-14-bold-capitalize, -.text-14-bold-uppercase, -.text-14-normal, -.text-14-normal-150, -.text-14-normal-uppercase { +.text-14, .text-14-italic, .text-14-bold, .text-14-bold-capitalize, .text-14-bold-uppercase, .text-14-normal, .text-14-normal-150, .text-14-normal-uppercase { font-style: normal; font-size: 0.875rem; line-height: 120%; } -.text-14-normal, -.text-14-normal-150, -.text-14-normal-uppercase { +.text-14-normal, .text-14-normal-150, .text-14-normal-uppercase { font-weight: normal; } .text-14-normal-uppercase { @@ -306,9 +282,7 @@ p { .text-14-normal-150 { line-height: 150%; } -.text-14-bold, -.text-14-bold-capitalize, -.text-14-bold-uppercase { +.text-14-bold, .text-14-bold-capitalize, .text-14-bold-uppercase { font-weight: 700; } .text-14-bold-uppercase { @@ -322,21 +296,12 @@ p { font-weight: normal; } -.text-15, -.text-15-italic, -.text-15-bold, -.text-15-bold-capitalize, -.text-15-bold-uppercase, -.text-15-normal, -.text-15-normal-150, -.text-15-normal-uppercase { +.text-15, .text-15-italic, .text-15-bold, .text-15-bold-capitalize, .text-15-bold-uppercase, .text-15-normal, .text-15-normal-150, .text-15-normal-uppercase { font-style: normal; font-size: 0.938rem; line-height: 120%; } -.text-15-normal, -.text-15-normal-150, -.text-15-normal-uppercase { +.text-15-normal, .text-15-normal-150, .text-15-normal-uppercase { font-weight: normal; } .text-15-normal-uppercase { @@ -345,9 +310,7 @@ p { .text-15-normal-150 { line-height: 150%; } -.text-15-bold, -.text-15-bold-capitalize, -.text-15-bold-uppercase { +.text-15-bold, .text-15-bold-capitalize, .text-15-bold-uppercase { font-weight: 700; } .text-15-bold-uppercase { @@ -361,21 +324,12 @@ p { font-weight: normal; } -.text-16, -.text-16-italic, -.text-16-bold, -.text-16-bold-capitalize, -.text-16-bold-uppercase, -.text-16-normal, -.text-16-normal-150, -.text-16-normal-uppercase { +.text-16, .text-16-italic, .text-16-bold, .text-16-bold-capitalize, .text-16-bold-uppercase, .text-16-normal, .text-16-normal-150, .text-16-normal-uppercase { font-style: normal; font-size: 1rem; line-height: 120%; } -.text-16-normal, -.text-16-normal-150, -.text-16-normal-uppercase { +.text-16-normal, .text-16-normal-150, .text-16-normal-uppercase { font-weight: normal; } .text-16-normal-uppercase { @@ -384,9 +338,7 @@ p { .text-16-normal-150 { line-height: 150%; } -.text-16-bold, -.text-16-bold-capitalize, -.text-16-bold-uppercase { +.text-16-bold, .text-16-bold-capitalize, .text-16-bold-uppercase { font-weight: 700; } .text-16-bold-uppercase { @@ -400,21 +352,12 @@ p { font-weight: normal; } -.text-18, -.text-18-italic, -.text-18-bold, -.text-18-bold-capitalize, -.text-18-bold-uppercase, -.text-18-normal, -.text-18-normal-150, -.text-18-normal-uppercase { +.text-18, .text-18-italic, .text-18-bold, .text-18-bold-capitalize, .text-18-bold-uppercase, .text-18-normal, .text-18-normal-150, .text-18-normal-uppercase { font-style: normal; font-size: 1.125rem; line-height: 120%; } -.text-18-normal, -.text-18-normal-150, -.text-18-normal-uppercase { +.text-18-normal, .text-18-normal-150, .text-18-normal-uppercase { font-weight: normal; } .text-18-normal-uppercase { @@ -423,9 +366,7 @@ p { .text-18-normal-150 { line-height: 150%; } -.text-18-bold, -.text-18-bold-capitalize, -.text-18-bold-uppercase { +.text-18-bold, .text-18-bold-capitalize, .text-18-bold-uppercase { font-weight: 700; } .text-18-bold-uppercase { @@ -439,21 +380,12 @@ p { font-weight: normal; } -.text-19, -.text-19-italic, -.text-19-bold, -.text-19-bold-capitalize, -.text-19-bold-uppercase, -.text-19-normal, -.text-19-normal-150, -.text-19-normal-uppercase { +.text-19, .text-19-italic, .text-19-bold, .text-19-bold-capitalize, .text-19-bold-uppercase, .text-19-normal, .text-19-normal-150, .text-19-normal-uppercase { font-style: normal; font-size: 1.188rem; line-height: 120%; } -.text-19-normal, -.text-19-normal-150, -.text-19-normal-uppercase { +.text-19-normal, .text-19-normal-150, .text-19-normal-uppercase { font-weight: normal; } .text-19-normal-uppercase { @@ -462,9 +394,7 @@ p { .text-19-normal-150 { line-height: 150%; } -.text-19-bold, -.text-19-bold-capitalize, -.text-19-bold-uppercase { +.text-19-bold, .text-19-bold-capitalize, .text-19-bold-uppercase { font-weight: 700; } .text-19-bold-uppercase { @@ -478,21 +408,12 @@ p { font-weight: normal; } -.text-20, -.text-20-italic, -.text-20-bold, -.text-20-bold-capitalize, -.text-20-bold-uppercase, -.text-20-normal, -.text-20-normal-150, -.text-20-normal-uppercase { +.text-20, .text-20-italic, .text-20-bold, .text-20-bold-capitalize, .text-20-bold-uppercase, .text-20-normal, .text-20-normal-150, .text-20-normal-uppercase { font-style: normal; font-size: 1.25rem; line-height: 120%; } -.text-20-normal, -.text-20-normal-150, -.text-20-normal-uppercase { +.text-20-normal, .text-20-normal-150, .text-20-normal-uppercase { font-weight: normal; } .text-20-normal-uppercase { @@ -501,9 +422,7 @@ p { .text-20-normal-150 { line-height: 150%; } -.text-20-bold, -.text-20-bold-capitalize, -.text-20-bold-uppercase { +.text-20-bold, .text-20-bold-capitalize, .text-20-bold-uppercase { font-weight: 700; } .text-20-bold-uppercase { @@ -517,21 +436,12 @@ p { font-weight: normal; } -.text-21, -.text-21-italic, -.text-21-bold, -.text-21-bold-capitalize, -.text-21-bold-uppercase, -.text-21-normal, -.text-21-normal-150, -.text-21-normal-uppercase { +.text-21, .text-21-italic, .text-21-bold, .text-21-bold-capitalize, .text-21-bold-uppercase, .text-21-normal, .text-21-normal-150, .text-21-normal-uppercase { font-style: normal; font-size: 1.313rem; line-height: 120%; } -.text-21-normal, -.text-21-normal-150, -.text-21-normal-uppercase { +.text-21-normal, .text-21-normal-150, .text-21-normal-uppercase { font-weight: normal; } .text-21-normal-uppercase { @@ -540,9 +450,7 @@ p { .text-21-normal-150 { line-height: 150%; } -.text-21-bold, -.text-21-bold-capitalize, -.text-21-bold-uppercase { +.text-21-bold, .text-21-bold-capitalize, .text-21-bold-uppercase { font-weight: 700; } .text-21-bold-uppercase { @@ -556,21 +464,12 @@ p { font-weight: normal; } -.text-22, -.text-22-italic, -.text-22-bold, -.text-22-bold-capitalize, -.text-22-bold-uppercase, -.text-22-normal, -.text-22-normal-150, -.text-22-normal-uppercase { +.text-22, .text-22-italic, .text-22-bold, .text-22-bold-capitalize, .text-22-bold-uppercase, .text-22-normal, .text-22-normal-150, .text-22-normal-uppercase { font-style: normal; font-size: 1.375rem; line-height: 120%; } -.text-22-normal, -.text-22-normal-150, -.text-22-normal-uppercase { +.text-22-normal, .text-22-normal-150, .text-22-normal-uppercase { font-weight: normal; } .text-22-normal-uppercase { @@ -579,9 +478,7 @@ p { .text-22-normal-150 { line-height: 150%; } -.text-22-bold, -.text-22-bold-capitalize, -.text-22-bold-uppercase { +.text-22-bold, .text-22-bold-capitalize, .text-22-bold-uppercase { font-weight: 700; } .text-22-bold-uppercase { @@ -595,115 +492,68 @@ p { font-weight: normal; } -.text-24, -.text-24-italic, -.text-24-bold, -.text-24-bold-capitalize, -.text-24-bold-uppercase, -.text-24-normal, -.text-24-normal-150, -.text-24-normal-uppercase { +.text-24, .text-24-italic, .text-24-bold, .text-24-bold-capitalize, .text-24-bold-uppercase, .text-24-normal, .text-24-normal-150, .text-24-normal-uppercase { font-style: normal; font-size: 1.5rem; line-height: 120%; } -/* line 52, src/styles/base/_typography.scss */ -.text-24-normal, -.text-24-normal-uppercase, -.text-24-normal-150 { +.text-24-normal, .text-24-normal-150, .text-24-normal-uppercase { font-weight: normal; } -/* line 55, src/styles/base/_typography.scss */ .text-24-normal-uppercase { text-transform: uppercase; } -/* line 59, src/styles/base/_typography.scss */ .text-24-normal-150 { line-height: 150%; } -/* line 64, src/styles/base/_typography.scss */ -.text-24-bold, -.text-24-bold-uppercase, -.text-24-bold-capitalize { +.text-24-bold, .text-24-bold-capitalize, .text-24-bold-uppercase { font-weight: 700; } -/* line 67, src/styles/base/_typography.scss */ .text-24-bold-uppercase { text-transform: uppercase; } -/* line 71, src/styles/base/_typography.scss */ .text-24-bold-capitalize { text-transform: capitalize; } -/* line 76, src/styles/base/_typography.scss */ .text-24-italic { font-style: italic; font-weight: normal; } -/* line 48, src/styles/base/_typography.scss */ -.text-26, -.text-26-normal, -.text-26-normal-uppercase, -.text-26-normal-150, -.text-26-bold, -.text-26-bold-uppercase, -.text-26-bold-capitalize, -.text-26-italic { +.text-26, .text-26-italic, .text-26-bold, .text-26-bold-capitalize, .text-26-bold-uppercase, .text-26-normal, .text-26-normal-150, .text-26-normal-uppercase { font-style: normal; font-size: 1.625rem; line-height: 120%; } -/* line 52, src/styles/base/_typography.scss */ -.text-26-normal, -.text-26-normal-uppercase, -.text-26-normal-150 { +.text-26-normal, .text-26-normal-150, .text-26-normal-uppercase { font-weight: normal; } -/* line 55, src/styles/base/_typography.scss */ .text-26-normal-uppercase { text-transform: uppercase; } -/* line 59, src/styles/base/_typography.scss */ .text-26-normal-150 { line-height: 150%; } -/* line 64, src/styles/base/_typography.scss */ -.text-26-bold, -.text-26-bold-uppercase, -.text-26-bold-capitalize { +.text-26-bold, .text-26-bold-capitalize, .text-26-bold-uppercase { font-weight: 700; } -/* line 67, src/styles/base/_typography.scss */ .text-26-bold-uppercase { text-transform: uppercase; } -/* line 71, src/styles/base/_typography.scss */ .text-26-bold-capitalize { text-transform: capitalize; } -/* line 76, src/styles/base/_typography.scss */ .text-26-italic { font-style: italic; font-weight: normal; } -/* line 48, src/styles/base/_typography.scss */ -.text-28, -.text-28-normal, -.text-28-normal-uppercase, -.text-28-normal-150, -.text-28-bold, -.text-28-bold-uppercase, -.text-28-bold-capitalize, -.text-28-italic { +.text-28, .text-28-italic, .text-28-bold, .text-28-bold-capitalize, .text-28-bold-uppercase, .text-28-normal, .text-28-normal-150, .text-28-normal-uppercase { font-style: normal; font-size: 1.75rem; line-height: 120%; } -.text-28-normal, -.text-28-normal-150, -.text-28-normal-uppercase { +.text-28-normal, .text-28-normal-150, .text-28-normal-uppercase { font-weight: normal; } .text-28-normal-uppercase { @@ -712,9 +562,7 @@ p { .text-28-normal-150 { line-height: 150%; } -.text-28-bold, -.text-28-bold-capitalize, -.text-28-bold-uppercase { +.text-28-bold, .text-28-bold-capitalize, .text-28-bold-uppercase { font-weight: 700; } .text-28-bold-uppercase { @@ -728,21 +576,12 @@ p { font-weight: normal; } -.text-36, -.text-36-italic, -.text-36-bold, -.text-36-bold-capitalize, -.text-36-bold-uppercase, -.text-36-normal, -.text-36-normal-150, -.text-36-normal-uppercase { +.text-36, .text-36-italic, .text-36-bold, .text-36-bold-capitalize, .text-36-bold-uppercase, .text-36-normal, .text-36-normal-150, .text-36-normal-uppercase { font-style: normal; font-size: 2.25rem; line-height: 120%; } -.text-36-normal, -.text-36-normal-150, -.text-36-normal-uppercase { +.text-36-normal, .text-36-normal-150, .text-36-normal-uppercase { font-weight: normal; } .text-36-normal-uppercase { @@ -751,9 +590,7 @@ p { .text-36-normal-150 { line-height: 150%; } -.text-36-bold, -.text-36-bold-capitalize, -.text-36-bold-uppercase { +.text-36-bold, .text-36-bold-capitalize, .text-36-bold-uppercase { font-weight: 700; } .text-36-bold-uppercase { @@ -821,7 +658,7 @@ p { font-size: 1rem; line-height: 120%; } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { .chart-ticks-x-text { font-size: 0.685rem; } @@ -834,7 +671,7 @@ p { font-size: 0.9rem; line-height: 120%; } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { .chart-ticks-y-text { font-size: 0.75rem; } @@ -1168,12 +1005,7 @@ p { /** TABS GRADIENT **/ /** SCROLLBAR **/ button.btn-highlight { - background: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(226, 137, 4, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #f1c017; + background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017; background-color: #e3b82a; border: none; border-radius: 2px; @@ -1185,10 +1017,7 @@ button.btn-highlight { button.btn-highlight span:first-child { color: #000000; } -button.btn-highlight:hover, -button.btn-highlight:focus, -button.btn-highlight.active, -button.btn-highlight:disabled { +button.btn-highlight:hover, button.btn-highlight:focus, button.btn-highlight.active, button.btn-highlight:disabled { background-color: #b89318; } button.btn-highlight:disabled { @@ -1207,16 +1036,10 @@ button.btn-primary-positive { button.btn-primary-positive span:first-child { color: #e3b82a; } -button.btn-primary-positive:hover, -button.btn-primary-positive:focus, -button.btn-primary-positive.active, -button.btn-primary-positive:disabled { +button.btn-primary-positive:hover, button.btn-primary-positive:focus, button.btn-primary-positive.active, button.btn-primary-positive:disabled { background-color: rgba(18, 18, 18, 0.2); } -button.btn-primary-positive:hover span:first-child, -button.btn-primary-positive:focus span:first-child, -button.btn-primary-positive.active span:first-child, -button.btn-primary-positive:disabled span:first-child { +button.btn-primary-positive:hover span:first-child, button.btn-primary-positive:focus span:first-child, button.btn-primary-positive.active span:first-child, button.btn-primary-positive:disabled span:first-child { color: rgba(227, 184, 42, 0.7); } button.btn-primary-positive:disabled { @@ -1235,16 +1058,10 @@ button.btn-primary-negative { button.btn-primary-negative span:first-child { color: #e3b82a; } -button.btn-primary-negative:hover, -button.btn-primary-negative:focus, -button.btn-primary-negative.active, -button.btn-primary-negative:disabled { +button.btn-primary-negative:hover, button.btn-primary-negative:focus, button.btn-primary-negative.active, button.btn-primary-negative:disabled { background-color: rgba(123, 123, 123, 0.2); } -button.btn-primary-negative:hover span:first-child, -button.btn-primary-negative:focus span:first-child, -button.btn-primary-negative.active span:first-child, -button.btn-primary-negative:disabled span:first-child { +button.btn-primary-negative:hover span:first-child, button.btn-primary-negative:focus span:first-child, button.btn-primary-negative.active span:first-child, button.btn-primary-negative:disabled span:first-child { color: rgba(227, 184, 42, 0.7); } button.btn-primary-negative:disabled { @@ -1263,16 +1080,10 @@ button.btn-secondary-positive { button.btn-secondary-positive span:first-child { color: #e0e0e0; } -button.btn-secondary-positive:hover, -button.btn-secondary-positive:focus, -button.btn-secondary-positive.active, -button.btn-secondary-positive:disabled { +button.btn-secondary-positive:hover, button.btn-secondary-positive:focus, button.btn-secondary-positive.active, button.btn-secondary-positive:disabled { background-color: rgba(18, 18, 18, 0.2); } -button.btn-secondary-positive:hover span:first-child, -button.btn-secondary-positive:focus span:first-child, -button.btn-secondary-positive.active span:first-child, -button.btn-secondary-positive:disabled span:first-child { +button.btn-secondary-positive:hover span:first-child, button.btn-secondary-positive:focus span:first-child, button.btn-secondary-positive.active span:first-child, button.btn-secondary-positive:disabled span:first-child { color: rgba(224, 224, 224, 0.7); } button.btn-secondary-positive:disabled { @@ -1291,16 +1102,10 @@ button.btn-secondary-negative { button.btn-secondary-negative span:first-child { color: #e0e0e0; } -button.btn-secondary-negative:hover, -button.btn-secondary-negative:focus, -button.btn-secondary-negative.active, -button.btn-secondary-negative:disabled { +button.btn-secondary-negative:hover, button.btn-secondary-negative:focus, button.btn-secondary-negative.active, button.btn-secondary-negative:disabled { background-color: rgba(123, 123, 123, 0.2); } -button.btn-secondary-negative:hover span:first-child, -button.btn-secondary-negative:focus span:first-child, -button.btn-secondary-negative.active span:first-child, -button.btn-secondary-negative:disabled span:first-child { +button.btn-secondary-negative:hover span:first-child, button.btn-secondary-negative:focus span:first-child, button.btn-secondary-negative.active span:first-child, button.btn-secondary-negative:disabled span:first-child { color: rgba(224, 224, 224, 0.7); } button.btn-secondary-negative:disabled { @@ -1319,10 +1124,7 @@ button.btn-duel-off { button.btn-duel-off span:first-child { color: #ffffff; } -button.btn-duel-off:hover, -button.btn-duel-off:focus, -button.btn-duel-off.active, -button.btn-duel-off:disabled { +button.btn-duel-off:hover, button.btn-duel-off:focus, button.btn-duel-off.active, button.btn-duel-off:disabled { background-color: black; } button.btn-duel-off:disabled { @@ -1341,21 +1143,14 @@ button.btn-duel-active { button.btn-duel-active span:first-child { color: #121212; } -button.btn-duel-active:hover, -button.btn-duel-active:focus, -button.btn-duel-active.active, -button.btn-duel-active:disabled { +button.btn-duel-active:hover, button.btn-duel-active:focus, button.btn-duel-active.active, button.btn-duel-active:disabled { background-color: #00bebe; } button.btn-duel-active:disabled { cursor: not-allowed; } button.btn-duel-on { - background: radial-gradient( - 60.65% 30.62% at 50% 3.13%, - #2a2b30 0%, - #1b1c22 100% - ); + background: radial-gradient(60.65% 30.62% at 50% 3.13%, #2a2b30 0%, #1b1c22 100%); background-color: #121212; border: 1px solid #58ffff; border-radius: 2px; @@ -1367,22 +1162,14 @@ button.btn-duel-on { button.btn-duel-on span:first-child { color: #ffffff; } -button.btn-duel-on:hover, -button.btn-duel-on:focus, -button.btn-duel-on.active, -button.btn-duel-on:disabled { +button.btn-duel-on:hover, button.btn-duel-on:focus, button.btn-duel-on.active, button.btn-duel-on:disabled { background-color: black; } button.btn-duel-on:disabled { cursor: not-allowed; } button.btn-profile-next { - background: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(226, 137, 4, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #f1c017; + background: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017; background-color: #e3b82a; border: none; border-radius: 2px; @@ -1394,10 +1181,7 @@ button.btn-profile-next { button.btn-profile-next span:first-child { color: #000000; } -button.btn-profile-next:hover, -button.btn-profile-next:focus, -button.btn-profile-next.active, -button.btn-profile-next:disabled { +button.btn-profile-next:hover, button.btn-profile-next:focus, button.btn-profile-next.active, button.btn-profile-next:disabled { background-color: #b89318; } button.btn-profile-next:disabled { @@ -1440,11 +1224,7 @@ button.btn-profile-back:disabled { padding: 16px; } .card:hover { - background: linear-gradient( - 180deg, - rgba(70, 71, 77, 0.7) 0%, - rgba(57, 58, 63, 0.7) 100% - ); + background: linear-gradient(180deg, rgba(70, 71, 77, 0.7) 0%, rgba(57, 58, 63, 0.7) 100%); } .card.rich-card { padding: 24px 16px; @@ -1478,13 +1258,13 @@ div.modal-paper { align-items: center; color: #ffffff; } -@media only screen and (max-width: 1023px) { +@media only screen and (max-width : 1023px) { div.modal-paper { width: 35rem; margin: 0; } } -@media only screen and (max-width: 768px) { +@media only screen and (max-width : 768px) { div.modal-paper { padding: 1rem; width: 85%; @@ -1498,6 +1278,9 @@ div.modal-paper.no-padding { div.modal-paper.blue-border { border: 1px solid rgba(88, 255, 255, 0.2509803922); } +div.modal-paper.blue-light-border { + border: 1px solid #61f0f2; +} div.modal-paper.yellow-border { border: 1px solid rgba(227, 184, 42, 0.4); } @@ -1630,23 +1413,9 @@ a.MuiTypography-colorPrimary { :root { --blue: #58ffff; --blue40: rgba(88, 255, 255, 0.2509803922); - --blueBackground: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(1, 153, 163, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #58ffff; - --blueRadialGradient: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(1, 153, 163, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #58ffff; - --blueRadialGradientTrans: radial-gradient( - circle, - #58ffff 0%, - rgba(255, 255, 255, 0) 100% - ); + --blueBackground: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff; + --blueRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(1, 153, 163, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #58ffff; + --blueRadialGradientTrans: radial-gradient(circle, #58ffff 0%, rgba(255, 255, 255, 0) 100%); --elecColor: #d87b39; --elecColor40: rgba(216, 123, 57, 0.4); --elecCompareColor: #e2bca1; @@ -1666,55 +1435,15 @@ a.MuiTypography-colorPrimary { --darkLight: #25262b; --darkLight2: #121212; --textFont: Lato, sans-serif; - --greyLinearGradientBackground: linear-gradient( - 180deg, - rgb(50, 51, 57) 0%, - rgb(37, 38, 43) 100% - ); - --multiColorRadialGradientTrans: radial-gradient( - circle, - #e3b82a 0%, - rgba(255, 255, 255, 0) 100% - ); - --elecColorRadialGradientTrans: radial-gradient( - circle, - #d87b39 0%, - rgba(255, 255, 255, 0) 100% - ); - --waterColorRadialGradientTrans: radial-gradient( - circle, - #3a98ec 0%, - rgba(255, 255, 255, 0) 100% - ); - --gasColorRadialGradientTrans: radial-gradient( - circle, - #e3b82a 0%, - rgba(255, 255, 255, 0) 100% - ); - --multiColorRadialGradient: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(226, 137, 4, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #f1c017; - --elecColorRadialGradient: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(158, 67, 2, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #d87b39; - --gasColorRadialGradient: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(4, 106, 88, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #45d1b8; - --waterColorRadialGradient: radial-gradient( - 105.25% 64.58% at 49.68% 70.83%, - rgba(2, 93, 174, 0.5) 0%, - rgba(255, 255, 255, 0) 100% - ), - #3a98ec; + --greyLinearGradientBackground: linear-gradient(180deg, rgb(50, 51, 57) 0%, rgb(37, 38, 43) 100%); + --multiColorRadialGradientTrans: radial-gradient(circle, #e3b82a 0%, rgba(255, 255, 255, 0) 100%); + --elecColorRadialGradientTrans: radial-gradient(circle, #d87b39 0%, rgba(255, 255, 255, 0) 100%); + --waterColorRadialGradientTrans: radial-gradient(circle, #3a98ec 0%, rgba(255, 255, 255, 0) 100%); + --gasColorRadialGradientTrans: radial-gradient(circle, #e3b82a 0%, rgba(255, 255, 255, 0) 100%); + --multiColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(226, 137, 4, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #f1c017; + --elecColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(158, 67, 2, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #d87b39; + --gasColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(4, 106, 88, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #45d1b8; + --waterColorRadialGradient: radial-gradient(105.25% 64.58% at 49.68% 70.83%, rgba(2, 93, 174, 0.5) 0%, rgba(255, 255, 255, 0) 100%), #3a98ec; } .application { diff --git a/src/styles/index.css.map b/src/styles/index.css.map index 43e4f91032c182c88b68a4977026db7edd39c0df..159f95e2be3aca6c2c611a33af848742379652b9 100644 --- a/src/styles/index.css.map +++ b/src/styles/index.css.map @@ -1 +1 @@ -{"version":3,"sourceRoot":"","sources":["index.scss","base/_color.scss","base/_layout.scss","base/_z-index.scss","base/_typography.scss","base/_typo-variables.scss","components/_barchart.scss","components/_buttons.scss","base/_mixins.scss","components/_card.scss","components/_dialog.scss","components/_expansion-panel.scss","components/_link.scss"],"names":[],"mappings":"AAAA;AACQ;AACR;AACQ;AACR;ACJA;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;ADhIQ;AEZR;EACE,YDHO;;;ACMT;EACE,YDPO;ECQP;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;;AACA;EANF;IAOI;;;;AAIJ;EACE,kBDaM;;ACZN;EAFF;IAGI;IACA;;;;AAIJ;EACE;EACA;;;AAEF;EACE;;;AAEF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA,SCxDS;EDyDT;EACA;EACA;;AACA;EAVF;IAWI;;;AAEF;EACE;EAKA;;AACA;EACE;EACA,ODvBQ;;AC0BZ;EACE;EACA;EACA;;AACA;EAJF;IAKI;;;AAEF;EAPF;IAQI;;;AAEF;EACE;EACA;;AACA;EACE;;AAEF;EACE;EACA;;AAEF;EACE;EACA;EACA;EACA,ODlDM;;ACoDR;EACE;;AAEF;EACE;IACE;IACA,OD1DI;;EC4DN;IACE;;EAEF;IACE;;;;AAOV;EACE;EACA;EACA;EACA;EACA;EACA;EACA,OD9EY;;AC+EZ;EACE;EACA;EACA;;AAEF;EACE;EACA;;;AAIJ;AACE;AAIA;AAIA;;AAPA;EACE;;AAGF;EACE,YDHc;;ACMhB;EACE,YDNc;;;AAnJlB;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AAhJA;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AG5IA;EACE,aCLU;;;ADQZ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAOE,OHsCU;EGrCV,aChBU;;;ADmBZ;EACE;EACA,aCrBU;EDsBV;EACA;EACA;EACA;;;AAGF;EACE,aC7BU;ED8BV;EACA;EACA;EACA;EAEA;EACA;EACA,OHeY;EGdZ;;;AAEF;EACE,OHtBY;EGuBZ;EACA;;;AAIA;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AAKN;AACA;EACE,aCrFU;EDsFV;EACA;EACA;EACA;EACA,OHtCY;;;AGwCd;EACE,aC7FU;ED8FV;EACA;EACA;EACA;EACA,OH9CY;;;AGgDd;EACE,aCrGU;EDsGV;EACA;EACA;EACA;EACA,OHtDY;;;AGwDd;EACE,aC7GU;ED8GV;EACA;EACA;EACA;EACA,OH9DY;;;AGgEd;EACE,aCrHU;EDsHV;EACA;EACA;EACA;EACA,OHtEY;;;AGyEd;AACA;EACE,aC/HU;EDgIV;EACA;EACA;EACA;;AACA;EANF;IAOI;;;;AAGJ;EACE,aCzIU;ED0IV;EACA;EACA;EACA;;AACA;EANF;IAOI;;;;AAIJ;AACA;EACE,aCrJU;EDsJV;EACA;EACA;EACA;EACA,OHtGY;;;AApDd;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AK7IA;EACE,OLkDU;;AKjDV;EACE,MLgDQ;;AK/CR;EACE,ML4CQ;;AKzCZ;EACE;EACA;EACA;;;AAGJ;EACE,MLoCU;;AKnCV;EACE,MLgCU;;;AK3BZ;AAAA;EACE;;;AAGJ;EACE;;AACA;EACE;;;AAGJ;EACE;;;AAUA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;;;AAGJ;EACE,MLuBe;;AKtBf;EACE,MLmBS;EKlBT;;;AAIJ;EACE,MLiBuB;;AKhBvB;EACE,MLciB;EKbjB;;;AAIJ;EACE,MLmBgB;;AKlBhB;EACE,MLeU;EKdV;;;AAIJ;EACE,MLawB;;AKZxB;EACE,MLUkB;EKTlB;;;AAIJ;EACE,MLHc;;AKId;EACE,MLPQ;EKQR;;;AAIJ;EACE,MLTsB;;AKUtB;EACE,MLZgB;EKahB;;;AAIJ;EACE,MLRgB;;AKShB;EACE,MLXU;EKYV;;AAGA;EACE;;;AAIN;EACE,MLpFW;;AKqFX;EACE,MLtFS;EKuFT;;AAGA;EACE;;;AAIN;EACE,ML1HK;EK2HL;;AACA;EACE,MLpCU;EKqCV;;AAGA;EACE;;;AAKN;EACE,ML5CwB;;AK6CxB;EACE,ML/CkB;EKgDlB;;;AAGJ;EACE;EACA,QLvDY;;;AKyDd;EACE,MLzEmB;;AK0EnB;EACE,ML3EiB;EK4EjB;;;AAGJ;EACE,ML/DoB;;AKgEpB;EACE,MLjEkB;EKkElB;;;AAGJ;AACA;EACE;EACA;EACA;EACA;EACA;;;AAEF;EACE;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;;AAIJ;EACE;EACA;EACA;EACA;EACA;;;AAEF;EACE;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;;AAIJ;EACE;EACA;EACA;EACA;;;AAEF;EACE;IACE;IACA;;EAEF;IACE;IACA;;EAEF;IACE;IACA;;;AAIJ;AACA;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;ALxRF;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AM5IE;ECEA,YPiH4B;EOhH5B,kBPYY;EOXZ,QDHyC;ECIzC;EACA;EACA;EACA;EACA;;AACA;EACE,ODV8B;;ACYhC;EDXI;;ACiBJ;EACE;;ADfF;ECHA,YDQI;ECPJ,kBDII;ECHJ,QDKI;ECJJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPIU;;AOFZ;EDDI;;AACA;EACE;;ACKN;EACE;;ADFF;EChBA,YDqBI;ECpBJ,kBDiBI;EChBJ,QDkBI;ECjBJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPIU;;AOFZ;EDYI;;AACA;EACE;;ACRN;EACE;;ADWF;EC7BA,YDkCI;ECjCJ,kBD8BI;EC7BJ,QD+BI;EC9BJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPqCU;;AOnCZ;EDyBI;;AACA;EACE;;ACrBN;EACE;;ADwBF;EC1CA,YD+CI;EC9CJ,kBD2CI;EC1CJ,QD4CI;EC3CJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPqCU;;AOnCZ;EDsCI;;AACA;EACE;;AClCN;EACE;;ADqCF;ECvDA,YPFa;EOGb,kBPHa;EOIb,QDyDI;ECxDJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPiCI;;AO/BN;EDmDI;;AC7CJ;EACE;;AD+CF;ECjEA,YPmBK;EOlBL,kBPkBK;EOjBL,QDgEwC;EC/DxC;EACA;EACA;EACA;EACA;;AACA;EACE,OPXW;;AOab;EDwDI;;AClDJ;EACE;;ADoDF;ECtEA;EACA,kBPHa;EOIb,QDqEyC;ECpEzC;EACA;EACA;EACA;EACA;;AACA;EACE,OPiCI;;AO/BN;ED6DI;;ACvDJ;EACE;;ADyDF;EC3EA,YPiH4B;EOhH5B,kBPYY;EOXZ,QD0EyC;ECzEzC;EACA;EACA;EACA;EACA;;AACA;EACE,ODmE8B;;ACjEhC;EDkEI;;AC5DJ;EACE;;AD8DF;EChFA,YDiF0C;EChF1C,kBDgFkB;EC/ElB,QD+EoC;EC9EpC;EACA;EACA;EACA;EACA;;AACA;EACE,OPsCQ;;AO9BV;EACE;;;APxBJ;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AQ9IA;EACE,YRoDgC;EQnDhC;EACA;EACA;EACA;EACA;;AACA;EACE,YRkDoC;;AQhDtC;EACE;;;ARbJ;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AS5IE;EACE;;;AAIJ;EACE,YT6CgC;ES5ChC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,OT4BM;;AS3BN;EAZF;IAaI;IACA;;;AAEF;EAhBF;IAiBI;IACA;IACA;IACA;;;AAEF;EACE;;AAEF;EACE;;AAEF;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA,SP3CO;;;AO+CX;EACE,YTKgC;ESJhC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,OTZM;ESaN;EACA;;AACA;EACE,YT5DW;;;AAJf;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AU9IA;EACE;EACA,OVgDY;EU/CZ,YVkDgC;EUjDhC;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;;AAEF;EACE;;;AAGJ;EACE;EACA;;AACA;EACE;EACA;EACA;;AAEF;EACE;;AACA;EACE;;AAGJ;EACE;EACA;;AAEF;EACE;;;AAGJ;EACE;EACA;;AACA;EACE;;;AAGJ;EACE;;;AVlDF;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AW/IA;EACE,OXgBW;;AWfX;EACE,OXcS;;;AWVb;EACE;EACA;;AACA;EACE;;;AAGJ;EACE;;;AAEF;EACE,OXiCY;;;ADlCd;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EAME;EACA,kBCzDa","file":"index.css"} \ No newline at end of file +{"version":3,"sourceRoot":"","sources":["index.scss","base/_color.scss","base/_layout.scss","base/_z-index.scss","base/_typography.scss","base/_typo-variables.scss","components/_barchart.scss","components/_buttons.scss","base/_mixins.scss","components/_card.scss","components/_dialog.scss","components/_expansion-panel.scss","components/_link.scss"],"names":[],"mappings":"AAAA;AACQ;AACR;AACQ;AACR;ACJA;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;ADhIQ;AEZR;EACE,YDDa;;;ACIf;EACE,YDLa;ECMb;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;;;AAGF;EACE;EACA;EACA;EACA;EACA;;AACA;EANF;IAOI;;;;AAIJ;EACE,kBDaM;;ACZN;EAFF;IAGI;IACA;;;;AAIJ;EACE;EACA;;;AAEF;EACE;;;AAEF;EACE;;;AAGF;EACE;EACA;EACA;EACA;EACA;EACA,SCxDS;EDyDT;EACA;EACA;;AACA;EAVF;IAWI;;;AAEF;EACE;EAKA;;AACA;EACE;EACA,ODvBQ;;AC0BZ;EACE;EACA;EACA;;AACA;EAJF;IAKI;;;AAEF;EAPF;IAQI;;;AAEF;EACE;EACA;;AACA;EACE;;AAEF;EACE;EACA;;AAEF;EACE;EACA;EACA;EACA,ODlDM;;ACoDR;EACE;;AAEF;EACE;IACE;IACA,OD1DI;;EC4DN;IACE;;EAEF;IACE;;;;AAOV;EACE;EACA;EACA;EACA;EACA;EACA;EACA,OD9EY;;AC+EZ;EACE;EACA;EACA;;AAEF;EACE;EACA;;;AAIJ;AACE;AAIA;AAIA;;AAPA;EACE;;AAGF;EACE,YDHc;;ACMhB;EACE,YDNc;;;AAnJlB;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AAhJA;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AG5IA;EACE,aCLU;;;ADQZ;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EAOE,OHsCU;EGrCV,aChBU;;;ADmBZ;EACE;EACA,aCrBU;EDsBV;EACA;EACA;EACA;;;AAGF;EACE,aC7BU;ED8BV;EACA;EACA;EACA;EAEA;EACA;EACA,OHeY;EGdZ;;;AAEF;EACE,OHtBY;EGuBZ;EACA;;;AAIA;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AA/BJ;EACE;EACA,WC/CQ;EDgDR;;AACA;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;;AACA;EAEE;;AAEF;EAEE;;AAGJ;EAEE;EACA;;;AAKN;AACA;EACE,aCrFU;EDsFV;EACA;EACA;EACA;EACA,OHtCY;;;AGwCd;EACE,aC7FU;ED8FV;EACA;EACA;EACA;EACA,OH9CY;;;AGgDd;EACE,aCrGU;EDsGV;EACA;EACA;EACA;EACA,OHtDY;;;AGwDd;EACE,aC7GU;ED8GV;EACA;EACA;EACA;EACA,OH9DY;;;AGgEd;EACE,aCrHU;EDsHV;EACA;EACA;EACA;EACA,OHtEY;;;AGyEd;AACA;EACE,aC/HU;EDgIV;EACA;EACA;EACA;;AACA;EANF;IAOI;;;;AAGJ;EACE,aCzIU;ED0IV;EACA;EACA;EACA;;AACA;EANF;IAOI;;;;AAIJ;AACA;EACE,aCrJU;EDsJV;EACA;EACA;EACA;EACA,OHtGY;;;AApDd;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AK7IA;EACE,OLkDU;;AKjDV;EACE,MLgDQ;;AK/CR;EACE,ML4CQ;;AKzCZ;EACE;EACA;EACA;;;AAGJ;EACE,MLoCU;;AKnCV;EACE,MLgCU;;;AK3BZ;AAAA;EACE;;;AAGJ;EACE;;AACA;EACE;;;AAGJ;EACE;;;AAUA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;EACE;;;AAGJ;EACE,MLuBe;;AKtBf;EACE,MLmBS;EKlBT;;;AAIJ;EACE,MLiBuB;;AKhBvB;EACE,MLciB;EKbjB;;;AAIJ;EACE,MLmBgB;;AKlBhB;EACE,MLeU;EKdV;;;AAIJ;EACE,MLawB;;AKZxB;EACE,MLUkB;EKTlB;;;AAIJ;EACE,MLHc;;AKId;EACE,MLPQ;EKQR;;;AAIJ;EACE,MLTsB;;AKUtB;EACE,MLZgB;EKahB;;;AAIJ;EACE,MLRgB;;AKShB;EACE,MLXU;EKYV;;AAGA;EACE;;;AAIN;EACE,MLpFW;;AKqFX;EACE,MLtFS;EKuFT;;AAGA;EACE;;;AAIN;EACE,ML1HK;EK2HL;;AACA;EACE,MLpCU;EKqCV;;AAGA;EACE;;;AAKN;EACE,ML5CwB;;AK6CxB;EACE,ML/CkB;EKgDlB;;;AAGJ;EACE;EACA,QLvDY;;;AKyDd;EACE,MLzEmB;;AK0EnB;EACE,ML3EiB;EK4EjB;;;AAGJ;EACE,ML/DoB;;AKgEpB;EACE,MLjEkB;EKkElB;;;AAGJ;AACA;EACE;EACA;EACA;EACA;EACA;;;AAEF;EACE;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;;AAIJ;EACE;EACA;EACA;EACA;EACA;;;AAEF;EACE;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;EAEF;IACE;;;AAIJ;EACE;EACA;EACA;EACA;;;AAEF;EACE;IACE;IACA;;EAEF;IACE;IACA;;EAEF;IACE;IACA;;;AAIJ;AACA;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;AAEF;EACE;;;ALxRF;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AM5IE;ECEA,YPiH4B;EOhH5B,kBPYY;EOXZ,QDHyC;ECIzC;EACA;EACA;EACA;EACA;;AACA;EACE,ODV8B;;ACYhC;EDXI;;ACiBJ;EACE;;ADfF;ECHA,YDQI;ECPJ,kBDII;ECHJ,QDKI;ECJJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPIU;;AOFZ;EDDI;;AACA;EACE;;ACKN;EACE;;ADFF;EChBA,YDqBI;ECpBJ,kBDiBI;EChBJ,QDkBI;ECjBJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPIU;;AOFZ;EDYI;;AACA;EACE;;ACRN;EACE;;ADWF;EC7BA,YDkCI;ECjCJ,kBD8BI;EC7BJ,QD+BI;EC9BJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPqCU;;AOnCZ;EDyBI;;AACA;EACE;;ACrBN;EACE;;ADwBF;EC1CA,YD+CI;EC9CJ,kBD2CI;EC1CJ,QD4CI;EC3CJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPqCU;;AOnCZ;EDsCI;;AACA;EACE;;AClCN;EACE;;ADqCF;ECvDA,YPFa;EOGb,kBPHa;EOIb,QDyDI;ECxDJ;EACA;EACA;EACA;EACA;;AACA;EACE,OPiCI;;AO/BN;EDmDI;;AC7CJ;EACE;;AD+CF;ECjEA,YPmBK;EOlBL,kBPkBK;EOjBL,QDgEwC;EC/DxC;EACA;EACA;EACA;EACA;;AACA;EACE,OPXW;;AOab;EDwDI;;AClDJ;EACE;;ADoDF;ECtEA;EACA,kBPHa;EOIb,QDqEyC;ECpEzC;EACA;EACA;EACA;EACA;;AACA;EACE,OPiCI;;AO/BN;ED6DI;;ACvDJ;EACE;;ADyDF;EC3EA,YPiH4B;EOhH5B,kBPYY;EOXZ,QD0EyC;ECzEzC;EACA;EACA;EACA;EACA;;AACA;EACE,ODmE8B;;ACjEhC;EDkEI;;AC5DJ;EACE;;AD8DF;EChFA,YDiF0C;EChF1C,kBDgFkB;EC/ElB,QD+EoC;EC9EpC;EACA;EACA;EACA;EACA;;AACA;EACE,OPsCQ;;AO9BV;EACE;;;APxBJ;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AQ9IA;EACE,YRoDgC;EQnDhC;EACA;EACA;EACA;EACA;;AACA;EACE,YRkDoC;;AQhDtC;EACE;;;ARbJ;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AS5IE;EACE;;;AAIJ;EACE,YT6CgC;ES5ChC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,OT4BM;;AS3BN;EAZF;IAaI;IACA;;;AAEF;EAhBF;IAiBI;IACA;IACA;IACA;;;AAEF;EACE;;AAEF;EACE;;AAEF;EACE;;AAEF;EACE;;AAEF;EACE;EACA;EACA;EACA;EACA,SP9CO;;;AOkDX;EACE,YTEgC;ESDhC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,OTfM;ESgBN;EACA;;AACA;EACE,YT/DW;;;AAJf;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AU9IA;EACE;EACA,OVgDY;EU/CZ,YVkDgC;EUjDhC;EACA;EACA;EACA;;AACA;EACE;;AAEF;EACE;;AAEF;EACE;;;AAGJ;EACE;EACA;;AACA;EACE;EACA;EACA;;AAEF;EACE;;AACA;EACE;;AAGJ;EACE;EACA;;AAEF;EACE;;;AAGJ;EACE;EACA;;AACA;EACE;;;AAGJ;EACE;;;AVlDF;AAYA;AAGA;AAMA;AAGA;AAmBA;AAIA;AAIA;AAoBA;AA0BA;AA+CA;AW/IA;EACE,OXgBW;;AWfX;EACE,OXcS;;;AWVb;EACE;EACA;;AACA;EACE;;;AAGJ;EACE;;;AAEF;EACE,OXiCY;;;ADlCd;EACE;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGF;EAME;EACA,kBCzDa","file":"index.css"} \ No newline at end of file diff --git a/src/types/cozy-ui.d.ts b/src/types/cozy-ui.d.ts index a13bfbd3f043d8493ea441d5efba5c0b0cce5896..e45466e6769d12c9dcce14662af7d6754bd4e218 100644 --- a/src/types/cozy-ui.d.ts +++ b/src/types/cozy-ui.d.ts @@ -1,5 +1,3 @@ -/* eslint-disable @typescript-eslint/interface-name-prefix */ -/* eslint-disable @typescript-eslint/no-explicit-any */ declare module 'cozy-ui/transpiled/react/Icon' declare module 'cozy-ui/transpiled/react/Spinner' declare module 'cozy-ui/transpiled/react/Layout' diff --git a/src/utils/picto.spec.ts b/src/utils/picto.spec.ts index 68ca4e3e300e03d252a1e6d2b693437fc19670c8..1e8838e7626615cdb4882cbf9f18dcfe06f45255 100644 --- a/src/utils/picto.spec.ts +++ b/src/utils/picto.spec.ts @@ -115,11 +115,11 @@ describe('picto utilis test', () => { describe('getPartnerPicto test', () => { it('should return enedis logo icon', () => { - const result = getPartnerPicto('enedisgrandlyon', false) + const result = getPartnerPicto('enedis-sge-grandlyon', false) expect(result).toBe(iconEnedisLogo) }) it('should return white enedis logo icon', () => { - const result = getPartnerPicto('enedisgrandlyon', true) + const result = getPartnerPicto('enedis-sge-grandlyon', true) expect(result).toBe(iconEnedisWhiteLogo) }) it('should return egl logo icon', () => { diff --git a/tests/__mocks__/accountsData.mock.ts b/tests/__mocks__/accountsData.mock.ts index ba83fe802f2ddcdfc4066e9150105ef33a4ddce7..f79d94eef56e4c66723c8695915b12a1d944b55b 100644 --- a/tests/__mocks__/accountsData.mock.ts +++ b/tests/__mocks__/accountsData.mock.ts @@ -1,11 +1,10 @@ -/* eslint-disable @typescript-eslint/camelcase */ import { Account } from 'models' export const accountsData: Account[] = [ { _id: '88e68b8450cee09fe2f077610901094d', _rev: '1-88e68b8450cee09fe2f077610901094d', - account_type: 'enedisgrandlyon', + account_type: 'enedis-sge-grandlyon', name: '', oauth: { access_token: 'MY_ACCESS_TOCKEN', diff --git a/tests/__mocks__/fluidStatusData.mock.ts b/tests/__mocks__/fluidStatusData.mock.ts index e9495d91ad3d8e71ce43308f0098bb7512ec301b..eed87db3203e78b254cdccc0ce585689ac49ab40 100644 --- a/tests/__mocks__/fluidStatusData.mock.ts +++ b/tests/__mocks__/fluidStatusData.mock.ts @@ -1,8 +1,8 @@ import { FluidState } from 'enum/fluid.enum' +import { FluidSlugType } from 'enum/fluidSlug.enum' import { DateTime } from 'luxon' import { FluidStatus } from 'models' import { PartnersInfo } from 'models/partnersInfo.model' -/* eslint-disable @typescript-eslint/camelcase */ export const fluidStatusData: FluidStatus[] = [ { @@ -24,7 +24,7 @@ export const fluidStatusData: FluidStatus[] = [ konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.ELECTRICITY, siteLink: '', activation: '', }, @@ -49,7 +49,7 @@ export const fluidStatusData: FluidStatus[] = [ konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.WATER, siteLink: '', activation: '', }, @@ -74,7 +74,7 @@ export const fluidStatusData: FluidStatus[] = [ konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.GAS, siteLink: '', activation: '', }, @@ -114,7 +114,7 @@ export const fluidStatusConnectedData: FluidStatus[] = [ konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.ELECTRICITY, siteLink: '', activation: '', }, @@ -139,7 +139,7 @@ export const fluidStatusConnectedData: FluidStatus[] = [ konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.WATER, siteLink: '', activation: '', }, @@ -164,10 +164,57 @@ export const fluidStatusConnectedData: FluidStatus[] = [ konnectorConfig: { name: '', oauth: true, - slug: '', + slug: FluidSlugType.GAS, siteLink: '', activation: '', }, }, }, ] +export const SgeStatusWithAccout: FluidStatus = { + fluidType: 0, + status: FluidState.KONNECTOR_NOT_FOUND, + firstDataDate: DateTime.fromISO('2019-09-01T00:00:00.000Z', { + zone: 'utc', + }), + lastDataDate: DateTime.fromISO('2020-09-01T00:00:00.000Z', { + zone: 'utc', + }), + connection: { + shouldLaunchKonnector: false, + isUpdating: false, + konnector: null, + account: { + _id: '88e68b8450cee09fe2f077610901094d', + _rev: '1-88e68b8450cee09fe2f077610901094d', + account_type: 'enedis-sge-grandlyon', + name: '', + oauth: { + access_token: 'MY_ACCESS_TOCKEN', + expires_at: '2020-10-09T08:00:00.285910671+02:00', + refresh_token: '', + token_type: 'Bearer', + }, + oauth_callback_results: { + issued_at: '1592232569642', + refresh_token_issued_at: '1592232569642', + scope: '/my_eneids_scope', + usage_points_id: '', + }, + cozyMetadata: { + createdAt: '2020-11-10T16:42:11.132Z', + metadataVersion: 1, + updatedAt: '2020-11-10T16:42:11.132Z', + }, + }, + trigger: null, + triggerState: null, + konnectorConfig: { + name: '', + oauth: false, + slug: FluidSlugType.ELECTRICITY, + siteLink: '', + activation: '', + }, + }, +} diff --git a/tests/__mocks__/globalStateData.mock.ts b/tests/__mocks__/globalStateData.mock.ts index 4b8de03a74274e1cd9df2f8a74c4df7e440c3210..7f57f724b5cd20c78232b43538a5eff0c8dcd535 100644 --- a/tests/__mocks__/globalStateData.mock.ts +++ b/tests/__mocks__/globalStateData.mock.ts @@ -1,4 +1,5 @@ import { FluidState, FluidType } from 'enum/fluid.enum' +import { FluidSlugType } from 'enum/fluidSlug.enum' import { ScreenType } from 'enum/screen.enum' import { GlobalState } from 'models' @@ -33,7 +34,7 @@ export const globalStateData: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.ELECTRICITY, siteLink: '', activation: '', }, @@ -54,7 +55,7 @@ export const globalStateData: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.WATER, siteLink: '', activation: '', }, @@ -75,7 +76,7 @@ export const globalStateData: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.GAS, siteLink: '', activation: '', }, @@ -84,4 +85,16 @@ export const globalStateData: GlobalState = { ], fluidTypes: [], shouldRefreshConsent: false, + sgeConnect: { + currentStep: 0, + firstName: '', + lastName: '', + pdl: null, + address: '', + zipCode: null, + city: '', + dataConsent: false, + pdlConfirm: false, + shouldLaunchAccount: false, + }, } diff --git a/tests/__mocks__/konnectorsData.mock.ts b/tests/__mocks__/konnectorsData.mock.ts index b1a2498685116a6c09802648a464bba217fb34fb..f0671c57702ff4a945a9df22a596ca03731d688a 100644 --- a/tests/__mocks__/konnectorsData.mock.ts +++ b/tests/__mocks__/konnectorsData.mock.ts @@ -2,9 +2,9 @@ import { Konnector } from 'models' export const konnectorsData: Konnector[] = [ { - _id: 'io.cozy.konnectors/enedisgrandlyon', + _id: 'io.cozy.konnectors/enedis-sge-grandlyon', name: 'Enedis', - slug: 'enedisgrandlyon', + slug: 'enedis-sge-grandlyon', state: 'ready', }, { diff --git a/tests/__mocks__/mockConfig.mock.ts b/tests/__mocks__/mockConfig.mock.ts index 5cede83e872fa85290a48038c65befd1b95a421b..0a09c66984c13ef33654064323155375debf0f21 100644 --- a/tests/__mocks__/mockConfig.mock.ts +++ b/tests/__mocks__/mockConfig.mock.ts @@ -10,7 +10,7 @@ const mockConfig = { konnectorConfig: { name: 'Enedis', oauth: true, - slug: 'enedisgrandlyon', + slug: 'enedis-sge-grandlyon', siteLink: 'https://mon-compte-client.enedis.fr/', activation: 'https://mon-compte-particulier.enedis.fr/donnees/', }, diff --git a/tests/__mocks__/profileType.mock.ts b/tests/__mocks__/profileType.mock.ts index 52197f89c178db115de01ef5dae64f43f7f60d36..7262c68221dc88bd38669be611993480d7f97eb0 100644 --- a/tests/__mocks__/profileType.mock.ts +++ b/tests/__mocks__/profileType.mock.ts @@ -1,4 +1,3 @@ -/* eslint-disable @typescript-eslint/camelcase */ import { FluidType } from 'enum/fluid.enum' import { ConstructionYear, @@ -43,6 +42,7 @@ export const profileTypeData: ProfileType = { zone: 'utc', }), warmingFluid: 2, + equipments: [], } export const mockProfileType: ProfileType = { @@ -65,6 +65,7 @@ export const mockProfileType: ProfileType = { updateDate: DateTime.fromISO('2021-01-01T00:00:00.000Z', { zone: 'utc', }), + equipments: [], } export const mockEstimatedConsumption = 3182 export const mockCorrectedConsumption = 3500 @@ -101,6 +102,7 @@ export const mockProfileType1: ProfileType = { updateDate: DateTime.fromISO('2021-01-01T00:00:00.000Z', { zone: 'utc', }), + equipments: [], } export const mockEstimatedConsumption1 = 6450 export const mockCorrectedConsumption1 = 6450 @@ -129,6 +131,7 @@ export const mockProfileType2: ProfileType = { updateDate: DateTime.fromISO('2021-01-01T00:00:00.000Z', { zone: 'utc', }), + equipments: [], } export const mockEstimatedConsumption2 = 16560 export const mockCorrectedConsumption2 = 15411 @@ -155,6 +158,7 @@ export const mockTestProfile1: ProfileType = { updateDate: DateTime.fromISO('2021-01-01T00:00:00.000Z', { zone: 'utc', }), + equipments: [], } export const mockMonthlyForecastJanuaryTestProfile1: MonthlyForecast = { fluidForecast: [ @@ -219,6 +223,7 @@ export const mockTestProfile2: ProfileType = { updateDate: DateTime.fromISO('2021-01-01T00:00:00.000Z', { zone: 'utc', }), + equipments: [], } export const mockMonthlyForecastJanuaryTestProfile2: MonthlyForecast = { @@ -284,6 +289,7 @@ export const mockTestProfile3: ProfileType = { updateDate: DateTime.fromISO('2021-01-01T00:00:00.000Z', { zone: 'utc', }), + equipments: [], } export const mockMonthlyForecastJanuaryTestProfile3: MonthlyForecast = { diff --git a/tests/__mocks__/store.ts b/tests/__mocks__/store.ts index 74f61acc8ef2376b703c69b199126a9d3eee09be..305a23ab8216bba6fd846de2e22422e48bf342d3 100644 --- a/tests/__mocks__/store.ts +++ b/tests/__mocks__/store.ts @@ -1,6 +1,5 @@ -/* eslint-disable @typescript-eslint/camelcase */ - import { FluidState, FluidType } from 'enum/fluid.enum' +import { FluidSlugType } from 'enum/fluidSlug.enum' import { ConstructionYear, Floor, @@ -57,7 +56,7 @@ export const mockInitialGlobalState: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.ELECTRICITY, siteLink: '', activation: '', }, @@ -78,7 +77,7 @@ export const mockInitialGlobalState: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.WATER, siteLink: '', activation: '', }, @@ -99,7 +98,7 @@ export const mockInitialGlobalState: GlobalState = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.GAS, siteLink: '', activation: '', }, @@ -108,6 +107,18 @@ export const mockInitialGlobalState: GlobalState = { ], fluidTypes: [], shouldRefreshConsent: false, + sgeConnect: { + address: '', + city: '', + currentStep: 0, + dataConsent: false, + firstName: '', + lastName: '', + pdl: null, + pdlConfirm: false, + zipCode: null, + shouldLaunchAccount: false, + }, } export const mockExpiredElec: FluidStatus = { fluidType: FluidType.ELECTRICITY, @@ -132,7 +143,7 @@ export const mockExpiredElec: FluidStatus = { konnectorConfig: { name: '', oauth: false, - slug: '', + slug: FluidSlugType.ELECTRICITY, siteLink: '', activation: '', }, @@ -185,14 +196,13 @@ export const mockInitialProfileTypeState: ProfileType = { hotWaterFluid: FluidType.ELECTRICITY, cookingFluid: FluidType.ELECTRICITY, updateDate: DateTime.fromISO('0000-01-01T00:00:00.000Z'), + equipments: [], } export const mockInitialChartState: ChartState = { - selectedDate: DateTime.local() - .endOf('minute') - .setZone('utc', { - keepLocalTime: true, - }), + selectedDate: DateTime.local().endOf('minute').setZone('utc', { + keepLocalTime: true, + }), currentTimeStep: TimeStep.WEEK, currentIndex: 0, currentDatachart: { actualData: [], comparisonData: null }, @@ -222,7 +232,6 @@ export const mockInitialEcolyoState = { const middlewares = [thunkMiddleware.withExtraArgument({ mockClient })] const mockStore = configureStore(middlewares) -// eslint-disable-next-line @typescript-eslint/no-explicit-any const mockedStore: any = mockStore({ ecolyo: mockInitialEcolyoState, }) diff --git a/tests/__mocks__/testUtils.ts b/tests/__mocks__/testUtils.ts index 2fe27298a9e9e930caf3ac30bf4e2f52489aaaa7..6b779ccf6faab7c684fa756df3415156264a349d 100644 --- a/tests/__mocks__/testUtils.ts +++ b/tests/__mocks__/testUtils.ts @@ -1,7 +1,6 @@ import { ReactWrapper } from 'enzyme' import { act } from 'react-dom/test-utils' -// eslint-disable-next-line @typescript-eslint/no-explicit-any export const waitForComponentToPaint = async <TP extends any = {}>( wrapper: ReactWrapper<TP> ): Promise<void> => { diff --git a/tests/__mocks__/triggersData.mock.ts b/tests/__mocks__/triggersData.mock.ts index c10a77c9b8073519e8f8c9ca5ec200c810204785..b24db384bb7381a226cfdf10a22a500a64228b46 100644 --- a/tests/__mocks__/triggersData.mock.ts +++ b/tests/__mocks__/triggersData.mock.ts @@ -12,7 +12,7 @@ export const triggersData: Trigger[] = [ options: null, message: { account: '88e68b8450cee09fe2f077610901094d', - konnector: 'enedisgrandlyon', + konnector: 'enedis-sge-grandlyon', }, cozyMetadata: { doctypeVersion: '1', @@ -78,7 +78,7 @@ export const triggersEnedisData: Trigger[] = [ options: null, message: { account: '88e68b8450cee09fe2f077610901094d', - konnector: 'enedisgrandlyon', + konnector: 'enedis-sge-grandlyon', }, cozyMetadata: { doctypeVersion: '1', @@ -99,7 +99,7 @@ export const triggersEnedisData: Trigger[] = [ options: null, message: { account: '90e68b8450cee09fe2f077610901094d', - konnector: 'enedisgrandlyon', + konnector: 'enedis-sge-grandlyon', }, cozyMetadata: { doctypeVersion: '1', @@ -120,7 +120,7 @@ export const triggersEnedisData: Trigger[] = [ options: null, message: { account: '89e68b8450cee09fe2f077610901094d', - konnector: 'enedisgrandlyon', + konnector: 'enedis-sge-grandlyon', }, cozyMetadata: { doctypeVersion: '1',