diff --git a/.nojekyll b/.nojekyll new file mode 100644 index 00000000..e69de29b diff --git a/404.html b/404.html new file mode 100644 index 00000000..3377c221 --- /dev/null +++ b/404.html @@ -0,0 +1,20 @@ + + + + + + 404 | js-lib + + + + + + + + + +
Skip to content

404

PAGE NOT FOUND

But if you don't change your direction, and if you keep looking, you may end up where you are heading.
+ + + + \ No newline at end of file diff --git a/array.html b/array.html new file mode 100644 index 00000000..13d545fa --- /dev/null +++ b/array.html @@ -0,0 +1,253 @@ + + + + + + Array | js-lib + + + + + + + + + + + + +
Skip to content

Array

_range

Quickly generate an incremental array of numbers.

  • Starts with 0, unless specified differently
  • Step is 1, unless specified differently
  • Lower bound is inclusive, higher-bound is exclusive.
ts
_range(3)
+// [0, 1, 2]
+
+_range(3, 6)
+// [3, 4, 5]
+
+_range(1, 10, 2)
+// [1, 3, 5, 7, 9]
_range(3)
+// [0, 1, 2]
+
+_range(3, 6)
+// [3, 4, 5]
+
+_range(1, 10, 2)
+// [1, 3, 5, 7, 9]

_chunk

Splits an input array into "chunks" of defined size. Last/remaining chunk may be of "incomplete" size. Returns array-of-arrays.

ts
const a = [1, 2, 3, 4, 5, 6]
+
+_chunk(a, 2)
+// [[1, 2], [3, 4], [5, 6]]
+
+_chunk(a, 3)
+// [[1, 2, 3], [4, 5, 6]]
+
+_chunk(a, 4)
+// [[1, 2, 3, 4], [5, 6]]]
const a = [1, 2, 3, 4, 5, 6]
+
+_chunk(a, 2)
+// [[1, 2], [3, 4], [5, 6]]
+
+_chunk(a, 3)
+// [[1, 2, 3], [4, 5, 6]]
+
+_chunk(a, 4)
+// [[1, 2, 3, 4], [5, 6]]]

_flatten

Polyfill to Array.flat() with depth=1. From https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flat

ts
_flatten([
+  [1, 2],
+  [3, 4],
+])
+// [1, 2, 3, 4]
_flatten([
+  [1, 2],
+  [3, 4],
+])
+// [1, 2, 3, 4]

_flattenDeep

Based on https://github.com/you-dont-need/You-Dont-Need-Lodash-Underscore#_flattendeep

Recursive Array.flat(), with infinite depth.

ts
_flattenDeep([
+  [
+    [1, 2],
+    [3, 4],
+  ],
+  [5, 6],
+  [7],
+])
+// [1, 2, 3, 4, 5, 6, 7]
_flattenDeep([
+  [
+    [1, 2],
+    [3, 4],
+  ],
+  [5, 6],
+  [7],
+])
+// [1, 2, 3, 4, 5, 6, 7]

_uniq

Convenience function to remove duplicates from an array of primitives.

ts
const a = [1, 2, 2, 3]
+_uniq(a)
+// [1, 2, 3]
const a = [1, 2, 2, 3]
+_uniq(a)
+// [1, 2, 3]

_uniqBy

Remove duplicates from array of objects, providing a comparator function.

ts
const a = [{ age: 18 }, { age: 20 }, { age: 18 }]
+_uniqBy(a, obj => obj.age)
+// [{ age: 18 }, { age: 20 }]
const a = [{ age: 18 }, { age: 20 }, { age: 18 }]
+_uniqBy(a, obj => obj.age)
+// [{ age: 18 }, { age: 20 }]

_by

ts
const a = [
+  { id: 'id1', a: 'a1' },
+  { id: 'id2', b: 'b1' },
+]
+
+_by(a, r => r.id)
+// {
+//  id1: {id: 'id1', a: 'a1'},
+//  id2: {id: 'id2', b: 'b1'},
+//}
const a = [
+  { id: 'id1', a: 'a1' },
+  { id: 'id2', b: 'b1' },
+]
+
+_by(a, r => r.id)
+// {
+//  id1: {id: 'id1', a: 'a1'},
+//  id2: {id: 'id2', b: 'b1'},
+//}

_groupBy

ts
const a = [1, 2, 3, 4, 5]
+
+_groupBy(a, r => (r % 2 ? 'even' : 'odd'))
+// {
+//  odd: [1, 3, 5],
+//  even: [2, 4],
+// }
const a = [1, 2, 3, 4, 5]
+
+_groupBy(a, r => (r % 2 ? 'even' : 'odd'))
+// {
+//  odd: [1, 3, 5],
+//  even: [2, 4],
+// }

Returning undefined from the Mapper will EXCLUDE the item.

_sortBy

Sort an array of object, providing a comparator function.

ts
const a = [{ age: 18 }, { age: 20 }, { age: 19 }]
+_sortBy(a, obj => obj.age)
+// [{ age: 18 }, {age: 19 }, { age: 20 }]
const a = [{ age: 18 }, { age: 20 }, { age: 19 }]
+_sortBy(a, obj => obj.age)
+// [{ age: 18 }, {age: 19 }, { age: 20 }]

_sortNumbers

Sort an array of numbers. Needs a special treatment because of a caveat, that a default comparator function compares things as Strings (even Numbers), so '21' > '100'.

ts
const a = [1, 3, 2]
+_sortNumbers(a)
+// [1, 2, 3]
const a = [1, 3, 2]
+_sortNumbers(a)
+// [1, 2, 3]

_findLast

Like .find(), but tries to find an element from the END of the array.

ts
const a = [1, 2, 3, 4, 5]
+_findLast(a, n => n % 2 === 0)
+// 4
const a = [1, 2, 3, 4, 5]
+_findLast(a, n => n % 2 === 0)
+// 4

_takeWhile, _takeRightWhile, _dropWhile, _dropRightWhile

ts
const a = [1, 2, 3, 4, 5, 2, 1]
+
+_takeWhile(a, r => r <= 3)
+// [1, 2, 3]
+
+_takeRightWhile(a, r => r <= 3)
+// [1, 2]
+// Note that the order is reversed when taking from Right!
+
+_dropWhile(a, r => r <= 3)
+// [4, 5, 2, 1]
+
+_dropRightWhile(a, r => r <= 3)
+// [5, 4, 3, 2, 1]
+// Note that the order is reversed when dropping from Right!
const a = [1, 2, 3, 4, 5, 2, 1]
+
+_takeWhile(a, r => r <= 3)
+// [1, 2, 3]
+
+_takeRightWhile(a, r => r <= 3)
+// [1, 2]
+// Note that the order is reversed when taking from Right!
+
+_dropWhile(a, r => r <= 3)
+// [4, 5, 2, 1]
+
+_dropRightWhile(a, r => r <= 3)
+// [5, 4, 3, 2, 1]
+// Note that the order is reversed when dropping from Right!

_countBy

ts
_countBy(['a', 'aa', 'aaa', 'aaa', 'aaaa'], r => r.length)
+// {
+//   1: 1,
+//   2: 1,
+//   3: 2,
+//   4: 1,
+// })
_countBy(['a', 'aa', 'aaa', 'aaa', 'aaaa'], r => r.length)
+// {
+//   1: 1,
+//   2: 1,
+//   3: 2,
+//   4: 1,
+// })

_intersection

Inspired by Lodash's _.intersection.

ts
_intersection([2, 1], [2, 3])
+// [2]
+
+_intersection([1], [2])
+// []
+
+_intersection()
+// []
+
+_intersection([1])
+// [1]
_intersection([2, 1], [2, 3])
+// [2]
+
+_intersection([1], [2])
+// []
+
+_intersection()
+// []
+
+_intersection([1])
+// [1]

_difference

Inspired by Lodash's _.difference

ts
_difference([2, 1], [2, 3])
+// [1]
+
+_difference([1], [2])
+// [1]
+
+_difference([1], [1])
+// []
+
+_difference([1])
+// [1]
_difference([2, 1], [2, 3])
+// [1]
+
+_difference([1], [2])
+// [1]
+
+_difference([1], [1])
+// []
+
+_difference([1])
+// [1]

_sum

Inspired by Lodash's _.sum

Same as Lodash, sum of empty array returns 0 (not NaN, not error)

ts
_sum([]) // 0
+_sum([1]) // 1
+_sum([1, 2]) // 3
_sum([]) // 0
+_sum([1]) // 1
+_sum([1, 2]) // 3

_sumBy

Inspired by Lodash's _.sumBy

ts
const items = [
+  { a: 1 },
+  { a: 2 },
+  { b: 3 }, // `a` is undefined (not a number) here, will be treated as 0
+]
+
+_sumBy(items, i => i.a) // 1 + 2 + 0 == 3
const items = [
+  { a: 1 },
+  { a: 2 },
+  { b: 3 }, // `a` is undefined (not a number) here, will be treated as 0
+]
+
+_sumBy(items, i => i.a) // 1 + 2 + 0 == 3

_mapToObject

Map an array of T to a StringMap<V>, by returning a tuple of [key, value] from a mapper function.

Return undefined/null/false/0/void to filter out (not include) a value.

Similar to reduce, but with subjectively cleaner syntax of returning "entries".

Similar to mapping to "entries" and passing to Object.fromEntries().

ts
_mapToObject([1, 2, 3], n => [n, n * 2])
+// { '1': 2, '2': 4, '3': 6 }
+
+_mapToObject([1, 2, 3], n => [n, `id${n}`])
+// { '1': 'id1, '2': 'id2', '3': 'id3' }
_mapToObject([1, 2, 3], n => [n, n * 2])
+// { '1': 2, '2': 4, '3': 6 }
+
+_mapToObject([1, 2, 3], n => [n, `id${n}`])
+// { '1': 'id1, '2': 'id2', '3': 'id3' }

_shuffle

Randomly shuffle an array values.

Uses Fisher–Yates algorithm.

Based on: https://stackoverflow.com/a/12646864/4919972

ts
const a = [1, 2, 3, 4, 5]
+const b = _shuffle(a)
+// [3, 1, 2, 5, 4]
+
+// Mutating example
+_shuffle(a)
+// a == [4, 2, 3, 1, 5]
const a = [1, 2, 3, 4, 5]
+const b = _shuffle(a)
+// [3, 1, 2, 5, 4]
+
+// Mutating example
+_shuffle(a)
+// a == [4, 2, 3, 1, 5]

_last

Returns last element of the array, or undefined if the array is empty.

Very simple semantic convenience method (lodash-inspired).

ts
const a = [1, 2, 3]
+_last(a) // 3
+
+const a = []
+_last(a) // undefined
const a = [1, 2, 3]
+_last(a) // 3
+
+const a = []
+_last(a) // undefined
+ + + + \ No newline at end of file diff --git a/assets/app.d916755b.js b/assets/app.d916755b.js new file mode 100644 index 00000000..41b65d39 --- /dev/null +++ b/assets/app.d916755b.js @@ -0,0 +1 @@ +import{s,a0 as i,a1 as u,a2 as c,a3 as l,a4 as d,a5 as f,a6 as m,a7 as h,a8 as A,a9 as g,aa as P,d as v,u as y,j as C,y as w,ab as _,ac as b,ad as E,ae as R}from"./chunks/framework.01940dea.js";import{t as D}from"./chunks/theme.1bf5c1be.js";function p(e){if(e.extends){const a=p(e.extends);return{...a,...e,async enhanceApp(t){a.enhanceApp&&await a.enhanceApp(t),e.enhanceApp&&await e.enhanceApp(t)}}}return e}const o=p(D),j=v({name:"VitePressApp",setup(){const{site:e}=y();return C(()=>{w(()=>{document.documentElement.lang=e.value.lang,document.documentElement.dir=e.value.dir})}),_(),b(),E(),o.setup&&o.setup(),()=>R(o.Layout)}});async function O(){const e=T(),a=S();a.provide(u,e);const t=c(e.route);return a.provide(l,t),a.component("Content",d),a.component("ClientOnly",f),Object.defineProperties(a.config.globalProperties,{$frontmatter:{get(){return t.frontmatter.value}},$params:{get(){return t.page.value.params}}}),o.enhanceApp&&await o.enhanceApp({app:a,router:e,siteData:m}),{app:a,router:e,data:t}}function S(){return h(j)}function T(){let e=s,a;return A(t=>{let n=g(t),r=null;return n&&(e&&(a=n),(e||a===n)&&(n=n.replace(/\.js$/,".lean.js")),r=P(()=>import(n),[])),s&&(e=!1),r},o.NotFound)}s&&O().then(({app:e,router:a,data:t})=>{a.go().then(()=>{i(a.route,t.site),e.mount("#app")})});export{O as createApp}; diff --git a/assets/array.md.1624f1c9.js b/assets/array.md.1624f1c9.js new file mode 100644 index 00000000..3ed1b89a --- /dev/null +++ b/assets/array.md.1624f1c9.js @@ -0,0 +1,231 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const h=JSON.parse('{"title":"Array","description":"","frontmatter":{},"headers":[],"relativePath":"array.md","filePath":"array.md"}'),p={name:"array.md"},o=l(`

Array

_range

Quickly generate an incremental array of numbers.

ts
_range(3)
+// [0, 1, 2]
+
+_range(3, 6)
+// [3, 4, 5]
+
+_range(1, 10, 2)
+// [1, 3, 5, 7, 9]
_range(3)
+// [0, 1, 2]
+
+_range(3, 6)
+// [3, 4, 5]
+
+_range(1, 10, 2)
+// [1, 3, 5, 7, 9]

_chunk

Splits an input array into "chunks" of defined size. Last/remaining chunk may be of "incomplete" size. Returns array-of-arrays.

ts
const a = [1, 2, 3, 4, 5, 6]
+
+_chunk(a, 2)
+// [[1, 2], [3, 4], [5, 6]]
+
+_chunk(a, 3)
+// [[1, 2, 3], [4, 5, 6]]
+
+_chunk(a, 4)
+// [[1, 2, 3, 4], [5, 6]]]
const a = [1, 2, 3, 4, 5, 6]
+
+_chunk(a, 2)
+// [[1, 2], [3, 4], [5, 6]]
+
+_chunk(a, 3)
+// [[1, 2, 3], [4, 5, 6]]
+
+_chunk(a, 4)
+// [[1, 2, 3, 4], [5, 6]]]

_flatten

Polyfill to Array.flat() with depth=1. From https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/flat

ts
_flatten([
+  [1, 2],
+  [3, 4],
+])
+// [1, 2, 3, 4]
_flatten([
+  [1, 2],
+  [3, 4],
+])
+// [1, 2, 3, 4]

_flattenDeep

Based on https://github.com/you-dont-need/You-Dont-Need-Lodash-Underscore#_flattendeep

Recursive Array.flat(), with infinite depth.

ts
_flattenDeep([
+  [
+    [1, 2],
+    [3, 4],
+  ],
+  [5, 6],
+  [7],
+])
+// [1, 2, 3, 4, 5, 6, 7]
_flattenDeep([
+  [
+    [1, 2],
+    [3, 4],
+  ],
+  [5, 6],
+  [7],
+])
+// [1, 2, 3, 4, 5, 6, 7]

_uniq

Convenience function to remove duplicates from an array of primitives.

ts
const a = [1, 2, 2, 3]
+_uniq(a)
+// [1, 2, 3]
const a = [1, 2, 2, 3]
+_uniq(a)
+// [1, 2, 3]

_uniqBy

Remove duplicates from array of objects, providing a comparator function.

ts
const a = [{ age: 18 }, { age: 20 }, { age: 18 }]
+_uniqBy(a, obj => obj.age)
+// [{ age: 18 }, { age: 20 }]
const a = [{ age: 18 }, { age: 20 }, { age: 18 }]
+_uniqBy(a, obj => obj.age)
+// [{ age: 18 }, { age: 20 }]

_by

ts
const a = [
+  { id: 'id1', a: 'a1' },
+  { id: 'id2', b: 'b1' },
+]
+
+_by(a, r => r.id)
+// {
+//  id1: {id: 'id1', a: 'a1'},
+//  id2: {id: 'id2', b: 'b1'},
+//}
const a = [
+  { id: 'id1', a: 'a1' },
+  { id: 'id2', b: 'b1' },
+]
+
+_by(a, r => r.id)
+// {
+//  id1: {id: 'id1', a: 'a1'},
+//  id2: {id: 'id2', b: 'b1'},
+//}

_groupBy

ts
const a = [1, 2, 3, 4, 5]
+
+_groupBy(a, r => (r % 2 ? 'even' : 'odd'))
+// {
+//  odd: [1, 3, 5],
+//  even: [2, 4],
+// }
const a = [1, 2, 3, 4, 5]
+
+_groupBy(a, r => (r % 2 ? 'even' : 'odd'))
+// {
+//  odd: [1, 3, 5],
+//  even: [2, 4],
+// }

Returning undefined from the Mapper will EXCLUDE the item.

_sortBy

Sort an array of object, providing a comparator function.

ts
const a = [{ age: 18 }, { age: 20 }, { age: 19 }]
+_sortBy(a, obj => obj.age)
+// [{ age: 18 }, {age: 19 }, { age: 20 }]
const a = [{ age: 18 }, { age: 20 }, { age: 19 }]
+_sortBy(a, obj => obj.age)
+// [{ age: 18 }, {age: 19 }, { age: 20 }]

_sortNumbers

Sort an array of numbers. Needs a special treatment because of a caveat, that a default comparator function compares things as Strings (even Numbers), so '21' > '100'.

ts
const a = [1, 3, 2]
+_sortNumbers(a)
+// [1, 2, 3]
const a = [1, 3, 2]
+_sortNumbers(a)
+// [1, 2, 3]

_findLast

Like .find(), but tries to find an element from the END of the array.

ts
const a = [1, 2, 3, 4, 5]
+_findLast(a, n => n % 2 === 0)
+// 4
const a = [1, 2, 3, 4, 5]
+_findLast(a, n => n % 2 === 0)
+// 4

_takeWhile, _takeRightWhile, _dropWhile, _dropRightWhile

ts
const a = [1, 2, 3, 4, 5, 2, 1]
+
+_takeWhile(a, r => r <= 3)
+// [1, 2, 3]
+
+_takeRightWhile(a, r => r <= 3)
+// [1, 2]
+// Note that the order is reversed when taking from Right!
+
+_dropWhile(a, r => r <= 3)
+// [4, 5, 2, 1]
+
+_dropRightWhile(a, r => r <= 3)
+// [5, 4, 3, 2, 1]
+// Note that the order is reversed when dropping from Right!
const a = [1, 2, 3, 4, 5, 2, 1]
+
+_takeWhile(a, r => r <= 3)
+// [1, 2, 3]
+
+_takeRightWhile(a, r => r <= 3)
+// [1, 2]
+// Note that the order is reversed when taking from Right!
+
+_dropWhile(a, r => r <= 3)
+// [4, 5, 2, 1]
+
+_dropRightWhile(a, r => r <= 3)
+// [5, 4, 3, 2, 1]
+// Note that the order is reversed when dropping from Right!

_countBy

ts
_countBy(['a', 'aa', 'aaa', 'aaa', 'aaaa'], r => r.length)
+// {
+//   1: 1,
+//   2: 1,
+//   3: 2,
+//   4: 1,
+// })
_countBy(['a', 'aa', 'aaa', 'aaa', 'aaaa'], r => r.length)
+// {
+//   1: 1,
+//   2: 1,
+//   3: 2,
+//   4: 1,
+// })

_intersection

Inspired by Lodash's _.intersection.

ts
_intersection([2, 1], [2, 3])
+// [2]
+
+_intersection([1], [2])
+// []
+
+_intersection()
+// []
+
+_intersection([1])
+// [1]
_intersection([2, 1], [2, 3])
+// [2]
+
+_intersection([1], [2])
+// []
+
+_intersection()
+// []
+
+_intersection([1])
+// [1]

_difference

Inspired by Lodash's _.difference

ts
_difference([2, 1], [2, 3])
+// [1]
+
+_difference([1], [2])
+// [1]
+
+_difference([1], [1])
+// []
+
+_difference([1])
+// [1]
_difference([2, 1], [2, 3])
+// [1]
+
+_difference([1], [2])
+// [1]
+
+_difference([1], [1])
+// []
+
+_difference([1])
+// [1]

_sum

Inspired by Lodash's _.sum

Same as Lodash, sum of empty array returns 0 (not NaN, not error)

ts
_sum([]) // 0
+_sum([1]) // 1
+_sum([1, 2]) // 3
_sum([]) // 0
+_sum([1]) // 1
+_sum([1, 2]) // 3

_sumBy

Inspired by Lodash's _.sumBy

ts
const items = [
+  { a: 1 },
+  { a: 2 },
+  { b: 3 }, // \`a\` is undefined (not a number) here, will be treated as 0
+]
+
+_sumBy(items, i => i.a) // 1 + 2 + 0 == 3
const items = [
+  { a: 1 },
+  { a: 2 },
+  { b: 3 }, // \`a\` is undefined (not a number) here, will be treated as 0
+]
+
+_sumBy(items, i => i.a) // 1 + 2 + 0 == 3

_mapToObject

Map an array of T to a StringMap<V>, by returning a tuple of [key, value] from a mapper function.

Return undefined/null/false/0/void to filter out (not include) a value.

Similar to reduce, but with subjectively cleaner syntax of returning "entries".

Similar to mapping to "entries" and passing to Object.fromEntries().

ts
_mapToObject([1, 2, 3], n => [n, n * 2])
+// { '1': 2, '2': 4, '3': 6 }
+
+_mapToObject([1, 2, 3], n => [n, \`id\${n}\`])
+// { '1': 'id1, '2': 'id2', '3': 'id3' }
_mapToObject([1, 2, 3], n => [n, n * 2])
+// { '1': 2, '2': 4, '3': 6 }
+
+_mapToObject([1, 2, 3], n => [n, \`id\${n}\`])
+// { '1': 'id1, '2': 'id2', '3': 'id3' }

_shuffle

Randomly shuffle an array values.

Uses Fisher–Yates algorithm.

Based on: https://stackoverflow.com/a/12646864/4919972

ts
const a = [1, 2, 3, 4, 5]
+const b = _shuffle(a)
+// [3, 1, 2, 5, 4]
+
+// Mutating example
+_shuffle(a)
+// a == [4, 2, 3, 1, 5]
const a = [1, 2, 3, 4, 5]
+const b = _shuffle(a)
+// [3, 1, 2, 5, 4]
+
+// Mutating example
+_shuffle(a)
+// a == [4, 2, 3, 1, 5]

_last

Returns last element of the array, or undefined if the array is empty.

Very simple semantic convenience method (lodash-inspired).

ts
const a = [1, 2, 3]
+_last(a) // 3
+
+const a = []
+_last(a) // undefined
const a = [1, 2, 3]
+_last(a) // 3
+
+const a = []
+_last(a) // undefined
`,67),e=[o];function t(c,r,y,E,i,d){return a(),n("div",null,e)}const C=s(p,[["render",t]]);export{h as __pageData,C as default}; diff --git a/assets/array.md.1624f1c9.lean.js b/assets/array.md.1624f1c9.lean.js new file mode 100644 index 00000000..911aacca --- /dev/null +++ b/assets/array.md.1624f1c9.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const h=JSON.parse('{"title":"Array","description":"","frontmatter":{},"headers":[],"relativePath":"array.md","filePath":"array.md"}'),p={name:"array.md"},o=l("",67),e=[o];function t(c,r,y,E,i,d){return a(),n("div",null,e)}const C=s(p,[["render",t]]);export{h as __pageData,C as default}; diff --git a/assets/chunks/framework.01940dea.js b/assets/chunks/framework.01940dea.js new file mode 100644 index 00000000..a4dd6a7d --- /dev/null +++ b/assets/chunks/framework.01940dea.js @@ -0,0 +1,2 @@ +function os(e,t){const n=Object.create(null),s=e.split(",");for(let r=0;r!!n[r.toLowerCase()]:r=>!!n[r]}const te={},pt=[],Oe=()=>{},Ji=()=>!1,Xi=/^on[^a-z]/,Ut=e=>Xi.test(e),ls=e=>e.startsWith("onUpdate:"),ie=Object.assign,cs=(e,t)=>{const n=e.indexOf(t);n>-1&&e.splice(n,1)},Qi=Object.prototype.hasOwnProperty,J=(e,t)=>Qi.call(e,t),j=Array.isArray,gt=e=>_n(e)==="[object Map]",Or=e=>_n(e)==="[object Set]",W=e=>typeof e=="function",ne=e=>typeof e=="string",yn=e=>typeof e=="symbol",ee=e=>e!==null&&typeof e=="object",Pr=e=>(ee(e)||W(e))&&W(e.then)&&W(e.catch),Ir=Object.prototype.toString,_n=e=>Ir.call(e),Zi=e=>_n(e).slice(8,-1),Fr=e=>_n(e)==="[object Object]",as=e=>ne(e)&&e!=="NaN"&&e[0]!=="-"&&""+parseInt(e,10)===e,It=os(",key,ref,ref_for,ref_key,onVnodeBeforeMount,onVnodeMounted,onVnodeBeforeUpdate,onVnodeUpdated,onVnodeBeforeUnmount,onVnodeUnmounted"),bn=e=>{const t=Object.create(null);return n=>t[n]||(t[n]=e(n))},Gi=/-(\w)/g,Le=bn(e=>e.replace(Gi,(t,n)=>n?n.toUpperCase():"")),eo=/\B([A-Z])/g,at=bn(e=>e.replace(eo,"-$1").toLowerCase()),vn=bn(e=>e.charAt(0).toUpperCase()+e.slice(1)),sn=bn(e=>e?`on${vn(e)}`:""),ct=(e,t)=>!Object.is(e,t),Hn=(e,t)=>{for(let n=0;n{Object.defineProperty(e,t,{configurable:!0,enumerable:!1,value:n})},to=e=>{const t=parseFloat(e);return isNaN(t)?e:t},no=e=>{const t=ne(e)?Number(e):NaN;return isNaN(t)?e:t};let Ns;const qn=()=>Ns||(Ns=typeof globalThis<"u"?globalThis:typeof self<"u"?self:typeof window<"u"?window:typeof global<"u"?global:{});function us(e){if(j(e)){const t={};for(let n=0;n{if(n){const s=n.split(ro);s.length>1&&(t[s[0].trim()]=s[1].trim())}}),t}function fs(e){let t="";if(ne(e))t=e;else if(j(e))for(let n=0;nne(e)?e:e==null?"":j(e)||ee(e)&&(e.toString===Ir||!W(e.toString))?JSON.stringify(e,Lr,2):String(e),Lr=(e,t)=>t&&t.__v_isRef?Lr(e,t.value):gt(t)?{[`Map(${t.size})`]:[...t.entries()].reduce((n,[s,r])=>(n[`${s} =>`]=r,n),{})}:Or(t)?{[`Set(${t.size})`]:[...t.values()]}:ee(t)&&!j(t)&&!Fr(t)?String(t):t;let be;class ao{constructor(t=!1){this.detached=t,this._active=!0,this.effects=[],this.cleanups=[],this.parent=be,!t&&be&&(this.index=(be.scopes||(be.scopes=[])).push(this)-1)}get active(){return this._active}run(t){if(this._active){const n=be;try{return be=this,t()}finally{be=n}}}on(){be=this}off(){be=this.parent}stop(t){if(this._active){let n,s;for(n=0,s=this.effects.length;n{const t=new Set(e);return t.w=0,t.n=0,t},Hr=e=>(e.w&Xe)>0,$r=e=>(e.n&Xe)>0,ho=({deps:e})=>{if(e.length)for(let t=0;t{const{deps:t}=e;if(t.length){let n=0;for(let s=0;s{(d==="length"||!yn(d)&&d>=c)&&l.push(u)})}else switch(n!==void 0&&l.push(o.get(n)),t){case"add":j(e)?as(n)&&l.push(o.get("length")):(l.push(o.get(it)),gt(e)&&l.push(o.get(Yn)));break;case"delete":j(e)||(l.push(o.get(it)),gt(e)&&l.push(o.get(Yn)));break;case"set":gt(e)&&l.push(o.get(it));break}if(l.length===1)l[0]&&Jn(l[0]);else{const c=[];for(const u of l)u&&c.push(...u);Jn(ds(c))}}function Jn(e,t){const n=j(e)?e:[...e];for(const s of n)s.computed&&$s(s);for(const s of n)s.computed||$s(s)}function $s(e,t){(e!==Se||e.allowRecurse)&&(e.scheduler?e.scheduler():e.run())}function go(e,t){var n;return(n=cn.get(e))==null?void 0:n.get(t)}const mo=os("__proto__,__v_isRef,__isVue"),Br=new Set(Object.getOwnPropertyNames(Symbol).filter(e=>e!=="arguments"&&e!=="caller").map(e=>Symbol[e]).filter(yn)),js=yo();function yo(){const e={};return["includes","indexOf","lastIndexOf"].forEach(t=>{e[t]=function(...n){const s=X(this);for(let i=0,o=this.length;i{e[t]=function(...n){Et();const s=X(this)[t].apply(this,n);return Tt(),s}}),e}function _o(e){const t=X(this);return ye(t,"has",e),t.hasOwnProperty(e)}class kr{constructor(t=!1,n=!1){this._isReadonly=t,this._shallow=n}get(t,n,s){const r=this._isReadonly,i=this._shallow;if(n==="__v_isReactive")return!r;if(n==="__v_isReadonly")return r;if(n==="__v_isShallow")return i;if(n==="__v_raw"&&s===(r?i?Io:Vr:i?Wr:Kr).get(t))return t;const o=j(t);if(!r){if(o&&J(js,n))return Reflect.get(js,n,s);if(n==="hasOwnProperty")return _o}const l=Reflect.get(t,n,s);return(yn(n)?Br.has(n):mo(n))||(r||ye(t,"get",n),i)?l:ce(l)?o&&as(n)?l:l.value:ee(l)?r?xn(l):Cn(l):l}}class Ur extends kr{constructor(t=!1){super(!1,t)}set(t,n,s,r){let i=t[n];if(vt(i)&&ce(i)&&!ce(s))return!1;if(!this._shallow&&(!an(s)&&!vt(s)&&(i=X(i),s=X(s)),!j(t)&&ce(i)&&!ce(s)))return i.value=s,!0;const o=j(t)&&as(n)?Number(n)e,wn=e=>Reflect.getPrototypeOf(e);function Vt(e,t,n=!1,s=!1){e=e.__v_raw;const r=X(e),i=X(t);n||(ct(t,i)&&ye(r,"get",t),ye(r,"get",i));const{has:o}=wn(r),l=s?ps:n?ys:Ht;if(o.call(r,t))return l(e.get(t));if(o.call(r,i))return l(e.get(i));e!==r&&e.get(t)}function qt(e,t=!1){const n=this.__v_raw,s=X(n),r=X(e);return t||(ct(e,r)&&ye(s,"has",e),ye(s,"has",r)),e===r?n.has(e):n.has(e)||n.has(r)}function zt(e,t=!1){return e=e.__v_raw,!t&&ye(X(e),"iterate",it),Reflect.get(e,"size",e)}function Ds(e){e=X(e);const t=X(this);return wn(t).has.call(t,e)||(t.add(e),je(t,"add",e,e)),this}function Bs(e,t){t=X(t);const n=X(this),{has:s,get:r}=wn(n);let i=s.call(n,e);i||(e=X(e),i=s.call(n,e));const o=r.call(n,e);return n.set(e,t),i?ct(t,o)&&je(n,"set",e,t):je(n,"add",e,t),this}function ks(e){const t=X(this),{has:n,get:s}=wn(t);let r=n.call(t,e);r||(e=X(e),r=n.call(t,e)),s&&s.call(t,e);const i=t.delete(e);return r&&je(t,"delete",e,void 0),i}function Us(){const e=X(this),t=e.size!==0,n=e.clear();return t&&je(e,"clear",void 0,void 0),n}function Yt(e,t){return function(s,r){const i=this,o=i.__v_raw,l=X(o),c=t?ps:e?ys:Ht;return!e&&ye(l,"iterate",it),o.forEach((u,d)=>s.call(r,c(u),c(d),i))}}function Jt(e,t,n){return function(...s){const r=this.__v_raw,i=X(r),o=gt(i),l=e==="entries"||e===Symbol.iterator&&o,c=e==="keys"&&o,u=r[e](...s),d=n?ps:t?ys:Ht;return!t&&ye(i,"iterate",c?Yn:it),{next(){const{value:h,done:b}=u.next();return b?{value:h,done:b}:{value:l?[d(h[0]),d(h[1])]:d(h),done:b}},[Symbol.iterator](){return this}}}}function Be(e){return function(...t){return e==="delete"?!1:this}}function xo(){const e={get(i){return Vt(this,i)},get size(){return zt(this)},has:qt,add:Ds,set:Bs,delete:ks,clear:Us,forEach:Yt(!1,!1)},t={get(i){return Vt(this,i,!1,!0)},get size(){return zt(this)},has:qt,add:Ds,set:Bs,delete:ks,clear:Us,forEach:Yt(!1,!0)},n={get(i){return Vt(this,i,!0)},get size(){return zt(this,!0)},has(i){return qt.call(this,i,!0)},add:Be("add"),set:Be("set"),delete:Be("delete"),clear:Be("clear"),forEach:Yt(!0,!1)},s={get(i){return Vt(this,i,!0,!0)},get size(){return zt(this,!0)},has(i){return qt.call(this,i,!0)},add:Be("add"),set:Be("set"),delete:Be("delete"),clear:Be("clear"),forEach:Yt(!0,!0)};return["keys","values","entries",Symbol.iterator].forEach(i=>{e[i]=Jt(i,!1,!1),n[i]=Jt(i,!0,!1),t[i]=Jt(i,!1,!0),s[i]=Jt(i,!0,!0)}),[e,n,t,s]}const[Eo,To,Ao,So]=xo();function gs(e,t){const n=t?e?So:Ao:e?To:Eo;return(s,r,i)=>r==="__v_isReactive"?!e:r==="__v_isReadonly"?e:r==="__v_raw"?s:Reflect.get(J(n,r)&&r in s?n:s,r,i)}const Ro={get:gs(!1,!1)},Oo={get:gs(!1,!0)},Po={get:gs(!0,!1)},Kr=new WeakMap,Wr=new WeakMap,Vr=new WeakMap,Io=new WeakMap;function Fo(e){switch(e){case"Object":case"Array":return 1;case"Map":case"Set":case"WeakMap":case"WeakSet":return 2;default:return 0}}function Mo(e){return e.__v_skip||!Object.isExtensible(e)?0:Fo(Zi(e))}function Cn(e){return vt(e)?e:ms(e,!1,vo,Ro,Kr)}function Lo(e){return ms(e,!1,Co,Oo,Wr)}function xn(e){return ms(e,!0,wo,Po,Vr)}function ms(e,t,n,s,r){if(!ee(e)||e.__v_raw&&!(t&&e.__v_isReactive))return e;const i=r.get(e);if(i)return i;const o=Mo(e);if(o===0)return e;const l=new Proxy(e,o===2?s:n);return r.set(e,l),l}function mt(e){return vt(e)?mt(e.__v_raw):!!(e&&e.__v_isReactive)}function vt(e){return!!(e&&e.__v_isReadonly)}function an(e){return!!(e&&e.__v_isShallow)}function qr(e){return mt(e)||vt(e)}function X(e){const t=e&&e.__v_raw;return t?X(t):e}function Ft(e){return ln(e,"__v_skip",!0),e}const Ht=e=>ee(e)?Cn(e):e,ys=e=>ee(e)?xn(e):e;function _s(e){qe&&Se&&(e=X(e),Dr(e.dep||(e.dep=ds())))}function bs(e,t){e=X(e);const n=e.dep;n&&Jn(n)}function ce(e){return!!(e&&e.__v_isRef===!0)}function me(e){return Yr(e,!1)}function zr(e){return Yr(e,!0)}function Yr(e,t){return ce(e)?e:new No(e,t)}class No{constructor(t,n){this.__v_isShallow=n,this.dep=void 0,this.__v_isRef=!0,this._rawValue=n?t:X(t),this._value=n?t:Ht(t)}get value(){return _s(this),this._value}set value(t){const n=this.__v_isShallow||an(t)||vt(t);t=n?t:X(t),ct(t,this._rawValue)&&(this._rawValue=t,this._value=n?t:Ht(t),bs(this))}}function vs(e){return ce(e)?e.value:e}const Ho={get:(e,t,n)=>vs(Reflect.get(e,t,n)),set:(e,t,n,s)=>{const r=e[t];return ce(r)&&!ce(n)?(r.value=n,!0):Reflect.set(e,t,n,s)}};function Jr(e){return mt(e)?e:new Proxy(e,Ho)}class $o{constructor(t){this.dep=void 0,this.__v_isRef=!0;const{get:n,set:s}=t(()=>_s(this),()=>bs(this));this._get=n,this._set=s}get value(){return this._get()}set value(t){this._set(t)}}function jo(e){return new $o(e)}class Do{constructor(t,n,s){this._object=t,this._key=n,this._defaultValue=s,this.__v_isRef=!0}get value(){const t=this._object[this._key];return t===void 0?this._defaultValue:t}set value(t){this._object[this._key]=t}get dep(){return go(X(this._object),this._key)}}class Bo{constructor(t){this._getter=t,this.__v_isRef=!0,this.__v_isReadonly=!0}get value(){return this._getter()}}function ko(e,t,n){return ce(e)?e:W(e)?new Bo(e):ee(e)&&arguments.length>1?Uo(e,t,n):me(e)}function Uo(e,t,n){const s=e[t];return ce(s)?s:new Do(e,t,n)}class Ko{constructor(t,n,s,r){this._setter=n,this.dep=void 0,this.__v_isRef=!0,this.__v_isReadonly=!1,this._dirty=!0,this.effect=new hs(t,()=>{this._dirty||(this._dirty=!0,bs(this))}),this.effect.computed=this,this.effect.active=this._cacheable=!r,this.__v_isReadonly=s}get value(){const t=X(this);return _s(t),(t._dirty||!t._cacheable)&&(t._dirty=!1,t._value=t.effect.run()),t._value}set value(t){this._setter(t)}}function Wo(e,t,n=!1){let s,r;const i=W(e);return i?(s=e,r=Oe):(s=e.get,r=e.set),new Ko(s,r,i||!r,n)}function ze(e,t,n,s){let r;try{r=s?e(...s):e()}catch(i){En(i,t,n)}return r}function Ee(e,t,n,s){if(W(e)){const i=ze(e,t,n,s);return i&&Pr(i)&&i.catch(o=>{En(o,t,n)}),i}const r=[];for(let i=0;i>>1,r=fe[s],i=jt(r);iMe&&fe.splice(t,1)}function Yo(e){j(e)?yt.push(...e):(!$e||!$e.includes(e,e.allowRecurse?nt+1:nt))&&yt.push(e),Qr()}function Ks(e,t=$t?Me+1:0){for(;tjt(n)-jt(s)),nt=0;nt<$e.length;nt++)$e[nt]();$e=null,nt=0}}const jt=e=>e.id==null?1/0:e.id,Jo=(e,t)=>{const n=jt(e)-jt(t);if(n===0){if(e.pre&&!t.pre)return-1;if(t.pre&&!e.pre)return 1}return n};function Zr(e){Xn=!1,$t=!0,fe.sort(Jo);const t=Oe;try{for(Me=0;Mene(T)?T.trim():T)),h&&(r=n.map(to))}let l,c=s[l=sn(t)]||s[l=sn(Le(t))];!c&&i&&(c=s[l=sn(at(t))]),c&&Ee(c,e,6,r);const u=s[l+"Once"];if(u){if(!e.emitted)e.emitted={};else if(e.emitted[l])return;e.emitted[l]=!0,Ee(u,e,6,r)}}function Gr(e,t,n=!1){const s=t.emitsCache,r=s.get(e);if(r!==void 0)return r;const i=e.emits;let o={},l=!1;if(!W(e)){const c=u=>{const d=Gr(u,t,!0);d&&(l=!0,ie(o,d))};!n&&t.mixins.length&&t.mixins.forEach(c),e.extends&&c(e.extends),e.mixins&&e.mixins.forEach(c)}return!i&&!l?(ee(e)&&s.set(e,null),null):(j(i)?i.forEach(c=>o[c]=null):ie(o,i),ee(e)&&s.set(e,o),o)}function An(e,t){return!e||!Ut(t)?!1:(t=t.slice(2).replace(/Once$/,""),J(e,t[0].toLowerCase()+t.slice(1))||J(e,at(t))||J(e,t))}let de=null,Sn=null;function fn(e){const t=de;return de=e,Sn=e&&e.type.__scopeId||null,t}function ba(e){Sn=e}function va(){Sn=null}function Qo(e,t=de,n){if(!t||e._n)return e;const s=(...r)=>{s._d&&tr(-1);const i=fn(t);let o;try{o=e(...r)}finally{fn(i),s._d&&tr(1)}return o};return s._n=!0,s._c=!0,s._d=!0,s}function $n(e){const{type:t,vnode:n,proxy:s,withProxy:r,props:i,propsOptions:[o],slots:l,attrs:c,emit:u,render:d,renderCache:h,data:b,setupState:T,ctx:I,inheritAttrs:O}=e;let D,U;const Y=fn(e);try{if(n.shapeFlag&4){const p=r||s;D=Ae(d.call(p,p,h,i,T,b,I)),U=c}else{const p=t;D=Ae(p.length>1?p(i,{attrs:c,slots:l,emit:u}):p(i,null)),U=t.props?c:Zo(c)}}catch(p){Nt.length=0,En(p,e,1),D=ue(ve)}let m=D;if(U&&O!==!1){const p=Object.keys(U),{shapeFlag:M}=m;p.length&&M&7&&(o&&p.some(ls)&&(U=Go(U,o)),m=Qe(m,U))}return n.dirs&&(m=Qe(m),m.dirs=m.dirs?m.dirs.concat(n.dirs):n.dirs),n.transition&&(m.transition=n.transition),D=m,fn(Y),D}const Zo=e=>{let t;for(const n in e)(n==="class"||n==="style"||Ut(n))&&((t||(t={}))[n]=e[n]);return t},Go=(e,t)=>{const n={};for(const s in e)(!ls(s)||!(s.slice(9)in t))&&(n[s]=e[s]);return n};function el(e,t,n){const{props:s,children:r,component:i}=e,{props:o,children:l,patchFlag:c}=t,u=i.emitsOptions;if(t.dirs||t.transition)return!0;if(n&&c>=0){if(c&1024)return!0;if(c&16)return s?Ws(s,o,u):!!o;if(c&8){const d=t.dynamicProps;for(let h=0;he.__isSuspense;function ei(e,t){t&&t.pendingBranch?j(e)?t.effects.push(...e):t.effects.push(e):Yo(e)}function ti(e,t){return Rn(e,null,t)}function wa(e,t){return Rn(e,null,{flush:"post"})}const Xt={};function Ye(e,t,n){return Rn(e,t,n)}function Rn(e,t,{immediate:n,deep:s,flush:r,onTrack:i,onTrigger:o}=te){var l;const c=Nr()===((l=le)==null?void 0:l.scope)?le:null;let u,d=!1,h=!1;if(ce(e)?(u=()=>e.value,d=an(e)):mt(e)?(u=()=>e,s=!0):j(e)?(h=!0,d=e.some(p=>mt(p)||an(p)),u=()=>e.map(p=>{if(ce(p))return p.value;if(mt(p))return ht(p);if(W(p))return ze(p,c,2)})):W(e)?t?u=()=>ze(e,c,2):u=()=>{if(!(c&&c.isUnmounted))return b&&b(),Ee(e,c,3,[T])}:u=Oe,t&&s){const p=u;u=()=>ht(p())}let b,T=p=>{b=Y.onStop=()=>{ze(p,c,4)}},I;if(Bt)if(T=Oe,t?n&&Ee(t,c,3,[u(),h?[]:void 0,T]):u(),r==="sync"){const p=Xl();I=p.__watcherHandles||(p.__watcherHandles=[])}else return Oe;let O=h?new Array(e.length).fill(Xt):Xt;const D=()=>{if(Y.active)if(t){const p=Y.run();(s||d||(h?p.some((M,K)=>ct(M,O[K])):ct(p,O)))&&(b&&b(),Ee(t,c,3,[p,O===Xt?void 0:h&&O[0]===Xt?[]:O,T]),O=p)}else Y.run()};D.allowRecurse=!!t;let U;r==="sync"?U=D:r==="post"?U=()=>pe(D,c&&c.suspense):(D.pre=!0,c&&(D.id=c.uid),U=()=>Cs(D));const Y=new hs(u,U);t?n?D():O=Y.run():r==="post"?pe(Y.run.bind(Y),c&&c.suspense):Y.run();const m=()=>{Y.stop(),c&&c.scope&&cs(c.scope.effects,Y)};return I&&I.push(m),m}function sl(e,t,n){const s=this.proxy,r=ne(e)?e.includes(".")?ni(s,e):()=>s[e]:e.bind(s,s);let i;W(t)?i=t:(i=t.handler,n=t);const o=le;Ct(this);const l=Rn(r,i.bind(s),n);return o?Ct(o):ot(),l}function ni(e,t){const n=t.split(".");return()=>{let s=e;for(let r=0;r{ht(n,t)});else if(Fr(e))for(const n in e)ht(e[n],t);return e}function Fe(e,t,n,s){const r=e.dirs,i=t&&t.dirs;for(let o=0;o{e.isMounted=!0}),ci(()=>{e.isUnmounting=!0}),e}const we=[Function,Array],si={mode:String,appear:Boolean,persisted:Boolean,onBeforeEnter:we,onEnter:we,onAfterEnter:we,onEnterCancelled:we,onBeforeLeave:we,onLeave:we,onAfterLeave:we,onLeaveCancelled:we,onBeforeAppear:we,onAppear:we,onAfterAppear:we,onAppearCancelled:we},il={name:"BaseTransition",props:si,setup(e,{slots:t}){const n=Mn(),s=rl();let r;return()=>{const i=t.default&&ii(t.default(),!0);if(!i||!i.length)return;let o=i[0];if(i.length>1){for(const O of i)if(O.type!==ve){o=O;break}}const l=X(e),{mode:c}=l;if(s.isLeaving)return jn(o);const u=Vs(o);if(!u)return jn(o);const d=Qn(u,l,s,n);Zn(u,d);const h=n.subTree,b=h&&Vs(h);let T=!1;const{getTransitionKey:I}=u.type;if(I){const O=I();r===void 0?r=O:O!==r&&(r=O,T=!0)}if(b&&b.type!==ve&&(!st(u,b)||T)){const O=Qn(b,l,s,n);if(Zn(b,O),c==="out-in")return s.isLeaving=!0,O.afterLeave=()=>{s.isLeaving=!1,n.update.active!==!1&&n.update()},jn(o);c==="in-out"&&u.type!==ve&&(O.delayLeave=(D,U,Y)=>{const m=ri(s,b);m[String(b.key)]=b,D[We]=()=>{U(),D[We]=void 0,delete d.delayedLeave},d.delayedLeave=Y})}return o}}},ol=il;function ri(e,t){const{leavingVNodes:n}=e;let s=n.get(t.type);return s||(s=Object.create(null),n.set(t.type,s)),s}function Qn(e,t,n,s){const{appear:r,mode:i,persisted:o=!1,onBeforeEnter:l,onEnter:c,onAfterEnter:u,onEnterCancelled:d,onBeforeLeave:h,onLeave:b,onAfterLeave:T,onLeaveCancelled:I,onBeforeAppear:O,onAppear:D,onAfterAppear:U,onAppearCancelled:Y}=t,m=String(e.key),p=ri(n,e),M=(w,P)=>{w&&Ee(w,s,9,P)},K=(w,P)=>{const A=P[1];M(w,P),j(w)?w.every(Q=>Q.length<=1)&&A():w.length<=1&&A()},B={mode:i,persisted:o,beforeEnter(w){let P=l;if(!n.isMounted)if(r)P=O||l;else return;w[We]&&w[We](!0);const A=p[m];A&&st(e,A)&&A.el[We]&&A.el[We](),M(P,[w])},enter(w){let P=c,A=u,Q=d;if(!n.isMounted)if(r)P=D||c,A=U||u,Q=Y||d;else return;let S=!1;const V=w[Qt]=re=>{S||(S=!0,re?M(Q,[w]):M(A,[w]),B.delayedLeave&&B.delayedLeave(),w[Qt]=void 0)};P?K(P,[w,V]):V()},leave(w,P){const A=String(e.key);if(w[Qt]&&w[Qt](!0),n.isUnmounting)return P();M(h,[w]);let Q=!1;const S=w[We]=V=>{Q||(Q=!0,P(),V?M(I,[w]):M(T,[w]),w[We]=void 0,p[A]===e&&delete p[A])};p[A]=e,b?K(b,[w,S]):S()},clone(w){return Qn(w,t,n,s)}};return B}function jn(e){if(On(e))return e=Qe(e),e.children=null,e}function Vs(e){return On(e)?e.children?e.children[0]:void 0:e}function Zn(e,t){e.shapeFlag&6&&e.component?Zn(e.component.subTree,t):e.shapeFlag&128?(e.ssContent.transition=t.clone(e.ssContent),e.ssFallback.transition=t.clone(e.ssFallback)):e.transition=t}function ii(e,t=!1,n){let s=[],r=0;for(let i=0;i1)for(let i=0;iie({name:e.name},t,{setup:e}))():e}const _t=e=>!!e.type.__asyncLoader,On=e=>e.type.__isKeepAlive;function ll(e,t){li(e,"a",t)}function cl(e,t){li(e,"da",t)}function li(e,t,n=le){const s=e.__wdc||(e.__wdc=()=>{let r=n;for(;r;){if(r.isDeactivated)return;r=r.parent}return e()});if(Pn(t,s,n),n){let r=n.parent;for(;r&&r.parent;)On(r.parent.vnode)&&al(s,t,n,r),r=r.parent}}function al(e,t,n,s){const r=Pn(t,e,s,!0);In(()=>{cs(s[t],r)},n)}function Pn(e,t,n=le,s=!1){if(n){const r=n[e]||(n[e]=[]),i=t.__weh||(t.__weh=(...o)=>{if(n.isUnmounted)return;Et(),Ct(n);const l=Ee(t,n,e,o);return ot(),Tt(),l});return s?r.unshift(i):r.push(i),i}}const De=e=>(t,n=le)=>(!Bt||e==="sp")&&Pn(e,(...s)=>t(...s),n),ul=De("bm"),At=De("m"),fl=De("bu"),dl=De("u"),ci=De("bum"),In=De("um"),hl=De("sp"),pl=De("rtg"),gl=De("rtc");function ml(e,t=le){Pn("ec",e,t)}const xs="components";function Ca(e,t){return ui(xs,e,!0,t)||e}const ai=Symbol.for("v-ndc");function xa(e){return ne(e)?ui(xs,e,!1)||e:e||ai}function ui(e,t,n=!0,s=!1){const r=de||le;if(r){const i=r.type;if(e===xs){const l=zl(i,!1);if(l&&(l===t||l===Le(t)||l===vn(Le(t))))return i}const o=qs(r[e]||i[e],t)||qs(r.appContext[e],t);return!o&&s?i:o}}function qs(e,t){return e&&(e[t]||e[Le(t)]||e[vn(Le(t))])}function Ea(e,t,n,s){let r;const i=n&&n[s];if(j(e)||ne(e)){r=new Array(e.length);for(let o=0,l=e.length;ot(o,l,void 0,i&&i[l]));else{const o=Object.keys(e);r=new Array(o.length);for(let l=0,c=o.length;lgn(t)?!(t.type===ve||t.type===ge&&!fi(t.children)):!0)?e:null}function Aa(e,t){const n={};for(const s in e)n[t&&/[A-Z]/.test(s)?`on:${s}`:sn(s)]=e[s];return n}const Gn=e=>e?Si(e)?Rs(e)||e.proxy:Gn(e.parent):null,Mt=ie(Object.create(null),{$:e=>e,$el:e=>e.vnode.el,$data:e=>e.data,$props:e=>e.props,$attrs:e=>e.attrs,$slots:e=>e.slots,$refs:e=>e.refs,$parent:e=>Gn(e.parent),$root:e=>Gn(e.root),$emit:e=>e.emit,$options:e=>Es(e),$forceUpdate:e=>e.f||(e.f=()=>Cs(e.update)),$nextTick:e=>e.n||(e.n=Tn.bind(e.proxy)),$watch:e=>sl.bind(e)}),Dn=(e,t)=>e!==te&&!e.__isScriptSetup&&J(e,t),yl={get({_:e},t){const{ctx:n,setupState:s,data:r,props:i,accessCache:o,type:l,appContext:c}=e;let u;if(t[0]!=="$"){const T=o[t];if(T!==void 0)switch(T){case 1:return s[t];case 2:return r[t];case 4:return n[t];case 3:return i[t]}else{if(Dn(s,t))return o[t]=1,s[t];if(r!==te&&J(r,t))return o[t]=2,r[t];if((u=e.propsOptions[0])&&J(u,t))return o[t]=3,i[t];if(n!==te&&J(n,t))return o[t]=4,n[t];es&&(o[t]=0)}}const d=Mt[t];let h,b;if(d)return t==="$attrs"&&ye(e,"get",t),d(e);if((h=l.__cssModules)&&(h=h[t]))return h;if(n!==te&&J(n,t))return o[t]=4,n[t];if(b=c.config.globalProperties,J(b,t))return b[t]},set({_:e},t,n){const{data:s,setupState:r,ctx:i}=e;return Dn(r,t)?(r[t]=n,!0):s!==te&&J(s,t)?(s[t]=n,!0):J(e.props,t)||t[0]==="$"&&t.slice(1)in e?!1:(i[t]=n,!0)},has({_:{data:e,setupState:t,accessCache:n,ctx:s,appContext:r,propsOptions:i}},o){let l;return!!n[o]||e!==te&&J(e,o)||Dn(t,o)||(l=i[0])&&J(l,o)||J(s,o)||J(Mt,o)||J(r.config.globalProperties,o)},defineProperty(e,t,n){return n.get!=null?e._.accessCache[t]=0:J(n,"value")&&this.set(e,t,n.value,null),Reflect.defineProperty(e,t,n)}};function Sa(){return _l().slots}function _l(){const e=Mn();return e.setupContext||(e.setupContext=Oi(e))}function zs(e){return j(e)?e.reduce((t,n)=>(t[n]=null,t),{}):e}let es=!0;function bl(e){const t=Es(e),n=e.proxy,s=e.ctx;es=!1,t.beforeCreate&&Ys(t.beforeCreate,e,"bc");const{data:r,computed:i,methods:o,watch:l,provide:c,inject:u,created:d,beforeMount:h,mounted:b,beforeUpdate:T,updated:I,activated:O,deactivated:D,beforeDestroy:U,beforeUnmount:Y,destroyed:m,unmounted:p,render:M,renderTracked:K,renderTriggered:B,errorCaptured:w,serverPrefetch:P,expose:A,inheritAttrs:Q,components:S,directives:V,filters:re}=t;if(u&&vl(u,s,null),o)for(const q in o){const $=o[q];W($)&&(s[q]=$.bind(n))}if(r){const q=r.call(n,n);ee(q)&&(e.data=Cn(q))}if(es=!0,i)for(const q in i){const $=i[q],Ne=W($)?$.bind(n,n):W($.get)?$.get.bind(n,n):Oe,Kt=!W($)&&W($.set)?$.set.bind(n):Oe,Ze=oe({get:Ne,set:Kt});Object.defineProperty(s,q,{enumerable:!0,configurable:!0,get:()=>Ze.value,set:Pe=>Ze.value=Pe})}if(l)for(const q in l)di(l[q],s,n,q);if(c){const q=W(c)?c.call(n):c;Reflect.ownKeys(q).forEach($=>{Al($,q[$])})}d&&Ys(d,e,"c");function L(q,$){j($)?$.forEach(Ne=>q(Ne.bind(n))):$&&q($.bind(n))}if(L(ul,h),L(At,b),L(fl,T),L(dl,I),L(ll,O),L(cl,D),L(ml,w),L(gl,K),L(pl,B),L(ci,Y),L(In,p),L(hl,P),j(A))if(A.length){const q=e.exposed||(e.exposed={});A.forEach($=>{Object.defineProperty(q,$,{get:()=>n[$],set:Ne=>n[$]=Ne})})}else e.exposed||(e.exposed={});M&&e.render===Oe&&(e.render=M),Q!=null&&(e.inheritAttrs=Q),S&&(e.components=S),V&&(e.directives=V)}function vl(e,t,n=Oe){j(e)&&(e=ts(e));for(const s in e){const r=e[s];let i;ee(r)?"default"in r?i=bt(r.from||s,r.default,!0):i=bt(r.from||s):i=bt(r),ce(i)?Object.defineProperty(t,s,{enumerable:!0,configurable:!0,get:()=>i.value,set:o=>i.value=o}):t[s]=i}}function Ys(e,t,n){Ee(j(e)?e.map(s=>s.bind(t.proxy)):e.bind(t.proxy),t,n)}function di(e,t,n,s){const r=s.includes(".")?ni(n,s):()=>n[s];if(ne(e)){const i=t[e];W(i)&&Ye(r,i)}else if(W(e))Ye(r,e.bind(n));else if(ee(e))if(j(e))e.forEach(i=>di(i,t,n,s));else{const i=W(e.handler)?e.handler.bind(n):t[e.handler];W(i)&&Ye(r,i,e)}}function Es(e){const t=e.type,{mixins:n,extends:s}=t,{mixins:r,optionsCache:i,config:{optionMergeStrategies:o}}=e.appContext,l=i.get(t);let c;return l?c=l:!r.length&&!n&&!s?c=t:(c={},r.length&&r.forEach(u=>dn(c,u,o,!0)),dn(c,t,o)),ee(t)&&i.set(t,c),c}function dn(e,t,n,s=!1){const{mixins:r,extends:i}=t;i&&dn(e,i,n,!0),r&&r.forEach(o=>dn(e,o,n,!0));for(const o in t)if(!(s&&o==="expose")){const l=wl[o]||n&&n[o];e[o]=l?l(e[o],t[o]):t[o]}return e}const wl={data:Js,props:Xs,emits:Xs,methods:Pt,computed:Pt,beforeCreate:he,created:he,beforeMount:he,mounted:he,beforeUpdate:he,updated:he,beforeDestroy:he,beforeUnmount:he,destroyed:he,unmounted:he,activated:he,deactivated:he,errorCaptured:he,serverPrefetch:he,components:Pt,directives:Pt,watch:xl,provide:Js,inject:Cl};function Js(e,t){return t?e?function(){return ie(W(e)?e.call(this,this):e,W(t)?t.call(this,this):t)}:t:e}function Cl(e,t){return Pt(ts(e),ts(t))}function ts(e){if(j(e)){const t={};for(let n=0;n1)return n&&W(t)?t.call(s&&s.proxy):t}}function Sl(e,t,n,s=!1){const r={},i={};ln(i,Fn,1),e.propsDefaults=Object.create(null),pi(e,t,r,i);for(const o in e.propsOptions[0])o in r||(r[o]=void 0);n?e.props=s?r:Lo(r):e.type.props?e.props=r:e.props=i,e.attrs=i}function Rl(e,t,n,s){const{props:r,attrs:i,vnode:{patchFlag:o}}=e,l=X(r),[c]=e.propsOptions;let u=!1;if((s||o>0)&&!(o&16)){if(o&8){const d=e.vnode.dynamicProps;for(let h=0;h{c=!0;const[b,T]=gi(h,t,!0);ie(o,b),T&&l.push(...T)};!n&&t.mixins.length&&t.mixins.forEach(d),e.extends&&d(e.extends),e.mixins&&e.mixins.forEach(d)}if(!i&&!c)return ee(e)&&s.set(e,pt),pt;if(j(i))for(let d=0;d-1,T[1]=O<0||I-1||J(T,"default"))&&l.push(h)}}}const u=[o,l];return ee(e)&&s.set(e,u),u}function Qs(e){return e[0]!=="$"}function Zs(e){const t=e&&e.toString().match(/^\s*(function|class) (\w+)/);return t?t[2]:e===null?"null":""}function Gs(e,t){return Zs(e)===Zs(t)}function er(e,t){return j(t)?t.findIndex(n=>Gs(n,e)):W(t)&&Gs(t,e)?0:-1}const mi=e=>e[0]==="_"||e==="$stable",Ts=e=>j(e)?e.map(Ae):[Ae(e)],Ol=(e,t,n)=>{if(t._n)return t;const s=Qo((...r)=>Ts(t(...r)),n);return s._c=!1,s},yi=(e,t,n)=>{const s=e._ctx;for(const r in e){if(mi(r))continue;const i=e[r];if(W(i))t[r]=Ol(r,i,s);else if(i!=null){const o=Ts(i);t[r]=()=>o}}},_i=(e,t)=>{const n=Ts(t);e.slots.default=()=>n},Pl=(e,t)=>{if(e.vnode.shapeFlag&32){const n=t._;n?(e.slots=X(t),ln(t,"_",n)):yi(t,e.slots={})}else e.slots={},t&&_i(e,t);ln(e.slots,Fn,1)},Il=(e,t,n)=>{const{vnode:s,slots:r}=e;let i=!0,o=te;if(s.shapeFlag&32){const l=t._;l?n&&l===1?i=!1:(ie(r,t),!n&&l===1&&delete r._):(i=!t.$stable,yi(t,r)),o=t}else t&&(_i(e,t),o={default:1});if(i)for(const l in r)!mi(l)&&o[l]==null&&delete r[l]};function pn(e,t,n,s,r=!1){if(j(e)){e.forEach((b,T)=>pn(b,t&&(j(t)?t[T]:t),n,s,r));return}if(_t(s)&&!r)return;const i=s.shapeFlag&4?Rs(s.component)||s.component.proxy:s.el,o=r?null:i,{i:l,r:c}=e,u=t&&t.r,d=l.refs===te?l.refs={}:l.refs,h=l.setupState;if(u!=null&&u!==c&&(ne(u)?(d[u]=null,J(h,u)&&(h[u]=null)):ce(u)&&(u.value=null)),W(c))ze(c,l,12,[o,d]);else{const b=ne(c),T=ce(c);if(b||T){const I=()=>{if(e.f){const O=b?J(h,c)?h[c]:d[c]:c.value;r?j(O)&&cs(O,i):j(O)?O.includes(i)||O.push(i):b?(d[c]=[i],J(h,c)&&(h[c]=d[c])):(c.value=[i],e.k&&(d[e.k]=c.value))}else b?(d[c]=o,J(h,c)&&(h[c]=o)):T&&(c.value=o,e.k&&(d[e.k]=o))};o?(I.id=-1,pe(I,n)):I()}}}let ke=!1;const Zt=e=>/svg/.test(e.namespaceURI)&&e.tagName!=="foreignObject",Gt=e=>e.nodeType===8;function Fl(e){const{mt:t,p:n,o:{patchProp:s,createText:r,nextSibling:i,parentNode:o,remove:l,insert:c,createComment:u}}=e,d=(m,p)=>{if(!p.hasChildNodes()){n(null,m,p),un(),p._vnode=m;return}ke=!1,h(p.firstChild,m,null,null,null),un(),p._vnode=m,ke&&console.error("Hydration completed but contains mismatches.")},h=(m,p,M,K,B,w=!1)=>{const P=Gt(m)&&m.data==="[",A=()=>O(m,p,M,K,B,P),{type:Q,ref:S,shapeFlag:V,patchFlag:re}=p;let ae=m.nodeType;p.el=m,re===-2&&(w=!1,p.dynamicChildren=null);let L=null;switch(Q){case wt:ae!==3?p.children===""?(c(p.el=r(""),o(m),m),L=m):L=A():(m.data!==p.children&&(ke=!0,m.data=p.children),L=i(m));break;case ve:if(ae!==8||P)if(m.tagName.toLowerCase()==="template"){const q=p.el.content.firstChild;U(q,m,M),p.el=m=q,L=i(m)}else L=A();else L=i(m);break;case Lt:if(P&&(m=i(m),ae=m.nodeType),ae===1||ae===3){L=m;const q=!p.children.length;for(let $=0;${w=w||!!p.dynamicChildren;const{type:P,props:A,patchFlag:Q,shapeFlag:S,dirs:V,transition:re}=p,ae=P==="input"&&V||P==="option";if(ae||Q!==-1){if(V&&Fe(p,null,M,"created"),A)if(ae||!w||Q&48)for(const $ in A)(ae&&$.endsWith("value")||Ut($)&&!It($))&&s(m,$,null,A[$],!1,void 0,M);else A.onClick&&s(m,"onClick",null,A.onClick,!1,void 0,M);let L;(L=A&&A.onVnodeBeforeMount)&&Ce(L,M,p);let q=!1;if(Y(m)){q=bi(K,re)&&M&&M.vnode.props&&M.vnode.props.appear;const $=m.content.firstChild;q&&re.beforeEnter($),U($,m,M),p.el=m=$}if(V&&Fe(p,null,M,"beforeMount"),((L=A&&A.onVnodeMounted)||V||q)&&ei(()=>{L&&Ce(L,M,p),q&&re.enter(m),V&&Fe(p,null,M,"mounted")},K),S&16&&!(A&&(A.innerHTML||A.textContent))){let $=T(m.firstChild,p,m,M,K,B,w);for(;$;){ke=!0;const Ne=$;$=$.nextSibling,l(Ne)}}else S&8&&m.textContent!==p.children&&(ke=!0,m.textContent=p.children)}return m.nextSibling},T=(m,p,M,K,B,w,P)=>{P=P||!!p.dynamicChildren;const A=p.children,Q=A.length;for(let S=0;S{const{slotScopeIds:P}=p;P&&(B=B?B.concat(P):P);const A=o(m),Q=T(i(m),p,A,M,K,B,w);return Q&&Gt(Q)&&Q.data==="]"?i(p.anchor=Q):(ke=!0,c(p.anchor=u("]"),A,Q),Q)},O=(m,p,M,K,B,w)=>{if(ke=!0,p.el=null,w){const Q=D(m);for(;;){const S=i(m);if(S&&S!==Q)l(S);else break}}const P=i(m),A=o(m);return l(m),n(null,p,A,P,M,K,Zt(A),B),P},D=(m,p="[",M="]")=>{let K=0;for(;m;)if(m=i(m),m&&Gt(m)&&(m.data===p&&K++,m.data===M)){if(K===0)return i(m);K--}return m},U=(m,p,M)=>{const K=p.parentNode;K&&K.replaceChild(m,p);let B=M;for(;B;)B.vnode.el===p&&(B.vnode.el=m,B.subTree.el=m),B=B.parent},Y=m=>m.nodeType===1&&m.tagName.toLowerCase()==="template";return[d,h]}const pe=ei;function Ml(e){return Ll(e,Fl)}function Ll(e,t){const n=qn();n.__VUE__=!0;const{insert:s,remove:r,patchProp:i,createElement:o,createText:l,createComment:c,setText:u,setElementText:d,parentNode:h,nextSibling:b,setScopeId:T=Oe,insertStaticContent:I}=e,O=(a,f,g,y=null,_=null,x=null,R=!1,C=null,E=!!f.dynamicChildren)=>{if(a===f)return;a&&!st(a,f)&&(y=Wt(a),Pe(a,_,x,!0),a=null),f.patchFlag===-2&&(E=!1,f.dynamicChildren=null);const{type:v,ref:N,shapeFlag:F}=f;switch(v){case wt:D(a,f,g,y);break;case ve:U(a,f,g,y);break;case Lt:a==null&&Y(f,g,y,R);break;case ge:S(a,f,g,y,_,x,R,C,E);break;default:F&1?M(a,f,g,y,_,x,R,C,E):F&6?V(a,f,g,y,_,x,R,C,E):(F&64||F&128)&&v.process(a,f,g,y,_,x,R,C,E,ut)}N!=null&&_&&pn(N,a&&a.ref,x,f||a,!f)},D=(a,f,g,y)=>{if(a==null)s(f.el=l(f.children),g,y);else{const _=f.el=a.el;f.children!==a.children&&u(_,f.children)}},U=(a,f,g,y)=>{a==null?s(f.el=c(f.children||""),g,y):f.el=a.el},Y=(a,f,g,y)=>{[a.el,a.anchor]=I(a.children,f,g,y,a.el,a.anchor)},m=({el:a,anchor:f},g,y)=>{let _;for(;a&&a!==f;)_=b(a),s(a,g,y),a=_;s(f,g,y)},p=({el:a,anchor:f})=>{let g;for(;a&&a!==f;)g=b(a),r(a),a=g;r(f)},M=(a,f,g,y,_,x,R,C,E)=>{R=R||f.type==="svg",a==null?K(f,g,y,_,x,R,C,E):P(a,f,_,x,R,C,E)},K=(a,f,g,y,_,x,R,C)=>{let E,v;const{type:N,props:F,shapeFlag:H,transition:k,dirs:z}=a;if(E=a.el=o(a.type,x,F&&F.is,F),H&8?d(E,a.children):H&16&&w(a.children,E,null,y,_,x&&N!=="foreignObject",R,C),z&&Fe(a,null,y,"created"),B(E,a,a.scopeId,R,y),F){for(const Z in F)Z!=="value"&&!It(Z)&&i(E,Z,null,F[Z],x,a.children,y,_,He);"value"in F&&i(E,"value",null,F.value),(v=F.onVnodeBeforeMount)&&Ce(v,y,a)}z&&Fe(a,null,y,"beforeMount");const G=bi(_,k);G&&k.beforeEnter(E),s(E,f,g),((v=F&&F.onVnodeMounted)||G||z)&&pe(()=>{v&&Ce(v,y,a),G&&k.enter(E),z&&Fe(a,null,y,"mounted")},_)},B=(a,f,g,y,_)=>{if(g&&T(a,g),y)for(let x=0;x{for(let v=E;v{const C=f.el=a.el;let{patchFlag:E,dynamicChildren:v,dirs:N}=f;E|=a.patchFlag&16;const F=a.props||te,H=f.props||te;let k;g&&Ge(g,!1),(k=H.onVnodeBeforeUpdate)&&Ce(k,g,f,a),N&&Fe(f,a,g,"beforeUpdate"),g&&Ge(g,!0);const z=_&&f.type!=="foreignObject";if(v?A(a.dynamicChildren,v,C,g,y,z,x):R||$(a,f,C,null,g,y,z,x,!1),E>0){if(E&16)Q(C,f,F,H,g,y,_);else if(E&2&&F.class!==H.class&&i(C,"class",null,H.class,_),E&4&&i(C,"style",F.style,H.style,_),E&8){const G=f.dynamicProps;for(let Z=0;Z{k&&Ce(k,g,f,a),N&&Fe(f,a,g,"updated")},y)},A=(a,f,g,y,_,x,R)=>{for(let C=0;C{if(g!==y){if(g!==te)for(const C in g)!It(C)&&!(C in y)&&i(a,C,g[C],null,R,f.children,_,x,He);for(const C in y){if(It(C))continue;const E=y[C],v=g[C];E!==v&&C!=="value"&&i(a,C,v,E,R,f.children,_,x,He)}"value"in y&&i(a,"value",g.value,y.value)}},S=(a,f,g,y,_,x,R,C,E)=>{const v=f.el=a?a.el:l(""),N=f.anchor=a?a.anchor:l("");let{patchFlag:F,dynamicChildren:H,slotScopeIds:k}=f;k&&(C=C?C.concat(k):k),a==null?(s(v,g,y),s(N,g,y),w(f.children,g,N,_,x,R,C,E)):F>0&&F&64&&H&&a.dynamicChildren?(A(a.dynamicChildren,H,g,_,x,R,C),(f.key!=null||_&&f===_.subTree)&&vi(a,f,!0)):$(a,f,g,N,_,x,R,C,E)},V=(a,f,g,y,_,x,R,C,E)=>{f.slotScopeIds=C,a==null?f.shapeFlag&512?_.ctx.activate(f,g,y,R,E):re(f,g,y,_,x,R,E):ae(a,f,E)},re=(a,f,g,y,_,x,R)=>{const C=a.component=Kl(a,y,_);if(On(a)&&(C.ctx.renderer=ut),Wl(C),C.asyncDep){if(_&&_.registerDep(C,L),!a.el){const E=C.subTree=ue(ve);U(null,E,f,g)}return}L(C,a,f,g,_,x,R)},ae=(a,f,g)=>{const y=f.component=a.component;if(el(a,f,g))if(y.asyncDep&&!y.asyncResolved){q(y,f,g);return}else y.next=f,zo(y.update),y.update();else f.el=a.el,y.vnode=f},L=(a,f,g,y,_,x,R)=>{const C=()=>{if(a.isMounted){let{next:N,bu:F,u:H,parent:k,vnode:z}=a,G=N,Z;Ge(a,!1),N?(N.el=z.el,q(a,N,R)):N=z,F&&Hn(F),(Z=N.props&&N.props.onVnodeBeforeUpdate)&&Ce(Z,k,N,z),Ge(a,!0);const se=$n(a),Te=a.subTree;a.subTree=se,O(Te,se,h(Te.el),Wt(Te),a,_,x),N.el=se.el,G===null&&tl(a,se.el),H&&pe(H,_),(Z=N.props&&N.props.onVnodeUpdated)&&pe(()=>Ce(Z,k,N,z),_)}else{let N;const{el:F,props:H}=f,{bm:k,m:z,parent:G}=a,Z=_t(f);if(Ge(a,!1),k&&Hn(k),!Z&&(N=H&&H.onVnodeBeforeMount)&&Ce(N,G,f),Ge(a,!0),F&&Nn){const se=()=>{a.subTree=$n(a),Nn(F,a.subTree,a,_,null)};Z?f.type.__asyncLoader().then(()=>!a.isUnmounted&&se()):se()}else{const se=a.subTree=$n(a);O(null,se,g,y,a,_,x),f.el=se.el}if(z&&pe(z,_),!Z&&(N=H&&H.onVnodeMounted)){const se=f;pe(()=>Ce(N,G,se),_)}(f.shapeFlag&256||G&&_t(G.vnode)&&G.vnode.shapeFlag&256)&&a.a&&pe(a.a,_),a.isMounted=!0,f=g=y=null}},E=a.effect=new hs(C,()=>Cs(v),a.scope),v=a.update=()=>E.run();v.id=a.uid,Ge(a,!0),v()},q=(a,f,g)=>{f.component=a;const y=a.vnode.props;a.vnode=f,a.next=null,Rl(a,f.props,y,g),Il(a,f.children,g),Et(),Ks(),Tt()},$=(a,f,g,y,_,x,R,C,E=!1)=>{const v=a&&a.children,N=a?a.shapeFlag:0,F=f.children,{patchFlag:H,shapeFlag:k}=f;if(H>0){if(H&128){Kt(v,F,g,y,_,x,R,C,E);return}else if(H&256){Ne(v,F,g,y,_,x,R,C,E);return}}k&8?(N&16&&He(v,_,x),F!==v&&d(g,F)):N&16?k&16?Kt(v,F,g,y,_,x,R,C,E):He(v,_,x,!0):(N&8&&d(g,""),k&16&&w(F,g,y,_,x,R,C,E))},Ne=(a,f,g,y,_,x,R,C,E)=>{a=a||pt,f=f||pt;const v=a.length,N=f.length,F=Math.min(v,N);let H;for(H=0;HN?He(a,_,x,!0,!1,F):w(f,g,y,_,x,R,C,E,F)},Kt=(a,f,g,y,_,x,R,C,E)=>{let v=0;const N=f.length;let F=a.length-1,H=N-1;for(;v<=F&&v<=H;){const k=a[v],z=f[v]=E?Ve(f[v]):Ae(f[v]);if(st(k,z))O(k,z,g,null,_,x,R,C,E);else break;v++}for(;v<=F&&v<=H;){const k=a[F],z=f[H]=E?Ve(f[H]):Ae(f[H]);if(st(k,z))O(k,z,g,null,_,x,R,C,E);else break;F--,H--}if(v>F){if(v<=H){const k=H+1,z=kH)for(;v<=F;)Pe(a[v],_,x,!0),v++;else{const k=v,z=v,G=new Map;for(v=z;v<=H;v++){const _e=f[v]=E?Ve(f[v]):Ae(f[v]);_e.key!=null&&G.set(_e.key,v)}let Z,se=0;const Te=H-z+1;let ft=!1,Fs=0;const St=new Array(Te);for(v=0;v=Te){Pe(_e,_,x,!0);continue}let Ie;if(_e.key!=null)Ie=G.get(_e.key);else for(Z=z;Z<=H;Z++)if(St[Z-z]===0&&st(_e,f[Z])){Ie=Z;break}Ie===void 0?Pe(_e,_,x,!0):(St[Ie-z]=v+1,Ie>=Fs?Fs=Ie:ft=!0,O(_e,f[Ie],g,null,_,x,R,C,E),se++)}const Ms=ft?Nl(St):pt;for(Z=Ms.length-1,v=Te-1;v>=0;v--){const _e=z+v,Ie=f[_e],Ls=_e+1{const{el:x,type:R,transition:C,children:E,shapeFlag:v}=a;if(v&6){Ze(a.component.subTree,f,g,y);return}if(v&128){a.suspense.move(f,g,y);return}if(v&64){R.move(a,f,g,ut);return}if(R===ge){s(x,f,g);for(let F=0;FC.enter(x),_);else{const{leave:F,delayLeave:H,afterLeave:k}=C,z=()=>s(x,f,g),G=()=>{F(x,()=>{z(),k&&k()})};H?H(x,z,G):G()}else s(x,f,g)},Pe=(a,f,g,y=!1,_=!1)=>{const{type:x,props:R,ref:C,children:E,dynamicChildren:v,shapeFlag:N,patchFlag:F,dirs:H}=a;if(C!=null&&pn(C,null,g,a,!0),N&256){f.ctx.deactivate(a);return}const k=N&1&&H,z=!_t(a);let G;if(z&&(G=R&&R.onVnodeBeforeUnmount)&&Ce(G,f,a),N&6)Yi(a.component,g,y);else{if(N&128){a.suspense.unmount(g,y);return}k&&Fe(a,null,f,"beforeUnmount"),N&64?a.type.remove(a,f,g,_,ut,y):v&&(x!==ge||F>0&&F&64)?He(v,f,g,!1,!0):(x===ge&&F&384||!_&&N&16)&&He(E,f,g),y&&Ps(a)}(z&&(G=R&&R.onVnodeUnmounted)||k)&&pe(()=>{G&&Ce(G,f,a),k&&Fe(a,null,f,"unmounted")},g)},Ps=a=>{const{type:f,el:g,anchor:y,transition:_}=a;if(f===ge){zi(g,y);return}if(f===Lt){p(a);return}const x=()=>{r(g),_&&!_.persisted&&_.afterLeave&&_.afterLeave()};if(a.shapeFlag&1&&_&&!_.persisted){const{leave:R,delayLeave:C}=_,E=()=>R(g,x);C?C(a.el,x,E):E()}else x()},zi=(a,f)=>{let g;for(;a!==f;)g=b(a),r(a),a=g;r(f)},Yi=(a,f,g)=>{const{bum:y,scope:_,update:x,subTree:R,um:C}=a;y&&Hn(y),_.stop(),x&&(x.active=!1,Pe(R,a,f,g)),C&&pe(C,f),pe(()=>{a.isUnmounted=!0},f),f&&f.pendingBranch&&!f.isUnmounted&&a.asyncDep&&!a.asyncResolved&&a.suspenseId===f.pendingId&&(f.deps--,f.deps===0&&f.resolve())},He=(a,f,g,y=!1,_=!1,x=0)=>{for(let R=x;Ra.shapeFlag&6?Wt(a.component.subTree):a.shapeFlag&128?a.suspense.next():b(a.anchor||a.el),Is=(a,f,g)=>{a==null?f._vnode&&Pe(f._vnode,null,null,!0):O(f._vnode||null,a,f,null,null,null,g),Ks(),un(),f._vnode=a},ut={p:O,um:Pe,m:Ze,r:Ps,mt:re,mc:w,pc:$,pbc:A,n:Wt,o:e};let Ln,Nn;return t&&([Ln,Nn]=t(ut)),{render:Is,hydrate:Ln,createApp:Tl(Is,Ln)}}function Ge({effect:e,update:t},n){e.allowRecurse=t.allowRecurse=n}function bi(e,t){return(!e||e&&!e.pendingBranch)&&t&&!t.persisted}function vi(e,t,n=!1){const s=e.children,r=t.children;if(j(s)&&j(r))for(let i=0;i>1,e[n[l]]0&&(t[s]=n[i-1]),n[i]=s)}}for(i=n.length,o=n[i-1];i-- >0;)n[i]=o,o=t[o];return n}const Hl=e=>e.__isTeleport,ge=Symbol.for("v-fgt"),wt=Symbol.for("v-txt"),ve=Symbol.for("v-cmt"),Lt=Symbol.for("v-stc"),Nt=[];let Re=null;function wi(e=!1){Nt.push(Re=e?null:[])}function $l(){Nt.pop(),Re=Nt[Nt.length-1]||null}let Dt=1;function tr(e){Dt+=e}function Ci(e){return e.dynamicChildren=Dt>0?Re||pt:null,$l(),Dt>0&&Re&&Re.push(e),e}function Ra(e,t,n,s,r,i){return Ci(Ti(e,t,n,s,r,i,!0))}function xi(e,t,n,s,r){return Ci(ue(e,t,n,s,r,!0))}function gn(e){return e?e.__v_isVNode===!0:!1}function st(e,t){return e.type===t.type&&e.key===t.key}const Fn="__vInternal",Ei=({key:e})=>e??null,rn=({ref:e,ref_key:t,ref_for:n})=>(typeof e=="number"&&(e=""+e),e!=null?ne(e)||ce(e)||W(e)?{i:de,r:e,k:t,f:!!n}:e:null);function Ti(e,t=null,n=null,s=0,r=null,i=e===ge?0:1,o=!1,l=!1){const c={__v_isVNode:!0,__v_skip:!0,type:e,props:t,key:t&&Ei(t),ref:t&&rn(t),scopeId:Sn,slotScopeIds:null,children:n,component:null,suspense:null,ssContent:null,ssFallback:null,dirs:null,transition:null,el:null,anchor:null,target:null,targetAnchor:null,staticCount:0,shapeFlag:i,patchFlag:s,dynamicProps:r,dynamicChildren:null,appContext:null,ctx:de};return l?(As(c,n),i&128&&e.normalize(c)):n&&(c.shapeFlag|=ne(n)?8:16),Dt>0&&!o&&Re&&(c.patchFlag>0||i&6)&&c.patchFlag!==32&&Re.push(c),c}const ue=jl;function jl(e,t=null,n=null,s=0,r=null,i=!1){if((!e||e===ai)&&(e=ve),gn(e)){const l=Qe(e,t,!0);return n&&As(l,n),Dt>0&&!i&&Re&&(l.shapeFlag&6?Re[Re.indexOf(e)]=l:Re.push(l)),l.patchFlag|=-2,l}if(Yl(e)&&(e=e.__vccOpts),t){t=Dl(t);let{class:l,style:c}=t;l&&!ne(l)&&(t.class=fs(l)),ee(c)&&(qr(c)&&!j(c)&&(c=ie({},c)),t.style=us(c))}const o=ne(e)?1:nl(e)?128:Hl(e)?64:ee(e)?4:W(e)?2:0;return Ti(e,t,n,s,r,o,i,!0)}function Dl(e){return e?qr(e)||Fn in e?ie({},e):e:null}function Qe(e,t,n=!1){const{props:s,ref:r,patchFlag:i,children:o}=e,l=t?Bl(s||{},t):s;return{__v_isVNode:!0,__v_skip:!0,type:e.type,props:l,key:l&&Ei(l),ref:t&&t.ref?n&&r?j(r)?r.concat(rn(t)):[r,rn(t)]:rn(t):r,scopeId:e.scopeId,slotScopeIds:e.slotScopeIds,children:o,target:e.target,targetAnchor:e.targetAnchor,staticCount:e.staticCount,shapeFlag:e.shapeFlag,patchFlag:t&&e.type!==ge?i===-1?16:i|16:i,dynamicProps:e.dynamicProps,dynamicChildren:e.dynamicChildren,appContext:e.appContext,dirs:e.dirs,transition:e.transition,component:e.component,suspense:e.suspense,ssContent:e.ssContent&&Qe(e.ssContent),ssFallback:e.ssFallback&&Qe(e.ssFallback),el:e.el,anchor:e.anchor,ctx:e.ctx,ce:e.ce}}function Ai(e=" ",t=0){return ue(wt,null,e,t)}function Oa(e,t){const n=ue(Lt,null,e);return n.staticCount=t,n}function Pa(e="",t=!1){return t?(wi(),xi(ve,null,e)):ue(ve,null,e)}function Ae(e){return e==null||typeof e=="boolean"?ue(ve):j(e)?ue(ge,null,e.slice()):typeof e=="object"?Ve(e):ue(wt,null,String(e))}function Ve(e){return e.el===null&&e.patchFlag!==-1||e.memo?e:Qe(e)}function As(e,t){let n=0;const{shapeFlag:s}=e;if(t==null)t=null;else if(j(t))n=16;else if(typeof t=="object")if(s&65){const r=t.default;r&&(r._c&&(r._d=!1),As(e,r()),r._c&&(r._d=!0));return}else{n=32;const r=t._;!r&&!(Fn in t)?t._ctx=de:r===3&&de&&(de.slots._===1?t._=1:(t._=2,e.patchFlag|=1024))}else W(t)?(t={default:t,_ctx:de},n=32):(t=String(t),s&64?(n=16,t=[Ai(t)]):n=8);e.children=t,e.shapeFlag|=n}function Bl(...e){const t={};for(let n=0;nle||de;let Ss,dt,nr="__VUE_INSTANCE_SETTERS__";(dt=qn()[nr])||(dt=qn()[nr]=[]),dt.push(e=>le=e),Ss=e=>{dt.length>1?dt.forEach(t=>t(e)):dt[0](e)};const Ct=e=>{Ss(e),e.scope.on()},ot=()=>{le&&le.scope.off(),Ss(null)};function Si(e){return e.vnode.shapeFlag&4}let Bt=!1;function Wl(e,t=!1){Bt=t;const{props:n,children:s}=e.vnode,r=Si(e);Sl(e,n,r,t),Pl(e,s);const i=r?Vl(e,t):void 0;return Bt=!1,i}function Vl(e,t){const n=e.type;e.accessCache=Object.create(null),e.proxy=Ft(new Proxy(e.ctx,yl));const{setup:s}=n;if(s){const r=e.setupContext=s.length>1?Oi(e):null;Ct(e),Et();const i=ze(s,e,0,[e.props,r]);if(Tt(),ot(),Pr(i)){if(i.then(ot,ot),t)return i.then(o=>{sr(e,o,t)}).catch(o=>{En(o,e,0)});e.asyncDep=i}else sr(e,i,t)}else Ri(e,t)}function sr(e,t,n){W(t)?e.type.__ssrInlineRender?e.ssrRender=t:e.render=t:ee(t)&&(e.setupState=Jr(t)),Ri(e,n)}let rr;function Ri(e,t,n){const s=e.type;if(!e.render){if(!t&&rr&&!s.render){const r=s.template||Es(e).template;if(r){const{isCustomElement:i,compilerOptions:o}=e.appContext.config,{delimiters:l,compilerOptions:c}=s,u=ie(ie({isCustomElement:i,delimiters:l},o),c);s.render=rr(r,u)}}e.render=s.render||Oe}{Ct(e),Et();try{bl(e)}finally{Tt(),ot()}}}function ql(e){return e.attrsProxy||(e.attrsProxy=new Proxy(e.attrs,{get(t,n){return ye(e,"get","$attrs"),t[n]}}))}function Oi(e){const t=n=>{e.exposed=n||{}};return{get attrs(){return ql(e)},slots:e.slots,emit:e.emit,expose:t}}function Rs(e){if(e.exposed)return e.exposeProxy||(e.exposeProxy=new Proxy(Jr(Ft(e.exposed)),{get(t,n){if(n in t)return t[n];if(n in Mt)return Mt[n](e)},has(t,n){return n in t||n in Mt}}))}function zl(e,t=!0){return W(e)?e.displayName||e.name:e.name||t&&e.__name}function Yl(e){return W(e)&&"__vccOpts"in e}const oe=(e,t)=>Wo(e,t,Bt);function ss(e,t,n){const s=arguments.length;return s===2?ee(t)&&!j(t)?gn(t)?ue(e,null,[t]):ue(e,t):ue(e,null,t):(s>3?n=Array.prototype.slice.call(arguments,2):s===3&&gn(n)&&(n=[n]),ue(e,t,n))}const Jl=Symbol.for("v-scx"),Xl=()=>bt(Jl),Ql="3.3.7",Zl="http://www.w3.org/2000/svg",rt=typeof document<"u"?document:null,ir=rt&&rt.createElement("template"),Gl={insert:(e,t,n)=>{t.insertBefore(e,n||null)},remove:e=>{const t=e.parentNode;t&&t.removeChild(e)},createElement:(e,t,n,s)=>{const r=t?rt.createElementNS(Zl,e):rt.createElement(e,n?{is:n}:void 0);return e==="select"&&s&&s.multiple!=null&&r.setAttribute("multiple",s.multiple),r},createText:e=>rt.createTextNode(e),createComment:e=>rt.createComment(e),setText:(e,t)=>{e.nodeValue=t},setElementText:(e,t)=>{e.textContent=t},parentNode:e=>e.parentNode,nextSibling:e=>e.nextSibling,querySelector:e=>rt.querySelector(e),setScopeId(e,t){e.setAttribute(t,"")},insertStaticContent(e,t,n,s,r,i){const o=n?n.previousSibling:t.lastChild;if(r&&(r===i||r.nextSibling))for(;t.insertBefore(r.cloneNode(!0),n),!(r===i||!(r=r.nextSibling)););else{ir.innerHTML=s?`${e}`:e;const l=ir.content;if(s){const c=l.firstChild;for(;c.firstChild;)l.appendChild(c.firstChild);l.removeChild(c)}t.insertBefore(l,n)}return[o?o.nextSibling:t.firstChild,n?n.previousSibling:t.lastChild]}},Ue="transition",Rt="animation",kt=Symbol("_vtc"),Pi=(e,{slots:t})=>ss(ol,ec(e),t);Pi.displayName="Transition";const Ii={name:String,type:String,css:{type:Boolean,default:!0},duration:[String,Number,Object],enterFromClass:String,enterActiveClass:String,enterToClass:String,appearFromClass:String,appearActiveClass:String,appearToClass:String,leaveFromClass:String,leaveActiveClass:String,leaveToClass:String};Pi.props=ie({},si,Ii);const et=(e,t=[])=>{j(e)?e.forEach(n=>n(...t)):e&&e(...t)},or=e=>e?j(e)?e.some(t=>t.length>1):e.length>1:!1;function ec(e){const t={};for(const S in e)S in Ii||(t[S]=e[S]);if(e.css===!1)return t;const{name:n="v",type:s,duration:r,enterFromClass:i=`${n}-enter-from`,enterActiveClass:o=`${n}-enter-active`,enterToClass:l=`${n}-enter-to`,appearFromClass:c=i,appearActiveClass:u=o,appearToClass:d=l,leaveFromClass:h=`${n}-leave-from`,leaveActiveClass:b=`${n}-leave-active`,leaveToClass:T=`${n}-leave-to`}=e,I=tc(r),O=I&&I[0],D=I&&I[1],{onBeforeEnter:U,onEnter:Y,onEnterCancelled:m,onLeave:p,onLeaveCancelled:M,onBeforeAppear:K=U,onAppear:B=Y,onAppearCancelled:w=m}=t,P=(S,V,re)=>{tt(S,V?d:l),tt(S,V?u:o),re&&re()},A=(S,V)=>{S._isLeaving=!1,tt(S,h),tt(S,T),tt(S,b),V&&V()},Q=S=>(V,re)=>{const ae=S?B:Y,L=()=>P(V,S,re);et(ae,[V,L]),lr(()=>{tt(V,S?c:i),Ke(V,S?d:l),or(ae)||cr(V,s,O,L)})};return ie(t,{onBeforeEnter(S){et(U,[S]),Ke(S,i),Ke(S,o)},onBeforeAppear(S){et(K,[S]),Ke(S,c),Ke(S,u)},onEnter:Q(!1),onAppear:Q(!0),onLeave(S,V){S._isLeaving=!0;const re=()=>A(S,V);Ke(S,h),rc(),Ke(S,b),lr(()=>{S._isLeaving&&(tt(S,h),Ke(S,T),or(p)||cr(S,s,D,re))}),et(p,[S,re])},onEnterCancelled(S){P(S,!1),et(m,[S])},onAppearCancelled(S){P(S,!0),et(w,[S])},onLeaveCancelled(S){A(S),et(M,[S])}})}function tc(e){if(e==null)return null;if(ee(e))return[Bn(e.enter),Bn(e.leave)];{const t=Bn(e);return[t,t]}}function Bn(e){return no(e)}function Ke(e,t){t.split(/\s+/).forEach(n=>n&&e.classList.add(n)),(e[kt]||(e[kt]=new Set)).add(t)}function tt(e,t){t.split(/\s+/).forEach(s=>s&&e.classList.remove(s));const n=e[kt];n&&(n.delete(t),n.size||(e[kt]=void 0))}function lr(e){requestAnimationFrame(()=>{requestAnimationFrame(e)})}let nc=0;function cr(e,t,n,s){const r=e._endId=++nc,i=()=>{r===e._endId&&s()};if(n)return setTimeout(i,n);const{type:o,timeout:l,propCount:c}=sc(e,t);if(!o)return s();const u=o+"end";let d=0;const h=()=>{e.removeEventListener(u,b),i()},b=T=>{T.target===e&&++d>=c&&h()};setTimeout(()=>{d(n[I]||"").split(", "),r=s(`${Ue}Delay`),i=s(`${Ue}Duration`),o=ar(r,i),l=s(`${Rt}Delay`),c=s(`${Rt}Duration`),u=ar(l,c);let d=null,h=0,b=0;t===Ue?o>0&&(d=Ue,h=o,b=i.length):t===Rt?u>0&&(d=Rt,h=u,b=c.length):(h=Math.max(o,u),d=h>0?o>u?Ue:Rt:null,b=d?d===Ue?i.length:c.length:0);const T=d===Ue&&/\b(transform|all)(,|$)/.test(s(`${Ue}Property`).toString());return{type:d,timeout:h,propCount:b,hasTransform:T}}function ar(e,t){for(;e.lengthur(n)+ur(e[s])))}function ur(e){return e==="auto"?0:Number(e.slice(0,-1).replace(",","."))*1e3}function rc(){return document.body.offsetHeight}function ic(e,t,n){const s=e[kt];s&&(t=(t?[t,...s]:[...s]).join(" ")),t==null?e.removeAttribute("class"):n?e.setAttribute("class",t):e.className=t}const oc=Symbol("_vod");function lc(e,t,n){const s=e.style,r=ne(n);if(n&&!r){if(t&&!ne(t))for(const i in t)n[i]==null&&rs(s,i,"");for(const i in n)rs(s,i,n[i])}else{const i=s.display;r?t!==n&&(s.cssText=n):t&&e.removeAttribute("style"),oc in e&&(s.display=i)}}const fr=/\s*!important$/;function rs(e,t,n){if(j(n))n.forEach(s=>rs(e,t,s));else if(n==null&&(n=""),t.startsWith("--"))e.setProperty(t,n);else{const s=cc(e,t);fr.test(n)?e.setProperty(at(s),n.replace(fr,""),"important"):e[s]=n}}const dr=["Webkit","Moz","ms"],kn={};function cc(e,t){const n=kn[t];if(n)return n;let s=Le(t);if(s!=="filter"&&s in e)return kn[t]=s;s=vn(s);for(let r=0;rUn||(gc.then(()=>Un=0),Un=Date.now());function yc(e,t){const n=s=>{if(!s._vts)s._vts=Date.now();else if(s._vts<=n.attached)return;Ee(_c(s,n.value),t,5,[s])};return n.value=e,n.attached=mc(),n}function _c(e,t){if(j(t)){const n=e.stopImmediatePropagation;return e.stopImmediatePropagation=()=>{n.call(e),e._stopped=!0},t.map(s=>r=>!r._stopped&&s&&s(r))}else return t}const mr=/^on[a-z]/,bc=(e,t,n,s,r=!1,i,o,l,c)=>{t==="class"?ic(e,s,r):t==="style"?lc(e,n,s):Ut(t)?ls(t)||hc(e,t,n,s,o):(t[0]==="."?(t=t.slice(1),!0):t[0]==="^"?(t=t.slice(1),!1):vc(e,t,s,r))?uc(e,t,s,i,o,l,c):(t==="true-value"?e._trueValue=s:t==="false-value"&&(e._falseValue=s),ac(e,t,s,r))};function vc(e,t,n,s){return s?!!(t==="innerHTML"||t==="textContent"||t in e&&mr.test(t)&&W(n)):t==="spellcheck"||t==="draggable"||t==="translate"||t==="form"||t==="list"&&e.tagName==="INPUT"||t==="type"&&e.tagName==="TEXTAREA"||mr.test(t)&&ne(n)?!1:t in e}const wc=["ctrl","shift","alt","meta"],Cc={stop:e=>e.stopPropagation(),prevent:e=>e.preventDefault(),self:e=>e.target!==e.currentTarget,ctrl:e=>!e.ctrlKey,shift:e=>!e.shiftKey,alt:e=>!e.altKey,meta:e=>!e.metaKey,left:e=>"button"in e&&e.button!==0,middle:e=>"button"in e&&e.button!==1,right:e=>"button"in e&&e.button!==2,exact:(e,t)=>wc.some(n=>e[`${n}Key`]&&!t.includes(n))},Ia=(e,t)=>(n,...s)=>{for(let r=0;rn=>{if(!("key"in n))return;const s=at(n.key);if(t.some(r=>r===s||xc[r]===s))return e(n)},Ec=ie({patchProp:bc},Gl);let Kn,yr=!1;function Tc(){return Kn=yr?Kn:Ml(Ec),yr=!0,Kn}const Ma=(...e)=>{const t=Tc().createApp(...e),{mount:n}=t;return t.mount=s=>{const r=Ac(s);if(r)return n(r,!0,r instanceof SVGElement)},t};function Ac(e){return ne(e)?document.querySelector(e):e}const La=(e,t)=>{const n=e.__vccOpts||e;for(const[s,r]of t)n[s]=r;return n},Sc="modulepreload",Rc=function(e){return"/js-lib/"+e},_r={},Na=function(t,n,s){if(!n||n.length===0)return t();const r=document.getElementsByTagName("link");return Promise.all(n.map(i=>{if(i=Rc(i),i in _r)return;_r[i]=!0;const o=i.endsWith(".css"),l=o?'[rel="stylesheet"]':"";if(!!s)for(let d=r.length-1;d>=0;d--){const h=r[d];if(h.href===i&&(!o||h.rel==="stylesheet"))return}else if(document.querySelector(`link[href="${i}"]${l}`))return;const u=document.createElement("link");if(u.rel=o?"stylesheet":Sc,o||(u.as="script",u.crossOrigin=""),u.href=i,document.head.appendChild(u),o)return new Promise((d,h)=>{u.addEventListener("load",d),u.addEventListener("error",()=>h(new Error(`Unable to preload CSS for ${i}`)))})})).then(()=>t()).catch(i=>{const o=new Event("vite:preloadError",{cancelable:!0});if(o.payload=i,window.dispatchEvent(o),!o.defaultPrevented)throw i})},Oc=window.__VP_SITE_DATA__;function Os(e){return Nr()?(fo(e),!0):!1}function Je(e){return typeof e=="function"?e():vs(e)}function Ha(e,t){const n=(t==null?void 0:t.computedGetter)===!1?vs:Je;return function(...s){return oe(()=>e.apply(this,s.map(r=>n(r))))}}const Fi=typeof window<"u"&&typeof document<"u",Pc=Object.prototype.toString,Ic=e=>Pc.call(e)==="[object Object]",Mi=()=>{},br=Fc();function Fc(){var e;return Fi&&((e=window==null?void 0:window.navigator)==null?void 0:e.userAgent)&&/iP(ad|hone|od)/.test(window.navigator.userAgent)}function Mc(e,t){function n(...s){return new Promise((r,i)=>{Promise.resolve(e(()=>t.apply(this,s),{fn:t,thisArg:this,args:s})).then(r).catch(i)})}return n}const Li=e=>e();function Lc(e=Li){const t=me(!0);function n(){t.value=!1}function s(){t.value=!0}const r=(...i)=>{t.value&&e(...i)};return{isActive:xn(t),pause:n,resume:s,eventFilter:r}}function Ni(...e){if(e.length!==1)return ko(...e);const t=e[0];return typeof t=="function"?xn(jo(()=>({get:t,set:Mi}))):me(t)}function Nc(e,t,n={}){const{eventFilter:s=Li,...r}=n;return Ye(e,Mc(s,t),r)}function Hc(e,t,n={}){const{eventFilter:s,...r}=n,{eventFilter:i,pause:o,resume:l,isActive:c}=Lc(s);return{stop:Nc(e,t,{...r,eventFilter:i}),pause:o,resume:l,isActive:c}}function $c(e,t=!0){Mn()?At(e):t?e():Tn(e)}function Hi(e){var t;const n=Je(e);return(t=n==null?void 0:n.$el)!=null?t:n}const xt=Fi?window:void 0;function mn(...e){let t,n,s,r;if(typeof e[0]=="string"||Array.isArray(e[0])?([n,s,r]=e,t=xt):[t,n,s,r]=e,!t)return Mi;Array.isArray(n)||(n=[n]),Array.isArray(s)||(s=[s]);const i=[],o=()=>{i.forEach(d=>d()),i.length=0},l=(d,h,b,T)=>(d.addEventListener(h,b,T),()=>d.removeEventListener(h,b,T)),c=Ye(()=>[Hi(t),Je(r)],([d,h])=>{if(o(),!d)return;const b=Ic(h)?{...h}:h;i.push(...n.flatMap(T=>s.map(I=>l(d,T,I,b))))},{immediate:!0,flush:"post"}),u=()=>{c(),o()};return Os(u),u}function jc(){const e=me(!1);return Mn()&&At(()=>{e.value=!0}),e}function Dc(e){const t=jc();return oe(()=>(t.value,!!e()))}function Bc(e,t={}){const{window:n=xt}=t,s=Dc(()=>n&&"matchMedia"in n&&typeof n.matchMedia=="function");let r;const i=me(!1),o=u=>{i.value=u.matches},l=()=>{r&&("removeEventListener"in r?r.removeEventListener("change",o):r.removeListener(o))},c=ti(()=>{s.value&&(l(),r=n.matchMedia(Je(e)),"addEventListener"in r?r.addEventListener("change",o):r.addListener(o),i.value=r.matches)});return Os(()=>{c(),l(),r=void 0}),i}const en=typeof globalThis<"u"?globalThis:typeof window<"u"?window:typeof global<"u"?global:typeof self<"u"?self:{},tn="__vueuse_ssr_handlers__",kc=Uc();function Uc(){return tn in en||(en[tn]=en[tn]||{}),en[tn]}function $i(e,t){return kc[e]||t}function Kc(e){return e==null?"any":e instanceof Set?"set":e instanceof Map?"map":e instanceof Date?"date":typeof e=="boolean"?"boolean":typeof e=="string"?"string":typeof e=="object"?"object":Number.isNaN(e)?"any":"number"}const Wc={boolean:{read:e=>e==="true",write:e=>String(e)},object:{read:e=>JSON.parse(e),write:e=>JSON.stringify(e)},number:{read:e=>Number.parseFloat(e),write:e=>String(e)},any:{read:e=>e,write:e=>String(e)},string:{read:e=>e,write:e=>String(e)},map:{read:e=>new Map(JSON.parse(e)),write:e=>JSON.stringify(Array.from(e.entries()))},set:{read:e=>new Set(JSON.parse(e)),write:e=>JSON.stringify(Array.from(e))},date:{read:e=>new Date(e),write:e=>e.toISOString()}},vr="vueuse-storage";function Vc(e,t,n,s={}){var r;const{flush:i="pre",deep:o=!0,listenToStorageChanges:l=!0,writeDefaults:c=!0,mergeDefaults:u=!1,shallow:d,window:h=xt,eventFilter:b,onError:T=w=>{console.error(w)}}=s,I=(d?zr:me)(t);if(!n)try{n=$i("getDefaultStorage",()=>{var w;return(w=xt)==null?void 0:w.localStorage})()}catch(w){T(w)}if(!n)return I;const O=Je(t),D=Kc(O),U=(r=s.serializer)!=null?r:Wc[D],{pause:Y,resume:m}=Hc(I,()=>p(I.value),{flush:i,deep:o,eventFilter:b});return h&&l&&(mn(h,"storage",B),mn(h,vr,K)),B(),I;function p(w){try{if(w==null)n.removeItem(e);else{const P=U.write(w),A=n.getItem(e);A!==P&&(n.setItem(e,P),h&&h.dispatchEvent(new CustomEvent(vr,{detail:{key:e,oldValue:A,newValue:P,storageArea:n}})))}}catch(P){T(P)}}function M(w){const P=w?w.newValue:n.getItem(e);if(P==null)return c&&O!==null&&n.setItem(e,U.write(O)),O;if(!w&&u){const A=U.read(P);return typeof u=="function"?u(A,O):D==="object"&&!Array.isArray(A)?{...O,...A}:A}else return typeof P!="string"?P:U.read(P)}function K(w){B(w.detail)}function B(w){if(!(w&&w.storageArea!==n)){if(w&&w.key==null){I.value=O;return}if(!(w&&w.key!==e)){Y();try{(w==null?void 0:w.newValue)!==U.write(I.value)&&(I.value=M(w))}catch(P){T(P)}finally{w?Tn(m):m()}}}}}function qc(e){return Bc("(prefers-color-scheme: dark)",e)}function zc(e={}){const{selector:t="html",attribute:n="class",initialValue:s="auto",window:r=xt,storage:i,storageKey:o="vueuse-color-scheme",listenToStorageChanges:l=!0,storageRef:c,emitAuto:u,disableTransition:d=!0}=e,h={auto:"",light:"light",dark:"dark",...e.modes||{}},b=qc({window:r}),T=oe(()=>b.value?"dark":"light"),I=c||(o==null?Ni(s):Vc(o,s,i,{window:r,listenToStorageChanges:l})),O=oe(()=>I.value==="auto"?T.value:I.value),D=$i("updateHTMLAttrs",(p,M,K)=>{const B=typeof p=="string"?r==null?void 0:r.document.querySelector(p):Hi(p);if(!B)return;let w;if(d){w=r.document.createElement("style");const P="*,*::before,*::after{-webkit-transition:none!important;-moz-transition:none!important;-o-transition:none!important;-ms-transition:none!important;transition:none!important}";w.appendChild(document.createTextNode(P)),r.document.head.appendChild(w)}if(M==="class"){const P=K.split(/\s/g);Object.values(h).flatMap(A=>(A||"").split(/\s/g)).filter(Boolean).forEach(A=>{P.includes(A)?B.classList.add(A):B.classList.remove(A)})}else B.setAttribute(M,K);d&&(r.getComputedStyle(w).opacity,document.head.removeChild(w))});function U(p){var M;D(t,n,(M=h[p])!=null?M:p)}function Y(p){e.onChanged?e.onChanged(p,U):U(p)}Ye(O,Y,{flush:"post",immediate:!0}),$c(()=>Y(O.value));const m=oe({get(){return u?I.value:O.value},set(p){I.value=p}});try{return Object.assign(m,{store:I,system:T,state:O})}catch{return m}}function Yc(e={}){const{valueDark:t="dark",valueLight:n=""}=e,s=zc({...e,onChanged:(i,o)=>{var l;e.onChanged?(l=e.onChanged)==null||l.call(e,i==="dark",o,i):o(i)},modes:{dark:t,light:n}});return oe({get(){return s.value==="dark"},set(i){const o=i?"dark":"light";s.system.value===o?s.value="auto":s.value=o}})}function Wn(e){return typeof Window<"u"&&e instanceof Window?e.document.documentElement:typeof Document<"u"&&e instanceof Document?e.documentElement:e}function ji(e){const t=window.getComputedStyle(e);if(t.overflowX==="scroll"||t.overflowY==="scroll"||t.overflowX==="auto"&&e.clientWidth1?!0:(t.preventDefault&&t.preventDefault(),!1)}function $a(e,t=!1){const n=me(t);let s=null,r;Ye(Ni(e),l=>{const c=Wn(Je(l));if(c){const u=c;r=u.style.overflow,n.value&&(u.style.overflow="hidden")}},{immediate:!0});const i=()=>{const l=Wn(Je(e));!l||n.value||(br&&(s=mn(l,"touchmove",c=>{Jc(c)},{passive:!1})),l.style.overflow="hidden",n.value=!0)},o=()=>{const l=Wn(Je(e));!l||!n.value||(br&&(s==null||s()),l.style.overflow=r,n.value=!1)};return Os(o),oe({get(){return n.value},set(l){l?i():o()}})}function ja(e={}){const{window:t=xt}=e;if(!t)return{x:me(0),y:me(0)};const n=me(t.scrollX),s=me(t.scrollY);return mn(t,"scroll",()=>{n.value=t.scrollX,s.value=t.scrollY},{capture:!1,passive:!0}),{x:n,y:s}}const Di=/^[a-z]+:/i,Xc="vitepress-theme-appearance",Bi=/#.*$/,Qc=/(index)?\.(md|html)$/,xe=typeof document<"u",ki={relativePath:"",filePath:"",title:"404",description:"Not Found",headers:[],frontmatter:{sidebar:!1,layout:"page"},lastUpdated:0,isNotFound:!0};function Zc(e,t,n=!1){if(t===void 0)return!1;if(e=wr(`/${e}`),n)return new RegExp(t).test(e);if(wr(t)!==e)return!1;const s=t.match(Bi);return s?(xe?location.hash:"")===s[0]:!0}function wr(e){return decodeURI(e).replace(Bi,"").replace(Qc,"")}function Gc(e){return Di.test(e)}function ea(e,t){var s,r,i,o,l,c,u;const n=Object.keys(e.locales).find(d=>d!=="root"&&!Gc(d)&&Zc(t,`/${d}/`,!0))||"root";return Object.assign({},e,{localeIndex:n,lang:((s=e.locales[n])==null?void 0:s.lang)??e.lang,dir:((r=e.locales[n])==null?void 0:r.dir)??e.dir,title:((i=e.locales[n])==null?void 0:i.title)??e.title,titleTemplate:((o=e.locales[n])==null?void 0:o.titleTemplate)??e.titleTemplate,description:((l=e.locales[n])==null?void 0:l.description)??e.description,head:Ki(e.head,((c=e.locales[n])==null?void 0:c.head)??[]),themeConfig:{...e.themeConfig,...(u=e.locales[n])==null?void 0:u.themeConfig}})}function Ui(e,t){const n=t.title||e.title,s=t.titleTemplate??e.titleTemplate;if(typeof s=="string"&&s.includes(":title"))return s.replace(/:title/g,n);const r=ta(e.title,s);return`${n}${r}`}function ta(e,t){return t===!1?"":t===!0||t===void 0?` | ${e}`:e===t?"":` | ${t}`}function na(e,t){const[n,s]=t;if(n!=="meta")return!1;const r=Object.entries(s)[0];return r==null?!1:e.some(([i,o])=>i===n&&o[r[0]]===r[1])}function Ki(e,t){return[...e.filter(n=>!na(t,n)),...t]}const sa=/[\u0000-\u001F"#$&*+,:;<=>?[\]^`{|}\u007F]/g,ra=/^[a-z]:/i;function Cr(e){const t=ra.exec(e),n=t?t[0]:"";return n+e.slice(n.length).replace(sa,"_").replace(/(^|\/)_+(?=[^/]*$)/,"$1")}const ia=Symbol(),lt=zr(Oc);function Da(e){const t=oe(()=>ea(lt.value,e.data.relativePath)),n=t.value.appearance,s=n==="force-dark"?me(!0):n?Yc({storageKey:Xc,initialValue:()=>typeof n=="string"?n:"auto",...typeof n=="object"?n:{}}):me(!1);return{site:t,theme:oe(()=>t.value.themeConfig),page:oe(()=>e.data),frontmatter:oe(()=>e.data.frontmatter),params:oe(()=>e.data.params),lang:oe(()=>t.value.lang),dir:oe(()=>t.value.dir),localeIndex:oe(()=>t.value.localeIndex||"root"),title:oe(()=>Ui(t.value,e.data)),description:oe(()=>e.data.description||t.value.description),isDark:s}}function oa(){const e=bt(ia);if(!e)throw new Error("vitepress data not properly injected in app");return e}function la(e,t){return`${e}${t}`.replace(/\/+/g,"/")}function xr(e){return Di.test(e)||!e.startsWith("/")?e:la(lt.value.base,e)}function ca(e){let t=e.replace(/\.html$/,"");if(t=decodeURIComponent(t),t=t.replace(/\/$/,"/index"),xe){const n="/js-lib/";t=Cr(t.slice(n.length).replace(/\//g,"_")||"index")+".md";let s=__VP_HASH_MAP__[t.toLowerCase()];if(s||(t=t.endsWith("_index.md")?t.slice(0,-9)+".md":t.slice(0,-3)+"_index.md",s=__VP_HASH_MAP__[t.toLowerCase()]),!s)return null;t=`${n}assets/${t}.${s}.js`}else t=`./${Cr(t.slice(1).replace(/\//g,"_"))}.md.js`;return t}let on=[];function Ba(e){on.push(e),In(()=>{on=on.filter(t=>t!==e)})}const aa=Symbol(),Wi="http://a.com",ua=()=>({path:"/",component:null,data:ki});function ka(e,t){const n=Cn(ua()),s={route:n,go:r};async function r(l=xe?location.href:"/"){var c,u;l=is(l),await((c=s.onBeforeRouteChange)==null?void 0:c.call(s,l))!==!1&&(Ar(l),await o(l),await((u=s.onAfterRouteChanged)==null?void 0:u.call(s,l)))}let i=null;async function o(l,c=0,u=!1){var b;if(await((b=s.onBeforePageLoad)==null?void 0:b.call(s,l))===!1)return;const d=new URL(l,Wi),h=i=d.pathname;try{let T=await e(h);if(!T)throw new Error(`Page not found: ${h}`);if(i===h){i=null;const{default:I,__pageData:O}=T;if(!I)throw new Error(`Invalid route component: ${I}`);n.path=xe?h:xr(h),n.component=Ft(I),n.data=Ft(O),xe&&Tn(()=>{let D=lt.value.base+O.relativePath.replace(/(?:(^|\/)index)?\.md$/,"$1");if(!lt.value.cleanUrls&&!D.endsWith("/")&&(D+=".html"),D!==d.pathname&&(d.pathname=D,l=D+d.search+d.hash,history.replaceState(null,"",l)),d.hash&&!c){let U=null;try{U=document.getElementById(decodeURIComponent(d.hash).slice(1))}catch(Y){console.warn(Y)}if(U){Er(U,d.hash);return}}window.scrollTo(0,c)})}}catch(T){if(!/fetch|Page not found/.test(T.message)&&!/^\/404(\.html|\/)?$/.test(l)&&console.error(T),!u)try{const I=await fetch(lt.value.base+"hashmap.json");window.__VP_HASH_MAP__=await I.json(),await o(l,c,!0);return}catch{}i===h&&(i=null,n.path=xe?h:xr(h),n.component=t?Ft(t):null,n.data=ki)}}return xe&&(window.addEventListener("click",l=>{if(l.target.closest("button"))return;const u=l.target.closest("a");if(u&&!u.closest(".vp-raw")&&(u instanceof SVGElement||!u.download)){const{target:d}=u,{href:h,origin:b,pathname:T,hash:I,search:O}=new URL(u.href instanceof SVGAnimatedString?u.href.animVal:u.href,u.baseURI),D=window.location,U=T.match(/\.\w+$/);!l.ctrlKey&&!l.shiftKey&&!l.altKey&&!l.metaKey&&!d&&b===D.origin&&!(U&&U[0]!==".html")&&(l.preventDefault(),T===D.pathname&&O===D.search?(I!==D.hash&&(history.pushState(null,"",I),window.dispatchEvent(new Event("hashchange"))),I?Er(u,I,u.classList.contains("header-anchor")):(Ar(h),window.scrollTo(0,0))):r(h))}},{capture:!0}),window.addEventListener("popstate",l=>{o(is(location.href),l.state&&l.state.scrollPosition||0)}),window.addEventListener("hashchange",l=>{l.preventDefault()})),s}function fa(){const e=bt(aa);if(!e)throw new Error("useRouter() is called without provider.");return e}function Vi(){return fa().route}function Er(e,t,n=!1){let s=null;try{s=e.classList.contains("header-anchor")?e:document.getElementById(decodeURIComponent(t).slice(1))}catch(r){console.warn(r)}if(s){let u=function(){!n||Math.abs(c-window.scrollY)>window.innerHeight?window.scrollTo(0,c):window.scrollTo({left:0,top:c,behavior:"smooth"})},r=lt.value.scrollOffset,i=0,o=24;if(typeof r=="object"&&"padding"in r&&(o=r.padding,r=r.selector),typeof r=="number")i=r;else if(typeof r=="string")i=Tr(r,o);else if(Array.isArray(r))for(const d of r){const h=Tr(d,o);if(h){i=h;break}}const l=parseInt(window.getComputedStyle(s).paddingTop,10),c=window.scrollY+s.getBoundingClientRect().top-i+l;requestAnimationFrame(u)}}function Tr(e,t){const n=document.querySelector(e);if(!n)return 0;const s=n.getBoundingClientRect().bottom;return s<0?0:s+t}function Ar(e){xe&&e!==is(location.href)&&(history.replaceState({scrollPosition:window.scrollY},document.title),history.pushState(null,"",e))}function is(e){const t=new URL(e,Wi);return t.pathname=t.pathname.replace(/(^|\/)index(\.html)?$/,"$1"),lt.value.cleanUrls?t.pathname=t.pathname.replace(/\.html$/,""):!t.pathname.endsWith("/")&&!t.pathname.endsWith(".html")&&(t.pathname+=".html"),t.pathname+t.search+t.hash}const Sr=()=>on.forEach(e=>e()),Ua=oi({name:"VitePressContent",props:{as:{type:[Object,String],default:"div"}},setup(e){const t=Vi(),{site:n}=oa();return()=>ss(e.as,n.value.contentProps??{style:{position:"relative"}},[t.component?ss(t.component,{onVnodeMounted:Sr,onVnodeUpdated:Sr}):"404 Page Not Found"])}}),Ka=oi({setup(e,{slots:t}){const n=me(!1);return At(()=>{n.value=!0}),()=>n.value&&t.default?t.default():null}});function Wa(){xe&&window.addEventListener("click",e=>{var n;const t=e.target;if(t.matches(".vp-code-group input")){const s=(n=t.parentElement)==null?void 0:n.parentElement;if(!s)return;const r=Array.from(s.querySelectorAll("input")).indexOf(t);if(r<0)return;const i=s.querySelector(".blocks");if(!i)return;const o=Array.from(i.children).find(u=>u.classList.contains("active"));if(!o)return;const l=i.children[r];if(!l||o===l)return;o.classList.remove("active"),l.classList.add("active");const c=s==null?void 0:s.querySelector(`label[for="${t.id}"]`);c==null||c.scrollIntoView({block:"nearest"})}})}function Va(){if(xe){const e=new WeakMap;window.addEventListener("click",t=>{var s;const n=t.target;if(n.matches('div[class*="language-"] > button.copy')){const r=n.parentElement,i=(s=n.nextElementSibling)==null?void 0:s.nextElementSibling;if(!r||!i)return;const o=/language-(shellscript|shell|bash|sh|zsh)/.test(r.className);let l="";i.querySelectorAll("span.line:not(.diff.remove)").forEach(c=>l+=(c.textContent||"")+` +`),l=l.slice(0,-1),o&&(l=l.replace(/^ *(\$|>) /gm,"").trim()),da(l).then(()=>{n.classList.add("copied"),clearTimeout(e.get(n));const c=setTimeout(()=>{n.classList.remove("copied"),n.blur(),e.delete(n)},2e3);e.set(n,c)})}})}}async function da(e){try{return navigator.clipboard.writeText(e)}catch{const t=document.createElement("textarea"),n=document.activeElement;t.value=e,t.setAttribute("readonly",""),t.style.contain="strict",t.style.position="absolute",t.style.left="-9999px",t.style.fontSize="12pt";const s=document.getSelection(),r=s?s.rangeCount>0&&s.getRangeAt(0):null;document.body.appendChild(t),t.select(),t.selectionStart=0,t.selectionEnd=e.length,document.execCommand("copy"),document.body.removeChild(t),r&&(s.removeAllRanges(),s.addRange(r)),n&&n.focus()}}function qa(e,t){let n=[],s=!0;const r=i=>{if(s){s=!1;return}const o=i.map(Rr);n.forEach((l,c)=>{const u=o.findIndex(d=>d==null?void 0:d.isEqualNode(l??null));u!==-1?delete o[u]:(l==null||l.remove(),delete n[c])}),o.forEach(l=>l&&document.head.appendChild(l)),n=[...n,...o].filter(Boolean)};ti(()=>{const i=e.data,o=t.value,l=i&&i.description,c=i&&i.frontmatter.head||[],u=Ui(o,i);u!==document.title&&(document.title=u);const d=l||o.description;let h=document.querySelector("meta[name=description]");h?h.getAttribute("content")!==d&&h.setAttribute("content",d):Rr(["meta",{name:"description",content:d}]),r(Ki(o.head,pa(c)))})}function Rr([e,t,n]){const s=document.createElement(e);for(const r in t)s.setAttribute(r,t[r]);return n&&(s.innerHTML=n),e==="script"&&!t.async&&(s.async=!1),s}function ha(e){return e[0]==="meta"&&e[1]&&e[1].name==="description"}function pa(e){return e.filter(t=>!ha(t))}const Vn=new Set,qi=()=>document.createElement("link"),ga=e=>{const t=qi();t.rel="prefetch",t.href=e,document.head.appendChild(t)},ma=e=>{const t=new XMLHttpRequest;t.open("GET",e,t.withCredentials=!0),t.send()};let nn;const ya=xe&&(nn=qi())&&nn.relList&&nn.relList.supports&&nn.relList.supports("prefetch")?ga:ma;function za(){if(!xe||!window.IntersectionObserver)return;let e;if((e=navigator.connection)&&(e.saveData||/2g/.test(e.effectiveType)))return;const t=window.requestIdleCallback||setTimeout;let n=null;const s=()=>{n&&n.disconnect(),n=new IntersectionObserver(i=>{i.forEach(o=>{if(o.isIntersecting){const l=o.target;n.unobserve(l);const{pathname:c}=l;if(!Vn.has(c)){Vn.add(c);const u=ca(c);u&&ya(u)}}})}),t(()=>{document.querySelectorAll("#app a").forEach(i=>{const{hostname:o,pathname:l}=new URL(i.href instanceof SVGAnimatedString?i.href.animVal:i.href,i.baseURI),c=l.match(/\.\w+$/);c&&c[0]!==".html"||i.target!=="_blank"&&o===location.hostname&&(l!==location.pathname?n.observe(i):Vn.add(l))})})};At(s);const r=Vi();Ye(()=>r.path,s),In(()=>{n&&n.disconnect()})}export{Sa as $,wa as A,dl as B,Ca as C,Ea as D,zr as E,ge as F,Ba as G,ue as H,xa as I,Di as J,Vi as K,Bl as L,bt as M,us as N,Tn as O,ja as P,Oa as Q,xn as R,Ha as S,Pi as T,ko as U,$a as V,Al as W,Fa as X,Aa as Y,Ia as Z,La as _,Ai as a,qa as a0,aa as a1,Da as a2,ia as a3,Ua as a4,Ka as a5,lt as a6,Ma as a7,ka as a8,ca as a9,Na as aa,za as ab,Va as ac,Wa as ad,ss as ae,xi as b,Ra as c,oi as d,Pa as e,xr as f,oe as g,me as h,Gc as i,At as j,Ti as k,vs as l,va as m,fs as n,wi as o,ba as p,Zc as q,Ta as r,xe as s,_a as t,oa as u,Bc as v,Qo as w,Ye as x,ti as y,In as z}; diff --git a/assets/chunks/theme.1bf5c1be.js b/assets/chunks/theme.1bf5c1be.js new file mode 100644 index 00000000..934bd843 --- /dev/null +++ b/assets/chunks/theme.1bf5c1be.js @@ -0,0 +1 @@ +import{d as g,o as a,c as i,r as u,n as N,a as x,t as L,_ as m,b as $,w as v,T as ce,e as f,u as He,i as ze,f as ue,g as k,h as S,j as G,k as c,l,p as H,m as z,q as O,s as K,v as re,x as U,y as te,z as de,A as Pe,B as De,C as j,F as M,D as A,E as _e,G as Y,H as h,I as E,J as Ve,K as se,L as Q,M as ne,N as Fe,O as Ee,P as we,Q as Oe,R as Ge,S as Ue,U as je,V as Le,W as Se,X as qe,Y as Re,Z as Ke,$ as We}from"./framework.01940dea.js";const Ye=g({__name:"VPBadge",props:{text:{},type:{default:"tip"}},setup(s){return(e,t)=>(a(),i("span",{class:N(["VPBadge",e.type])},[u(e.$slots,"default",{},()=>[x(L(e.text),1)],!0)],2))}});const Je=m(Ye,[["__scopeId","data-v-9613cc9f"]]),Ze={key:0,class:"VPBackdrop"},Qe=g({__name:"VPBackdrop",props:{show:{type:Boolean}},setup(s){return(e,t)=>(a(),$(ce,{name:"fade"},{default:v(()=>[e.show?(a(),i("div",Ze)):f("",!0)]),_:1}))}});const Xe=m(Qe,[["__scopeId","data-v-c79a1216"]]),P=He;function et(s,e){let t,n=!1;return()=>{t&&clearTimeout(t),n?t=setTimeout(s,e):(s(),(n=!0)&&setTimeout(()=>n=!1,e))}}function le(s){return/^\//.test(s)?s:`/${s}`}function J(s){const{pathname:e,search:t,hash:n,protocol:o}=new URL(s,"http://a.com");if(ze(s)||s.startsWith("#")||!o.startsWith("http")||/\.(?!html|md)\w+($|\?)/i.test(s))return s;const{site:r}=P(),d=e.endsWith("/")||e.endsWith(".html")?s:s.replace(/(?:(^\.+)\/)?.*$/,`$1${e.replace(/(\.md)?$/,r.value.cleanUrls?"":".html")}${t}${n}`);return ue(d)}function Z({removeCurrent:s=!0,correspondingLink:e=!1}={}){const{site:t,localeIndex:n,page:o,theme:r}=P(),d=k(()=>{var _,b;return{label:(_=t.value.locales[n.value])==null?void 0:_.label,link:((b=t.value.locales[n.value])==null?void 0:b.link)||(n.value==="root"?"/":`/${n.value}/`)}});return{localeLinks:k(()=>Object.entries(t.value.locales).flatMap(([_,b])=>s&&d.value.label===b.label?[]:{text:b.label,link:tt(b.link||(_==="root"?"/":`/${_}/`),r.value.i18nRouting!==!1&&e,o.value.relativePath.slice(d.value.link.length-1),!t.value.cleanUrls)})),currentLang:d}}function tt(s,e,t,n){return e?s.replace(/\/$/,"")+le(t.replace(/(^|\/)index\.md$/,"$1").replace(/\.md$/,n?".html":"")):s}const st=s=>(H("data-v-f87ff6e4"),s=s(),z(),s),nt={class:"NotFound"},ot={class:"code"},at={class:"title"},rt=st(()=>c("div",{class:"divider"},null,-1)),lt={class:"quote"},it={class:"action"},ct=["href","aria-label"],ut=g({__name:"NotFound",setup(s){const{site:e,theme:t}=P(),{localeLinks:n}=Z({removeCurrent:!1}),o=S("/");return G(()=>{var d;const r=window.location.pathname.replace(e.value.base,"").replace(/(^.*?\/).*$/,"/$1");n.value.length&&(o.value=((d=n.value.find(({link:p})=>p.startsWith(r)))==null?void 0:d.link)||n.value[0].link)}),(r,d)=>{var p,_,b,y,w;return a(),i("div",nt,[c("p",ot,L(((p=l(t).notFound)==null?void 0:p.code)??"404"),1),c("h1",at,L(((_=l(t).notFound)==null?void 0:_.title)??"PAGE NOT FOUND"),1),rt,c("blockquote",lt,L(((b=l(t).notFound)==null?void 0:b.quote)??"But if you don't change your direction, and if you keep looking, you may end up where you are heading."),1),c("div",it,[c("a",{class:"link",href:l(ue)(o.value),"aria-label":((y=l(t).notFound)==null?void 0:y.linkLabel)??"go to home"},L(((w=l(t).notFound)==null?void 0:w.linkText)??"Take me home"),9,ct)])])}}});const dt=m(ut,[["__scopeId","data-v-f87ff6e4"]]);function Me(s,e){if(Array.isArray(s))return X(s);if(s==null)return[];e=le(e);const t=Object.keys(s).sort((o,r)=>r.split("/").length-o.split("/").length).find(o=>e.startsWith(le(o))),n=t?s[t]:[];return Array.isArray(n)?X(n):X(n.items,n.base)}function _t(s){const e=[];let t=0;for(const n in s){const o=s[n];if(o.items){t=e.push(o);continue}e[t]||e.push({items:[]}),e[t].items.push(o)}return e}function vt(s){const e=[];function t(n){for(const o of n)o.text&&o.link&&e.push({text:o.text,link:o.link,docFooterText:o.docFooterText}),o.items&&t(o.items)}return t(s),e}function ie(s,e){return Array.isArray(e)?e.some(t=>ie(s,t)):O(s,e.link)?!0:e.items?ie(s,e.items):!1}function X(s,e){return[...s].map(t=>{const n={...t},o=n.base||e;return o&&n.link&&(n.link=o+n.link),n.items&&(n.items=X(n.items,o)),n})}function D(){const{frontmatter:s,page:e,theme:t}=P(),n=re("(min-width: 960px)"),o=S(!1),r=k(()=>{const T=t.value.sidebar,V=e.value.relativePath;return T?Me(T,V):[]}),d=S(r.value);U(r,(T,V)=>{JSON.stringify(T)!==JSON.stringify(V)&&(d.value=r.value)});const p=k(()=>s.value.sidebar!==!1&&d.value.length>0&&s.value.layout!=="home"),_=k(()=>b?s.value.aside==null?t.value.aside==="left":s.value.aside==="left":!1),b=k(()=>s.value.layout==="home"?!1:s.value.aside!=null?!!s.value.aside:t.value.aside!==!1),y=k(()=>p.value&&n.value),w=k(()=>p.value?_t(d.value):[]);function C(){o.value=!0}function I(){o.value=!1}function B(){o.value?I():C()}return{isOpen:o,sidebar:d,sidebarGroups:w,hasSidebar:p,hasAside:b,leftAside:_,isSidebarEnabled:y,open:C,close:I,toggle:B}}function pt(s,e){let t;te(()=>{t=s.value?document.activeElement:void 0}),G(()=>{window.addEventListener("keyup",n)}),de(()=>{window.removeEventListener("keyup",n)});function n(o){o.key==="Escape"&&s.value&&(e(),t==null||t.focus())}}const Ne=S(K?location.hash:"");K&&window.addEventListener("hashchange",()=>{Ne.value=location.hash});function ht(s){const{page:e}=P(),t=S(!1),n=k(()=>s.value.collapsed!=null),o=k(()=>!!s.value.link),r=S(!1),d=()=>{r.value=O(e.value.relativePath,s.value.link)};U([e,s,Ne],d),G(d);const p=k(()=>r.value?!0:s.value.items?ie(e.value.relativePath,s.value.items):!1),_=k(()=>!!(s.value.items&&s.value.items.length));te(()=>{t.value=!!(n.value&&s.value.collapsed)}),Pe(()=>{(r.value||p.value)&&(t.value=!1)});function b(){n.value&&(t.value=!t.value)}return{collapsed:t,collapsible:n,isLink:o,isActiveLink:r,hasActiveLink:p,hasChildren:_,toggle:b}}function ft(){const{hasSidebar:s}=D(),e=re("(min-width: 960px)"),t=re("(min-width: 1280px)");return{isAsideEnabled:k(()=>!t.value&&!e.value?!1:s.value?t.value:e.value)}}const mt=71;function ve(s){return typeof s.outline=="object"&&!Array.isArray(s.outline)&&s.outline.label||s.outlineTitle||"On this page"}function pe(s){const e=[...document.querySelectorAll(".VPDoc :where(h1,h2,h3,h4,h5,h6)")].filter(t=>t.id&&t.hasChildNodes()).map(t=>{const n=Number(t.tagName[1]);return{title:gt(t),link:"#"+t.id,level:n}});return bt(e,s)}function gt(s){let e="";for(const t of s.childNodes)if(t.nodeType===1){if(t.classList.contains("VPBadge")||t.classList.contains("header-anchor"))continue;e+=t.textContent}else t.nodeType===3&&(e+=t.textContent);return e.trim()}function bt(s,e){if(e===!1)return[];const t=(typeof e=="object"&&!Array.isArray(e)?e.level:e)||2,[n,o]=typeof t=="number"?[t,t]:t==="deep"?[2,6]:t;s=s.filter(d=>d.level>=n&&d.level<=o);const r=[];e:for(let d=0;d=0;_--){const b=s[_];if(b.level{requestAnimationFrame(r),window.addEventListener("scroll",n)}),De(()=>{d(location.hash)}),de(()=>{window.removeEventListener("scroll",n)});function r(){if(!t.value)return;const p=[].slice.call(s.value.querySelectorAll(".outline-link")),_=[].slice.call(document.querySelectorAll(".content .header-anchor")).filter(I=>p.some(B=>B.hash===I.hash&&I.offsetParent!==null)),b=window.scrollY,y=window.innerHeight,w=document.body.offsetHeight,C=Math.abs(b+y-w)<1;if(_.length&&C){d(_[_.length-1].hash);return}for(let I=0;I<_.length;I++){const B=_[I],T=_[I+1],[V,q]=kt(I,B,T);if(V){d(q);return}}}function d(p){o&&o.classList.remove("active"),p==null?o=null:o=s.value.querySelector(`a[href="${decodeURIComponent(p)}"]`);const _=o;_?(_.classList.add("active"),e.value.style.top=_.offsetTop+33+"px",e.value.style.opacity="1"):(e.value.style.top="33px",e.value.style.opacity="0")}}function ke(s){return s.parentElement.offsetTop-mt}function kt(s,e,t){const n=window.scrollY;return s===0&&n===0?[!0,null]:n{const o=j("VPDocOutlineItem",!0);return a(),i("ul",{class:N(t.root?"root":"nested")},[(a(!0),i(M,null,A(t.headers,({children:r,link:d,title:p})=>(a(),i("li",null,[c("a",{class:"outline-link",href:d,onClick:e,title:p},L(p),9,yt),r!=null&&r.length?(a(),$(o,{key:0,headers:r},null,8,["headers"])):f("",!0)]))),256))],2)}}});const he=m(Pt,[["__scopeId","data-v-d0ee3533"]]),Vt=s=>(H("data-v-d330b1bb"),s=s(),z(),s),wt={class:"content"},Lt={class:"outline-title",role:"heading","aria-level":"2"},St={"aria-labelledby":"doc-outline-aria-label"},Mt=Vt(()=>c("span",{class:"visually-hidden",id:"doc-outline-aria-label"}," Table of Contents for current page ",-1)),Nt=g({__name:"VPDocAsideOutline",setup(s){const{frontmatter:e,theme:t}=P(),n=_e([]);Y(()=>{n.value=pe(e.value.outline??t.value.outline)});const o=S(),r=S();return $t(o,r),(d,p)=>(a(),i("div",{class:N(["VPDocAsideOutline",{"has-outline":n.value.length>0}]),ref_key:"container",ref:o,role:"navigation"},[c("div",wt,[c("div",{class:"outline-marker",ref_key:"marker",ref:r},null,512),c("div",Lt,L(l(ve)(l(t))),1),c("nav",St,[Mt,h(he,{headers:n.value,root:!0},null,8,["headers"])])])],2))}});const It=m(Nt,[["__scopeId","data-v-d330b1bb"]]),Ct={class:"VPDocAsideCarbonAds"},Tt=g({__name:"VPDocAsideCarbonAds",props:{carbonAds:{}},setup(s){const e=()=>null;return(t,n)=>(a(),i("div",Ct,[h(l(e),{"carbon-ads":t.carbonAds},null,8,["carbon-ads"])]))}}),Bt=s=>(H("data-v-3f215769"),s=s(),z(),s),At={class:"VPDocAside"},xt=Bt(()=>c("div",{class:"spacer"},null,-1)),Ht=g({__name:"VPDocAside",setup(s){const{theme:e}=P();return(t,n)=>(a(),i("div",At,[u(t.$slots,"aside-top",{},void 0,!0),u(t.$slots,"aside-outline-before",{},void 0,!0),h(It),u(t.$slots,"aside-outline-after",{},void 0,!0),xt,u(t.$slots,"aside-ads-before",{},void 0,!0),l(e).carbonAds?(a(),$(Tt,{key:0,"carbon-ads":l(e).carbonAds},null,8,["carbon-ads"])):f("",!0),u(t.$slots,"aside-ads-after",{},void 0,!0),u(t.$slots,"aside-bottom",{},void 0,!0)]))}});const zt=m(Ht,[["__scopeId","data-v-3f215769"]]);function Dt(){const{theme:s,page:e}=P();return k(()=>{const{text:t="Edit this page",pattern:n=""}=s.value.editLink||{};let o;return typeof n=="function"?o=n(e.value):o=n.replace(/:path/g,e.value.filePath),{url:o,text:t}})}function Ft(){const{page:s,theme:e,frontmatter:t}=P();return k(()=>{var _,b,y,w,C,I,B,T;const n=Me(e.value.sidebar,s.value.relativePath),o=vt(n),r=o.findIndex(V=>O(s.value.relativePath,V.link)),d=((_=e.value.docFooter)==null?void 0:_.prev)===!1&&!t.value.prev||t.value.prev===!1,p=((b=e.value.docFooter)==null?void 0:b.next)===!1&&!t.value.next||t.value.next===!1;return{prev:d?void 0:{text:(typeof t.value.prev=="string"?t.value.prev:typeof t.value.prev=="object"?t.value.prev.text:void 0)??((y=o[r-1])==null?void 0:y.docFooterText)??((w=o[r-1])==null?void 0:w.text),link:(typeof t.value.prev=="object"?t.value.prev.link:void 0)??((C=o[r-1])==null?void 0:C.link)},next:p?void 0:{text:(typeof t.value.next=="string"?t.value.next:typeof t.value.next=="object"?t.value.next.text:void 0)??((I=o[r+1])==null?void 0:I.docFooterText)??((B=o[r+1])==null?void 0:B.text),link:(typeof t.value.next=="object"?t.value.next.link:void 0)??((T=o[r+1])==null?void 0:T.link)}}})}const Et={},Ot={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},Gt=c("path",{d:"M18,23H4c-1.7,0-3-1.3-3-3V6c0-1.7,1.3-3,3-3h7c0.6,0,1,0.4,1,1s-0.4,1-1,1H4C3.4,5,3,5.4,3,6v14c0,0.6,0.4,1,1,1h14c0.6,0,1-0.4,1-1v-7c0-0.6,0.4-1,1-1s1,0.4,1,1v7C21,21.7,19.7,23,18,23z"},null,-1),Ut=c("path",{d:"M8,17c-0.3,0-0.5-0.1-0.7-0.3C7,16.5,6.9,16.1,7,15.8l1-4c0-0.2,0.1-0.3,0.3-0.5l9.5-9.5c1.2-1.2,3.2-1.2,4.4,0c1.2,1.2,1.2,3.2,0,4.4l-9.5,9.5c-0.1,0.1-0.3,0.2-0.5,0.3l-4,1C8.2,17,8.1,17,8,17zM9.9,12.5l-0.5,2.1l2.1-0.5l9.3-9.3c0.4-0.4,0.4-1.1,0-1.6c-0.4-0.4-1.2-0.4-1.6,0l0,0L9.9,12.5z M18.5,2.5L18.5,2.5L18.5,2.5z"},null,-1),jt=[Gt,Ut];function qt(s,e){return a(),i("svg",Ot,jt)}const Rt=m(Et,[["render",qt]]),F=g({__name:"VPLink",props:{tag:{},href:{},noIcon:{type:Boolean},target:{},rel:{}},setup(s){const e=s,t=k(()=>e.tag??(e.href?"a":"span")),n=k(()=>e.href&&Ve.test(e.href));return(o,r)=>(a(),$(E(t.value),{class:N(["VPLink",{link:o.href,"vp-external-link-icon":n.value,"no-icon":o.noIcon}]),href:o.href?l(J)(o.href):void 0,target:o.target??(n.value?"_blank":void 0),rel:o.rel??(n.value?"noreferrer":void 0)},{default:v(()=>[u(o.$slots,"default")]),_:3},8,["class","href","target","rel"]))}}),Kt={class:"VPLastUpdated"},Wt=["datetime"],Yt=g({__name:"VPDocFooterLastUpdated",setup(s){const{theme:e,page:t,frontmatter:n,lang:o}=P(),r=k(()=>new Date(n.value.lastUpdated??t.value.lastUpdated)),d=k(()=>r.value.toISOString()),p=S("");return G(()=>{te(()=>{var _,b,y;p.value=new Intl.DateTimeFormat((b=(_=e.value.lastUpdated)==null?void 0:_.formatOptions)!=null&&b.forceLocale?o.value:void 0,((y=e.value.lastUpdated)==null?void 0:y.formatOptions)??{dateStyle:"short",timeStyle:"short"}).format(r.value)})}),(_,b)=>{var y;return a(),i("p",Kt,[x(L(((y=l(e).lastUpdated)==null?void 0:y.text)||l(e).lastUpdatedText||"Last updated")+": ",1),c("time",{datetime:d.value},L(p.value),9,Wt)])}}});const Jt=m(Yt,[["__scopeId","data-v-7e05ebdb"]]),Zt={key:0,class:"VPDocFooter"},Qt={key:0,class:"edit-info"},Xt={key:0,class:"edit-link"},es={key:1,class:"last-updated"},ts={key:1,class:"prev-next"},ss={class:"pager"},ns=["href"],os=["innerHTML"],as=["innerHTML"],rs={class:"pager"},ls=["href"],is=["innerHTML"],cs=["innerHTML"],us=g({__name:"VPDocFooter",setup(s){const{theme:e,page:t,frontmatter:n}=P(),o=Dt(),r=Ft(),d=k(()=>e.value.editLink&&n.value.editLink!==!1),p=k(()=>t.value.lastUpdated&&n.value.lastUpdated!==!1),_=k(()=>d.value||p.value||r.value.prev||r.value.next);return(b,y)=>{var w,C,I,B,T,V;return _.value?(a(),i("footer",Zt,[u(b.$slots,"doc-footer-before",{},void 0,!0),d.value||p.value?(a(),i("div",Qt,[d.value?(a(),i("div",Xt,[h(F,{class:"edit-link-button",href:l(o).url,"no-icon":!0},{default:v(()=>[h(Rt,{class:"edit-link-icon","aria-label":"edit icon"}),x(" "+L(l(o).text),1)]),_:1},8,["href"])])):f("",!0),p.value?(a(),i("div",es,[h(Jt)])):f("",!0)])):f("",!0),(w=l(r).prev)!=null&&w.link||(C=l(r).next)!=null&&C.link?(a(),i("nav",ts,[c("div",ss,[(I=l(r).prev)!=null&&I.link?(a(),i("a",{key:0,class:"pager-link prev",href:l(J)(l(r).prev.link)},[c("span",{class:"desc",innerHTML:((B=l(e).docFooter)==null?void 0:B.prev)||"Previous page"},null,8,os),c("span",{class:"title",innerHTML:l(r).prev.text},null,8,as)],8,ns)):f("",!0)]),c("div",rs,[(T=l(r).next)!=null&&T.link?(a(),i("a",{key:0,class:"pager-link next",href:l(J)(l(r).next.link)},[c("span",{class:"desc",innerHTML:((V=l(e).docFooter)==null?void 0:V.next)||"Next page"},null,8,is),c("span",{class:"title",innerHTML:l(r).next.text},null,8,cs)],8,ls)):f("",!0)])])):f("",!0)])):f("",!0)}}});const ds=m(us,[["__scopeId","data-v-ef5dee53"]]),_s={},vs={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},ps=c("path",{d:"M9,19c-0.3,0-0.5-0.1-0.7-0.3c-0.4-0.4-0.4-1,0-1.4l5.3-5.3L8.3,6.7c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l6,6c0.4,0.4,0.4,1,0,1.4l-6,6C9.5,18.9,9.3,19,9,19z"},null,-1),hs=[ps];function fs(s,e){return a(),i("svg",vs,hs)}const fe=m(_s,[["render",fs]]),ms={key:0,class:"VPDocOutlineDropdown"},gs={key:0,class:"items"},bs=g({__name:"VPDocOutlineDropdown",setup(s){const{frontmatter:e,theme:t}=P(),n=S(!1);Y(()=>{n.value=!1});const o=_e([]);return Y(()=>{o.value=pe(e.value.outline??t.value.outline)}),(r,d)=>o.value.length>0?(a(),i("div",ms,[c("button",{onClick:d[0]||(d[0]=p=>n.value=!n.value),class:N({open:n.value})},[x(L(l(ve)(l(t)))+" ",1),h(fe,{class:"icon"})],2),n.value?(a(),i("div",gs,[h(he,{headers:o.value},null,8,["headers"])])):f("",!0)])):f("",!0)}});const $s=m(bs,[["__scopeId","data-v-eadfb36b"]]),ks=s=>(H("data-v-6b87e69f"),s=s(),z(),s),ys={class:"container"},Ps=ks(()=>c("div",{class:"aside-curtain"},null,-1)),Vs={class:"aside-container"},ws={class:"aside-content"},Ls={class:"content"},Ss={class:"content-container"},Ms={class:"main"},Ns=g({__name:"VPDoc",setup(s){const{theme:e}=P(),t=se(),{hasSidebar:n,hasAside:o,leftAside:r}=D(),d=k(()=>t.path.replace(/[./]+/g,"_").replace(/_html$/,""));return(p,_)=>{const b=j("Content");return a(),i("div",{class:N(["VPDoc",{"has-sidebar":l(n),"has-aside":l(o)}])},[u(p.$slots,"doc-top",{},void 0,!0),c("div",ys,[l(o)?(a(),i("div",{key:0,class:N(["aside",{"left-aside":l(r)}])},[Ps,c("div",Vs,[c("div",ws,[h(zt,null,{"aside-top":v(()=>[u(p.$slots,"aside-top",{},void 0,!0)]),"aside-bottom":v(()=>[u(p.$slots,"aside-bottom",{},void 0,!0)]),"aside-outline-before":v(()=>[u(p.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(p.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(p.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(p.$slots,"aside-ads-after",{},void 0,!0)]),_:3})])])],2)):f("",!0),c("div",Ls,[c("div",Ss,[u(p.$slots,"doc-before",{},void 0,!0),h($s),c("main",Ms,[h(b,{class:N(["vp-doc",[d.value,l(e).externalLinkIcon&&"external-link-icon-enabled"]])},null,8,["class"])]),h(ds,null,{"doc-footer-before":v(()=>[u(p.$slots,"doc-footer-before",{},void 0,!0)]),_:3}),u(p.$slots,"doc-after",{},void 0,!0)])])]),u(p.$slots,"doc-bottom",{},void 0,!0)],2)}}});const Is=m(Ns,[["__scopeId","data-v-6b87e69f"]]),Cs=g({__name:"VPButton",props:{tag:{},size:{default:"medium"},theme:{default:"brand"},text:{},href:{}},setup(s){const e=s,t=k(()=>e.href&&Ve.test(e.href)),n=k(()=>e.tag||e.href?"a":"button");return(o,r)=>(a(),$(E(n.value),{class:N(["VPButton",[o.size,o.theme]]),href:o.href?l(J)(o.href):void 0,target:t.value?"_blank":void 0,rel:t.value?"noreferrer":void 0},{default:v(()=>[x(L(o.text),1)]),_:1},8,["class","href","target","rel"]))}});const Ts=m(Cs,[["__scopeId","data-v-c1c5efc1"]]),Bs=["src","alt"],As=g({inheritAttrs:!1,__name:"VPImage",props:{image:{},alt:{}},setup(s){return(e,t)=>{const n=j("VPImage",!0);return e.image?(a(),i(M,{key:0},[typeof e.image=="string"||"src"in e.image?(a(),i("img",Q({key:0,class:"VPImage"},typeof e.image=="string"?e.$attrs:{...e.image,...e.$attrs},{src:l(ue)(typeof e.image=="string"?e.image:e.image.src),alt:e.alt??(typeof e.image=="string"?"":e.image.alt||"")}),null,16,Bs)):(a(),i(M,{key:1},[h(n,Q({class:"dark",image:e.image.dark,alt:e.image.alt},e.$attrs),null,16,["image","alt"]),h(n,Q({class:"light",image:e.image.light,alt:e.image.alt},e.$attrs),null,16,["image","alt"])],64))],64)):f("",!0)}}});const ee=m(As,[["__scopeId","data-v-8426fc1a"]]),xs=s=>(H("data-v-da5d1713"),s=s(),z(),s),Hs={class:"container"},zs={class:"main"},Ds={key:0,class:"name"},Fs=["innerHTML"],Es=["innerHTML"],Os=["innerHTML"],Gs={key:0,class:"actions"},Us={key:0,class:"image"},js={class:"image-container"},qs=xs(()=>c("div",{class:"image-bg"},null,-1)),Rs=g({__name:"VPHero",props:{name:{},text:{},tagline:{},image:{},actions:{}},setup(s){const e=ne("hero-image-slot-exists");return(t,n)=>(a(),i("div",{class:N(["VPHero",{"has-image":t.image||l(e)}])},[c("div",Hs,[c("div",zs,[u(t.$slots,"home-hero-info",{},()=>[t.name?(a(),i("h1",Ds,[c("span",{innerHTML:t.name,class:"clip"},null,8,Fs)])):f("",!0),t.text?(a(),i("p",{key:1,innerHTML:t.text,class:"text"},null,8,Es)):f("",!0),t.tagline?(a(),i("p",{key:2,innerHTML:t.tagline,class:"tagline"},null,8,Os)):f("",!0)],!0),t.actions?(a(),i("div",Gs,[(a(!0),i(M,null,A(t.actions,o=>(a(),i("div",{key:o.link,class:"action"},[h(Ts,{tag:"a",size:"medium",theme:o.theme,text:o.text,href:o.link},null,8,["theme","text","href"])]))),128))])):f("",!0)]),t.image||l(e)?(a(),i("div",Us,[c("div",js,[qs,u(t.$slots,"home-hero-image",{},()=>[t.image?(a(),$(ee,{key:0,class:"image-src",image:t.image},null,8,["image"])):f("",!0)],!0)])])):f("",!0)])],2))}});const Ks=m(Rs,[["__scopeId","data-v-da5d1713"]]),Ws=g({__name:"VPHomeHero",setup(s){const{frontmatter:e}=P();return(t,n)=>l(e).hero?(a(),$(Ks,{key:0,class:"VPHomeHero",name:l(e).hero.name,text:l(e).hero.text,tagline:l(e).hero.tagline,image:l(e).hero.image,actions:l(e).hero.actions},{"home-hero-info":v(()=>[u(t.$slots,"home-hero-info")]),"home-hero-image":v(()=>[u(t.$slots,"home-hero-image")]),_:3},8,["name","text","tagline","image","actions"])):f("",!0)}}),Ys={},Js={xmlns:"http://www.w3.org/2000/svg",viewBox:"0 0 24 24"},Zs=c("path",{d:"M19.9,12.4c0.1-0.2,0.1-0.5,0-0.8c-0.1-0.1-0.1-0.2-0.2-0.3l-7-7c-0.4-0.4-1-0.4-1.4,0s-0.4,1,0,1.4l5.3,5.3H5c-0.6,0-1,0.4-1,1s0.4,1,1,1h11.6l-5.3,5.3c-0.4,0.4-0.4,1,0,1.4c0.2,0.2,0.5,0.3,0.7,0.3s0.5-0.1,0.7-0.3l7-7C19.8,12.6,19.9,12.5,19.9,12.4z"},null,-1),Qs=[Zs];function Xs(s,e){return a(),i("svg",Js,Qs)}const en=m(Ys,[["render",Xs]]),tn={class:"box"},sn={key:0,class:"icon"},nn=["innerHTML"],on=["innerHTML"],an=["innerHTML"],rn={key:4,class:"link-text"},ln={class:"link-text-value"},cn=g({__name:"VPFeature",props:{icon:{},title:{},details:{},link:{},linkText:{},rel:{},target:{}},setup(s){return(e,t)=>(a(),$(F,{class:"VPFeature",href:e.link,rel:e.rel,target:e.target,"no-icon":!0,tag:e.link?"a":"div"},{default:v(()=>[c("article",tn,[typeof e.icon=="object"&&e.icon.wrap?(a(),i("div",sn,[h(ee,{image:e.icon,alt:e.icon.alt,height:e.icon.height||48,width:e.icon.width||48},null,8,["image","alt","height","width"])])):typeof e.icon=="object"?(a(),$(ee,{key:1,image:e.icon,alt:e.icon.alt,height:e.icon.height||48,width:e.icon.width||48},null,8,["image","alt","height","width"])):e.icon?(a(),i("div",{key:2,class:"icon",innerHTML:e.icon},null,8,nn)):f("",!0),c("h2",{class:"title",innerHTML:e.title},null,8,on),e.details?(a(),i("p",{key:3,class:"details",innerHTML:e.details},null,8,an)):f("",!0),e.linkText?(a(),i("div",rn,[c("p",ln,[x(L(e.linkText)+" ",1),h(en,{class:"link-text-icon"})])])):f("",!0)])]),_:1},8,["href","rel","target","tag"]))}});const un=m(cn,[["__scopeId","data-v-33204567"]]),dn={key:0,class:"VPFeatures"},_n={class:"container"},vn={class:"items"},pn=g({__name:"VPFeatures",props:{features:{}},setup(s){const e=s,t=k(()=>{const n=e.features.length;if(n){if(n===2)return"grid-2";if(n===3)return"grid-3";if(n%3===0)return"grid-6";if(n>3)return"grid-4"}else return});return(n,o)=>n.features?(a(),i("div",dn,[c("div",_n,[c("div",vn,[(a(!0),i(M,null,A(n.features,r=>(a(),i("div",{key:r.title,class:N(["item",[t.value]])},[h(un,{icon:r.icon,title:r.title,details:r.details,link:r.link,"link-text":r.linkText,rel:r.rel,target:r.target},null,8,["icon","title","details","link","link-text","rel","target"])],2))),128))])])])):f("",!0)}});const hn=m(pn,[["__scopeId","data-v-a6181336"]]),fn=g({__name:"VPHomeFeatures",setup(s){const{frontmatter:e}=P();return(t,n)=>l(e).features?(a(),$(hn,{key:0,class:"VPHomeFeatures",features:l(e).features},null,8,["features"])):f("",!0)}}),mn={class:"VPHome"},gn=g({__name:"VPHome",setup(s){return(e,t)=>{const n=j("Content");return a(),i("div",mn,[u(e.$slots,"home-hero-before",{},void 0,!0),h(Ws,null,{"home-hero-info":v(()=>[u(e.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(e.$slots,"home-hero-image",{},void 0,!0)]),_:3}),u(e.$slots,"home-hero-after",{},void 0,!0),u(e.$slots,"home-features-before",{},void 0,!0),h(fn),u(e.$slots,"home-features-after",{},void 0,!0),h(n)])}}});const bn=m(gn,[["__scopeId","data-v-d82743a8"]]),$n={},kn={class:"VPPage"};function yn(s,e){const t=j("Content");return a(),i("div",kn,[u(s.$slots,"page-top"),h(t),u(s.$slots,"page-bottom")])}const Pn=m($n,[["render",yn]]),Vn=g({__name:"VPContent",setup(s){const{page:e,frontmatter:t}=P(),{hasSidebar:n}=D();return(o,r)=>(a(),i("div",{class:N(["VPContent",{"has-sidebar":l(n),"is-home":l(t).layout==="home"}]),id:"VPContent"},[l(e).isNotFound?u(o.$slots,"not-found",{key:0},()=>[h(dt)],!0):l(t).layout==="page"?(a(),$(Pn,{key:1},{"page-top":v(()=>[u(o.$slots,"page-top",{},void 0,!0)]),"page-bottom":v(()=>[u(o.$slots,"page-bottom",{},void 0,!0)]),_:3})):l(t).layout==="home"?(a(),$(bn,{key:2},{"home-hero-before":v(()=>[u(o.$slots,"home-hero-before",{},void 0,!0)]),"home-hero-info":v(()=>[u(o.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(o.$slots,"home-hero-image",{},void 0,!0)]),"home-hero-after":v(()=>[u(o.$slots,"home-hero-after",{},void 0,!0)]),"home-features-before":v(()=>[u(o.$slots,"home-features-before",{},void 0,!0)]),"home-features-after":v(()=>[u(o.$slots,"home-features-after",{},void 0,!0)]),_:3})):l(t).layout&&l(t).layout!=="doc"?(a(),$(E(l(t).layout),{key:3})):(a(),$(Is,{key:4},{"doc-top":v(()=>[u(o.$slots,"doc-top",{},void 0,!0)]),"doc-bottom":v(()=>[u(o.$slots,"doc-bottom",{},void 0,!0)]),"doc-footer-before":v(()=>[u(o.$slots,"doc-footer-before",{},void 0,!0)]),"doc-before":v(()=>[u(o.$slots,"doc-before",{},void 0,!0)]),"doc-after":v(()=>[u(o.$slots,"doc-after",{},void 0,!0)]),"aside-top":v(()=>[u(o.$slots,"aside-top",{},void 0,!0)]),"aside-outline-before":v(()=>[u(o.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(o.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(o.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(o.$slots,"aside-ads-after",{},void 0,!0)]),"aside-bottom":v(()=>[u(o.$slots,"aside-bottom",{},void 0,!0)]),_:3}))],2))}});const wn=m(Vn,[["__scopeId","data-v-669faec9"]]),Ln={class:"container"},Sn=["innerHTML"],Mn=["innerHTML"],Nn=g({__name:"VPFooter",setup(s){const{theme:e,frontmatter:t}=P(),{hasSidebar:n}=D();return(o,r)=>l(e).footer&&l(t).footer!==!1?(a(),i("footer",{key:0,class:N(["VPFooter",{"has-sidebar":l(n)}])},[c("div",Ln,[l(e).footer.message?(a(),i("p",{key:0,class:"message",innerHTML:l(e).footer.message},null,8,Sn)):f("",!0),l(e).footer.copyright?(a(),i("p",{key:1,class:"copyright",innerHTML:l(e).footer.copyright},null,8,Mn)):f("",!0)])],2)):f("",!0)}});const In=m(Nn,[["__scopeId","data-v-e03eb2e1"]]),Cn={class:"header"},Tn={class:"outline"},Bn=g({__name:"VPLocalNavOutlineDropdown",props:{headers:{},navHeight:{}},setup(s){const e=s,{theme:t}=P(),n=S(!1),o=S(0),r=S();Y(()=>{n.value=!1});function d(){n.value=!n.value,o.value=window.innerHeight+Math.min(window.scrollY-e.navHeight,0)}function p(b){b.target.classList.contains("outline-link")&&(r.value&&(r.value.style.transition="none"),Ee(()=>{n.value=!1}))}function _(){n.value=!1,window.scrollTo({top:0,left:0,behavior:"smooth"})}return(b,y)=>(a(),i("div",{class:"VPLocalNavOutlineDropdown",style:Fe({"--vp-vh":o.value+"px"})},[b.headers.length>0?(a(),i("button",{key:0,onClick:d,class:N({open:n.value})},[x(L(l(ve)(l(t)))+" ",1),h(fe,{class:"icon"})],2)):(a(),i("button",{key:1,onClick:_},L(l(t).returnToTopLabel||"Return to top"),1)),h(ce,{name:"flyout"},{default:v(()=>[n.value?(a(),i("div",{key:0,ref_key:"items",ref:r,class:"items",onClick:p},[c("div",Cn,[c("a",{class:"top-link",href:"#",onClick:_},L(l(t).returnToTopLabel||"Return to top"),1)]),c("div",Tn,[h(he,{headers:b.headers},null,8,["headers"])])],512)):f("",!0)]),_:1})],4))}});const An=m(Bn,[["__scopeId","data-v-1c15a60a"]]),xn={},Hn={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},zn=c("path",{d:"M17,11H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h14c0.6,0,1,0.4,1,1S17.6,11,17,11z"},null,-1),Dn=c("path",{d:"M21,7H3C2.4,7,2,6.6,2,6s0.4-1,1-1h18c0.6,0,1,0.4,1,1S21.6,7,21,7z"},null,-1),Fn=c("path",{d:"M21,15H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h18c0.6,0,1,0.4,1,1S21.6,15,21,15z"},null,-1),En=c("path",{d:"M17,19H3c-0.6,0-1-0.4-1-1s0.4-1,1-1h14c0.6,0,1,0.4,1,1S17.6,19,17,19z"},null,-1),On=[zn,Dn,Fn,En];function Gn(s,e){return a(),i("svg",Hn,On)}const Un=m(xn,[["render",Gn]]),jn=["aria-expanded"],qn={class:"menu-text"},Rn=g({__name:"VPLocalNav",props:{open:{type:Boolean}},emits:["open-menu"],setup(s){const{theme:e,frontmatter:t}=P(),{hasSidebar:n}=D(),{y:o}=we(),r=_e([]),d=S(0);G(()=>{d.value=parseInt(getComputedStyle(document.documentElement).getPropertyValue("--vp-nav-height"))}),Y(()=>{r.value=pe(t.value.outline??e.value.outline)});const p=k(()=>r.value.length===0&&!n.value),_=k(()=>({VPLocalNav:!0,fixed:p.value,"reached-top":o.value>=d.value}));return(b,y)=>l(t).layout!=="home"&&(!p.value||l(o)>=d.value)?(a(),i("div",{key:0,class:N(_.value)},[l(n)?(a(),i("button",{key:0,class:"menu","aria-expanded":b.open,"aria-controls":"VPSidebarNav",onClick:y[0]||(y[0]=w=>b.$emit("open-menu"))},[h(Un,{class:"menu-icon"}),c("span",qn,L(l(e).sidebarMenuLabel||"Menu"),1)],8,jn)):f("",!0),h(An,{headers:r.value,navHeight:d.value},null,8,["headers","navHeight"])],2)):f("",!0)}});const Kn=m(Rn,[["__scopeId","data-v-79c8c1df"]]);function Wn(){const s=S(!1);function e(){s.value=!0,window.addEventListener("resize",o)}function t(){s.value=!1,window.removeEventListener("resize",o)}function n(){s.value?t():e()}function o(){window.outerWidth>=768&&t()}const r=se();return U(()=>r.path,t),{isScreenOpen:s,openScreen:e,closeScreen:t,toggleScreen:n}}const Yn={},Jn={class:"VPSwitch",type:"button",role:"switch"},Zn={class:"check"},Qn={key:0,class:"icon"};function Xn(s,e){return a(),i("button",Jn,[c("span",Zn,[s.$slots.default?(a(),i("span",Qn,[u(s.$slots,"default",{},void 0,!0)])):f("",!0)])])}const eo=m(Yn,[["render",Xn],["__scopeId","data-v-b1685198"]]),to={},so={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},no=c("path",{d:"M12.1,22c-0.3,0-0.6,0-0.9,0c-5.5-0.5-9.5-5.4-9-10.9c0.4-4.8,4.2-8.6,9-9c0.4,0,0.8,0.2,1,0.5c0.2,0.3,0.2,0.8-0.1,1.1c-2,2.7-1.4,6.4,1.3,8.4c2.1,1.6,5,1.6,7.1,0c0.3-0.2,0.7-0.3,1.1-0.1c0.3,0.2,0.5,0.6,0.5,1c-0.2,2.7-1.5,5.1-3.6,6.8C16.6,21.2,14.4,22,12.1,22zM9.3,4.4c-2.9,1-5,3.6-5.2,6.8c-0.4,4.4,2.8,8.3,7.2,8.7c2.1,0.2,4.2-0.4,5.8-1.8c1.1-0.9,1.9-2.1,2.4-3.4c-2.5,0.9-5.3,0.5-7.5-1.1C9.2,11.4,8.1,7.7,9.3,4.4z"},null,-1),oo=[no];function ao(s,e){return a(),i("svg",so,oo)}const ro=m(to,[["render",ao]]),lo={},io={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},co=Oe('',9),uo=[co];function _o(s,e){return a(),i("svg",io,uo)}const vo=m(lo,[["render",_o]]),po=g({__name:"VPSwitchAppearance",setup(s){const{isDark:e}=P(),t=ne("toggle-appearance",()=>{e.value=!e.value});return(n,o)=>(a(),$(eo,{title:"toggle dark mode",class:"VPSwitchAppearance","aria-checked":l(e),onClick:l(t)},{default:v(()=>[h(vo,{class:"sun"}),h(ro,{class:"moon"})]),_:1},8,["aria-checked","onClick"]))}});const me=m(po,[["__scopeId","data-v-ce54a7d1"]]),ho={key:0,class:"VPNavBarAppearance"},fo=g({__name:"VPNavBarAppearance",setup(s){const{site:e}=P();return(t,n)=>l(e).appearance&&l(e).appearance!=="force-dark"?(a(),i("div",ho,[h(me)])):f("",!0)}});const mo=m(fo,[["__scopeId","data-v-e6aabb21"]]),ge=S();let Ie=!1,ae=0;function go(s){const e=S(!1);if(K){!Ie&&bo(),ae++;const t=U(ge,n=>{var o,r,d;n===s.el.value||(o=s.el.value)!=null&&o.contains(n)?(e.value=!0,(r=s.onFocus)==null||r.call(s)):(e.value=!1,(d=s.onBlur)==null||d.call(s))});de(()=>{t(),ae--,ae||$o()})}return Ge(e)}function bo(){document.addEventListener("focusin",Ce),Ie=!0,ge.value=document.activeElement}function $o(){document.removeEventListener("focusin",Ce)}function Ce(){ge.value=document.activeElement}const ko={},yo={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Po=c("path",{d:"M12,16c-0.3,0-0.5-0.1-0.7-0.3l-6-6c-0.4-0.4-0.4-1,0-1.4s1-0.4,1.4,0l5.3,5.3l5.3-5.3c0.4-0.4,1-0.4,1.4,0s0.4,1,0,1.4l-6,6C12.5,15.9,12.3,16,12,16z"},null,-1),Vo=[Po];function wo(s,e){return a(),i("svg",yo,Vo)}const Te=m(ko,[["render",wo]]),Lo={},So={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Mo=c("circle",{cx:"12",cy:"12",r:"2"},null,-1),No=c("circle",{cx:"19",cy:"12",r:"2"},null,-1),Io=c("circle",{cx:"5",cy:"12",r:"2"},null,-1),Co=[Mo,No,Io];function To(s,e){return a(),i("svg",So,Co)}const Bo=m(Lo,[["render",To]]),Ao={class:"VPMenuLink"},xo=g({__name:"VPMenuLink",props:{item:{}},setup(s){const{page:e}=P();return(t,n)=>(a(),i("div",Ao,[h(F,{class:N({active:l(O)(l(e).relativePath,t.item.activeMatch||t.item.link,!!t.item.activeMatch)}),href:t.item.link,target:t.item.target,rel:t.item.rel},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["class","href","target","rel"])]))}});const oe=m(xo,[["__scopeId","data-v-43f1e123"]]),Ho={class:"VPMenuGroup"},zo={key:0,class:"title"},Do=g({__name:"VPMenuGroup",props:{text:{},items:{}},setup(s){return(e,t)=>(a(),i("div",Ho,[e.text?(a(),i("p",zo,L(e.text),1)):f("",!0),(a(!0),i(M,null,A(e.items,n=>(a(),i(M,null,["link"in n?(a(),$(oe,{key:0,item:n},null,8,["item"])):f("",!0)],64))),256))]))}});const Fo=m(Do,[["__scopeId","data-v-69e747b5"]]),Eo={class:"VPMenu"},Oo={key:0,class:"items"},Go=g({__name:"VPMenu",props:{items:{}},setup(s){return(e,t)=>(a(),i("div",Eo,[e.items?(a(),i("div",Oo,[(a(!0),i(M,null,A(e.items,n=>(a(),i(M,{key:n.text},["link"in n?(a(),$(oe,{key:0,item:n},null,8,["item"])):(a(),$(Fo,{key:1,text:n.text,items:n.items},null,8,["text","items"]))],64))),128))])):f("",!0),u(e.$slots,"default",{},void 0,!0)]))}});const Uo=m(Go,[["__scopeId","data-v-e7ea1737"]]),jo=["aria-expanded","aria-label"],qo={key:0,class:"text"},Ro=["innerHTML"],Ko={class:"menu"},Wo=g({__name:"VPFlyout",props:{icon:{},button:{},label:{},items:{}},setup(s){const e=S(!1),t=S();go({el:t,onBlur:n});function n(){e.value=!1}return(o,r)=>(a(),i("div",{class:"VPFlyout",ref_key:"el",ref:t,onMouseenter:r[1]||(r[1]=d=>e.value=!0),onMouseleave:r[2]||(r[2]=d=>e.value=!1)},[c("button",{type:"button",class:"button","aria-haspopup":"true","aria-expanded":e.value,"aria-label":o.label,onClick:r[0]||(r[0]=d=>e.value=!e.value)},[o.button||o.icon?(a(),i("span",qo,[o.icon?(a(),$(E(o.icon),{key:0,class:"option-icon"})):f("",!0),o.button?(a(),i("span",{key:1,innerHTML:o.button},null,8,Ro)):f("",!0),h(Te,{class:"text-icon"})])):(a(),$(Bo,{key:1,class:"icon"}))],8,jo),c("div",Ko,[h(Uo,{items:o.items},{default:v(()=>[u(o.$slots,"default",{},void 0,!0)]),_:3},8,["items"])])],544))}});const be=m(Wo,[["__scopeId","data-v-9c007e85"]]),Yo={discord:'Discord',facebook:'Facebook',github:'GitHub',instagram:'Instagram',linkedin:'LinkedIn',mastodon:'Mastodon',slack:'Slack',twitter:'Twitter',x:'X',youtube:'YouTube'},Jo=["href","aria-label","innerHTML"],Zo=g({__name:"VPSocialLink",props:{icon:{},link:{},ariaLabel:{}},setup(s){const e=s,t=k(()=>typeof e.icon=="object"?e.icon.svg:Yo[e.icon]);return(n,o)=>(a(),i("a",{class:"VPSocialLink no-icon",href:n.link,"aria-label":n.ariaLabel??(typeof n.icon=="string"?n.icon:""),target:"_blank",rel:"noopener",innerHTML:t.value},null,8,Jo))}});const Qo=m(Zo,[["__scopeId","data-v-f80f8133"]]),Xo={class:"VPSocialLinks"},ea=g({__name:"VPSocialLinks",props:{links:{}},setup(s){return(e,t)=>(a(),i("div",Xo,[(a(!0),i(M,null,A(e.links,({link:n,icon:o,ariaLabel:r})=>(a(),$(Qo,{key:n,icon:o,link:n,ariaLabel:r},null,8,["icon","link","ariaLabel"]))),128))]))}});const $e=m(ea,[["__scopeId","data-v-7bc22406"]]),ta={key:0,class:"group translations"},sa={class:"trans-title"},na={key:1,class:"group"},oa={class:"item appearance"},aa={class:"label"},ra={class:"appearance-action"},la={key:2,class:"group"},ia={class:"item social-links"},ca=g({__name:"VPNavBarExtra",setup(s){const{site:e,theme:t}=P(),{localeLinks:n,currentLang:o}=Z({correspondingLink:!0}),r=k(()=>n.value.length&&o.value.label||e.value.appearance||t.value.socialLinks);return(d,p)=>r.value?(a(),$(be,{key:0,class:"VPNavBarExtra",label:"extra navigation"},{default:v(()=>[l(n).length&&l(o).label?(a(),i("div",ta,[c("p",sa,L(l(o).label),1),(a(!0),i(M,null,A(l(n),_=>(a(),$(oe,{key:_.link,item:_},null,8,["item"]))),128))])):f("",!0),l(e).appearance?(a(),i("div",na,[c("div",oa,[c("p",aa,L(l(t).darkModeSwitchLabel||"Appearance"),1),c("div",ra,[h(me)])])])):f("",!0),l(t).socialLinks?(a(),i("div",la,[c("div",ia,[h($e,{class:"social-links-list",links:l(t).socialLinks},null,8,["links"])])])):f("",!0)]),_:1})):f("",!0)}});const ua=m(ca,[["__scopeId","data-v-40855f84"]]),da=s=>(H("data-v-e5dd9c1c"),s=s(),z(),s),_a=["aria-expanded"],va=da(()=>c("span",{class:"container"},[c("span",{class:"top"}),c("span",{class:"middle"}),c("span",{class:"bottom"})],-1)),pa=[va],ha=g({__name:"VPNavBarHamburger",props:{active:{type:Boolean}},emits:["click"],setup(s){return(e,t)=>(a(),i("button",{type:"button",class:N(["VPNavBarHamburger",{active:e.active}]),"aria-label":"mobile navigation","aria-expanded":e.active,"aria-controls":"VPNavScreen",onClick:t[0]||(t[0]=n=>e.$emit("click"))},pa,10,_a))}});const fa=m(ha,[["__scopeId","data-v-e5dd9c1c"]]),ma=["innerHTML"],ga=g({__name:"VPNavBarMenuLink",props:{item:{}},setup(s){const{page:e}=P();return(t,n)=>(a(),$(F,{class:N({VPNavBarMenuLink:!0,active:l(O)(l(e).relativePath,t.item.activeMatch||t.item.link,!!t.item.activeMatch)}),href:t.item.link,target:t.item.target,rel:t.item.rel,tabindex:"0"},{default:v(()=>[c("span",{innerHTML:t.item.text},null,8,ma)]),_:1},8,["class","href","target","rel"]))}});const ba=m(ga,[["__scopeId","data-v-42ef59de"]]),$a=g({__name:"VPNavBarMenuGroup",props:{item:{}},setup(s){const e=s,{page:t}=P(),n=r=>"link"in r?O(t.value.relativePath,r.link,!!e.item.activeMatch):r.items.some(n),o=k(()=>n(e.item));return(r,d)=>(a(),$(be,{class:N({VPNavBarMenuGroup:!0,active:l(O)(l(t).relativePath,r.item.activeMatch,!!r.item.activeMatch)||o.value}),button:r.item.text,items:r.item.items},null,8,["class","button","items"]))}}),ka=s=>(H("data-v-7f418b0f"),s=s(),z(),s),ya={key:0,"aria-labelledby":"main-nav-aria-label",class:"VPNavBarMenu"},Pa=ka(()=>c("span",{id:"main-nav-aria-label",class:"visually-hidden"},"Main Navigation",-1)),Va=g({__name:"VPNavBarMenu",setup(s){const{theme:e}=P();return(t,n)=>l(e).nav?(a(),i("nav",ya,[Pa,(a(!0),i(M,null,A(l(e).nav,o=>(a(),i(M,{key:o.text},["link"in o?(a(),$(ba,{key:0,item:o},null,8,["item"])):(a(),$($a,{key:1,item:o},null,8,["item"]))],64))),128))])):f("",!0)}});const wa=m(Va,[["__scopeId","data-v-7f418b0f"]]);function La(s,e){const{localeIndex:t}=P();function n(o){var I,B;const r=o.split("."),d=s&&typeof s=="object",p=d&&((B=(I=s.locales)==null?void 0:I[t.value])==null?void 0:B.translations)||null,_=d&&s.translations||null;let b=p,y=_,w=e;const C=r.pop();for(const T of r){let V=null;const q=w==null?void 0:w[T];q&&(V=w=q);const W=y==null?void 0:y[T];W&&(V=y=W);const R=b==null?void 0:b[T];R&&(V=b=R),q||(w=V),W||(y=V),R||(b=V)}return(b==null?void 0:b[C])??(y==null?void 0:y[C])??(w==null?void 0:w[C])??""}return n}const Sa=["aria-label"],Ma={class:"DocSearch-Button-Container"},Na=c("svg",{class:"DocSearch-Search-Icon",width:"20",height:"20",viewBox:"0 0 20 20","aria-label":"search icon"},[c("path",{d:"M14.386 14.386l4.0877 4.0877-4.0877-4.0877c-2.9418 2.9419-7.7115 2.9419-10.6533 0-2.9419-2.9418-2.9419-7.7115 0-10.6533 2.9418-2.9419 7.7115-2.9419 10.6533 0 2.9419 2.9418 2.9419 7.7115 0 10.6533z",stroke:"currentColor",fill:"none","fill-rule":"evenodd","stroke-linecap":"round","stroke-linejoin":"round"})],-1),Ia={class:"DocSearch-Button-Placeholder"},Ca=c("span",{class:"DocSearch-Button-Keys"},[c("kbd",{class:"DocSearch-Button-Key"}),c("kbd",{class:"DocSearch-Button-Key"},"K")],-1),ye=g({__name:"VPNavBarSearchButton",setup(s){const{theme:e}=P(),t={button:{buttonText:"Search",buttonAriaLabel:"Search"}},n=Ue(La)(je(()=>{var o;return(o=e.value.search)==null?void 0:o.options}),t);return(o,r)=>(a(),i("button",{type:"button",class:"DocSearch DocSearch-Button","aria-label":l(n)("button.buttonAriaLabel")},[c("span",Ma,[Na,c("span",Ia,L(l(n)("button.buttonText")),1)]),Ca],8,Sa))}});const Ta={class:"VPNavBarSearch"},Ba={id:"local-search"},Aa={key:1,id:"docsearch"},xa=g({__name:"VPNavBarSearch",setup(s){const e=()=>null,t=()=>null,{theme:n}=P(),o=S(!1),r=S(!1);G(()=>{});function d(){o.value||(o.value=!0,setTimeout(p,16))}function p(){const y=new Event("keydown");y.key="k",y.metaKey=!0,window.dispatchEvent(y),setTimeout(()=>{document.querySelector(".DocSearch-Modal")||p()},16)}const _=S(!1),b="";return(y,w)=>{var C;return a(),i("div",Ta,[l(b)==="local"?(a(),i(M,{key:0},[_.value?(a(),$(l(e),{key:0,onClose:w[0]||(w[0]=I=>_.value=!1)})):f("",!0),c("div",Ba,[h(ye,{onClick:w[1]||(w[1]=I=>_.value=!0)})])],64)):l(b)==="algolia"?(a(),i(M,{key:1},[o.value?(a(),$(l(t),{key:0,algolia:((C=l(n).search)==null?void 0:C.options)??l(n).algolia,onVnodeBeforeMount:w[2]||(w[2]=I=>r.value=!0)},null,8,["algolia"])):f("",!0),r.value?f("",!0):(a(),i("div",Aa,[h(ye,{onClick:d})]))],64)):f("",!0)])}}});const Ha=g({__name:"VPNavBarSocialLinks",setup(s){const{theme:e}=P();return(t,n)=>l(e).socialLinks?(a(),$($e,{key:0,class:"VPNavBarSocialLinks",links:l(e).socialLinks},null,8,["links"])):f("",!0)}});const za=m(Ha,[["__scopeId","data-v-0394ad82"]]),Da=["href"],Fa=g({__name:"VPNavBarTitle",setup(s){const{site:e,theme:t}=P(),{hasSidebar:n}=D(),{currentLang:o}=Z();return(r,d)=>(a(),i("div",{class:N(["VPNavBarTitle",{"has-sidebar":l(n)}])},[c("a",{class:"title",href:l(t).logoLink??l(J)(l(o).link)},[u(r.$slots,"nav-bar-title-before",{},void 0,!0),l(t).logo?(a(),$(ee,{key:0,class:"logo",image:l(t).logo},null,8,["image"])):f("",!0),l(t).siteTitle?(a(),i(M,{key:1},[x(L(l(t).siteTitle),1)],64)):l(t).siteTitle===void 0?(a(),i(M,{key:2},[x(L(l(e).title),1)],64)):f("",!0),u(r.$slots,"nav-bar-title-after",{},void 0,!0)],8,Da)],2))}});const Ea=m(Fa,[["__scopeId","data-v-86d1bed8"]]),Oa={},Ga={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},Ua=c("path",{d:"M0 0h24v24H0z",fill:"none"},null,-1),ja=c("path",{d:" M12.87 15.07l-2.54-2.51.03-.03c1.74-1.94 2.98-4.17 3.71-6.53H17V4h-7V2H8v2H1v1.99h11.17C11.5 7.92 10.44 9.75 9 11.35 8.07 10.32 7.3 9.19 6.69 8h-2c.73 1.63 1.73 3.17 2.98 4.56l-5.09 5.02L4 19l5-5 3.11 3.11.76-2.04zM18.5 10h-2L12 22h2l1.12-3h4.75L21 22h2l-4.5-12zm-2.62 7l1.62-4.33L19.12 17h-3.24z ",class:"css-c4d79v"},null,-1),qa=[Ua,ja];function Ra(s,e){return a(),i("svg",Ga,qa)}const Be=m(Oa,[["render",Ra]]),Ka={class:"items"},Wa={class:"title"},Ya=g({__name:"VPNavBarTranslations",setup(s){const{theme:e}=P(),{localeLinks:t,currentLang:n}=Z({correspondingLink:!0});return(o,r)=>l(t).length&&l(n).label?(a(),$(be,{key:0,class:"VPNavBarTranslations",icon:Be,label:l(e).langMenuLabel||"Change language"},{default:v(()=>[c("div",Ka,[c("p",Wa,L(l(n).label),1),(a(!0),i(M,null,A(l(t),d=>(a(),$(oe,{key:d.link,item:d},null,8,["item"]))),128))])]),_:1},8,["label"])):f("",!0)}});const Ja=m(Ya,[["__scopeId","data-v-74abcbb9"]]),Za=s=>(H("data-v-a0fd61f4"),s=s(),z(),s),Qa={class:"container"},Xa={class:"title"},er={class:"content"},tr=Za(()=>c("div",{class:"curtain"},null,-1)),sr={class:"content-body"},nr=g({__name:"VPNavBar",props:{isScreenOpen:{type:Boolean}},emits:["toggle-screen"],setup(s){const{y:e}=we(),{hasSidebar:t}=D(),{frontmatter:n}=P(),o=S({});return Pe(()=>{o.value={"has-sidebar":t.value,top:n.value.layout==="home"&&e.value===0}}),(r,d)=>(a(),i("div",{class:N(["VPNavBar",o.value])},[c("div",Qa,[c("div",Xa,[h(Ea,null,{"nav-bar-title-before":v(()=>[u(r.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(r.$slots,"nav-bar-title-after",{},void 0,!0)]),_:3})]),c("div",er,[tr,c("div",sr,[u(r.$slots,"nav-bar-content-before",{},void 0,!0),h(xa,{class:"search"}),h(wa,{class:"menu"}),h(Ja,{class:"translations"}),h(mo,{class:"appearance"}),h(za,{class:"social-links"}),h(ua,{class:"extra"}),u(r.$slots,"nav-bar-content-after",{},void 0,!0),h(fa,{class:"hamburger",active:r.isScreenOpen,onClick:d[0]||(d[0]=p=>r.$emit("toggle-screen"))},null,8,["active"])])])])],2))}});const or=m(nr,[["__scopeId","data-v-a0fd61f4"]]),ar={key:0,class:"VPNavScreenAppearance"},rr={class:"text"},lr=g({__name:"VPNavScreenAppearance",setup(s){const{site:e,theme:t}=P();return(n,o)=>l(e).appearance?(a(),i("div",ar,[c("p",rr,L(l(t).darkModeSwitchLabel||"Appearance"),1),h(me)])):f("",!0)}});const ir=m(lr,[["__scopeId","data-v-add8f686"]]),cr=g({__name:"VPNavScreenMenuLink",props:{item:{}},setup(s){const e=ne("close-screen");return(t,n)=>(a(),$(F,{class:"VPNavScreenMenuLink",href:t.item.link,target:t.item.target,rel:t.item.rel,onClick:l(e)},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["href","target","rel","onClick"]))}});const ur=m(cr,[["__scopeId","data-v-05f27b2a"]]),dr={},_r={xmlns:"http://www.w3.org/2000/svg","aria-hidden":"true",focusable:"false",viewBox:"0 0 24 24"},vr=c("path",{d:"M18.9,10.9h-6v-6c0-0.6-0.4-1-1-1s-1,0.4-1,1v6h-6c-0.6,0-1,0.4-1,1s0.4,1,1,1h6v6c0,0.6,0.4,1,1,1s1-0.4,1-1v-6h6c0.6,0,1-0.4,1-1S19.5,10.9,18.9,10.9z"},null,-1),pr=[vr];function hr(s,e){return a(),i("svg",_r,pr)}const fr=m(dr,[["render",hr]]),mr=g({__name:"VPNavScreenMenuGroupLink",props:{item:{}},setup(s){const e=ne("close-screen");return(t,n)=>(a(),$(F,{class:"VPNavScreenMenuGroupLink",href:t.item.link,target:t.item.target,rel:t.item.rel,onClick:l(e)},{default:v(()=>[x(L(t.item.text),1)]),_:1},8,["href","target","rel","onClick"]))}});const Ae=m(mr,[["__scopeId","data-v-19976ae1"]]),gr={class:"VPNavScreenMenuGroupSection"},br={key:0,class:"title"},$r=g({__name:"VPNavScreenMenuGroupSection",props:{text:{},items:{}},setup(s){return(e,t)=>(a(),i("div",gr,[e.text?(a(),i("p",br,L(e.text),1)):f("",!0),(a(!0),i(M,null,A(e.items,n=>(a(),$(Ae,{key:n.text,item:n},null,8,["item"]))),128))]))}});const kr=m($r,[["__scopeId","data-v-8133b170"]]),yr=["aria-controls","aria-expanded"],Pr={class:"button-text"},Vr=["id"],wr={key:1,class:"group"},Lr=g({__name:"VPNavScreenMenuGroup",props:{text:{},items:{}},setup(s){const e=s,t=S(!1),n=k(()=>`NavScreenGroup-${e.text.replace(" ","-").toLowerCase()}`);function o(){t.value=!t.value}return(r,d)=>(a(),i("div",{class:N(["VPNavScreenMenuGroup",{open:t.value}])},[c("button",{class:"button","aria-controls":n.value,"aria-expanded":t.value,onClick:o},[c("span",Pr,L(r.text),1),h(fr,{class:"button-icon"})],8,yr),c("div",{id:n.value,class:"items"},[(a(!0),i(M,null,A(r.items,p=>(a(),i(M,{key:p.text},["link"in p?(a(),i("div",{key:p.text,class:"item"},[h(Ae,{item:p},null,8,["item"])])):(a(),i("div",wr,[h(kr,{text:p.text,items:p.items},null,8,["text","items"])]))],64))),128))],8,Vr)],2))}});const Sr=m(Lr,[["__scopeId","data-v-1ecb84e7"]]),Mr={key:0,class:"VPNavScreenMenu"},Nr=g({__name:"VPNavScreenMenu",setup(s){const{theme:e}=P();return(t,n)=>l(e).nav?(a(),i("nav",Mr,[(a(!0),i(M,null,A(l(e).nav,o=>(a(),i(M,{key:o.text},["link"in o?(a(),$(ur,{key:0,item:o},null,8,["item"])):(a(),$(Sr,{key:1,text:o.text||"",items:o.items},null,8,["text","items"]))],64))),128))])):f("",!0)}}),Ir=g({__name:"VPNavScreenSocialLinks",setup(s){const{theme:e}=P();return(t,n)=>l(e).socialLinks?(a(),$($e,{key:0,class:"VPNavScreenSocialLinks",links:l(e).socialLinks},null,8,["links"])):f("",!0)}}),Cr={class:"list"},Tr=g({__name:"VPNavScreenTranslations",setup(s){const{localeLinks:e,currentLang:t}=Z({correspondingLink:!0}),n=S(!1);function o(){n.value=!n.value}return(r,d)=>l(e).length&&l(t).label?(a(),i("div",{key:0,class:N(["VPNavScreenTranslations",{open:n.value}])},[c("button",{class:"title",onClick:o},[h(Be,{class:"icon lang"}),x(" "+L(l(t).label)+" ",1),h(Te,{class:"icon chevron"})]),c("ul",Cr,[(a(!0),i(M,null,A(l(e),p=>(a(),i("li",{key:p.link,class:"item"},[h(F,{class:"link",href:p.link},{default:v(()=>[x(L(p.text),1)]),_:2},1032,["href"])]))),128))])],2)):f("",!0)}});const Br=m(Tr,[["__scopeId","data-v-d72aa483"]]),Ar={class:"container"},xr=g({__name:"VPNavScreen",props:{open:{type:Boolean}},setup(s){const e=S(null),t=Le(K?document.body:null);return(n,o)=>(a(),$(ce,{name:"fade",onEnter:o[0]||(o[0]=r=>t.value=!0),onAfterLeave:o[1]||(o[1]=r=>t.value=!1)},{default:v(()=>[n.open?(a(),i("div",{key:0,class:"VPNavScreen",ref_key:"screen",ref:e,id:"VPNavScreen"},[c("div",Ar,[u(n.$slots,"nav-screen-content-before",{},void 0,!0),h(Nr,{class:"menu"}),h(Br,{class:"translations"}),h(ir,{class:"appearance"}),h(Ir,{class:"social-links"}),u(n.$slots,"nav-screen-content-after",{},void 0,!0)])],512)):f("",!0)]),_:3}))}});const Hr=m(xr,[["__scopeId","data-v-cc5739dd"]]),zr={key:0,class:"VPNav"},Dr=g({__name:"VPNav",setup(s){const{isScreenOpen:e,closeScreen:t,toggleScreen:n}=Wn(),{frontmatter:o}=P(),r=k(()=>o.value.navbar!==!1);return Se("close-screen",t),te(()=>{K&&document.documentElement.classList.toggle("hide-nav",!r.value)}),(d,p)=>r.value?(a(),i("header",zr,[h(or,{"is-screen-open":l(e),onToggleScreen:l(n)},{"nav-bar-title-before":v(()=>[u(d.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(d.$slots,"nav-bar-title-after",{},void 0,!0)]),"nav-bar-content-before":v(()=>[u(d.$slots,"nav-bar-content-before",{},void 0,!0)]),"nav-bar-content-after":v(()=>[u(d.$slots,"nav-bar-content-after",{},void 0,!0)]),_:3},8,["is-screen-open","onToggleScreen"]),h(Hr,{open:l(e)},{"nav-screen-content-before":v(()=>[u(d.$slots,"nav-screen-content-before",{},void 0,!0)]),"nav-screen-content-after":v(()=>[u(d.$slots,"nav-screen-content-after",{},void 0,!0)]),_:3},8,["open"])])):f("",!0)}});const Fr=m(Dr,[["__scopeId","data-v-ae24b3ad"]]),Er=s=>(H("data-v-e31bd47b"),s=s(),z(),s),Or=["role","tabindex"],Gr=Er(()=>c("div",{class:"indicator"},null,-1)),Ur=["onKeydown"],jr={key:1,class:"items"},qr=g({__name:"VPSidebarItem",props:{item:{},depth:{}},setup(s){const e=s,{collapsed:t,collapsible:n,isLink:o,isActiveLink:r,hasActiveLink:d,hasChildren:p,toggle:_}=ht(k(()=>e.item)),b=k(()=>p.value?"section":"div"),y=k(()=>o.value?"a":"div"),w=k(()=>p.value?e.depth+2===7?"p":`h${e.depth+2}`:"p"),C=k(()=>o.value?void 0:"button"),I=k(()=>[[`level-${e.depth}`],{collapsible:n.value},{collapsed:t.value},{"is-link":o.value},{"is-active":r.value},{"has-active":d.value}]);function B(V){"key"in V&&V.key!=="Enter"||!e.item.link&&_()}function T(){e.item.link&&_()}return(V,q)=>{const W=j("VPSidebarItem",!0);return a(),$(E(b.value),{class:N(["VPSidebarItem",I.value])},{default:v(()=>[V.item.text?(a(),i("div",Q({key:0,class:"item",role:C.value},Re(V.item.items?{click:B,keydown:B}:{},!0),{tabindex:V.item.items&&0}),[Gr,V.item.link?(a(),$(F,{key:0,tag:y.value,class:"link",href:V.item.link,rel:V.item.rel,target:V.item.target},{default:v(()=>[(a(),$(E(w.value),{class:"text",innerHTML:V.item.text},null,8,["innerHTML"]))]),_:1},8,["tag","href","rel","target"])):(a(),$(E(w.value),{key:1,class:"text",innerHTML:V.item.text},null,8,["innerHTML"])),V.item.collapsed!=null?(a(),i("div",{key:2,class:"caret",role:"button","aria-label":"toggle section",onClick:T,onKeydown:qe(T,["enter"]),tabindex:"0"},[h(fe,{class:"caret-icon"})],40,Ur)):f("",!0)],16,Or)):f("",!0),V.item.items&&V.item.items.length?(a(),i("div",jr,[V.depth<5?(a(!0),i(M,{key:0},A(V.item.items,R=>(a(),$(W,{key:R.text,item:R,depth:V.depth+1},null,8,["item","depth"]))),128)):f("",!0)])):f("",!0)]),_:1},8,["class"])}}});const Rr=m(qr,[["__scopeId","data-v-e31bd47b"]]),xe=s=>(H("data-v-b00e2fdd"),s=s(),z(),s),Kr=xe(()=>c("div",{class:"curtain"},null,-1)),Wr={class:"nav",id:"VPSidebarNav","aria-labelledby":"sidebar-aria-label",tabindex:"-1"},Yr=xe(()=>c("span",{class:"visually-hidden",id:"sidebar-aria-label"}," Sidebar Navigation ",-1)),Jr=g({__name:"VPSidebar",props:{open:{type:Boolean}},setup(s){const{sidebarGroups:e,hasSidebar:t}=D(),n=s,o=S(null),r=Le(K?document.body:null);return U([n,o],()=>{var d;n.open?(r.value=!0,(d=o.value)==null||d.focus()):r.value=!1},{immediate:!0,flush:"post"}),(d,p)=>l(t)?(a(),i("aside",{key:0,class:N(["VPSidebar",{open:d.open}]),ref_key:"navEl",ref:o,onClick:p[0]||(p[0]=Ke(()=>{},["stop"]))},[Kr,c("nav",Wr,[Yr,u(d.$slots,"sidebar-nav-before",{},void 0,!0),(a(!0),i(M,null,A(l(e),_=>(a(),i("div",{key:_.text,class:"group"},[h(Rr,{item:_,depth:0},null,8,["item"])]))),128)),u(d.$slots,"sidebar-nav-after",{},void 0,!0)])],2)):f("",!0)}});const Zr=m(Jr,[["__scopeId","data-v-b00e2fdd"]]),Qr=g({__name:"VPSkipLink",setup(s){const e=se(),t=S();U(()=>e.path,()=>t.value.focus());function n({target:o}){const r=document.getElementById(decodeURIComponent(o.hash).slice(1));if(r){const d=()=>{r.removeAttribute("tabindex"),r.removeEventListener("blur",d)};r.setAttribute("tabindex","-1"),r.addEventListener("blur",d),r.focus(),window.scrollTo(0,0)}}return(o,r)=>(a(),i(M,null,[c("span",{ref_key:"backToTop",ref:t,tabindex:"-1"},null,512),c("a",{href:"#VPContent",class:"VPSkipLink visually-hidden",onClick:n}," Skip to content ")],64))}});const Xr=m(Qr,[["__scopeId","data-v-0f60ec36"]]),el=g({__name:"Layout",setup(s){const{isOpen:e,open:t,close:n}=D(),o=se();U(()=>o.path,n),pt(e,n);const{frontmatter:r}=P(),d=We(),p=k(()=>!!d["home-hero-image"]);return Se("hero-image-slot-exists",p),(_,b)=>{const y=j("Content");return l(r).layout!==!1?(a(),i("div",{key:0,class:N(["Layout",l(r).pageClass])},[u(_.$slots,"layout-top",{},void 0,!0),h(Xr),h(Xe,{class:"backdrop",show:l(e),onClick:l(n)},null,8,["show","onClick"]),h(Fr,null,{"nav-bar-title-before":v(()=>[u(_.$slots,"nav-bar-title-before",{},void 0,!0)]),"nav-bar-title-after":v(()=>[u(_.$slots,"nav-bar-title-after",{},void 0,!0)]),"nav-bar-content-before":v(()=>[u(_.$slots,"nav-bar-content-before",{},void 0,!0)]),"nav-bar-content-after":v(()=>[u(_.$slots,"nav-bar-content-after",{},void 0,!0)]),"nav-screen-content-before":v(()=>[u(_.$slots,"nav-screen-content-before",{},void 0,!0)]),"nav-screen-content-after":v(()=>[u(_.$slots,"nav-screen-content-after",{},void 0,!0)]),_:3}),h(Kn,{open:l(e),onOpenMenu:l(t)},null,8,["open","onOpenMenu"]),h(Zr,{open:l(e)},{"sidebar-nav-before":v(()=>[u(_.$slots,"sidebar-nav-before",{},void 0,!0)]),"sidebar-nav-after":v(()=>[u(_.$slots,"sidebar-nav-after",{},void 0,!0)]),_:3},8,["open"]),h(wn,null,{"page-top":v(()=>[u(_.$slots,"page-top",{},void 0,!0)]),"page-bottom":v(()=>[u(_.$slots,"page-bottom",{},void 0,!0)]),"not-found":v(()=>[u(_.$slots,"not-found",{},void 0,!0)]),"home-hero-before":v(()=>[u(_.$slots,"home-hero-before",{},void 0,!0)]),"home-hero-info":v(()=>[u(_.$slots,"home-hero-info",{},void 0,!0)]),"home-hero-image":v(()=>[u(_.$slots,"home-hero-image",{},void 0,!0)]),"home-hero-after":v(()=>[u(_.$slots,"home-hero-after",{},void 0,!0)]),"home-features-before":v(()=>[u(_.$slots,"home-features-before",{},void 0,!0)]),"home-features-after":v(()=>[u(_.$slots,"home-features-after",{},void 0,!0)]),"doc-footer-before":v(()=>[u(_.$slots,"doc-footer-before",{},void 0,!0)]),"doc-before":v(()=>[u(_.$slots,"doc-before",{},void 0,!0)]),"doc-after":v(()=>[u(_.$slots,"doc-after",{},void 0,!0)]),"doc-top":v(()=>[u(_.$slots,"doc-top",{},void 0,!0)]),"doc-bottom":v(()=>[u(_.$slots,"doc-bottom",{},void 0,!0)]),"aside-top":v(()=>[u(_.$slots,"aside-top",{},void 0,!0)]),"aside-bottom":v(()=>[u(_.$slots,"aside-bottom",{},void 0,!0)]),"aside-outline-before":v(()=>[u(_.$slots,"aside-outline-before",{},void 0,!0)]),"aside-outline-after":v(()=>[u(_.$slots,"aside-outline-after",{},void 0,!0)]),"aside-ads-before":v(()=>[u(_.$slots,"aside-ads-before",{},void 0,!0)]),"aside-ads-after":v(()=>[u(_.$slots,"aside-ads-after",{},void 0,!0)]),_:3}),h(In),u(_.$slots,"layout-bottom",{},void 0,!0)],2)):(a(),$(y,{key:1}))}}});const tl=m(el,[["__scopeId","data-v-5a346dfe"]]);const nl={Layout:tl,enhanceApp:({app:s})=>{s.component("Badge",Je)}};export{nl as t}; diff --git a/assets/date.md.5f9576ec.js b/assets/date.md.5f9576ec.js new file mode 100644 index 00000000..bf2fd25a --- /dev/null +++ b/assets/date.md.5f9576ec.js @@ -0,0 +1 @@ +import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.01940dea.js";const y=JSON.parse('{"title":"LocalDate, LocalTime","description":"","frontmatter":{},"headers":[],"relativePath":"date.md","filePath":"date.md"}'),d={name:"date.md"},i=o('

LocalDate, LocalTime

Why?

Serves as an alternative / replacement of Moment.js / Day.js.

It tries to address the shortcomings of Day.js and time-lib.

time-lib was created as a wrapper around Day.js, due to following limitations:

  • Day.js doesn't provide all features that we need without plugins. This creates an "import problem": you cannot just import dayjs, you need to import it from a place that had plugins properly installed and initialized. It immediately creates an "import ambiguity": should I import from dayjs or from my_code/dayjs.ts?
  • Day.js is created as CommonJS module, all plugins has to be explicitly required. There are issues around TypeScript esModuleInterop. Result of it is that we needed to completely fork Day.js types and put it into time-lib.
  • There are more/deeper ESM issues when it's used in ESM context (e.g with Vite).

Next level of reasoning is that we needed our own opinionated API that would use standards that we use, for example:

  • We always use classic Unixtime (in seconds, not milliseconds)
  • We always use classic ISO8601 date without timezone, e.g 1984-06-21

Just the second/millisecond confusion can create serious bugs.

Mixup between similarly-called .toISOString and .toISODate can create very subtle bugs.

So, after multiple issues being accumulated and inability to properly fork Day.js, it was decided to try and simply rewrite Day.js functionality into LocalDate and LocalTime.

Reasons:

  • No milliseconds in the API (not needed)
  • Classic UnixTime, never "millisecond unixtime"
  • No timezone support/confusion, all dates/times are always treated as "local" (inspired by Java LocalDate/LocalDateTime)
  • Ability to parse "timezone-aware ISO8601 string", e.g 1984-06-21T17:15:02+02 into a LocalDate of just 1984-06-21 or LocalTime of 1984-06-21T17:15:02 (try achieving it with Moment.js or Day.js!)
  • .toJSON automatically formats LocalTime as unixtimestamp, LocalDate as ISO8601 date-only string
  • Prevents dayjs(undefined) being dayjs.now()
  • Strict parsing/validation by default. Will validate all input upon creation and will throw parse error on any invalid input. We believe it allows to catch errors sooner.
  • Optimized for performance and code maintenance, not on code size (as Day.js is, which results in its poorer performance in certain cases, and/or in less code maintainability)
  • No arbitrary .format by design. List of well-known format outputs instead.
  • Separate LocalDate class for simplified (and more performant) dealing with "just Dates without time information". Similar to Java's LocalDate. It allows much more simple and robust implementation, compared to dealing with js Date object intricacies (mostly around timezones).

API

API is designed to be closely (but not 100%) compatible with Day.js/Moment.js.

Examples:

day.js (via time-lib)LocalTimeLocalDate
nowdayjs()localTime()
todaydayjs().startOf('day')localDate()
create from unixtimestampdayjs.unix(ts)localTime(ts)
parse from ISO8601 date stringdayjs(str)localDate(str)
parse from ISO8601 date+time stringdayjs(str)localTime(str)
now plus 1 hourdayjs().add(1, 'hour')localTime().plus(1, 'hour')
today plus 1 daydayjs().startOf('day').add(1, 'day')localDate().plus(1, 'day')
toISODate (just date)dayjs().toISODate()localTime().toISODate()localDate().toISODate()
toISODate with timedayjs().format()localTime().toISODateTime()
diff in daysdayjs().diff(other, 'day')localTime().diff(other, 'day')localDate().diff(other, 'day')
to unixtimestampdayjs().unix()localTime().unix()localDate().unix()
isBeforedayjs().isBefore(other)localTime().isBefore(other)localDate().isBefore(other)

As you can see above - API is kept very similar.

DateInterval

Useful to describe an interval of Dates, e.g [inclusive] interval between 1984-06-21 and 1984-07-11 can be described as 1984-06-21/1984-07-11 (as per ISO8601).

.toJSON automatically stringifies DateInterval into a string.

Create DateInterval: DateInterval.parse('1984-06-21/1984-07-11') or DateInterval.of('1984-06-21', '1984-07-11').

',22),r=[i];function l(s,n,c,m,u,p){return e(),a("div",null,r)}const f=t(d,[["render",l]]);export{y as __pageData,f as default}; diff --git a/assets/date.md.5f9576ec.lean.js b/assets/date.md.5f9576ec.lean.js new file mode 100644 index 00000000..d18dbc37 --- /dev/null +++ b/assets/date.md.5f9576ec.lean.js @@ -0,0 +1 @@ +import{_ as t,o as e,c as a,Q as o}from"./chunks/framework.01940dea.js";const y=JSON.parse('{"title":"LocalDate, LocalTime","description":"","frontmatter":{},"headers":[],"relativePath":"date.md","filePath":"date.md"}'),d={name:"date.md"},i=o("",22),r=[i];function l(s,n,c,m,u,p){return e(),a("div",null,r)}const f=t(d,[["render",l]]);export{y as __pageData,f as default}; diff --git a/assets/decorators.md.5b065daa.js b/assets/decorators.md.5b065daa.js new file mode 100644 index 00000000..7f6752c4 --- /dev/null +++ b/assets/decorators.md.5b065daa.js @@ -0,0 +1,113 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Decorators","description":"","frontmatter":{},"headers":[],"relativePath":"decorators.md","filePath":"decorators.md"}'),o={name:"decorators.md"},p=l(`

Decorators

@_Debounce

Wrapper around _debounce.

@_Throttle

Wrapper around _throttle.

@_LogMethod

Allows to Log every execution of the method.

Console-logs when method had started, when it finished, time taken and if error happened.

Supports both sync and async methods.

Awaits if method returns a Promise.

Example output:

>> syncMethodSuccess()
+<< syncMethodSuccess() took 124 ms
+
+>> asyncMethod()
+<< asyncMethodThrow() took 10 ms ERROR: MyError
>> syncMethodSuccess()
+<< syncMethodSuccess() took 124 ms
+
+>> asyncMethod()
+<< asyncMethodThrow() took 10 ms ERROR: MyError
ts
class C {
+  @_LogMethod()
+  async hello() { ... }
+}
class C {
+  @_LogMethod()
+  async hello() { ... }
+}

@_Memo

Powerful Memoization decorator.

Simplest usage:

ts
class C {
+  @_Memo()
+  async init() { ... }
+}
+
+await c.init() // first time will run the initialization
+
+await c.init() // second time it'll skip it
+// Allows "max 1 execution" pattern
class C {
+  @_Memo()
+  async init() { ... }
+}
+
+await c.init() // first time will run the initialization
+
+await c.init() // second time it'll skip it
+// Allows "max 1 execution" pattern

Memoization caches values for each unique set of input parameters. So, e.g, if you want to hit a somewhat slow/expensive endpoint, you may want to cache it in memory like this:

ts
class C {
+  @_Memo()
+  async getExchangeRates(day: string) { ... }
+}
+
+// First time will hit the endpoint
+await c.getExchangeRates('2021-06-21')
+
+// Second time will immediately return cached result, cause the input is the same
+await c.getExchangeRates('2021-06-21')
+
+// Input has changed, so it's a cache-miss, will hit the endpoint
+await c.getExchangeRates('2021-06-22')
class C {
+  @_Memo()
+  async getExchangeRates(day: string) { ... }
+}
+
+// First time will hit the endpoint
+await c.getExchangeRates('2021-06-21')
+
+// Second time will immediately return cached result, cause the input is the same
+await c.getExchangeRates('2021-06-21')
+
+// Input has changed, so it's a cache-miss, will hit the endpoint
+await c.getExchangeRates('2021-06-22')

Pay attention that the cache of the returned values is kept forever, so, be mindful of possible memory leaks.

nodejs-lib (link pending) has a LRUMemoCache class that impements LRU cache. Example:

ts
@_Memo({ cacheFactory: () => new LRUMemoCache({...}) })
+async someMethod() {}
@_Memo({ cacheFactory: () => new LRUMemoCache({...}) })
+async someMethod() {}

@_Retry

Wrapper around pRetry.

@_Timeout

Decoratod method will throw TimeoutError if it hasn't finished in given time.

Wrapper around pTimeout.

ts
class C {
+  @_Timeout({ timeout: 1000 })
+  async hello() {
+    // some logic
+  }
+}
+
+const c = new C()
+await c.hello()
+// will throw if not finished in 1000 ms
class C {
+  @_Timeout({ timeout: 1000 })
+  async hello() {
+    // some logic
+  }
+}
+
+const c = new C()
+await c.hello()
+// will throw if not finished in 1000 ms

@_TryCatch

Wraps the method into a try/catch block, console.error(err) on error, but never re-throws (always suppresses the error).

ts
class C {
+  @_TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}
class C {
+  @_TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}

Wrapper around _tryCatch function.

_createPromiseDecorator

Powerful helper to create your own Decorators around async (Promise-returning) methods.

Example of a @TryCatch decorator that will wrap a method with "try/catch", console.error the error and suppress it (by returning undefined in case of any error).

Example usage:

ts
class C {
+  @TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}
class C {
+  @TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}

Example implementation of such a decorator using _createPromiseDecorator:

ts
export const TryCatch = () =>
+  _createPromiseDecorator({
+    decoratorName: 'TryCatch',
+    catchFn: ({ err, target, key }) => {
+      console.error(err)
+      return undefined
+    },
+  })
export const TryCatch = () =>
+  _createPromiseDecorator({
+    decoratorName: 'TryCatch',
+    catchFn: ({ err, target, key }) => {
+      console.error(err)
+      return undefined
+    },
+  })

_createPromiseDecorator allows you to define your "hooks" on different stages of a Promise:

  • beforeFn: before the method execution
  • thenFn: after successful method execution
  • catchFn: after method throws (returns rejected Promise)
  • finallyFn: after method returns resolved or rejected Promise (useful to e.g "hide the blocking loader")

Example of a @BlockingLoader decorator, that wraps the method, shows the BlockingLoader before the method execution and hides it in the end of the execution (regardless if it errored or succeeded):

ts
export const BlockingLoader = () =>
+  _createPromiseDecorator({
+    decoratorName: 'BlockingLoader',
+    beforeFn: () => store.commit('setBlockingLoader'),
+    catchFn: ({ err }) => errorDialog(err),
+    finallyFn: () => store.commit('setBlockingLoader', false),
+  })
export const BlockingLoader = () =>
+  _createPromiseDecorator({
+    decoratorName: 'BlockingLoader',
+    beforeFn: () => store.commit('setBlockingLoader'),
+    catchFn: ({ err }) => errorDialog(err),
+    finallyFn: () => store.commit('setBlockingLoader', false),
+  })
`,43),e=[p];function t(c,r,y,E,i,d){return a(),n("div",null,e)}const u=s(o,[["render",t]]);export{F as __pageData,u as default}; diff --git a/assets/decorators.md.5b065daa.lean.js b/assets/decorators.md.5b065daa.lean.js new file mode 100644 index 00000000..ce13c39f --- /dev/null +++ b/assets/decorators.md.5b065daa.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Decorators","description":"","frontmatter":{},"headers":[],"relativePath":"decorators.md","filePath":"decorators.md"}'),o={name:"decorators.md"},p=l("",43),e=[p];function t(c,r,y,E,i,d){return a(),n("div",null,e)}const u=s(o,[["render",t]]);export{F as __pageData,u as default}; diff --git a/assets/error.md.47250209.js b/assets/error.md.47250209.js new file mode 100644 index 00000000..6441ac89 --- /dev/null +++ b/assets/error.md.47250209.js @@ -0,0 +1,55 @@ +import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.01940dea.js";const u=JSON.parse('{"title":"Error","description":"","frontmatter":{},"headers":[],"relativePath":"error.md","filePath":"error.md"}'),n={name:"error.md"},r=e(`

Error

_tryCatch

Wraps/decorates a passed function with "try/catch", so it never throws, but logs the error (if occured).

ts
const someDangerousFunction = () => { ... }
+
+const fn = _tryCatch(someDangerousFunction)
+
+fn()
+// will log on error, but never throw
const someDangerousFunction = () => { ... }
+
+const fn = _tryCatch(someDangerousFunction)
+
+fn()
+// will log on error, but never throw

Allows to pass onError() function hook, that will be called on error.

ErrorObject

Standartized "Error object" that contains arbitrary data object that can hold additional data.

This data object is defined as a Generic type to ErrorObject, so, e.g. HttpError has HttpErrorData, which has a mandatory httpStatusCode: number property.

Usage example of that:

ts
.catch((err: HttpErrorObject) => {
+  console.log(err.data.httpStatusCode)
+})
.catch((err: HttpErrorObject) => {
+  console.log(err.data.httpStatusCode)
+})

AppError

The most basic implementation of an Error that complies with ErrorObject specification. Difference is that ErrorObject is purely a TypeScript interface (around any JS object), but AppError is a sub-class of Error. So, with AppError you can do if (err instanceof AppError) ....

Because AppError implements ErrorObject, it guarantees an err.data object.

This basic contract allows to establish a standartized interface between the Frontend (in frontend-lib) and Backend (in backend-lib) and implement error-handling more efficiently.

HttpError

Subclass of AppError that has some additional properties inside data, namely: httpStatusCode: number.

HttpErrorResponse

This is a standartized "Error response from the Backend" (as implemented in backend-lib). You can check/assert it with _isHttpErrorResponse, and then have all the guarantees and types about the containing error object.

Handling these type of errors is done "automatically" in getKy of the frontend-lib, and in getGot of the backend-lib.

_anyToError

Cast any to Error.

_errorToErrorObject

Cast Error to ErrorObject.

_isHttpErrorResponse

Assert if provided value: any is a HttpErrorResponse.

_isHttpErrorObject

Assert if provided value: any is a HttpErrorObject (an HttpError, same as AppError<HttpErrorData>).

_isErrorObject

Assert if provided value: any is an ErrorObject.

_assert

Asserts that a boolean condition is truthy, otherwise throws an Error.

Evaluates the condition (casts it to Boolean). Expects it to be truthy, otherwise throws AppError.

Should be used NOT for "expected" / user-facing errors, but vice-versa - for completely unexpected and 100% buggy "should never happen" cases.

It'll result in http 500 on the server (cause that's the right code for "unexpected" errors). Pass { httpStatusCode: x } at errorData argument to override the http code (will be picked up by backend-lib).

API is similar to Node's assert(), except:

  1. Throws js-lib's AppError
  2. Has a default message, if not provided
  3. Sets userFriendly flag to true, cause it's always better to have at least SOME clue, rather than fully generic "Oops" error.
ts
function run(err: any) {
+  _assert(err instanceof AppError)
+  // from here TypeScript will know that \`err instanceof AppError === true\`, or \`err: AppError\`
+
+  // Example with custom error message:
+  _assert(err instanceof AppError, 'error should be of type AppError')
+}
function run(err: any) {
+  _assert(err instanceof AppError)
+  // from here TypeScript will know that \`err instanceof AppError === true\`, or \`err: AppError\`
+
+  // Example with custom error message:
+  _assert(err instanceof AppError, 'error should be of type AppError')
+}

_assertEquals

Similar to _assert, but allows to provide 2 values (first 2 arguments) and throws if they are NOT equal.

Does a shallow equality check (!==), use _assertDeepEquals if you need a deep-check.

_assertDeepEquals

Similar to _assertEquals, but does a deep assertion (using _deepEquals).

_assertIsError

Asserts that passed value is instanceof Error.

_assertsIsTypeOf

Asserts that typeof value matches expected type.

_assertsIsString

Asserts that typeof value === 'string

_assertsIsNumber

Asserts that typeof value === 'number

_try

Calls a function, returns a Tuple of [error, value]. Allows to write shorter code that avoids try/catch. Useful e.g. in unit tests.

Similar to pTry, but for sync functions.

ts
const [err, v] = _try(() => someFunction())
const [err, v] = _try(() => someFunction())

pTry

Loosely inspired by await-to-js.

Similar to _try, but for promises.

Async/await wrapper for easy error handling. Wraps async/await calls in try catch blocks and returns a tuple containing the error or the results of the promise

ts
interface ServerResponse {
+  test: number
+}
+
+interface CustomError {
+  code: number
+  data: {
+    title: string
+    body: string
+  }
+}
+
+const p = Promise.resolve({ test: 123 })
+
+const [err, result] = await pTuple<ServerResponse, CustomError>(p)
interface ServerResponse {
+  test: number
+}
+
+interface CustomError {
+  code: number
+  data: {
+    title: string
+    body: string
+  }
+}
+
+const p = Promise.resolve({ test: 123 })
+
+const [err, result] = await pTuple<ServerResponse, CustomError>(p)
`,59),p=[r];function l(t,c,i,E,y,d){return a(),o("div",null,p)}const b=s(n,[["render",l]]);export{u as __pageData,b as default}; diff --git a/assets/error.md.47250209.lean.js b/assets/error.md.47250209.lean.js new file mode 100644 index 00000000..27ad97a0 --- /dev/null +++ b/assets/error.md.47250209.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as o,Q as e}from"./chunks/framework.01940dea.js";const u=JSON.parse('{"title":"Error","description":"","frontmatter":{},"headers":[],"relativePath":"error.md","filePath":"error.md"}'),n={name:"error.md"},r=e("",59),p=[r];function l(t,c,i,E,y,d){return a(),o("div",null,p)}const b=s(n,[["render",l]]);export{u as __pageData,b as default}; diff --git a/assets/fetcher.md.3d42ae20.js b/assets/fetcher.md.3d42ae20.js new file mode 100644 index 00000000..56df623d --- /dev/null +++ b/assets/fetcher.md.3d42ae20.js @@ -0,0 +1,49 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Fetcher","description":"","frontmatter":{},"headers":[],"relativePath":"fetcher.md","filePath":"fetcher.md"}'),o={name:"fetcher.md"},e=l(`

Fetcher

Convenient wrapper around fetch.

Features

  • Works in the Browser and on the Server (Node.js)
  • Convenient API, e.g fetcher.get(), fetcher.post(), etc.
  • Throws HttpError automatically, no need to check if (res.ok)
  • Allows to set timeout
  • Conveniently retries on retry-able errors
  • Allows to conveniently log requests/responses, configurable
  • Allows to convert searchParams object into a query string
  • Allows to define beforeRequest/beforeRetry/afterResponse hooks

Comparison

Fetcher:

tsx
const fetcher = getFetcher()
+
+const result = await fetcher.post('https://example.com', {
+  json: { foo: true },
+})
const fetcher = getFetcher()
+
+const result = await fetcher.post('https://example.com', {
+  json: { foo: true },
+})

Ky:

tsx
const result = await ky
+  .post('https://example.com/hello', {
+    json: { foo: true },
+  })
+  .json()
const result = await ky
+  .post('https://example.com/hello', {
+    json: { foo: true },
+  })
+  .json()

Plain fetch:

tsx
class HTTPError extends Error {}
+
+const response = await fetch('https://example.com', {
+  method: 'POST',
+  body: JSON.stringify({ foo: true }),
+  headers: {
+    'content-type': 'application/json',
+  },
+})
+
+if (!response.ok) {
+  throw new HTTPError(\`Fetch error: \${response.statusText}\`)
+}
+
+const json = await response.json()
+
+console.log(json)
class HTTPError extends Error {}
+
+const response = await fetch('https://example.com', {
+  method: 'POST',
+  body: JSON.stringify({ foo: true }),
+  headers: {
+    'content-type': 'application/json',
+  },
+})
+
+if (!response.ok) {
+  throw new HTTPError(\`Fetch error: \${response.statusText}\`)
+}
+
+const json = await response.json()
+
+console.log(json)

Prior art

Heavily inspired by:

Why

Differences from prior projects:

  • Targets both Browser and Node by design, targeting Node with native fetch support. This is similar to ky plus ky-universal.
  • Incorporates everything from getKy and getGot, so you don’t need multiple layers. For example, with ky you would need: ky, ky-for-people, getKy (frontend-lib). With fetcher you need only fetcher (part of js-lib).

Goals

  • Simplicity. It focuses on the most simple and common use cases, and not on the most advanced or edge cases.
  • Assume native fetch support (Browser and Node), no polyfills. Should work equally well in Browser and Node, ideally without platform-specific quirks.
  • Written in TypeScript, with first-class TypeScript support.
`,19),p=[e];function t(r,c,y,E,i,h){return a(),n("div",null,p)}const u=s(o,[["render",t]]);export{F as __pageData,u as default}; diff --git a/assets/fetcher.md.3d42ae20.lean.js b/assets/fetcher.md.3d42ae20.lean.js new file mode 100644 index 00000000..f2a59791 --- /dev/null +++ b/assets/fetcher.md.3d42ae20.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Fetcher","description":"","frontmatter":{},"headers":[],"relativePath":"fetcher.md","filePath":"fetcher.md"}'),o={name:"fetcher.md"},e=l("",19),p=[e];function t(r,c,y,E,i,h){return a(),n("div",null,p)}const u=s(o,[["render",t]]);export{F as __pageData,u as default}; diff --git a/assets/httpRequestError.md.ea988257.js b/assets/httpRequestError.md.ea988257.js new file mode 100644 index 00000000..21983ba9 --- /dev/null +++ b/assets/httpRequestError.md.ea988257.js @@ -0,0 +1,43 @@ +import{_ as s,o as e,c as n,Q as a}from"./chunks/framework.01940dea.js";const m=JSON.parse('{"title":"","description":"","frontmatter":{},"headers":[],"relativePath":"httpRequestError.md","filePath":"httpRequestError.md"}'),r={name:"httpRequestError.md"},p=a(`
Backend makes a Fetch call to some API
+API returns error1 with 500 and a message1
+Fetcher wraps error1 with error2 which is a FetcherError
+method
+url
+baseUrl?
+statusCode
+millis
+message: 500 GET /someUrl
+causedBy error1
+
+genericErrorHandler needs to return error2
+it wraps error2 (FetchError) with error3: HttpError
+Maybe there's just no need to do that wrapping?! Return ErrorObject as is
+Requester (Fetcher) would always know httpStatusCode of the error they just received
+
+Why is HttpError needed?
+For the Backend to set the right httpStatusCode
+Maybe it's enough to just have it as AppError with httpStatusCode?
+
+Rename HttpError to HttpRequestError, which is the same as FetchError
+HttpErrorResponse becomes BackendErrorResponseObject (detected by name and message)
Backend makes a Fetch call to some API
+API returns error1 with 500 and a message1
+Fetcher wraps error1 with error2 which is a FetcherError
+method
+url
+baseUrl?
+statusCode
+millis
+message: 500 GET /someUrl
+causedBy error1
+
+genericErrorHandler needs to return error2
+it wraps error2 (FetchError) with error3: HttpError
+Maybe there's just no need to do that wrapping?! Return ErrorObject as is
+Requester (Fetcher) would always know httpStatusCode of the error they just received
+
+Why is HttpError needed?
+For the Backend to set the right httpStatusCode
+Maybe it's enough to just have it as AppError with httpStatusCode?
+
+Rename HttpError to HttpRequestError, which is the same as FetchError
+HttpErrorResponse becomes BackendErrorResponseObject (detected by name and message)
`,1),t=[p];function l(o,c,i,h,d,y){return e(),n("div",null,t)}const E=s(r,[["render",l]]);export{m as __pageData,E as default}; diff --git a/assets/httpRequestError.md.ea988257.lean.js b/assets/httpRequestError.md.ea988257.lean.js new file mode 100644 index 00000000..afd50380 --- /dev/null +++ b/assets/httpRequestError.md.ea988257.lean.js @@ -0,0 +1 @@ +import{_ as s,o as e,c as n,Q as a}from"./chunks/framework.01940dea.js";const m=JSON.parse('{"title":"","description":"","frontmatter":{},"headers":[],"relativePath":"httpRequestError.md","filePath":"httpRequestError.md"}'),r={name:"httpRequestError.md"},p=a("",1),t=[p];function l(o,c,i,h,d,y){return e(),n("div",null,t)}const E=s(r,[["render",l]]);export{m as __pageData,E as default}; diff --git a/assets/index.md.96458ebc.js b/assets/index.md.96458ebc.js new file mode 100644 index 00000000..25981cce --- /dev/null +++ b/assets/index.md.96458ebc.js @@ -0,0 +1,17 @@ +import{_ as e,o as s,c as a,Q as o}from"./chunks/framework.01940dea.js";const g=JSON.parse('{"title":"js-lib","description":"","frontmatter":{},"headers":[],"relativePath":"index.md","filePath":"index.md"}'),t={name:"index.md"},n=o(`

js-lib

Standard library for universal (browser + Node.js) javascript

npmmin.gz sizeActionsloc

MaintainabilityTest Coveragecode style: prettier

Design

Inspired by Lodash, bluebird, promise-fun and other useful small packages.

Designed to play well with the rest of opinionated "Natural Cycles JS Platform" (link pending). This package is the lowest-level production dependency (not devDependency) of the Platform. Almost everything else depends on it.

All functions in this package are exported in index.ts (flat), no namespacing is used. So, to avoid conflicts and "global import namespace" pollution , all functions are prefixed with an underscore (e.g _.pick becomes _pick), with some exceptions (later). Promise functions are prefixed with p, e.g pMap.

Decorators are _prefixed and PascalCased (e.g @_Debounce). _is to be consistent with other naming in this package. PascalCase is to distinguish decorators from similar functions that are not decorators. Example:\\_debounceis a function (lodash-based),\\_Debounceis a decorator (used as@\\_Debounce). PascalCase convention follows Angular/Ionic convention (but doesn't follow TypeScript documentation convention; we had to pick one).

Interfaces and Classes are named as usual (no prefix, PascalCase, e.g AppError).

Q: Why not just use lodash?

A:

  • We believe Lodash is outdated (many functions are pre-ES6 / obsolete by ES6).
  • Because it has so many outdated functions - its size is bigger, and solutions to tree-shake exist, but complicated.
  • First-class TypeScript support (all code in this repo is TypeScript).

This package is intended to be 0-dependency (exception: tslib from TypeScript), "not bloated", tree-shakeable. Supported by reasonably modern Browsers and Node.js latest LTS.

To fulfil that requirement it exports ESM version (for Browsers) as es2017.

Exports default CJS version for Node as es2019 (with native async/await, for better performance, async stack-traces, etc).

Mutation

All function does NOT mutate the arguments by default.

Many functions support "mutation flag", which can be set to true to perform a mutation.

For example:

ts
const obj = { a: 'a', b: 'b' }
+
+// Non-mutating (default)
+const obj2 = _pick(obj, ['a'])
+// { a: 'a' }
+
+// Mutating (opt-in)
+_pick(obj, ['a'], true)
+// obj was mutated
const obj = { a: 'a', b: 'b' }
+
+// Non-mutating (default)
+const obj2 = _pick(obj, ['a'])
+// { a: 'a' }
+
+// Mutating (opt-in)
+_pick(obj, ['a'], true)
+// obj was mutated

Highlights

Packaging

  • engines.node >= Node.js LTS
  • main: dist/index.js: commonjs, es2021 - targeting Node.js
  • module: dist-esm/index.js: esm, es2017 - targeting Browsers
  • types: dist/index.d.ts: typescript types
  • /src folder with source *.ts files included
`,25),l=[n];function p(i,r,c,d,h,u){return s(),a("div",null,l)}const m=e(t,[["render",p]]);export{g as __pageData,m as default}; diff --git a/assets/index.md.96458ebc.lean.js b/assets/index.md.96458ebc.lean.js new file mode 100644 index 00000000..715de2c7 --- /dev/null +++ b/assets/index.md.96458ebc.lean.js @@ -0,0 +1 @@ +import{_ as e,o as s,c as a,Q as o}from"./chunks/framework.01940dea.js";const g=JSON.parse('{"title":"js-lib","description":"","frontmatter":{},"headers":[],"relativePath":"index.md","filePath":"index.md"}'),t={name:"index.md"},n=o("",25),l=[n];function p(i,r,c,d,h,u){return s(),a("div",null,l)}const m=e(t,[["render",p]]);export{g as __pageData,m as default}; diff --git a/assets/inter-italic-cyrillic-ext.33bd5a8e.woff2 b/assets/inter-italic-cyrillic-ext.33bd5a8e.woff2 new file mode 100644 index 00000000..2a687296 Binary files /dev/null and b/assets/inter-italic-cyrillic-ext.33bd5a8e.woff2 differ diff --git a/assets/inter-italic-cyrillic.ea42a392.woff2 b/assets/inter-italic-cyrillic.ea42a392.woff2 new file mode 100644 index 00000000..f6403515 Binary files /dev/null and b/assets/inter-italic-cyrillic.ea42a392.woff2 differ diff --git a/assets/inter-italic-greek-ext.4fbe9427.woff2 b/assets/inter-italic-greek-ext.4fbe9427.woff2 new file mode 100644 index 00000000..00218960 Binary files /dev/null and b/assets/inter-italic-greek-ext.4fbe9427.woff2 differ diff --git a/assets/inter-italic-greek.8f4463c4.woff2 b/assets/inter-italic-greek.8f4463c4.woff2 new file mode 100644 index 00000000..71c265f8 Binary files /dev/null and b/assets/inter-italic-greek.8f4463c4.woff2 differ diff --git a/assets/inter-italic-latin-ext.bd8920cc.woff2 b/assets/inter-italic-latin-ext.bd8920cc.woff2 new file mode 100644 index 00000000..9c1b9440 Binary files /dev/null and b/assets/inter-italic-latin-ext.bd8920cc.woff2 differ diff --git a/assets/inter-italic-latin.bd3b6f56.woff2 b/assets/inter-italic-latin.bd3b6f56.woff2 new file mode 100644 index 00000000..01fcf207 Binary files /dev/null and b/assets/inter-italic-latin.bd3b6f56.woff2 differ diff --git a/assets/inter-italic-vietnamese.6ce511fb.woff2 b/assets/inter-italic-vietnamese.6ce511fb.woff2 new file mode 100644 index 00000000..e4f788ee Binary files /dev/null and b/assets/inter-italic-vietnamese.6ce511fb.woff2 differ diff --git a/assets/inter-roman-cyrillic-ext.e75737ce.woff2 b/assets/inter-roman-cyrillic-ext.e75737ce.woff2 new file mode 100644 index 00000000..28593ccb Binary files /dev/null and b/assets/inter-roman-cyrillic-ext.e75737ce.woff2 differ diff --git a/assets/inter-roman-cyrillic.5f2c6c8c.woff2 b/assets/inter-roman-cyrillic.5f2c6c8c.woff2 new file mode 100644 index 00000000..a20adc16 Binary files /dev/null and b/assets/inter-roman-cyrillic.5f2c6c8c.woff2 differ diff --git a/assets/inter-roman-greek-ext.ab0619bc.woff2 b/assets/inter-roman-greek-ext.ab0619bc.woff2 new file mode 100644 index 00000000..e3b0be76 Binary files /dev/null and b/assets/inter-roman-greek-ext.ab0619bc.woff2 differ diff --git a/assets/inter-roman-greek.d5a6d92a.woff2 b/assets/inter-roman-greek.d5a6d92a.woff2 new file mode 100644 index 00000000..f790e047 Binary files /dev/null and b/assets/inter-roman-greek.d5a6d92a.woff2 differ diff --git a/assets/inter-roman-latin-ext.0030eebd.woff2 b/assets/inter-roman-latin-ext.0030eebd.woff2 new file mode 100644 index 00000000..715bd903 Binary files /dev/null and b/assets/inter-roman-latin-ext.0030eebd.woff2 differ diff --git a/assets/inter-roman-latin.2ed14f66.woff2 b/assets/inter-roman-latin.2ed14f66.woff2 new file mode 100644 index 00000000..a540b7af Binary files /dev/null and b/assets/inter-roman-latin.2ed14f66.woff2 differ diff --git a/assets/inter-roman-vietnamese.14ce25a6.woff2 b/assets/inter-roman-vietnamese.14ce25a6.woff2 new file mode 100644 index 00000000..5a9f9cb9 Binary files /dev/null and b/assets/inter-roman-vietnamese.14ce25a6.woff2 differ diff --git a/assets/json.md.1d0c16e2.js b/assets/json.md.1d0c16e2.js new file mode 100644 index 00000000..62fab695 --- /dev/null +++ b/assets/json.md.1d0c16e2.js @@ -0,0 +1,41 @@ +import{_ as s,o as n,c as a,Q as o}from"./chunks/framework.01940dea.js";const f=JSON.parse('{"title":"Json","description":"","frontmatter":{},"headers":[],"relativePath":"json.md","filePath":"json.md"}'),l={name:"json.md"},p=o(`

Json

_jsonParseIfPossible

Attempts to parse object as JSON.

Returns original object if JSON parse failed (silently).

ts
_jsonParseIfPossible('abc') // 'abc' (no change, not a json string)
+_jsonParseIfPossible(null) // null (no change)
+_jsonParseIfPossible({ a: 'a' }) // {a: 'a'} (same object, not a json string)
+_jsonParseIfPossible('{"a": "a"}') // {a: 'a'} gotcha! parsed json string into an object!
_jsonParseIfPossible('abc') // 'abc' (no change, not a json string)
+_jsonParseIfPossible(null) // null (no change)
+_jsonParseIfPossible({ a: 'a' }) // {a: 'a'} (same object, not a json string)
+_jsonParseIfPossible('{"a": "a"}') // {a: 'a'} gotcha! parsed json string into an object!

_stringify

Inspired by _inspect from nodejs-lib, which is based on util.inpect that is not available in the Browser.

Transforms any to human-readable string (via JSON.stringify pretty).

Safe (no error throwing).

Correclty prints Error, AppError, ErrorObject: error.message + '\\n' + _stringify(error.data)

Enforces max length (default to 1000, pass 0 to skip it).

Logs numbers as-is (as a String), e.g: 6.

Logs strings as-is (without single quotes around, unlike default util.inspect behavior).

Otherwise - just uses JSON.stringify.

Returns empty_string string if empty string is passed.

Returns undefined (not a string, but actual undefined) if undefined is passed (default util.inspect behavior).

ts
_stringify(undefined) // 'undefined'
+_stringify(null) // 'null'
+_stringify(true) // 'true'
+_stringify(false) // 'false'
+_stringify(NaN) // 'null'
+_stringify(Infinity) // 'null'
+_stringify('') // 'empty_string'
+_stringify(' ') // 'empty_string'
+_stringify('ho ho ho') // 'ho ho ho'
+_stringify(15) // '15'
+_stringify(new Error('some msg')) // 'Error: some msg'
+
+// AppError is stringified with it's Data object
+_stringify(new AppError('some msg', { k1: 'v1' }))
+// 'AppError: some msg\\n
+// {
+//   "k1": "v1"
+// }'
_stringify(undefined) // 'undefined'
+_stringify(null) // 'null'
+_stringify(true) // 'true'
+_stringify(false) // 'false'
+_stringify(NaN) // 'null'
+_stringify(Infinity) // 'null'
+_stringify('') // 'empty_string'
+_stringify(' ') // 'empty_string'
+_stringify('ho ho ho') // 'ho ho ho'
+_stringify(15) // '15'
+_stringify(new Error('some msg')) // 'Error: some msg'
+
+// AppError is stringified with it's Data object
+_stringify(new AppError('some msg', { k1: 'v1' }))
+// 'AppError: some msg\\n
+// {
+//   "k1": "v1"
+// }'
`,17),e=[p];function t(r,c,i,y,E,d){return n(),a("div",null,e)}const u=s(l,[["render",t]]);export{f as __pageData,u as default}; diff --git a/assets/json.md.1d0c16e2.lean.js b/assets/json.md.1d0c16e2.lean.js new file mode 100644 index 00000000..7632d6d6 --- /dev/null +++ b/assets/json.md.1d0c16e2.lean.js @@ -0,0 +1 @@ +import{_ as s,o as n,c as a,Q as o}from"./chunks/framework.01940dea.js";const f=JSON.parse('{"title":"Json","description":"","frontmatter":{},"headers":[],"relativePath":"json.md","filePath":"json.md"}'),l={name:"json.md"},p=o("",17),e=[p];function t(r,c,i,y,E,d){return n(),a("div",null,e)}const u=s(l,[["render",t]]);export{f as __pageData,u as default}; diff --git a/assets/lazy.md.584a783f.js b/assets/lazy.md.584a783f.js new file mode 100644 index 00000000..2684f518 --- /dev/null +++ b/assets/lazy.md.584a783f.js @@ -0,0 +1,27 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const h=JSON.parse('{"title":"Lazy","description":"","frontmatter":{},"headers":[],"relativePath":"lazy.md","filePath":"lazy.md"}'),p={name:"lazy.md"},e=l(`

Lazy

_lazyValue

Based on: https://github.com/sindresorhus/lazy-value

ts
const value = _lazyValue(() => expensiveComputation())
+
+value() // calls expensiveComputation() once
+value() // returns cached result
+value() // returns cached result
const value = _lazyValue(() => expensiveComputation())
+
+value() // calls expensiveComputation() once
+value() // returns cached result
+value() // returns cached result

_defineLazyProperty

Based on: https://github.com/sindresorhus/define-lazy-prop

ts
interface Obj {
+  v: number
+}
+
+const obj = {} as Obj
+
+_defineLazyProperty(obj, 'v', () => expensiveComputation())
+obj.v // runs expensiveComputation() once
+obj.v // cached value
+obj.v // cached value
interface Obj {
+  v: number
+}
+
+const obj = {} as Obj
+
+_defineLazyProperty(obj, 'v', () => expensiveComputation())
+obj.v // runs expensiveComputation() once
+obj.v // cached value
+obj.v // cached value

_defineLazyProps

Like _defineLazyProperty, but allows to define multiple props at once.

`,9),o=[e];function t(c,r,y,i,E,d){return a(),n("div",null,o)}const v=s(p,[["render",t]]);export{h as __pageData,v as default}; diff --git a/assets/lazy.md.584a783f.lean.js b/assets/lazy.md.584a783f.lean.js new file mode 100644 index 00000000..e4e56dcd --- /dev/null +++ b/assets/lazy.md.584a783f.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const h=JSON.parse('{"title":"Lazy","description":"","frontmatter":{},"headers":[],"relativePath":"lazy.md","filePath":"lazy.md"}'),p={name:"lazy.md"},e=l("",9),o=[e];function t(c,r,y,i,E,d){return a(),n("div",null,o)}const v=s(p,[["render",t]]);export{h as __pageData,v as default}; diff --git a/assets/math.md.152995c2.js b/assets/math.md.152995c2.js new file mode 100644 index 00000000..ea3404a3 --- /dev/null +++ b/assets/math.md.152995c2.js @@ -0,0 +1,79 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Math","description":"","frontmatter":{},"headers":[],"relativePath":"math.md","filePath":"math.md"}'),p={name:"math.md"},o=l(`

Math

_randomInt

Returns a random integer in the provided range. As usual, lower-bound is inclusing, while higher-bound is exclusive. Unusually, both lower and higher bounds are inclusive.

ts
_randomInt(1, 3)
+// 1
+// 3
+// 2
_randomInt(1, 3)
+// 1
+// 3
+// 2

_randomArrayItem

Returns a random item from the given array.

Don't use it on empty array. It'll return undefined in that case, but that is not reflected in function's output type!

ts
const a = [1, 2, 3]
+_randomArrayItem(a)
+// random of 1, 2 or 3
const a = [1, 2, 3]
+_randomArrayItem(a)
+// random of 1, 2 or 3

_createDeterministicRandom

Returns a "deterministic Math.random() function".

Useful to make tests that need to use Math.random() deterministic.

ts
const deterministicRandom = _createDeterministicRandom()
+
+deterministicRandom()
+// => 0.9872818551957607
+
+deterministicRandom()
+// => 0.34880331158638
const deterministicRandom = _createDeterministicRandom()
+
+deterministicRandom()
+// => 0.9872818551957607
+
+deterministicRandom()
+// => 0.34880331158638

Based on this gist which is based on Robert Jenkins’ 32 bit integer hash function.

_average

Calculate an average of the array of numbers.

ts
_average([1, 2, 3, 4])
+// 2.5
_average([1, 2, 3, 4])
+// 2.5

_averageWeighted

Calculate a "weighted average", given the array of numbers and corresponding array of weights.

ts
const numbers = [1, 2]
+const weights = [3, 1]
+_averageWeighted(numbers, weights)
+// 1.25
const numbers = [1, 2]
+const weights = [3, 1]
+_averageWeighted(numbers, weights)
+// 1.25

_median

Calculate a Median of the array of numbers.

ts
_median([1, 2, 3]) // 2
+_median([1, 2, 3, 4]) // 2.5
+_median([1, 1, 1, 3, 999]) // 1
_median([1, 2, 3]) // 2
+_median([1, 2, 3, 4]) // 2.5
+_median([1, 1, 1, 3, 999]) // 1

_percentile

Calculate a Percentile of the array of numbers.

ts
const numbers = [1200, 1400]
+_percentile(numbers, 0) // 1200
+_percentile(numbers, 10) // 1220
+_percentile(numbers, 20) // 1240
+_percentile(numbers, 30) // 1260
+_percentile(numbers, 40) // 1280
+_percentile(numbers, 50) // 1300
+_percentile(numbers, 60) // 1320
+_percentile(numbers, 70) // 1340
+_percentile(numbers, 80) // 1360
+_percentile(numbers, 90) // 1380
+_percentile(numbers, 100) // 1400
const numbers = [1200, 1400]
+_percentile(numbers, 0) // 1200
+_percentile(numbers, 10) // 1220
+_percentile(numbers, 20) // 1240
+_percentile(numbers, 30) // 1260
+_percentile(numbers, 40) // 1280
+_percentile(numbers, 50) // 1300
+_percentile(numbers, 60) // 1320
+_percentile(numbers, 70) // 1340
+_percentile(numbers, 80) // 1360
+_percentile(numbers, 90) // 1380
+_percentile(numbers, 100) // 1400

SimpleMovingAverage

ts
// SMA with the size of 2:
+const sma = new SimpleMovingAverage(2)
+sma.avg // 0 by default, when no numbers were pushed
+
+sma.push(1) // [1]
+sma.avg // 1
+
+sma.push(2) // [1, 2]
+sma.avg // 1.5
+
+sma.push(3) // [1, 2, 3]
+sma.avg // 2.5
// SMA with the size of 2:
+const sma = new SimpleMovingAverage(2)
+sma.avg // 0 by default, when no numbers were pushed
+
+sma.push(1) // [1]
+sma.avg // 1
+
+sma.push(2) // [1, 2]
+sma.avg // 1.5
+
+sma.push(3) // [1, 2, 3]
+sma.avg // 2.5
`,27),e=[o];function t(c,r,y,i,E,d){return a(),n("div",null,e)}const m=s(p,[["render",t]]);export{F as __pageData,m as default}; diff --git a/assets/math.md.152995c2.lean.js b/assets/math.md.152995c2.lean.js new file mode 100644 index 00000000..c5a6c5d0 --- /dev/null +++ b/assets/math.md.152995c2.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Math","description":"","frontmatter":{},"headers":[],"relativePath":"math.md","filePath":"math.md"}'),p={name:"math.md"},o=l("",27),e=[o];function t(c,r,y,i,E,d){return a(),n("div",null,e)}const m=s(p,[["render",t]]);export{F as __pageData,m as default}; diff --git a/assets/number.md.65c527f0.js b/assets/number.md.65c527f0.js new file mode 100644 index 00000000..54e66b6a --- /dev/null +++ b/assets/number.md.65c527f0.js @@ -0,0 +1,71 @@ +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.01940dea.js";const d=JSON.parse('{"title":"Number","description":"","frontmatter":{},"headers":[],"relativePath":"number.md","filePath":"number.md"}'),p={name:"number.md"},o=l(`

Number

_inRange

Checks if the provided number (1st argument) is withing range of 2nd and 3rd argument. As usual, lower-bound is inclusive, while higher-boung is exclusive.

ts
_inRange(-10, 1, 5)
+// false
+
+_inRange(1, 1, 5)
+// true
+
+_inRange(3, 1, 5)
+// true
+
+_inRange(5, 1, 5)
+// false
+
+_inRange(7, 1, 5)
+// false
_inRange(-10, 1, 5)
+// false
+
+_inRange(1, 1, 5)
+// true
+
+_inRange(3, 1, 5)
+// true
+
+_inRange(5, 1, 5)
+// false
+
+_inRange(7, 1, 5)
+// false

_clamp

Inspired by Lodash's _clamp.

"Clamps" (fits) the number (first argument) within the min/max ranges of 2nd/3rd arguments (range inclusive).

ts
// range is always [5, 10] in these cases
+_clamp(3, 5, 10) // 5
+_clamp(4, 5, 10) // 5
+_clamp(5, 5, 10) // 5
+_clamp(6, 5, 10) // 6
+_clamp(9, 5, 10) // 9
+_clamp(10, 5, 10) // 10
+_clamp(11, 5, 10) // 10
// range is always [5, 10] in these cases
+_clamp(3, 5, 10) // 5
+_clamp(4, 5, 10) // 5
+_clamp(5, 5, 10) // 5
+_clamp(6, 5, 10) // 6
+_clamp(9, 5, 10) // 9
+_clamp(10, 5, 10) // 10
+_clamp(11, 5, 10) // 10

_toFixed

Same as Number.toFixed, but conveniently casts the output to Number.

ts
_toFixed(1.2345, 2)
+// 1.23
+
+_toFixed(1.1, 2)
+// 1.1
+// not '1.10' !
_toFixed(1.2345, 2)
+// 1.23
+
+_toFixed(1.1, 2)
+// 1.1
+// not '1.10' !

_toPrecision

Same as Number.toPrecision(), but conveniently casts the output to Number.

ts
_toPrecision(1634.56, 1)
+// 2000
+
+_toPrecision(1234.56, 2)
+// 1600
_toPrecision(1634.56, 1)
+// 2000
+
+_toPrecision(1234.56, 2)
+// 1600

_round

Round (like Math.round) the Number to the nearest "discriminator" (2nd argument):

ts
_round(1634, 1000) // 2000
+_round(1634, 500) // 1500
+_round(1634, 100) // 1600
+_round(1634, 10) // 1630
+_round(1634, 1) // 1634
+_round(1634.5678, 0.1) // 1634.6
+_round(1634.5678, 0.01) // 1634.57
_round(1634, 1000) // 2000
+_round(1634, 500) // 1500
+_round(1634, 100) // 1600
+_round(1634, 10) // 1630
+_round(1634, 1) // 1634
+_round(1634.5678, 0.1) // 1634.6
+_round(1634.5678, 0.01) // 1634.57
`,17),e=[o];function c(t,r,y,E,i,F){return n(),a("div",null,e)}const u=s(p,[["render",c]]);export{d as __pageData,u as default}; diff --git a/assets/number.md.65c527f0.lean.js b/assets/number.md.65c527f0.lean.js new file mode 100644 index 00000000..00fb6196 --- /dev/null +++ b/assets/number.md.65c527f0.lean.js @@ -0,0 +1 @@ +import{_ as s,o as n,c as a,Q as l}from"./chunks/framework.01940dea.js";const d=JSON.parse('{"title":"Number","description":"","frontmatter":{},"headers":[],"relativePath":"number.md","filePath":"number.md"}'),p={name:"number.md"},o=l("",17),e=[o];function c(t,r,y,E,i,F){return n(),a("div",null,e)}const u=s(p,[["render",c]]);export{d as __pageData,u as default}; diff --git a/assets/object.md.4acc3c49.js b/assets/object.md.4acc3c49.js new file mode 100644 index 00000000..56a8df89 --- /dev/null +++ b/assets/object.md.4acc3c49.js @@ -0,0 +1,561 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Object","description":"","frontmatter":{},"headers":[],"relativePath":"object.md","filePath":"object.md"}'),p={name:"object.md"},o=l(`

Object

_pick

Inspired by Lodash's _.pick.

ts
_pick({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { a: 'a', b: 'b' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// { a: 'a' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// {}
+
+_pick({ a: 'a', b: 'b', c: 'c' }, [])
+// {}
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _pick(obj, ['a'], true)
+obj === obj2 // true
_pick({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { a: 'a', b: 'b' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// { a: 'a' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// {}
+
+_pick({ a: 'a', b: 'b', c: 'c' }, [])
+// {}
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _pick(obj, ['a'], true)
+obj === obj2 // true

_omit

Inspired by Lodash's _.omit. The opposite of _pick.

ts
_omit({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// {  b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// { a: 'a', b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, [])
+// { a: 'a', b: 'b', c: 'c' }
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _omit(obj, ['a', 'b'], true)
+obj === obj2 // true
_omit({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// {  b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// { a: 'a', b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, [])
+// { a: 'a', b: 'b', c: 'c' }
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _omit(obj, ['a', 'b'], true)
+obj === obj2 // true

_mask

Similar to _omit, but supports deep object access via dot-notation (a.b). Supports "mutation flag" argument.

ts
const obj = {
+  a: 'a',
+  b: {
+    b1: 'b1',
+    b2: 'b2',
+  },
+}
+
+_mask(obj, ['b.b1'])
+// { a: 'a', b: { b1: 'b1' }}
+
+_mask(obj, ['b.b1'], true)
+// obj was mutated
const obj = {
+  a: 'a',
+  b: {
+    b1: 'b1',
+    b2: 'b2',
+  },
+}
+
+_mask(obj, ['b.b1'])
+// { a: 'a', b: { b1: 'b1' }}
+
+_mask(obj, ['b.b1'], true)
+// obj was mutated

_filterFalsyValues

Returns an object with all Falsy values filtered out. Non-mutating by default.

ts
_filterFalsyValues({
+  a: 'a',
+  b: '', // falsy
+  c: 0, // falsy
+  d: [], // not falsy
+})
+// { a: 'a', d: [] }
_filterFalsyValues({
+  a: 'a',
+  b: '', // falsy
+  c: 0, // falsy
+  d: [], // not falsy
+})
+// { a: 'a', d: [] }

_filterNullishValues

Returns an object with all Nullish (null or undefined) values filtered out. Non-mutating by default.

ts
_filterNullishValues({
+  a: 'a',
+  b: null, // nullish
+  c: undefined, // nullish
+  d: '', // not nullish
+})
+// { a: 'a', d: '' }
_filterNullishValues({
+  a: 'a',
+  b: null, // nullish
+  c: undefined, // nullish
+  d: '', // not nullish
+})
+// { a: 'a', d: '' }

_filterUndefinedValues

Returns an object with all undefined values filtered out. null values are kept.

Non-mutating by default.

ts
_filterUndefinedValues({
+  a: 'a',
+  b: null,
+  c: undefined, // removed
+  d: '',
+})
+// { a: 'a', b: null, d: '' }
_filterUndefinedValues({
+  a: 'a',
+  b: null,
+  c: undefined, // removed
+  d: '',
+})
+// { a: 'a', b: null, d: '' }

_filterEmptyArrays

Returns an object will all empty arrays filtered out. Non-mutating by default.

ts
_filterEmptyArrays({
+  a: 'a',
+  b: [], // empty array
+  c: 'c',
+})
+// { a: 'a', c: 'c' }
_filterEmptyArrays({
+  a: 'a',
+  b: [], // empty array
+  c: 'c',
+})
+// { a: 'a', c: 'c' }

_filterEmptyValues

Filters the object by removing all key-value pairs where Value is Empty (according to _isEmpty() specification).

ts
_filterEmptyValues({
+  a: 0,
+  b: '',
+  c: [],
+  d: {},
+  e: {
+    f: [],
+  },
+  g: new Set(),
+  h: 'h',
+})
+// {
+//   a: 0,
+//   e: {
+//     f: [],
+//   },
+//   h: 'h',
+//  })
_filterEmptyValues({
+  a: 0,
+  b: '',
+  c: [],
+  d: {},
+  e: {
+    f: [],
+  },
+  g: new Set(),
+  h: 'h',
+})
+// {
+//   a: 0,
+//   e: {
+//     f: [],
+//   },
+//   h: 'h',
+//  })

_filterObject

Returns clone of obj without properties that does not pass predicate. Allows filtering by both key and value.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Predicate to keep only even-numbered values
+_filterObject(obj, (_k, v) => v % 2 === 0)
+// { b: 2 }
+
+// Predicate to only keep keys that start with \`a\`
+_filterObject(obj, (k, _v) => k.startsWith('a'))
+// { a: 1 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Predicate to keep only even-numbered values
+_filterObject(obj, (_k, v) => v % 2 === 0)
+// { b: 2 }
+
+// Predicate to only keep keys that start with \`a\`
+_filterObject(obj, (k, _v) => k.startsWith('a'))
+// { a: 1 }

_mapKeys

Returns a clone of obj with modified Keys, based on a Mapper function.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to add \`_odd\` or \`_even\` to the object key, based on its value
+_mapKeys(obj, (k, v) => k + (v % 2 ? '_odd' : '_even'))
+// { a_odd: 1, b_even: 2, c_odd: 3 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to add \`_odd\` or \`_even\` to the object key, based on its value
+_mapKeys(obj, (k, v) => k + (v % 2 ? '_odd' : '_even'))
+// { a_odd: 1, b_even: 2, c_odd: 3 }

_mapValues

Returns a clone of obj with modified Values, based on a Mapper function.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2
+_mapValues(obj, (_k, v) => v * 2)
+// { a: 2, b: 4, c: 6 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2
+_mapValues(obj, (_k, v) => v * 2)
+// { a: 2, b: 4, c: 6 }

_mapObject

Returns a clone of obj where both Keys and Values can be modified by a Mapper function. Mapper function needs to return a Tuple [key, value].

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2, and append the value to the end of the key
+_mapObject(obj, (k, v) => {
+  const newValue = v * 2
+  return [k + newValue, newValue]
+})
+// { a2: 2, b4: 4, c6: 6 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2, and append the value to the end of the key
+_mapObject(obj, (k, v) => {
+  const newValue = v * 2
+  return [k + newValue, newValue]
+})
+// { a2: 2, b4: 4, c6: 6 }

_findKeyByValue

Fiven an object, find a key string for a given value: any.

Inspired by Lodash's _.findKey.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+_findKeyByValue(obj, 1) // 'a'
+_findKeyByValue(obj, 2) // 'b'
+_findKeyByValue(obj, 3) // 'c'
+_findKeyByValue(obj, 4) // undefined
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+_findKeyByValue(obj, 1) // 'a'
+_findKeyByValue(obj, 2) // 'b'
+_findKeyByValue(obj, 3) // 'c'
+_findKeyByValue(obj, 4) // undefined

_objectNullValuesToUndefined

Returns a clone of the object where null values are replaced with undefined

ts
const obj = {
+  a: 1, // intact
+  b: null, // replaced with \`undefined\`
+  c: undefined, // intact
+}
+
+_objectNullValuesToUndefined(obj)
+// { a: 1, b: undefined, c: undefined }
const obj = {
+  a: 1, // intact
+  b: null, // replaced with \`undefined\`
+  c: undefined, // intact
+}
+
+_objectNullValuesToUndefined(obj)
+// { a: 1, b: undefined, c: undefined }

_deepCopy

Does a deep copy of an object.

Actually, it is just a semantic function that internally does JSON.parse(JSON.stringify(o)), which is currently the fastest+simplest+relyable way to do a deep copy.

Because it does JSON.parse/stringify - it'll remove undefined values/keys from objects.

ts
const obj = { a: 'a', b: { bb: 'bb' } }
+const obj2 = _deepCopy(obj)
+// Deep copy of obj
const obj = { a: 'a', b: { bb: 'bb' } }
+const obj2 = _deepCopy(obj)
+// Deep copy of obj

_isPrimitive

Returns Boolean indication if passed value is a primitive.

ts
_isPrimitive(5)
+// true
+
+_isPrimitive({ a: 'a' })
+// false
_isPrimitive(5)
+// true
+
+_isPrimitive({ a: 'a' })
+// false

Best specification is the source code:

ts
export function _isPrimitive(v: any): v is null | undefined | number | boolean | string {
+  return (
+    v === null ||
+    v === undefined ||
+    typeof v === 'number' ||
+    typeof v === 'boolean' ||
+    typeof v === 'string'
+  )
+}
export function _isPrimitive(v: any): v is null | undefined | number | boolean | string {
+  return (
+    v === null ||
+    v === undefined ||
+    typeof v === 'number' ||
+    typeof v === 'boolean' ||
+    typeof v === 'string'
+  )
+}

_isEmpty

Object is considered empty if it's one of:

  • undefined
  • '' (empty string)
  • [] (empty array)
  • {} (empty object)
  • new Map() (empty Map)
  • new Set() (empty Set)

_undefinedIfEmpty

Returns undefined if it's empty (according to _isEmpty() specification), otherwise returns the original object.

ts
_undefinedIfEmpty('') // undefined, because it's empty
+_undefinedIfEmpty([]) // undefined, because it's empty
+_undefinedIfEmpty(new Map()) // undefined, because it's empty
+_undefinedIfEmpty('a') // 'a', intact
+_undefinedIfEmpty(false) // false, intact
_undefinedIfEmpty('') // undefined, because it's empty
+_undefinedIfEmpty([]) // undefined, because it's empty
+_undefinedIfEmpty(new Map()) // undefined, because it's empty
+_undefinedIfEmpty('a') // 'a', intact
+_undefinedIfEmpty(false) // false, intact

_merge

Deeply merges the second object into the first one. Returns the first object (merged). Mutates the first object!

ts
const obj1 = {
+  a: 'a',
+  b: {
+    bb1: 'bb1',
+  },
+}
+
+const obj2 = {
+  b: {
+    bb2: 'bb2',
+  },
+  c: 'c',
+}
+
+_merge(obj1, obj2)
+// {
+//   a: 'a',
+//   b: {
+//     bb1: 'bb1',
+//     bb2: 'bb2',
+//   },
+//   c: 'c',
+// }
const obj1 = {
+  a: 'a',
+  b: {
+    bb1: 'bb1',
+  },
+}
+
+const obj2 = {
+  b: {
+    bb2: 'bb2',
+  },
+  c: 'c',
+}
+
+_merge(obj1, obj2)
+// {
+//   a: 'a',
+//   b: {
+//     bb1: 'bb1',
+//     bb2: 'bb2',
+//   },
+//   c: 'c',
+// }

_deepTrim

Deeply traverses the object and trims all String values found.

ts
const o = {
+  a: 'abc ',
+  b: 'c',
+  d: 12,
+  e: {
+    f: '  sd a ',
+  },
+}
+
+_deepTrim(o)
+// {
+//   a: 'abc',
+//   b: 'c',
+//   d: 12,
+//   e: {
+//     f: 'sd a',
+//   },
+// }
const o = {
+  a: 'abc ',
+  b: 'c',
+  d: 12,
+  e: {
+    f: '  sd a ',
+  },
+}
+
+_deepTrim(o)
+// {
+//   a: 'abc',
+//   b: 'c',
+//   d: 12,
+//   e: {
+//     f: 'sd a',
+//   },
+// }

_sortObjectDeep

Based on IndigoUnited/js-deep-sort-object.

Deeply traverses the object and makes it "sort-stable" (deterministic). Useful for e.g snapshot-testing, or in any place where sort-stable result is expected. Resulting object is still Equal to the original object.

  • Arrays are sorted order-preserved (!), because array order has a meaning and shouldn't be changed (!).
  • Objects are sorted by their key name.
ts
const obj = {
+  b: 'b',
+  c: ['c3', 'c1', 'c2'],
+  a: 'a',
+}
+
+_sortObjectDeep(obj)
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: ['c1', 'c2', 'c3'],
+// }
const obj = {
+  b: 'b',
+  c: ['c3', 'c1', 'c2'],
+  a: 'a',
+}
+
+_sortObjectDeep(obj)
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: ['c1', 'c2', 'c3'],
+// }

_sortObject

Allows to sort object by the list of known keys.

Example:

ts
const obj = {
+  b: 'b',
+  c: 'c',
+  extra: 'extra',
+  a: 'a',
+}
+
+_sortObject(obj, ['a', 'b', 'c'])
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: 'c',
+//   extra: 'extra',
+// }
const obj = {
+  b: 'b',
+  c: 'c',
+  extra: 'extra',
+  a: 'a',
+}
+
+_sortObject(obj, ['a', 'b', 'c'])
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: 'c',
+//   extra: 'extra',
+// }

_deepEquals

Based on epoberezkin/fast-deep-equal.

Performance-optimized function to check if objects (values) are deeply-equal to each other.

ts
const obj1 = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+// Different key order, but still equals
+const obj2 = {
+  b: {
+    bb: 'bb',
+  },
+  a: 'a',
+}
+
+const obj3 = {
+  a: 'a',
+  b: {
+    bb: 'bb3', // not equal!
+  },
+}
+
+_deepEquals(obj1, obj2) // true
+_deepEquals(obj1, obj3) // false
+_deepEquals(obj2, obj3) // false
const obj1 = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+// Different key order, but still equals
+const obj2 = {
+  b: {
+    bb: 'bb',
+  },
+  a: 'a',
+}
+
+const obj3 = {
+  a: 'a',
+  b: {
+    bb: 'bb3', // not equal!
+  },
+}
+
+_deepEquals(obj1, obj2) // true
+_deepEquals(obj1, obj3) // false
+_deepEquals(obj2, obj3) // false

_invert

Returns an Object with "inverted" keys and values.

ts
const obj = {
+  a: '1',
+  b: '2',
+}
+
+_invert(obj)
+// {
+//   '1': 'a',
+//   '2': 'b',
+// }
const obj = {
+  a: '1',
+  b: '2',
+}
+
+_invert(obj)
+// {
+//   '1': 'a',
+//   '2': 'b',
+// }

_invertMap

Returns a Map with "inverted" keys and values.

ts
const map = new Map<string, number>([
+  ['a', 1],
+  ['b', 2],
+])
+
+_invertMap(map)
+// Map
+//   1 => 'a'
+//   2 => 'b'
const map = new Map<string, number>([
+  ['a', 1],
+  ['b', 2],
+])
+
+_invertMap(map)
+// Map
+//   1 => 'a'
+//   2 => 'b'

_get, _has, _set, _unset

Gets the object value via the famous "dot-notation":

ts
const obj = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+_get(obj, 'b.bb') // 'bb'
+_has(obj, 'b.bb') // true
+_has(obj, 'b.bb2') // false
+_set(obj, 'b.bb2', 'bb2value') // sets obj.b.bb2 to 'bb2Value'
+_unset(obj, 'b.bb') // deletes obj.b.bb
const obj = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+_get(obj, 'b.bb') // 'bb'
+_has(obj, 'b.bb') // true
+_has(obj, 'b.bb2') // false
+_set(obj, 'b.bb2', 'bb2value') // sets obj.b.bb2 to 'bb2Value'
+_unset(obj, 'b.bb') // deletes obj.b.bb

_stringMapValues

Needed due to https://github.com/microsoft/TypeScript/issues/13778
Only affects typings, no runtime effect.

ts
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}

Before:

ts
const values = Object.values(map)
+// values: (string | undefined)[]
const values = Object.values(map)
+// values: (string | undefined)[]

After:

ts
const values = _stringMapValues(map)
+// values: string[]
const values = _stringMapValues(map)
+// values: string[]

_stringMapEntries

Needed due to https://github.com/microsoft/TypeScript/issues/13778
Only affects typings, no runtime effect.

ts
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}

Before:

ts
const entries = Object.entries(map)
+// entries: [string, string | undefined][]
const entries = Object.entries(map)
+// entries: [string, string | undefined][]

After:

ts
const entries = _stringMapEntries(map)
+// entries: [string, string][]
const entries = _stringMapEntries(map)
+// entries: [string, string][]
`,103),e=[o];function c(t,r,y,E,i,d){return a(),n("div",null,e)}const u=s(p,[["render",c]]);export{F as __pageData,u as default}; diff --git a/assets/object.md.4acc3c49.lean.js b/assets/object.md.4acc3c49.lean.js new file mode 100644 index 00000000..535056fd --- /dev/null +++ b/assets/object.md.4acc3c49.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Object","description":"","frontmatter":{},"headers":[],"relativePath":"object.md","filePath":"object.md"}'),p={name:"object.md"},o=l("",103),e=[o];function c(t,r,y,E,i,d){return a(),n("div",null,e)}const u=s(p,[["render",c]]);export{F as __pageData,u as default}; diff --git a/assets/promise.md.28e1b8f6.js b/assets/promise.md.28e1b8f6.js new file mode 100644 index 00000000..ce649f47 --- /dev/null +++ b/assets/promise.md.28e1b8f6.js @@ -0,0 +1,113 @@ +import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Promise","description":"","frontmatter":{},"headers":[],"relativePath":"promise.md","filePath":"promise.md"}'),l={name:"promise.md"},o=p(`

Promise

Inspired by bluebird and Sindre's promise-fun packages.

"Copy-pasted" (with small adjustments) here, because:

  1. Bluebird is outdated (pre-ES6)

  2. p-* packages are amazing, but not all of them are needed. Some of them are very much needed though.

  3. To fix issues with Types. Here, everything is TypeScript, so, first class support and sync.

  4. To fix issues with IDE auto-imports, which is still quite bad for "default exported" packages.

Downside is that (as every fork) we lose "auto-update" possibility from these packages. We believe it's not as bad, because packages imported here have mature API and stability (example: pMap).

pMap

Based on p-map

Allows to asynchronously map an array of Promises, with options to:

  • control concurrency (default: Infinity)
  • control error behavior (ErrorMode):
    • THROW_IMMEDIATELY (default)
    • THROW_AGGREGATED: throw AggregateError in the end of execution, if at least 1 error happened
    • SUPPRESS: completely suppress (ignore) errors
ts
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+const results = await pMap(promises, async r => { ... }, {
+  concurrency: 2,
+  errorMode: ErrorMode.SUPPRESS,
+})
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+const results = await pMap(promises, async r => { ... }, {
+  concurrency: 2,
+  errorMode: ErrorMode.SUPPRESS,
+})

pProps

Based on p-props

Syntax-sugar to concurrently execute multiple promises and map their results to named properties.

Before:

ts
const [r1, r2, r3] = await Promise.all([
+  fetch(...),
+  fetch(...),
+  fetch(...),
+])
const [r1, r2, r3] = await Promise.all([
+  fetch(...),
+  fetch(...),
+  fetch(...),
+])

After:

ts
const {r1, r2, r3} = await pProps({
+  r1: fetch(...),
+  r2: fetch(...),
+  r3: fetch(...),
+})
const {r1, r2, r3} = await pProps({
+  r1: fetch(...),
+  r2: fetch(...),
+  r3: fetch(...),
+})

pFilter

Based on p-filter

Allows to asynchrously filter an array of Promises.

ts
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+
+const results = await pFilter(promises, async r => (await r.json()).success)
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+
+const results = await pFilter(promises, async r => (await r.json()).success)

pDefer

Allows to create a "ResolvablePromise", which is a normal native Promise (so, can be awaited, etc), extended with .resolve() and .reject() methods, so you can control it. Similar to jQuery's Deferred, or RxJS's Subject (which is both an Observable and allows to emit values).

Sometimes useful to "promisify" a callback-style API.

ts
async function run(): Promise<string> {
+  const defer = pDefer<string>()
+
+  someOldApi(
+    (result: string) => {
+      defer.resolve(result)
+    },
+    err => defer.reject(err),
+  )
+
+  return await defer.promise
+}
async function run(): Promise<string> {
+  const defer = pDefer<string>()
+
+  someOldApi(
+    (result: string) => {
+      defer.resolve(result)
+    },
+    err => defer.reject(err),
+  )
+
+  return await defer.promise
+}

pDelay

Based on p-delay

Just a fancy async/await style setTimeout

Before:

ts
await new Promise(resolve => setTimeout(resolve, 500))
await new Promise(resolve => setTimeout(resolve, 500))

After:

ts
await pDelay(500)
await pDelay(500)

Allows to return a value:

ts
const res = await pDelay(500, 'hello')
+// hello
const res = await pDelay(500, 'hello')
+// hello

pRetry

Based on p-retry

Returns a Function (!), enhanced with retry capabilities.

Simplest example:

ts
const save = pRetry(async () => await dao.save())
+
+await save()
+// will retry 3 times, with default delay of 1 second and exponential back-off (x2 delay multiplier)
const save = pRetry(async () => await dao.save())
+
+await save()
+// will retry 3 times, with default delay of 1 second and exponential back-off (x2 delay multiplier)

Advanced example (with options):

ts
const save = pRetry(async () => await dao.save(), {
+  maxAttempts: 5,
+  predicate: err => err?.message.includes('GOAWAY'),
+})
+
+await save()
+// will try up to 5 times, but only if err.message contains GOAWAY
const save = pRetry(async () => await dao.save(), {
+  maxAttempts: 5,
+  predicate: err => err?.message.includes('GOAWAY'),
+})
+
+await save()
+// will try up to 5 times, but only if err.message contains GOAWAY

pTimeoutFn

Based on p-timeout

Decorates a Function with a timeout.

Throws an Error if the Function is not resolved in a certain time.

If the Function rejects - passes this rejection further.

ts
const decoratedFn = pTimeout(someFunction, { timeout: 1000 })
+
+await decoratedFn()
+// will throw Timeout error if \`someFunction\` is not finished in 1000 ms.
+// otherwise will pass
const decoratedFn = pTimeout(someFunction, { timeout: 1000 })
+
+await decoratedFn()
+// will throw Timeout error if \`someFunction\` is not finished in 1000 ms.
+// otherwise will pass

pHang

Syntax-sugar for returning a never-resolving ("hung") Promise.

Has semantic meaning, telling us that this Promise is meant to never get resolved or rejected.

Before:

ts
return new Promise()
return new Promise()

After:

ts
return pHang()
return pHang()

Useful e.g when you do location.reload() (let's say, you want to reload the page after being logged-in as an Admin) and want your BlockingLoader to never stop spinning:

ts
async function adminLogin(): Promise<void> {
+  location.href = '/admin'
+  return pHang()
+}
async function adminLogin(): Promise<void> {
+  location.href = '/admin'
+  return pHang()
+}

pState

Returns Promise's "state" as a String, one of:

  • pending
  • resolved
  • rejected
ts
const p = new Promise()
+await pState(p)
+// 'pending'
+
+const p = new Promise.resolve()
+await pState(p)
+// 'resolved'
const p = new Promise()
+await pState(p)
+// 'pending'
+
+const p = new Promise.resolve()
+await pState(p)
+// 'resolved'
`,60),e=[o];function t(r,c,y,E,i,d){return a(),n("div",null,e)}const u=s(l,[["render",t]]);export{F as __pageData,u as default}; diff --git a/assets/promise.md.28e1b8f6.lean.js b/assets/promise.md.28e1b8f6.lean.js new file mode 100644 index 00000000..fe388279 --- /dev/null +++ b/assets/promise.md.28e1b8f6.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Promise","description":"","frontmatter":{},"headers":[],"relativePath":"promise.md","filePath":"promise.md"}'),l={name:"promise.md"},o=p("",60),e=[o];function t(r,c,y,E,i,d){return a(),n("div",null,e)}const u=s(l,[["render",t]]);export{F as __pageData,u as default}; diff --git a/assets/string.md.68f834bf.js b/assets/string.md.68f834bf.js new file mode 100644 index 00000000..38365609 --- /dev/null +++ b/assets/string.md.68f834bf.js @@ -0,0 +1,69 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const u=JSON.parse('{"title":"String","description":"","frontmatter":{},"headers":[],"relativePath":"string.md","filePath":"string.md"}'),e={name:"string.md"},p=l(`

String

_capitalize

Capitalizes first char, lowercases the rest of the string.

ts
_capitalize('hello') // Hello
+_capitalize('HELLO') // HELLO (no change)
+_capitalize('hello world') // Hello world
_capitalize('hello') // Hello
+_capitalize('HELLO') // HELLO (no change)
+_capitalize('hello world') // Hello world

_upperFirst

Uppercases first char.

ts
_upperFirst('hello') // Hello
+_upperFirst('HELLO') // HELLO (no change)
+_upperFirst('hELLO') // HELLO
_upperFirst('hello') // Hello
+_upperFirst('HELLO') // HELLO (no change)
+_upperFirst('hELLO') // HELLO

_lowerFirst

Lowercases first char.

ts
_lowerFirst('Hello') // hello
+_lowerFirst('hello') // hello (no change)
+_lowerFirst('HELLO') // hELLO
_lowerFirst('Hello') // hello
+_lowerFirst('hello') // hello (no change)
+_lowerFirst('HELLO') // hELLO

_camelCase 🐪

Transforms the input string to camelCase 🐪. Implementation adapted from Lodash.

ts
_camelCase('la la la')
+_camelCase('la_la_la')
+_camelCase('la-la-la')
+// laLaLa
_camelCase('la la la')
+_camelCase('la_la_la')
+_camelCase('la-la-la')
+// laLaLa

_snakeCase 🐍

Transforms the input string to snake_case 🐍. Implementation adapted from Lodash.

ts
_snakeCase('la la la')
+_snakeCase('la-la-la')
+_snakeCase('laLaLa')
+// la_la_la
_snakeCase('la la la')
+_snakeCase('la-la-la')
+_snakeCase('laLaLa')
+// la_la_la

_kebabCase 🥙

Transforms the input string to kebab-case 🥙. Implementation adapted from Lodash.

ts
_kebabCase('la la la')
+_kebabCase('la_la_la')
+_kebabCase('laLaLa')
+// la-la-la
_kebabCase('la la la')
+_kebabCase('la_la_la')
+_kebabCase('laLaLa')
+// la-la-la

_split

Like String.split, but with the limited number of tokens.

ts
_split('a_b_c', '_', 2)
+// ['a', 'b_c']
_split('a_b_c', '_', 2)
+// ['a', 'b_c']

_substringBefore

ts
_substringBefore('file1.test.ts', '.')
+// 'file1'
+
+_substringBefore('file1.test.ts', '.ts')
+// 'file1.test'
_substringBefore('file1.test.ts', '.')
+// 'file1'
+
+_substringBefore('file1.test.ts', '.ts')
+// 'file1.test'

_substringBeforeLast

ts
_substringBeforeLast('file1.test.ts', '.')
+// 'file1.test'
_substringBeforeLast('file1.test.ts', '.')
+// 'file1.test'

_substringAfter

ts
_substringAfter('file1.test.ts', '.')
+// 'test.ts'
_substringAfter('file1.test.ts', '.')
+// 'test.ts'

_substringAfterLast

ts
_substringAfterLast('file1.test.ts', '.')
+// 'ts'
_substringAfterLast('file1.test.ts', '.')
+// 'ts'

_substringBetweenLast

ts
const s = '/Users/lalala/someFile.test.ts'
+_substringBetweenLast(s, '/', '.'))
+// 'someFile'
const s = '/Users/lalala/someFile.test.ts'
+_substringBetweenLast(s, '/', '.'))
+// 'someFile'

_truncate

Truncates the string to the needed length, putting ... (or a custom "ending") in the end, if needed. The maxLen (second argument) includes the "ending string" (3rd argument).

ts
_truncate('Hello World!', 5) // 'He...'
+_truncate('Hello World!', 6) // 'Hel...'
+_truncate('Hello World!', 100) // 'Hello World!' (no truncation needed)
+
+// Custom "ending"
+_truncate('Hello World!', 5, '|') // 'Hell|'
_truncate('Hello World!', 5) // 'He...'
+_truncate('Hello World!', 6) // 'Hel...'
+_truncate('Hello World!', 100) // 'Hello World!' (no truncation needed)
+
+// Custom "ending"
+_truncate('Hello World!', 5, '|') // 'Hell|'

_truncateMiddle

Truncates the string in the middle.

ts
_truncateMiddle('abcdefghijklmnopqrstuvwxyz', 10)
+// 'abcd...xyz'
_truncateMiddle('abcdefghijklmnopqrstuvwxyz', 10)
+// 'abcd...xyz'

_replaceAll

Polyfill for String.prototype.replaceAll.

Based on regex implementation (slightly faster than "split/join" implementation).

_nl2br

Converts \\n (aka new-line) to <br>, to be presented in HTML.

Keeps \\n, so if it's printed in non-HTML environment it still looks ok-ish.

_parseQueryString

Parses location.search string (e.g ?a=1&b=2) into a StringMap, e.g: { a: '1', b: '2' }

Pass location.search to it in the Frontend, or any other string on the Backend (where location.search is not available).

Works both with and without leading ? character.

Yes, there's URLSearchParams existing in the Frontend (not in Node yet), but it's API is not as convenient. And the implementation here is super-small.

Goal of this function is to produce exactly same output as URLSearchParams would.

ts
// Assuming url is http://example.com?a=1&b=2
+
+_parseQueryString(location.search)
+// { a: '1', b: '2' }
// Assuming url is http://example.com?a=1&b=2
+
+_parseQueryString(location.search)
+// { a: '1', b: '2' }
`,51),o=[p];function t(c,r,i,y,E,d){return a(),n("div",null,o)}const F=s(e,[["render",t]]);export{u as __pageData,F as default}; diff --git a/assets/string.md.68f834bf.lean.js b/assets/string.md.68f834bf.lean.js new file mode 100644 index 00000000..78488ec4 --- /dev/null +++ b/assets/string.md.68f834bf.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const u=JSON.parse('{"title":"String","description":"","frontmatter":{},"headers":[],"relativePath":"string.md","filePath":"string.md"}'),e={name:"string.md"},p=l("",51),o=[p];function t(c,r,i,y,E,d){return a(),n("div",null,o)}const F=s(e,[["render",t]]);export{u as __pageData,F as default}; diff --git a/assets/style.d9da1fab.css b/assets/style.d9da1fab.css new file mode 100644 index 00000000..a8bff9b1 --- /dev/null +++ b/assets/style.d9da1fab.css @@ -0,0 +1 @@ +@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-cyrillic.5f2c6c8c.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-cyrillic-ext.e75737ce.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-greek.d5a6d92a.woff2) format("woff2");unicode-range:U+0370-03FF}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-greek-ext.ab0619bc.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-latin.2ed14f66.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-latin-ext.0030eebd.woff2) format("woff2");unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:normal;font-named-instance:"Regular";src:url(/js-lib/assets/inter-roman-vietnamese.14ce25a6.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-cyrillic.ea42a392.woff2) format("woff2");unicode-range:U+0301,U+0400-045F,U+0490-0491,U+04B0-04B1,U+2116}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-cyrillic-ext.33bd5a8e.woff2) format("woff2");unicode-range:U+0460-052F,U+1C80-1C88,U+20B4,U+2DE0-2DFF,U+A640-A69F,U+FE2E-FE2F}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-greek.8f4463c4.woff2) format("woff2");unicode-range:U+0370-03FF}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-greek-ext.4fbe9427.woff2) format("woff2");unicode-range:U+1F00-1FFF}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-latin.bd3b6f56.woff2) format("woff2");unicode-range:U+0000-00FF,U+0131,U+0152-0153,U+02BB-02BC,U+02C6,U+02DA,U+02DC,U+2000-206F,U+2074,U+20AC,U+2122,U+2191,U+2193,U+2212,U+2215,U+FEFF,U+FFFD}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-latin-ext.bd8920cc.woff2) format("woff2");unicode-range:U+0100-024F,U+0259,U+1E00-1EFF,U+2020,U+20A0-20AB,U+20AD-20CF,U+2113,U+2C60-2C7F,U+A720-A7FF}@font-face{font-family:Inter var;font-weight:100 900;font-display:swap;font-style:italic;font-named-instance:"Italic";src:url(/js-lib/assets/inter-italic-vietnamese.6ce511fb.woff2) format("woff2");unicode-range:U+0102-0103,U+0110-0111,U+0128-0129,U+0168-0169,U+01A0-01A1,U+01AF-01B0,U+1EA0-1EF9,U+20AB}@font-face{font-family:Chinese Quotes;src:local("PingFang SC Regular"),local("PingFang SC"),local("SimHei"),local("Source Han Sans SC");unicode-range:U+2018,U+2019,U+201C,U+201D}:root{--vp-c-white: #ffffff;--vp-c-black: #000000;--vp-c-neutral: var(--vp-c-black);--vp-c-neutral-inverse: var(--vp-c-white)}.dark{--vp-c-neutral: var(--vp-c-white);--vp-c-neutral-inverse: var(--vp-c-black)}:root{--vp-c-gray-1: #dddde3;--vp-c-gray-2: #e4e4e9;--vp-c-gray-3: #ebebef;--vp-c-gray-soft: rgba(142, 150, 170, .14);--vp-c-indigo-1: #3451b2;--vp-c-indigo-2: #3a5ccc;--vp-c-indigo-3: #5672cd;--vp-c-indigo-soft: rgba(100, 108, 255, .14);--vp-c-green-1: #18794e;--vp-c-green-2: #299764;--vp-c-green-3: #30a46c;--vp-c-green-soft: rgba(16, 185, 129, .14);--vp-c-yellow-1: #915930;--vp-c-yellow-2: #946300;--vp-c-yellow-3: #9f6a00;--vp-c-yellow-soft: rgba(234, 179, 8, .14);--vp-c-red-1: #b8272c;--vp-c-red-2: #d5393e;--vp-c-red-3: #e0575b;--vp-c-red-soft: rgba(244, 63, 94, .14);--vp-c-sponsor: #db2777}.dark{--vp-c-gray-1: #515c67;--vp-c-gray-2: #414853;--vp-c-gray-3: #32363f;--vp-c-gray-soft: rgba(101, 117, 133, .16);--vp-c-indigo-1: #a8b1ff;--vp-c-indigo-2: #5c73e7;--vp-c-indigo-3: #3e63dd;--vp-c-indigo-soft: rgba(100, 108, 255, .16);--vp-c-green-1: #3dd68c;--vp-c-green-2: #30a46c;--vp-c-green-3: #298459;--vp-c-green-soft: rgba(16, 185, 129, .16);--vp-c-yellow-1: #f9b44e;--vp-c-yellow-2: #da8b17;--vp-c-yellow-3: #a46a0a;--vp-c-yellow-soft: rgba(234, 179, 8, .16);--vp-c-red-1: #f66f81;--vp-c-red-2: #f14158;--vp-c-red-3: #b62a3c;--vp-c-red-soft: rgba(244, 63, 94, .16)}:root{--vp-c-bg: #ffffff;--vp-c-bg-alt: #f6f6f7;--vp-c-bg-elv: #ffffff;--vp-c-bg-soft: #f6f6f7}.dark{--vp-c-bg: #1b1b1f;--vp-c-bg-alt: #161618;--vp-c-bg-elv: #202127;--vp-c-bg-soft: #202127}:root{--vp-c-border: #c2c2c4;--vp-c-divider: #e2e2e3;--vp-c-gutter: #e2e2e3}.dark{--vp-c-border: #3c3f44;--vp-c-divider: #2e2e32;--vp-c-gutter: #000000}:root{--vp-c-text-1: rgba(60, 60, 67);--vp-c-text-2: rgba(60, 60, 67, .78);--vp-c-text-3: rgba(60, 60, 67, .56)}.dark{--vp-c-text-1: rgba(255, 255, 245, .86);--vp-c-text-2: rgba(235, 235, 245, .6);--vp-c-text-3: rgba(235, 235, 245, .38)}:root{--vp-c-default-1: var(--vp-c-gray-1);--vp-c-default-2: var(--vp-c-gray-2);--vp-c-default-3: var(--vp-c-gray-3);--vp-c-default-soft: var(--vp-c-gray-soft);--vp-c-brand-1: var(--vp-c-indigo-1);--vp-c-brand-2: var(--vp-c-indigo-2);--vp-c-brand-3: var(--vp-c-indigo-3);--vp-c-brand-soft: var(--vp-c-indigo-soft);--vp-c-brand: var(--vp-c-brand-1);--vp-c-tip-1: var(--vp-c-brand-1);--vp-c-tip-2: var(--vp-c-brand-2);--vp-c-tip-3: var(--vp-c-brand-3);--vp-c-tip-soft: var(--vp-c-brand-soft);--vp-c-warning-1: var(--vp-c-yellow-1);--vp-c-warning-2: var(--vp-c-yellow-2);--vp-c-warning-3: var(--vp-c-yellow-3);--vp-c-warning-soft: var(--vp-c-yellow-soft);--vp-c-danger-1: var(--vp-c-red-1);--vp-c-danger-2: var(--vp-c-red-2);--vp-c-danger-3: var(--vp-c-red-3);--vp-c-danger-soft: var(--vp-c-red-soft)}:root{--vp-font-family-base: "Chinese Quotes", "Inter var", "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Helvetica, Arial, "Noto Sans", sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--vp-font-family-mono: ui-monospace, SFMono-Regular, "SF Mono", Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace}:root{--vp-shadow-1: 0 1px 2px rgba(0, 0, 0, .04), 0 1px 2px rgba(0, 0, 0, .06);--vp-shadow-2: 0 3px 12px rgba(0, 0, 0, .07), 0 1px 4px rgba(0, 0, 0, .07);--vp-shadow-3: 0 12px 32px rgba(0, 0, 0, .1), 0 2px 6px rgba(0, 0, 0, .08);--vp-shadow-4: 0 14px 44px rgba(0, 0, 0, .12), 0 3px 9px rgba(0, 0, 0, .12);--vp-shadow-5: 0 18px 56px rgba(0, 0, 0, .16), 0 4px 12px rgba(0, 0, 0, .16)}:root{--vp-z-index-footer: 10;--vp-z-index-local-nav: 20;--vp-z-index-nav: 30;--vp-z-index-layout-top: 40;--vp-z-index-backdrop: 50;--vp-z-index-sidebar: 60}:root{--vp-icon-copy: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' height='20' width='20' stroke='rgba(128,128,128,1)' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M9 5H7a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2h-2M9 5a2 2 0 0 0 2 2h2a2 2 0 0 0 2-2M9 5a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2'/%3E%3C/svg%3E");--vp-icon-copied: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' height='20' width='20' stroke='rgba(128,128,128,1)' stroke-width='2' viewBox='0 0 24 24'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M9 5H7a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h10a2 2 0 0 0 2-2V7a2 2 0 0 0-2-2h-2M9 5a2 2 0 0 0 2 2h2a2 2 0 0 0 2-2M9 5a2 2 0 0 1 2-2h2a2 2 0 0 1 2 2m-6 9 2 2 4-4'/%3E%3C/svg%3E")}:root{--vp-layout-max-width: 1440px}:root{--vp-header-anchor-symbol: "#"}:root{--vp-code-line-height: 1.7;--vp-code-font-size: .875em;--vp-code-color: var(--vp-c-brand-1);--vp-code-link-color: var(--vp-c-brand-1);--vp-code-link-hover-color: var(--vp-c-brand-2);--vp-code-bg: var(--vp-c-default-soft);--vp-code-block-color: var(--vp-c-text-2);--vp-code-block-bg: var(--vp-c-bg-alt);--vp-code-block-divider-color: var(--vp-c-gutter);--vp-code-lang-color: var(--vp-c-text-3);--vp-code-line-highlight-color: var(--vp-c-default-soft);--vp-code-line-number-color: var(--vp-c-text-3);--vp-code-line-diff-add-color: var(--vp-c-green-soft);--vp-code-line-diff-add-symbol-color: var(--vp-c-green-1);--vp-code-line-diff-remove-color: var(--vp-c-red-soft);--vp-code-line-diff-remove-symbol-color: var(--vp-c-red-1);--vp-code-line-warning-color: var(--vp-c-yellow-soft);--vp-code-line-error-color: var(--vp-c-red-soft);--vp-code-copy-code-border-color: var(--vp-c-divider);--vp-code-copy-code-bg: var(--vp-c-bg-soft);--vp-code-copy-code-hover-border-color: var(--vp-c-divider);--vp-code-copy-code-hover-bg: var(--vp-c-bg);--vp-code-copy-code-active-text: var(--vp-c-text-2);--vp-code-copy-copied-text-content: "Copied";--vp-code-tab-divider: var(--vp-code-block-divider-color);--vp-code-tab-text-color: var(--vp-c-text-2);--vp-code-tab-bg: var(--vp-code-block-bg);--vp-code-tab-hover-text-color: var(--vp-c-text-1);--vp-code-tab-active-text-color: var(--vp-c-text-1);--vp-code-tab-active-bar-color: var(--vp-c-brand-1)}:root{--vp-button-brand-border: transparent;--vp-button-brand-text: var(--vp-c-white);--vp-button-brand-bg: var(--vp-c-brand-3);--vp-button-brand-hover-border: transparent;--vp-button-brand-hover-text: var(--vp-c-white);--vp-button-brand-hover-bg: var(--vp-c-brand-2);--vp-button-brand-active-border: transparent;--vp-button-brand-active-text: var(--vp-c-white);--vp-button-brand-active-bg: var(--vp-c-brand-1);--vp-button-alt-border: transparent;--vp-button-alt-text: var(--vp-c-text-1);--vp-button-alt-bg: var(--vp-c-default-3);--vp-button-alt-hover-border: transparent;--vp-button-alt-hover-text: var(--vp-c-text-1);--vp-button-alt-hover-bg: var(--vp-c-default-2);--vp-button-alt-active-border: transparent;--vp-button-alt-active-text: var(--vp-c-text-1);--vp-button-alt-active-bg: var(--vp-c-default-1);--vp-button-sponsor-border: var(--vp-c-text-2);--vp-button-sponsor-text: var(--vp-c-text-2);--vp-button-sponsor-bg: transparent;--vp-button-sponsor-hover-border: var(--vp-c-sponsor);--vp-button-sponsor-hover-text: var(--vp-c-sponsor);--vp-button-sponsor-hover-bg: transparent;--vp-button-sponsor-active-border: var(--vp-c-sponsor);--vp-button-sponsor-active-text: var(--vp-c-sponsor);--vp-button-sponsor-active-bg: transparent}:root{--vp-custom-block-font-size: 14px;--vp-custom-block-code-font-size: 13px;--vp-custom-block-info-border: transparent;--vp-custom-block-info-text: var(--vp-c-text-1);--vp-custom-block-info-bg: var(--vp-c-default-soft);--vp-custom-block-info-code-bg: var(--vp-c-default-soft);--vp-custom-block-tip-border: transparent;--vp-custom-block-tip-text: var(--vp-c-text-1);--vp-custom-block-tip-bg: var(--vp-c-brand-soft);--vp-custom-block-tip-code-bg: var(--vp-c-brand-soft);--vp-custom-block-warning-border: transparent;--vp-custom-block-warning-text: var(--vp-c-text-1);--vp-custom-block-warning-bg: var(--vp-c-warning-soft);--vp-custom-block-warning-code-bg: var(--vp-c-warning-soft);--vp-custom-block-danger-border: transparent;--vp-custom-block-danger-text: var(--vp-c-text-1);--vp-custom-block-danger-bg: var(--vp-c-danger-soft);--vp-custom-block-danger-code-bg: var(--vp-c-danger-soft);--vp-custom-block-details-border: var(--vp-custom-block-info-border);--vp-custom-block-details-text: var(--vp-custom-block-info-text);--vp-custom-block-details-bg: var(--vp-custom-block-info-bg);--vp-custom-block-details-code-bg: var(--vp-custom-block-info-code-bg)}:root{--vp-input-border-color: var(--vp-c-border);--vp-input-bg-color: var(--vp-c-bg-alt);--vp-input-switch-bg-color: var(--vp-c-gray-soft)}:root{--vp-nav-height: 64px;--vp-nav-bg-color: var(--vp-c-bg);--vp-nav-screen-bg-color: var(--vp-c-bg);--vp-nav-logo-height: 24px}.hide-nav{--vp-nav-height: 0px}.hide-nav .VPSidebar{--vp-nav-height: 22px}:root{--vp-local-nav-bg-color: var(--vp-c-bg)}:root{--vp-sidebar-width: 272px;--vp-sidebar-bg-color: var(--vp-c-bg-alt)}:root{--vp-backdrop-bg-color: rgba(0, 0, 0, .6)}:root{--vp-home-hero-name-color: var(--vp-c-brand-1);--vp-home-hero-name-background: transparent;--vp-home-hero-image-background-image: none;--vp-home-hero-image-filter: none}:root{--vp-badge-info-border: transparent;--vp-badge-info-text: var(--vp-c-text-2);--vp-badge-info-bg: var(--vp-c-default-soft);--vp-badge-tip-border: transparent;--vp-badge-tip-text: var(--vp-c-brand-1);--vp-badge-tip-bg: var(--vp-c-brand-soft);--vp-badge-warning-border: transparent;--vp-badge-warning-text: var(--vp-c-warning-1);--vp-badge-warning-bg: var(--vp-c-warning-soft);--vp-badge-danger-border: transparent;--vp-badge-danger-text: var(--vp-c-danger-1);--vp-badge-danger-bg: var(--vp-c-danger-soft)}:root{--vp-carbon-ads-text-color: var(--vp-c-text-1);--vp-carbon-ads-poweredby-color: var(--vp-c-text-2);--vp-carbon-ads-bg-color: var(--vp-c-bg-soft);--vp-carbon-ads-hover-text-color: var(--vp-c-brand-1);--vp-carbon-ads-hover-poweredby-color: var(--vp-c-text-1)}:root{--vp-local-search-bg: var(--vp-c-bg);--vp-local-search-result-bg: var(--vp-c-bg);--vp-local-search-result-border: var(--vp-c-divider);--vp-local-search-result-selected-bg: var(--vp-c-bg);--vp-local-search-result-selected-border: var(--vp-c-brand-1);--vp-local-search-highlight-bg: var(--vp-c-brand-1);--vp-local-search-highlight-text: var(--vp-c-neutral-inverse)}@media (prefers-reduced-motion: reduce){*,:before,:after{animation-delay:-1ms!important;animation-duration:1ms!important;animation-iteration-count:1!important;background-attachment:initial!important;scroll-behavior:auto!important;transition-duration:0s!important;transition-delay:0s!important}}*,:before,:after{box-sizing:border-box}html{line-height:1.4;font-size:16px;-webkit-text-size-adjust:100%}html.dark{color-scheme:dark}body{margin:0;width:100%;min-width:320px;min-height:100vh;line-height:24px;font-family:var(--vp-font-family-base);font-size:16px;font-weight:400;color:var(--vp-c-text-1);background-color:var(--vp-c-bg);direction:ltr;font-synthesis:style;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}main{display:block}h1,h2,h3,h4,h5,h6{margin:0;line-height:24px;font-size:16px;font-weight:400}p{margin:0}strong,b{font-weight:600}a,area,button,[role=button],input,label,select,summary,textarea{touch-action:manipulation}a{color:inherit;text-decoration:inherit}ol,ul{list-style:none;margin:0;padding:0}blockquote{margin:0}pre,code,kbd,samp{font-family:var(--vp-font-family-mono)}img,svg,video,canvas,audio,iframe,embed,object{display:block}figure{margin:0}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{border:0;padding:0;line-height:inherit;color:inherit}button{padding:0;font-family:inherit;background-color:transparent;background-image:none}button:enabled,[role=button]:enabled{cursor:pointer}button:focus,button:focus-visible{outline:1px dotted;outline:4px auto -webkit-focus-ring-color}button:focus:not(:focus-visible){outline:none!important}input:focus,textarea:focus,select:focus{outline:none}table{border-collapse:collapse}input{background-color:transparent}input:-ms-input-placeholder,textarea:-ms-input-placeholder{color:var(--vp-c-text-3)}input::-ms-input-placeholder,textarea::-ms-input-placeholder{color:var(--vp-c-text-3)}input::placeholder,textarea::placeholder{color:var(--vp-c-text-3)}input::-webkit-outer-spin-button,input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}textarea{resize:vertical}select{-webkit-appearance:none}fieldset{margin:0;padding:0}h1,h2,h3,h4,h5,h6,li,p{overflow-wrap:break-word}vite-error-overlay{z-index:9999}mjx-container{display:inline-block;margin:auto 2px -2px}mjx-container>svg{margin:auto}.visually-hidden{position:absolute;width:1px;height:1px;white-space:nowrap;clip:rect(0 0 0 0);clip-path:inset(50%);overflow:hidden}.custom-block{border:1px solid transparent;border-radius:8px;padding:16px 16px 8px;line-height:24px;font-size:var(--vp-custom-block-font-size);color:var(--vp-c-text-2)}.custom-block.info{border-color:var(--vp-custom-block-info-border);color:var(--vp-custom-block-info-text);background-color:var(--vp-custom-block-info-bg)}.custom-block.info a,.custom-block.info code{color:var(--vp-c-brand-1)}.custom-block.info a:hover{color:var(--vp-c-brand-2)}.custom-block.info code{background-color:var(--vp-custom-block-info-code-bg)}.custom-block.tip{border-color:var(--vp-custom-block-tip-border);color:var(--vp-custom-block-tip-text);background-color:var(--vp-custom-block-tip-bg)}.custom-block.tip a,.custom-block.tip code{color:var(--vp-c-brand-1)}.custom-block.tip a:hover{color:var(--vp-c-brand-2)}.custom-block.tip code{background-color:var(--vp-custom-block-tip-code-bg)}.custom-block.warning{border-color:var(--vp-custom-block-warning-border);color:var(--vp-custom-block-warning-text);background-color:var(--vp-custom-block-warning-bg)}.custom-block.warning a,.custom-block.warning code{color:var(--vp-c-warning-1)}.custom-block.warning a:hover{color:var(--vp-c-warning-2)}.custom-block.warning code{background-color:var(--vp-custom-block-warning-code-bg)}.custom-block.danger{border-color:var(--vp-custom-block-danger-border);color:var(--vp-custom-block-danger-text);background-color:var(--vp-custom-block-danger-bg)}.custom-block.danger a,.custom-block.danger code{color:var(--vp-c-danger-1)}.custom-block.danger a:hover{color:var(--vp-c-danger-2)}.custom-block.danger code{background-color:var(--vp-custom-block-danger-code-bg)}.custom-block.details{border-color:var(--vp-custom-block-details-border);color:var(--vp-custom-block-details-text);background-color:var(--vp-custom-block-details-bg)}.custom-block.details a{color:var(--vp-c-brand-1)}.custom-block.details a:hover{color:var(--vp-c-brand-2)}.custom-block.details code{background-color:var(--vp-custom-block-details-code-bg)}.custom-block-title{font-weight:600}.custom-block p+p{margin:8px 0}.custom-block.details summary{margin:0 0 8px;font-weight:700;cursor:pointer}.custom-block.details summary+p{margin:8px 0}.custom-block a{color:inherit;font-weight:600;text-decoration:underline;text-underline-offset:2px;transition:opacity .25s}.custom-block a:hover{opacity:.75}.custom-block code{font-size:var(--vp-custom-block-code-font-size)}.custom-block.custom-block th,.custom-block.custom-block blockquote>p{font-size:var(--vp-custom-block-font-size);color:inherit}.dark .vp-code-light{display:none}html:not(.dark) .vp-code-dark{display:none}.vp-code-group{margin-top:16px}.vp-code-group .tabs{position:relative;display:flex;margin-right:-24px;margin-left:-24px;padding:0 12px;background-color:var(--vp-code-tab-bg);overflow-x:auto;overflow-y:hidden;box-shadow:inset 0 -1px var(--vp-code-tab-divider)}@media (min-width: 640px){.vp-code-group .tabs{margin-right:0;margin-left:0;border-radius:8px 8px 0 0}}.vp-code-group .tabs input{position:fixed;opacity:0;pointer-events:none}.vp-code-group .tabs label{position:relative;display:inline-block;border-bottom:1px solid transparent;padding:0 12px;line-height:48px;font-size:14px;font-weight:500;color:var(--vp-code-tab-text-color);white-space:nowrap;cursor:pointer;transition:color .25s}.vp-code-group .tabs label:after{position:absolute;right:8px;bottom:-1px;left:8px;z-index:1;height:2px;border-radius:2px;content:"";background-color:transparent;transition:background-color .25s}.vp-code-group label:hover{color:var(--vp-code-tab-hover-text-color)}.vp-code-group input:checked+label{color:var(--vp-code-tab-active-text-color)}.vp-code-group input:checked+label:after{background-color:var(--vp-code-tab-active-bar-color)}.vp-code-group div[class*=language-],.vp-block{display:none;margin-top:0!important;border-top-left-radius:0!important;border-top-right-radius:0!important}.vp-code-group div[class*=language-].active,.vp-block.active{display:block}.vp-block{padding:20px 24px}.vp-doc h1,.vp-doc h2,.vp-doc h3,.vp-doc h4,.vp-doc h5,.vp-doc h6{position:relative;font-weight:600;outline:none}.vp-doc h1{letter-spacing:-.02em;line-height:40px;font-size:28px}.vp-doc h2{margin:48px 0 16px;border-top:1px solid var(--vp-c-divider);padding-top:24px;letter-spacing:-.02em;line-height:32px;font-size:24px}.vp-doc h3{margin:32px 0 0;letter-spacing:-.01em;line-height:28px;font-size:20px}.vp-doc .header-anchor{position:absolute;top:0;left:0;margin-left:-.87em;font-weight:500;-webkit-user-select:none;user-select:none;opacity:0;text-decoration:none;transition:color .25s,opacity .25s}.vp-doc .header-anchor:before{content:var(--vp-header-anchor-symbol)}.vp-doc h1:hover .header-anchor,.vp-doc h1 .header-anchor:focus,.vp-doc h2:hover .header-anchor,.vp-doc h2 .header-anchor:focus,.vp-doc h3:hover .header-anchor,.vp-doc h3 .header-anchor:focus,.vp-doc h4:hover .header-anchor,.vp-doc h4 .header-anchor:focus,.vp-doc h5:hover .header-anchor,.vp-doc h5 .header-anchor:focus,.vp-doc h6:hover .header-anchor,.vp-doc h6 .header-anchor:focus{opacity:1}@media (min-width: 768px){.vp-doc h1{letter-spacing:-.02em;line-height:40px;font-size:32px}}.vp-doc h2 .header-anchor{top:24px}.vp-doc p,.vp-doc summary{margin:16px 0}.vp-doc p{line-height:28px}.vp-doc blockquote{margin:16px 0;border-left:2px solid var(--vp-c-divider);padding-left:16px;transition:border-color .5s}.vp-doc blockquote>p{margin:0;font-size:16px;color:var(--vp-c-text-2);transition:color .5s}.vp-doc a{font-weight:500;color:var(--vp-c-brand-1);text-decoration:underline;text-underline-offset:2px;transition:color .25s,opacity .25s}.vp-doc a:hover{color:var(--vp-c-brand-2)}.vp-doc strong{font-weight:600}.vp-doc ul,.vp-doc ol{padding-left:1.25rem;margin:16px 0}.vp-doc ul{list-style:disc}.vp-doc ol{list-style:decimal}.vp-doc li+li{margin-top:8px}.vp-doc li>ol,.vp-doc li>ul{margin:8px 0 0}.vp-doc table{display:block;border-collapse:collapse;margin:20px 0;overflow-x:auto}.vp-doc tr{border-top:1px solid var(--vp-c-divider);transition:background-color .5s}.vp-doc tr:nth-child(2n){background-color:var(--vp-c-bg-soft)}.vp-doc th,.vp-doc td{border:1px solid var(--vp-c-divider);padding:8px 16px}.vp-doc th{text-align:left;font-size:14px;font-weight:600;color:var(--vp-c-text-2);background-color:var(--vp-c-bg-soft)}.vp-doc td{font-size:14px}.vp-doc hr{margin:16px 0;border:none;border-top:1px solid var(--vp-c-divider)}.vp-doc .custom-block{margin:16px 0}.vp-doc .custom-block p{margin:8px 0;line-height:24px}.vp-doc .custom-block p:first-child{margin:0}.vp-doc .custom-block div[class*=language-]{margin:8px 0;border-radius:8px}.vp-doc .custom-block div[class*=language-] code{font-weight:400;background-color:transparent}.vp-doc .custom-block .vp-code-group .tabs{margin:0;border-radius:8px 8px 0 0}.vp-doc :not(pre,h1,h2,h3,h4,h5,h6)>code{font-size:var(--vp-code-font-size);color:var(--vp-code-color)}.vp-doc :not(pre)>code{border-radius:4px;padding:3px 6px;background-color:var(--vp-code-bg);transition:color .25s,background-color .5s}.vp-doc a>code{color:var(--vp-code-link-color)}.vp-doc a:hover>code{color:var(--vp-code-link-hover-color)}.vp-doc h1>code,.vp-doc h2>code,.vp-doc h3>code{font-size:.9em}.vp-doc div[class*=language-],.vp-block{position:relative;margin:16px -24px;background-color:var(--vp-code-block-bg);overflow-x:auto;transition:background-color .5s}@media (min-width: 640px){.vp-doc div[class*=language-],.vp-block{border-radius:8px;margin:16px 0}}@media (max-width: 639px){.vp-doc li div[class*=language-]{border-radius:8px 0 0 8px}}.vp-doc div[class*=language-]+div[class*=language-],.vp-doc div[class$=-api]+div[class*=language-],.vp-doc div[class*=language-]+div[class$=-api]>div[class*=language-]{margin-top:-8px}.vp-doc [class*=language-] pre,.vp-doc [class*=language-] code{direction:ltr;text-align:left;white-space:pre;word-spacing:normal;word-break:normal;word-wrap:normal;-moz-tab-size:4;-o-tab-size:4;tab-size:4;-webkit-hyphens:none;-moz-hyphens:none;-ms-hyphens:none;hyphens:none}.vp-doc [class*=language-] pre{position:relative;z-index:1;margin:0;padding:20px 0;background:transparent;overflow-x:auto}.vp-doc [class*=language-] code{display:block;padding:0 24px;width:fit-content;min-width:100%;line-height:var(--vp-code-line-height);font-size:var(--vp-code-font-size);color:var(--vp-code-block-color);transition:color .5s}.vp-doc [class*=language-] code .highlighted{background-color:var(--vp-code-line-highlight-color);transition:background-color .5s;margin:0 -24px;padding:0 24px;width:calc(100% + 48px);display:inline-block}.vp-doc [class*=language-] code .highlighted.error{background-color:var(--vp-code-line-error-color)}.vp-doc [class*=language-] code .highlighted.warning{background-color:var(--vp-code-line-warning-color)}.vp-doc [class*=language-] code .diff{transition:background-color .5s;margin:0 -24px;padding:0 24px;width:calc(100% + 48px);display:inline-block}.vp-doc [class*=language-] code .diff:before{position:absolute;left:10px}.vp-doc [class*=language-] .has-focused-lines .line:not(.has-focus){filter:blur(.095rem);opacity:.4;transition:filter .35s,opacity .35s}.vp-doc [class*=language-] .has-focused-lines .line:not(.has-focus){opacity:.7;transition:filter .35s,opacity .35s}.vp-doc [class*=language-]:hover .has-focused-lines .line:not(.has-focus){filter:blur(0);opacity:1}.vp-doc [class*=language-] code .diff.remove{background-color:var(--vp-code-line-diff-remove-color);opacity:.7}.vp-doc [class*=language-] code .diff.remove:before{content:"-";color:var(--vp-code-line-diff-remove-symbol-color)}.vp-doc [class*=language-] code .diff.add{background-color:var(--vp-code-line-diff-add-color)}.vp-doc [class*=language-] code .diff.add:before{content:"+";color:var(--vp-code-line-diff-add-symbol-color)}.vp-doc div[class*=language-].line-numbers-mode{padding-left:32px}.vp-doc .line-numbers-wrapper{position:absolute;top:0;bottom:0;left:0;z-index:3;border-right:1px solid var(--vp-code-block-divider-color);padding-top:20px;width:32px;text-align:center;font-family:var(--vp-font-family-mono);line-height:var(--vp-code-line-height);font-size:var(--vp-code-font-size);color:var(--vp-code-line-number-color);transition:border-color .5s,color .5s}.vp-doc [class*=language-]>button.copy{direction:ltr;position:absolute;top:12px;right:12px;z-index:3;border:1px solid var(--vp-code-copy-code-border-color);border-radius:4px;width:40px;height:40px;background-color:var(--vp-code-copy-code-bg);opacity:0;cursor:pointer;background-image:var(--vp-icon-copy);background-position:50%;background-size:20px;background-repeat:no-repeat;transition:border-color .25s,background-color .25s,opacity .25s}.vp-doc [class*=language-]:hover>button.copy,.vp-doc [class*=language-]>button.copy:focus{opacity:1}.vp-doc [class*=language-]>button.copy:hover,.vp-doc [class*=language-]>button.copy.copied{border-color:var(--vp-code-copy-code-hover-border-color);background-color:var(--vp-code-copy-code-hover-bg)}.vp-doc [class*=language-]>button.copy.copied,.vp-doc [class*=language-]>button.copy:hover.copied{border-radius:0 4px 4px 0;background-color:var(--vp-code-copy-code-hover-bg);background-image:var(--vp-icon-copied)}.vp-doc [class*=language-]>button.copy.copied:before,.vp-doc [class*=language-]>button.copy:hover.copied:before{position:relative;top:-1px;transform:translate(calc(-100% - 1px));display:flex;justify-content:center;align-items:center;border:1px solid var(--vp-code-copy-code-hover-border-color);border-right:0;border-radius:4px 0 0 4px;padding:0 10px;width:fit-content;height:40px;text-align:center;font-size:12px;font-weight:500;color:var(--vp-code-copy-code-active-text);background-color:var(--vp-code-copy-code-hover-bg);white-space:nowrap;content:var(--vp-code-copy-copied-text-content)}.vp-doc [class*=language-]>span.lang{position:absolute;top:2px;right:8px;z-index:2;font-size:12px;font-weight:500;color:var(--vp-code-lang-color);transition:color .4s,opacity .4s}.vp-doc [class*=language-]:hover>button.copy+span.lang,.vp-doc [class*=language-]>button.copy:focus+span.lang{opacity:0}.vp-doc .VPTeamMembers{margin-top:24px}.vp-doc .VPTeamMembers.small.count-1 .container{margin:0!important;max-width:calc((100% - 24px)/2)!important}.vp-doc .VPTeamMembers.small.count-2 .container,.vp-doc .VPTeamMembers.small.count-3 .container{max-width:100%!important}.vp-doc .VPTeamMembers.medium.count-1 .container{margin:0!important;max-width:calc((100% - 24px)/2)!important}:is(.vp-external-link-icon,.vp-doc a[href*="://"],.vp-doc a[target=_blank]):not(.no-icon):after{display:inline-block;margin-top:-1px;margin-left:4px;width:11px;height:11px;background:currentColor;color:var(--vp-c-text-3);flex-shrink:0;--icon: url("data:image/svg+xml, %3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' %3E%3Cpath d='M0 0h24v24H0V0z' fill='none' /%3E%3Cpath d='M9 5v2h6.59L4 18.59 5.41 20 17 8.41V15h2V5H9z' /%3E%3C/svg%3E");-webkit-mask-image:var(--icon);mask-image:var(--icon)}.vp-external-link-icon:after{content:""}.vp-sponsor{border-radius:16px;overflow:hidden}.vp-sponsor.aside{border-radius:12px}.vp-sponsor-section+.vp-sponsor-section{margin-top:4px}.vp-sponsor-tier{margin-bottom:4px;text-align:center;letter-spacing:1px;line-height:24px;width:100%;font-weight:600;color:var(--vp-c-text-2);background-color:var(--vp-c-bg-soft)}.vp-sponsor.normal .vp-sponsor-tier{padding:13px 0 11px;font-size:14px}.vp-sponsor.aside .vp-sponsor-tier{padding:9px 0 7px;font-size:12px}.vp-sponsor-grid+.vp-sponsor-tier{margin-top:4px}.vp-sponsor-grid{display:flex;flex-wrap:wrap;gap:4px}.vp-sponsor-grid.xmini .vp-sponsor-grid-link{height:64px}.vp-sponsor-grid.xmini .vp-sponsor-grid-image{max-width:64px;max-height:22px}.vp-sponsor-grid.mini .vp-sponsor-grid-link{height:72px}.vp-sponsor-grid.mini .vp-sponsor-grid-image{max-width:96px;max-height:24px}.vp-sponsor-grid.small .vp-sponsor-grid-link{height:96px}.vp-sponsor-grid.small .vp-sponsor-grid-image{max-width:96px;max-height:24px}.vp-sponsor-grid.medium .vp-sponsor-grid-link{height:112px}.vp-sponsor-grid.medium .vp-sponsor-grid-image{max-width:120px;max-height:36px}.vp-sponsor-grid.big .vp-sponsor-grid-link{height:184px}.vp-sponsor-grid.big .vp-sponsor-grid-image{max-width:192px;max-height:56px}.vp-sponsor-grid[data-vp-grid="2"] .vp-sponsor-grid-item{width:calc((100% - 4px)/2)}.vp-sponsor-grid[data-vp-grid="3"] .vp-sponsor-grid-item{width:calc((100% - 4px * 2) / 3)}.vp-sponsor-grid[data-vp-grid="4"] .vp-sponsor-grid-item{width:calc((100% - 12px)/4)}.vp-sponsor-grid[data-vp-grid="5"] .vp-sponsor-grid-item{width:calc((100% - 16px)/5)}.vp-sponsor-grid[data-vp-grid="6"] .vp-sponsor-grid-item{width:calc((100% - 4px * 5) / 6)}.vp-sponsor-grid-item{flex-shrink:0;width:100%;background-color:var(--vp-c-bg-soft);transition:background-color .25s}.vp-sponsor-grid-item:hover{background-color:var(--vp-c-default-soft)}.vp-sponsor-grid-item:hover .vp-sponsor-grid-image{filter:grayscale(0) invert(0)}.vp-sponsor-grid-item.empty:hover{background-color:var(--vp-c-bg-soft)}.dark .vp-sponsor-grid-item:hover{background-color:var(--vp-c-white)}.dark .vp-sponsor-grid-item.empty:hover{background-color:var(--vp-c-bg-soft)}.vp-sponsor-grid-link{display:flex}.vp-sponsor-grid-box{display:flex;justify-content:center;align-items:center;width:100%}.vp-sponsor-grid-image{max-width:100%;filter:grayscale(1);transition:filter .25s}.dark .vp-sponsor-grid-image{filter:grayscale(1) invert(1)}.VPBadge[data-v-9613cc9f]{display:inline-block;margin-left:2px;border:1px solid transparent;border-radius:12px;padding:0 10px;line-height:22px;font-size:12px;font-weight:500;transform:translateY(-2px)}.vp-doc h1>.VPBadge[data-v-9613cc9f]{margin-top:4px;vertical-align:top}.vp-doc h2>.VPBadge[data-v-9613cc9f]{margin-top:3px;padding:0 8px;vertical-align:top}.vp-doc h3>.VPBadge[data-v-9613cc9f]{vertical-align:middle}.vp-doc h4>.VPBadge[data-v-9613cc9f],.vp-doc h5>.VPBadge[data-v-9613cc9f],.vp-doc h6>.VPBadge[data-v-9613cc9f]{vertical-align:middle;line-height:18px}.VPBadge.info[data-v-9613cc9f]{border-color:var(--vp-badge-info-border);color:var(--vp-badge-info-text);background-color:var(--vp-badge-info-bg)}.VPBadge.tip[data-v-9613cc9f]{border-color:var(--vp-badge-tip-border);color:var(--vp-badge-tip-text);background-color:var(--vp-badge-tip-bg)}.VPBadge.warning[data-v-9613cc9f]{border-color:var(--vp-badge-warning-border);color:var(--vp-badge-warning-text);background-color:var(--vp-badge-warning-bg)}.VPBadge.danger[data-v-9613cc9f]{border-color:var(--vp-badge-danger-border);color:var(--vp-badge-danger-text);background-color:var(--vp-badge-danger-bg)}.VPBackdrop[data-v-c79a1216]{position:fixed;top:0;right:0;bottom:0;left:0;z-index:var(--vp-z-index-backdrop);background:var(--vp-backdrop-bg-color);transition:opacity .5s}.VPBackdrop.fade-enter-from[data-v-c79a1216],.VPBackdrop.fade-leave-to[data-v-c79a1216]{opacity:0}.VPBackdrop.fade-leave-active[data-v-c79a1216]{transition-duration:.25s}@media (min-width: 1280px){.VPBackdrop[data-v-c79a1216]{display:none}}.NotFound[data-v-f87ff6e4]{padding:64px 24px 96px;text-align:center}@media (min-width: 768px){.NotFound[data-v-f87ff6e4]{padding:96px 32px 168px}}.code[data-v-f87ff6e4]{line-height:64px;font-size:64px;font-weight:600}.title[data-v-f87ff6e4]{padding-top:12px;letter-spacing:2px;line-height:20px;font-size:20px;font-weight:700}.divider[data-v-f87ff6e4]{margin:24px auto 18px;width:64px;height:1px;background-color:var(--vp-c-divider)}.quote[data-v-f87ff6e4]{margin:0 auto;max-width:256px;font-size:14px;font-weight:500;color:var(--vp-c-text-2)}.action[data-v-f87ff6e4]{padding-top:20px}.link[data-v-f87ff6e4]{display:inline-block;border:1px solid var(--vp-c-brand-1);border-radius:16px;padding:3px 16px;font-size:14px;font-weight:500;color:var(--vp-c-brand-1);transition:border-color .25s,color .25s}.link[data-v-f87ff6e4]:hover{border-color:var(--vp-c-brand-2);color:var(--vp-c-brand-2)}.root[data-v-d0ee3533]{position:relative;z-index:1}.nested[data-v-d0ee3533]{padding-left:16px}.outline-link[data-v-d0ee3533]{display:block;line-height:28px;color:var(--vp-c-text-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;transition:color .5s;font-weight:400}.outline-link[data-v-d0ee3533]:hover,.outline-link.active[data-v-d0ee3533]{color:var(--vp-c-text-1);transition:color .25s}.outline-link.nested[data-v-d0ee3533]{padding-left:13px}.VPDocAsideOutline[data-v-d330b1bb]{display:none}.VPDocAsideOutline.has-outline[data-v-d330b1bb]{display:block}.content[data-v-d330b1bb]{position:relative;border-left:1px solid var(--vp-c-divider);padding-left:16px;font-size:13px;font-weight:500}.outline-marker[data-v-d330b1bb]{position:absolute;top:32px;left:-1px;z-index:0;opacity:0;width:2px;border-radius:2px;height:18px;background-color:var(--vp-c-brand-1);transition:top .25s cubic-bezier(0,1,.5,1),background-color .5s,opacity .25s}.outline-title[data-v-d330b1bb]{letter-spacing:.4px;line-height:28px;font-size:13px;font-weight:600}.VPDocAside[data-v-3f215769]{display:flex;flex-direction:column;flex-grow:1}.spacer[data-v-3f215769]{flex-grow:1}.VPDocAside[data-v-3f215769] .spacer+.VPDocAsideSponsors,.VPDocAside[data-v-3f215769] .spacer+.VPDocAsideCarbonAds{margin-top:24px}.VPDocAside[data-v-3f215769] .VPDocAsideSponsors+.VPDocAsideCarbonAds{margin-top:16px}.VPLastUpdated[data-v-7e05ebdb]{line-height:24px;font-size:14px;font-weight:500;color:var(--vp-c-text-2)}@media (min-width: 640px){.VPLastUpdated[data-v-7e05ebdb]{line-height:32px;font-size:14px;font-weight:500}}.VPDocFooter[data-v-ef5dee53]{margin-top:64px}.edit-info[data-v-ef5dee53]{padding-bottom:18px}@media (min-width: 640px){.edit-info[data-v-ef5dee53]{display:flex;justify-content:space-between;align-items:center;padding-bottom:14px}}.edit-link-button[data-v-ef5dee53]{display:flex;align-items:center;border:0;line-height:32px;font-size:14px;font-weight:500;color:var(--vp-c-brand-1);transition:color .25s}.edit-link-button[data-v-ef5dee53]:hover{color:var(--vp-c-brand-2)}.edit-link-icon[data-v-ef5dee53]{margin-right:8px;width:14px;height:14px;fill:currentColor}.prev-next[data-v-ef5dee53]{border-top:1px solid var(--vp-c-divider);padding-top:24px;display:grid;grid-row-gap:8px}@media (min-width: 640px){.prev-next[data-v-ef5dee53]{grid-template-columns:repeat(2,1fr);grid-column-gap:16px}}.pager-link[data-v-ef5dee53]{display:block;border:1px solid var(--vp-c-divider);border-radius:8px;padding:11px 16px 13px;width:100%;height:100%;transition:border-color .25s}.pager-link[data-v-ef5dee53]:hover{border-color:var(--vp-c-brand-1)}.pager-link.next[data-v-ef5dee53]{margin-left:auto;text-align:right}.desc[data-v-ef5dee53]{display:block;line-height:20px;font-size:12px;font-weight:500;color:var(--vp-c-text-2)}.title[data-v-ef5dee53]{display:block;line-height:20px;font-size:14px;font-weight:500;color:var(--vp-c-brand-1);transition:color .25s}.VPDocOutlineDropdown[data-v-eadfb36b]{margin-bottom:48px}.VPDocOutlineDropdown button[data-v-eadfb36b]{display:block;font-size:14px;font-weight:500;line-height:24px;border:1px solid var(--vp-c-border);padding:4px 12px;color:var(--vp-c-text-2);background-color:var(--vp-c-default-soft);border-radius:8px;transition:color .5s}.VPDocOutlineDropdown button[data-v-eadfb36b]:hover{color:var(--vp-c-text-1);transition:color .25s}.VPDocOutlineDropdown button.open[data-v-eadfb36b]{color:var(--vp-c-text-1)}.icon[data-v-eadfb36b]{display:inline-block;vertical-align:middle;width:16px;height:16px;fill:currentColor}[data-v-eadfb36b] .outline-link{font-size:14px;font-weight:400}.open>.icon[data-v-eadfb36b]{transform:rotate(90deg)}.items[data-v-eadfb36b]{margin-top:12px;border-left:1px solid var(--vp-c-divider)}.VPDoc[data-v-6b87e69f]{padding:32px 24px 96px;width:100%}.VPDoc .VPDocOutlineDropdown[data-v-6b87e69f]{display:none}@media (min-width: 960px) and (max-width: 1279px){.VPDoc .VPDocOutlineDropdown[data-v-6b87e69f]{display:block}}@media (min-width: 768px){.VPDoc[data-v-6b87e69f]{padding:48px 32px 128px}}@media (min-width: 960px){.VPDoc[data-v-6b87e69f]{padding:32px 32px 0}.VPDoc:not(.has-sidebar) .container[data-v-6b87e69f]{display:flex;justify-content:center;max-width:992px}.VPDoc:not(.has-sidebar) .content[data-v-6b87e69f]{max-width:752px}}@media (min-width: 1280px){.VPDoc .container[data-v-6b87e69f]{display:flex;justify-content:center}.VPDoc .aside[data-v-6b87e69f]{display:block}}@media (min-width: 1440px){.VPDoc:not(.has-sidebar) .content[data-v-6b87e69f]{max-width:784px}.VPDoc:not(.has-sidebar) .container[data-v-6b87e69f]{max-width:1104px}}.container[data-v-6b87e69f]{margin:0 auto;width:100%}.aside[data-v-6b87e69f]{position:relative;display:none;order:2;flex-grow:1;padding-left:32px;width:100%;max-width:256px}.left-aside[data-v-6b87e69f]{order:1;padding-left:unset;padding-right:32px}.aside-container[data-v-6b87e69f]{position:fixed;top:0;padding-top:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + var(--vp-doc-top-height, 0px) + 32px);width:224px;height:100vh;overflow-x:hidden;overflow-y:auto;scrollbar-width:none}.aside-container[data-v-6b87e69f]::-webkit-scrollbar{display:none}.aside-curtain[data-v-6b87e69f]{position:fixed;bottom:0;z-index:10;width:224px;height:32px;background:linear-gradient(transparent,var(--vp-c-bg) 70%)}.aside-content[data-v-6b87e69f]{display:flex;flex-direction:column;min-height:calc(100vh - (var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 32px));padding-bottom:32px}.content[data-v-6b87e69f]{position:relative;margin:0 auto;width:100%}@media (min-width: 960px){.content[data-v-6b87e69f]{padding:0 32px 128px}}@media (min-width: 1280px){.content[data-v-6b87e69f]{order:1;margin:0;min-width:640px}}.content-container[data-v-6b87e69f]{margin:0 auto}.VPDoc.has-aside .content-container[data-v-6b87e69f]{max-width:688px}.external-link-icon-enabled[data-v-6b87e69f] :is(.vp-doc a[href*="://"],.vp-doc a[target=_blank]):after{content:"";color:currentColor}.VPButton[data-v-c1c5efc1]{display:inline-block;border:1px solid transparent;text-align:center;font-weight:600;white-space:nowrap;transition:color .25s,border-color .25s,background-color .25s}.VPButton[data-v-c1c5efc1]:active{transition:color .1s,border-color .1s,background-color .1s}.VPButton.medium[data-v-c1c5efc1]{border-radius:20px;padding:0 20px;line-height:38px;font-size:14px}.VPButton.big[data-v-c1c5efc1]{border-radius:24px;padding:0 24px;line-height:46px;font-size:16px}.VPButton.brand[data-v-c1c5efc1]{border-color:var(--vp-button-brand-border);color:var(--vp-button-brand-text);background-color:var(--vp-button-brand-bg)}.VPButton.brand[data-v-c1c5efc1]:hover{border-color:var(--vp-button-brand-hover-border);color:var(--vp-button-brand-hover-text);background-color:var(--vp-button-brand-hover-bg)}.VPButton.brand[data-v-c1c5efc1]:active{border-color:var(--vp-button-brand-active-border);color:var(--vp-button-brand-active-text);background-color:var(--vp-button-brand-active-bg)}.VPButton.alt[data-v-c1c5efc1]{border-color:var(--vp-button-alt-border);color:var(--vp-button-alt-text);background-color:var(--vp-button-alt-bg)}.VPButton.alt[data-v-c1c5efc1]:hover{border-color:var(--vp-button-alt-hover-border);color:var(--vp-button-alt-hover-text);background-color:var(--vp-button-alt-hover-bg)}.VPButton.alt[data-v-c1c5efc1]:active{border-color:var(--vp-button-alt-active-border);color:var(--vp-button-alt-active-text);background-color:var(--vp-button-alt-active-bg)}.VPButton.sponsor[data-v-c1c5efc1]{border-color:var(--vp-button-sponsor-border);color:var(--vp-button-sponsor-text);background-color:var(--vp-button-sponsor-bg)}.VPButton.sponsor[data-v-c1c5efc1]:hover{border-color:var(--vp-button-sponsor-hover-border);color:var(--vp-button-sponsor-hover-text);background-color:var(--vp-button-sponsor-hover-bg)}.VPButton.sponsor[data-v-c1c5efc1]:active{border-color:var(--vp-button-sponsor-active-border);color:var(--vp-button-sponsor-active-text);background-color:var(--vp-button-sponsor-active-bg)}html:not(.dark) .VPImage.dark[data-v-8426fc1a]{display:none}.dark .VPImage.light[data-v-8426fc1a]{display:none}.VPHero[data-v-da5d1713]{margin-top:calc((var(--vp-nav-height) + var(--vp-layout-top-height, 0px)) * -1);padding:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 48px) 24px 48px}@media (min-width: 640px){.VPHero[data-v-da5d1713]{padding:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 80px) 48px 64px}}@media (min-width: 960px){.VPHero[data-v-da5d1713]{padding:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 80px) 64px 64px}}.container[data-v-da5d1713]{display:flex;flex-direction:column;margin:0 auto;max-width:1152px}@media (min-width: 960px){.container[data-v-da5d1713]{flex-direction:row}}.main[data-v-da5d1713]{position:relative;z-index:10;order:2;flex-grow:1;flex-shrink:0}.VPHero.has-image .container[data-v-da5d1713]{text-align:center}@media (min-width: 960px){.VPHero.has-image .container[data-v-da5d1713]{text-align:left}}@media (min-width: 960px){.main[data-v-da5d1713]{order:1;width:calc((100% / 3) * 2)}.VPHero.has-image .main[data-v-da5d1713]{max-width:592px}}.name[data-v-da5d1713],.text[data-v-da5d1713]{max-width:392px;letter-spacing:-.4px;line-height:40px;font-size:32px;font-weight:700;white-space:pre-wrap}.VPHero.has-image .name[data-v-da5d1713],.VPHero.has-image .text[data-v-da5d1713]{margin:0 auto}.name[data-v-da5d1713]{color:var(--vp-home-hero-name-color)}.clip[data-v-da5d1713]{background:var(--vp-home-hero-name-background);-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:var(--vp-home-hero-name-color)}@media (min-width: 640px){.name[data-v-da5d1713],.text[data-v-da5d1713]{max-width:576px;line-height:56px;font-size:48px}}@media (min-width: 960px){.name[data-v-da5d1713],.text[data-v-da5d1713]{line-height:64px;font-size:56px}.VPHero.has-image .name[data-v-da5d1713],.VPHero.has-image .text[data-v-da5d1713]{margin:0}}.tagline[data-v-da5d1713]{padding-top:8px;max-width:392px;line-height:28px;font-size:18px;font-weight:500;white-space:pre-wrap;color:var(--vp-c-text-2)}.VPHero.has-image .tagline[data-v-da5d1713]{margin:0 auto}@media (min-width: 640px){.tagline[data-v-da5d1713]{padding-top:12px;max-width:576px;line-height:32px;font-size:20px}}@media (min-width: 960px){.tagline[data-v-da5d1713]{line-height:36px;font-size:24px}.VPHero.has-image .tagline[data-v-da5d1713]{margin:0}}.actions[data-v-da5d1713]{display:flex;flex-wrap:wrap;margin:-6px;padding-top:24px}.VPHero.has-image .actions[data-v-da5d1713]{justify-content:center}@media (min-width: 640px){.actions[data-v-da5d1713]{padding-top:32px}}@media (min-width: 960px){.VPHero.has-image .actions[data-v-da5d1713]{justify-content:flex-start}}.action[data-v-da5d1713]{flex-shrink:0;padding:6px}.image[data-v-da5d1713]{order:1;margin:-76px -24px -48px}@media (min-width: 640px){.image[data-v-da5d1713]{margin:-108px -24px -48px}}@media (min-width: 960px){.image[data-v-da5d1713]{flex-grow:1;order:2;margin:0;min-height:100%}}.image-container[data-v-da5d1713]{position:relative;margin:0 auto;width:320px;height:320px}@media (min-width: 640px){.image-container[data-v-da5d1713]{width:392px;height:392px}}@media (min-width: 960px){.image-container[data-v-da5d1713]{display:flex;justify-content:center;align-items:center;width:100%;height:100%;transform:translate(-32px,-32px)}}.image-bg[data-v-da5d1713]{position:absolute;top:50%;left:50%;border-radius:50%;width:192px;height:192px;background-image:var(--vp-home-hero-image-background-image);filter:var(--vp-home-hero-image-filter);transform:translate(-50%,-50%)}@media (min-width: 640px){.image-bg[data-v-da5d1713]{width:256px;height:256px}}@media (min-width: 960px){.image-bg[data-v-da5d1713]{width:320px;height:320px}}[data-v-da5d1713] .image-src{position:absolute;top:50%;left:50%;max-width:192px;max-height:192px;transform:translate(-50%,-50%)}@media (min-width: 640px){[data-v-da5d1713] .image-src{max-width:256px;max-height:256px}}@media (min-width: 960px){[data-v-da5d1713] .image-src{max-width:320px;max-height:320px}}.VPFeature[data-v-33204567]{display:block;border:1px solid var(--vp-c-bg-soft);border-radius:12px;height:100%;background-color:var(--vp-c-bg-soft);transition:border-color .25s,background-color .25s}.VPFeature.link[data-v-33204567]:hover{border-color:var(--vp-c-brand-1)}.box[data-v-33204567]{display:flex;flex-direction:column;padding:24px;height:100%}.box[data-v-33204567]>.VPImage{margin-bottom:20px}.icon[data-v-33204567]{display:flex;justify-content:center;align-items:center;margin-bottom:20px;border-radius:6px;background-color:var(--vp-c-default-soft);width:48px;height:48px;font-size:24px;transition:background-color .25s}.title[data-v-33204567]{line-height:24px;font-size:16px;font-weight:600}.details[data-v-33204567]{flex-grow:1;padding-top:8px;line-height:24px;font-size:14px;font-weight:500;color:var(--vp-c-text-2)}.link-text[data-v-33204567]{padding-top:8px}.link-text-value[data-v-33204567]{display:flex;align-items:center;font-size:14px;font-weight:500;color:var(--vp-c-brand-1)}.link-text-icon[data-v-33204567]{display:inline-block;margin-left:6px;width:14px;height:14px;fill:currentColor}.VPFeatures[data-v-a6181336]{position:relative;padding:0 24px}@media (min-width: 640px){.VPFeatures[data-v-a6181336]{padding:0 48px}}@media (min-width: 960px){.VPFeatures[data-v-a6181336]{padding:0 64px}}.container[data-v-a6181336]{margin:0 auto;max-width:1152px}.items[data-v-a6181336]{display:flex;flex-wrap:wrap;margin:-8px}.item[data-v-a6181336]{padding:8px;width:100%}@media (min-width: 640px){.item.grid-2[data-v-a6181336],.item.grid-4[data-v-a6181336],.item.grid-6[data-v-a6181336]{width:50%}}@media (min-width: 768px){.item.grid-2[data-v-a6181336],.item.grid-4[data-v-a6181336]{width:50%}.item.grid-3[data-v-a6181336],.item.grid-6[data-v-a6181336]{width:calc(100% / 3)}}@media (min-width: 960px){.item.grid-4[data-v-a6181336]{width:25%}}.VPHome[data-v-d82743a8]{padding-bottom:96px}.VPHome[data-v-d82743a8] .VPHomeSponsors{margin-top:112px;margin-bottom:-128px}@media (min-width: 768px){.VPHome[data-v-d82743a8]{padding-bottom:128px}}.VPContent[data-v-669faec9]{flex-grow:1;flex-shrink:0;margin:var(--vp-layout-top-height, 0px) auto 0;width:100%}.VPContent.is-home[data-v-669faec9]{width:100%;max-width:100%}.VPContent.has-sidebar[data-v-669faec9]{margin:0}@media (min-width: 960px){.VPContent[data-v-669faec9]{padding-top:var(--vp-nav-height)}.VPContent.has-sidebar[data-v-669faec9]{margin:var(--vp-layout-top-height, 0px) 0 0;padding-left:var(--vp-sidebar-width)}}@media (min-width: 1440px){.VPContent.has-sidebar[data-v-669faec9]{padding-right:calc((100vw - var(--vp-layout-max-width)) / 2);padding-left:calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width))}}.VPFooter[data-v-e03eb2e1]{position:relative;z-index:var(--vp-z-index-footer);border-top:1px solid var(--vp-c-gutter);padding:32px 24px;background-color:var(--vp-c-bg)}.VPFooter.has-sidebar[data-v-e03eb2e1]{display:none}@media (min-width: 768px){.VPFooter[data-v-e03eb2e1]{padding:32px}}.container[data-v-e03eb2e1]{margin:0 auto;max-width:var(--vp-layout-max-width);text-align:center}.message[data-v-e03eb2e1],.copyright[data-v-e03eb2e1]{line-height:24px;font-size:14px;font-weight:500;color:var(--vp-c-text-2)}.VPLocalNavOutlineDropdown[data-v-1c15a60a]{padding:12px 20px 11px}.VPLocalNavOutlineDropdown button[data-v-1c15a60a]{display:block;font-size:12px;font-weight:500;line-height:24px;color:var(--vp-c-text-2);transition:color .5s;position:relative}.VPLocalNavOutlineDropdown button[data-v-1c15a60a]:hover{color:var(--vp-c-text-1);transition:color .25s}.VPLocalNavOutlineDropdown button.open[data-v-1c15a60a]{color:var(--vp-c-text-1)}.icon[data-v-1c15a60a]{display:inline-block;vertical-align:middle;margin-left:2px;width:14px;height:14px;fill:currentColor}[data-v-1c15a60a] .outline-link{font-size:14px;padding:2px 0}.open>.icon[data-v-1c15a60a]{transform:rotate(90deg)}.items[data-v-1c15a60a]{position:absolute;top:64px;right:16px;left:16px;display:grid;gap:1px;border:1px solid var(--vp-c-border);border-radius:8px;background-color:var(--vp-c-gutter);max-height:calc(var(--vp-vh, 100vh) - 86px);overflow:hidden auto;box-shadow:var(--vp-shadow-3)}.header[data-v-1c15a60a]{background-color:var(--vp-c-bg-soft)}.top-link[data-v-1c15a60a]{display:block;padding:0 16px;line-height:48px;font-size:14px;font-weight:500;color:var(--vp-c-brand-1)}.outline[data-v-1c15a60a]{padding:8px 0;background-color:var(--vp-c-bg-soft)}.flyout-enter-active[data-v-1c15a60a]{transition:all .2s ease-out}.flyout-leave-active[data-v-1c15a60a]{transition:all .15s ease-in}.flyout-enter-from[data-v-1c15a60a],.flyout-leave-to[data-v-1c15a60a]{opacity:0;transform:translateY(-16px)}.VPLocalNav[data-v-79c8c1df]{position:sticky;top:0;left:0;z-index:var(--vp-z-index-local-nav);display:flex;justify-content:space-between;align-items:center;border-top:1px solid var(--vp-c-gutter);border-bottom:1px solid var(--vp-c-gutter);padding-top:var(--vp-layout-top-height, 0px);width:100%;background-color:var(--vp-local-nav-bg-color)}.VPLocalNav.fixed[data-v-79c8c1df]{position:fixed}.VPLocalNav.reached-top[data-v-79c8c1df]{border-top-color:transparent}@media (min-width: 960px){.VPLocalNav[data-v-79c8c1df]{display:none}}.menu[data-v-79c8c1df]{display:flex;align-items:center;padding:12px 24px 11px;line-height:24px;font-size:12px;font-weight:500;color:var(--vp-c-text-2);transition:color .5s}.menu[data-v-79c8c1df]:hover{color:var(--vp-c-text-1);transition:color .25s}@media (min-width: 768px){.menu[data-v-79c8c1df]{padding:0 32px}}.menu-icon[data-v-79c8c1df]{margin-right:8px;width:16px;height:16px;fill:currentColor}.VPOutlineDropdown[data-v-79c8c1df]{padding:12px 24px 11px}@media (min-width: 768px){.VPOutlineDropdown[data-v-79c8c1df]{padding:12px 32px 11px}}.VPSwitch[data-v-b1685198]{position:relative;border-radius:11px;display:block;width:40px;height:22px;flex-shrink:0;border:1px solid var(--vp-input-border-color);background-color:var(--vp-input-switch-bg-color);transition:border-color .25s!important}.VPSwitch[data-v-b1685198]:hover{border-color:var(--vp-c-brand-1)}.check[data-v-b1685198]{position:absolute;top:1px;left:1px;width:18px;height:18px;border-radius:50%;background-color:var(--vp-c-neutral-inverse);box-shadow:var(--vp-shadow-1);transition:transform .25s!important}.icon[data-v-b1685198]{position:relative;display:block;width:18px;height:18px;border-radius:50%;overflow:hidden}.icon[data-v-b1685198] svg{position:absolute;top:3px;left:3px;width:12px;height:12px;fill:var(--vp-c-text-2)}.dark .icon[data-v-b1685198] svg{fill:var(--vp-c-text-1);transition:opacity .25s!important}.sun[data-v-ce54a7d1]{opacity:1}.moon[data-v-ce54a7d1],.dark .sun[data-v-ce54a7d1]{opacity:0}.dark .moon[data-v-ce54a7d1]{opacity:1}.dark .VPSwitchAppearance[data-v-ce54a7d1] .check{transform:translate(18px)}.VPNavBarAppearance[data-v-e6aabb21]{display:none}@media (min-width: 1280px){.VPNavBarAppearance[data-v-e6aabb21]{display:flex;align-items:center}}.VPMenuGroup+.VPMenuLink[data-v-43f1e123]{margin:12px -12px 0;border-top:1px solid var(--vp-c-divider);padding:12px 12px 0}.link[data-v-43f1e123]{display:block;border-radius:6px;padding:0 12px;line-height:32px;font-size:14px;font-weight:500;color:var(--vp-c-text-1);white-space:nowrap;transition:background-color .25s,color .25s}.link[data-v-43f1e123]:hover{color:var(--vp-c-brand-1);background-color:var(--vp-c-default-soft)}.link.active[data-v-43f1e123]{color:var(--vp-c-brand-1)}.VPMenuGroup[data-v-69e747b5]{margin:12px -12px 0;border-top:1px solid var(--vp-c-divider);padding:12px 12px 0}.VPMenuGroup[data-v-69e747b5]:first-child{margin-top:0;border-top:0;padding-top:0}.VPMenuGroup+.VPMenuGroup[data-v-69e747b5]{margin-top:12px;border-top:1px solid var(--vp-c-divider)}.title[data-v-69e747b5]{padding:0 12px;line-height:32px;font-size:14px;font-weight:600;color:var(--vp-c-text-2);white-space:nowrap;transition:color .25s}.VPMenu[data-v-e7ea1737]{border-radius:12px;padding:12px;min-width:128px;border:1px solid var(--vp-c-divider);background-color:var(--vp-c-bg-elv);box-shadow:var(--vp-shadow-3);transition:background-color .5s;max-height:calc(100vh - var(--vp-nav-height));overflow-y:auto}.VPMenu[data-v-e7ea1737] .group{margin:0 -12px;padding:0 12px 12px}.VPMenu[data-v-e7ea1737] .group+.group{border-top:1px solid var(--vp-c-divider);padding:11px 12px 12px}.VPMenu[data-v-e7ea1737] .group:last-child{padding-bottom:0}.VPMenu[data-v-e7ea1737] .group+.item{border-top:1px solid var(--vp-c-divider);padding:11px 16px 0}.VPMenu[data-v-e7ea1737] .item{padding:0 16px;white-space:nowrap}.VPMenu[data-v-e7ea1737] .label{flex-grow:1;line-height:28px;font-size:12px;font-weight:500;color:var(--vp-c-text-2);transition:color .5s}.VPMenu[data-v-e7ea1737] .action{padding-left:24px}.VPFlyout[data-v-9c007e85]{position:relative}.VPFlyout[data-v-9c007e85]:hover{color:var(--vp-c-brand-1);transition:color .25s}.VPFlyout:hover .text[data-v-9c007e85]{color:var(--vp-c-text-2)}.VPFlyout:hover .icon[data-v-9c007e85]{fill:var(--vp-c-text-2)}.VPFlyout.active .text[data-v-9c007e85]{color:var(--vp-c-brand-1)}.VPFlyout.active:hover .text[data-v-9c007e85]{color:var(--vp-c-brand-2)}.VPFlyout:hover .menu[data-v-9c007e85],.button[aria-expanded=true]+.menu[data-v-9c007e85]{opacity:1;visibility:visible;transform:translateY(0)}.button[aria-expanded=false]+.menu[data-v-9c007e85]{opacity:0;visibility:hidden;transform:translateY(0)}.button[data-v-9c007e85]{display:flex;align-items:center;padding:0 12px;height:var(--vp-nav-height);color:var(--vp-c-text-1);transition:color .5s}.text[data-v-9c007e85]{display:flex;align-items:center;line-height:var(--vp-nav-height);font-size:14px;font-weight:500;color:var(--vp-c-text-1);transition:color .25s}.option-icon[data-v-9c007e85]{margin-right:0;width:16px;height:16px;fill:currentColor}.text-icon[data-v-9c007e85]{margin-left:4px;width:14px;height:14px;fill:currentColor}.icon[data-v-9c007e85]{width:20px;height:20px;fill:currentColor;transition:fill .25s}.menu[data-v-9c007e85]{position:absolute;top:calc(var(--vp-nav-height) / 2 + 20px);right:0;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s,transform .25s}.VPSocialLink[data-v-f80f8133]{display:flex;justify-content:center;align-items:center;width:36px;height:36px;color:var(--vp-c-text-2);transition:color .5s}.VPSocialLink[data-v-f80f8133]:hover{color:var(--vp-c-text-1);transition:color .25s}.VPSocialLink[data-v-f80f8133]>svg{width:20px;height:20px;fill:currentColor}.VPSocialLinks[data-v-7bc22406]{display:flex;justify-content:center}.VPNavBarExtra[data-v-40855f84]{display:none;margin-right:-12px}@media (min-width: 768px){.VPNavBarExtra[data-v-40855f84]{display:block}}@media (min-width: 1280px){.VPNavBarExtra[data-v-40855f84]{display:none}}.trans-title[data-v-40855f84]{padding:0 24px 0 12px;line-height:32px;font-size:14px;font-weight:700;color:var(--vp-c-text-1)}.item.appearance[data-v-40855f84],.item.social-links[data-v-40855f84]{display:flex;align-items:center;padding:0 12px}.item.appearance[data-v-40855f84]{min-width:176px}.appearance-action[data-v-40855f84]{margin-right:-2px}.social-links-list[data-v-40855f84]{margin:-4px -8px}.VPNavBarHamburger[data-v-e5dd9c1c]{display:flex;justify-content:center;align-items:center;width:48px;height:var(--vp-nav-height)}@media (min-width: 768px){.VPNavBarHamburger[data-v-e5dd9c1c]{display:none}}.container[data-v-e5dd9c1c]{position:relative;width:16px;height:14px;overflow:hidden}.VPNavBarHamburger:hover .top[data-v-e5dd9c1c]{top:0;left:0;transform:translate(4px)}.VPNavBarHamburger:hover .middle[data-v-e5dd9c1c]{top:6px;left:0;transform:translate(0)}.VPNavBarHamburger:hover .bottom[data-v-e5dd9c1c]{top:12px;left:0;transform:translate(8px)}.VPNavBarHamburger.active .top[data-v-e5dd9c1c]{top:6px;transform:translate(0) rotate(225deg)}.VPNavBarHamburger.active .middle[data-v-e5dd9c1c]{top:6px;transform:translate(16px)}.VPNavBarHamburger.active .bottom[data-v-e5dd9c1c]{top:6px;transform:translate(0) rotate(135deg)}.VPNavBarHamburger.active:hover .top[data-v-e5dd9c1c],.VPNavBarHamburger.active:hover .middle[data-v-e5dd9c1c],.VPNavBarHamburger.active:hover .bottom[data-v-e5dd9c1c]{background-color:var(--vp-c-text-2);transition:top .25s,background-color .25s,transform .25s}.top[data-v-e5dd9c1c],.middle[data-v-e5dd9c1c],.bottom[data-v-e5dd9c1c]{position:absolute;width:16px;height:2px;background-color:var(--vp-c-text-1);transition:top .25s,background-color .5s,transform .25s}.top[data-v-e5dd9c1c]{top:0;left:0;transform:translate(0)}.middle[data-v-e5dd9c1c]{top:6px;left:0;transform:translate(8px)}.bottom[data-v-e5dd9c1c]{top:12px;left:0;transform:translate(4px)}.VPNavBarMenuLink[data-v-42ef59de]{display:flex;align-items:center;padding:0 12px;line-height:var(--vp-nav-height);font-size:14px;font-weight:500;color:var(--vp-c-text-1);transition:color .25s}.VPNavBarMenuLink.active[data-v-42ef59de],.VPNavBarMenuLink[data-v-42ef59de]:hover{color:var(--vp-c-brand-1)}.VPNavBarMenu[data-v-7f418b0f]{display:none}@media (min-width: 768px){.VPNavBarMenu[data-v-7f418b0f]{display:flex}}/*! @docsearch/css 3.5.2 | MIT License | © Algolia, Inc. and contributors | https://docsearch.algolia.com */:root{--docsearch-primary-color:#5468ff;--docsearch-text-color:#1c1e21;--docsearch-spacing:12px;--docsearch-icon-stroke-width:1.4;--docsearch-highlight-color:var(--docsearch-primary-color);--docsearch-muted-color:#969faf;--docsearch-container-background:rgba(101,108,133,.8);--docsearch-logo-color:#5468ff;--docsearch-modal-width:560px;--docsearch-modal-height:600px;--docsearch-modal-background:#f5f6f7;--docsearch-modal-shadow:inset 1px 1px 0 0 hsla(0,0%,100%,.5),0 3px 8px 0 #555a64;--docsearch-searchbox-height:56px;--docsearch-searchbox-background:#ebedf0;--docsearch-searchbox-focus-background:#fff;--docsearch-searchbox-shadow:inset 0 0 0 2px var(--docsearch-primary-color);--docsearch-hit-height:56px;--docsearch-hit-color:#444950;--docsearch-hit-active-color:#fff;--docsearch-hit-background:#fff;--docsearch-hit-shadow:0 1px 3px 0 #d4d9e1;--docsearch-key-gradient:linear-gradient(-225deg,#d5dbe4,#f8f8f8);--docsearch-key-shadow:inset 0 -2px 0 0 #cdcde6,inset 0 0 1px 1px #fff,0 1px 2px 1px rgba(30,35,90,.4);--docsearch-footer-height:44px;--docsearch-footer-background:#fff;--docsearch-footer-shadow:0 -1px 0 0 #e0e3e8,0 -3px 6px 0 rgba(69,98,155,.12)}html[data-theme=dark]{--docsearch-text-color:#f5f6f7;--docsearch-container-background:rgba(9,10,17,.8);--docsearch-modal-background:#15172a;--docsearch-modal-shadow:inset 1px 1px 0 0 #2c2e40,0 3px 8px 0 #000309;--docsearch-searchbox-background:#090a11;--docsearch-searchbox-focus-background:#000;--docsearch-hit-color:#bec3c9;--docsearch-hit-shadow:none;--docsearch-hit-background:#090a11;--docsearch-key-gradient:linear-gradient(-26.5deg,#565872,#31355b);--docsearch-key-shadow:inset 0 -2px 0 0 #282d55,inset 0 0 1px 1px #51577d,0 2px 2px 0 rgba(3,4,9,.3);--docsearch-footer-background:#1e2136;--docsearch-footer-shadow:inset 0 1px 0 0 rgba(73,76,106,.5),0 -4px 8px 0 rgba(0,0,0,.2);--docsearch-logo-color:#fff;--docsearch-muted-color:#7f8497}.DocSearch-Button{align-items:center;background:var(--docsearch-searchbox-background);border:0;border-radius:40px;color:var(--docsearch-muted-color);cursor:pointer;display:flex;font-weight:500;height:36px;justify-content:space-between;margin:0 0 0 16px;padding:0 8px;-webkit-user-select:none;user-select:none}.DocSearch-Button:active,.DocSearch-Button:focus,.DocSearch-Button:hover{background:var(--docsearch-searchbox-focus-background);box-shadow:var(--docsearch-searchbox-shadow);color:var(--docsearch-text-color);outline:none}.DocSearch-Button-Container{align-items:center;display:flex}.DocSearch-Search-Icon{stroke-width:1.6}.DocSearch-Button .DocSearch-Search-Icon{color:var(--docsearch-text-color)}.DocSearch-Button-Placeholder{font-size:1rem;padding:0 12px 0 6px}.DocSearch-Button-Keys{display:flex;min-width:calc(40px + .8em)}.DocSearch-Button-Key{align-items:center;background:var(--docsearch-key-gradient);border-radius:3px;box-shadow:var(--docsearch-key-shadow);color:var(--docsearch-muted-color);display:flex;height:18px;justify-content:center;margin-right:.4em;position:relative;padding:0 0 2px;border:0;top:-1px;width:20px}@media (max-width:768px){.DocSearch-Button-Keys,.DocSearch-Button-Placeholder{display:none}}.DocSearch--active{overflow:hidden!important}.DocSearch-Container,.DocSearch-Container *{box-sizing:border-box}.DocSearch-Container{background-color:var(--docsearch-container-background);height:100vh;left:0;position:fixed;top:0;width:100vw;z-index:200}.DocSearch-Container a{text-decoration:none}.DocSearch-Link{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;color:var(--docsearch-highlight-color);cursor:pointer;font:inherit;margin:0;padding:0}.DocSearch-Modal{background:var(--docsearch-modal-background);border-radius:6px;box-shadow:var(--docsearch-modal-shadow);flex-direction:column;margin:60px auto auto;max-width:var(--docsearch-modal-width);position:relative}.DocSearch-SearchBar{display:flex;padding:var(--docsearch-spacing) var(--docsearch-spacing) 0}.DocSearch-Form{align-items:center;background:var(--docsearch-searchbox-focus-background);border-radius:4px;box-shadow:var(--docsearch-searchbox-shadow);display:flex;height:var(--docsearch-searchbox-height);margin:0;padding:0 var(--docsearch-spacing);position:relative;width:100%}.DocSearch-Input{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:transparent;border:0;color:var(--docsearch-text-color);flex:1;font:inherit;font-size:1.2em;height:100%;outline:none;padding:0 0 0 8px;width:80%}.DocSearch-Input::placeholder{color:var(--docsearch-muted-color);opacity:1}.DocSearch-Input::-webkit-search-cancel-button,.DocSearch-Input::-webkit-search-decoration,.DocSearch-Input::-webkit-search-results-button,.DocSearch-Input::-webkit-search-results-decoration{display:none}.DocSearch-LoadingIndicator,.DocSearch-MagnifierLabel,.DocSearch-Reset{margin:0;padding:0}.DocSearch-MagnifierLabel,.DocSearch-Reset{align-items:center;color:var(--docsearch-highlight-color);display:flex;justify-content:center}.DocSearch-Container--Stalled .DocSearch-MagnifierLabel,.DocSearch-LoadingIndicator{display:none}.DocSearch-Container--Stalled .DocSearch-LoadingIndicator{align-items:center;color:var(--docsearch-highlight-color);display:flex;justify-content:center}@media screen and (prefers-reduced-motion:reduce){.DocSearch-Reset{animation:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;border-radius:50%;color:var(--docsearch-icon-color);cursor:pointer;right:0;stroke-width:var(--docsearch-icon-stroke-width)}}.DocSearch-Reset{animation:fade-in .1s ease-in forwards;-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;border-radius:50%;color:var(--docsearch-icon-color);cursor:pointer;padding:2px;right:0;stroke-width:var(--docsearch-icon-stroke-width)}.DocSearch-Reset[hidden]{display:none}.DocSearch-Reset:hover{color:var(--docsearch-highlight-color)}.DocSearch-LoadingIndicator svg,.DocSearch-MagnifierLabel svg{height:24px;width:24px}.DocSearch-Cancel{display:none}.DocSearch-Dropdown{max-height:calc(var(--docsearch-modal-height) - var(--docsearch-searchbox-height) - var(--docsearch-spacing) - var(--docsearch-footer-height));min-height:var(--docsearch-spacing);overflow-y:auto;overflow-y:overlay;padding:0 var(--docsearch-spacing);scrollbar-color:var(--docsearch-muted-color) var(--docsearch-modal-background);scrollbar-width:thin}.DocSearch-Dropdown::-webkit-scrollbar{width:12px}.DocSearch-Dropdown::-webkit-scrollbar-track{background:transparent}.DocSearch-Dropdown::-webkit-scrollbar-thumb{background-color:var(--docsearch-muted-color);border:3px solid var(--docsearch-modal-background);border-radius:20px}.DocSearch-Dropdown ul{list-style:none;margin:0;padding:0}.DocSearch-Label{font-size:.75em;line-height:1.6em}.DocSearch-Help,.DocSearch-Label{color:var(--docsearch-muted-color)}.DocSearch-Help{font-size:.9em;margin:0;-webkit-user-select:none;user-select:none}.DocSearch-Title{font-size:1.2em}.DocSearch-Logo a{display:flex}.DocSearch-Logo svg{color:var(--docsearch-logo-color);margin-left:8px}.DocSearch-Hits:last-of-type{margin-bottom:24px}.DocSearch-Hits mark{background:none;color:var(--docsearch-highlight-color)}.DocSearch-HitsFooter{color:var(--docsearch-muted-color);display:flex;font-size:.85em;justify-content:center;margin-bottom:var(--docsearch-spacing);padding:var(--docsearch-spacing)}.DocSearch-HitsFooter a{border-bottom:1px solid;color:inherit}.DocSearch-Hit{border-radius:4px;display:flex;padding-bottom:4px;position:relative}@media screen and (prefers-reduced-motion:reduce){.DocSearch-Hit--deleting{transition:none}}.DocSearch-Hit--deleting{opacity:0;transition:all .25s linear}@media screen and (prefers-reduced-motion:reduce){.DocSearch-Hit--favoriting{transition:none}}.DocSearch-Hit--favoriting{transform:scale(0);transform-origin:top center;transition:all .25s linear;transition-delay:.25s}.DocSearch-Hit a{background:var(--docsearch-hit-background);border-radius:4px;box-shadow:var(--docsearch-hit-shadow);display:block;padding-left:var(--docsearch-spacing);width:100%}.DocSearch-Hit-source{background:var(--docsearch-modal-background);color:var(--docsearch-highlight-color);font-size:.85em;font-weight:600;line-height:32px;margin:0 -4px;padding:8px 4px 0;position:sticky;top:0;z-index:10}.DocSearch-Hit-Tree{color:var(--docsearch-muted-color);height:var(--docsearch-hit-height);opacity:.5;stroke-width:var(--docsearch-icon-stroke-width);width:24px}.DocSearch-Hit[aria-selected=true] a{background-color:var(--docsearch-highlight-color)}.DocSearch-Hit[aria-selected=true] mark{text-decoration:underline}.DocSearch-Hit-Container{align-items:center;color:var(--docsearch-hit-color);display:flex;flex-direction:row;height:var(--docsearch-hit-height);padding:0 var(--docsearch-spacing) 0 0}.DocSearch-Hit-icon{height:20px;width:20px}.DocSearch-Hit-action,.DocSearch-Hit-icon{color:var(--docsearch-muted-color);stroke-width:var(--docsearch-icon-stroke-width)}.DocSearch-Hit-action{align-items:center;display:flex;height:22px;width:22px}.DocSearch-Hit-action svg{display:block;height:18px;width:18px}.DocSearch-Hit-action+.DocSearch-Hit-action{margin-left:6px}.DocSearch-Hit-action-button{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;border-radius:50%;color:inherit;cursor:pointer;padding:2px}svg.DocSearch-Hit-Select-Icon{display:none}.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-Select-Icon{display:block}.DocSearch-Hit-action-button:focus,.DocSearch-Hit-action-button:hover{background:rgba(0,0,0,.2);transition:background-color .1s ease-in}@media screen and (prefers-reduced-motion:reduce){.DocSearch-Hit-action-button:focus,.DocSearch-Hit-action-button:hover{transition:none}}.DocSearch-Hit-action-button:focus path,.DocSearch-Hit-action-button:hover path{fill:#fff}.DocSearch-Hit-content-wrapper{display:flex;flex:1 1 auto;flex-direction:column;font-weight:500;justify-content:center;line-height:1.2em;margin:0 8px;overflow-x:hidden;position:relative;text-overflow:ellipsis;white-space:nowrap;width:80%}.DocSearch-Hit-title{font-size:.9em}.DocSearch-Hit-path{color:var(--docsearch-muted-color);font-size:.75em}.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-action,.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-icon,.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-path,.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-text,.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-title,.DocSearch-Hit[aria-selected=true] .DocSearch-Hit-Tree,.DocSearch-Hit[aria-selected=true] mark{color:var(--docsearch-hit-active-color)!important}@media screen and (prefers-reduced-motion:reduce){.DocSearch-Hit-action-button:focus,.DocSearch-Hit-action-button:hover{background:rgba(0,0,0,.2);transition:none}}.DocSearch-ErrorScreen,.DocSearch-NoResults,.DocSearch-StartScreen{font-size:.9em;margin:0 auto;padding:36px 0;text-align:center;width:80%}.DocSearch-Screen-Icon{color:var(--docsearch-muted-color);padding-bottom:12px}.DocSearch-NoResults-Prefill-List{display:inline-block;padding-bottom:24px;text-align:left}.DocSearch-NoResults-Prefill-List ul{display:inline-block;padding:8px 0 0}.DocSearch-NoResults-Prefill-List li{list-style-position:inside;list-style-type:"» "}.DocSearch-Prefill{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;border-radius:1em;color:var(--docsearch-highlight-color);cursor:pointer;display:inline-block;font-size:1em;font-weight:700;padding:0}.DocSearch-Prefill:focus,.DocSearch-Prefill:hover{outline:none;text-decoration:underline}.DocSearch-Footer{align-items:center;background:var(--docsearch-footer-background);border-radius:0 0 8px 8px;box-shadow:var(--docsearch-footer-shadow);display:flex;flex-direction:row-reverse;flex-shrink:0;height:var(--docsearch-footer-height);justify-content:space-between;padding:0 var(--docsearch-spacing);position:relative;-webkit-user-select:none;user-select:none;width:100%;z-index:300}.DocSearch-Commands{color:var(--docsearch-muted-color);display:flex;list-style:none;margin:0;padding:0}.DocSearch-Commands li{align-items:center;display:flex}.DocSearch-Commands li:not(:last-of-type){margin-right:.8em}.DocSearch-Commands-Key{align-items:center;background:var(--docsearch-key-gradient);border-radius:2px;box-shadow:var(--docsearch-key-shadow);display:flex;height:18px;justify-content:center;margin-right:.4em;padding:0 0 1px;color:var(--docsearch-muted-color);border:0;width:20px}@media (max-width:768px){:root{--docsearch-spacing:10px;--docsearch-footer-height:40px}.DocSearch-Dropdown{height:100%}.DocSearch-Container{height:100vh;height:-webkit-fill-available;height:calc(var(--docsearch-vh, 1vh)*100);position:absolute}.DocSearch-Footer{border-radius:0;bottom:0;position:absolute}.DocSearch-Hit-content-wrapper{display:flex;position:relative;width:80%}.DocSearch-Modal{border-radius:0;box-shadow:none;height:100vh;height:-webkit-fill-available;height:calc(var(--docsearch-vh, 1vh)*100);margin:0;max-width:100%;width:100%}.DocSearch-Dropdown{max-height:calc(var(--docsearch-vh, 1vh)*100 - var(--docsearch-searchbox-height) - var(--docsearch-spacing) - var(--docsearch-footer-height))}.DocSearch-Cancel{-webkit-appearance:none;-moz-appearance:none;appearance:none;background:none;border:0;color:var(--docsearch-highlight-color);cursor:pointer;display:inline-block;flex:none;font:inherit;font-size:1em;font-weight:500;margin-left:var(--docsearch-spacing);outline:none;overflow:hidden;padding:0;-webkit-user-select:none;user-select:none;white-space:nowrap}.DocSearch-Commands,.DocSearch-Hit-Tree{display:none}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}[class*=DocSearch]{--docsearch-primary-color: var(--vp-c-brand-1);--docsearch-highlight-color: var(--docsearch-primary-color);--docsearch-text-color: var(--vp-c-text-1);--docsearch-muted-color: var(--vp-c-text-2);--docsearch-searchbox-shadow: none;--docsearch-searchbox-background: transparent;--docsearch-searchbox-focus-background: transparent;--docsearch-key-gradient: transparent;--docsearch-key-shadow: none;--docsearch-modal-background: var(--vp-c-bg-soft);--docsearch-footer-background: var(--vp-c-bg)}.dark [class*=DocSearch]{--docsearch-modal-shadow: none;--docsearch-footer-shadow: none;--docsearch-logo-color: var(--vp-c-text-2);--docsearch-hit-background: var(--vp-c-default-soft);--docsearch-hit-color: var(--vp-c-text-2);--docsearch-hit-shadow: none}.DocSearch-Button{display:flex;justify-content:center;align-items:center;margin:0;padding:0;width:48px;height:55px;background:transparent;transition:border-color .25s}.DocSearch-Button:hover{background:transparent}.DocSearch-Button:focus{outline:1px dotted;outline:5px auto -webkit-focus-ring-color}.DocSearch-Button:focus:not(:focus-visible){outline:none!important}@media (min-width: 768px){.DocSearch-Button{justify-content:flex-start;border:1px solid transparent;border-radius:8px;padding:0 10px 0 12px;width:100%;height:40px;background-color:var(--vp-c-bg-alt)}.DocSearch-Button:hover{border-color:var(--vp-c-brand-1);background:var(--vp-c-bg-alt)}}.DocSearch-Button .DocSearch-Button-Container{display:flex;align-items:center}.DocSearch-Button .DocSearch-Search-Icon{position:relative;width:16px;height:16px;color:var(--vp-c-text-1);fill:currentColor;transition:color .5s}.DocSearch-Button:hover .DocSearch-Search-Icon{color:var(--vp-c-text-1)}@media (min-width: 768px){.DocSearch-Button .DocSearch-Search-Icon{top:1px;margin-right:8px;width:14px;height:14px;color:var(--vp-c-text-2)}}.DocSearch-Button .DocSearch-Button-Placeholder{display:none;margin-top:2px;padding:0 16px 0 0;font-size:13px;font-weight:500;color:var(--vp-c-text-2);transition:color .5s}.DocSearch-Button:hover .DocSearch-Button-Placeholder{color:var(--vp-c-text-1)}@media (min-width: 768px){.DocSearch-Button .DocSearch-Button-Placeholder{display:inline-block}}.DocSearch-Button .DocSearch-Button-Keys{direction:ltr;display:none;min-width:auto}@media (min-width: 768px){.DocSearch-Button .DocSearch-Button-Keys{display:flex;align-items:center}}.DocSearch-Button .DocSearch-Button-Key{display:block;margin:2px 0 0;border:1px solid var(--vp-c-divider);border-right:none;border-radius:4px 0 0 4px;padding-left:6px;min-width:0;width:auto;height:22px;line-height:22px;font-family:var(--vp-font-family-base);font-size:12px;font-weight:500;transition:color .5s,border-color .5s}.DocSearch-Button .DocSearch-Button-Key+.DocSearch-Button-Key{border-right:1px solid var(--vp-c-divider);border-left:none;border-radius:0 4px 4px 0;padding-left:2px;padding-right:6px}.DocSearch-Button .DocSearch-Button-Key:first-child{font-size:0!important}.DocSearch-Button .DocSearch-Button-Key:first-child:after{content:"Ctrl";font-size:12px;letter-spacing:normal;color:var(--docsearch-muted-color)}.mac .DocSearch-Button .DocSearch-Button-Key:first-child:after{content:"⌘"}.DocSearch-Button .DocSearch-Button-Key:first-child>*{display:none}.VPNavBarSearch{display:flex;align-items:center}@media (min-width: 768px){.VPNavBarSearch{flex-grow:1;padding-left:24px}}@media (min-width: 960px){.VPNavBarSearch{padding-left:32px}}.dark .DocSearch-Footer{border-top:1px solid var(--vp-c-divider)}.DocSearch-Form{border:1px solid var(--vp-c-brand-1);background-color:var(--vp-c-white)}.dark .DocSearch-Form{background-color:var(--vp-c-default-soft)}.DocSearch-Screen-Icon>svg{margin:auto}.VPNavBarSocialLinks[data-v-0394ad82]{display:none}@media (min-width: 1280px){.VPNavBarSocialLinks[data-v-0394ad82]{display:flex;align-items:center}}.title[data-v-86d1bed8]{display:flex;align-items:center;border-bottom:1px solid transparent;width:100%;height:var(--vp-nav-height);font-size:16px;font-weight:600;color:var(--vp-c-text-1);transition:opacity .25s}@media (min-width: 960px){.title[data-v-86d1bed8]{flex-shrink:0}.VPNavBarTitle.has-sidebar .title[data-v-86d1bed8]{border-bottom-color:var(--vp-c-divider)}}[data-v-86d1bed8] .logo{margin-right:8px;height:var(--vp-nav-logo-height)}.VPNavBarTranslations[data-v-74abcbb9]{display:none}@media (min-width: 1280px){.VPNavBarTranslations[data-v-74abcbb9]{display:flex;align-items:center}}.title[data-v-74abcbb9]{padding:0 24px 0 12px;line-height:32px;font-size:14px;font-weight:700;color:var(--vp-c-text-1)}.VPNavBar[data-v-a0fd61f4]{position:relative;border-bottom:1px solid transparent;padding:0 8px 0 24px;height:var(--vp-nav-height);pointer-events:none;white-space:nowrap}@media (min-width: 768px){.VPNavBar[data-v-a0fd61f4]{padding:0 32px}}@media (min-width: 960px){.VPNavBar.has-sidebar[data-v-a0fd61f4]{padding:0}.VPNavBar[data-v-a0fd61f4]:not(.has-sidebar):not(.top){border-bottom-color:var(--vp-c-gutter);background-color:var(--vp-nav-bg-color)}}.container[data-v-a0fd61f4]{display:flex;justify-content:space-between;margin:0 auto;max-width:calc(var(--vp-layout-max-width) - 64px);height:var(--vp-nav-height);pointer-events:none}.container>.title[data-v-a0fd61f4],.container>.content[data-v-a0fd61f4]{pointer-events:none}.container[data-v-a0fd61f4] *{pointer-events:auto}@media (min-width: 960px){.VPNavBar.has-sidebar .container[data-v-a0fd61f4]{max-width:100%}}.title[data-v-a0fd61f4]{flex-shrink:0;height:calc(var(--vp-nav-height) - 1px);transition:background-color .5s}@media (min-width: 960px){.VPNavBar.has-sidebar .title[data-v-a0fd61f4]{position:absolute;top:0;left:0;z-index:2;padding:0 32px;width:var(--vp-sidebar-width);height:var(--vp-nav-height);background-color:transparent}}@media (min-width: 1440px){.VPNavBar.has-sidebar .title[data-v-a0fd61f4]{padding-left:max(32px,calc((100% - (var(--vp-layout-max-width) - 64px)) / 2));width:calc((100% - (var(--vp-layout-max-width) - 64px)) / 2 + var(--vp-sidebar-width) - 32px)}}.content[data-v-a0fd61f4]{flex-grow:1}@media (min-width: 960px){.VPNavBar.has-sidebar .content[data-v-a0fd61f4]{position:relative;z-index:1;padding-right:32px;padding-left:var(--vp-sidebar-width)}}@media (min-width: 1440px){.VPNavBar.has-sidebar .content[data-v-a0fd61f4]{padding-right:calc((100vw - var(--vp-layout-max-width)) / 2 + 32px);padding-left:calc((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width))}}.content-body[data-v-a0fd61f4]{display:flex;justify-content:flex-end;align-items:center;height:calc(var(--vp-nav-height) - 1px);transition:background-color .5s}@media (min-width: 960px){.VPNavBar:not(.top) .content-body[data-v-a0fd61f4]{position:relative;background-color:var(--vp-nav-bg-color)}}@media (max-width: 767px){.content-body[data-v-a0fd61f4]{column-gap:.5rem}}.menu+.translations[data-v-a0fd61f4]:before,.menu+.appearance[data-v-a0fd61f4]:before,.menu+.social-links[data-v-a0fd61f4]:before,.translations+.appearance[data-v-a0fd61f4]:before,.appearance+.social-links[data-v-a0fd61f4]:before{margin-right:8px;margin-left:8px;width:1px;height:24px;background-color:var(--vp-c-divider);content:""}.menu+.appearance[data-v-a0fd61f4]:before,.translations+.appearance[data-v-a0fd61f4]:before{margin-right:16px}.appearance+.social-links[data-v-a0fd61f4]:before{margin-left:16px}.social-links[data-v-a0fd61f4]{margin-right:-8px}@media (min-width: 960px){.VPNavBar.has-sidebar .curtain[data-v-a0fd61f4]{position:absolute;right:0;bottom:-31px;width:calc(100% - var(--vp-sidebar-width));height:32px}.VPNavBar.has-sidebar .curtain[data-v-a0fd61f4]:before{display:block;width:100%;height:32px;background:linear-gradient(var(--vp-c-bg),transparent 70%);content:""}}@media (min-width: 1440px){.VPNavBar.has-sidebar .curtain[data-v-a0fd61f4]{width:calc(100% - ((100vw - var(--vp-layout-max-width)) / 2 + var(--vp-sidebar-width)))}}.VPNavScreenAppearance[data-v-add8f686]{display:flex;justify-content:space-between;align-items:center;border-radius:8px;padding:12px 14px 12px 16px;background-color:var(--vp-c-bg-soft)}.text[data-v-add8f686]{line-height:24px;font-size:12px;font-weight:500;color:var(--vp-c-text-2)}.VPNavScreenMenuLink[data-v-05f27b2a]{display:block;border-bottom:1px solid var(--vp-c-divider);padding:12px 0 11px;line-height:24px;font-size:14px;font-weight:500;color:var(--vp-c-text-1);transition:border-color .25s,color .25s}.VPNavScreenMenuLink[data-v-05f27b2a]:hover{color:var(--vp-c-brand-1)}.VPNavScreenMenuGroupLink[data-v-19976ae1]{display:block;margin-left:12px;line-height:32px;font-size:14px;font-weight:400;color:var(--vp-c-text-1);transition:color .25s}.VPNavScreenMenuGroupLink[data-v-19976ae1]:hover{color:var(--vp-c-brand-1)}.VPNavScreenMenuGroupSection[data-v-8133b170]{display:block}.title[data-v-8133b170]{line-height:32px;font-size:13px;font-weight:700;color:var(--vp-c-text-2);transition:color .25s}.VPNavScreenMenuGroup[data-v-1ecb84e7]{border-bottom:1px solid var(--vp-c-divider);height:48px;overflow:hidden;transition:border-color .5s}.VPNavScreenMenuGroup .items[data-v-1ecb84e7]{visibility:hidden}.VPNavScreenMenuGroup.open .items[data-v-1ecb84e7]{visibility:visible}.VPNavScreenMenuGroup.open[data-v-1ecb84e7]{padding-bottom:10px;height:auto}.VPNavScreenMenuGroup.open .button[data-v-1ecb84e7]{padding-bottom:6px;color:var(--vp-c-brand-1)}.VPNavScreenMenuGroup.open .button-icon[data-v-1ecb84e7]{transform:rotate(45deg)}.button[data-v-1ecb84e7]{display:flex;justify-content:space-between;align-items:center;padding:12px 4px 11px 0;width:100%;line-height:24px;font-size:14px;font-weight:500;color:var(--vp-c-text-1);transition:color .25s}.button[data-v-1ecb84e7]:hover{color:var(--vp-c-brand-1)}.button-icon[data-v-1ecb84e7]{width:14px;height:14px;fill:var(--vp-c-text-2);transition:fill .5s,transform .25s}.group[data-v-1ecb84e7]:first-child{padding-top:0}.group+.group[data-v-1ecb84e7],.group+.item[data-v-1ecb84e7]{padding-top:4px}.VPNavScreenTranslations[data-v-d72aa483]{height:24px;overflow:hidden}.VPNavScreenTranslations.open[data-v-d72aa483]{height:auto}.title[data-v-d72aa483]{display:flex;align-items:center;font-size:14px;font-weight:500;color:var(--vp-c-text-1)}.icon[data-v-d72aa483]{width:16px;height:16px;fill:currentColor}.icon.lang[data-v-d72aa483]{margin-right:8px}.icon.chevron[data-v-d72aa483]{margin-left:4px}.list[data-v-d72aa483]{padding:4px 0 0 24px}.link[data-v-d72aa483]{line-height:32px;font-size:13px;color:var(--vp-c-text-1)}.VPNavScreen[data-v-cc5739dd]{position:fixed;top:calc(var(--vp-nav-height) + var(--vp-layout-top-height, 0px) + 1px);right:0;bottom:0;left:0;padding:0 32px;width:100%;background-color:var(--vp-nav-screen-bg-color);overflow-y:auto;transition:background-color .5s;pointer-events:auto}.VPNavScreen.fade-enter-active[data-v-cc5739dd],.VPNavScreen.fade-leave-active[data-v-cc5739dd]{transition:opacity .25s}.VPNavScreen.fade-enter-active .container[data-v-cc5739dd],.VPNavScreen.fade-leave-active .container[data-v-cc5739dd]{transition:transform .25s ease}.VPNavScreen.fade-enter-from[data-v-cc5739dd],.VPNavScreen.fade-leave-to[data-v-cc5739dd]{opacity:0}.VPNavScreen.fade-enter-from .container[data-v-cc5739dd],.VPNavScreen.fade-leave-to .container[data-v-cc5739dd]{transform:translateY(-8px)}@media (min-width: 768px){.VPNavScreen[data-v-cc5739dd]{display:none}}.container[data-v-cc5739dd]{margin:0 auto;padding:24px 0 96px;max-width:288px}.menu+.translations[data-v-cc5739dd],.menu+.appearance[data-v-cc5739dd],.translations+.appearance[data-v-cc5739dd]{margin-top:24px}.menu+.social-links[data-v-cc5739dd]{margin-top:16px}.appearance+.social-links[data-v-cc5739dd]{margin-top:16px}.VPNav[data-v-ae24b3ad]{position:relative;top:var(--vp-layout-top-height, 0px);left:0;z-index:var(--vp-z-index-nav);width:100%;pointer-events:none;transition:background-color .5s}@media (min-width: 960px){.VPNav[data-v-ae24b3ad]{position:fixed}}.VPSidebarItem.level-0[data-v-e31bd47b]{padding-bottom:24px}.VPSidebarItem.collapsed.level-0[data-v-e31bd47b]{padding-bottom:10px}.item[data-v-e31bd47b]{position:relative;display:flex;width:100%}.VPSidebarItem.collapsible>.item[data-v-e31bd47b]{cursor:pointer}.indicator[data-v-e31bd47b]{position:absolute;top:6px;bottom:6px;left:-17px;width:2px;border-radius:2px;transition:background-color .25s}.VPSidebarItem.level-2.is-active>.item>.indicator[data-v-e31bd47b],.VPSidebarItem.level-3.is-active>.item>.indicator[data-v-e31bd47b],.VPSidebarItem.level-4.is-active>.item>.indicator[data-v-e31bd47b],.VPSidebarItem.level-5.is-active>.item>.indicator[data-v-e31bd47b]{background-color:var(--vp-c-brand-1)}.link[data-v-e31bd47b]{display:flex;align-items:center;flex-grow:1}.text[data-v-e31bd47b]{flex-grow:1;padding:4px 0;line-height:24px;font-size:14px;transition:color .25s}.VPSidebarItem.level-0 .text[data-v-e31bd47b]{font-weight:700;color:var(--vp-c-text-1)}.VPSidebarItem.level-1 .text[data-v-e31bd47b],.VPSidebarItem.level-2 .text[data-v-e31bd47b],.VPSidebarItem.level-3 .text[data-v-e31bd47b],.VPSidebarItem.level-4 .text[data-v-e31bd47b],.VPSidebarItem.level-5 .text[data-v-e31bd47b]{font-weight:500;color:var(--vp-c-text-2)}.VPSidebarItem.level-0.is-link>.item>.link:hover .text[data-v-e31bd47b],.VPSidebarItem.level-1.is-link>.item>.link:hover .text[data-v-e31bd47b],.VPSidebarItem.level-2.is-link>.item>.link:hover .text[data-v-e31bd47b],.VPSidebarItem.level-3.is-link>.item>.link:hover .text[data-v-e31bd47b],.VPSidebarItem.level-4.is-link>.item>.link:hover .text[data-v-e31bd47b],.VPSidebarItem.level-5.is-link>.item>.link:hover .text[data-v-e31bd47b]{color:var(--vp-c-brand-1)}.VPSidebarItem.level-0.has-active>.item>.text[data-v-e31bd47b],.VPSidebarItem.level-1.has-active>.item>.text[data-v-e31bd47b],.VPSidebarItem.level-2.has-active>.item>.text[data-v-e31bd47b],.VPSidebarItem.level-3.has-active>.item>.text[data-v-e31bd47b],.VPSidebarItem.level-4.has-active>.item>.text[data-v-e31bd47b],.VPSidebarItem.level-5.has-active>.item>.text[data-v-e31bd47b],.VPSidebarItem.level-0.has-active>.item>.link>.text[data-v-e31bd47b],.VPSidebarItem.level-1.has-active>.item>.link>.text[data-v-e31bd47b],.VPSidebarItem.level-2.has-active>.item>.link>.text[data-v-e31bd47b],.VPSidebarItem.level-3.has-active>.item>.link>.text[data-v-e31bd47b],.VPSidebarItem.level-4.has-active>.item>.link>.text[data-v-e31bd47b],.VPSidebarItem.level-5.has-active>.item>.link>.text[data-v-e31bd47b]{color:var(--vp-c-text-1)}.VPSidebarItem.level-0.is-active>.item .link>.text[data-v-e31bd47b],.VPSidebarItem.level-1.is-active>.item .link>.text[data-v-e31bd47b],.VPSidebarItem.level-2.is-active>.item .link>.text[data-v-e31bd47b],.VPSidebarItem.level-3.is-active>.item .link>.text[data-v-e31bd47b],.VPSidebarItem.level-4.is-active>.item .link>.text[data-v-e31bd47b],.VPSidebarItem.level-5.is-active>.item .link>.text[data-v-e31bd47b]{color:var(--vp-c-brand-1)}.caret[data-v-e31bd47b]{display:flex;justify-content:center;align-items:center;margin-right:-7px;width:32px;height:32px;color:var(--vp-c-text-3);cursor:pointer;transition:color .25s;flex-shrink:0}.item:hover .caret[data-v-e31bd47b]{color:var(--vp-c-text-2)}.item:hover .caret[data-v-e31bd47b]:hover{color:var(--vp-c-text-1)}.caret-icon[data-v-e31bd47b]{width:18px;height:18px;fill:currentColor;transform:rotate(90deg);transition:transform .25s}.VPSidebarItem.collapsed .caret-icon[data-v-e31bd47b]{transform:rotate(0)}.VPSidebarItem.level-1 .items[data-v-e31bd47b],.VPSidebarItem.level-2 .items[data-v-e31bd47b],.VPSidebarItem.level-3 .items[data-v-e31bd47b],.VPSidebarItem.level-4 .items[data-v-e31bd47b],.VPSidebarItem.level-5 .items[data-v-e31bd47b]{border-left:1px solid var(--vp-c-divider);padding-left:16px}.VPSidebarItem.collapsed .items[data-v-e31bd47b]{display:none}.VPSidebar[data-v-b00e2fdd]{position:fixed;top:var(--vp-layout-top-height, 0px);bottom:0;left:0;z-index:var(--vp-z-index-sidebar);padding:32px 32px 96px;width:calc(100vw - 64px);max-width:320px;background-color:var(--vp-sidebar-bg-color);opacity:0;box-shadow:var(--vp-c-shadow-3);overflow-x:hidden;overflow-y:auto;transform:translate(-100%);transition:opacity .5s,transform .25s ease;overscroll-behavior:contain}.VPSidebar.open[data-v-b00e2fdd]{opacity:1;visibility:visible;transform:translate(0);transition:opacity .25s,transform .5s cubic-bezier(.19,1,.22,1)}.dark .VPSidebar[data-v-b00e2fdd]{box-shadow:var(--vp-shadow-1)}@media (min-width: 960px){.VPSidebar[data-v-b00e2fdd]{z-index:1;padding-top:var(--vp-nav-height);padding-bottom:128px;width:var(--vp-sidebar-width);max-width:100%;background-color:var(--vp-sidebar-bg-color);opacity:1;visibility:visible;box-shadow:none;transform:translate(0)}}@media (min-width: 1440px){.VPSidebar[data-v-b00e2fdd]{padding-left:max(32px,calc((100% - (var(--vp-layout-max-width) - 64px)) / 2));width:calc((100% - (var(--vp-layout-max-width) - 64px)) / 2 + var(--vp-sidebar-width) - 32px)}}@media (min-width: 960px){.curtain[data-v-b00e2fdd]{position:sticky;top:-64px;left:0;z-index:1;margin-top:calc(var(--vp-nav-height) * -1);margin-right:-32px;margin-left:-32px;height:var(--vp-nav-height);background-color:var(--vp-sidebar-bg-color)}}.nav[data-v-b00e2fdd]{outline:0}.group+.group[data-v-b00e2fdd]{border-top:1px solid var(--vp-c-divider);padding-top:10px}@media (min-width: 960px){.group[data-v-b00e2fdd]{padding-top:10px;width:calc(var(--vp-sidebar-width) - 64px)}}.VPSkipLink[data-v-0f60ec36]{top:8px;left:8px;padding:8px 16px;z-index:999;border-radius:8px;font-size:12px;font-weight:700;text-decoration:none;color:var(--vp-c-brand-1);box-shadow:var(--vp-shadow-3);background-color:var(--vp-c-bg)}.VPSkipLink[data-v-0f60ec36]:focus{height:auto;width:auto;clip:auto;clip-path:none}@media (min-width: 1280px){.VPSkipLink[data-v-0f60ec36]{top:14px;left:16px}}.Layout[data-v-5a346dfe]{display:flex;flex-direction:column;min-height:100vh}.VPHomeSponsors[data-v-96bd69d5]{border-top:1px solid var(--vp-c-gutter);padding:88px 24px 96px;background-color:var(--vp-c-bg)}.container[data-v-96bd69d5]{margin:0 auto;max-width:1152px}.love[data-v-96bd69d5]{margin:0 auto;width:28px;height:28px;color:var(--vp-c-text-3)}.icon[data-v-96bd69d5]{width:28px;height:28px;fill:currentColor}.message[data-v-96bd69d5]{margin:0 auto;padding-top:10px;max-width:320px;text-align:center;line-height:24px;font-size:16px;font-weight:500;color:var(--vp-c-text-2)}.sponsors[data-v-96bd69d5]{padding-top:32px}.action[data-v-96bd69d5]{padding-top:40px;text-align:center}.VPTeamPage[data-v-10b00018]{padding-bottom:96px}@media (min-width: 768px){.VPTeamPage[data-v-10b00018]{padding-bottom:128px}}.VPTeamPageSection+.VPTeamPageSection[data-v-10b00018-s],.VPTeamMembers+.VPTeamPageSection[data-v-10b00018-s]{margin-top:64px}.VPTeamMembers+.VPTeamMembers[data-v-10b00018-s]{margin-top:24px}@media (min-width: 768px){.VPTeamPageTitle+.VPTeamPageSection[data-v-10b00018-s]{margin-top:16px}.VPTeamPageSection+.VPTeamPageSection[data-v-10b00018-s],.VPTeamMembers+.VPTeamPageSection[data-v-10b00018-s]{margin-top:96px}}.VPTeamMembers[data-v-10b00018-s]{padding:0 24px}@media (min-width: 768px){.VPTeamMembers[data-v-10b00018-s]{padding:0 48px}}@media (min-width: 960px){.VPTeamMembers[data-v-10b00018-s]{padding:0 64px}}.VPTeamPageTitle[data-v-bf2cbdac]{padding:48px 32px;text-align:center}@media (min-width: 768px){.VPTeamPageTitle[data-v-bf2cbdac]{padding:64px 48px 48px}}@media (min-width: 960px){.VPTeamPageTitle[data-v-bf2cbdac]{padding:80px 64px 48px}}.title[data-v-bf2cbdac]{letter-spacing:0;line-height:44px;font-size:36px;font-weight:500}@media (min-width: 768px){.title[data-v-bf2cbdac]{letter-spacing:-.5px;line-height:56px;font-size:48px}}.lead[data-v-bf2cbdac]{margin:0 auto;max-width:512px;padding-top:12px;line-height:24px;font-size:16px;font-weight:500;color:var(--vp-c-text-2)}@media (min-width: 768px){.lead[data-v-bf2cbdac]{max-width:592px;letter-spacing:.15px;line-height:28px;font-size:20px}}.VPTeamPageSection[data-v-b1a88750]{padding:0 32px}@media (min-width: 768px){.VPTeamPageSection[data-v-b1a88750]{padding:0 48px}}@media (min-width: 960px){.VPTeamPageSection[data-v-b1a88750]{padding:0 64px}}.title[data-v-b1a88750]{position:relative;margin:0 auto;max-width:1152px;text-align:center;color:var(--vp-c-text-2)}.title-line[data-v-b1a88750]{position:absolute;top:16px;left:0;width:100%;height:1px;background-color:var(--vp-c-divider)}.title-text[data-v-b1a88750]{position:relative;display:inline-block;padding:0 24px;letter-spacing:0;line-height:32px;font-size:20px;font-weight:500;background-color:var(--vp-c-bg)}.lead[data-v-b1a88750]{margin:0 auto;max-width:480px;padding-top:12px;text-align:center;line-height:24px;font-size:16px;font-weight:500;color:var(--vp-c-text-2)}.members[data-v-b1a88750]{padding-top:40px}.VPTeamMembersItem[data-v-28528e42]{display:flex;flex-direction:column;gap:2px;border-radius:12px;width:100%;height:100%;overflow:hidden}.VPTeamMembersItem.small .profile[data-v-28528e42]{padding:32px}.VPTeamMembersItem.small .data[data-v-28528e42]{padding-top:20px}.VPTeamMembersItem.small .avatar[data-v-28528e42]{width:64px;height:64px}.VPTeamMembersItem.small .name[data-v-28528e42]{line-height:24px;font-size:16px}.VPTeamMembersItem.small .affiliation[data-v-28528e42]{padding-top:4px;line-height:20px;font-size:14px}.VPTeamMembersItem.small .desc[data-v-28528e42]{padding-top:12px;line-height:20px;font-size:14px}.VPTeamMembersItem.small .links[data-v-28528e42]{margin:0 -16px -20px;padding:10px 0 0}.VPTeamMembersItem.medium .profile[data-v-28528e42]{padding:48px 32px}.VPTeamMembersItem.medium .data[data-v-28528e42]{padding-top:24px;text-align:center}.VPTeamMembersItem.medium .avatar[data-v-28528e42]{width:96px;height:96px}.VPTeamMembersItem.medium .name[data-v-28528e42]{letter-spacing:.15px;line-height:28px;font-size:20px}.VPTeamMembersItem.medium .affiliation[data-v-28528e42]{padding-top:4px;font-size:16px}.VPTeamMembersItem.medium .desc[data-v-28528e42]{padding-top:16px;max-width:288px;font-size:16px}.VPTeamMembersItem.medium .links[data-v-28528e42]{margin:0 -16px -12px;padding:16px 12px 0}.profile[data-v-28528e42]{flex-grow:1;background-color:var(--vp-c-bg-soft)}.data[data-v-28528e42]{text-align:center}.avatar[data-v-28528e42]{position:relative;flex-shrink:0;margin:0 auto;border-radius:50%;box-shadow:var(--vp-shadow-3)}.avatar-img[data-v-28528e42]{position:absolute;top:0;right:0;bottom:0;left:0;border-radius:50%;object-fit:cover}.name[data-v-28528e42]{margin:0;font-weight:600}.affiliation[data-v-28528e42]{margin:0;font-weight:500;color:var(--vp-c-text-2)}.org.link[data-v-28528e42]{color:var(--vp-c-text-2);transition:color .25s}.org.link[data-v-28528e42]:hover{color:var(--vp-c-brand-1)}.desc[data-v-28528e42]{margin:0 auto}.desc[data-v-28528e42] a{font-weight:500;color:var(--vp-c-brand-1);text-decoration-style:dotted;transition:color .25s}.links[data-v-28528e42]{display:flex;justify-content:center;height:56px}.sp-link[data-v-28528e42]{display:flex;justify-content:center;align-items:center;text-align:center;padding:16px;font-size:14px;font-weight:500;color:var(--vp-c-sponsor);background-color:var(--vp-c-bg-soft);transition:color .25s,background-color .25s}.sp .sp-link.link[data-v-28528e42]:hover,.sp .sp-link.link[data-v-28528e42]:focus{outline:none;color:var(--vp-c-white);background-color:var(--vp-c-sponsor)}.sp-icon[data-v-28528e42]{margin-right:8px;width:16px;height:16px;fill:currentColor}.VPTeamMembers.small .container[data-v-6cb0dbc4]{grid-template-columns:repeat(auto-fit,minmax(224px,1fr))}.VPTeamMembers.small.count-1 .container[data-v-6cb0dbc4]{max-width:276px}.VPTeamMembers.small.count-2 .container[data-v-6cb0dbc4]{max-width:576px}.VPTeamMembers.small.count-3 .container[data-v-6cb0dbc4]{max-width:876px}.VPTeamMembers.medium .container[data-v-6cb0dbc4]{grid-template-columns:repeat(auto-fit,minmax(256px,1fr))}@media (min-width: 375px){.VPTeamMembers.medium .container[data-v-6cb0dbc4]{grid-template-columns:repeat(auto-fit,minmax(288px,1fr))}}.VPTeamMembers.medium.count-1 .container[data-v-6cb0dbc4]{max-width:368px}.VPTeamMembers.medium.count-2 .container[data-v-6cb0dbc4]{max-width:760px}.container[data-v-6cb0dbc4]{display:grid;gap:24px;margin:0 auto;max-width:1152px}.badges p{display:flex;gap:10px} diff --git a/assets/time.md.c33ce592.js b/assets/time.md.c33ce592.js new file mode 100644 index 00000000..f118819d --- /dev/null +++ b/assets/time.md.c33ce592.js @@ -0,0 +1,29 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const m=JSON.parse('{"title":"Time","description":"","frontmatter":{},"headers":[],"relativePath":"time.md","filePath":"time.md"}'),p={name:"time.md"},o=l(`

Time

_ms

Prints a human-string for a given number of milliseconds.

ts
_ms(1) // '1 ms'
+_ms(10) // '10 ms'
+_ms(1005) // '1.005 sec'
+_ms(49123) // '49 sec'
+_ms(60000) // '1m0s'
+_ms(60912) // '1m0s'
+_ms(69123) // '1m9s'
+_ms(3292100) // '54m52s'
+_ms(69642430) // '19h20m'
+_ms(101963481) // '28h'
_ms(1) // '1 ms'
+_ms(10) // '10 ms'
+_ms(1005) // '1.005 sec'
+_ms(49123) // '49 sec'
+_ms(60000) // '1m0s'
+_ms(60912) // '1m0s'
+_ms(69123) // '1m9s'
+_ms(3292100) // '54m52s'
+_ms(69642430) // '19h20m'
+_ms(101963481) // '28h'

_since

Useful to measure and human-print the "time elapsed since".

ts
const started = Date.now()
+
+// ... do stuff!
+
+console.log(\`Took \${_since(started)}\`)
+// Took 19m13s
const started = Date.now()
+
+// ... do stuff!
+
+console.log(\`Took \${_since(started)}\`)
+// Took 19m13s

Uses _ms for pretty-printing.

_debounce

Debounce function from Lodash.

See the typescript declaration for Options.

ts
const fn = _debounce(originalFn, 100, { leading: false, trailing: false, maxWait: 300 })
const fn = _debounce(originalFn, 100, { leading: false, trailing: false, maxWait: 300 })

_throttle

Throttle function from Lodash.

See the typescript declaration for Options.

ts
const fn = _throttle(originalFn, 100)
const fn = _throttle(originalFn, 100)
`,16),e=[o];function t(c,r,y,E,i,d){return a(),n("div",null,e)}const h=s(p,[["render",t]]);export{m as __pageData,h as default}; diff --git a/assets/time.md.c33ce592.lean.js b/assets/time.md.c33ce592.lean.js new file mode 100644 index 00000000..0bac787c --- /dev/null +++ b/assets/time.md.c33ce592.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const m=JSON.parse('{"title":"Time","description":"","frontmatter":{},"headers":[],"relativePath":"time.md","filePath":"time.md"}'),p={name:"time.md"},o=l("",16),e=[o];function t(c,r,y,E,i,d){return a(),n("div",null,e)}const h=s(p,[["render",t]]);export{m as __pageData,h as default}; diff --git a/assets/types.md.25b42ce5.js b/assets/types.md.25b42ce5.js new file mode 100644 index 00000000..3badc852 --- /dev/null +++ b/assets/types.md.25b42ce5.js @@ -0,0 +1,21 @@ +import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Types","description":"","frontmatter":{},"headers":[],"relativePath":"types.md","filePath":"types.md"}'),l={name:"types.md"},o=p(`

Types

Things that should exist in type-fest, but don't (yet).

Some types are copy-pasted from type-fest, because:

  1. To not introduce (another) dependency of this 0-dep lib
  2. To avoid multiple type-fest versions conflicts (that happened many times in the past)

StringMap

ts
const m: StringMap = { a: 'a' }
+// Same as:
+// const m: { [a: string]: string | undefined }
+
+const m: StringMap<number> = { a: 5 }
+// Same as:
+// const m: { [a: string]: number | undefined }
const m: StringMap = { a: 'a' }
+// Same as:
+// const m: { [a: string]: string | undefined }
+
+const m: StringMap<number> = { a: 5 }
+// Same as:
+// const m: { [a: string]: number | undefined }

The | undefined part is important!

It allows to set undefined values to StringMap, e.g:

ts
m.name = name1 // where \`name1\` can be undefined
m.name = name1 // where \`name1\` can be undefined

Mapper

ts
export type Mapper<IN = any, OUT = any> = (input: IN, index: number) => OUT
export type Mapper<IN = any, OUT = any> = (input: IN, index: number) => OUT

AsyncMapper

ts
export type AsyncMapper<IN = any, OUT = any> = (input: IN, index: number) => OUT | PromiseLike<OUT>
export type AsyncMapper<IN = any, OUT = any> = (input: IN, index: number) => OUT | PromiseLike<OUT>

Predicate

ts
export type Predicate<T> = (item: T, index: number) => boolean
export type Predicate<T> = (item: T, index: number) => boolean

Async Predicate

ts
export type AsyncPredicate<T> = (item: T, index: number) => boolean | PromiseLike<boolean>
export type AsyncPredicate<T> = (item: T, index: number) => boolean | PromiseLike<boolean>

_passthroughPredicate

Predicate that passes everything (returns true for every item).

ts
_passthroughPredicate(anything) // true
+  [(1, 2, 3)].filter(_passthroughPredicate)
+// [1, 2, 3]
_passthroughPredicate(anything) // true
+  [(1, 2, 3)].filter(_passthroughPredicate)
+// [1, 2, 3]

_passNothingPredicate

Predicate that passes nothing (returns false for every item).

ts
_passNothingPredicate(anything) // false
+  [(1, 2, 3)].filter(_passNothingPredicate)
+// []
_passNothingPredicate(anything) // false
+  [(1, 2, 3)].filter(_passNothingPredicate)
+// []

_noop

Function that takes any arguments and returns undefined. Literally does nothing.

Can be useful to replace some real world functions with mocks.

ts
element.click = _noop
element.click = _noop

Merge

ReadonlyDeep

Promisable

PromiseValue

`,31),e=[o];function t(r,c,y,E,i,d){return a(),n("div",null,e)}const g=s(l,[["render",t]]);export{F as __pageData,g as default}; diff --git a/assets/types.md.25b42ce5.lean.js b/assets/types.md.25b42ce5.lean.js new file mode 100644 index 00000000..763c4900 --- /dev/null +++ b/assets/types.md.25b42ce5.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as p}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Types","description":"","frontmatter":{},"headers":[],"relativePath":"types.md","filePath":"types.md"}'),l={name:"types.md"},o=p("",31),e=[o];function t(r,c,y,E,i,d){return a(),n("div",null,e)}const g=s(l,[["render",t]]);export{F as __pageData,g as default}; diff --git a/assets/units.md.61157064.js b/assets/units.md.61157064.js new file mode 100644 index 00000000..a687f1d1 --- /dev/null +++ b/assets/units.md.61157064.js @@ -0,0 +1,15 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Units","description":"","frontmatter":{},"headers":[],"relativePath":"units.md","filePath":"units.md"}'),p={name:"units.md"},o=l(`

Units

_kb, _mb, _gb, _hb

Human-prints byte number into kilobytes, megabytes, gigabutes and "human-bytes" (_hb):

ts
_hb(0) // '0 byte(s)'
+_hb(500) // '500 byte(s)'
+_hb(1000) // '1 Kb'
+_hb(1024 ** 2) // '1 Mb'
+_hb(1024 ** 3) // '1 Gb'
+_kb(1000) // 1
+_mb(1024 ** 2) // 1
+_gb(1024 ** 3) // 1
_hb(0) // '0 byte(s)'
+_hb(500) // '500 byte(s)'
+_hb(1000) // '1 Kb'
+_hb(1024 ** 2) // '1 Mb'
+_hb(1024 ** 3) // '1 Gb'
+_kb(1000) // 1
+_mb(1024 ** 2) // 1
+_gb(1024 ** 3) // 1
`,4),e=[o];function t(c,r,y,E,i,b){return a(),n("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default}; diff --git a/assets/units.md.61157064.lean.js b/assets/units.md.61157064.lean.js new file mode 100644 index 00000000..1374988c --- /dev/null +++ b/assets/units.md.61157064.lean.js @@ -0,0 +1 @@ +import{_ as s,o as a,c as n,Q as l}from"./chunks/framework.01940dea.js";const F=JSON.parse('{"title":"Units","description":"","frontmatter":{},"headers":[],"relativePath":"units.md","filePath":"units.md"}'),p={name:"units.md"},o=l("",4),e=[o];function t(c,r,y,E,i,b){return a(),n("div",null,e)}const h=s(p,[["render",t]]);export{F as __pageData,h as default}; diff --git a/custom.css b/custom.css new file mode 100644 index 00000000..ccb09df6 --- /dev/null +++ b/custom.css @@ -0,0 +1,21 @@ +.app-content button { + border: 1px solid #aaa; + border-radius: 4px; + background-color: #eee; + padding: 4px 16px; + margin: 0 2px; + cursor: pointer; +} + +.app-content button:hover { + background-color: #ddd; +} + +.app-content button[disabled] { + color: #aaa; + cursor: default; +} + +.app-content button[disabled]:hover { + background-color: #eee; +} diff --git a/date.html b/date.html new file mode 100644 index 00000000..3991eb30 --- /dev/null +++ b/date.html @@ -0,0 +1,23 @@ + + + + + + LocalDate, LocalTime | js-lib + + + + + + + + + + + + +
Skip to content

LocalDate, LocalTime

Why?

Serves as an alternative / replacement of Moment.js / Day.js.

It tries to address the shortcomings of Day.js and time-lib.

time-lib was created as a wrapper around Day.js, due to following limitations:

  • Day.js doesn't provide all features that we need without plugins. This creates an "import problem": you cannot just import dayjs, you need to import it from a place that had plugins properly installed and initialized. It immediately creates an "import ambiguity": should I import from dayjs or from my_code/dayjs.ts?
  • Day.js is created as CommonJS module, all plugins has to be explicitly required. There are issues around TypeScript esModuleInterop. Result of it is that we needed to completely fork Day.js types and put it into time-lib.
  • There are more/deeper ESM issues when it's used in ESM context (e.g with Vite).

Next level of reasoning is that we needed our own opinionated API that would use standards that we use, for example:

  • We always use classic Unixtime (in seconds, not milliseconds)
  • We always use classic ISO8601 date without timezone, e.g 1984-06-21

Just the second/millisecond confusion can create serious bugs.

Mixup between similarly-called .toISOString and .toISODate can create very subtle bugs.

So, after multiple issues being accumulated and inability to properly fork Day.js, it was decided to try and simply rewrite Day.js functionality into LocalDate and LocalTime.

Reasons:

  • No milliseconds in the API (not needed)
  • Classic UnixTime, never "millisecond unixtime"
  • No timezone support/confusion, all dates/times are always treated as "local" (inspired by Java LocalDate/LocalDateTime)
  • Ability to parse "timezone-aware ISO8601 string", e.g 1984-06-21T17:15:02+02 into a LocalDate of just 1984-06-21 or LocalTime of 1984-06-21T17:15:02 (try achieving it with Moment.js or Day.js!)
  • .toJSON automatically formats LocalTime as unixtimestamp, LocalDate as ISO8601 date-only string
  • Prevents dayjs(undefined) being dayjs.now()
  • Strict parsing/validation by default. Will validate all input upon creation and will throw parse error on any invalid input. We believe it allows to catch errors sooner.
  • Optimized for performance and code maintenance, not on code size (as Day.js is, which results in its poorer performance in certain cases, and/or in less code maintainability)
  • No arbitrary .format by design. List of well-known format outputs instead.
  • Separate LocalDate class for simplified (and more performant) dealing with "just Dates without time information". Similar to Java's LocalDate. It allows much more simple and robust implementation, compared to dealing with js Date object intricacies (mostly around timezones).

API

API is designed to be closely (but not 100%) compatible with Day.js/Moment.js.

Examples:

day.js (via time-lib)LocalTimeLocalDate
nowdayjs()localTime()
todaydayjs().startOf('day')localDate()
create from unixtimestampdayjs.unix(ts)localTime(ts)
parse from ISO8601 date stringdayjs(str)localDate(str)
parse from ISO8601 date+time stringdayjs(str)localTime(str)
now plus 1 hourdayjs().add(1, 'hour')localTime().plus(1, 'hour')
today plus 1 daydayjs().startOf('day').add(1, 'day')localDate().plus(1, 'day')
toISODate (just date)dayjs().toISODate()localTime().toISODate()localDate().toISODate()
toISODate with timedayjs().format()localTime().toISODateTime()
diff in daysdayjs().diff(other, 'day')localTime().diff(other, 'day')localDate().diff(other, 'day')
to unixtimestampdayjs().unix()localTime().unix()localDate().unix()
isBeforedayjs().isBefore(other)localTime().isBefore(other)localDate().isBefore(other)

As you can see above - API is kept very similar.

DateInterval

Useful to describe an interval of Dates, e.g [inclusive] interval between 1984-06-21 and 1984-07-11 can be described as 1984-06-21/1984-07-11 (as per ISO8601).

.toJSON automatically stringifies DateInterval into a string.

Create DateInterval: DateInterval.parse('1984-06-21/1984-07-11') or DateInterval.of('1984-06-21', '1984-07-11').

+ + + + \ No newline at end of file diff --git a/decorators.html b/decorators.html new file mode 100644 index 00000000..96e3fe01 --- /dev/null +++ b/decorators.html @@ -0,0 +1,135 @@ + + + + + + Decorators | js-lib + + + + + + + + + + + + +
Skip to content

Decorators

@_Debounce

Wrapper around _debounce.

@_Throttle

Wrapper around _throttle.

@_LogMethod

Allows to Log every execution of the method.

Console-logs when method had started, when it finished, time taken and if error happened.

Supports both sync and async methods.

Awaits if method returns a Promise.

Example output:

>> syncMethodSuccess()
+<< syncMethodSuccess() took 124 ms
+
+>> asyncMethod()
+<< asyncMethodThrow() took 10 ms ERROR: MyError
>> syncMethodSuccess()
+<< syncMethodSuccess() took 124 ms
+
+>> asyncMethod()
+<< asyncMethodThrow() took 10 ms ERROR: MyError
ts
class C {
+  @_LogMethod()
+  async hello() { ... }
+}
class C {
+  @_LogMethod()
+  async hello() { ... }
+}

@_Memo

Powerful Memoization decorator.

Simplest usage:

ts
class C {
+  @_Memo()
+  async init() { ... }
+}
+
+await c.init() // first time will run the initialization
+
+await c.init() // second time it'll skip it
+// Allows "max 1 execution" pattern
class C {
+  @_Memo()
+  async init() { ... }
+}
+
+await c.init() // first time will run the initialization
+
+await c.init() // second time it'll skip it
+// Allows "max 1 execution" pattern

Memoization caches values for each unique set of input parameters. So, e.g, if you want to hit a somewhat slow/expensive endpoint, you may want to cache it in memory like this:

ts
class C {
+  @_Memo()
+  async getExchangeRates(day: string) { ... }
+}
+
+// First time will hit the endpoint
+await c.getExchangeRates('2021-06-21')
+
+// Second time will immediately return cached result, cause the input is the same
+await c.getExchangeRates('2021-06-21')
+
+// Input has changed, so it's a cache-miss, will hit the endpoint
+await c.getExchangeRates('2021-06-22')
class C {
+  @_Memo()
+  async getExchangeRates(day: string) { ... }
+}
+
+// First time will hit the endpoint
+await c.getExchangeRates('2021-06-21')
+
+// Second time will immediately return cached result, cause the input is the same
+await c.getExchangeRates('2021-06-21')
+
+// Input has changed, so it's a cache-miss, will hit the endpoint
+await c.getExchangeRates('2021-06-22')

Pay attention that the cache of the returned values is kept forever, so, be mindful of possible memory leaks.

nodejs-lib (link pending) has a LRUMemoCache class that impements LRU cache. Example:

ts
@_Memo({ cacheFactory: () => new LRUMemoCache({...}) })
+async someMethod() {}
@_Memo({ cacheFactory: () => new LRUMemoCache({...}) })
+async someMethod() {}

@_Retry

Wrapper around pRetry.

@_Timeout

Decoratod method will throw TimeoutError if it hasn't finished in given time.

Wrapper around pTimeout.

ts
class C {
+  @_Timeout({ timeout: 1000 })
+  async hello() {
+    // some logic
+  }
+}
+
+const c = new C()
+await c.hello()
+// will throw if not finished in 1000 ms
class C {
+  @_Timeout({ timeout: 1000 })
+  async hello() {
+    // some logic
+  }
+}
+
+const c = new C()
+await c.hello()
+// will throw if not finished in 1000 ms

@_TryCatch

Wraps the method into a try/catch block, console.error(err) on error, but never re-throws (always suppresses the error).

ts
class C {
+  @_TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}
class C {
+  @_TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}

Wrapper around _tryCatch function.

_createPromiseDecorator

Powerful helper to create your own Decorators around async (Promise-returning) methods.

Example of a @TryCatch decorator that will wrap a method with "try/catch", console.error the error and suppress it (by returning undefined in case of any error).

Example usage:

ts
class C {
+  @TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}
class C {
+  @TryCatch() // fine if it fails
+  async logSomeAnalytics() {}
+}

Example implementation of such a decorator using _createPromiseDecorator:

ts
export const TryCatch = () =>
+  _createPromiseDecorator({
+    decoratorName: 'TryCatch',
+    catchFn: ({ err, target, key }) => {
+      console.error(err)
+      return undefined
+    },
+  })
export const TryCatch = () =>
+  _createPromiseDecorator({
+    decoratorName: 'TryCatch',
+    catchFn: ({ err, target, key }) => {
+      console.error(err)
+      return undefined
+    },
+  })

_createPromiseDecorator allows you to define your "hooks" on different stages of a Promise:

  • beforeFn: before the method execution
  • thenFn: after successful method execution
  • catchFn: after method throws (returns rejected Promise)
  • finallyFn: after method returns resolved or rejected Promise (useful to e.g "hide the blocking loader")

Example of a @BlockingLoader decorator, that wraps the method, shows the BlockingLoader before the method execution and hides it in the end of the execution (regardless if it errored or succeeded):

ts
export const BlockingLoader = () =>
+  _createPromiseDecorator({
+    decoratorName: 'BlockingLoader',
+    beforeFn: () => store.commit('setBlockingLoader'),
+    catchFn: ({ err }) => errorDialog(err),
+    finallyFn: () => store.commit('setBlockingLoader', false),
+  })
export const BlockingLoader = () =>
+  _createPromiseDecorator({
+    decoratorName: 'BlockingLoader',
+    beforeFn: () => store.commit('setBlockingLoader'),
+    catchFn: ({ err }) => errorDialog(err),
+    finallyFn: () => store.commit('setBlockingLoader', false),
+  })
+ + + + \ No newline at end of file diff --git a/error.html b/error.html new file mode 100644 index 00000000..0847b1a0 --- /dev/null +++ b/error.html @@ -0,0 +1,77 @@ + + + + + + Error | js-lib + + + + + + + + + + + + +
Skip to content

Error

_tryCatch

Wraps/decorates a passed function with "try/catch", so it never throws, but logs the error (if occured).

ts
const someDangerousFunction = () => { ... }
+
+const fn = _tryCatch(someDangerousFunction)
+
+fn()
+// will log on error, but never throw
const someDangerousFunction = () => { ... }
+
+const fn = _tryCatch(someDangerousFunction)
+
+fn()
+// will log on error, but never throw

Allows to pass onError() function hook, that will be called on error.

ErrorObject

Standartized "Error object" that contains arbitrary data object that can hold additional data.

This data object is defined as a Generic type to ErrorObject, so, e.g. HttpError has HttpErrorData, which has a mandatory httpStatusCode: number property.

Usage example of that:

ts
.catch((err: HttpErrorObject) => {
+  console.log(err.data.httpStatusCode)
+})
.catch((err: HttpErrorObject) => {
+  console.log(err.data.httpStatusCode)
+})

AppError

The most basic implementation of an Error that complies with ErrorObject specification. Difference is that ErrorObject is purely a TypeScript interface (around any JS object), but AppError is a sub-class of Error. So, with AppError you can do if (err instanceof AppError) ....

Because AppError implements ErrorObject, it guarantees an err.data object.

This basic contract allows to establish a standartized interface between the Frontend (in frontend-lib) and Backend (in backend-lib) and implement error-handling more efficiently.

HttpError

Subclass of AppError that has some additional properties inside data, namely: httpStatusCode: number.

HttpErrorResponse

This is a standartized "Error response from the Backend" (as implemented in backend-lib). You can check/assert it with _isHttpErrorResponse, and then have all the guarantees and types about the containing error object.

Handling these type of errors is done "automatically" in getKy of the frontend-lib, and in getGot of the backend-lib.

_anyToError

Cast any to Error.

_errorToErrorObject

Cast Error to ErrorObject.

_isHttpErrorResponse

Assert if provided value: any is a HttpErrorResponse.

_isHttpErrorObject

Assert if provided value: any is a HttpErrorObject (an HttpError, same as AppError<HttpErrorData>).

_isErrorObject

Assert if provided value: any is an ErrorObject.

_assert

Asserts that a boolean condition is truthy, otherwise throws an Error.

Evaluates the condition (casts it to Boolean). Expects it to be truthy, otherwise throws AppError.

Should be used NOT for "expected" / user-facing errors, but vice-versa - for completely unexpected and 100% buggy "should never happen" cases.

It'll result in http 500 on the server (cause that's the right code for "unexpected" errors). Pass { httpStatusCode: x } at errorData argument to override the http code (will be picked up by backend-lib).

API is similar to Node's assert(), except:

  1. Throws js-lib's AppError
  2. Has a default message, if not provided
  3. Sets userFriendly flag to true, cause it's always better to have at least SOME clue, rather than fully generic "Oops" error.
ts
function run(err: any) {
+  _assert(err instanceof AppError)
+  // from here TypeScript will know that `err instanceof AppError === true`, or `err: AppError`
+
+  // Example with custom error message:
+  _assert(err instanceof AppError, 'error should be of type AppError')
+}
function run(err: any) {
+  _assert(err instanceof AppError)
+  // from here TypeScript will know that `err instanceof AppError === true`, or `err: AppError`
+
+  // Example with custom error message:
+  _assert(err instanceof AppError, 'error should be of type AppError')
+}

_assertEquals

Similar to _assert, but allows to provide 2 values (first 2 arguments) and throws if they are NOT equal.

Does a shallow equality check (!==), use _assertDeepEquals if you need a deep-check.

_assertDeepEquals

Similar to _assertEquals, but does a deep assertion (using _deepEquals).

_assertIsError

Asserts that passed value is instanceof Error.

_assertsIsTypeOf

Asserts that typeof value matches expected type.

_assertsIsString

Asserts that typeof value === 'string

_assertsIsNumber

Asserts that typeof value === 'number

_try

Calls a function, returns a Tuple of [error, value]. Allows to write shorter code that avoids try/catch. Useful e.g. in unit tests.

Similar to pTry, but for sync functions.

ts
const [err, v] = _try(() => someFunction())
const [err, v] = _try(() => someFunction())

pTry

Loosely inspired by await-to-js.

Similar to _try, but for promises.

Async/await wrapper for easy error handling. Wraps async/await calls in try catch blocks and returns a tuple containing the error or the results of the promise

ts
interface ServerResponse {
+  test: number
+}
+
+interface CustomError {
+  code: number
+  data: {
+    title: string
+    body: string
+  }
+}
+
+const p = Promise.resolve({ test: 123 })
+
+const [err, result] = await pTuple<ServerResponse, CustomError>(p)
interface ServerResponse {
+  test: number
+}
+
+interface CustomError {
+  code: number
+  data: {
+    title: string
+    body: string
+  }
+}
+
+const p = Promise.resolve({ test: 123 })
+
+const [err, result] = await pTuple<ServerResponse, CustomError>(p)
+ + + + \ No newline at end of file diff --git a/fetcher.html b/fetcher.html new file mode 100644 index 00000000..08cb53c1 --- /dev/null +++ b/fetcher.html @@ -0,0 +1,71 @@ + + + + + + Fetcher | js-lib + + + + + + + + + + + + +
Skip to content

Fetcher

Convenient wrapper around fetch.

Features

  • Works in the Browser and on the Server (Node.js)
  • Convenient API, e.g fetcher.get(), fetcher.post(), etc.
  • Throws HttpError automatically, no need to check if (res.ok)
  • Allows to set timeout
  • Conveniently retries on retry-able errors
  • Allows to conveniently log requests/responses, configurable
  • Allows to convert searchParams object into a query string
  • Allows to define beforeRequest/beforeRetry/afterResponse hooks

Comparison

Fetcher:

tsx
const fetcher = getFetcher()
+
+const result = await fetcher.post('https://example.com', {
+  json: { foo: true },
+})
const fetcher = getFetcher()
+
+const result = await fetcher.post('https://example.com', {
+  json: { foo: true },
+})

Ky:

tsx
const result = await ky
+  .post('https://example.com/hello', {
+    json: { foo: true },
+  })
+  .json()
const result = await ky
+  .post('https://example.com/hello', {
+    json: { foo: true },
+  })
+  .json()

Plain fetch:

tsx
class HTTPError extends Error {}
+
+const response = await fetch('https://example.com', {
+  method: 'POST',
+  body: JSON.stringify({ foo: true }),
+  headers: {
+    'content-type': 'application/json',
+  },
+})
+
+if (!response.ok) {
+  throw new HTTPError(`Fetch error: ${response.statusText}`)
+}
+
+const json = await response.json()
+
+console.log(json)
class HTTPError extends Error {}
+
+const response = await fetch('https://example.com', {
+  method: 'POST',
+  body: JSON.stringify({ foo: true }),
+  headers: {
+    'content-type': 'application/json',
+  },
+})
+
+if (!response.ok) {
+  throw new HTTPError(`Fetch error: ${response.statusText}`)
+}
+
+const json = await response.json()
+
+console.log(json)

Prior art

Heavily inspired by:

Why

Differences from prior projects:

  • Targets both Browser and Node by design, targeting Node with native fetch support. This is similar to ky plus ky-universal.
  • Incorporates everything from getKy and getGot, so you don’t need multiple layers. For example, with ky you would need: ky, ky-for-people, getKy (frontend-lib). With fetcher you need only fetcher (part of js-lib).

Goals

  • Simplicity. It focuses on the most simple and common use cases, and not on the most advanced or edge cases.
  • Assume native fetch support (Browser and Node), no polyfills. Should work equally well in Browser and Node, ideally without platform-specific quirks.
  • Written in TypeScript, with first-class TypeScript support.
+ + + + \ No newline at end of file diff --git a/hashmap.json b/hashmap.json new file mode 100644 index 00000000..0b8dd579 --- /dev/null +++ b/hashmap.json @@ -0,0 +1 @@ +{"array.md":"1624f1c9","decorators.md":"5b065daa","date.md":"5f9576ec","math.md":"152995c2","number.md":"65c527f0","promise.md":"28e1b8f6","string.md":"68f834bf","httprequesterror.md":"ea988257","index.md":"96458ebc","fetcher.md":"3d42ae20","json.md":"1d0c16e2","lazy.md":"584a783f","error.md":"47250209","object.md":"4acc3c49","time.md":"c33ce592","types.md":"25b42ce5","units.md":"61157064"} diff --git a/httpRequestError.html b/httpRequestError.html new file mode 100644 index 00000000..17dfdfac --- /dev/null +++ b/httpRequestError.html @@ -0,0 +1,65 @@ + + + + + + js-lib | js-lib + + + + + + + + + + + + +
Skip to content
Backend makes a Fetch call to some API
+API returns error1 with 500 and a message1
+Fetcher wraps error1 with error2 which is a FetcherError
+method
+url
+baseUrl?
+statusCode
+millis
+message: 500 GET /someUrl
+causedBy error1
+
+genericErrorHandler needs to return error2
+it wraps error2 (FetchError) with error3: HttpError
+Maybe there's just no need to do that wrapping?! Return ErrorObject as is
+Requester (Fetcher) would always know httpStatusCode of the error they just received
+
+Why is HttpError needed?
+For the Backend to set the right httpStatusCode
+Maybe it's enough to just have it as AppError with httpStatusCode?
+
+Rename HttpError to HttpRequestError, which is the same as FetchError
+HttpErrorResponse becomes BackendErrorResponseObject (detected by name and message)
Backend makes a Fetch call to some API
+API returns error1 with 500 and a message1
+Fetcher wraps error1 with error2 which is a FetcherError
+method
+url
+baseUrl?
+statusCode
+millis
+message: 500 GET /someUrl
+causedBy error1
+
+genericErrorHandler needs to return error2
+it wraps error2 (FetchError) with error3: HttpError
+Maybe there's just no need to do that wrapping?! Return ErrorObject as is
+Requester (Fetcher) would always know httpStatusCode of the error they just received
+
+Why is HttpError needed?
+For the Backend to set the right httpStatusCode
+Maybe it's enough to just have it as AppError with httpStatusCode?
+
+Rename HttpError to HttpRequestError, which is the same as FetchError
+HttpErrorResponse becomes BackendErrorResponseObject (detected by name and message)
+ + + + \ No newline at end of file diff --git a/index.html b/index.html new file mode 100644 index 00000000..4c6c0938 --- /dev/null +++ b/index.html @@ -0,0 +1,39 @@ + + + + + + js-lib | js-lib + + + + + + + + + + + + +
Skip to content

js-lib

Standard library for universal (browser + Node.js) javascript

npmmin.gz sizeActionsloc

MaintainabilityTest Coveragecode style: prettier

Design

Inspired by Lodash, bluebird, promise-fun and other useful small packages.

Designed to play well with the rest of opinionated "Natural Cycles JS Platform" (link pending). This package is the lowest-level production dependency (not devDependency) of the Platform. Almost everything else depends on it.

All functions in this package are exported in index.ts (flat), no namespacing is used. So, to avoid conflicts and "global import namespace" pollution , all functions are prefixed with an underscore (e.g _.pick becomes _pick), with some exceptions (later). Promise functions are prefixed with p, e.g pMap.

Decorators are _prefixed and PascalCased (e.g @_Debounce). _is to be consistent with other naming in this package. PascalCase is to distinguish decorators from similar functions that are not decorators. Example:\_debounceis a function (lodash-based),\_Debounceis a decorator (used as@\_Debounce). PascalCase convention follows Angular/Ionic convention (but doesn't follow TypeScript documentation convention; we had to pick one).

Interfaces and Classes are named as usual (no prefix, PascalCase, e.g AppError).

Q: Why not just use lodash?

A:

  • We believe Lodash is outdated (many functions are pre-ES6 / obsolete by ES6).
  • Because it has so many outdated functions - its size is bigger, and solutions to tree-shake exist, but complicated.
  • First-class TypeScript support (all code in this repo is TypeScript).

This package is intended to be 0-dependency (exception: tslib from TypeScript), "not bloated", tree-shakeable. Supported by reasonably modern Browsers and Node.js latest LTS.

To fulfil that requirement it exports ESM version (for Browsers) as es2017.

Exports default CJS version for Node as es2019 (with native async/await, for better performance, async stack-traces, etc).

Mutation

All function does NOT mutate the arguments by default.

Many functions support "mutation flag", which can be set to true to perform a mutation.

For example:

ts
const obj = { a: 'a', b: 'b' }
+
+// Non-mutating (default)
+const obj2 = _pick(obj, ['a'])
+// { a: 'a' }
+
+// Mutating (opt-in)
+_pick(obj, ['a'], true)
+// obj was mutated
const obj = { a: 'a', b: 'b' }
+
+// Non-mutating (default)
+const obj2 = _pick(obj, ['a'])
+// { a: 'a' }
+
+// Mutating (opt-in)
+_pick(obj, ['a'], true)
+// obj was mutated

Highlights

Packaging

  • engines.node >= Node.js LTS
  • main: dist/index.js: commonjs, es2021 - targeting Node.js
  • module: dist-esm/index.js: esm, es2017 - targeting Browsers
  • types: dist/index.d.ts: typescript types
  • /src folder with source *.ts files included
+ + + + \ No newline at end of file diff --git a/json.html b/json.html new file mode 100644 index 00000000..ed9bd66c --- /dev/null +++ b/json.html @@ -0,0 +1,63 @@ + + + + + + Json | js-lib + + + + + + + + + + + + +
Skip to content

Json

_jsonParseIfPossible

Attempts to parse object as JSON.

Returns original object if JSON parse failed (silently).

ts
_jsonParseIfPossible('abc') // 'abc' (no change, not a json string)
+_jsonParseIfPossible(null) // null (no change)
+_jsonParseIfPossible({ a: 'a' }) // {a: 'a'} (same object, not a json string)
+_jsonParseIfPossible('{"a": "a"}') // {a: 'a'} gotcha! parsed json string into an object!
_jsonParseIfPossible('abc') // 'abc' (no change, not a json string)
+_jsonParseIfPossible(null) // null (no change)
+_jsonParseIfPossible({ a: 'a' }) // {a: 'a'} (same object, not a json string)
+_jsonParseIfPossible('{"a": "a"}') // {a: 'a'} gotcha! parsed json string into an object!

_stringify

Inspired by _inspect from nodejs-lib, which is based on util.inpect that is not available in the Browser.

Transforms any to human-readable string (via JSON.stringify pretty).

Safe (no error throwing).

Correclty prints Error, AppError, ErrorObject: error.message + '\n' + _stringify(error.data)

Enforces max length (default to 1000, pass 0 to skip it).

Logs numbers as-is (as a String), e.g: 6.

Logs strings as-is (without single quotes around, unlike default util.inspect behavior).

Otherwise - just uses JSON.stringify.

Returns empty_string string if empty string is passed.

Returns undefined (not a string, but actual undefined) if undefined is passed (default util.inspect behavior).

ts
_stringify(undefined) // 'undefined'
+_stringify(null) // 'null'
+_stringify(true) // 'true'
+_stringify(false) // 'false'
+_stringify(NaN) // 'null'
+_stringify(Infinity) // 'null'
+_stringify('') // 'empty_string'
+_stringify(' ') // 'empty_string'
+_stringify('ho ho ho') // 'ho ho ho'
+_stringify(15) // '15'
+_stringify(new Error('some msg')) // 'Error: some msg'
+
+// AppError is stringified with it's Data object
+_stringify(new AppError('some msg', { k1: 'v1' }))
+// 'AppError: some msg\n
+// {
+//   "k1": "v1"
+// }'
_stringify(undefined) // 'undefined'
+_stringify(null) // 'null'
+_stringify(true) // 'true'
+_stringify(false) // 'false'
+_stringify(NaN) // 'null'
+_stringify(Infinity) // 'null'
+_stringify('') // 'empty_string'
+_stringify(' ') // 'empty_string'
+_stringify('ho ho ho') // 'ho ho ho'
+_stringify(15) // '15'
+_stringify(new Error('some msg')) // 'Error: some msg'
+
+// AppError is stringified with it's Data object
+_stringify(new AppError('some msg', { k1: 'v1' }))
+// 'AppError: some msg\n
+// {
+//   "k1": "v1"
+// }'
+ + + + \ No newline at end of file diff --git a/lazy.html b/lazy.html new file mode 100644 index 00000000..29de7ff0 --- /dev/null +++ b/lazy.html @@ -0,0 +1,49 @@ + + + + + + Lazy | js-lib + + + + + + + + + + + + +
Skip to content

Lazy

_lazyValue

Based on: https://github.com/sindresorhus/lazy-value

ts
const value = _lazyValue(() => expensiveComputation())
+
+value() // calls expensiveComputation() once
+value() // returns cached result
+value() // returns cached result
const value = _lazyValue(() => expensiveComputation())
+
+value() // calls expensiveComputation() once
+value() // returns cached result
+value() // returns cached result

_defineLazyProperty

Based on: https://github.com/sindresorhus/define-lazy-prop

ts
interface Obj {
+  v: number
+}
+
+const obj = {} as Obj
+
+_defineLazyProperty(obj, 'v', () => expensiveComputation())
+obj.v // runs expensiveComputation() once
+obj.v // cached value
+obj.v // cached value
interface Obj {
+  v: number
+}
+
+const obj = {} as Obj
+
+_defineLazyProperty(obj, 'v', () => expensiveComputation())
+obj.v // runs expensiveComputation() once
+obj.v // cached value
+obj.v // cached value

_defineLazyProps

Like _defineLazyProperty, but allows to define multiple props at once.

+ + + + \ No newline at end of file diff --git a/math.html b/math.html new file mode 100644 index 00000000..f8248199 --- /dev/null +++ b/math.html @@ -0,0 +1,101 @@ + + + + + + Math | js-lib + + + + + + + + + + + + +
Skip to content

Math

_randomInt

Returns a random integer in the provided range. As usual, lower-bound is inclusing, while higher-bound is exclusive. Unusually, both lower and higher bounds are inclusive.

ts
_randomInt(1, 3)
+// 1
+// 3
+// 2
_randomInt(1, 3)
+// 1
+// 3
+// 2

_randomArrayItem

Returns a random item from the given array.

Don't use it on empty array. It'll return undefined in that case, but that is not reflected in function's output type!

ts
const a = [1, 2, 3]
+_randomArrayItem(a)
+// random of 1, 2 or 3
const a = [1, 2, 3]
+_randomArrayItem(a)
+// random of 1, 2 or 3

_createDeterministicRandom

Returns a "deterministic Math.random() function".

Useful to make tests that need to use Math.random() deterministic.

ts
const deterministicRandom = _createDeterministicRandom()
+
+deterministicRandom()
+// => 0.9872818551957607
+
+deterministicRandom()
+// => 0.34880331158638
const deterministicRandom = _createDeterministicRandom()
+
+deterministicRandom()
+// => 0.9872818551957607
+
+deterministicRandom()
+// => 0.34880331158638

Based on this gist which is based on Robert Jenkins’ 32 bit integer hash function.

_average

Calculate an average of the array of numbers.

ts
_average([1, 2, 3, 4])
+// 2.5
_average([1, 2, 3, 4])
+// 2.5

_averageWeighted

Calculate a "weighted average", given the array of numbers and corresponding array of weights.

ts
const numbers = [1, 2]
+const weights = [3, 1]
+_averageWeighted(numbers, weights)
+// 1.25
const numbers = [1, 2]
+const weights = [3, 1]
+_averageWeighted(numbers, weights)
+// 1.25

_median

Calculate a Median of the array of numbers.

ts
_median([1, 2, 3]) // 2
+_median([1, 2, 3, 4]) // 2.5
+_median([1, 1, 1, 3, 999]) // 1
_median([1, 2, 3]) // 2
+_median([1, 2, 3, 4]) // 2.5
+_median([1, 1, 1, 3, 999]) // 1

_percentile

Calculate a Percentile of the array of numbers.

ts
const numbers = [1200, 1400]
+_percentile(numbers, 0) // 1200
+_percentile(numbers, 10) // 1220
+_percentile(numbers, 20) // 1240
+_percentile(numbers, 30) // 1260
+_percentile(numbers, 40) // 1280
+_percentile(numbers, 50) // 1300
+_percentile(numbers, 60) // 1320
+_percentile(numbers, 70) // 1340
+_percentile(numbers, 80) // 1360
+_percentile(numbers, 90) // 1380
+_percentile(numbers, 100) // 1400
const numbers = [1200, 1400]
+_percentile(numbers, 0) // 1200
+_percentile(numbers, 10) // 1220
+_percentile(numbers, 20) // 1240
+_percentile(numbers, 30) // 1260
+_percentile(numbers, 40) // 1280
+_percentile(numbers, 50) // 1300
+_percentile(numbers, 60) // 1320
+_percentile(numbers, 70) // 1340
+_percentile(numbers, 80) // 1360
+_percentile(numbers, 90) // 1380
+_percentile(numbers, 100) // 1400

SimpleMovingAverage

ts
// SMA with the size of 2:
+const sma = new SimpleMovingAverage(2)
+sma.avg // 0 by default, when no numbers were pushed
+
+sma.push(1) // [1]
+sma.avg // 1
+
+sma.push(2) // [1, 2]
+sma.avg // 1.5
+
+sma.push(3) // [1, 2, 3]
+sma.avg // 2.5
// SMA with the size of 2:
+const sma = new SimpleMovingAverage(2)
+sma.avg // 0 by default, when no numbers were pushed
+
+sma.push(1) // [1]
+sma.avg // 1
+
+sma.push(2) // [1, 2]
+sma.avg // 1.5
+
+sma.push(3) // [1, 2, 3]
+sma.avg // 2.5
+ + + + \ No newline at end of file diff --git a/number.html b/number.html new file mode 100644 index 00000000..393324f6 --- /dev/null +++ b/number.html @@ -0,0 +1,93 @@ + + + + + + Number | js-lib + + + + + + + + + + + + +
Skip to content

Number

_inRange

Checks if the provided number (1st argument) is withing range of 2nd and 3rd argument. As usual, lower-bound is inclusive, while higher-boung is exclusive.

ts
_inRange(-10, 1, 5)
+// false
+
+_inRange(1, 1, 5)
+// true
+
+_inRange(3, 1, 5)
+// true
+
+_inRange(5, 1, 5)
+// false
+
+_inRange(7, 1, 5)
+// false
_inRange(-10, 1, 5)
+// false
+
+_inRange(1, 1, 5)
+// true
+
+_inRange(3, 1, 5)
+// true
+
+_inRange(5, 1, 5)
+// false
+
+_inRange(7, 1, 5)
+// false

_clamp

Inspired by Lodash's _clamp.

"Clamps" (fits) the number (first argument) within the min/max ranges of 2nd/3rd arguments (range inclusive).

ts
// range is always [5, 10] in these cases
+_clamp(3, 5, 10) // 5
+_clamp(4, 5, 10) // 5
+_clamp(5, 5, 10) // 5
+_clamp(6, 5, 10) // 6
+_clamp(9, 5, 10) // 9
+_clamp(10, 5, 10) // 10
+_clamp(11, 5, 10) // 10
// range is always [5, 10] in these cases
+_clamp(3, 5, 10) // 5
+_clamp(4, 5, 10) // 5
+_clamp(5, 5, 10) // 5
+_clamp(6, 5, 10) // 6
+_clamp(9, 5, 10) // 9
+_clamp(10, 5, 10) // 10
+_clamp(11, 5, 10) // 10

_toFixed

Same as Number.toFixed, but conveniently casts the output to Number.

ts
_toFixed(1.2345, 2)
+// 1.23
+
+_toFixed(1.1, 2)
+// 1.1
+// not '1.10' !
_toFixed(1.2345, 2)
+// 1.23
+
+_toFixed(1.1, 2)
+// 1.1
+// not '1.10' !

_toPrecision

Same as Number.toPrecision(), but conveniently casts the output to Number.

ts
_toPrecision(1634.56, 1)
+// 2000
+
+_toPrecision(1234.56, 2)
+// 1600
_toPrecision(1634.56, 1)
+// 2000
+
+_toPrecision(1234.56, 2)
+// 1600

_round

Round (like Math.round) the Number to the nearest "discriminator" (2nd argument):

ts
_round(1634, 1000) // 2000
+_round(1634, 500) // 1500
+_round(1634, 100) // 1600
+_round(1634, 10) // 1630
+_round(1634, 1) // 1634
+_round(1634.5678, 0.1) // 1634.6
+_round(1634.5678, 0.01) // 1634.57
_round(1634, 1000) // 2000
+_round(1634, 500) // 1500
+_round(1634, 100) // 1600
+_round(1634, 10) // 1630
+_round(1634, 1) // 1634
+_round(1634.5678, 0.1) // 1634.6
+_round(1634.5678, 0.01) // 1634.57
+ + + + \ No newline at end of file diff --git a/object.html b/object.html new file mode 100644 index 00000000..4556c6e4 --- /dev/null +++ b/object.html @@ -0,0 +1,583 @@ + + + + + + Object | js-lib + + + + + + + + + + + + +
Skip to content

Object

_pick

Inspired by Lodash's _.pick.

ts
_pick({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { a: 'a', b: 'b' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// { a: 'a' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// {}
+
+_pick({ a: 'a', b: 'b', c: 'c' }, [])
+// {}
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _pick(obj, ['a'], true)
+obj === obj2 // true
_pick({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { a: 'a', b: 'b' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// { a: 'a' }
+
+_pick({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// {}
+
+_pick({ a: 'a', b: 'b', c: 'c' }, [])
+// {}
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _pick(obj, ['a'], true)
+obj === obj2 // true

_omit

Inspired by Lodash's _.omit. The opposite of _pick.

ts
_omit({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// {  b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// { a: 'a', b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, [])
+// { a: 'a', b: 'b', c: 'c' }
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _omit(obj, ['a', 'b'], true)
+obj === obj2 // true
_omit({ a: 'a', b: 'b', c: 'c' }, ['a', 'b'])
+// { c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['a'])
+// {  b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, ['d'])
+// { a: 'a', b: 'b', c: 'c' }
+
+_omit({ a: 'a', b: 'b', c: 'c' }, [])
+// { a: 'a', b: 'b', c: 'c' }
+
+// Supports "mutation flag" which would mutate the object and return it (same object):
+const obj = { a: 'a', b: 'b', c: 'c' }
+const obj2 = _omit(obj, ['a', 'b'], true)
+obj === obj2 // true

_mask

Similar to _omit, but supports deep object access via dot-notation (a.b). Supports "mutation flag" argument.

ts
const obj = {
+  a: 'a',
+  b: {
+    b1: 'b1',
+    b2: 'b2',
+  },
+}
+
+_mask(obj, ['b.b1'])
+// { a: 'a', b: { b1: 'b1' }}
+
+_mask(obj, ['b.b1'], true)
+// obj was mutated
const obj = {
+  a: 'a',
+  b: {
+    b1: 'b1',
+    b2: 'b2',
+  },
+}
+
+_mask(obj, ['b.b1'])
+// { a: 'a', b: { b1: 'b1' }}
+
+_mask(obj, ['b.b1'], true)
+// obj was mutated

_filterFalsyValues

Returns an object with all Falsy values filtered out. Non-mutating by default.

ts
_filterFalsyValues({
+  a: 'a',
+  b: '', // falsy
+  c: 0, // falsy
+  d: [], // not falsy
+})
+// { a: 'a', d: [] }
_filterFalsyValues({
+  a: 'a',
+  b: '', // falsy
+  c: 0, // falsy
+  d: [], // not falsy
+})
+// { a: 'a', d: [] }

_filterNullishValues

Returns an object with all Nullish (null or undefined) values filtered out. Non-mutating by default.

ts
_filterNullishValues({
+  a: 'a',
+  b: null, // nullish
+  c: undefined, // nullish
+  d: '', // not nullish
+})
+// { a: 'a', d: '' }
_filterNullishValues({
+  a: 'a',
+  b: null, // nullish
+  c: undefined, // nullish
+  d: '', // not nullish
+})
+// { a: 'a', d: '' }

_filterUndefinedValues

Returns an object with all undefined values filtered out. null values are kept.

Non-mutating by default.

ts
_filterUndefinedValues({
+  a: 'a',
+  b: null,
+  c: undefined, // removed
+  d: '',
+})
+// { a: 'a', b: null, d: '' }
_filterUndefinedValues({
+  a: 'a',
+  b: null,
+  c: undefined, // removed
+  d: '',
+})
+// { a: 'a', b: null, d: '' }

_filterEmptyArrays

Returns an object will all empty arrays filtered out. Non-mutating by default.

ts
_filterEmptyArrays({
+  a: 'a',
+  b: [], // empty array
+  c: 'c',
+})
+// { a: 'a', c: 'c' }
_filterEmptyArrays({
+  a: 'a',
+  b: [], // empty array
+  c: 'c',
+})
+// { a: 'a', c: 'c' }

_filterEmptyValues

Filters the object by removing all key-value pairs where Value is Empty (according to _isEmpty() specification).

ts
_filterEmptyValues({
+  a: 0,
+  b: '',
+  c: [],
+  d: {},
+  e: {
+    f: [],
+  },
+  g: new Set(),
+  h: 'h',
+})
+// {
+//   a: 0,
+//   e: {
+//     f: [],
+//   },
+//   h: 'h',
+//  })
_filterEmptyValues({
+  a: 0,
+  b: '',
+  c: [],
+  d: {},
+  e: {
+    f: [],
+  },
+  g: new Set(),
+  h: 'h',
+})
+// {
+//   a: 0,
+//   e: {
+//     f: [],
+//   },
+//   h: 'h',
+//  })

_filterObject

Returns clone of obj without properties that does not pass predicate. Allows filtering by both key and value.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Predicate to keep only even-numbered values
+_filterObject(obj, (_k, v) => v % 2 === 0)
+// { b: 2 }
+
+// Predicate to only keep keys that start with `a`
+_filterObject(obj, (k, _v) => k.startsWith('a'))
+// { a: 1 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Predicate to keep only even-numbered values
+_filterObject(obj, (_k, v) => v % 2 === 0)
+// { b: 2 }
+
+// Predicate to only keep keys that start with `a`
+_filterObject(obj, (k, _v) => k.startsWith('a'))
+// { a: 1 }

_mapKeys

Returns a clone of obj with modified Keys, based on a Mapper function.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to add `_odd` or `_even` to the object key, based on its value
+_mapKeys(obj, (k, v) => k + (v % 2 ? '_odd' : '_even'))
+// { a_odd: 1, b_even: 2, c_odd: 3 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to add `_odd` or `_even` to the object key, based on its value
+_mapKeys(obj, (k, v) => k + (v % 2 ? '_odd' : '_even'))
+// { a_odd: 1, b_even: 2, c_odd: 3 }

_mapValues

Returns a clone of obj with modified Values, based on a Mapper function.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2
+_mapValues(obj, (_k, v) => v * 2)
+// { a: 2, b: 4, c: 6 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2
+_mapValues(obj, (_k, v) => v * 2)
+// { a: 2, b: 4, c: 6 }

_mapObject

Returns a clone of obj where both Keys and Values can be modified by a Mapper function. Mapper function needs to return a Tuple [key, value].

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2, and append the value to the end of the key
+_mapObject(obj, (k, v) => {
+  const newValue = v * 2
+  return [k + newValue, newValue]
+})
+// { a2: 2, b4: 4, c6: 6 }
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+// Mapper to multiply object values by 2, and append the value to the end of the key
+_mapObject(obj, (k, v) => {
+  const newValue = v * 2
+  return [k + newValue, newValue]
+})
+// { a2: 2, b4: 4, c6: 6 }

_findKeyByValue

Fiven an object, find a key string for a given value: any.

Inspired by Lodash's _.findKey.

ts
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+_findKeyByValue(obj, 1) // 'a'
+_findKeyByValue(obj, 2) // 'b'
+_findKeyByValue(obj, 3) // 'c'
+_findKeyByValue(obj, 4) // undefined
const obj = {
+  a: 1,
+  b: 2,
+  c: 3,
+}
+
+_findKeyByValue(obj, 1) // 'a'
+_findKeyByValue(obj, 2) // 'b'
+_findKeyByValue(obj, 3) // 'c'
+_findKeyByValue(obj, 4) // undefined

_objectNullValuesToUndefined

Returns a clone of the object where null values are replaced with undefined

ts
const obj = {
+  a: 1, // intact
+  b: null, // replaced with `undefined`
+  c: undefined, // intact
+}
+
+_objectNullValuesToUndefined(obj)
+// { a: 1, b: undefined, c: undefined }
const obj = {
+  a: 1, // intact
+  b: null, // replaced with `undefined`
+  c: undefined, // intact
+}
+
+_objectNullValuesToUndefined(obj)
+// { a: 1, b: undefined, c: undefined }

_deepCopy

Does a deep copy of an object.

Actually, it is just a semantic function that internally does JSON.parse(JSON.stringify(o)), which is currently the fastest+simplest+relyable way to do a deep copy.

Because it does JSON.parse/stringify - it'll remove undefined values/keys from objects.

ts
const obj = { a: 'a', b: { bb: 'bb' } }
+const obj2 = _deepCopy(obj)
+// Deep copy of obj
const obj = { a: 'a', b: { bb: 'bb' } }
+const obj2 = _deepCopy(obj)
+// Deep copy of obj

_isPrimitive

Returns Boolean indication if passed value is a primitive.

ts
_isPrimitive(5)
+// true
+
+_isPrimitive({ a: 'a' })
+// false
_isPrimitive(5)
+// true
+
+_isPrimitive({ a: 'a' })
+// false

Best specification is the source code:

ts
export function _isPrimitive(v: any): v is null | undefined | number | boolean | string {
+  return (
+    v === null ||
+    v === undefined ||
+    typeof v === 'number' ||
+    typeof v === 'boolean' ||
+    typeof v === 'string'
+  )
+}
export function _isPrimitive(v: any): v is null | undefined | number | boolean | string {
+  return (
+    v === null ||
+    v === undefined ||
+    typeof v === 'number' ||
+    typeof v === 'boolean' ||
+    typeof v === 'string'
+  )
+}

_isEmpty

Object is considered empty if it's one of:

  • undefined
  • '' (empty string)
  • [] (empty array)
  • {} (empty object)
  • new Map() (empty Map)
  • new Set() (empty Set)

_undefinedIfEmpty

Returns undefined if it's empty (according to _isEmpty() specification), otherwise returns the original object.

ts
_undefinedIfEmpty('') // undefined, because it's empty
+_undefinedIfEmpty([]) // undefined, because it's empty
+_undefinedIfEmpty(new Map()) // undefined, because it's empty
+_undefinedIfEmpty('a') // 'a', intact
+_undefinedIfEmpty(false) // false, intact
_undefinedIfEmpty('') // undefined, because it's empty
+_undefinedIfEmpty([]) // undefined, because it's empty
+_undefinedIfEmpty(new Map()) // undefined, because it's empty
+_undefinedIfEmpty('a') // 'a', intact
+_undefinedIfEmpty(false) // false, intact

_merge

Deeply merges the second object into the first one. Returns the first object (merged). Mutates the first object!

ts
const obj1 = {
+  a: 'a',
+  b: {
+    bb1: 'bb1',
+  },
+}
+
+const obj2 = {
+  b: {
+    bb2: 'bb2',
+  },
+  c: 'c',
+}
+
+_merge(obj1, obj2)
+// {
+//   a: 'a',
+//   b: {
+//     bb1: 'bb1',
+//     bb2: 'bb2',
+//   },
+//   c: 'c',
+// }
const obj1 = {
+  a: 'a',
+  b: {
+    bb1: 'bb1',
+  },
+}
+
+const obj2 = {
+  b: {
+    bb2: 'bb2',
+  },
+  c: 'c',
+}
+
+_merge(obj1, obj2)
+// {
+//   a: 'a',
+//   b: {
+//     bb1: 'bb1',
+//     bb2: 'bb2',
+//   },
+//   c: 'c',
+// }

_deepTrim

Deeply traverses the object and trims all String values found.

ts
const o = {
+  a: 'abc ',
+  b: 'c',
+  d: 12,
+  e: {
+    f: '  sd a ',
+  },
+}
+
+_deepTrim(o)
+// {
+//   a: 'abc',
+//   b: 'c',
+//   d: 12,
+//   e: {
+//     f: 'sd a',
+//   },
+// }
const o = {
+  a: 'abc ',
+  b: 'c',
+  d: 12,
+  e: {
+    f: '  sd a ',
+  },
+}
+
+_deepTrim(o)
+// {
+//   a: 'abc',
+//   b: 'c',
+//   d: 12,
+//   e: {
+//     f: 'sd a',
+//   },
+// }

_sortObjectDeep

Based on IndigoUnited/js-deep-sort-object.

Deeply traverses the object and makes it "sort-stable" (deterministic). Useful for e.g snapshot-testing, or in any place where sort-stable result is expected. Resulting object is still Equal to the original object.

  • Arrays are sorted order-preserved (!), because array order has a meaning and shouldn't be changed (!).
  • Objects are sorted by their key name.
ts
const obj = {
+  b: 'b',
+  c: ['c3', 'c1', 'c2'],
+  a: 'a',
+}
+
+_sortObjectDeep(obj)
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: ['c1', 'c2', 'c3'],
+// }
const obj = {
+  b: 'b',
+  c: ['c3', 'c1', 'c2'],
+  a: 'a',
+}
+
+_sortObjectDeep(obj)
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: ['c1', 'c2', 'c3'],
+// }

_sortObject

Allows to sort object by the list of known keys.

Example:

ts
const obj = {
+  b: 'b',
+  c: 'c',
+  extra: 'extra',
+  a: 'a',
+}
+
+_sortObject(obj, ['a', 'b', 'c'])
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: 'c',
+//   extra: 'extra',
+// }
const obj = {
+  b: 'b',
+  c: 'c',
+  extra: 'extra',
+  a: 'a',
+}
+
+_sortObject(obj, ['a', 'b', 'c'])
+// {
+//   a: 'a',
+//   b: 'b',
+//   c: 'c',
+//   extra: 'extra',
+// }

_deepEquals

Based on epoberezkin/fast-deep-equal.

Performance-optimized function to check if objects (values) are deeply-equal to each other.

ts
const obj1 = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+// Different key order, but still equals
+const obj2 = {
+  b: {
+    bb: 'bb',
+  },
+  a: 'a',
+}
+
+const obj3 = {
+  a: 'a',
+  b: {
+    bb: 'bb3', // not equal!
+  },
+}
+
+_deepEquals(obj1, obj2) // true
+_deepEquals(obj1, obj3) // false
+_deepEquals(obj2, obj3) // false
const obj1 = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+// Different key order, but still equals
+const obj2 = {
+  b: {
+    bb: 'bb',
+  },
+  a: 'a',
+}
+
+const obj3 = {
+  a: 'a',
+  b: {
+    bb: 'bb3', // not equal!
+  },
+}
+
+_deepEquals(obj1, obj2) // true
+_deepEquals(obj1, obj3) // false
+_deepEquals(obj2, obj3) // false

_invert

Returns an Object with "inverted" keys and values.

ts
const obj = {
+  a: '1',
+  b: '2',
+}
+
+_invert(obj)
+// {
+//   '1': 'a',
+//   '2': 'b',
+// }
const obj = {
+  a: '1',
+  b: '2',
+}
+
+_invert(obj)
+// {
+//   '1': 'a',
+//   '2': 'b',
+// }

_invertMap

Returns a Map with "inverted" keys and values.

ts
const map = new Map<string, number>([
+  ['a', 1],
+  ['b', 2],
+])
+
+_invertMap(map)
+// Map
+//   1 => 'a'
+//   2 => 'b'
const map = new Map<string, number>([
+  ['a', 1],
+  ['b', 2],
+])
+
+_invertMap(map)
+// Map
+//   1 => 'a'
+//   2 => 'b'

_get, _has, _set, _unset

Gets the object value via the famous "dot-notation":

ts
const obj = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+_get(obj, 'b.bb') // 'bb'
+_has(obj, 'b.bb') // true
+_has(obj, 'b.bb2') // false
+_set(obj, 'b.bb2', 'bb2value') // sets obj.b.bb2 to 'bb2Value'
+_unset(obj, 'b.bb') // deletes obj.b.bb
const obj = {
+  a: 'a',
+  b: {
+    bb: 'bb',
+  },
+}
+
+_get(obj, 'b.bb') // 'bb'
+_has(obj, 'b.bb') // true
+_has(obj, 'b.bb2') // false
+_set(obj, 'b.bb2', 'bb2value') // sets obj.b.bb2 to 'bb2Value'
+_unset(obj, 'b.bb') // deletes obj.b.bb

_stringMapValues

Needed due to https://github.com/microsoft/TypeScript/issues/13778
Only affects typings, no runtime effect.

ts
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}

Before:

ts
const values = Object.values(map)
+// values: (string | undefined)[]
const values = Object.values(map)
+// values: (string | undefined)[]

After:

ts
const values = _stringMapValues(map)
+// values: string[]
const values = _stringMapValues(map)
+// values: string[]

_stringMapEntries

Needed due to https://github.com/microsoft/TypeScript/issues/13778
Only affects typings, no runtime effect.

ts
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}
const map: StringMap = {
+  a: 'a',
+  b: 'b',
+}

Before:

ts
const entries = Object.entries(map)
+// entries: [string, string | undefined][]
const entries = Object.entries(map)
+// entries: [string, string | undefined][]

After:

ts
const entries = _stringMapEntries(map)
+// entries: [string, string][]
const entries = _stringMapEntries(map)
+// entries: [string, string][]
+ + + + \ No newline at end of file diff --git a/promise.html b/promise.html new file mode 100644 index 00000000..bbba69d3 --- /dev/null +++ b/promise.html @@ -0,0 +1,135 @@ + + + + + + Promise | js-lib + + + + + + + + + + + + +
Skip to content

Promise

Inspired by bluebird and Sindre's promise-fun packages.

"Copy-pasted" (with small adjustments) here, because:

  1. Bluebird is outdated (pre-ES6)

  2. p-* packages are amazing, but not all of them are needed. Some of them are very much needed though.

  3. To fix issues with Types. Here, everything is TypeScript, so, first class support and sync.

  4. To fix issues with IDE auto-imports, which is still quite bad for "default exported" packages.

Downside is that (as every fork) we lose "auto-update" possibility from these packages. We believe it's not as bad, because packages imported here have mature API and stability (example: pMap).

pMap

Based on p-map

Allows to asynchronously map an array of Promises, with options to:

  • control concurrency (default: Infinity)
  • control error behavior (ErrorMode):
    • THROW_IMMEDIATELY (default)
    • THROW_AGGREGATED: throw AggregateError in the end of execution, if at least 1 error happened
    • SUPPRESS: completely suppress (ignore) errors
ts
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+const results = await pMap(promises, async r => { ... }, {
+  concurrency: 2,
+  errorMode: ErrorMode.SUPPRESS,
+})
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+const results = await pMap(promises, async r => { ... }, {
+  concurrency: 2,
+  errorMode: ErrorMode.SUPPRESS,
+})

pProps

Based on p-props

Syntax-sugar to concurrently execute multiple promises and map their results to named properties.

Before:

ts
const [r1, r2, r3] = await Promise.all([
+  fetch(...),
+  fetch(...),
+  fetch(...),
+])
const [r1, r2, r3] = await Promise.all([
+  fetch(...),
+  fetch(...),
+  fetch(...),
+])

After:

ts
const {r1, r2, r3} = await pProps({
+  r1: fetch(...),
+  r2: fetch(...),
+  r3: fetch(...),
+})
const {r1, r2, r3} = await pProps({
+  r1: fetch(...),
+  r2: fetch(...),
+  r3: fetch(...),
+})

pFilter

Based on p-filter

Allows to asynchrously filter an array of Promises.

ts
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+
+const results = await pFilter(promises, async r => (await r.json()).success)
const promises = [
+   fetch(...),
+   fetch(...),
+   fetch(...),
+]
+
+const results = await pFilter(promises, async r => (await r.json()).success)

pDefer

Allows to create a "ResolvablePromise", which is a normal native Promise (so, can be awaited, etc), extended with .resolve() and .reject() methods, so you can control it. Similar to jQuery's Deferred, or RxJS's Subject (which is both an Observable and allows to emit values).

Sometimes useful to "promisify" a callback-style API.

ts
async function run(): Promise<string> {
+  const defer = pDefer<string>()
+
+  someOldApi(
+    (result: string) => {
+      defer.resolve(result)
+    },
+    err => defer.reject(err),
+  )
+
+  return await defer.promise
+}
async function run(): Promise<string> {
+  const defer = pDefer<string>()
+
+  someOldApi(
+    (result: string) => {
+      defer.resolve(result)
+    },
+    err => defer.reject(err),
+  )
+
+  return await defer.promise
+}

pDelay

Based on p-delay

Just a fancy async/await style setTimeout

Before:

ts
await new Promise(resolve => setTimeout(resolve, 500))
await new Promise(resolve => setTimeout(resolve, 500))

After:

ts
await pDelay(500)
await pDelay(500)

Allows to return a value:

ts
const res = await pDelay(500, 'hello')
+// hello
const res = await pDelay(500, 'hello')
+// hello

pRetry

Based on p-retry

Returns a Function (!), enhanced with retry capabilities.

Simplest example:

ts
const save = pRetry(async () => await dao.save())
+
+await save()
+// will retry 3 times, with default delay of 1 second and exponential back-off (x2 delay multiplier)
const save = pRetry(async () => await dao.save())
+
+await save()
+// will retry 3 times, with default delay of 1 second and exponential back-off (x2 delay multiplier)

Advanced example (with options):

ts
const save = pRetry(async () => await dao.save(), {
+  maxAttempts: 5,
+  predicate: err => err?.message.includes('GOAWAY'),
+})
+
+await save()
+// will try up to 5 times, but only if err.message contains GOAWAY
const save = pRetry(async () => await dao.save(), {
+  maxAttempts: 5,
+  predicate: err => err?.message.includes('GOAWAY'),
+})
+
+await save()
+// will try up to 5 times, but only if err.message contains GOAWAY

pTimeoutFn

Based on p-timeout

Decorates a Function with a timeout.

Throws an Error if the Function is not resolved in a certain time.

If the Function rejects - passes this rejection further.

ts
const decoratedFn = pTimeout(someFunction, { timeout: 1000 })
+
+await decoratedFn()
+// will throw Timeout error if `someFunction` is not finished in 1000 ms.
+// otherwise will pass
const decoratedFn = pTimeout(someFunction, { timeout: 1000 })
+
+await decoratedFn()
+// will throw Timeout error if `someFunction` is not finished in 1000 ms.
+// otherwise will pass

pHang

Syntax-sugar for returning a never-resolving ("hung") Promise.

Has semantic meaning, telling us that this Promise is meant to never get resolved or rejected.

Before:

ts
return new Promise()
return new Promise()

After:

ts
return pHang()
return pHang()

Useful e.g when you do location.reload() (let's say, you want to reload the page after being logged-in as an Admin) and want your BlockingLoader to never stop spinning:

ts
async function adminLogin(): Promise<void> {
+  location.href = '/admin'
+  return pHang()
+}
async function adminLogin(): Promise<void> {
+  location.href = '/admin'
+  return pHang()
+}

pState

Returns Promise's "state" as a String, one of:

  • pending
  • resolved
  • rejected
ts
const p = new Promise()
+await pState(p)
+// 'pending'
+
+const p = new Promise.resolve()
+await pState(p)
+// 'resolved'
const p = new Promise()
+await pState(p)
+// 'pending'
+
+const p = new Promise.resolve()
+await pState(p)
+// 'resolved'
+ + + + \ No newline at end of file diff --git a/string.html b/string.html new file mode 100644 index 00000000..e2c9119a --- /dev/null +++ b/string.html @@ -0,0 +1,91 @@ + + + + + + String | js-lib + + + + + + + + + + + + +
Skip to content

String

_capitalize

Capitalizes first char, lowercases the rest of the string.

ts
_capitalize('hello') // Hello
+_capitalize('HELLO') // HELLO (no change)
+_capitalize('hello world') // Hello world
_capitalize('hello') // Hello
+_capitalize('HELLO') // HELLO (no change)
+_capitalize('hello world') // Hello world

_upperFirst

Uppercases first char.

ts
_upperFirst('hello') // Hello
+_upperFirst('HELLO') // HELLO (no change)
+_upperFirst('hELLO') // HELLO
_upperFirst('hello') // Hello
+_upperFirst('HELLO') // HELLO (no change)
+_upperFirst('hELLO') // HELLO

_lowerFirst

Lowercases first char.

ts
_lowerFirst('Hello') // hello
+_lowerFirst('hello') // hello (no change)
+_lowerFirst('HELLO') // hELLO
_lowerFirst('Hello') // hello
+_lowerFirst('hello') // hello (no change)
+_lowerFirst('HELLO') // hELLO

_camelCase 🐪

Transforms the input string to camelCase 🐪. Implementation adapted from Lodash.

ts
_camelCase('la la la')
+_camelCase('la_la_la')
+_camelCase('la-la-la')
+// laLaLa
_camelCase('la la la')
+_camelCase('la_la_la')
+_camelCase('la-la-la')
+// laLaLa

_snakeCase 🐍

Transforms the input string to snake_case 🐍. Implementation adapted from Lodash.

ts
_snakeCase('la la la')
+_snakeCase('la-la-la')
+_snakeCase('laLaLa')
+// la_la_la
_snakeCase('la la la')
+_snakeCase('la-la-la')
+_snakeCase('laLaLa')
+// la_la_la

_kebabCase 🥙

Transforms the input string to kebab-case 🥙. Implementation adapted from Lodash.

ts
_kebabCase('la la la')
+_kebabCase('la_la_la')
+_kebabCase('laLaLa')
+// la-la-la
_kebabCase('la la la')
+_kebabCase('la_la_la')
+_kebabCase('laLaLa')
+// la-la-la

_split

Like String.split, but with the limited number of tokens.

ts
_split('a_b_c', '_', 2)
+// ['a', 'b_c']
_split('a_b_c', '_', 2)
+// ['a', 'b_c']

_substringBefore

ts
_substringBefore('file1.test.ts', '.')
+// 'file1'
+
+_substringBefore('file1.test.ts', '.ts')
+// 'file1.test'
_substringBefore('file1.test.ts', '.')
+// 'file1'
+
+_substringBefore('file1.test.ts', '.ts')
+// 'file1.test'

_substringBeforeLast

ts
_substringBeforeLast('file1.test.ts', '.')
+// 'file1.test'
_substringBeforeLast('file1.test.ts', '.')
+// 'file1.test'

_substringAfter

ts
_substringAfter('file1.test.ts', '.')
+// 'test.ts'
_substringAfter('file1.test.ts', '.')
+// 'test.ts'

_substringAfterLast

ts
_substringAfterLast('file1.test.ts', '.')
+// 'ts'
_substringAfterLast('file1.test.ts', '.')
+// 'ts'

_substringBetweenLast

ts
const s = '/Users/lalala/someFile.test.ts'
+_substringBetweenLast(s, '/', '.'))
+// 'someFile'
const s = '/Users/lalala/someFile.test.ts'
+_substringBetweenLast(s, '/', '.'))
+// 'someFile'

_truncate

Truncates the string to the needed length, putting ... (or a custom "ending") in the end, if needed. The maxLen (second argument) includes the "ending string" (3rd argument).

ts
_truncate('Hello World!', 5) // 'He...'
+_truncate('Hello World!', 6) // 'Hel...'
+_truncate('Hello World!', 100) // 'Hello World!' (no truncation needed)
+
+// Custom "ending"
+_truncate('Hello World!', 5, '|') // 'Hell|'
_truncate('Hello World!', 5) // 'He...'
+_truncate('Hello World!', 6) // 'Hel...'
+_truncate('Hello World!', 100) // 'Hello World!' (no truncation needed)
+
+// Custom "ending"
+_truncate('Hello World!', 5, '|') // 'Hell|'

_truncateMiddle

Truncates the string in the middle.

ts
_truncateMiddle('abcdefghijklmnopqrstuvwxyz', 10)
+// 'abcd...xyz'
_truncateMiddle('abcdefghijklmnopqrstuvwxyz', 10)
+// 'abcd...xyz'

_replaceAll

Polyfill for String.prototype.replaceAll.

Based on regex implementation (slightly faster than "split/join" implementation).

_nl2br

Converts \n (aka new-line) to <br>, to be presented in HTML.

Keeps \n, so if it's printed in non-HTML environment it still looks ok-ish.

_parseQueryString

Parses location.search string (e.g ?a=1&b=2) into a StringMap, e.g: { a: '1', b: '2' }

Pass location.search to it in the Frontend, or any other string on the Backend (where location.search is not available).

Works both with and without leading ? character.

Yes, there's URLSearchParams existing in the Frontend (not in Node yet), but it's API is not as convenient. And the implementation here is super-small.

Goal of this function is to produce exactly same output as URLSearchParams would.

ts
// Assuming url is http://example.com?a=1&b=2
+
+_parseQueryString(location.search)
+// { a: '1', b: '2' }
// Assuming url is http://example.com?a=1&b=2
+
+_parseQueryString(location.search)
+// { a: '1', b: '2' }
+ + + + \ No newline at end of file diff --git a/time.html b/time.html new file mode 100644 index 00000000..b8281686 --- /dev/null +++ b/time.html @@ -0,0 +1,51 @@ + + + + + + Time | js-lib + + + + + + + + + + + + +
Skip to content

Time

_ms

Prints a human-string for a given number of milliseconds.

ts
_ms(1) // '1 ms'
+_ms(10) // '10 ms'
+_ms(1005) // '1.005 sec'
+_ms(49123) // '49 sec'
+_ms(60000) // '1m0s'
+_ms(60912) // '1m0s'
+_ms(69123) // '1m9s'
+_ms(3292100) // '54m52s'
+_ms(69642430) // '19h20m'
+_ms(101963481) // '28h'
_ms(1) // '1 ms'
+_ms(10) // '10 ms'
+_ms(1005) // '1.005 sec'
+_ms(49123) // '49 sec'
+_ms(60000) // '1m0s'
+_ms(60912) // '1m0s'
+_ms(69123) // '1m9s'
+_ms(3292100) // '54m52s'
+_ms(69642430) // '19h20m'
+_ms(101963481) // '28h'

_since

Useful to measure and human-print the "time elapsed since".

ts
const started = Date.now()
+
+// ... do stuff!
+
+console.log(`Took ${_since(started)}`)
+// Took 19m13s
const started = Date.now()
+
+// ... do stuff!
+
+console.log(`Took ${_since(started)}`)
+// Took 19m13s

Uses _ms for pretty-printing.

_debounce

Debounce function from Lodash.

See the typescript declaration for Options.

ts
const fn = _debounce(originalFn, 100, { leading: false, trailing: false, maxWait: 300 })
const fn = _debounce(originalFn, 100, { leading: false, trailing: false, maxWait: 300 })

_throttle

Throttle function from Lodash.

See the typescript declaration for Options.

ts
const fn = _throttle(originalFn, 100)
const fn = _throttle(originalFn, 100)
+ + + + \ No newline at end of file diff --git a/types.html b/types.html new file mode 100644 index 00000000..f51eb328 --- /dev/null +++ b/types.html @@ -0,0 +1,43 @@ + + + + + + Types | js-lib + + + + + + + + + + + + +
Skip to content

Types

Things that should exist in type-fest, but don't (yet).

Some types are copy-pasted from type-fest, because:

  1. To not introduce (another) dependency of this 0-dep lib
  2. To avoid multiple type-fest versions conflicts (that happened many times in the past)

StringMap

ts
const m: StringMap = { a: 'a' }
+// Same as:
+// const m: { [a: string]: string | undefined }
+
+const m: StringMap<number> = { a: 5 }
+// Same as:
+// const m: { [a: string]: number | undefined }
const m: StringMap = { a: 'a' }
+// Same as:
+// const m: { [a: string]: string | undefined }
+
+const m: StringMap<number> = { a: 5 }
+// Same as:
+// const m: { [a: string]: number | undefined }

The | undefined part is important!

It allows to set undefined values to StringMap, e.g:

ts
m.name = name1 // where `name1` can be undefined
m.name = name1 // where `name1` can be undefined

Mapper

ts
export type Mapper<IN = any, OUT = any> = (input: IN, index: number) => OUT
export type Mapper<IN = any, OUT = any> = (input: IN, index: number) => OUT

AsyncMapper

ts
export type AsyncMapper<IN = any, OUT = any> = (input: IN, index: number) => OUT | PromiseLike<OUT>
export type AsyncMapper<IN = any, OUT = any> = (input: IN, index: number) => OUT | PromiseLike<OUT>

Predicate

ts
export type Predicate<T> = (item: T, index: number) => boolean
export type Predicate<T> = (item: T, index: number) => boolean

Async Predicate

ts
export type AsyncPredicate<T> = (item: T, index: number) => boolean | PromiseLike<boolean>
export type AsyncPredicate<T> = (item: T, index: number) => boolean | PromiseLike<boolean>

_passthroughPredicate

Predicate that passes everything (returns true for every item).

ts
_passthroughPredicate(anything) // true
+  [(1, 2, 3)].filter(_passthroughPredicate)
+// [1, 2, 3]
_passthroughPredicate(anything) // true
+  [(1, 2, 3)].filter(_passthroughPredicate)
+// [1, 2, 3]

_passNothingPredicate

Predicate that passes nothing (returns false for every item).

ts
_passNothingPredicate(anything) // false
+  [(1, 2, 3)].filter(_passNothingPredicate)
+// []
_passNothingPredicate(anything) // false
+  [(1, 2, 3)].filter(_passNothingPredicate)
+// []

_noop

Function that takes any arguments and returns undefined. Literally does nothing.

Can be useful to replace some real world functions with mocks.

ts
element.click = _noop
element.click = _noop

Merge

ReadonlyDeep

Promisable

PromiseValue

+ + + + \ No newline at end of file diff --git a/units.html b/units.html new file mode 100644 index 00000000..810bcfec --- /dev/null +++ b/units.html @@ -0,0 +1,37 @@ + + + + + + Units | js-lib + + + + + + + + + + + + +
Skip to content

Units

_kb, _mb, _gb, _hb

Human-prints byte number into kilobytes, megabytes, gigabutes and "human-bytes" (_hb):

ts
_hb(0) // '0 byte(s)'
+_hb(500) // '500 byte(s)'
+_hb(1000) // '1 Kb'
+_hb(1024 ** 2) // '1 Mb'
+_hb(1024 ** 3) // '1 Gb'
+_kb(1000) // 1
+_mb(1024 ** 2) // 1
+_gb(1024 ** 3) // 1
_hb(0) // '0 byte(s)'
+_hb(500) // '500 byte(s)'
+_hb(1000) // '1 Kb'
+_hb(1024 ** 2) // '1 Mb'
+_hb(1024 ** 3) // '1 Gb'
+_kb(1000) // 1
+_mb(1024 ** 2) // 1
+_gb(1024 ** 3) // 1
+ + + + \ No newline at end of file