Skip to content

Commit

Permalink
feat(segment): add tauri and svelte
Browse files Browse the repository at this point in the history
  • Loading branch information
Hampter authored and JanDeDobbeleer committed Nov 24, 2024
1 parent 07e1c8d commit 77e5f33
Show file tree
Hide file tree
Showing 7 changed files with 300 additions and 0 deletions.
6 changes: 6 additions & 0 deletions src/config/segment_types.go
Original file line number Diff line number Diff line change
Expand Up @@ -185,6 +185,8 @@ const (
STATUS SegmentType = "status"
// STRAVA is a sports activity tracker
STRAVA SegmentType = "strava"
// Svelte segment
SVELTE SegmentType = "svelte"
// Subversion segment
SVN SegmentType = "svn"
// SWIFT writes the active swift version
Expand All @@ -193,6 +195,8 @@ const (
SYSTEMINFO SegmentType = "sysinfo"
// TALOSCTL writes the talosctl context
TALOSCTL SegmentType = "talosctl"
// Tauri Segment
TAURI SegmentType = "tauri"
// TERRAFORM writes the terraform workspace we're currently in
TERRAFORM SegmentType = "terraform"
// TEXT writes a text
Expand Down Expand Up @@ -306,10 +310,12 @@ var Segments = map[SegmentType]func() SegmentWriter{
SPOTIFY: func() SegmentWriter { return &segments.Spotify{} },
STATUS: func() SegmentWriter { return &segments.Status{} },
STRAVA: func() SegmentWriter { return &segments.Strava{} },
SVELTE: func() SegmentWriter { return &segments.Svelte{} },
SVN: func() SegmentWriter { return &segments.Svn{} },
SWIFT: func() SegmentWriter { return &segments.Swift{} },
SYSTEMINFO: func() SegmentWriter { return &segments.SystemInfo{} },
TALOSCTL: func() SegmentWriter { return &segments.TalosCTL{} },
TAURI: func() SegmentWriter { return &segments.Tauri{} },
TERRAFORM: func() SegmentWriter { return &segments.Terraform{} },
TEXT: func() SegmentWriter { return &segments.Text{} },
TIME: func() SegmentWriter { return &segments.Time{} },
Expand Down
30 changes: 30 additions & 0 deletions src/segments/svelte.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package segments

type Svelte struct {
language
}

func (s *Svelte) Template() string {
return languageTemplate
}

func (s *Svelte) Enabled() bool {
if !s.hasNodePackage("svelte") {
return false
}

s.extensions = []string{"package.json"}
s.commands = []*cmd{
{
regex: `(?:(?P<version>((?P<major>[0-9]+).(?P<minor>[0-9]+).(?P<patch>[0-9]+))))`,
getVersion: s.getVersion,
},
}
s.versionURLTemplate = "https://github.com/sveltejs/svelte/releases/tag/svelte%40{{.Full}}"

return s.language.Enabled()
}

func (s *Svelte) getVersion() (string, error) {
return s.nodePackageVersion("svelte")
}
30 changes: 30 additions & 0 deletions src/segments/tauri.go
Original file line number Diff line number Diff line change
@@ -0,0 +1,30 @@
package segments

import (
"path/filepath"
)

type Tauri struct {
language
}

func (t *Tauri) Template() string {
return languageTemplate
}

func (t *Tauri) Enabled() bool {
t.extensions = []string{"package.json"}
t.commands = []*cmd{
{
regex: `(?:(?P<version>((?P<major>[0-9]+).(?P<minor>[0-9]+).(?P<patch>[0-9]+))))`,
getVersion: t.getVersion,
},
}
t.versionURLTemplate = "https://github.com/tauri-apps/tauri/releases/tag/tauri-v{{.Full}}"

return t.language.Enabled()
}

func (t *Tauri) getVersion() (string, error) {
return t.nodePackageVersion(filepath.Join("@tauri-apps", "api"))
}
106 changes: 106 additions & 0 deletions themes/schema.json
Original file line number Diff line number Diff line change
Expand Up @@ -386,9 +386,11 @@
"shell",
"sysinfo",
"strava",
"svelte",
"svn",
"swift",
"talosctl",
"tauri",
"time",
"text",
"terraform",
Expand Down Expand Up @@ -4899,6 +4901,110 @@
}
}
}
},
{
"if": {
"properties": {
"type": {
"const": "tauri"
}
}
},
"then": {
"title": "Tauri Segment",
"description": "https://ohmyposh.dev/docs/segments/cli/tauri",
"properties": {
"properties": {
"properties": {
"home_enabled": {
"$ref": "#/definitions/home_enabled"
},
"fetch_version": {
"$ref": "#/definitions/fetch_version"
},
"cache_duration": {
"$ref": "#/definitions/cache_duration",
"default": "none"
},
"display_mode": {
"$ref": "#/definitions/display_mode"
},
"missing_command_text": {
"$ref": "#/definitions/missing_command_text"
},
"version_url_template": {
"$ref": "#/definitions/version_url_template"
},
"extensions": {
"type": "array",
"title": "Extensions",
"description": "The extensions to look for when determining if the current directory is a Tauri project",
"default": [
"package.json"
],
"items": {
"type": "string"
}
},
"folders": {
"$ref": "#/definitions/folders"
}
}
}
}
}
},
{
"if": {
"properties": {
"type": {
"const": "svelte"
}
}
},
"then": {
"title": "Svelte Segment",
"description": "https://ohmyposh.dev/docs/segments/cli/svelte",
"properties": {
"properties": {
"properties": {
"home_enabled": {
"$ref": "#/definitions/home_enabled"
},
"fetch_version": {
"$ref": "#/definitions/fetch_version"
},
"cache_duration": {
"$ref": "#/definitions/cache_duration",
"default": "none"
},
"display_mode": {
"$ref": "#/definitions/display_mode"
},
"missing_command_text": {
"$ref": "#/definitions/missing_command_text"
},
"version_url_template": {
"$ref": "#/definitions/version_url_template"
},
"extensions": {
"type": "array",
"title": "Extensions",
"description": "The extensions to look for when determining if the current directory is a Svelte project",
"default": [
"package.json"
],
"items": {
"type": "string"
}
},
"folders": {
"$ref": "#/definitions/folders"
}
}
}
}
}
}
]
}
Expand Down
63 changes: 63 additions & 0 deletions website/docs/segments/cli/svelte.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
---
id: svelte
title: Svelte
sidebar_label: Svelte
---

## What

Display the currently active Svelte version.

## Sample Configuration

import Config from "@site/src/components/Config.js";

<Config
data={{
type: "svelte",
style: "powerline",
powerline_symbol: "\uE0B0",
foreground: "#000000",
background: "#1976d2",
template: " \ue697 {{ .Full }} ",
}}
/>

## Properties

| Name | Type | Default | Description |
| ---------------------- | :--------: | :------------: | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| `home_enabled` | `boolean` | `false` | display the segment in the HOME folder or not |
| `fetch_version` | `boolean` | `true` | fetch the svelte version |
| `cache_duration` | `string` | `24h` | the duration for which the version will be cached. The duration is a string in the format `1h2m3s` and is parsed using the [time.ParseDuration] function from the Go standard library. To disable the cache, use `none` |
| `missing_command_text` | `string` | | text to display when the command is missing |
| `display_mode` | `string` | `context` | <ul><li>`always`: the segment is always displayed</li><li>`files`: the segment is only displayed when file `extensions` listed are present</li><li>`context`: displays the segment when the environment or files is active</li></ul> |
| `version_url_template` | `string` | | a go [text/template][go-text-template] [template][templates] that creates the URL of the version info / release notes |
| `extensions` | `[]string` | `angular.json` | allows to override the default list of file extensions to validate |
| `folders` | `[]string` | | allows to override the list of folder names to validate |

## Template ([info][templates])

:::note default template

```template
{{ if .Error }}{{ .Error }}{{ else }}{{ .Full }}{{ end }}
```

:::

### Properties

| Name | Type | Description |
| -------- | -------- | -------------------------------------------------- |
| `.Full` | `string` | the full version |
| `.Major` | `string` | major number |
| `.Minor` | `string` | minor number |
| `.Patch` | `string` | patch number |
| `.URL` | `string` | URL of the version info / release notes |
| `.Error` | `string` | error encountered when fetching the version string |

[go-text-template]: https://golang.org/pkg/text/template/
[templates]: /docs/configuration/templates
[svelte-docs]: https://svelte.dev/docs/svelte/overview
[time.ParseDuration]: https://golang.org/pkg/time/#ParseDuration
63 changes: 63 additions & 0 deletions website/docs/segments/cli/tauri.mdx
Original file line number Diff line number Diff line change
@@ -0,0 +1,63 @@
---
id: tauri
title: Tauri
sidebar_label: Tauri
---

## What

Display the currently active Tauri version.

## Sample Configuration

import Config from "@site/src/components/Config.js";

<Config
data={{
type: "tauri",
style: "powerline",
powerline_symbol: "\uE0B0",
foreground: "#000000",
background: "#1976d2",
template: " \ue8bb {{ .Full }} ",
}}
/>

## Properties

| Name | Type | Default | Description |
| ---------------------- | :--------: | :------------: | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ |
| `home_enabled` | `boolean` | `false` | display the segment in the HOME folder or not |
| `fetch_version` | `boolean` | `true` | fetch the tauri version |
| `cache_duration` | `string` | `24h` | the duration for which the version will be cached. The duration is a string in the format `1h2m3s` and is parsed using the [time.ParseDuration] function from the Go standard library. To disable the cache, use `none` |
| `missing_command_text` | `string` | | text to display when the command is missing |
| `display_mode` | `string` | `context` | <ul><li>`always`: the segment is always displayed</li><li>`files`: the segment is only displayed when file `extensions` listed are present</li><li>`context`: displays the segment when the environment or files is active</li></ul> |
| `version_url_template` | `string` | | a go [text/template][go-text-template] [template][templates] that creates the URL of the version info / release notes |
| `extensions` | `[]string` | `angular.json` | allows to override the default list of file extensions to validate |
| `folders` | `[]string` | | allows to override the list of folder names to validate |

## Template ([info][templates])

:::note default template

```template
{{ if .Error }}{{ .Error }}{{ else }}{{ .Full }}{{ end }}
```

:::

### Properties

| Name | Type | Description |
| -------- | -------- | -------------------------------------------------- |
| `.Full` | `string` | the full version |
| `.Major` | `string` | major number |
| `.Minor` | `string` | minor number |
| `.Patch` | `string` | patch number |
| `.URL` | `string` | URL of the version info / release notes |
| `.Error` | `string` | error encountered when fetching the version string |

[go-text-template]: https://golang.org/pkg/text/template/
[templates]: /docs/configuration/templates
[tauri-docs]: https://v2.tauri.app/
[time.ParseDuration]: https://golang.org/pkg/time/#ParseDuration
2 changes: 2 additions & 0 deletions website/sidebars.js
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,9 @@ module.exports = {
"segments/cli/pnpm",
"segments/cli/quasar",
"segments/cli/react",
"segments/cli/svelte",
"segments/cli/talosctl",
"segments/cli/tauri",
"segments/cli/terraform",
"segments/cli/ui5tooling",
"segments/cli/umbraco",
Expand Down

0 comments on commit 77e5f33

Please sign in to comment.