mirror of
https://github.com/JanDeDobbeleer/oh-my-posh.git
synced 2025-01-16 05:38:27 -08:00
194 lines
10 KiB
Plaintext
194 lines
10 KiB
Plaintext
---
|
|
id: brewfather
|
|
title: Brewfather
|
|
sidebar_label: Brewfather
|
|
---
|
|
|
|
## What
|
|
|
|
Calling all brewers! Keep up-to-date with the status of your [Brewfather][brewfather] batch directly in your
|
|
commandline prompt using the brewfather segment!
|
|
|
|
You will need your User ID and API Key as generated in
|
|
Brewfather's Settings screen, enabled with **batches.read** and **recipes.read** scopes.
|
|
|
|
## Sample Configuration
|
|
|
|
This example uses the default segment template to show a rendition of detail appropriate to the status of the batch
|
|
|
|
Additionally, the background of the segment will turn red if the latest reading is over 4 hours old - possibly helping indicate
|
|
an issue if, for example there is a Tilt or similar device that is supposed to be logging to Brewfather every 15 minutes.
|
|
|
|
:::info
|
|
Temperature units are in degrees C and specific gravity is expressed as `X.XXX` values.
|
|
:::
|
|
|
|
import Config from "@site/src/components/Config.js";
|
|
|
|
<Config
|
|
data={{
|
|
type: "brewfather",
|
|
style: "powerline",
|
|
powerline_symbol: "\uE0B0",
|
|
foreground: "#ffffff",
|
|
background: "#33158A",
|
|
background_templates: [
|
|
'{{ if and (.Reading) (eq .Status "Fermenting") (gt .ReadingAge 4) }}#cc1515{{end}}',
|
|
],
|
|
properties: {
|
|
user_id: "abcdefg123456",
|
|
api_key: "qrstuvw78910",
|
|
batch_id: "hijklmno098765",
|
|
},
|
|
}}
|
|
/>
|
|
|
|
## Properties
|
|
|
|
| Name | Type | Default | Description |
|
|
| -------------- | :------: | :-----: | ------------------------------------------------------------------------------------------------------------------------------- |
|
|
| `user_id` | `string` | | as provided by Brewfather's Generate API Key screen |
|
|
| `api_key` | `string` | | as provided by Brewfather's Generate API Key screen |
|
|
| `batch_id` | `string` | | Get this by navigating to the desired batch on the brewfather website, the batch id is at the end of the URL in the address bar |
|
|
| `http_timeout` | `int` | `2` | in milliseconds - How long to wait for the Brewfather service to answer the request |
|
|
| `day_icon` | `string` | `d` | icon or letter to use to indicate days |
|
|
|
|
## Icons
|
|
|
|
You can override the icons for temperature trend as used by template property `.TemperatureTrendIcon` with:
|
|
|
|
| Name | Description |
|
|
| -------------------- | ----------------------------------------------- |
|
|
| `doubleup_icon` | for increases of more than 4°C, default is `↑↑` |
|
|
| `singleup_icon` | increase 2-4°C, default is `↑` |
|
|
| `fortyfiveup_icon` | increase 0.5-2°C, default is `↗` |
|
|
| `flat_icon` | change less than 0.5°C, default is `→` |
|
|
| `fortyfivedown_icon` | decrease 0.5-2°C, default is `↘` |
|
|
| `singledown_icon` | decrease 2-4°C, default is `↓` |
|
|
| `doubledown_icon` | decrease more than 4°C, default is `↓↓` |
|
|
|
|
You can override the default icons for batch status as used by template property `.StatusIcon` with:
|
|
|
|
| Name |
|
|
| -------------------------- |
|
|
| `planning_status_icon` |
|
|
| `brewing_status_icon` |
|
|
| `fermenting_status_icon` |
|
|
| `conditioning_status_icon` |
|
|
| `completed_status_icon` |
|
|
| `archived_status_icon` |
|
|
|
|
## Template ([info][templates])
|
|
|
|
:::note default template
|
|
|
|
```template
|
|
{{ .StatusIcon }} {{ if .DaysBottledOrFermented }}{{ .DaysBottledOrFermented }}{{ .DayIcon }} {{ end }}{{ url .Recipe.Name .URL }} {{ printf \"%.1f\" .MeasuredAbv }}%{{ if and (.Reading) (eq .Status \"Fermenting\") }} {{ printf \"%.3f\" .Reading.Gravity }} {{ .Reading.Temperature }}\u00b0 {{ .TemperatureTrendIcon }}{{ end }}
|
|
```
|
|
|
|
:::
|
|
|
|
### Properties
|
|
|
|
| Name | Type | Description |
|
|
| ----------------------- | -------- | ------------------------------------------------------------------------------------------------ |
|
|
| .Status | `string` | One of "Planning", "Brewing", "Fermenting", "Conditioning", "Completed" or "Archived" |
|
|
| .StatusIcon | `string` | Icon representing above stats. Can be overridden with properties shown above |
|
|
| .TemperatureTrendIcon | `string` | Icon showing temperature trend based on latest and previous reading |
|
|
| .DaysFermenting | `int` | days since start of fermentation |
|
|
| .DaysBottled | `int` | days since bottled/kegged |
|
|
| .DaysBottledOrFermented | `int` | one of the above, chosen automatically based on batch status |
|
|
| .Recipe.Name | `string` | The recipe being brewed in this batch |
|
|
| .BatchName | `string` | The name of this batch |
|
|
| .BatchNumer | `int` | The number of this batch |
|
|
| .MeasuredAbv | `float` | The ABV for the batch - either estimated from recipe or calculated from entered OG and FG values |
|
|
| .ReadingAge | `int` | age in hours of most recent reading or -1 if there are no readings available |
|
|
|
|
#### Reading
|
|
|
|
`.Reading` contains the most recent data from devices or manual entry as visible on the Brewfather's batch Readings graph.
|
|
If there are no readings available, `.Reading` will be null.
|
|
|
|
| Name | Type | Description |
|
|
| -------------------- | -------- | ------------------------------------------ |
|
|
| .Reading.Gravity | `float` | specific gravity (in decimal point format) |
|
|
| .Reading.Temperature | `float` | temperature in °C |
|
|
| .Reading.Time | `int` | unix timestamp of reading |
|
|
| .Reading.Comment | `string` | comment attached to this reading |
|
|
| .Reading.DeviceType | `string` | source of the reading, e.g. "Tilt" |
|
|
| .Reading.DeviceID | `string` | id of the device, e.g. "PINK" |
|
|
|
|
#### Additional properties
|
|
|
|
| Name | Type | Description |
|
|
| ----------------- | -------- | --------------------------------------------------------------------- |
|
|
| .MeasuredOg | `float` | The OG for the batch as manually entered into Brewfather |
|
|
| .MeasuredFg | `float` | The FG for the batch as manually entered into Brewfather |
|
|
| .BrewDate | `int` | The unix timestamp of the brew day |
|
|
| .FermentStartDate | `int` | The unix timestamp when fermentation was started |
|
|
| .BottlingDate | `time` | The unix timestamp when bottled/kegged |
|
|
| .TemperatureTrend | `float` | The difference between the most recent and previous temperature in °C |
|
|
| .DayIcon | `string` | given by "day_icon", or "d" by default |
|
|
|
|
#### Hyperlink support
|
|
|
|
| Name | Type | Description |
|
|
| ------ | -------- | ---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
| `.URL` | `string` | the URL for the batch in the Brewfather app. You can use this to add a hyperlink to the segment if you are using a terminal that supports it. The default template implements this |
|
|
|
|
### Advanced Templating
|
|
|
|
The built in template will provides key useful information. However, you can use the properties about the batch
|
|
to build your own. For reference, the built-in template looks like this:
|
|
|
|
<Config
|
|
data={{
|
|
template:
|
|
'{{.StatusIcon}} {{if .DaysBottledOrFermented}}{{.DaysBottledOrFermented}}{{.DayIcon}} {{end}}[{{.Recipe.Name}}]({{.URL}}) {{printf "%.1f" .MeasuredAbv}}%{{ if and (.Reading) (eq .Status "Fermenting")}}: {{printf "%.3f" .Reading.Gravity}} {{.Reading.Temperature}}\u00b0 {{.TemperatureTrendIcon}}{{end}}',
|
|
}}
|
|
/>
|
|
|
|
### Unit conversion
|
|
|
|
By default temperature readings are provided in degrees C, gravity readings in decimal Specific Gravity unts (X.XXX).
|
|
|
|
The following conversion functions are available to the template to convert to other units:
|
|
|
|
#### Temperature
|
|
|
|
| Name | Description |
|
|
| -------------- | -------------------------------------------------------------------------- |
|
|
| `DegCToF` | input: `float` degrees in C; output `float` degrees in F (1 decimal place) |
|
|
| `DegCToKelvin` | input: `float` degrees in C; output `float` Kelvin (1 decimal place) |
|
|
|
|
#### Gravity
|
|
|
|
| Name | Description |
|
|
| --------- | -------------------------------------------------------------------------- |
|
|
| SGToBrix | input `float` SG in x.xxx decimal; output `float` Brix (2 decimal places) |
|
|
| SGToPlato | input `float` SG in x.xxx decimal; output `float` Plato (2 decimal places) |
|
|
|
|
_(These use the polynomial conversions from [Wikipedia][wikipedia_gravity_page])_
|
|
|
|
#### Example
|
|
|
|
<Config
|
|
data={{
|
|
template:
|
|
"{{if .Reading}}{{.SGToBrix .Reading.Gravity}}°Bx, {{.DegCToF .Reading.Temperature}}°F{{end}}",
|
|
}}
|
|
/>
|
|
|
|
To display gravity as SG in XXXX format (e.g. "1020" instead of "1.020"), use the `mulf` template function
|
|
|
|
<Config
|
|
data={{
|
|
template:
|
|
"{{if .Reading}}{{.mulf 1000 .Reading.Gravity}}, {{.DegCToF .Reading.Temperature}}°F{{end}}",
|
|
}}
|
|
/>
|
|
|
|
[templates]: /docs/configuration/templates
|
|
[brewfather]: http://brewfather.app
|
|
[wikipedia_gravity_page]: https://en.wikipedia.org/wiki/Brix#Specific_gravity_2
|