harvester-ui-extension/pkg/harvester/models/devices.harvesterhci.io.vgpudevice.js
Francesco Torchia 4f2688f6ab
Add pkg/harvester components + shell portings - 1
Signed-off-by: Francesco Torchia <francesco.torchia@suse.com>
2024-10-23 17:00:46 +02:00

130 lines
2.7 KiB
JavaScript

import SteveModel from '@shell/plugins/steve/steve-class';
import { escapeHtml } from '@shell/utils/string';
const STATUS_DISPLAY = {
enabled: {
displayKey: 'generic.enabled',
color: 'bg-success'
},
pending: {
displayKey: 'generic.inProgress',
color: 'bg-info'
},
disabled: {
displayKey: 'generic.disabled',
color: 'bg-warning'
},
error: {
displayKey: 'generic.disabled',
color: 'bg-warning'
}
};
/**
* Class representing PCI Device resource.
* @extends SteveModal
*/
export default class VGpuDevice extends SteveModel {
get _availableActions() {
const out = super._availableActions;
out.push(
{
action: 'enableVGpu',
enabled: !this.isEnabled,
icon: 'icon icon-fw icon-dot',
label: 'Enable',
},
{
action: 'disableVGpu',
enabled: this.isEnabled,
icon: 'icon icon-fw icon-dot-open',
label: 'Disable',
bulkable: true,
},
);
return out;
}
get canYaml() {
return false;
}
get canDelete() {
return false;
}
goToDetail() {
return false;
}
goToEdit() {
return false;
}
get isEnabled() {
return this?.spec?.enabled === true;
}
get isEnabling() {
return this.status?.vGPUStatus && this.status?.vGPUStatus !== 'vGPUConfigured';
}
get statusDisplay() {
if (this.isEnabling) {
return STATUS_DISPLAY.pending;
}
if (this.isEnabled) {
return STATUS_DISPLAY.enabled;
}
return STATUS_DISPLAY.disabled;
}
get stateDisplay() {
const t = this.$rootGetters['i18n/t'];
return t(this.statusDisplay.displayKey);
}
get stateBackground() {
return this.statusDisplay.color;
}
enableVGpu(resources = this) {
this.$dispatch('promptModal', {
resources,
component: 'EnableVGpuDevice'
});
}
async disableVGpu() {
const { vGPUTypeName, enabled } = this.spec;
try {
this.spec.vGPUTypeName = undefined;
this.spec.enabled = false;
await this.save();
} catch (err) {
this.spec.vGPUTypeName = vGPUTypeName;
this.spec.enabled = enabled;
this.$dispatch('growl/fromError', {
title: this.t('generic.notification.title.error', { name: escapeHtml(this.metadata.name) }),
err,
}, { root: true });
}
}
get groupByNode() {
const name = this.spec?.nodeName || this.$rootGetters['i18n/t']('generic.none');
return this.$rootGetters['i18n/t']('resourceTable.groupLabel.node', { name: escapeHtml(name) });
}
get vGpuAvailableTypes() {
return this.status?.availableTypes ? Object.keys(this.status.availableTypes) : [];
}
}