Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mk-5/fjira
The golang fuzzy-find cli jira interface 🚀
https://github.com/mk-5/fjira
Last synced: 3 days ago
JSON representation
The golang fuzzy-find cli jira interface 🚀
- Host: GitHub
- URL: https://github.com/mk-5/fjira
- Owner: mk-5
- License: agpl-3.0
- Created: 2022-03-26T16:13:52.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2024-11-13T06:57:20.000Z (2 months ago)
- Last Synced: 2025-01-05T05:07:18.005Z (10 days ago)
- Language: Go
- Homepage:
- Size: 5.02 MB
- Stars: 154
- Watchers: 4
- Forks: 5
- Open Issues: 18
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-cli-apps - fjira - Fuzzy finder and TUI application for Jira. (Productivity / HTTP Client)
- fucking-awesome-cli-apps - fjira - Fuzzy finder and TUI application for Jira. (Productivity / HTTP Client)
README
# Fjira - Fuzzy finder and TUI application for Jira.
[![Mentioned in Awesome Go](https://awesome.re/badge-flat.svg)](https://github.com/avelino/awesome-go)
![Test](https://github.com/mk-5/fjira/actions/workflows/tests.yml/badge.svg)
[![License: AGPL v3](https://img.shields.io/badge/License-AGPL%20v3-blue.svg)](https://github.com/mk-5/fjira/blob/master/LICENSE)
![GitHub release (latest by date)](https://img.shields.io/github/v/release/mk-5/fjira)
[![Go Report Card](https://goreportcard.com/badge/github.com/mk-5/fjira)](https://goreportcard.com/report/github.com/mk-5/fjira)
[![Go Reference](https://pkg.go.dev/badge/github.com/mk-5/fjira.svg)](https://pkg.go.dev/github.com/mk-5/fjira)
[![codecov](https://codecov.io/gh/mk-5/fjira/branch/master/graph/badge.svg?token=MJBTMYGQQW)](https://codecov.io/gh/mk-5/fjira)## Introduction
Fjira is a powerful command-line tool designed to simplify your interactions with Jira. Whether you're a developer,
project manager, or just a Jira enthusiast, Fjira streamlines your workflow, making Jira tasks more efficient than ever
before.![Fjira Demo](demo.gif)
## Key Features
- **Fuzzy-find like interface:** Search for Jira projects and issues with ease.
- **Assignee Control:** Quickly change issue assignees without navigating the Jira interface.
- **Status Updates:** Update Jira issue statuses directly from your terminal.
- **Efficient Comments:** Easily append comments to Jira issues.
- **Multi-Workspace Support:** Manage multiple Jira workspaces effortlessly.
- **Custom Searches:** Use Jira Query Language (JQL) for tailored searches.
- **Direct CLI Access:** Access Jira issues directly from the command line.
- **Cross-Platform Compatibility:** Works seamlessly on macOS, Linux, and Windows.## Installation
### macOS
```shell
brew tap mk-5/mk-5
brew install fjira
```### Linux
#### Ubuntu/Snap
```shell
snap install fjira
```#### Deb
Visit [https://github.com/mk-5/fjira/releases/latest](https://github.com/mk-5/fjira/releases/latest), and grab the
latest release version.```shell
sudo dpkg -i fjira_0.4.0_linux_amd64.deb
```#### AUR
```sh
yay -S fjira
```#### Binary
```shell
tar -xvzf fjira_0.4.0_Linux_x86_64.tar.gz
cp fjira /usr/local/bin/fjira
```### Windows
```shell
choco install fjira
```### Build from sources
```shell
make
./out/bin/fjira
```## Usage
```text
Usage:
fjira [flags]
fjira [command]Available Commands:
[issueKey] Open a Jira issue directly from the CLI
completion Generate the autocompletion script for the specified shell
filters Search using Jira filters
help Help about any command
jql Search using custom JQL queries
version Print the version number of fjira
workspace Switch to a different workspaceFlags:
-h, --help help for fjira
-p, --project string Open a project directly from CLIAdditional help topics:
fjira Open a fuzzy finder for projects as a default actionUse "fjira [command] --help" for more information about a command.
```## Getting Started
Using the Fjira CLI is straightforward. Simply run fjira in your terminal.
```shell
fjira
```## Workspaces
The first time you run Fjira, it will prompt you for your Jira API URL and token.
![Fjira First Run](demo_first_run.gif)
Fjira workspaces store Jira configuration data in a simple YAML file located at `~/.fjira`. You can switch between
multiple workspaces using the `fjira workspace` command.```shell
fjira workspace
```To create a new workspace, use the following command:
```shell
fjira workspace --new abc
```You can edit an existing workspace using the `--edit` flag:
```shell
fjira workspace --edit abc
```### Jira Token Type
Fjira supports both Jira Server and Jira Cloud, which use different token types for authorization. The tool will prompt
you to select the appropriate token type during workspace configuration.```shell
? Jira Token Type:1. api token
2. personal tokenEnter a number (Default is 1):
```### YAML configuration
If you prefer a manual approach, you have the option to add workspace configurations by creating a `fjira.yaml` file in the `~/.fjira/` directory.
For your convenience, an example configuration file is here: [fjira.yml](assets/fjira.yaml)## Projects search
The default view when you run `fjira` is the project search screen.
```shell
fjira
```## Opening a Specific Project
You can open a project directly from the CLI:
```shell
fjira --project=PROJ
```This will skip the project search screen and take you directly to the issues search screen.
## Opening an Issue Directly
To open an issue directly from the CLI:
```shell
fjira PROJ-123
```Fjira will skip all intermediate screens and take you directly to the issue view.
![Fjira Issue View](demo_issue.png)
## Boards View
Fjira also offers a board-like view. After opening a project, press F4 to access this view.
![Fjira Board View](demo_board_view.png)
## Custom JQL Queries
You can create and execute custom JQL queries with Fjira:
```shell
fjira jql
```![Fjira Custom JQL](demo_custom_jql.png)
## My Jira Filters
You can search using your stored (favourites) Jira Filters:
```shell
fjira filters
```![Fjira Filters](demo_filters.png)
## Custom Color Scheme
Tailor the fjira color scheme to match your preferences by creating a custom `~/.fjira/colors.yml` file. This file
allows you to personalize the colors according to your unique style.
Refer to the example file, located here: [colors.yml](assets/colors.yml)## Roadmap (TODO)
- Expand Documentation
- Create&Delete Jira Filters
- Support Additional Linux Package Managers (Apt, AUR, YUM)
- Introduce More Jira Features## Motivation
Fjira was designed for personal convenience, born out of a desire for efficiency and a love for terminal tools.
Often, we find ourselves in "I just need to transition issue 123 to the next status." While opening Jira, locating the
ticket on the board, and navigating the Jira issue modal are all perfectly fine, they do consume a fair amount of time.Fjira empowers you to execute such tasks directly from the terminal, where you're likely already working! 😄
If Fjira enhances your Jira experience as it did mine, please consider giving it a star on GitHub. 🌟 It will power-up me
for a future work.Feel free to contribute to this project and help shape its future! Your feedback and contributions are highly
appreciated.