vue-get 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,41 @@
1
+ <p align="center">
2
+ <img src="banner.svg" alt="vue-get" width="100%" />
3
+ </p>
4
+
5
+ <h1 align="center">vue-get</h1>
6
+
7
+ <p align="center">A Vue 3 composition API utility providing shorthand access to ref values. Supports both simple get(ref) for .value access and get(ref, key) for nested property access.</p>
8
+
9
+ <p align="center">
10
+ <a href="https://www.npmjs.com/package/vue-get"><img src="https://img.shields.io/npm/v/vue-get.svg" alt="npm version" /></a>
11
+ <a href="https://www.npmjs.com/package/vue-get"><img src="https://img.shields.io/npm/dm/vue-get.svg" alt="npm downloads" /></a>
12
+ <a href="https://github.com/vuefrag/vue-get/blob/main/LICENSE"><img src="https://img.shields.io/npm/l/vue-get.svg" alt="license" /></a>
13
+ </p>
14
+
15
+ ## Installation
16
+
17
+ ```bash
18
+ npm install vue-get
19
+ ```
20
+
21
+ ## Usage
22
+
23
+ ```ts
24
+ import { get } from 'vue-get';
25
+ ```
26
+
27
+ Shorthand for accessing `ref.value`
28
+
29
+ ```ts
30
+ import { get } from 'vue-get'
31
+
32
+ const a = ref(42)
33
+
34
+ console.log(get(a)) // 42
35
+ ```
36
+
37
+ > Extracted from [VueUse](https://vueuse.org/) for standalone use.
38
+
39
+ ## License
40
+
41
+ MIT
package/README.md ADDED
@@ -0,0 +1,41 @@
1
+ <p align="center">
2
+ <img src="logo.svg" alt="vue-get" width="180" />
3
+ </p>
4
+
5
+ <h1 align="center">vue-get</h1>
6
+
7
+ <p align="center">A Vue 3 composition API utility providing shorthand access to ref values. Supports both simple get(ref) for .value access and get(ref, key) for nested property access.</p>
8
+
9
+ <p align="center">
10
+ <a href="https://www.npmjs.com/package/vue-get"><img src="https://img.shields.io/npm/v/vue-get.svg" alt="npm version" /></a>
11
+ <a href="https://www.npmjs.com/package/vue-get"><img src="https://img.shields.io/npm/dm/vue-get.svg" alt="npm downloads" /></a>
12
+ <a href="https://github.com/vuefrag/vue-get/blob/main/LICENSE"><img src="https://img.shields.io/npm/l/vue-get.svg" alt="license" /></a>
13
+ </p>
14
+
15
+ ## Installation
16
+
17
+ ```bash
18
+ npm install vue-get
19
+ ```
20
+
21
+ ## Usage
22
+
23
+ ```ts
24
+ import { get } from 'vue-get';
25
+ ```
26
+
27
+ Shorthand for accessing `ref.value`
28
+
29
+ ```ts
30
+ import { get } from 'vue-get'
31
+
32
+ const a = ref(42)
33
+
34
+ console.log(get(a)) // 42
35
+ ```
36
+
37
+ > Extracted from [VueUse](https://vueuse.org/) for standalone use.
38
+
39
+ ## License
40
+
41
+ MIT
package/README.npm.md ADDED
@@ -0,0 +1,41 @@
1
+ <p align="center">
2
+ <img src="logo.svg" alt="vue-get" width="180" />
3
+ </p>
4
+
5
+ <h1 align="center">vue-get</h1>
6
+
7
+ <p align="center">A Vue 3 composition API utility providing shorthand access to ref values. Supports both simple get(ref) for .value access and get(ref, key) for nested property access.</p>
8
+
9
+ <p align="center">
10
+ <a href="https://www.npmjs.com/package/vue-get"><img src="https://img.shields.io/npm/v/vue-get.svg" alt="npm version" /></a>
11
+ <a href="https://www.npmjs.com/package/vue-get"><img src="https://img.shields.io/npm/dm/vue-get.svg" alt="npm downloads" /></a>
12
+ <a href="https://github.com/vuefrag/vue-get/blob/main/LICENSE"><img src="https://img.shields.io/npm/l/vue-get.svg" alt="license" /></a>
13
+ </p>
14
+
15
+ ## Installation
16
+
17
+ ```bash
18
+ npm install vue-get
19
+ ```
20
+
21
+ ## Usage
22
+
23
+ ```ts
24
+ import { get } from 'vue-get';
25
+ ```
26
+
27
+ Shorthand for accessing `ref.value`
28
+
29
+ ```ts
30
+ import { get } from 'vue-get'
31
+
32
+ const a = ref(42)
33
+
34
+ console.log(get(a)) // 42
35
+ ```
36
+
37
+ > Extracted from [VueUse](https://vueuse.org/) for standalone use.
38
+
39
+ ## License
40
+
41
+ MIT
package/banner.svg ADDED
@@ -0,0 +1,48 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1280 640" width="1280" height="640">
2
+ <defs>
3
+ <linearGradient id="banner-bg" x1="0%" y1="0%" x2="100%" y2="100%">
4
+ <stop offset="0%" style="stop-color:#2c3e50;stop-opacity:1" />
5
+ <stop offset="100%" style="stop-color:#1a252f;stop-opacity:1" />
6
+ </linearGradient>
7
+ </defs>
8
+
9
+ <!-- Background -->
10
+ <rect width="1280" height="640" fill="url(#banner-bg)"/>
11
+
12
+ <!-- Decorative elements -->
13
+ <circle cx="200" cy="150" r="120" fill="#3498db" opacity="0.06"/>
14
+ <circle cx="1150" cy="500" r="100" fill="#3498db" opacity="0.06"/>
15
+
16
+ <!-- Top accent bar -->
17
+ <rect x="0" y="0" width="1280" height="8" fill="#3498db"/>
18
+
19
+ <!-- Vuefrag badge -->
20
+ <g transform="translate(80, 80)">
21
+ <rect width="140" height="50" rx="8" fill="#3498db"/>
22
+ <text x="70" y="33" text-anchor="middle" font-family="system-ui, -apple-system, sans-serif" font-size="22" font-weight="700" fill="white">Vuefrag</text>
23
+ </g>
24
+
25
+ <!-- Package name -->
26
+ <text x="80" y="280" font-family="system-ui, -apple-system, sans-serif" font-size="72" font-weight="700" fill="white">vue-get</text>
27
+
28
+ <!-- Description -->
29
+ <text x="80" y="360" font-family="system-ui, -apple-system, sans-serif" font-size="32" fill="#94a3b8">Vue 3 shorthand for ref.value with optional nested key access</text>
30
+
31
+ <!-- Install command -->
32
+ <g transform="translate(80, 420)">
33
+ <rect width="340.8" height="60" rx="8" fill="#0f172a"/>
34
+ <text x="20" y="40" font-family="ui-monospace, monospace" font-size="24" fill="#94a3b8">npm install</text>
35
+ <text x="200" y="40" font-family="ui-monospace, monospace" font-size="24" fill="#3498db">vue-get</text>
36
+ </g>
37
+
38
+ <!-- Category badge -->
39
+ <g transform="translate(80, 520)">
40
+ <rect width="158" height="40" rx="20" fill="#3498db" opacity="0.2"/>
41
+ <text x="79" y="27" text-anchor="middle" font-family="system-ui, -apple-system, sans-serif" font-size="18" fill="#3498db">Utilities</text>
42
+ </g>
43
+
44
+ <!-- Category icon (top right corner) -->
45
+ <g>
46
+ <path d="M1040 120l-40 40 40 40" fill="none" stroke="#3498db" stroke-width="12" stroke-linecap="round" stroke-linejoin="round"/><path d="M1120 120l40 40-40 40" fill="none" stroke="#3498db" stroke-width="12" stroke-linecap="round" stroke-linejoin="round"/><line x1="1105" y1="110" x2="1055" y2="190" stroke="#3498db" stroke-width="10" stroke-linecap="round"/>
47
+ </g>
48
+ </svg>
package/dist/index.cjs ADDED
@@ -0,0 +1,11 @@
1
+ 'use strict';
2
+
3
+ const vue = require('vue');
4
+
5
+ function get(obj, key) {
6
+ if (key == null)
7
+ return vue.unref(obj);
8
+ return vue.unref(obj)[key];
9
+ }
10
+
11
+ exports.get = get;
@@ -0,0 +1,9 @@
1
+ import { MaybeRef } from 'vue';
2
+
3
+ /**
4
+ * Shorthand for accessing `ref.value`
5
+ */
6
+ declare function get<T>(ref: MaybeRef<T>): T;
7
+ declare function get<T, K extends keyof T>(ref: MaybeRef<T>, key: K): T[K];
8
+
9
+ export { get };
@@ -0,0 +1,9 @@
1
+ import { MaybeRef } from 'vue';
2
+
3
+ /**
4
+ * Shorthand for accessing `ref.value`
5
+ */
6
+ declare function get<T>(ref: MaybeRef<T>): T;
7
+ declare function get<T, K extends keyof T>(ref: MaybeRef<T>, key: K): T[K];
8
+
9
+ export { get };
@@ -0,0 +1,9 @@
1
+ import { MaybeRef } from 'vue';
2
+
3
+ /**
4
+ * Shorthand for accessing `ref.value`
5
+ */
6
+ declare function get<T>(ref: MaybeRef<T>): T;
7
+ declare function get<T, K extends keyof T>(ref: MaybeRef<T>, key: K): T[K];
8
+
9
+ export { get };
package/dist/index.mjs ADDED
@@ -0,0 +1,9 @@
1
+ import { unref } from 'vue';
2
+
3
+ function get(obj, key) {
4
+ if (key == null)
5
+ return unref(obj);
6
+ return unref(obj)[key];
7
+ }
8
+
9
+ export { get };
package/logo.svg ADDED
@@ -0,0 +1,31 @@
1
+ <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 96 96" width="256" height="256">
2
+ <defs>
3
+ <linearGradient id="bg-grad" x1="0%" y1="0%" x2="100%" y2="100%">
4
+ <stop offset="0%" style="stop-color:#2c3e50;stop-opacity:1" />
5
+ <stop offset="100%" style="stop-color:#1a252f;stop-opacity:1" />
6
+ </linearGradient>
7
+ </defs>
8
+
9
+ <!-- Background -->
10
+ <rect width="96" height="96" rx="16" fill="url(#bg-grad)"/>
11
+
12
+ <!-- Vue badge -->
13
+ <g transform="translate(8, 8)">
14
+ <rect width="18" height="9" rx="2" fill="#3498db"/>
15
+ <text x="9" y="6.8" text-anchor="middle" font-family="system-ui, -apple-system, sans-serif" font-size="4.5" font-weight="700" fill="white">VUE</text>
16
+ </g>
17
+
18
+ <!-- Category icon -->
19
+ <g>
20
+ <path d="M42 20l-8 8 8 8" fill="none" stroke="#3498db" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"/><path d="M54 20l8 8-8 8" fill="none" stroke="#3498db" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round"/><line x1="51" y1="18" x2="45" y2="38" stroke="#3498db" stroke-width="2" stroke-linecap="round"/>
21
+ </g>
22
+
23
+ <!-- Function name - textLength ensures it fits within bounds -->
24
+ <text x="48" y="56" text-anchor="middle" font-family="system-ui, -apple-system, sans-serif" font-size="14" font-weight="600" fill="white" textLength="25.2" lengthAdjust="spacingAndGlyphs">Get</text>
25
+
26
+ <!-- Category label -->
27
+ <text x="48" y="72" text-anchor="middle" font-family="system-ui, -apple-system, sans-serif" font-size="7" fill="#3498db" opacity="0.85">Utilities</text>
28
+
29
+ <!-- Bottom accent line -->
30
+ <rect x="28" y="82" width="40" height="2" rx="1" fill="#3498db" opacity="0.5"/>
31
+ </svg>
package/package.json ADDED
@@ -0,0 +1,61 @@
1
+ {
2
+ "name": "vue-get",
3
+ "version": "1.0.0",
4
+ "description": "Vue 3 shorthand for ref.value with optional nested key access",
5
+ "main": "dist/index.cjs",
6
+ "module": "dist/index.mjs",
7
+ "types": "dist/index.d.ts",
8
+ "exports": {
9
+ ".": {
10
+ "import": "./dist/index.mjs",
11
+ "require": "./dist/index.cjs",
12
+ "types": "./dist/index.d.ts"
13
+ }
14
+ },
15
+ "files": [
16
+ "dist",
17
+ "logo.svg",
18
+ "banner.svg"
19
+ ],
20
+ "scripts": {
21
+ "build": "unbuild",
22
+ "prepublishOnly": "cp README.npm.md README.md && npm run build",
23
+ "postpublish": "cp README.github.md README.md"
24
+ },
25
+ "keywords": [
26
+ "vue",
27
+ "vue3",
28
+ "vue-3",
29
+ "composable",
30
+ "composition-api",
31
+ "vueuse",
32
+ "utility",
33
+ "helper",
34
+ "utils",
35
+ "get",
36
+ "ref",
37
+ "value",
38
+ "accessor",
39
+ "shorthand",
40
+ "unwrap",
41
+ "nested"
42
+ ],
43
+ "author": "VueFrag",
44
+ "license": "MIT",
45
+ "repository": {
46
+ "type": "git",
47
+ "url": "git+https://github.com/vuefrag/vue-get.git"
48
+ },
49
+ "bugs": {
50
+ "url": "https://github.com/vuefrag/vue-get/issues"
51
+ },
52
+ "homepage": "https://github.com/vuefrag/vue-get#readme",
53
+ "peerDependencies": {
54
+ "vue": ">=3.0.0"
55
+ },
56
+ "devDependencies": {
57
+ "unbuild": "^2.0.0",
58
+ "typescript": "^5.0.0",
59
+ "vue": "^3.4.0"
60
+ }
61
+ }