Compare commits

..

5 Commits

Author SHA1 Message Date
Travis Abendshien
640a792d37 docs: add mkdocs-redirects 2025-09-28 12:45:53 -07:00
Travis Abendshien
eb818ed7db docs: adjust list margins 2025-09-18 02:55:12 -07:00
Travis Abendshien
c9e663d28c docs: futher layout changes 2025-09-18 02:39:28 -07:00
Travis Abendshien
9c907d2750 docs: update changelog 2025-09-18 01:46:57 -07:00
Travis Abendshien
7f304c7d47 refactor: add tab navigation, refactor docs layout 2025-09-16 15:48:43 -07:00
21 changed files with 165 additions and 246 deletions

286
README.md
View File

@@ -1,92 +1,120 @@
# TagStudio: A User-Focused Photo & File Management System
# TagStudio: A User-Focused Document Management System
[![Downloads](https://img.shields.io/github/downloads/TagStudioDev/TagStudio/total.svg?maxAge=2592001)](https://github.com/TagStudioDev/TagStudio/releases)
[![Translations](https://hosted.weblate.org/widget/tagstudio/strings/svg-badge.svg)](https://hosted.weblate.org/projects/tagstudio/strings/)
[![Translation](https://hosted.weblate.org/widget/tagstudio/strings/svg-badge.svg)](https://hosted.weblate.org/projects/tagstudio/strings/)
[![PyTest](https://github.com/TagStudioDev/TagStudio/actions/workflows/pytest.yaml/badge.svg)](https://github.com/TagStudioDev/TagStudio/actions/workflows/pytest.yaml)
[![MyPy](https://github.com/TagStudioDev/TagStudio/actions/workflows/mypy.yaml/badge.svg)](https://github.com/TagStudioDev/TagStudio/actions/workflows/mypy.yaml)
[![Ruff](https://github.com/TagStudioDev/TagStudio/actions/workflows/ruff.yaml/badge.svg)](https://github.com/TagStudioDev/TagStudio/actions/workflows/ruff.yaml)
[![Downloads](https://img.shields.io/github/downloads/TagStudioDev/TagStudio/total.svg?maxAge=2592001)](https://github.com/TagStudioDev/TagStudio/releases)
<p align="center">
<img width="60%" src="docs/assets/ts-9-3_logo_text.png">
<img width="60%" src="docs/assets/github_header.png">
</p>
TagStudio is a photo & file organization application with an underlying tag-based system that focuses on giving freedom and flexibility to the user. No proprietary programs or formats, no sea of sidecar files, and no complete upheaval of your filesystem structure. **Read the documentation and more at [docs.tagstud.io](https://docs.tagstud.io)!**
> [!NOTE]
> Thank you for being patient as we've migrated our database backend from JSON to SQL! The previous warnings about the main branch being experimental and unsupported have now been removed, and any pre-existing library save files created with official TagStudio releases are able to be opened and migrated with the new v9.5+ releases!
> [!IMPORTANT]
> This project is still in an early state. There are many missing optimizations and QoL features, as well as the presence of general quirks and occasional jankiness. Making frequent backups of your library save data is **always** important, regardless of what state the program is in.
>
> With this in mind, TagStudio will _NOT:_
>
> - Touch, move, or mess with your files in any way _(unless explicitly using the "Delete File(s)" feature, which is locked behind a confirmation dialog)_.
> - Ask you to recreate your tags or libraries after new releases. It's our highest priority to ensure that your data safely and smoothly transfers over to newer versions.
> - Cause you to suddenly be able to recall your 10 trillion downloaded images that you probably haven't even seen firsthand before. You're in control here, and even tools out there that use machine learning still needed to be verified by human eyes before being deemed accurate.
<p align="center">
<img width="80%" src="docs/assets/screenshot.png" alt="TagStudio Screenshot">
</p>
<p align="center">
<i>TagStudio Alpha v9.5.5 running on macOS Sequoia.</i>
<i>TagStudio Alpha v9.5.0 running on macOS Sequoia.</i>
</p>
## Contents
- [Feature Highlights](#feature-highlights)
- [Basic Usage](#basic-usage)
- [Goals](#goals)
- [Priorities](#priorities)
- [Current Features](#current-features)
- [Contributing](#contributing)
- [Installation](#installation)
- [Goals & Priorities](#goals--priorities)
- [Usage](#usage)
- [FAQ](#faq)
## Goals
- To achieve a portable, private, extensible, open-format, and feature-rich system of organizing and rediscovering files.
- To provide powerful methods for organization, notably the concept of tag inheritance, or "taggable tags" _(and in the near future, the combination of composition-based tags)._
- To create an implementation of such a system that is resilient against a users actions outside the program (modifying, moving, or renaming files) while also not burdening the user with mandatory sidecar files or requiring them to change their existing file structures and workflows.
- To support a wide range of users spanning across different platforms, multi-user setups, and those with large (several terabyte) libraries.
- To make the dang thing look nice, too. Its 2025, not 1995.
## Priorities
1. **The concept.** Even if TagStudio as an application fails, Id hope that the idea lives on in a superior project. The [goals](#goals) outlined above dont reference TagStudio once - _TagStudio_ is what references the _goals._
2. **The system.** Frontends and implementations can vary, as they should. The core underlying metadata management system is what should be interoperable between different frontends, programs, and operating systems. A standard implementation for this should settle as development continues. This opens up the doors for improved and varied clients, integration with third-party applications, and more.
3. **The application.** If nothing else, TagStudio the application serves as the first (and so far only) implementation for this system of metadata management. This has the responsibility of doing the idea justice and showing just whats possible when it comes to user file management.
4. (The name.) I think its fine for an app or client, but it doesnt really make sense for a system or standard. I suppose this will evolve with time...
## Contributing
If you're interested in contributing to TagStudio, please take a look at the [contribution guidelines](/CONTRIBUTING.md) for how to get started!
Translation hosting generously provided by [Weblate](https://weblate.org/en/). Check out our [project page](https://hosted.weblate.org/projects/tagstudio/) to help translate TagStudio!
## Feature Highlights
## Current Features
### Libraries
A TagStudio library contains all of your tags, fields for a set of files based on one of your system directories. Similar to how Obsidian [vaults](https://help.obsidian.md/vault) function, TagStudio libraries act as a layer on top of your existing folders and file structure, and don't require your to move or duplicate files.
- Create libraries/vaults centered around a system directory. Libraries contain a series of entries: the representations of your files combined with metadata fields. Each entry represents a file in your librarys directory, and is linked to its location.
- Address moved, deleted, or otherwise "unlinked" files by using the "Fix Unlinked Entries" option in the Tools menu.
TagStudio places a `.TagStudio` folder in the folder you open as a library. Files included in your library are referred to as "entries", and are kept track of inside of a SQLite database inside the `.TagStudio` folder along with tags and other library data.
### Tagging + Custom Metadata
### File Entries
- Add custom powerful tags to your library entries
- Add metadata to your library entries, including:
- Name, Author, Artist (Single-Line Text Fields)
- Description, Notes (Multiline Text Fields)
- Create rich tags composed of a name, color, a list of aliases, and a list of "parent tags" - these being tags in which these tags inherit values from.
- Copy and paste tags and fields across file entries
- Automatically organize tags into groups based on parent tags marked as "categories"
- Generate tags from your existing folder structure with the "Folders to Tags" macro (NOTE: these tags do NOT sync with folders after they are created)
All file types are supported in TagStudio libraries, just not all have dedicated preview support. For a full list of filetypes with supported previews, see the "[Supported Previews](https://docs.tagstud.io/preview-support)" page on the documentation site. There's also playback support for videos, audio files, and supported animated image formats.
For a generalized list of what's currently supported:
- **Images**
- Raster Images (JPEG, PNG, etc.)
- Vector (SVG)
- Animated (GIF, WEBP, APNG)
- RAW Formats
- **Videos**
- **Plaintext Files**
- **Documents** _(If supported)_
- **eBooks** _(If supported)_
- **Photoshop PSDs**, **Blender Projects**, **Krita Projects**, and more!
### [Tags](https://docs.tagstud.io/tags) and [Fields](https://docs.tagstud.io/fields)
Tags represent an object or attribute - this could be a person, place, object, concept, and more. Unlike most tagging systems, TagStudio tags are not solely represented by a line of text or a hashtag. Tags in TagStudio consist of several properties and relationships that give extra customization, searching power, and ease of tagging that cannot be achieved by string-based tags alone. TagStudio tags are designed to be as simple or as complex as you'd like, giving options to users of all skill levels and use cases.
Tags currently consist of the following attributes:
- **Name**: The full name for your tag. **_This does NOT have to be unique!_**
- **Shorthand Name**: The shortest alternate name for your tag, used for abbreviations.
- **Aliases**: Alternate names your tag goes by.
- **Color**: The display color of your tag.
- **Parent Tags**: Other tags in which this tag inherits from. In practice, this means that this tag can be substituted in searches for any listed parent tags.
- Parent tags checked with the "disambiguation" checkbox next to them will be used to help disambiguate tag names that may not be unique.
- For example: If you had a tag for "Freddy Fazbear", you might add "Five Nights at Freddy's" as one of the parent tags. If the disambiguation box is checked next to "Five Nights at Freddy's" parent tag, then the tag "Freddy Fazbear" will display as "Freddy Fazbear (Five Nights at Freddy's)". Furthermore, if the "Five Nights at Freddy's" tag has a shorthand like "FNAF", then the "Freddy Fazbear" tag will display as "Freddy Fazbear (FNAF)".
- **Is Category**: A property that when checked, treats this tag as a category in the preview panel.
Fields, like tags, are additional pieces of custom metadata that you can add to your file entries. Fields currently have several hardcoded names (e.g. "Title", "Author", "Series") but custom field names are planned for an upcoming update.
Field types currently include:
- **Text Lines**: Single lines of text.
- **Text Boxes**: Multi-line pieces of text.
- **Datetimes**: Dates and times.
### [Search](https://docs.tagstud.io/search)
### Search
- Search for file entries based on tags, file path (`path:`), file types (`filetype:`), and even media types! (`mediatype:`). Path searches currently use [glob](<https://en.wikipedia.org/wiki/Glob_(programming)>) syntax, so you may need to wrap your filename or filepath in asterisks while searching. This will not be strictly necessary in future versions of the program.
- Use and combine boolean operators (`AND`, `OR`, `NOT`) along with parentheses groups, quotation escaping, and underscore substitution to create detailed search queries
- Use special search conditions (`special:untagged` and `special:empty`) to find file entries without tags or fields, respectively
## Basic Usage
### File Entries
> [!TIP]
> For more usage instructions, see the [documentation site](https://docs.tagstud.io/libraries)!
- Nearly all file types are supported in TagStudio libraries - just not all have dedicated thumbnail support.
- Preview most image file types, animated GIFs, videos, plain text documents, audio files, Blender projects, and more!
- Open files or file locations by right-clicking on thumbnails and previews and selecting the respective context menu options. You can also click on the preview panel image to open the file, and click the file path label to open its location.
- Delete files from both your library and drive by right-clicking the thumbnail(s) and selecting the "Move to Trash"/"Move to Recycle Bin" option.
> [!NOTE]
> For more information on the project itself, please see the [FAQ](#faq) section as well as the [documentation](https://docs.tagstud.io/)!
## Installation
To download executable builds of TagStudio, visit the [Releases](https://github.com/TagStudioDev/TagStudio/releases) page of the GitHub repository and download the latest release for your system under the "Assets" section at the bottom of the release.
TagStudio has builds for **Windows**, **macOS** _(Apple Silicon & Intel)_, and **Linux**. We also offer portable releases for Windows and Linux which are self-contained and easier to move around.
For detailed instructions, installation help, and instructions for developing for TagStudio, please see the "[Installation](https://docs.tagstud.io/install/)" page on our documentation website.
<!-- prettier-ignore -->
> [!CAUTION]
> **We do not currently publish TagStudio to any package managers. Any TagStudio distributions outside of the GitHub [Releases](https://github.com/TagStudioDev/TagStudio/releases) page are _unofficial_ and not maintained by us.**
>
> Installation support will not be given to users installing from unofficial sources. Use these versions at your own risk!
### Third-Party Dependencies
For video thumbnails and playback, you'll also need [FFmpeg](https://ffmpeg.org/download.html) installed on your system. If you encounter any issues with this, please reference our [FFmpeg Help](/docs/help/ffmpeg.md) guide.
## Usage
### Creating/Opening a Library
@@ -94,36 +122,50 @@ With TagStudio opened, start by creating a new library or opening an existing on
### Refreshing the Library
Libraries under 10,000 files automatically scan for new or modified files when opened. In order to refresh the library manually, select "Refresh Directories" under the File menu or by pressing <kbd>Ctrl</kbd></kbd>+<kbd>R</kbd> (macOS: <kbd>⌘ Command</kbd>+<kbd>R</kbd>).
Libraries under 10,000 files automatically scan for new or modified files when opened. In order to refresh the library manually, select "Refresh Directories" under the File menu.
### Adding Tags to File Entries
Access the "Add Tag" search box by either clicking on the "Add Tag" button at the bottom of the right sidebar, accessing the "Add Tags to Selected" option from the File menu, or by pressing <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>T</kbd>.
From here you can search for existing tags or create a new one if the one you're looking for doesn't exist. Click the "+" button next to any tags you want to to the currently selected file entries. To quickly add the top result, press the <kbd>Enter</kbd>/<kbd>Return</kbd> key to add the the topmost tag and reset the tag search. Press <kbd>Enter</kbd>/<kbd>Return</kbd> once more to close the dialog box. By using this method, you can quickly add various tags in quick succession just by using the keyboard!
To remove a tag from a file entry, hover over the tag in the preview panel and click on the "-" icon that appears.
### Adding Metadata to File Entries
To add a metadata field to a file entry, start by clicking the "Add Field" button at the bottom of the preview panel. From the dropdown menu, select the type of metadata field youd like to add to the entry
### Editing Metadata Fields
#### Text Line / Text Box
Hover over the field and click the pencil icon. From there, add or edit text in the dialog box popup.
> [!WARNING]
> Keyboard control and navigation is currently _very_ buggy, but will be improved in future versions.
### Creating Tags
Create a new tag by accessing the "New Tag" option from the Edit menu or by pressing <kbd>Ctrl</kbd>+<kbd>T</kbd> (macOS: <kbd>⌘ Command</kbd>+<kbd>T</kbd>). In the tag creation panel, enter a tag name, optional shorthand name, optional tag aliases, optional parent tags, and an optional color.
Create a new tag by accessing the "New Tag" option from the Edit menu or by pressing <kbd>Ctrl</kbd>+<kbd>T</kbd>. In the tag creation panel, enter a tag name, optional shorthand name, optional tag aliases, optional parent tags, and an optional color.
- The tag **name** is the base name of the tag. **_This does NOT have to be unique!_**
- The tag **shorthand** is a special type of alias that displays in situations where screen space is more valuable, notably with name disambiguation.
- **Aliases** are alternate names for a tag. These let you search for terms other than the exact tag name in order to find the tag again.
- **Parent Tags** are tags in which this this tag can substitute for in searches. In other words, tags under this section are parents of this tag.
- Parent tags with the disambiguation check next to them will be used to help disambiguate tag names that may not be unique.
- For example: If you had a tag for "Freddy Fazbear", you might add "Five Nights at Freddy's" as one of the parent tags. If the disambiguation box is checked next to "Five Nights at Freddy's" parent tag, then the tag "Freddy Fazbear" will display as "Freddy Fazbear (Five Nights at Freddy's)". Furthermore, if the "Five Nights at Freddy's" tag has a shorthand like "FNAF", then the "Freddy Fazbear" tag will display as "Freddy Fazbear (FNAF)".
- The **color** option lets you select an optional color palette to use for your tag.
- The **"Is Category"** property lets you treat this tag as a category under which itself and any child tags inheriting from it will be sorted by inside the preview panel.
#### Tag Manager
You can manage your library of tags from opening the "Tag Manager" panel from Edit -> "Tag Manager" or by pressing <kbd>Ctrl</kbd>+<kbd>M</kbd> (macOS: <kbd>⌘ Command</kbd>+<kbd>M</kbd>). From here you can create, search for, edit, and permanently delete any tags you've created in your library.
You can manage your library of tags from opening the "Tag Manager" panel from Edit -> "Tag Manager". From here you can create, search for, edit, and permanently delete any tags you've created in your library.
### Editing Tags
To edit a tag, click on it inside the preview panel or right-click the tag and select "Edit Tag" from the context menu.
### Adding Tags to File Entries
Access the "Add Tag" search box by either clicking on the "Add Tag" button at the bottom of the right sidebar, accessing the "Add Tags to Selected" option from the File menu, or by pressing <kbd>Ctrl</kbd>+<kbd>Shift</kbd>+<kbd>T</kbd> (macOS: <kbd>⌘ Command</kbd>+<kbd>Shift</kbd>+<kbd>T</kbd>).
From here you can search for existing tags or create a new one if the one you're looking for doesn't exist. Click the "+" button next to any tags you want to the currently selected file entries. To quickly add the top result, press the <kbd>Enter</kbd>/<kbd>Return</kbd> key to add the top-most tag and reset the tag search. Press <kbd>Enter</kbd>/<kbd>Return</kbd> once more to close the dialog box. By using this method, you can quickly add various tags in quick succession just by using the keyboard!
To remove a tag from a file entry, hover over the tag in the preview panel and click on the "-" icon that appears.
### Adding Fields to File Entries
To add a metadata field to a file entry, start by clicking the "Add Field" button at the bottom of the preview panel. From the dropdown menu, select the type of metadata field youd like to add to the entry
### Editing Fields
Hover over the field and click the pencil icon. From there, add or edit text in the dialog box popup.
### Relinking Moved Files
Inevitably some of the files inside your library will be renamed, moved, or deleted. If a file has been renamed or moved, TagStudio will display the thumbnail as a red broken chain link. To relink moved files or delete these entries, select the "Manage Unlinked Entries" option under the Tools menu. Click the "Refresh" button to scan your library for unlinked entries. Once complete, you can attempt to "Search & Relink" any unlinked file entries to their respective files, or "Delete Unlinked Entries" in the event the original files have been deleted and you no longer wish to keep their entries inside your library.
@@ -134,101 +176,57 @@ Inevitably some of the files inside your library will be renamed, moved, or dele
> [!WARNING]
> If multiple matches for a moved file are found (matches are currently defined as files with a matching filename as the original), TagStudio will currently ignore the match groups. Adding a GUI for manual selection, as well as smarter automated relinking, are high priorities for future versions.
See instructions in the "[Creating Development Environment](/CONTRIBUTING.md/#creating-a-development-environment)" section from the [contributing](https://docs.tagstud.io/contributing) page.
### Saving the Library
## Installation
As of version 9.5, libraries are saved automatically as you go. To save a backup of your library, select File -> Save Library Backup from the menu bar.
To download executable builds of TagStudio, visit the [Releases](https://github.com/TagStudioDev/TagStudio/releases) page of the GitHub repository and download the latest release for your system under the "Assets" section at the bottom of the release.
### Half-Implemented Features
TagStudio has builds for **Windows**, **macOS** _(Apple Silicon & Intel)_, and **Linux**. We also offer portable releases for Windows and Linux which are self-contained and easier to move around.
These features were present in pre-public versions of TagStudio (9.0 and below) and have yet to be fully implemented.
For detailed instructions, installation help, and instructions for developing for TagStudio, please see the "[Installation](https://docs.tagstud.io/install)" page on our documentation website.
#### Fix Duplicate Files
> [!IMPORTANT]
> If you're interested in contributing to TagStudio, please take a look at the [contribution guidelines](https://docs.tagstud.io/contributing) for how to get started!
Load in a .dupeguru file generated by [dupeGuru](https://github.com/arsenetar/dupeguru/) and mirror metadata across entries marked as duplicates. After mirroring, return to dupeGuru to manage deletion of the duplicate files. After deletion, use the "Fix Unlinked Entries" feature in TagStudio to delete the duplicate set of entries for the now-deleted files
### Third-Party Dependencies
For video thumbnails and playback, you'll also need [FFmpeg](https://ffmpeg.org/download.html) installed on your system. If you encounter any issues with this, please reference our [FFmpeg Help](/docs/help/ffmpeg.md) guide. For faster library scanning and refreshing, it's also recommended you install [ripgrep](https://github.com/BurntSushi/ripgrep).
<!-- prettier-ignore -->
> [!CAUTION]
> **We do not currently publish TagStudio to any package managers. Any TagStudio distributions outside of the GitHub [Releases](https://github.com/TagStudioDev/TagStudio/releases) page are _unofficial_ and not maintained by us.**
>
> Installation support will not be given to users installing from unofficial sources. Use these versions at your own risk!
> While this feature is functional, its a pretty roundabout process and can be streamlined in the future.
## Goals & Priorities
#### Macros
TagStudio aims to create an **open** and **robust** format for file tagging that isn't burdened by the limitations of traditional tagging and file metadata systems. **TagStudio** is the first proof-of-concept implementation of this system.
Apply tags and other metadata automatically depending on certain criteria. Set specific macros to run when the files are added to the library. Part of this includes applying tags automatically based on parent folders.
See the [**Roadmap**](docs/roadmap.md) on the documentation site for a complete list of planned features and estimated timeline.
> [!CAUTION]
> Macro options are hardcoded, and theres currently no way for the user to interface with this (still incomplete) system at all.
### Overall Goals
#### Gallery-dl Sidecar Importing
- To achieve a portable, private, extensible, open-format, and feature-rich system of organizing and rediscovering files.
- To provide powerful methods for organization, notably the concept of tag inheritance, or "taggable tags" _(and in the near future, the combination of composition-based tags)._
- To create an implementation of such a system that is resilient against a users actions outside the program (modifying, moving, or renaming files) while also not burdening the user with mandatory sidecar files or requiring them to change their existing file structures and workflows.
- To support a wide range of users spanning across different platforms, multi-user setups, and those with large (several terabyte) libraries.
- To make the dang thing look nice, too. Its 2025, not 1995.
Import JSON sidecar data generated by [gallery-dl](https://github.com/mikf/gallery-dl).
### Project Priorities
> [!CAUTION]
> This feature is not supported or documented in any official capacity whatsoever. It will likely be rolled-in to a larger and more generalized sidecar importing feature in the future.
1. **The concept.** Even if TagStudio as an application fails, Id hope that the idea lives on in a superior project. The goals outlined above dont reference TagStudio once - _TagStudio_ is what references the _goals._
2. **The system.** Frontends and implementations can vary, as they should. The core underlying metadata management system is what should be interoperable between different frontends, programs, and operating systems. A standard implementation for this should settle as development continues. This opens up the doors for improved and varied clients, integration with third-party applications, and more.
3. **The application.** If nothing else, TagStudio the application serves as the first (and so far only) implementation for this system of metadata management. This has the responsibility of doing the idea justice and showing just whats possible when it comes to user file management.
## Launching/Building From Source
See instructions in the "[Creating Development Environment](/CONTRIBUTING.md/#creating-a-development-environment)" section from the [contribution documentation](/CONTRIBUTING.md).
## FAQ
### Will TagStudio move, modify, or mess with my files?
### What State Is the Project Currently In?
**No**, outside of _explicit_ functionality such as "Move File(s) to Trash".
As of writing (Alpha v9.5.0) the project is very usable, however there's some plenty of quirks and missing QoL features. Several additional features and changes are still planned (see: [Feature Roadmap](https://docs.tagstud.io/updates/roadmap/)) that add even more power and flexibility to the tagging and field systems while making it easier to tag in bulk and perform automated operations. Bugfixes and polish are constantly trickling in along with the larger feature releases.
### Will TagStudio require me to recreate my tags or library in future updates?
### What Features Are You Planning on Adding?
**No.** It's our highest priority to ensure that your data safely and smoothly transfers over to newer versions.
See the [Feature Roadmap](https://docs.tagstud.io/updates/roadmap/) page for the core features being planned and implemented for TagStudio. For a more up to date look on what's currently being added for upcoming releases, see our GitHub [milestones](https://github.com/TagStudioDev/TagStudio/milestones) for versioned releases.
### What state is the project currently in?
As of writing (Alpha v9.5.5) the project is very usable, however there's still some quirks and missing QoL features. Several additional features and changes are still planned (see: [roadmap](https://docs.tagstud.io/roadmap)) that add even more power and flexibility to the tagging and field systems while making it easier to tag in bulk and perform automated operations. Bugfixes and polishes are constantly trickling in along with the larger feature releases.
### What features are you planning on adding?
See the [roadmap](https://docs.tagstud.io/roadmap) page for the core features being planned and implemented for TagStudio. For a more up to date look on what's currently being added for upcoming releases, see our GitHub [milestones](https://github.com/TagStudioDev/TagStudio/milestones) for versioned releases.
The most important remaining features before I consider the program to be "feature complete" are:
- Custom names for Fields
- List views for files
- Multiple root directory support for libraries
- Improved file entry relinking
- File entry groups
- Sorting by file date modified and created
- Macros
- Improved search bar with visualized tags and improved autocomplete
- Side panel for easier tagging (pinned tags, recent tags, tag search, tag palette)
- Improved tag management interface
- Improved and finalized Tag Categories
- Fixed and improved mixed entry data displays (see: [#337](https://github.com/TagStudioDev/TagStudio/issues/337))
- Sharable tag data
- Separate core library + API
### What features will NOT be added?
### Features That Will NOT Be Added
- Native Cloud Integration
- There are plenty of services already (native or third-party) that allow you to mount your cloud drives as virtual drives on your system. Hosting a TagStudio library on one of these mounts should function similarly to what native integration would look like.
- Supporting native cloud integrations such as these would be an unnecessary "reinventing the wheel" burden for us that is outside the scope of this project.
- Native ChatGPT/Claude/Gemini/_Non-Local_ LLM Integration
- This could mean different things depending on your intentions. Whether it's trying to use an LLM to replace the native search, or to trying to use a model for image recognition, I'm not interested in hooking people's TagStudio libraries into non-local LLMs such as ChatGPT and/or turn the program into a "chatbot" interface (see: [Overall Goals/Privacy](#overall-goals)).
- With that being said, the future TagStudio API should be well-suited to connect to any sort of service you'd like, including machine learning models if so you choose. I just won't _personally_ add any native integrations with online services.
- Native ChatGPT/Non-Local LLM Integration
- This could mean different things depending on your intentions. Whether it's trying to use an LLM to replace the native search, or to trying to use a model for image recognition, I'm not interested in hooking people's TagStudio libraries into non-local LLMs such as ChatGPT and/or turn the program into a "chatbot" interface (see: [Goals/Privacy](#goals)). I wouldn't, however, mind using **locally** hosted models to provide the _optional_ ability for additional searching and tagging methods (especially when it comes to facial recognition) - but this would likely take the form of plugins external to the core program anyway.
### Is a Rust port coming?
### Why Is this Already Version 9?
Not from us, or at least _not quite_. There are plans to break off the core TagStudio library into its own MIT-licensed module that can be used in other applications and plugins, and ideally this would be written in Rust. While I understand there's a lot of vocal support and volunteers willing to help with this, it's something that's better off coming at my/our own pace in order to ensure it's done correctly to align with the project's intentions and to remain maintainable in the future.
### Windows Defender thinks TagStudio is a virus or a trojan, why?
Unfortunately, executable Python applications "compiled" with something like PyInstaller are notorious for raising false positives in anti-virus software, most commonly Windows Defender (see: [#276](https://github.com/TagStudioDev/TagStudio/issues/276) and related issues). There's really not much we can do about this on our end, as the malware matches frequently change and sample submissions to Microsoft are slow and often ineffective. If you're effected by this, you may need to allow TagStudio to bypass your anti-virus software.
### Why is TagStudio already on version 9.x?
Over the first few years of private development the project went through several major iterations and rewrites. These major version bumps came quickly, and by the time TagStudio was opened-sourced the version number had already reached v9.0. Instead of resetting to "v0.0" or "v1.0" for this public release I decided to keep my v9.x numbering scheme and reserve v10.0 for when all the core features on the [roadmap](https://docs.tagstud.io/roadmap/) are implemented. Ive also labeled this version as an "Alpha" and will drop this once either all of the core features are implemented or the project feels stable and feature-rich enough to be considered "Beta" and beyond.
Over the first few years of private development the project went through several major iterations and rewrites. These major version bumps came quickly, and by the time TagStudio was opened-sourced the version number had already reached v9.0. Instead of resetting to "v0.0" or "v1.0" for this public release I decided to keep my v9.x numbering scheme and reserve v10.0 for when all the core features on the [Feature Roadmap](https://docs.tagstud.io/updates/roadmap/) are implemented. Ive also labeled this version as an "Alpha" and will drop this once either all of the core features are implemented or the project feels stable and feature-rich enough to be considered "Beta" and beyond.

Binary file not shown.

Before

Width:  |  Height:  |  Size: 34 KiB

After

Width:  |  Height:  |  Size: 98 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 38 KiB

After

Width:  |  Height:  |  Size: 85 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 30 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 29 KiB

After

Width:  |  Height:  |  Size: 76 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 29 KiB

After

Width:  |  Height:  |  Size: 75 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 1.1 MiB

After

Width:  |  Height:  |  Size: 1.1 MiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 131 KiB

After

Width:  |  Height:  |  Size: 212 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 41 KiB

After

Width:  |  Height:  |  Size: 105 KiB

View File

@@ -17,7 +17,7 @@ hide:
<figure markdown="span">
![TagStudio screenshot](./assets/screenshot.png){ width=80% }
<figcaption>TagStudio Alpha v9.5.5 running on macOS Sequoia.</figcaption>
<figcaption>TagStudio Alpha v9.5.0 running on macOS Sequoia.</figcaption>
</figure>
<div class="grid" markdown>

View File

@@ -61,7 +61,7 @@ Video thumbnails will default to the closest viable frame from the middle of the
### :material-sine-wave: Audio
Audio thumbnails will default to embedded cover art (if any) and fallback to generated waveform thumbnails. Audio file playback is supported in the Preview Panel if you have [FFmpeg](install.md#third-party-dependencies) installed on your system. Audio waveforms are currently not cached.
Audio thumbnails will default to embedded cover art (if any) andfallback to generated waveform thumbnails. Audio file playback is supported in the Preview Panel if you have [FFmpeg](install.md#third-party-dependencies) installed on your system. Audio waveforms are currently not cached.
| Filetype | Extensions | Dependencies |
| ------------------- | ------------------------ | :----------: |
@@ -69,7 +69,7 @@ Audio thumbnails will default to embedded cover art (if any) and fallback to gen
| AIFF | `.aiff`, `.aif`, `.aifc` | FFmpeg |
| Apple Lossless[^2] | `.alac`, `.aac` | FFmpeg |
| FLAC | `.flac` | FFmpeg |
| MP3 | `.mp3` | FFmpeg |
| MP3 | `.mp3`, | FFmpeg |
| Ogg | `.ogg` | FFmpeg |
| WAVE | `.wav`, `.wave` | FFmpeg |
| Windows Media Audio | `.wma` | FFmpeg |

View File

@@ -163,11 +163,6 @@ class Tag(Base):
def __hash__(self) -> int:
return hash(self.id)
def __eq__(self, value: object) -> bool:
if not isinstance(value, Tag):
return False
return self.id == value.id
def __lt__(self, other: "Tag") -> bool:
return self.name < other.name

View File

@@ -149,12 +149,10 @@ class FieldContainers(QWidget):
tag = self.lib.get_tag(tag_id)
if not tag:
return
if toggle_value:
entry.tags.add(tag)
else:
entry.tags.discard(tag)
self.update_granular(entry_tags=entry.tags, entry_fields=entry.fields, update_badges=False)
new_tags = (
entry.tags.union({tag}) if toggle_value else {t for t in entry.tags if t.id != tag_id}
)
self.update_granular(entry_tags=new_tags, entry_fields=entry.fields, update_badges=False)
def hide_containers(self):
"""Hide all field and tag containers."""

View File

@@ -439,8 +439,7 @@ class ItemThumb(FlowWidget):
def set_item(self, entry: "Entry"):
self.set_item_id(entry.id)
path = unwrap(self.lib.library_dir) / entry.path
self.set_item_path(path)
self.set_item_path(entry.path)
def set_item_id(self, item_id: int):
self.item_id = item_id

View File

@@ -312,10 +312,7 @@ class MediaPlayer(QGraphicsView):
def mousePressEvent(self, event: QMouseEvent) -> None:
# Pause media if background is clicked, with buffer around controls
buffer: int = 6
if (
event.y() < (self.height() - self.controls.height() - buffer)
and event.button() == Qt.MouseButton.LeftButton
):
if event.y() < (self.height() - self.controls.height() - buffer):
self.toggle_play()
return super().mousePressEvent(event)

View File

@@ -40,13 +40,11 @@
"entries.duplicate.merge.label": "Fusionando entradas duplicadas...",
"entries.duplicate.refresh": "Recargar entradas duplicadas",
"entries.duplicates.description": "Las entradas duplicadas se definen como múltiples entradas que apuntan al mismo archivo en el disco. Al fusionarlas, se combinarán las etiquetas y los metadatos de todos los duplicados en una única entrada consolidada. No deben confundirse con los \"archivos duplicados\", que son duplicados de sus archivos fuera de TagStudio.",
"entries.generic.refresh_alt": "&Actualizar",
"entries.generic.remove.removing": "Eliminando entradas",
"entries.generic.remove.removing_count": "Eliminando {count} Entradas...",
"entries.ignored.description": "Las entradas de archivos son consideradas \"ignoradas\" si fueron añadidas a la librería antes de las reglas para ignorar archivos fuesen actualizadas para excluirlo. Los archivos ignorados se conservan en la librería por defecto para prevenir la pérdida de datos cuando se actualizan las reglas para ignorar archivos.",
"entries.ignored.ignored_count": "Entradas Ignoradas: {count}",
"entries.ignored.remove": "Eliminar Entradas Ignoradas",
"entries.ignored.remove_alt": "Quit&ar entradas ignoradas",
"entries.ignored.scanning": "Buscando en la Librería Entidades Ignoradas...",
"entries.ignored.title": "Corregir Entradas Ignoradas",
"entries.mirror": "&Reflejar",
@@ -64,7 +62,6 @@
"entries.unlinked.relink.manual": "&Reenlace manual",
"entries.unlinked.relink.title": "Volver a vincular las entradas",
"entries.unlinked.remove": "Eliminar Entradas No Vinculadas",
"entries.unlinked.remove_alt": "Quit&ar entradas desvinculadas",
"entries.unlinked.scanning": "Buscando entradas no enlazadas en la biblioteca...",
"entries.unlinked.search_and_relink": "&Buscar && volver a vincular",
"entries.unlinked.title": "Corregir entradas no vinculadas",
@@ -127,8 +124,6 @@
"generic.overwrite_alt": "&Sobrescribir",
"generic.paste": "Pegar",
"generic.recent_libraries": "Bibliotecas recientes",
"generic.remove": "Quitar",
"generic.remove_alt": "&Quitar",
"generic.rename": "Renombrar",
"generic.rename_alt": "&Renombrar",
"generic.reset": "Reiniciar",
@@ -187,7 +182,6 @@
"library_info.cleanup.backups": "Reespaldos de la Librería:",
"library_info.cleanup.dupe_files": "Archivos Duplicados:",
"library_info.cleanup.ignored": "Entradas Ignoradas:",
"library_info.cleanup.legacy_json": "Restos de biblioteca antigua:",
"library_info.cleanup.unlinked": "Entradas No Enlazadas:",
"library_info.stats": "Estadísticas",
"library_info.stats.colors": "Colores de Etiquetas:",
@@ -234,12 +228,10 @@
"menu.settings": "Ajustes...",
"menu.tools": "&Herramientas",
"menu.tools.fix_duplicate_files": "Reparar &archivos duplicados",
"menu.tools.fix_ignored_entries": "Reparar entradas &ignoradas",
"menu.tools.fix_unlinked_entries": "Reparar entradas &desvinculadas",
"menu.view": "&Ver",
"menu.view.decrease_thumbnail_size": "Reducir tamaño miniatura",
"menu.view.increase_thumbnail_size": "Aumentar tamaño miniatura",
"menu.view.library_info": "&Información biblioteca",
"menu.window": "Ventana",
"namespace.create.description": "Los espacios de nombre se utilizan en TagStudio para separar grupos de elementos, como pueden ser etiquetas y colores, de manera que facilita exportarlos y compartirlos. Los espacios de nombre que empiezan por \"tagstudio\" se reservan para uso interno de TagStudio.",
"namespace.create.description_color": "Los colores de las etiquetas utilizan espacios de nombre como grupos de paletas de colores. Todos los colores personalizados deben estar primero bajo un espacio de nombre.",
@@ -276,8 +268,6 @@
"settings.splash.label": "Pantalla de Bienvenida",
"settings.splash.option.classic": "Clásico (9.0)",
"settings.splash.option.default": "Por Defecto",
"settings.splash.option.goo_gears": "Código abierto (9.4)",
"settings.splash.option.ninety_five": "'95 (9.5)",
"settings.splash.option.random": "Aleatorio",
"settings.tag_click_action.add_to_search": "Añadir Etiqueta a la Búsqueda",
"settings.tag_click_action.label": "Acción al hacer Clic a la Etiqueta",
@@ -287,7 +277,6 @@
"settings.theme.label": "Tema:",
"settings.theme.light": "Claro",
"settings.theme.system": "Sistema",
"settings.thumb_cache_size.label": "Tamaño cache de miniaturas",
"settings.title": "Ajustes",
"settings.zeropadding.label": "Rellenar ceros en fechas",
"sorting.direction.ascending": "Ascendiente",

View File

@@ -266,7 +266,6 @@
"settings.generate_thumbs": "Génération de vignettes",
"settings.global": "Paramètres Globaux",
"settings.hourformat.label": "Temps sur 24-Heure",
"settings.infinite_scroll": "Défilement continu",
"settings.language": "Langage",
"settings.library": "Paramètres de la Bibliothèque",
"settings.open_library_on_start": "Ouvrir la Bibliothèque au Démarrage",

View File

@@ -266,7 +266,6 @@
"settings.generate_thumbs": "Indexkép-előállítás",
"settings.global": "Globális beállítások",
"settings.hourformat.label": "24-órás idő",
"settings.infinite_scroll": "Végtelen görgetés",
"settings.language": "&Nyelv",
"settings.library": "Könyvtárbeállítások",
"settings.open_library_on_start": "&Könyvtár megnyitása a program indulásakor",

View File

@@ -40,35 +40,24 @@
"entries.duplicate.merge.label": "重複エントリを統合しています...",
"entries.duplicate.refresh": "重複エントリを最新の状態にする",
"entries.duplicates.description": "重複エントリとは、ディスク上の同じファイルを指す複数のエントリを指します。これらをマージすると、すべての重複エントリのタグとメタデータが1つのまとまったエントリに統合されます。TagStudio の外部にあるファイル自体の複製である「重複ファイル」と混同しないようにご注意ください。",
"entries.generic.refresh_alt": "最新の情報に更新(&R)",
"entries.generic.remove.removing": "エントリの削除",
"entries.generic.remove.removing_count": "{count} 個のエントリを削除しています...",
"entries.ignored.description": "「無視」されたエントリとは、ユーザーの無視ルール(“.ts_ignore” ファイル)を更新して対象外にした後も、更新前にライブラリへ追加されていたため残っている項目を指します。無視ルールを更新した際の誤削除によるデータ損失を防ぐため、既定ではこれらのファイルはライブラリに保持されます。",
"entries.ignored.ignored_count": "無視されたエントリ: {count}",
"entries.ignored.remove": "無視されたエントリを削除",
"entries.ignored.remove_alt": "無視されたエントリを削除(&V)",
"entries.ignored.scanning": "無視されたエントリをライブラリ内でスキャンしています...",
"entries.ignored.title": "無視されたエントリの修正",
"entries.mirror": "ミラー(&M)",
"entries.mirror.confirmation": "以下の {count} 件のエントリをミラーリングしてもよろしいですか?",
"entries.mirror.label": "{total} 件中 {idx} 件のエントリをミラーリングしています...",
"entries.mirror.title": "エントリをミラー",
"entries.mirror.window_title": "エントリをミラー",
"entries.remove.plural.confirm": "これら <b>{count}</b> 件のエントリをライブラリから削除しますか? ディスク上のファイルは削除されません。",
"entries.remove.singular.confirm": "このエントリをライブラリから削除しますか? ディスク上のファイルは削除されません。",
"entries.remove.plural.confirm": "以下の {count} 件のエントリを削除してもよろしいですか?",
"entries.running.dialog.new_entries": "{total} 件の新しいファイル エントリを追加しています...",
"entries.running.dialog.title": "新しいファイルエントリを追加",
"entries.tags": "タグ",
"entries.unlinked.description": "ライブラリの各エントリは、ディレクトリ内のファイルにリンクされています。エントリにリンクされたファイルがTagStudio以外で移動または削除された場合、そのエントリはリンク切れとして扱われます。<br><br>リンク切れのエントリは、ディレクトリを検索して自動的に再リンクすることも、必要に応じて削除することもできます。",
"entries.unlinked.relink.attempting": "{unlinked_count} 件中 {index} 件のエントリを再リンク中、{fixed_count} 件を正常に再リンクしました",
"entries.unlinked.description": "ライブラリの各エントリは、ディレクトリ内のファイルにリンクされています。エントリにリンクされたファイルがTagStudio以外で移動または削除された場合、そのエントリはリンクとして扱われます。<br><br>リンクのエントリは、ディレクトリを検索して自動的に再リンクすることも、必要に応じて削除することもできます。",
"entries.unlinked.relink.attempting": "{unlinked_count} 件中 {index} 件の項目を再リンク中、{fixed_count} 件を正常に再リンクしました",
"entries.unlinked.relink.manual": "手動で再リンク(&M)",
"entries.unlinked.relink.title": "エントリの再リンク",
"entries.unlinked.remove": "リンク切れのエントリを削除",
"entries.unlinked.remove_alt": "リンク切れのエントリを削除(&V)",
"entries.unlinked.scanning": "リンク切れのエントリをライブラリ内でスキャンしています...",
"entries.unlinked.scanning": "リンクのエントリをライブラリ内でスキャンしています...",
"entries.unlinked.search_and_relink": "検索して再リンク(&S)",
"entries.unlinked.title": "リンク切れのエントリを修正",
"entries.unlinked.unlinked_count": "リンク切れのエントリ数: {count}",
"entries.unlinked.title": "リンクのエントリを修正",
"entries.unlinked.unlinked_count": "リンクのエントリ数: {count}",
"ffmpeg.missing.description": "FFmpeg または FFprobe が見つかりません。マルチメディアの再生とサムネイルの表示には FFmpeg のインストールが必要です。",
"ffmpeg.missing.status": "{ffmpeg}: {ffmpeg_status}<br>{ffprobe}: {ffprobe_status}",
"field.copy": "フィールドをコピー",
@@ -79,7 +68,7 @@
"file.date_modified": "更新日時",
"file.dimensions": "ディメンション",
"file.duplicates.description": "TagStudio では、重複ファイルを管理するために DupeGuru の結果をインポートできます。",
"file.duplicates.dupeguru.advice": "ミラーリングの後は、DupeGuru を使って不要なファイルを削除できます。次に、ツール メニューの「リンク切れのエントリを修正」機能を使って、リンクされていないエントリを削除します。",
"file.duplicates.dupeguru.advice": "ミラーリングの後は、DupeGuru を使って不要なファイルを削除できます。次に、ツール メニューの「リンクのエントリを修正」機能を使って、リンクされていないエントリを削除します。",
"file.duplicates.dupeguru.file_extension": "DupeGuru ファイル (*.dupeguru)",
"file.duplicates.dupeguru.load_file": "DupeGuru ファイルの読み込み(&L)",
"file.duplicates.dupeguru.no_file": "DupeGuru ファイルが選択されていません",
@@ -118,24 +107,20 @@
"generic.edit": "編集",
"generic.edit_alt": "編集(&E)",
"generic.filename": "ファイル名",
"generic.missing": "欠落",
"generic.missing": "紛失",
"generic.navigation.back": "戻る",
"generic.navigation.next": "次へ",
"generic.no": "いいえ",
"generic.none": "なし",
"generic.overwrite": "上書き",
"generic.overwrite_alt": "上書き(&O)",
"generic.paste": "貼り付け",
"generic.recent_libraries": "最近使用したライブラリ",
"generic.remove": "削除",
"generic.remove_alt": "削除(&R)",
"generic.rename": "名前の変更",
"generic.rename_alt": "名前の変更(&R)",
"generic.reset": "リセット",
"generic.save": "保存",
"generic.skip": "スキップ",
"generic.skip_alt": "スキップ(&S)",
"generic.yes": "はい",
"home.search": "検索",
"home.search_entries": "エントリを検索",
"home.search_library": "ライブラリを検索",
@@ -146,7 +131,6 @@
"home.thumbnail_size.medium": "中サムネイル",
"home.thumbnail_size.mini": "極小サムネイル",
"home.thumbnail_size.small": "小サムネイル",
"ignore.open_file": "ディスク上の \"{ts_ignore}\" ファイルを表示",
"json_migration.checking_for_parity": "パリティチェック中...",
"json_migration.creating_database_tables": "SQLデータベース テーブルを作成しています...",
"json_migration.description": "<br>ライブラリの移行処理を開始し、結果をプレビューします。変換されたライブラリは、 「移行完了」をクリックしない限り<i>使用されません</i>。<br><br>ライブラリ データは、値が一致しているか、「一致」ラベルが表示されている必要があります。 値が一致しない場合は赤色で表示され、その横に「<b>(!)</b>」マークが表示されます。<br><center><i>大規模なライブラリの場合、この処理に数分かかることがあります。</i></center>",
@@ -183,21 +167,9 @@
"library.refresh.scanning_preparing": "新しいファイルを検索中...\n準備中...",
"library.refresh.title": "ディレクトリを更新しています",
"library.scan_library.title": "ライブラリをスキャンしています",
"library_info.cleanup": "クリーンアップ",
"library_info.cleanup.backups": "ライブラリのバックアップ:",
"library_info.cleanup.dupe_files": "重複ファイル:",
"library_info.cleanup.ignored": "無視されたエントリ:",
"library_info.cleanup.legacy_json": "旧ライブラリの残存データ:",
"library_info.cleanup.unlinked": "リンク切れのエントリ:",
"library_info.stats": "統計",
"library_info.stats.colors": "タグの色:",
"library_info.stats.entries": "エントリ:",
"library_info.stats.fields": "フィールド:",
"library_info.stats.macros": "マクロ:",
"library_info.stats.namespaces": "名前空間:",
"library_info.stats.tags": "タグ:",
"library_info.title": "ライブラリ '{library_dir}'",
"library_info.version": "ライブラリ形式のバージョン: {version}",
"library_object.name": "名前",
"library_object.name_required": "名前 (必須)",
"library_object.slug": "ID スラッグ",
@@ -219,7 +191,6 @@
"menu.file.missing_library.message": "ライブラリ \"{library}\" の場所が見つかりません。",
"menu.file.missing_library.title": "ライブラリが見つかりません",
"menu.file.new_library": "新しいライブラリ",
"menu.file.open_backups_folder": "バックアップ フォルダーを開く",
"menu.file.open_create_library": "ライブラリを開く/作成する(&O)",
"menu.file.open_library": "ライブラリを開く",
"menu.file.open_recent_library": "最近使用したライブラリを開く",
@@ -233,23 +204,19 @@
"menu.select": "選択",
"menu.settings": "設定...",
"menu.tools": "ツール(&T)",
"menu.tools.fix_duplicate_files": "重複ファイルの修正(&D)",
"menu.tools.fix_ignored_entries": "無視されたエントリの修正(&I)",
"menu.tools.fix_unlinked_entries": "リンク切れのエントリの修正(&U)",
"menu.tools.fix_duplicate_files": "重複ファイルの修正(&F)",
"menu.tools.fix_unlinked_entries": "未リンク項目の修正(&U)",
"menu.view": "表示(&V)",
"menu.view.decrease_thumbnail_size": "サムネイル サイズの縮小",
"menu.view.increase_thumbnail_size": "サムネイル サイズの拡大",
"menu.view.library_info": "ライブラリ情報(&I)",
"menu.window": "ウィンドウ",
"namespace.create.description": "タグや色などの項目グループを分離し、エクスポートや共有をしやすくするために、TagStudio では名前空間を使用します。「tagstudio」で始まる名前空間は、TagStudio の内部用途として予約されています。",
"namespace.create.description_color": "タグの色は、名前空間をカラーパレットのグループとして使用します。すべてのカスタムカラーは、最初に名前空間グループに属している必要があります。",
"namespace.create.title": "名前空間の作成",
"namespace.new.button": "新しい名前空間",
"namespace.new.prompt": "カスタムカラーを追加するには、新しい名前空間を作成してください!",
"preview.ignored": "無視",
"preview.multiple_selection": "<b>{count}</b> 件選択済み",
"preview.no_selection": "選択されていません",
"preview.unlinked": "リンク切れ",
"select.add_tag_to_selected": "選択項目にタグを追加",
"select.all": "すべて選択",
"select.clear": "選択を解除",
@@ -263,10 +230,8 @@
"settings.filepath.option.full": "フルパスを表示",
"settings.filepath.option.name": "ファイル名のみ表示",
"settings.filepath.option.relative": "相対パスを表示",
"settings.generate_thumbs": "サムネイルの生成",
"settings.global": "グローバル設定",
"settings.hourformat.label": "24時間表示",
"settings.infinite_scroll": "無限スクロール",
"settings.language": "言語",
"settings.library": "ライブラリ設定",
"settings.open_library_on_start": "起動時にライブラリを開く",
@@ -274,12 +239,6 @@
"settings.restart_required": "変更を反映するには、TagStudio を再起動してください。",
"settings.show_filenames_in_grid": "グリッドにファイル名を表示",
"settings.show_recent_libraries": "最近使用したライブラリを表示",
"settings.splash.label": "スプラッシュ スクリーン",
"settings.splash.option.classic": "クラシック (9.0)",
"settings.splash.option.default": "既定",
"settings.splash.option.goo_gears": "オープン ソース (9.4)",
"settings.splash.option.ninety_five": "'95 (9.5)",
"settings.splash.option.random": "ランダム",
"settings.tag_click_action.add_to_search": "検索にタグを追加",
"settings.tag_click_action.label": "タグクリック操作",
"settings.tag_click_action.open_edit": "タグを編集",
@@ -288,12 +247,10 @@
"settings.theme.label": "テーマ:",
"settings.theme.light": "ライト",
"settings.theme.system": "システム",
"settings.thumb_cache_size.label": "サムネイル キャッシュ サイズ",
"settings.title": "設定",
"settings.zeropadding.label": "日付ゼロ埋め",
"sorting.direction.ascending": "昇順",
"sorting.direction.descending": "降順",
"sorting.mode.random": "ランダム",
"splash.opening_library": "ライブラリ \"{library_path}\" を開いています...",
"status.deleted_file_plural": "{count} 件のファイルを削除しました!",
"status.deleted_file_singular": "1 件のファイルを削除しました!",

View File

@@ -40,21 +40,13 @@
"entries.duplicate.merge.label": "Fletter duplikatoppføringer…",
"entries.duplicate.refresh": "Oppdater Duplikate Oppføringer",
"entries.duplicates.description": "Duplikate oppføringer er definert som flere oppføringer som peker til samme fil på disken. Å slå disse sammen vil kombinere etikettene og metadataen fra alle duplikater til én enkel oppføring. Disse må ikke forveksles med \"duplikate filer\", som er duplikater av selve filene utenfor TagStudio.",
"entries.generic.refresh_alt": "&Oppdater",
"entries.generic.remove.removing": "Sletter Oppføringer",
"entries.generic.remove.removing_count": "Fjerner {count} Oppføringer…",
"entries.ignored.ignored_count": "Ignorerte Oppføringer: {count}",
"entries.ignored.remove": "Fjern Ignorerte Oppføringer",
"entries.ignored.remove_alt": "Fjer&n Ignorerte Oppføringer",
"entries.ignored.scanning": "Skanner Biblioteket etter Duplikate Oppføringer…",
"entries.ignored.title": "Fiks Ignorerte Oppføringer",
"entries.mirror": "Speil",
"entries.mirror.confirmation": "Er du sikker på at du vil speile følgende {count} Oppføringer?",
"entries.mirror.label": "Speiler {idx}/{total} Oppføringer...",
"entries.mirror.title": "Speiler Oppføringer",
"entries.mirror.window_title": "Speil Oppføringer",
"entries.remove.plural.confirm": "Er du sikker på at du vil slette følgende {count} oppføringer fra biblioteket ditt? Ingen filer på disken vil slettes.",
"entries.remove.singular.confirm": "Er du sikker på at du vil fjerne denne oppføringen fra bibliotek ditt? Ingen filer på disken vil slettes.",
"entries.remove.plural.confirm": "Er du sikker på at di v slette følgende {count} oppføringer?",
"entries.running.dialog.new_entries": "Legger til {total} Nye Filoppføringer...",
"entries.running.dialog.title": "Legger til Nye Filoppføringer",
"entries.tags": "Etiketter",
@@ -238,7 +230,6 @@
"settings.filepath.option.relative": "Vis Relative Filbaner",
"settings.global": "Globale Innstillinger",
"settings.hourformat.label": "24-timersklokke",
"settings.infinite_scroll": "Uendelig Skrolling",
"settings.language": "Språk",
"settings.library": "Biblioteksinnstilllinger",
"settings.open_library_on_start": "Åpne Bibliotek ved Start",

View File

@@ -83,12 +83,11 @@
"json_migration.heading.shorthands": "Afkortingen:",
"json_migration.migration_complete": "Migratie Afgerond!",
"json_migration.title": "Migratie Formaat Opslaan: \"{path}\"",
"library_info.stats.fields": "Velden:",
"library_info.stats.tags": "Labels:",
"library.field.add": "Veld Toevoegen",
"library.field.mixed_data": "Gemixte Data",
"library.field.remove": "Veld Weghalen",
"library.refresh.scanning_preparing": "Mappen scannen voor nieuwe bestanden...\nVoorbereiden...",
"library_info.stats.fields": "Velden:",
"library_info.stats.tags": "Labels:",
"menu.delete_selected_files_ambiguous": "Bestand(en) verplaatsen naar {trash_term}",
"menu.delete_selected_files_plural": "Bestanden verplaatsen naar {trash_term}",
"menu.delete_selected_files_singular": "Bestand verplaatsen naar {trash_term}",
@@ -102,7 +101,6 @@
"menu.select": "Selecteren",
"menu.window": "Venster",
"select.all": "Alles Selecteren",
"select.inverse": "Selectie omkeren",
"sorting.direction.ascending": "Oplopend",
"sorting.direction.descending": "Aflopend",
"status.deleted_file_plural": "{count} Bestanden Verwijderd!",
@@ -122,6 +120,5 @@
"tag.new": "Nieuw Label",
"tag.remove": "Label Weghalen",
"trash.dialog.title.plural": "Bestanden Verwijderen",
"trash.dialog.title.singular": "Bestand Verwijden",
"trash.name.generic": "Prullenbak"
"trash.dialog.title.singular": "Bestand Verwijden"
}