Skip to content

Commit

Permalink
Convert quota meter to composition api and typescript
Browse files Browse the repository at this point in the history
  • Loading branch information
guerler committed May 31, 2024
1 parent 3283595 commit ed05a38
Show file tree
Hide file tree
Showing 2 changed files with 48 additions and 54 deletions.
2 changes: 1 addition & 1 deletion client/src/api/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -223,7 +223,7 @@ export interface User extends QuotaUsageResponse {
username?: string;
}

export interface AnonymousUser {
export interface AnonymousUser extends QuotaUsageResponse {
id?: string;
isAnonymous: true;
is_admin?: false;
Expand Down
100 changes: 47 additions & 53 deletions client/src/components/Masthead/QuotaMeter.vue
Original file line number Diff line number Diff line change
@@ -1,61 +1,55 @@
<template>
<div v-b-tooltip.hover.bottom class="quota-meter d-flex align-items-center" title="Storage and Usage Details">
<b-link class="quota-progress" to="/storage" data-description="storage dashboard link">
<b-progress :max="100">
<b-progress-bar aria-label="Quota usage" :value="usage" :variant="variant" />
</b-progress>
<span v-if="hasQuota">{{ usingString + " " + usage.toFixed(0) }}%</span>
<span v-else>{{ usingString + " " + totalUsageString }}</span>
</b-link>
</div>
</template>
<script setup lang="ts">
import { BLink, BProgress, BProgressBar } from "bootstrap-vue";
import { storeToRefs } from "pinia";
import { computed } from "vue";
<script>
import { mapState } from "pinia";
import { bytesToString } from "utils/utils";
import { useConfigStore } from "@/stores/configurationStore";
import { useConfig } from "@/composables/config";
import { useUserStore } from "@/stores/userStore";
import { bytesToString } from "@/utils/utils";
const { config } = useConfig();
const { currentUser } = storeToRefs(useUserStore());
const hasQuota = computed(() => {
const quotasEnabled = config.value.enable_quotas ?? false;
const quotaLimited = currentUser.value?.quota !== "unlimited" ?? false;
return quotasEnabled && quotaLimited;
});
const totalUsageString = computed(() => {
const total = currentUser.value?.total_disk_usage ?? 0;
return bytesToString(total, true);
});
export default {
name: "QuotaMeter",
data() {
return {
usingString: this.l("Using"),
};
},
computed: {
...mapState(useConfigStore, ["config"]),
...mapState(useUserStore, ["currentUser"]),
hasQuota() {
const quotasEnabled = this.config?.enable_quotas ?? false;
const quotaLimited = this.currentUser?.quota !== "unlimited" ?? false;
return quotasEnabled && quotaLimited;
},
usage() {
if (this.hasQuota) {
return this.currentUser?.quota_percent ?? 0;
} else {
return this.currentUser?.total_disk_usage ?? 0;
}
},
totalUsageString() {
const total = this.currentUser?.total_disk_usage ?? 0;
return bytesToString(total, true);
},
variant() {
if (!this.hasQuota || this.usage < 80) {
return "success";
} else if (this.usage < 95) {
return "warning";
} else {
return "danger";
}
},
},
};
const usage = computed(() => {
if (hasQuota.value) {
return currentUser.value?.quota_percent ?? 0;
}
return currentUser.value?.total_disk_usage ?? 0;
});
const variant = computed(() => {
if (!hasQuota.value || usage.value < 80) {
return "success";
} else if (usage.value < 95) {
return "warning";
}
return "danger";
});
</script>

<template>
<div v-b-tooltip.hover.bottom class="quota-meter d-flex align-items-center" title="Storage and Usage Details">
<BLink class="quota-progress" to="/storage" data-description="storage dashboard link">
<BProgress :max="100">
<BProgressBar aria-label="Quota usage" :value="usage" :variant="variant" />
</BProgress>
<span v-if="hasQuota">{{ "Usage " + usage.toFixed(0) }}%</span>
<span v-else>{{ "Usage " + totalUsageString }}</span>
</BLink>
</div>
</template>

<style lang="scss" scoped>
.quota-meter {
position: relative;
Expand Down

0 comments on commit ed05a38

Please sign in to comment.