GithubHelp home page GithubHelp logo

techwiz-3 / bubblewrap Goto Github PK

View Code? Open in Web Editor NEW
9.0 1.0 6.0 262 KB

🧼 A Python library that makes beautiful text bubbles in your terminal using NerdFont icons

License: GNU General Public License v3.0

Python 100.00%
hacktoberfest nerd nerd-fonts python-cli pythoncli rich tui bubbles bubblewrap zsh-theme shell cli command-line console python terminal

bubblewrap's Introduction

Bubblewrap

GitHub Super-Linter

bubbles

A Python library that makes beautiful text bubbles in your terminal using NerdFont icons.

Install

pip install bubblewrap-cli

Usage

The easiest way to use bubblewrap is with the Rich library.

from bubblewrap import Bubbles
from rich.console import Console

b = Bubbles()
c = Console()
print()
c.print(b.get_rich_bubble("This is text", bg_color="purple"))
print()
c.print(b.get_rich_bubble("Bubblewrap!", bg_color="dark_green", fg_color="grey66"))
print()

You can also use your own ANSI codes

from bubblewrap import Bubbles

b = Bubbles()

print()
# takes the text, circle style (an fg color), test style (the bg color same as fg color
# foreground and optionally it's own fg color), reset (your ANSI reset sequence)
print(b.get_ansi_bubbles("Ayo how are you?", "\033[31m", "\033[32;41m", "\033[0m"))
print()

Alternatively, you can link bubbles together:

from bubblewrap import Bubbles
from rich.console import Console

b = Bubbles()
c = Console()

print()
# default divider is an arrow
c.print(b.get_rich_chain("Fri 09:45", "white", "black")
         .link("直 Wi-Fi", "orange3", "white")
         .link(" Charging", "bright_green", "black").end())
# semi-circle divider
c.print(b.get_rich_chain("Fri 09:45", "white", "black", divider="")
         .link("直 Wi-Fi", "orange3", "white")
         .link(" Charging", "bright_green", "black").end())

print()
print(b.get_ansi_chain("~/Projects", "\033[37;45m", "\033[0m")
       .link("bubblewrap", "\033[30;46m")
       .link("שׂ main", "\033[30;43m").end())

Implementation

CLI's are becoming more colorful and graphical all the time. At the same time tools like starship and ohmyzsh are popularising the use of NerdFonts due to their beautiful icons and characters.
Meanwhile, UI's in general are becoming more rounded, look at the latest macOS, Windows, YouTube or Spotify GUI updates, design is moving towards bubbled and rounded looks.

With the rise of beautiful CLI's, the rising popularity of NerdFonts and the world's obssession with the rounded look, bubblewrap is the perfect way to make your CLI stand out.

But not everyone uses NerdFonts right? If you don't wish your CLI to be NerdFont dependant, simply add a CLI arguement that allows users to toggle bubblewrapped text on/off or add that option to your program's config file.

Example

bubbles

Contributors 🌟



bubblewrap's People

Contributors

aaaandrzej avatar aloner-pro avatar coldenate avatar sb-decoder avatar techwiz-3 avatar zluipaiva avatar

Stargazers

 avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar  avatar

Watchers

 avatar

bubblewrap's Issues

Add option to round off the start of links

>>> b = Bubbles(start_rounded=True)
>>> print(b.get_ansi_chain("~/Projects", "\033[37;45m", "\033[0m")
...        .link("\U+FAE2 bubblewrap", "\033[30;46m")
...        .link(" main", "\033[30;43m").end())

Screen Shot 2022-11-18 at 1 06 38 pm

Add support for NerdFont arrows

Commonly used in ZSH themes. Allow a similar function to create text with arrows like so:
Screen Shot 2022-10-12 at 11 37 41 am

The icon can be found here under the query arrow and is at the very bottom of the search. It looks like this:

Screen Shot 2022-10-12 at 11 36 12 am

Fix failing CI

CI failing in this this superlinter run, please solve the issues and make a PR.

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.