Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Add discount icon with discount package in contracts table #3392

Open
wants to merge 16 commits into
base: development
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
38 changes: 38 additions & 0 deletions packages/grid_client/src/clients/tf-grid/contracts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,9 @@ export interface GqlContracts {
export interface GqlConsumption extends GqlContracts {
contractBillReports: GqlContractBillReports[];
}
export interface GqlDiscountPackage {
contractBillReports: GqlContractBillReports[];
}

export interface GqlContractBillReports {
id: string;
Expand Down Expand Up @@ -107,6 +110,11 @@ export interface GetConsumptionOptions {
id: number;
}

export interface GetDiscountPackageOptions {
graphqlURL: string;
id: number;
}

export interface CancelMyContractOptions {
graphqlURL: string;
}
Expand Down Expand Up @@ -251,7 +259,37 @@ class TFContracts extends Contracts {
throw err;
}
}
/**
* Get contract discount package
* @param {GetDiscountPackageOptions} options
* @returns {Promie<DiscountLevel>}
*/
async getDiscountPackage(options: GetDiscountPackageOptions): Promise<DiscountLevel> {
const gqlClient = new Graphql(options.graphqlURL);

const body = `query getConsumption($contractId: BigInt!){
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

I notice that we can add order to the request body; i think this will be better
image

contractBillReports(where: {contractID_eq: $contractId} ) {
discountReceived

}
}`;

try {
const response = await gqlClient.query(body, { contractId: options.id });

const gqlDiscountPackage: GqlDiscountPackage = response["data"] as GqlDiscountPackage;
const billReports = gqlDiscountPackage.contractBillReports;
if (billReports.length === 0) {
return "None";
} else {
const discountPackage = billReports[billReports.length - 1].discountReceived;
return discountPackage;
}
} catch (err) {
(err as Error).message = formatErrorMessage(`Error getting discount package for contract ${options.id}.`, err);
throw err;
}
}
/**
* Get contract consumption per hour in TFT.
*
Expand Down
16 changes: 15 additions & 1 deletion packages/grid_client/src/modules/contracts.ts
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ import * as PATH from "path";

import {
ContractsOverdue,
type DiscountLevel,
GqlContracts,
GqlNameContract,
GqlNodeContract,
Expand All @@ -31,6 +32,7 @@ import {
BatchCancelContractsModel,
ContractCancelModel,
ContractConsumption,
ContractDiscountPackage,
ContractGetByNodeIdAndHashModel,
ContractGetModel,
ContractLockModel,
Expand Down Expand Up @@ -523,7 +525,19 @@ class Contracts {
async setDedicatedNodeExtraFee(options: SetDedicatedNodeExtraFeesModel) {
return (await this.client.contracts.setDedicatedNodeExtraFee(options)).apply();
}

/**
* Get contract discount package
* @param {ContractDiscountPackage} options
* @returns {Promie<DiscountLevel>}
* @decorators
* - `@expose`: Exposes the method for external use.
* - `@validateInput`: Validates the input options.
*/
@expose
@validateInput
async getDiscountPackage(options: ContractDiscountPackage): Promise<DiscountLevel> {
return this.client.contracts.getDiscountPackage({ id: options.id, graphqlURL: this.config.graphqlURL });
}
/**
* Get contract consumption per hour in TFT.
*
Expand Down
5 changes: 5 additions & 0 deletions packages/grid_client/src/modules/models.ts
Original file line number Diff line number Diff line change
Expand Up @@ -390,6 +390,10 @@ class ContractConsumption {
@Expose() @IsInt() @Min(1) id: number;
}

class ContractDiscountPackage {
@Expose() @IsInt() @Min(1) id: number;
}

class ContractLockModel extends ContractConsumption {}

class TwinCreateModel {
Expand Down Expand Up @@ -974,6 +978,7 @@ export {
ContractsByTwinId,
ContractsByAddress,
ContractConsumption,
ContractDiscountPackage,
ContractLockModel,
TwinCreateModel,
TwinGetModel,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -36,9 +36,23 @@
</template>

<template #[`item.consumption`]="{ item }">
<p v-if="item?.consumption !== 0 && item?.consumption !== undefined">
{{ item.consumption.toFixed(3) }} TFT/hour
</p>
<div
v-if="item?.consumption !== 0 && item?.consumption !== undefined"
class="d-flex justify-center align-center"
>
<p class="mr-2" cols="8">{{ item.consumption.toFixed(3) }} TFT/hour</p>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

image
using text-no-wrap may fix this issue.


<v-tooltip bottom color="primary" close-delay="100" v-if="item.discountPackage" cols="2">
<template v-slot:activator="{ props }">
<v-icon class="scale_beat mr-2" color="warning" v-bind="props">mdi-brightness-percent</v-icon>
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

i think we should remove the mr-2 no need for it

</template>

<span>
{{ item.discountPackage }}
</span>
</v-tooltip>
</div>

<p v-else>No Data Available</p>
</template>

Expand Down Expand Up @@ -289,7 +303,7 @@

<script lang="ts" setup>
// Import necessary types and libraries
import { ContractStates, type GridClient, type OverdueDetails } from "@threefold/grid_client";
import { ContractStates, discountPackages, type GridClient, type OverdueDetails } from "@threefold/grid_client";
import { type Contract, ContractState, type NodeStatus } from "@threefold/gridproxy_client";
import { TFChainError } from "@threefold/tfchain_client";
import { DeploymentKeyDeletionError } from "@threefold/types";
Expand Down
6 changes: 5 additions & 1 deletion packages/playground/src/utils/contracts.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import { ContractStates, type GridClient } from "@threefold/grid_client";
import { ContractStates, type DiscountLevel, type GridClient } from "@threefold/grid_client";
import { NodeStatus } from "@threefold/gridproxy_client";
import type { Ref } from "vue";

Expand Down Expand Up @@ -60,6 +60,8 @@ export async function normalizeContract(
consumption = 0;
}

const discountPackage = await grid.contracts.getDiscountPackage({ id });

return {
contract_id: id,
twin_id: c.twin_id,
Expand All @@ -76,6 +78,7 @@ export async function normalizeContract(
solutionType: data.projectName || data.type || "-",
expiration,
consumption: consumption,
discountPackage: discountPackage,
};
}

Expand Down Expand Up @@ -155,6 +158,7 @@ export interface NormalizedContract {
solutionName?: string;
deploymentType?: string;
expiration?: string;
discountPackage?: DiscountLevel;
}

export enum ContractType {
Expand Down
Loading