From 464368fd926f52418b525e36c498622094f01cc1 Mon Sep 17 00:00:00 2001 From: Joe Mooring Date: Mon, 20 Mar 2023 05:43:40 -0700 Subject: [PATCH] Document .Page.Store (#2011) Closes #1668 --- content/en/functions/store.md | 105 ++++++++++++++++++++++++++++++++++ 1 file changed, 105 insertions(+) create mode 100644 content/en/functions/store.md diff --git a/content/en/functions/store.md b/content/en/functions/store.md new file mode 100644 index 000000000..4723a9d26 --- /dev/null +++ b/content/en/functions/store.md @@ -0,0 +1,105 @@ +--- +title: .Store +description: Returns a Scratch that is not reset on server rebuilds. +categories: [functions] +menu: + docs: + parent: "functions" +keywords: [scratch] +signature: [] +--- + +The `.Store` method on `.Page` returns a [Scratch] to store and manipulate data. In contrast to the `.Scratch` method, this Scratch is not reset on server rebuilds. + +[Scratch]: /functions/scratch/ + +### Methods + +#### .Set + +Sets the value of a given key. + +```go-html-template +{{ .Store.Set "greeting" "Hello" }} +``` + +#### .Get + +Gets the value of a given key. + +```go-html-template +{{ .Store.Set "greeting" "Hello" }} + +{{ .Store.Get "greeting" }} → Hello +``` + +#### .Add + +Adds a given value to existing value(s) of the given key. + +For single values, `Add` accepts values that support Go's `+` operator. If the first `Add` for a key is an array or slice, the following adds will be appended to that list. + +```go-html-template +{{ .Store.Add "greetings" "Hello" }} +{{ .Store.Add "greetings" "Welcome" }} + +{{ .Store.Get "greetings" }} → HelloWelcome +``` + +```go-html-template +{{ .Store.Add "total" 3 }} +{{ .Store.Add "total" 7 }} + +{{ .Store.Get "total" }} → 10 +``` + +```go-html-template +{{ .Store.Add "greetings" (slice "Hello") }} +{{ .Store.Add "greetings" (slice "Welcome" "Cheers") }} + +{{ .Store.Get "greetings" }} → []interface {}{"Hello", "Welcome", "Cheers"} +``` + +#### .SetInMap + +Takes a `key`, `mapKey` and `value` and adds a map of `mapKey` and `value` to the given `key`. + +```go-html-template +{{ .Store.SetInMap "greetings" "english" "Hello" }} +{{ .Store.SetInMap "greetings" "french" "Bonjour" }} + +{{ .Store.Get "greetings" }} → map[french:Bonjour english:Hello] +``` + +#### .DeleteInMap + +Takes a `key` and `mapKey` and removes the map of `mapKey` from the given `key`. + +```go-html-template +{{ .Store.SetInMap "greetings" "english" "Hello" }} +{{ .Store.SetInMap "greetings" "french" "Bonjour" }} +{{ .Store.DeleteInMap "greetings" "english" }} + +{{ .Store.Get "greetings" }} → map[french:Bonjour] +``` + +#### .GetSortedMapValues + +Returns an array of values from `key` sorted by `mapKey`. + +```go-html-template +{{ .Store.SetInMap "greetings" "english" "Hello" }} +{{ .Store.SetInMap "greetings" "french" "Bonjour" }} + +{{ .Store.GetSortedMapValues "greetings" }} → [Hello Bonjour] +``` + +#### .Delete + +Removes the given key. + +```go-html-template +{{ .Store.Set "greeting" "Hello" }} + +{{ .Store.Delete "greeting" }} +```