Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/lukasandreano/vkma-boilerplate

Стартовый кит (шаблон) для создания сервиса на платформе VK Mini Apps.
https://github.com/lukasandreano/vkma-boilerplate

react react-router recoil swipeback vite vkma vkminiapps vkui

Last synced: 2 months ago
JSON representation

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

Awesome Lists containing this project

README

        

# Шаблон для создания сервиса на платформе VK Mini Apps

### Краткое описание

Это стартовый кит (шаблон) для создания сервиса на платформе [VK Mini Apps](https://vk.com/services).
Цель этого кита - ускорить создание сервисов, которые не требуют отдельных UI-компонентов.

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

- [React](https://reactjs.org/)
- [Recoil](https://recoiljs.org/)
- [VKMA Router](https://github.com/reyzitwo/react-router-vkminiapps)

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

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

```bash
git clone https://github.com/LukasAndreano/vkma-boilerplate.git
```

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

```bash
cd
yarn
yarn dev
```

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

```
http://localhost:3000
```

### 💡 Принцип работы со стейтом (Recoil)

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

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

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

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

В группах присутствует главный экран - _{panelName}.js_ и другие дополнительные: _anyScreenName.js_.

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

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

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

- \_\_global
- \_\_navigation

Модалки не привязаны к общим группам и имеют свою собственную директорию в _modals_.

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

### 📺 Модалки

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

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

```javascript

Любой children

```

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

```javascript
}
>
Любой children

```