Skip to content

Commit

Permalink
Merge pull request #208 from Studio-Yandex-Practicum/enhancement-159-…
Browse files Browse the repository at this point in the history
…footerApi

внедрить Api в footer
  • Loading branch information
ArturKhelshtein authored Feb 1, 2024
2 parents 13e0f54 + fab4e60 commit 4743ff9
Show file tree
Hide file tree
Showing 8 changed files with 125 additions and 8 deletions.
2 changes: 2 additions & 0 deletions src/app/providers/StoreProvider/config/StateSchema.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,11 +5,13 @@ import { BrandSchema } from '@/widgets/BrandBlock/types/types'
import { ApiInstance } from '@/shared/api/api'
import { ShopNewsSchema } from '@/widgets/NewsBlock/model/types/types'
import { StoreReviewsSchema } from '@/widgets/ReviewsBlock/model/types/types'
import { CoreBaseFooterSchema } from '@/widgets/Footer/model/types/types'

export interface StateSchema {
login: LoginSchema
storeReviews: StoreReviewsSchema
category: CategorySchema
coreBaseFooter: CoreBaseFooterSchema
brand: BrandSchema
searchResult: SearchResultSchema
shopNews: ShopNewsSchema
Expand Down
2 changes: 2 additions & 0 deletions src/app/providers/StoreProvider/config/store.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,15 @@ import categorySlice from '@/entities/Category/slice/categorySlice'
import brandSlice from '@/widgets/BrandBlock/slice/brandSlice'
import searchProductSlice from '@/features/SearchProduct/slice/searchProductSlice'
import { storeReviewsReducer } from '@/widgets/ReviewsBlock/model/slice/reviewsSlice'
import footerSlice from '@/widgets/Footer/model/slice/footerSlice'
import { shopNewsReducer } from '@/widgets/NewsBlock/model/slice/shopNewsSlice'

export type RootState = StateSchema

const rootReducer: ReducersMapObject<RootState> = {
login: loginReducer,
category: categorySlice,
coreBaseFooter: footerSlice,
brand: brandSlice,
searchResult: searchProductSlice,
storeReviews: storeReviewsReducer,
Expand Down
1 change: 1 addition & 0 deletions src/shared/api/types.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,7 @@ export enum ApiRoutes {
SEARCH = 'search',
STORE_REVIEWS = 'store-reviews',
CATEGORIES = 'catalogue/category',
CORE_BASE = 'core/base',
SHOP_NEWS = 'shopnews'
}

Expand Down
28 changes: 20 additions & 8 deletions src/widgets/Footer/Footer.tsx
Original file line number Diff line number Diff line change
@@ -1,22 +1,34 @@
import { useState } from 'react'
import { coreBaseData } from '@/mockData/coreBaseData'
import Logo from '@/shared/ui/logo/Logo'
import Link from '@/shared/ui/Link/Link'
import { Button } from '@/shared/ui/Button/Button'
import Modal from '@/shared/ui/Modal/Modal'
import { useState, useEffect } from 'react'
import { useDispatch, useSelector } from 'react-redux'

import { AppDispatch } from '@/app/providers/StoreProvider/config/store'
import Payments from '@/entities/Payments/Payments'
import SubscribeForm from '@/features/SubscribeForm/SubscribeForm'
import CallBack from '@/features/CallBack'
import styles from './footer.module.scss'
import SubscribeForm from '@/features/SubscribeForm/SubscribeForm'
import { Button } from '@/shared/ui/Button/Button'
import Link from '@/shared/ui/Link/Link'
import Logo from '@/shared/ui/logo/Logo'
import Modal from '@/shared/ui/Modal/Modal'
import Paragraph from '@/shared/ui/Paragraph/Paragraph'

import styles from './footer.module.scss'
import { getCoreBaseFooterSelector } from './model/selectors/selectors'
import { getCoreBase } from './model/services/getCoreBase'

function Footer() {
const dispatch = useDispatch<AppDispatch>()
const coreBaseData = useSelector(getCoreBaseFooterSelector)
const [isModalOpen, setIsModalOpen] = useState(false)
const [isModalClosing, setIsModalClosing] = useState(false)

const changeModalState = () => {
setIsModalOpen(!isModalOpen)
}

useEffect(() => {
dispatch(getCoreBase())
}, [])

const onSubmitHandler = () => {}
return (
<>
Expand Down
3 changes: 3 additions & 0 deletions src/widgets/Footer/model/selectors/selectors.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
import { StateSchema } from '@/app/providers/StoreProvider'

export const getCoreBaseFooterSelector = (state: StateSchema) => state.coreBaseFooter
23 changes: 23 additions & 0 deletions src/widgets/Footer/model/services/getCoreBase.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import { createAsyncThunk } from '@reduxjs/toolkit'

import { ThunkConfig } from '@/app/providers/StoreProvider/config/StateSchema'
import { apiErrorIdentify } from '@/shared/api/apiErrorIdentify'
import { ApiError, ApiErrorTypes, ApiRoutes } from '@/shared/api/types'

import { CoreBaseFooterData } from '../types/types'

export const getCoreBase = createAsyncThunk<CoreBaseFooterData, void, ThunkConfig<ApiError>>(
//void1- выходные данные, void2- входные данные , thunkConfig- тип store
'core/base', // action type, первый аргумент
async (_, thunkAPI) => {
// второй аргумент- асинхронная функция , кот вызовет dispatch в компоненте
const { rejectWithValue, extra } = thunkAPI
try {
const response = await extra.api.get(`api/${ApiRoutes.CORE_BASE}`)

return response.data.footer as CoreBaseFooterData
} catch (error) {
return rejectWithValue(apiErrorIdentify(error, ApiErrorTypes.DATA_EMPTY_ERROR))
}
}
)
49 changes: 49 additions & 0 deletions src/widgets/Footer/model/slice/footerSlice.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,49 @@
import { createSlice } from '@reduxjs/toolkit'

import { rejectedPayloadHandle } from '@/shared/api/rejectedPayloadHandle'

import { getCoreBase } from '../services/getCoreBase'
import { CoreBaseFooterSchema } from '../types/types'

const initialState: CoreBaseFooterSchema = {
isLoading: false,
footer: {
company_info: '',
disclaimer: '',
support_work_time: '',
main_logo: {
image: '',
url: '',
title: ''
},
additional_logos: [],
support: {
callback: '',
phone_number: ''
}
},
error: undefined
}

const footerSlice = createSlice({
name: 'footer',
initialState,
reducers: {},
extraReducers: builder => {
builder
.addCase(getCoreBase.pending, state => {
state.isLoading = true
state.error = undefined
})
.addCase(getCoreBase.fulfilled, (state, { payload }) => {
state.isLoading = false
state.footer = payload
})
.addCase(getCoreBase.rejected, (state, { payload }) => {
state.isLoading = false
state.error = rejectedPayloadHandle(payload)
})
}
})

export default footerSlice.reducer
25 changes: 25 additions & 0 deletions src/widgets/Footer/model/types/types.tsx
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
interface Logo {
image: string
url: string
title: string
}

interface Support {
callback: string
phone_number: string
}

export interface CoreBaseFooterData {
company_info: string
disclaimer: string
support_work_time: string
main_logo: Logo
additional_logos: Logo[]
support: Support
}

export interface CoreBaseFooterSchema {
isLoading: boolean
footer: CoreBaseFooterData
error?: string | string[]
}

0 comments on commit 4743ff9

Please sign in to comment.