#birthday #age #timezone #date-time #zodiac #storefront

birthday-struct

A crate for representing and manipulating birthdays, with support for time zones, age calculations, and integration with zodiac signs

2 unstable releases

0.2.0 Dec 11, 2024
0.1.0 Dec 11, 2024

#6 in #zodiac

Download history 92/week @ 2024-12-05 149/week @ 2024-12-12 1/week @ 2024-12-19

242 downloads per month

MIT license

76KB
954 lines

birthday-struct

birthday-struct is a Rust library designed for working with birthdays. It supports:

  • Representing birthdays with an associated time zone.
  • Calculating age based on the current date.
  • Checking how many days until the next birthday or since the last one.
  • Determining if today is the user's birthday.
  • Identifying the zodiac sign corresponding to a given birthday.
  • Providing localized birthday greetings in various languages.
  • Efficient serialization and deserialization of birthday and timezone data via Serde.

Features

  • Age Calculation:
    Compute a person's age from their birth date and today's date.

  • Next and Last Birthday:
    Find out how many days remain until the next birthday, or how many days have passed since the last one.

  • Is Today Their Birthday?:
    Quickly check if a birthday matches today's date.

  • Zodiac Sign Integration:
    Convert birthdays to their corresponding zodiac signs using the zodiac-sign crate.

  • Multilingual Greetings:
    Retrieve a birthday greeting in several languages via the language-enum crate.

  • Serialization and Time Zones:
    Serialize and deserialize birthday information, including time zones provided by chrono-tz.

Example

use birthday_struct::{BirthdayBuilder, Tz, birthday_greeting};
use language_enum::Language;

fn main() {
    let birthday = BirthdayBuilder::default()
        .day(10)
        .month(8)
        .year(1990)
        .time_zone(Tz::utc())
        .build()
        .unwrap();

    println!("Is today their birthday? {}", birthday.is_today());
    println!("They are {} years old.", birthday.age().unwrap_or(0));
    println!("Days until next birthday: {}", birthday.days_until_next());
    println!("Days since last birthday: {}", birthday.days_since_last());

    let greeting = birthday_greeting(&Language::English).unwrap_or("Hello!");
    println!("{}", greeting);

    let zodiac: zodiac_sign::ZodiacSign = birthday.clone().into();
    println!("Their zodiac sign is: {}", zodiac);
}

Installation

Add birthday-struct to your Cargo.toml:

[dependencies]
birthday-struct = "0.1.0"

License

This project is licensed under the MIT license. See the LICENSE file for details.

Dependencies

~2.7–4MB
~72K SLoC