KDC_Library 0.1.0
See the version list below for details.
dotnet add package KDC_Library --version 0.1.0
NuGet\Install-Package KDC_Library -Version 0.1.0
<PackageReference Include="KDC_Library" Version="0.1.0" />
paket add KDC_Library --version 0.1.0
#r "nuget: KDC_Library, 0.1.0"
// Install KDC_Library as a Cake Addin #addin nuget:?package=KDC_Library&version=0.1.0 // Install KDC_Library as a Cake Tool #tool nuget:?package=KDC_Library&version=0.1.0
<div align="center"> <img src="https://github.com/6ebeng/Kurdish-Digital-Calendar/blob/master/Assets/Positive%20Logo%20Only.png" alt="KDC" style="width:200px;height:auto;"> </div>
Kurdish Digital Calendar (KDC)
Help keep the Kurdish Digital Calendar project alive and free! Your donation supports the development and maintenance of this valuable resource for the Kurdish community. Every contribution, big or small, makes a difference. Thank you for your generosity!
<a href="https://www.paypal.com/donate/?business=4U9ZWTGCL4XDG&amount=5&no_recurring=0&item_name=Support+the+Kurdish+Digital+Calendar%21+Your+donation+helps+keep+this+project+alive+and+free.+Thank+you+for+your+generosity%21¤cy_code=USD"> <img src="https://img.shields.io/badge/Donate-PayPal-blue.svg" alt="Donate" style="width:130px;height:auto;"> </a> <a href="#"> <img src="https://img.shields.io/badge/7507270392-FastPay-red.svg" alt="Donate" style="width:175px;height:auto;"></a> </a> <a href="#"> <img src="https://img.shields.io/badge/7507270392-FIB-cyan.svg" alt="Donate" style="width:140px;height:auto;"> </a>
Donate by Crypto USDT-TRC20: TWtHokKWbRGG5R4BahUoggCMA8rL1TFttW
</br> </br>
Download and try it out 💾here.
<a href="https://www.youtube.com/watch?v=gs6IB8x-jhY" target="_blank" rel="noopener noreferrer"> <img src="https://raw.githubusercontent.com/6ebeng/Kurdish-Digital-Calendar/master/Assets/thumbnail_1.jpg" width="400" height="auto" /> </a>
</br> </br>
The Kurdish Digital Calendar (KDC) is a versatile and user-friendly add-in designed for Microsoft Office applications. It allows users to seamlessly insert and convert dates between Gregorian, Hijri, Umm Al-Qura, and Kurdish calendars. The add-in supports various Office applications, including Word, Excel, PowerPoint, Outlook, COM Library for Access, Visio, and MS Project, ensuring consistency and accuracy in date handling across documents.
</br> <img src="https://raw.githubusercontent.com/6ebeng/Kurdish-Digital-Calendar/master/Assets/Screenshots/Screenshot%20MS%20Word%202024-07-16%20010355.png" alt="Screenshot1" style="width:auto;height:auto;">
Media Coverage
Watch the interviews about the Kurdish Digital Calendar:
Supported Dialects
- Kurdish (Central) - Sorani
- Kurdish (Northern) - Kurmanji
Calendar Types
Primary Calendars
- KDC recognizes these primary calendars in Kurdish, Arabic, and English:
- Gregorian
- Hijri
- Umm al-Qura
Reverse Conversion Calendars
- These calendars are used for reverse conversion based on the chosen primary calendar:
- Gregorian (English)
- Gregorian (Arabic)
- Gregorian (Kurdish Central)
- Gregorian (Kurdish Northern)
- Hijri (English)
- Hijri (Arabic)
- Hijri (Kurdish Central)
- Hijri (Kurdish Northern)
- Umm al-Qura (English)
- Umm al-Qura (Arabic)
- Umm al-Qura (Kurdish Central)
- Umm al-Qura (Kurdish Northern)
- Kurdish (Central)
- Kurdish (Northern)
Supported Date Formats
- dddd, dd MMMM, yyyy
- dddd, dd/MM/yyyy
- dd MMMM, yyyy
- MMMM dd, yyyy
- dd/MM/yyyy
- MM/dd/yyyy
- yyyy/MM/dd
- MMMM yyyy
- MM/yyyy
- MMMM
- yyyy
Icon themes
- Light
- Dark
Features
KD Calendar Tab
Settings
- Settings
- Open the settings dialog to configure the calendar settings, such as selecting the dialect, icon theme, add suffix calendar name, and enabling/disabling automatic date updates upon load document or open document.
Update Dates
- Update Dates
- Updates all date entries in the document to reflect changes in calendar settings or formats.
Converter (Selected Date)
Calendar
- Calendar
- Select the type of calendar system (e.g., Gregorian, Hijri, Umm Al-Qura).
Date Conversion
From Source Date Format
- Select the format of the input date.
Switch
- Reverse the conversion between the selected calendar systems.
To Target Date Format
- Select the target format for conversion.
Convert
- Convert the selected date to the Kurdish calendar date or vice versa.
Insert Date
Automatic Update
- Update Automatically
- Automatically updates the date field when the document is opened or refreshed.
Date Format
- Format
- Select a date format to use when inserting dates into your document.
Insert Today's Date
- Today
- Insert today's date into the selected field.
Date Picker
- Choose
- Open a date picker to select and insert a specific Kurdish date based on Gregorian calendar.
COM Library Integration
The Kurdish Digital Calendar (KDC) provides a COM Library to facilitate the use of Kurdish date and number conversion in various Office applications through VBA. This guide explains how to use the KDC COM Library in VBA.
The KDC COM Library provides a set of functions for converting dates between different calendar systems and formats and converting numbers to Kurdish text:
ToKurdish (Support both Kurdish Central and Kurdish Northern Dialects)
- Insert the current Kurdish date into the document.
- Syntax:
ToKurdish(formatChoice, dialect, isAddSuffix)
Default Dialect is Kurdish Central.- Parameters
- formatChoice: The format of the output date.
- dialect: The dialect of Kurdish to use ("ckb" for Central or "ku" for Northern).
- isAddSuffix: A boolean value indicating whether to add suffixes to the output date.
- Example:
ToKurdish(1, "Kurdish (Central)", true)
orToKurdish(1, "Kurdish (Northern)", true)
- Result:
- Kurdish Central Dialect : "دووشەممە، 11 بەفرانبار، 2723ی كوردی"
- Kurdish Northern Dialect : "Duşem, 11 Berfanbar, 2723 Kurdî"
- Note: The function supports dates from 21/03/0001 to 31/12/9999.
- Parameters
ConvertNumberToKurdishCentralText
- Converts a number to Kurdish Central text.
- Syntax:
ConvertNumberToKurdishCentralText(Number)
- Parameters
- Number: The number to convert to Kurdish text.
- Example:
ConvertNumberToKurdishCentralText(123456789)
- Result: "سەد و بیست و سێ ملیۆن و چوار سەد و پەنجا و شەش هەزار و حەوت سهد و ههشتاو نۆ"
- Note: The function supports numbers up to 999,999,999,999,999,999.
- Parameters
ConvertNumberToKurdishNorthernText
- Converts a number to Kurdish Northern text.
- Syntax:
ConvertNumberToKurdishNorthernText(Number)
- Parameters
- Number: The number to convert to Kurdish text.
- Example:
ConvertNumberToKurdishNorthernText(123456789)
- Result: "sed û bîst û sê milyon û çar sed û pêncî û şeş hezar û heft sed û heştê û neh"
- Note: The function supports numbers up to 999,999,999,999,999,999.
- Parameters
ConvertDateBasedOnUserSelection (Support both Kurdish Central and Kurdish Northern Dialects)
- Converts a date between different calendar systems and formats based on user selection.
- Syntax:
ConvertDateBasedOnUserSelection(Date, fromCalendar, toCalendar, fromFormat, toFormat, targetDialect, isAddSuffix)
Default Dialect is Kurdish Central. - Parameters
- Date: The date to convert.
- fromCalendar: The calendar system of the input date.
- toCalendar: The calendar system of the output date.
- fromFormat: The format of the input date.
- toFormat: The format of the output date.
- targetDialect: The dialect of Kurdish to use ("ckb" for Central or "ku" for Northern).
- isAddSuffix: A boolean value indicating whether to add suffixes to the output date.
- Example:
ConvertDateBasedOnUserSelection("01/01/2024", "Gregorian", "Kurdish", "dd/MM/yyyy", "dddd, dd MMMM, yyyy", "Kurdish (Central)", true)
orKDC.ConvertDate("01/01/2024", "Gregorian", "Kurdish", "dd/MM/yyyy", "dddd, dd MMMM, yyyy", "Kurdish (Northern)", true)
- Result:
- Kurdish Central Dialect : "دووشەممە، 11 بەفرانبار، 2723ی كوردی"
- Kurdish Northern Dialect : "Duşem, 11 Berfanbar, 2723 Kurdî"
- Note: The function supports dates from 0002-01-01 to 9999-12-31.
KDC COM Library Functions in VBA Code Example
' Declare a reference to the .NET class
Dim kdcService As Object
' Insert Now Kurdish Date
Function ToKurdish(formatChoice As Integer, dialect As String, isAddSuffix As Boolean) As String
On Error GoTo ErrorHandler
Set kdcService = CreateObject("KDCLibrary.KDCServiceImplementation")
ToKurdish = kdcService.ToKurdish(formatChoice, dialect, isAddSuffix)
Exit Function
ErrorHandler:
ToKurdish = "Error: " & Err.Description
End Function
' Convert Date Based On User Selection
Function ConvertDateBasedOnUserSelection(selectedText As String, isReverse As Boolean, targetDialect As String, fromFormat As String, toFormat As String, targetCalendar As String, isAddSuffix As Boolean) As String
On Error GoTo ErrorHandler
Set kdcService = CreateObject("KDCLibrary.KDCServiceImplementation")
ConvertDateBasedOnUserSelection = kdcService.ConvertDateBasedOnUserSelection(selectedText, isReverse, targetDialect, fromFormat, toFormat, targetCalendar, isAddSuffix)
Exit Function
ErrorHandler:
ConvertDateBasedOnUserSelection = "Error: " & Err.Description
End Function
' Convert Number To Kurdish Central Text
Function ConvertNumberToKurdishCentralText(number As Long) As String
On Error GoTo ErrorHandler
Set kdcService = CreateObject("KDCLibrary.KDCServiceImplementation")
ConvertNumberToKurdishCentralText = kdcService.ConvertNumberToKurdishCentralText(number)
Exit Function
ErrorHandler:
ConvertNumberToKurdishCentralText = "Error: " & Err.Description
End Function
' Convert Number To Kurdish Northern Text
Function ConvertNumberToKurdishNorthernText(number As Long) As String
On Error GoTo ErrorHandler
Set kdcService = CreateObject("KDCLibrary.KDCServiceImplementation")
ConvertNumberToKurdishNorthernText = kdcService.ConvertNumberToKurdishNorthernText(number)
Exit Function
ErrorHandler:
ConvertNumberToKurdishNorthernText = "Error: " & Err.Description
End Function
' Test the functions with KDC Object
Sub ExampleUsage()
Dim number As Long
number = 12345
MsgBox "Kurdish Text (Central): " & ConvertNumberToKurdishCentralText(number)
MsgBox "Kurdish Text (Northern): " & ConvertNumberToKurdishNorthernText(number)
Dim kurdishDate As String
kurdishDate = ToKurdish(1, "Kurdish (Central)", True)
MsgBox "Kurdish Date: " & kurdishDate
Dim convertedDate As String
convertedDate = ConvertDateBasedOnUserSelection("01/01/2024", False, "Kurdish (Central)", "dd/MM/yyyy", "dddd, dd MMMM, yyyy", "Gregorian", True)
MsgBox "Converted Date: " & convertedDate
End Sub
' Test the functions with KDC Library Reference
Sub ExampleUsage2()
Dim kurdishDate As String
Dim number As Long
Dim convertedDate As String
Dim kdcService As New KDC_Library.KDCServiceImplementation
number = 12345
kurdishDate = kdcService.ToKurdish(1, "Kurdish (Central)", True)
convertedDate = kdcService.ConvertDateBasedOnUserSelection("01/01/2024", False, "Kurdish (Central)", "dd/MM/yyyy", "dddd, dd MMMM, yyyy", "Gregorian", True)
MsgBox "Kurdish Text (Central): " & kdcService.ConvertNumberToKurdishCentralText(number)
MsgBox "Kurdish Text (Northern): " & kdcService.ConvertNumberToKurdishNorthernText(number)
MsgBox "Kurdish Date: " & kurdishDate
MsgBox "Converted Date: " & convertedDate
End Sub
User-Defined Functions in MS Excel
- Call custom functions like
ConvertNumberToKurdishText
andConvertDateToKurdish
directly from Excel cells.ConvertNumberToKurdishText (Support both Kurdish Central and Kurdish Northern Dialects)
- Converts a number to Kurdish text.
- Syntax:
ConvertNumberToKurdishText(Number, langcode as Optional)
Default Dialect is Kurdish Central.- Parameters
- Number: The number to convert to Kurdish text.
- langcode (optional): The dialect of Kurdish to use ("ckb" for Central or "ku" for Northern).
- Parameters
- Example:
ConvertNumberToKurdishText(123456789)
orConvertNumberToKurdishText(123456789, "ku")
orConvertNumberToKurdishText(123456789, "ckb")
- Result:
- Kurdish Central Dialect : "سەد و بیست و سێ ملیۆن و چوار سەد و پەنجا و شەش هەزار و حەوت سهد و ههشتاو نۆ"
- Kurdish Northern Dialect : "sed û bîst û sê milyon û çar sed û pêncî û şeş hezar û heft sed û heştê û neh"
- Note: The function supports numbers up to 999,999,999,999,999,999.
ConvertDateToKurdish (Support both Kurdish Central and Kurdish Northern Dialects)
- Converts a date to the Kurdish calendar.
- Syntax:
ConvertDateToKurdish(Date, targetDialect as Optional, fromFormat as Optional, toFormat as Optional, targetCalendar as Optional, isAddSuffix as Optional)
Default Dialect is Kurdish Central.- Parameters
- Date: The date to convert to the Kurdish calendar.
- targetDialect: The dialect of Kurdish to use ("ckb" for Central or "ku" for Northern).
- fromFormat: The format of the input date.
- toFormat: The format of the output date.
- targetCalendar: The calendar system to use for conversion.
- isAddSuffix (optional): A boolean value indicating whether to add suffixes to the output date.
- Example:
ConvertDateToKurdish("01/01/2024", "Kurdish (Central)", "dd/MM/yyyy", "dddd, dd MMMM, yyyy", "Gregorian", true)
orConvertDateToKurdish(01/01/2024", "Kurdish (Northern)", "dd/MM/yyyy", "dddd, dd MMMM, yyyy", "Gregorian", true)
Default Dialect is Kurdish Central. - Result:
- Kurdish Central Dialect : "دووشەممە، 11 بەفرانبار، 2723ی كوردی"
- Kurdish Northern Dialect : "Duşem, 11 Berfanbar, 2723 Kurdî"
- Note: The function supports dates from 21/03/0001 to 31/12/9999.
- Parameters
Installation
Prerequisites
- Microsoft Office (Word, Excel, PowerPoint, Outlook, Access, Visio, Project)
- .NET Framework 4.7.2 or higher
- Visual Studio Tools for Office (VSTO) Runtime 2010 or higher
Using the Installer
- Download the latest release from the GitHub releases page.
- Run the installer and select the components you wish to install.
- Follow the on-screen instructions to complete the installation.
Contributing
To contribute to the Kurdish Digital Calendar project:
- Fork the repository on GitHub.
- Create a new branch for your feature or bug fix.
- Commit your changes and push your branch to GitHub.
- Open a pull request with a description of your changes.
For more information, see our contributing guidelines.
License
This project is licensed under the Custom License for Kurdish Digital Calendar (KDC).
You are free to use this software for personal, educational, or internal business purposes only. Redistribution, publication, and commercial use are strictly prohibited without express written permission from the author. For more details, please refer to the LICENSE file.
For permissions beyond the scope of this license, please contact rekbin.devs@gmail.com.
Credits
- Developed and maintained by Tishko Rasoul (Rekbin Devs).
- The Kurdish calendar algorithm is based on the following sources:
- Kurdish Academy Calendar (2009)
- Kurdish Calendar from Wikipedia
- Hjri Calendar from Wikipedia
- Salname
- Thanks to all contributors and supporters.
Support
For issues or questions, open an issue on the Kurish Digital Calendar or contact us at rekbin.devs@gmail.com.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET Framework | net472 is compatible. net48 was computed. net481 was computed. |
-
.NETFramework 4.7.2
- No dependencies.
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Intial release.