Skip to content

Latest commit

 

History

History
82 lines (54 loc) · 3.47 KB

README.md

File metadata and controls

82 lines (54 loc) · 3.47 KB

👨🏻‍💻 VK Mini App Boilerplate

❓Что это такое ❓

Это стартовый кит (шаблон) для создания сервиса на платформе VK Mini Apps.

Используемые в ките технологии / библиотеки / фреймворки:

⚙️ Начало работы

Склонируйте репозиторий в нужную вам директорию:

git clone https://github.com/LukasAndreano/vkma-boilerplate.git <name>

Установите зависимости и запустите приложение:

cd <name>
yarn
yarn dev

Далее перейдите в настройки сервиса и в адресе разработки (web & mvk) укажите:

http://localhost:3000

💡 Идея работы со стейтом (Recoil)

Каждая группа должна содержать свой атом (storage/atoms/.js), который не будет выходить за рамки этой группы или, в крайнем случае, только для модалок.

Пример атома в (storage/atoms/main.js)

📚 Как работать с группами (панелями/экранами)

У каждой группы есть своя директория в components, например: components/home.

В группах присутствует главный экран - base.js и другие дополнительные: anyScreenName.js.

В каждом компоненте могут присутствовать блоки, которые необходимо вынести в отдельный компонент, чтобы сохранить нормальную логическую структуру и не перегрузить этот самый компонент.

Названия таких компонентов должно начинаться с маленькой буквы. Например: usersStatistic.js.

Также присутствуют общие группы (в components) со следующими названиями:

  • __global
  • __modals
  • __navigation

Все эти разделы содержат в себе основные для работы приложения компоненты: навигация, модалки, а также глобальные компоненты (компоненты, которые могут быть переиспользованы n-ное количество раз в абсолютно разных частях приложения без привязки к группе компонентов).

📺 Модалки

Для создания модальных страниц (ModalPage) используется специальный конструктор: ModalConstructor, а для модальных карточек (ModalCard): CardConstructor.

Применение ModalConstructor:

<ModalConstructor id="start" title="Заголовок" close={toBack}>
  Любой children
</ModalConstructor>

Применение CardConstructor:

<CardConstructor
  id="start"
  close={toBack}
  title="Заголовок"
  icon={<Icon56DonateOutline />}
>
  Любой children
</CardConstructor>