Перейти к основному содержимому

Shared

Когда использовать?

Когда на страницах появляется много абстрактной логики (UIKit / hooks / helpers), из-за чего они начинают разбухать и дублировать реализации

Слой хорошо подходит для начала применения методологии 🚀

shared-themed-bordered

Описание

Здесь обычно находятся:

  • общий UIKit приложения (если такой есть)
  • общие вспомогательные библиотеки
  • общий модуль по работе с API
  • модуль конфигурации приложения и его окружения
    • Segment: shared/config
    • env-переменные, которые могут использоваться в коде вышележащих слоев

Структура

└── shared/
├── api/
├── config/
├── lib/
└── ui/

Примеры

Использование UIKit

shared/ui/button/index.tsx
export const Button = () => {...}
shared/ui/card/index.tsx
export const Card = () => {...}
**/**/index.tsx
import { Button } from "shared/ui/button";
import { Card } from "shared/ui/card";
// Или в крайних случаях
// import { Button, Card } from "shared/ui";

Использование переменных окружения

Реализация зависит от проекта и команды, здесь приведен лишь один из вариантов

shared/config/index.ts
export const isDevEnv = NODE_ENV === "development";
export const OAUTH_TOKEN = getEnvVar("REACT_APP_OAUTH_TOKEN");
**/**/index.tsx
import { OAUTH_TOKEN, isDevEnv } from "shared/config";

export const OAuthProvider = () => (
<OAuth
debug={isDevEnv}
token={OAUTH_TOKEN}
...
/>
)