|
1 | 1 | <template>
|
2 | 2 | <Addon :addon="props.addon">
|
3 | 3 | <template #badges>
|
4 |
| - <span class="badge" v-if="hasPlugin">Plugin</span> |
5 |
| - <span class="badge" v-if="commitDate" |
6 |
| - ><CodeIcon icon="cloud-download" />{{ commitDate }}</span |
| 4 | + <span class="badge" v-if="props.addon.hasPlugin">Plugin</span> |
| 5 | + <span class="badge" v-if="installDateFromNow" :title="installDate" |
| 6 | + ><CodeIcon icon="cloud-download" />{{ installDateFromNow }}</span |
7 | 7 | >
|
8 | 8 | <span v-if="updateAvailable" class="badge">
|
9 | 9 | <CodeIcon icon="repo-pull" />Update Available
|
10 | 10 | </span>
|
11 | 11 | </template>
|
12 | 12 | <template #quick-actions>
|
13 | 13 | <button
|
14 |
| - @click="addon.open" |
15 |
| - :title="`Open ${addon.name} in file explorer`" |
| 14 | + @click="open" |
| 15 | + :title="`Open ${props.addon.name} in file explorer`" |
16 | 16 | >
|
17 | 17 | <CodeIcon icon="folder" />
|
18 | 18 | </button>
|
19 | 19 | </template>
|
20 | 20 | <template #controls>
|
21 | 21 | <vscode-button
|
22 | 22 | v-if="updateAvailable"
|
23 |
| - @click="remoteAddon?.download" |
24 |
| - :aria-label="`Update ${name}`" |
25 |
| - :title="`Update ${name}`" |
| 23 | + @click="update" |
| 24 | + :aria-label="`Update ${props.addon.name}`" |
| 25 | + :title="`Update ${props.addon.name}`" |
26 | 26 | >Update</vscode-button
|
27 | 27 | >
|
28 | 28 | <vscode-button
|
29 |
| - v-if="!enabled" |
| 29 | + v-if="!props.addon.enabled" |
30 | 30 | :disabled="!workspaceOpen"
|
31 |
| - :aria-label="`Enable ${name}`" |
| 31 | + :aria-label="`Enable ${props.addon.name}`" |
32 | 32 | :title="
|
33 |
| - !workspaceOpen ? 'There is no workspace open' : `Enable ${name}` |
| 33 | + !workspaceOpen |
| 34 | + ? 'There is no workspace open' |
| 35 | + : `Enable ${props.addon.name}` |
34 | 36 | "
|
35 |
| - @click="addon.enable" |
| 37 | + @click="enable" |
36 | 38 | appearance="primary"
|
37 | 39 | >Enable</vscode-button
|
38 | 40 | >
|
39 | 41 | <vscode-button
|
40 |
| - v-if="enabled" |
| 42 | + v-if="props.addon.enabled" |
41 | 43 | :disabled="!workspaceOpen"
|
42 |
| - :aria-label="`Disable ${name}`" |
| 44 | + :aria-label="`Disable ${props.addon.name}`" |
43 | 45 | :title="
|
44 |
| - !workspaceOpen ? 'There is no workspace open' : `Disable ${name}` |
| 46 | + !workspaceOpen |
| 47 | + ? 'There is no workspace open' |
| 48 | + : `Disable ${props.addon.name}` |
45 | 49 | "
|
46 |
| - @click="addon.disable" |
| 50 | + @click="disable" |
47 | 51 | appearance="primary"
|
48 | 52 | >Disable</vscode-button
|
49 | 53 | >
|
50 | 54 | <vscode-button
|
51 |
| - :aria-label="`Uninstall ${name}`" |
52 |
| - :title="`Uninstall ${name}`" |
53 |
| - @click="addon.uninstall" |
| 55 | + :aria-label="`Uninstall ${props.addon.name}`" |
| 56 | + :title="`Uninstall ${props.addon.name}`" |
| 57 | + @click="uninstall" |
54 | 58 | appearance="secondary"
|
55 | 59 | >Uninstall</vscode-button
|
56 | 60 | >
|
|
59 | 63 | </template>
|
60 | 64 |
|
61 | 65 | <script setup lang="ts">
|
62 |
| -import type { LocalAddon } from "@/services/addon.service"; |
| 66 | +import type { LocalAddon } from "@/types/addon"; |
63 | 67 |
|
64 | 68 | import { computed } from "vue";
|
| 69 | +import dayjs from "dayjs"; |
65 | 70 | import CodeIcon from "@/components/CodeIcon.vue";
|
66 | 71 | import Addon from "./Addon.vue";
|
67 |
| -import { useAddonStore } from "@/stores/remoteAddons"; |
68 | 72 | import {
|
69 | 73 | provideVSCodeDesignSystem,
|
70 | 74 | vsCodeButton,
|
71 | 75 | } from "@vscode/webview-ui-toolkit";
|
72 | 76 | import { useAppStore } from "@/stores/app";
|
| 77 | +import { vscode } from "@/services/vscode.service"; |
73 | 78 |
|
74 | 79 | provideVSCodeDesignSystem().register(vsCodeButton());
|
75 | 80 |
|
76 | 81 | const props = defineProps<{ addon: LocalAddon }>();
|
77 | 82 |
|
78 |
| -const remoteAddonStore = useAddonStore(); |
79 | 83 | const appStore = useAppStore();
|
80 | 84 |
|
81 |
| -// Get remote version of this addon to compare versions |
82 |
| -const remoteAddon = computed(() => remoteAddonStore.getAddon(props.addon.name)); |
83 |
| -const updateAvailable = computed(() => |
84 |
| - remoteAddon.value?.commitDate?.isAfter(props.addon.installDate) |
| 85 | +const installDateFromNow = computed(() => |
| 86 | + dayjs(props.addon.installTimestamp).fromNow() |
85 | 87 | );
|
| 88 | +const installDate = computed(() => |
| 89 | + dayjs(props.addon.installTimestamp).local().format("MMMM DD, YYYY, h:mm A") |
| 90 | +); |
| 91 | +const updateAvailable = computed(() => props.addon.hasUpdate); |
86 | 92 |
|
87 | 93 | const workspaceOpen = computed(() => appStore.workspaceOpen);
|
88 | 94 |
|
89 |
| -const name = computed(() => props.addon.name); |
90 |
| -const enabled = computed(() => props.addon.enabled); |
91 |
| -const commitDate = computed(() => props.addon.installDate?.fromNow()); |
92 |
| -const hasPlugin = computed(() => props.addon.hasPlugin); |
| 95 | +const uninstall = () => { |
| 96 | + vscode.postMessage("uninstall", { |
| 97 | + name: props.addon.name, |
| 98 | + }); |
| 99 | +}; |
| 100 | +
|
| 101 | +const disable = () => { |
| 102 | + vscode.postMessage("disable", { |
| 103 | + name: props.addon.name, |
| 104 | + }); |
| 105 | +}; |
| 106 | +
|
| 107 | +const enable = () => { |
| 108 | + vscode.postMessage("enable", { |
| 109 | + name: props.addon.name, |
| 110 | + }); |
| 111 | +}; |
| 112 | +
|
| 113 | +const update = () => { |
| 114 | + vscode.postMessage("install", { |
| 115 | + name: props.addon.name, |
| 116 | + }); |
| 117 | +}; |
| 118 | +
|
| 119 | +const open = () => { |
| 120 | + vscode.postMessage("open", { |
| 121 | + name: props.addon.name, |
| 122 | + }); |
| 123 | +}; |
93 | 124 | </script>
|
0 commit comments