Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/knz/lipgloss-convert
String conversion functions for lipgloss Styles
https://github.com/knz/lipgloss-convert
hacktoberfest
Last synced: 3 months ago
JSON representation
String conversion functions for lipgloss Styles
- Host: GitHub
- URL: https://github.com/knz/lipgloss-convert
- Owner: knz
- License: apache-2.0
- Created: 2022-09-02T12:10:13.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2022-09-07T22:03:02.000Z (over 2 years ago)
- Last Synced: 2024-10-14T10:54:34.477Z (3 months ago)
- Topics: hacktoberfest
- Language: Go
- Homepage:
- Size: 65.4 KB
- Stars: 24
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# lipgloss-convert
[![Latest Release](https://img.shields.io/github/release/knz/lipgloss-convert.svg)](https://github.com/knz/lipgloss-convert/releases)
[![GoDoc](https://godoc.org/github.com/golang/gddo?status.svg)](https://pkg.go.dev/github.com/knz/lipgloss-convert)
[![Build Status](https://github.com/knz/lipgloss-convert/workflows/build/badge.svg)](https://github.com/knz/lipgloss-convert/actions)
[![Go ReportCard](https://goreportcard.com/badge/knz/lipgloss-convert)](https://goreportcard.com/report/knz/lipgloss-convert)
[![Coverage Status](https://coveralls.io/repos/github/knz/lipgloss-convert/badge.svg)](https://coveralls.io/github/knz/lipgloss-convert)String conversion functions for [lipgloss](https://github.com/charmbracelet/lipgloss) Styles.
This library defines the following two functions:
```go
type Style = lipgloss.Style// Import reads style specifications from the input string
// and sets the corresponding properties in the dst style.
func Import(dst Style, input string) (Style, error)// Export emits style specifications that represent
// the given style.
func Export(s Style) string
```## Exporting styles to text
For example:
```go
import (
"fmt""github.com/charmbracelet/lipgloss"
lipglossc "github.com/knz/lipgloss-convert"
)func main() {
style := lipgloss.NewStyle().
Bold(true).
Align(lipgloss.Center).
Foreground(lipgloss.Color("#FAFAFA")).
Background(lipgloss.AdaptiveColor{"#7D56F4", "#112233"})).
BorderTopForeground(lipgloss.Color("12")).
BorderStyle(lipgloss.RoundedBorder()).
PaddingTop(2).
PaddingLeft(4).
Width(22)fmt.Println(lipglossc.Export(s))
}
```Displays:
``` css
align: 0.5;
background: adaptive(#7D56F4,#112233);
bold: true;
border-style: border("─","─","│","│","╭","╮","╯","╰");
border-top-foreground: 12;
foreground: #FAFAFA;
padding-left: 4;
padding-top: 2;
width: 22;
```## Importing styles from text
The `Import` function applies the text directives specified in its input
argument to the style also provided as argument. Other properties already
in the style remain unchanged.Which properties are supported? See the [lipgloss
documentation](https://pkg.go.dev/github.com/charmbracelet/lipgloss)
for details. `Import` automatically supports all the lipgloss
properties, as follows:- `Foreground` in lipgloss becomes `foreground` in the textual syntax.
- `UnderlineSpaces` becomes `underline-spaces`.
- etc.`Import` also supports the following special cases:
- For colors:
```
foreground: #abc;
foreground: #aabbcc;
foreground: 123;
foreground: adaptive(,);
foreground: complete(,,);
foreground: adaptive(,);
foreground: adaptive(complete(,,),complete(,,));
```- Padding, margin, align etc which can take multiple values at once:
```
margin: 10
margin: 10 20
margin: 10 20 10 20
```- Border styles:
```
border-style: rounded;
border-style: hidden;
border-style: normal;
border-style: thick;
border-style: double;
```- Border styles with top/bottom or left/right selection (see the doc
for `lipgloss.Style`'s `Border()` method):```
border: normal true false;
border: normal true false false true;
```- Resetting a style with `clear`: this erases all the properties
in the style, to start with a fresh style.