Flutter MMCalendar

License: MIT Pub Version (including pre-releases)

Package to get Myanmar calendar information with Burmese Astrological Information, Holidays and Moon phase widget.

You can check Myanmar Calendar App using flutter_mmcalendar.

Installation ๐Ÿ’ป

โ— In order to start using flutter_mmcalendar you must have the Flutter SDK installed on your machine.

Add flutter_mmcalendar to your pubspec.yaml:

dependencies:
  flutter_mmcalendar:

Install it:

flutter packages get

Features

  • Myanmar Date
  • Western Date
  • Astrological Information
  • Holidays - Myanmar Thingyan holidays and other holidays.
  • MoonPhase widget.

Usage

Import package

import 'package:flutter_mmcalendar/flutter_mmcalendar.dart';

Sample Usage:

// Default
final mmCalendar = MmCalendar();

// English language config
final mmCalendar = MmCalendar(
  config: MmCalendarConfig.englishLanguage(),
);

// Specific language and calendar type
final mmCalendar = MmCalendar(
  config: const MmCalendarConfig(
    calendarType: CalendarType.gregorian,
    language: Language.myanmar,
  ),
);

And use it

// Get MyanmarDate by year, month and day
final myanmarDate = mmCalendar.fromDate(2023, 10, 19);

// Get MyanmarDate from DateTime
final today = DateTime.now();
final myanmarDate = mmCalendar.fromDateTime(tody);

Available configs:

  • MmCalendarConfig.defaultConfig()
  • MmCalendarConfig.myanmarLanguage()
  • MmCalendarConfig.zawgyiLanguage()
  • MmCalendarConfig.englishLanguage()
  • MmCalendarConfig.monLanguage()
  • MmCalendarConfig.karenLanguage()
  • MmCalendarConfig.taiLanguage()

Available languages:

  • english
  • myanmar - Myanmar Unicode
  • zawgyi - Myanmar Zawgyi
  • mon
  • karen
  • tai

NOTE: I am not gaurantee all of the languages are properply translated well. If you find out some translations are wrong, you can contact the developer via Email or you can contribute the github repository for translation accuracy.

Changing calendar config settings

You can call the following methods from your app settings. It will change globally.

// Calendar type
GlobalCalendarConfig().setCalendarType(CalendarType.julian);
// Language
GlobalCalendarConfig().setLanguage(Language.english);

Other usages:

final mmCalendar = MmCalendar();

// Date conversion methods.
// From built-in DateTime
mmCalendar.fromDateTime(DateTime.now());

// From a specified date
mmCalendar.fromDate(2023, 7, 27);

// From a specified date and time
mmCalendar.fromDateAndTime(2023, 7, 27, 10, 30, 01);

// From julian day
mmCalendar.fromJulian(2456599);

// Get WesternDate from julian day
final westernDate = mmCalendar.getWesternDateFromJulianDay(2456599);

/// Astrological information
final date = DateTime.now();
final astro = mmCalendar.getAstro(date);

// or you can get Astro from MyanmarDate
final astro = myanmarDate.astrol

astro.getMahabote();

// All Holidays
List<String> holidays = mmCalendar.getHolidays(DateTime.now());
List<String> anniversaries = mmCalendar.getAnniversaries(DateTime.now());
List<String> thingyanDays = mmCalendar.getThingyanDays(DateTime.now());

// or
List<String> holidays = myanmarDate.holidays;

// Formatting
// Default
final mmDateStr = myanmarDate.format();
// Custom pattern
final mmDateStr = myanmarDate.format("S s k, B y k, M p f r, En.");

Myanmar Date Format Patterns

Myanmar Date formats are specified by date pattern strings. The following pattern letters are defined ('S', 's', 'B', 'y', 'k', 'M', 'p', 'f', 'E', 'n', 'r', are reserved):

// S s k, B y k, M p f r En
MyanmarDateFormat.simple
// S
MyanmarDateFormat.sasanaYear
// s
MyanmarDateFormat.buddhistEra
// B
MyanmarDateFormat.burmeseYear
// y
MyanmarDateFormat.myanmarYear
// k
MyanmarDateFormat.ku
// M
MyanmarDateFormat.monthInYear
// p
MyanmarDateFormat.moonPhase
// f
MyanmarDateFormat.fortnightDay
// E
MyanmarDateFormat.dayNameInWeek
// n
MyanmarDateFormat.nay
// r
MyanmarDateFormat.yat
Letter Date Component Examples Myanmar Examples English
S Sasana year แ€žแ€ฌแ€žแ€”แ€ฌแ€”แ€พแ€…แ€บ Sasana Year
s Buddhist era แ‚แ…แ†แ 2561
B Burmese year แ€™แ€ผแ€”แ€บแ€™แ€ฌแ€”แ€พแ€…แ€บ Myanmar Year
y Myanmar year แแƒแ‡แ‰ 1379
k Ku แ€แ€ฏ
M Month in year แ€แ€ซแ€แ€ฑแ€ซแ€„แ€บ Wagaung
p Moon phase แ€œแ€†แ€”แ€บแ€ธ waxing
f Fortnight Day แ 1
r Yat แ€›แ€€แ€บ
E Day name in week แ€แ€”แ€„แ€บแ€นแ€œแ€ฌ Monday
n Nay แ€”แ€ฑแ€ท

Astrological Information

final mmCalendar = MmCalendar();

final myanmarDate = mmCalendar.fromDate(2023, 10, 19);
final astro = myanmarDate.astro;

// or
final astro = mmCalendar.getAstro(DateTime(2023, 10, 19))

// แ€กแ€™แ€ผแ€ญแ€แ€นแ€แ€…แ€ฏแ€แ€บ
final amyeittasote = astro.getAmyeittasote();

// แ€›แ€€แ€บแ€›แ€ฌแ€‡แ€ฌ, แ€•แ€ผแ€ฟแ€’แ€ซแ€ธ, แ€™แ€ฝแ€”แ€บแ€ธแ€œแ€ฝแ€ฒแ€•แ€ผแ€ฟแ€’แ€ซแ€ธ
final astrologicalDay = astro.getAstrologicalDay();

// "Binga", "Atun", "Yaza", "Adipati", "Marana", "Thike", "Puti"
final mahabote = astro.getMahabote();

// แ€™แ€Ÿแ€ฌแ€›แ€€แ€บแ€€แ€ผแ€™แ€บแ€ธ
final mahayatkyan = astro.getMahayatkyan();

// "West", "North", "East", "South"
final nagahle = astro.getNagahle();

// แ€”แ€‚แ€ซแ€ธแ€•แ€ฑแ€ซแ€บ
final nagapor = astro.getNagapor();

// "Ogre", "Elf", "Human"
final nakhat = astro.getNakhat();

// แ€ฅแ€•แ€ฏแ€žแ€บ
final sabbath = astro.getSabbath();

// แ€›แ€พแ€™แ€บแ€ธแ€›แ€€แ€บ
final shanyat = astro.getShanyat();

// แ€žแ€™แ€ฌแ€ธแ€Šแ€ญแ€ฏ
final thamanyo = astro.getThamanyo();

// แ€žแ€™แ€ฌแ€ธแ€–แ€ผแ€ฐ
final thamaphyu = astro.getThamaphyu();

// แ€แ€ซแ€›แ€™แ€ญแ€แ€นแ€แ€ฏแ€€แ€ผแ€ฎแ€ธ
final warameittugyi = astro.getWarameittugyi();

// แ€แ€ซแ€›แ€™แ€ญแ€แ€นแ€แ€ฏแ€„แ€šแ€บ
final warameittunge = astro.getWarameittunge();

// แ€›แ€€แ€บแ€•แ€ฏแ€•แ€บ
final yatpote = astro.getYatpote();

// แ€›แ€€แ€บแ€šแ€ฏแ€แ€บแ€™แ€ฌ
final yatyotema = astro.getYatyotema();

// "แ€•แ€ฏแ€ฟแ€”แ€พแ€…แ€บ", "แ€™แ€ฌแ€แ€”แ€พแ€…แ€บ", "แ€–แ€นแ€œแ€€แ€ญแ€ฏแ€”แ€บแ€žแ€ถแ€แ€…แ€นแ€†แ€ญแ€ฏแ€แ€บแ€›แ€”แ€พแ€…แ€บ", "แ€…แ€šแ€บแ€”แ€พแ€…แ€บ", "แ€•แ€ญแ€žแ€ปแ€€แ€บแ€”แ€พแ€…แ€บ", "แ€…แ€ญแ€ฟแ€”แ€พแ€…แ€บ", "แ€กแ€ฌแ€žแ€แ€บแ€”แ€พแ€…แ€บ", "แ€žแ€›แ€แ€”แ€บแ€”แ€พแ€…แ€บ",
// "แ€˜แ€’แ€นแ€’แ€ผแ€žแ€ถแ€แ€…แ€นแ€†แ€ฏแ€ถแ€›แ€บแ€”แ€พแ€…แ€บ", "แ€กแ€ฌแ€žแ€ญแ€”แ€บแ€”แ€พแ€…แ€บ", "แ€€แ€ผแ€แ€ญแ€ฏแ€€แ€บแ€”แ€พแ€…แ€บ", "แ€™แ€ผแ€ญแ€€แ€นแ€€แ€žแ€ญแ€ฏแ€แ€บแ€”แ€พแ€…แ€บ"
final yearName = astro.getYearName();

You can also check these days by calling is prefix properties.

Example:

// It will return true or false
final isAmyeittasote = astro.isAmyeittasote;

Moon Phase Widget

MoonPhaseWidget(
  date: DateTime.now(),
  size: 90,
),

Concept reference resources

Algorithm, Program and Calculation of Myanmar Calendar

C++ and Javascript Implementation

Java Library Implementation

Libraries

flutter_mmcalendar
Myanmar calendar library for flutter application with many utility methods and calculations.