andskur / OldNorseDictionary

An extensive Old Norse dictionary app available on macOS, iOS, iPadOS, and watchOS. Explore the language of the Vikings with detailed word information, search and filter options, and more.

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

Old Norse Dictionary πŸ“š

License Swift

Welcome to the Old Norse Dictionary app repository! This application is available on macOS, iOS, iPadOS, and watchOS. It allows you to explore the fascinating world of Old Norse language with its extensive collection of nouns, verbs, adjectives, adverbs, and more. Whether you're a language enthusiast, a history buff, or just curious about Old Norse, this app is your gateway to the ancient language of the Vikings.

Features ✨

  • Comprehensive collection of Old Norse words with English and Russian translations.
  • Filter words by type (noun, verb, adjective, etc.) and search by translation or Old Norse word.
  • Detailed word information, including noun cases, verb conjugations, and more.
  • Available on macOS, iOS, iPadOS, and watchOS.

Installation πŸ’»

The Old Norse Dictionary app is available for download on the macOS App Store. You can download it directly from the following link:

Download Old Norse Dictionary from the App Store

For developers who want to run the project locally:

  1. Clone the repository to your local machine.
  2. Open the project in Xcode.
  3. Choose the desired target (macOS, iOS, iPadOS, or watchOS).
  4. Press the Run button or use the Cmd+R shortcut to build and run the project.

Usage πŸ“–

The Old Norse Dictionary app is designed to be intuitive and easy to use. Here's a quick guide on how to use the app:

  1. Search: Enter a word in the search bar at the top of the screen. You can search for Old Norse words and see their English and Russian translations, or you can search for English or Russian words to find their Old Norse equivalents.

  2. Filter: Use the filter option to narrow down your search. You can filter words by type (noun, verb, adjective, etc.).

  3. Word Details: For each word in the search results, you'll see detailed information displayed by default. This includes noun cases, verb conjugations, and more.

  4. Switch Language: Use the dropdown menu to switch the search direction. You can choose from Old Norse to Russian, English to Old Norse, Old Norse to English, and Russian to Old Norse.

Remember, the app is available on macOS, iOS, iPadOS, and watchOS, so you can explore the Old Norse language on your preferred device.

Stay tuned for more features in future updates!

Code Structure πŸ—οΈ

The codebase is organized into several directories:

OldNorseDictionary
β”‚
β”œβ”€β”€ .github/workflows
β”‚   └── main.yml  # GitHub Actions workflow configuration file
β”‚
β”œβ”€β”€ Assets
β”‚   └── WordsData.json  # JSON file containing the data for the words in the dictionary
β”‚
β”œβ”€β”€ Source  # Main source code of the application
β”‚   β”œβ”€β”€ Models  # Contains the data models
β”‚   β”‚   β”œβ”€β”€ Case.swift  # Model for grammatical case
β”‚   β”‚   β”œβ”€β”€ Conjugation.swift  # Model for verb conjugation
β”‚   β”‚   β”œβ”€β”€ Number.swift  # Model for grammatical number
β”‚   β”‚   β”œβ”€β”€ Person.swift  # Model for grammatical person
β”‚   β”‚   └── Word.swift  # Main model representing a word in the dictionary
β”‚   β”‚
β”‚   β”œβ”€β”€ Views  # Contains the SwiftUI views
β”‚   β”‚   β”œβ”€β”€ WordDetailView.swift  # View for displaying the details of a word
β”‚   β”‚   └── WordSearchView.swift  # View for the word search functionality
β”‚   β”‚
β”‚   β”œβ”€β”€ Controllers  # Contains the controllers
β”‚   β”‚   └── WordSearchController.swift  # Controller for managing the word search functionality
β”‚   β”‚
β”‚   β”œβ”€β”€ Services  # Contains the services
β”‚   β”‚   └── WordService.swift  # Service for fetching and filtering words
β”‚   β”‚
β”‚   β”œβ”€β”€ Assets.xcassets  # Contains the assets used in the app, like images and colors
β”‚   β”œβ”€β”€ OldNorseDictionaryApp.swift  # Main entry point of the application
β”‚   └── OldNorseDictionary.entitlements  # File for specifying the app's entitlements
β”‚
β”œβ”€β”€ Tests  # Contains the unit tests for the application
β”‚   β”œβ”€β”€ OldNorseDictionaryUnitTests.xctestplan  # Test plan for the unit tests
β”‚   β”œβ”€β”€ UnitTests  # Contains the unit test cases
β”‚   β”‚   β”œβ”€β”€ WordSearchControllerTests.swift  # Test cases for the WordSearchController
β”‚   β”‚   └── WordServiceTests.swift  # Test cases for the WordService
β”‚
β”œβ”€β”€ WatchOSApp  # Contains the source code for the watchOS version of the app
β”‚   β”œβ”€β”€ Assets.xcassets  # Contains the assets used in the watchOS app
β”‚   β”œβ”€β”€ OldNorseDictionaryWatchOsApp.swift  # Main entry point of the watchOS application
β”‚   └── WordListView.swift  # View for displaying the list of words in the watchOS app
β”‚
β”œβ”€β”€ LICENSE  # File containing the license for the project
β”œβ”€β”€ PrivacyPolicy.md  # Markdown file containing the privacy policy for the app
└── README.md  # Markdown file containing information about the project

Contributing 🀝

Contributions to the Old Norse Dictionary app are very welcome! Whether it's reporting bugs, suggesting new features, improving documentation, or contributing code, we appreciate all forms of help.

Here's how you can contribute:

  1. Reporting Bugs: If you find a bug, please open an issue in the GitHub repository. Be sure to include a detailed description of the bug and steps to reproduce it.

  2. Suggesting Features: Have an idea for a new feature? Open an issue and describe your idea. Be as detailed as possible.

  3. Improving Documentation: Good documentation makes a great project even better. If you see a place where the documentation could be improved, please open an issue or submit a pull request.

  4. Contributing Code: If you'd like to contribute code, please fork the repository, make your changes, and submit a pull request. Please make sure your code follows the existing style for consistency.

Thank you for helping to improve the Old Norse Dictionary app!

License πŸ“œ

This project is licensed under the MIT License.

Credits πŸ™

The Old Norse Dictionary app was created by Andrey Skurlatov, a passionate developer with an interest in languages and history.

This project wouldn't be possible without the following resources:

  • Swift: The powerful and intuitive programming language for macOS, iOS, watchOS, and tvOS.
  • OpenAI: For providing the AI model that helped in code improvements and documentation.
  • School of Medieval Arts: For providing the Old Norse dictionary and fostering a love for the Old Norse language.

Contact πŸ“¬

If you have any questions, comments, or suggestions about the Old Norse Dictionary app, we'd love to hear from you! Here's how you can reach us:

We look forward to hearing from you!

About

An extensive Old Norse dictionary app available on macOS, iOS, iPadOS, and watchOS. Explore the language of the Vikings with detailed word information, search and filter options, and more.

License:MIT License


Languages

Language:Swift 100.0%