Clendar

Clendar - Minimal Calendar app. Written in SwiftUI.

648
86
Swift

SwiftLint


Hi everyone,

I wanted to provide an update regarding the Clendar app. Due to some personal matters, I haven’t been able to dedicate much time to maintaining the app recently.

I’m truly grateful for all the support and contributions from the Open Source community over the past years. Your encouragement and assistance have meant a lot to me and motivated me to continually improve the app. Unfortunately, I’ve had to step back temporarily to address some personal matters.

This app started out as just my personal project to catch up with annual WWDC changes, and one day I decided to convert the whole app from Swift & UIKit to SwiftUI.

The rest is history, and the stars keep rising 🌟❀️.

Words simply cannot describe how grateful I am for all your contributions and warm messages. I’m touched that everyone loves this small app and project as much as I do.

Clendar will always be in my heart.

Thank you for your understanding and patience. I look forward to resuming work on Clendar and continuing to engage with this fantastic community.

Best regards,

Vinh Nguyen


Clendar - Minimal Calendar

Minimal Calendar & Widget

Download on the App Store

Landing Page

Architecture

diagram

* Diagram generated by gitdiagram

Table of Contents

About

This project started out as a UIKit-based app for me to learn new WWDC features over the years. But one day, I decided to convert the whole app from UIKit to SwiftUI and boom, here we are.

This is the PR => https://github.com/vinhnx/Clendar/pull/35

What’s β€˜Clendar’?

It’s just Calendar, without an β€˜a’. I thought it was unique, but it turns out it’s not going well with ASO (App Store Optimization) and SEO (Search Engine Optimization).

Clendar is a calendar app made simpler. The application includes features like widgets, themes, keyboard shortcuts, and natural language parsing.

Its main features include:

  • Widgets, with customizable dark/light themes
  • Keyboard shortcuts
  • Siri shortcuts
  • Apple Watch complications
  • Custom app icons
  • Natural language parsing
  • Lunar day view
  • Dark and light modes built-in
  • Accessibility support
  • Localizations support

SwiftUI

πŸ“– I believe the best way to learn is by doing. SwiftUI is evolving and I think it’s the future of writing apps.

SwiftUI is an innovative, exceptionally simple way to build user interfaces across all Apple platforms with the power of Swift. Build user interfaces for any Apple device using just one set of tools and APIs.

– Apple

The true power of SwiftUI, to me, is its flexibility, thanks to its vast realm of view modifiers and expressiveness with property wrappers.

You can create a β€œHello, World!” app with just a few lines of code (check out the new @main attribute!) or even, a calendar view.

SwiftUI gives you the most flexible tool an Apple developer could ever ask for, all you need is a bit of creativity, and the possibilities, are, limitless.

Clendar would not be possible without the public knowledge of the community. To name a few, in no particular order:

My notes about SwiftUI:

By publishing Clendar, I would like to give back to the community. 😊

Tip to build on M1 Macs

So, maybe someone, who wants to contribute to this repo will find the next info very helpful.
If you have a MacBook on M1:

sudo arch -x86_64 gem install ffi
arch -x86_64 pod install

Or:

run terminal with Rosetta and run pod install

Thanks https://github.com/vinhnx/Clendar/issues/220#issuecomment-1107809043

Tech stacks

The following technologies were used to develop our application:

Core:

Build delivery tool:

Package Managers:

Linter:

Formatter:

Action:

Requirements

(for async/await):

  • Xcode 13.1
  • iOS 15.0
  • watchOS 8.0
  • Ruby (for Fastlane build automation)

My own Swift Packages currently used in Clendar

  • Shift - Result-based wrapper for EventKit. SwiftUI supported!
  • Laden - SwiftUI loading indicator view

Contributing

Contributing is more than welcome. If you feel like helping the app or want to add new features, feel free to take a look at my issues page. Thanks!

How To Contribute:

  • Report issues you’re facing
  • Give a πŸ‘ on issues that are relevant to you
  • Answer queries on the issue tracker

If you don’t know where to start:

  • Navigate to the issues page
  • Filter by label
  • Look for issues related to good first issue
  • Feel free to look at all the issues opened and pick one that interests you!
  1. Fork the project repository by clicking Fork in the top right-hand corner 🍴
  2. Clone the repository onto your local machine using the Git URL πŸ’»
  3. Switch to the branch you want to work on and start contributing! πŸ“

When submitting an issue, please make sure your description is clear and has enough information for someone to be able to reproduce the issue!

Important Files To Look At

Contributors

Huge thanks to everyone who took their precious time and effort to contribute to the project:

Words simply cannot describe how thankful I am. I’m deeply appreciative of all your kind contributions.

I feel very lucky that my small side project helps people find inspiration πŸ’™

Thank you again, you rock!

πŸ‡ΊπŸ‡³ πŸš€

License

MIT License

You can do whatever you want with this source code: modify, tweak, or use it as learning resources, for example… πŸ› πŸ‘¨πŸ»β€πŸ’»πŸ‘©πŸ»β€πŸ’»

But, please don’t re-distribute the app on the App Store with a different name. πŸ₯Ί

And, if you like, you can download the app for free on the App Store.

Open-source inspiration


Star History

Star History Chart


Thanks and take care! πŸ€

I’m @vinhnx on almost everywhere.