Разработка мобильного приложения для религиозных организаций
Приложение для религиозной организации — это несколько специфических требований, которых нет в обычном корпоративном приложении: мультиязычность с RTL-поддержкой (арабский, иврит), точное отображение священных текстов с верным рендерингом диакритических знаков, расписание богослужений с учётом лунного календаря, медиатека с проповедями и трансляции в реальном времени.
Тексты и типографика
Священные тексты — не обычный контент. Коран требует Arabic script с правильным тashkeel (огласовками), Тора — иврит с никудот. RTL-текст на мобильных: iOS UIKit работает с NSAttributedString + NSParagraphStyle, directional атрибуты через NSMutableParagraphStyle.baseWritingDirection = .rightToLeft. В SwiftUI — environment(\.layoutDirection, .rightToLeft).
На Android: android:textDirection="rtl" или TextView.textDirection = TEXT_DIRECTION_RTL. Для корректного рендеринга сложных скриптов — HarfBuzz (встроен в Android 5+) и ICU. Проблема с арабским лигатурами на старых Android-устройствах: HarfBuzz pre-5.0 не поддерживает все контекстуальные формы букв. Target minSdkVersion 21+ решает большинство проблем.
Шрифты: для арабского — Amiri, Scheherazade New (SIL). Для иврита — Frank Rühl Libre, Miriam. Bundled fonts вместо системных — гарантия корректного рендеринга на всех устройствах.
Расписание и исламский/еврейский календарь
Намаз-расписание — рассчитывается по геолокации на основе астрономических алгоритмов (методы расчёта: Muslim World League, ISNA, Karachi, MWL). Библиотеки: Adhan (Swift/Kotlin порт — открытый исходный код, хорошая точность). Вычисления на клиенте без сети — критично для offline.
Исламский (хиджри) календарь: iOS Calendar(identifier: .islamicCivil) или .islamicTabular. Android java.util.Calendar не поддерживает хиджри напрямую — нужен Android android.icu.util.IslamicCalendar (API 24+) или библиотека. Конвертация дат между григорианским и хиджри — частый источник ошибок в off-by-one при граничных датах.
Еврейский календарь: iOS Calendar(identifier: .hebrew). Рош Хашана, Yom Kippur, Песах — вычисляются относительно лунно-солнечного цикла. KosherJava (Android) — наиболее полная библиотека для расчёта еврейских дат и времени зажигания свечей.
Медиатека: проповеди и лекции
Проповеди — это аудио/видео контент с теми же требованиями что и подкаст-плеер: background playback, Lock Screen controls, variable speed, offline-загрузка. На iOS: AVPlayer + AVAudioSession.category = .playback. На Android: MediaSessionCompat + ExoPlayer через MediaBrowserServiceCompat для foreground service.
Каталог проповедей: серии, теги (тема, оратор, дата), full-text search. Elasticsearch с поддержкой арабской морфологии — arabic analyzer, стеммер Snowball для Arabic (есть в Elasticsearch). Для русскоязычных общин — russian analyzer.
Live-трансляция богослужений. RTMP-стриминг (OBS / мобильный энкодер) → конвертация в HLS через nginx-rtmp или AWS IVS → воспроизведение через AVPlayer (iOS) / ExoPlayer (Android). Для небольших общин — YouTube Live embed в WKWebView как простое решение. Для собственной инфраструктуры — Ant Media Server как self-hosted RTMP/HLS сервер.
Пожертвования и финансовые потоки
Прём пожертвований через Apple Pay / Google Pay: PKPaymentAuthorizationViewController на iOS, PaymentRequest API через Android Pay. Эквайринг: ЮKassa (ранее Яндекс.Касса) — хорошо работает с религиозными НКО, не требует сложной верификации для небольших сборов. Stripe для международных организаций.
Важно: Apple берёт 30% с In-App Purchases, но прямые платёжные SDK (Apple Pay к внешнему эквайреру) не подпадают под IAP fees при соблюдении App Store guidelines 3.1.1.
Уведомления по расписанию
Напоминания о намазе, богослужении, посте — локальные уведомления, не push. Они работают без сети и без сервера. На iOS: UNCalendarNotificationTrigger с DateComponents — планировать на неделю вперёд при изменении настроек или геолокации. На Android: AlarmManager.setExact (API 31+ требует SCHEDULE_EXACT_ALARM разрешение) или WorkManager с setInitialDelay.
Лимит: iOS позволяет максимум 64 запланированных локальных уведомления одновременно. При ежедневных 5 намазах на 10 дней = 50 уведомлений — вписывается. При пересчёте расписания (пользователь переехал) — отменить все предыдущие, запланировать новые.
Сроки
1–2 недели — базовое приложение с расписанием и медиатекой. 1–3 месяца — полнофункциональная платформа с live-трансляцией, пожертвованиями и RTL-поддержкой. Стоимость рассчитывается индивидуально после анализа требований.







