Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/HarryPeach/kia
🦕 Simple terminal spinners for Deno
https://github.com/HarryPeach/kia
cli-spinners deno hacktoberfest terminal-spinners
Last synced: 2 months ago
JSON representation
🦕 Simple terminal spinners for Deno
- Host: GitHub
- URL: https://github.com/HarryPeach/kia
- Owner: HarryPeach
- License: mit
- Created: 2020-05-07T14:38:13.000Z (over 4 years ago)
- Default Branch: master
- Last Pushed: 2023-01-15T01:39:07.000Z (about 2 years ago)
- Last Synced: 2024-10-28T12:15:29.897Z (3 months ago)
- Topics: cli-spinners, deno, hacktoberfest, terminal-spinners
- Language: TypeScript
- Homepage:
- Size: 76.2 KB
- Stars: 51
- Watchers: 2
- Forks: 8
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-deno - kia - Simple terminal spinners for Deno 🦕 (Modules / CLI utils)
README
# Kia
> Simple terminal spinners for Deno 🦕
`Version 0.4.1`
![](https://github.com/HarryPeach/kia/workflows/CI/badge.svg)
![weather.ts example](https://user-images.githubusercontent.com/4750998/81313185-710ac900-907f-11ea-9735-d623559d08f6.gif)
> Kia is based on, and has much of the features of,
> [ora](https://www.npmjs.com/package/ora). The project was also influenced by
> the work of: [cli-spinners](https://www.npmjs.com/package/cli-spinners), and
> [CLI Spinners for Deno](https://deno.land/x/cli_spinners/)## Usage
```typescript
import Kia from "https://deno.land/x/[email protected]/mod.ts";// Just a function to async sleep
function sleep(ms: number) {
return new Promise((resolve) => setTimeout(resolve, ms));
}const kia: any = new Kia("I will be back in about 3 seconds");
kia.start();
await sleep(3000); // or any other async action that'll take some time
kia.succeed("Action completed");
```More thorough examples are available in the
[examples folder](https://github.com/HarryPeach/kia/tree/master/examples)## API
### kia()
### kia(text)
### kia(options)
Kia can be created with a string or the Options interface. A string is simply
mapped to `Options.text````typescript
const kia = new Kia("Hello");
// or
const kia = new Kia({
text: "Hello",
color: "Red",
});
```#### options
You can pass any of the following options to the kia context:
##### text
Type: String
Default: ""
The text to display after the spinner
##### color
Type:
[Color](https://github.com/HarryPeach/kia/blob/8fb27cbd0bb4ef08ad26124d4a6e4f2ba2dc0c5c/util.ts#L6)Default: "white"
The color for the spinner to be. Uses the color type in util.ts, which maps to
the Deno standard colors.##### spinner
Type:
[Spinner](https://github.com/HarryPeach/kia/blob/8fb27cbd0bb4ef08ad26124d4a6e4f2ba2dc0c5c/spinners.ts#L1)Default: Dependent on OS (See below)
The spinner that the Kia instance should use. There are spinners provided in
`spinners.ts` or you can provide it with an object like so:```typescript
{
interval: 80,
frames: ["-", "|"]
}
```On windows the spinner defaults to `windows`, while on other OSes it defaults to
`dots`.Spinners can also be imported from anywhere as long as they follow this format.
See the `examples/externalSpinners.ts` example for more info.##### indent
Type: number
Default: 0
The level of indentation of the spinner in spaces
##### cursor
Type: boolean
Default: false
Whether or not to display a cursor when the spinner is active
##### writer
Type: Deno.Writer
Default: Deno.stdout
The resource to output to. This can be anything that uses the Writer interface
including stdout, stderr, and files.### Instance
#### .start(text?)
Starts the spinner. Optionally sets the text at the same time. Returns Kia
instance.#### .stop()
Stops the spinner and clears the line. Returns Kia instance.
#### .set(text)
#### .set(options)
Allows you to change the spinners options. Returns Kia instance.
```typescript
const kia = new Kia("Hello");
kia.set({ text: "Goodbye", color: "Red" });
```#### .succeed(text?)
#### .fail(text?)
#### .warn(text?)
#### .info(text?)
Stops the spinner, and returns a message with the current text or the provided
`text` as well as an icon indicating status. Wraps around `stopWithFlair()`.
Returns Kia instance.#### .stopWithFlair(text, flair)
Stops the spinner, and returns a message with the current text or the provided
`text` as well as the preceding flair/icon. Returns Kia instance.#### .stopAndPersist(options)
Stops the spinner and holds it in a static state. Returns the instance.
#### .renderNextFrame()
Renders the next frame of the spinner when it is stopped (i.e. can only be run
after .stopAndPersist()).#### .getText()
Returns the current text of the spinner
#### .getFrame()
Returns the current spinner frame
### forPromise(action, text)
### forPromise(action, options)
```typescript
import { forPromise } from "https://deno.land/x/[email protected]/mod.ts";forPromise(
async () => {
await yourAsyncAction();
},
{ text: name },
);
```Starts a spinner for a promise. The spinner is stopped with `.succeed()` if the
promise fulfills or with `.fail()` if it rejects. Returns the spinner instance.#### action
Type: Promise