Skip to content

Commit

Permalink
✨ [Frontend] VIP Market PoC (#6862)
Browse files Browse the repository at this point in the history
  • Loading branch information
odeimaiz authored Dec 2, 2024
1 parent a2f9058 commit 0c5a068
Show file tree
Hide file tree
Showing 10 changed files with 832 additions and 0 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -65,6 +65,7 @@ qx.Class.define("osparc.dashboard.SortedByMenuButton", {
field: "last_change_date",
direction: "desc"
},

getSortByOptions: function() {
return [{
id: "name",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -98,6 +98,7 @@ qx.Class.define("osparc.data.Resources", {
* added by oSPARC as compilation vars
*/
"appSummary": {
useCache: false,
endpoints: {
get: {
method: "GET",
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,6 +103,11 @@ qx.Class.define("osparc.navigation.UserMenu", {
control.addListener("execute", () => osparc.cluster.Utils.popUpClustersDetails(), this);
this.add(control);
break;
case "market":
control = new qx.ui.menu.Button(this.tr("Market"));
control.addListener("execute", () => osparc.vipMarket.MarketWindow.openWindow());
this.add(control);
break;
case "about":
control = new qx.ui.menu.Button(this.tr("About oSPARC"));
osparc.utils.Utils.setIdToWidget(control, "userMenuAboutBtn");
Expand Down Expand Up @@ -178,6 +183,11 @@ qx.Class.define("osparc.navigation.UserMenu", {
this.addSeparator();

this.__addAnnouncements();

if (osparc.product.Utils.showS4LStore()) {
this.getChildControl("market");
}

this.getChildControl("about");
if (osparc.product.Utils.showAboutProduct()) {
this.getChildControl("about-product");
Expand Down Expand Up @@ -241,6 +251,11 @@ qx.Class.define("osparc.navigation.UserMenu", {
this.addSeparator();

this.__addAnnouncements();

if (osparc.product.Utils.showS4LStore()) {
this.getChildControl("market");
}

this.getChildControl("about");
if (!osparc.product.Utils.isProduct("osparc")) {
this.getChildControl("about-product");
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -270,6 +270,14 @@ qx.Class.define("osparc.product.Utils", {
return true;
},

showS4LStore: function() {
const platformName = osparc.store.StaticInfo.getInstance().getPlatformName();
if (platformName !== "master") {
return false;
}
return this.isS4LProduct();
},

getProductThumbUrl: function(asset = "Default.png") {
const base = "https://raw.githubusercontent.com/ZurichMedTech/s4l-assets/main/app/full/project_thumbnails"
let url;
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,206 @@
/* ************************************************************************
osparc - the simcore frontend
https://osparc.io
Copyright:
2024 IT'IS Foundation, https://itis.swiss
License:
MIT: https://opensource.org/licenses/MIT
Authors:
* Odei Maiz (odeimaiz)
************************************************************************ */

qx.Class.define("osparc.vipMarket.AnatomicalModelDetails", {
extend: qx.ui.core.Widget,

construct: function() {
this.base(arguments);

const layout = new qx.ui.layout.Grow();
this._setLayout(layout);

this.__poplulateLayout();
},

events: {
"modelLeased": "qx.event.type.Event",
},

properties: {
anatomicalModelsData: {
check: "Object",
init: null,
nullable: true,
apply: "__poplulateLayout"
},
},

members: {
__poplulateLayout: function() {
this._removeAll();

const anatomicalModelsData = this.getAnatomicalModelsData();
if (anatomicalModelsData) {
const card = this.__createcCard(anatomicalModelsData);
this._add(card);
} else {
const selectModelLabel = new qx.ui.basic.Label().set({
value: this.tr("Select a model for more details"),
font: "text-16",
alignX: "center",
alignY: "middle",
allowGrowX: true,
allowGrowY: true,
});
this._add(selectModelLabel);
}
},

__createcCard: function(anatomicalModelsData) {
console.log(anatomicalModelsData);

const cardGrid = new qx.ui.layout.Grid(16, 16);
const cardLayout = new qx.ui.container.Composite(cardGrid);

const description = anatomicalModelsData["Description"];
description.split(" - ").forEach((desc, idx) => {
const titleLabel = new qx.ui.basic.Label().set({
value: desc,
font: "text-16",
alignX: "center",
alignY: "middle",
allowGrowX: true,
allowGrowY: true,
});
cardLayout.add(titleLabel, {
column: 0,
row: idx,
colSpan: 2,
});
});

const thumbnail = new qx.ui.basic.Image().set({
source: anatomicalModelsData["Thumbnail"],
alignY: "middle",
scale: true,
allowGrowX: true,
allowGrowY: true,
allowShrinkX: true,
allowShrinkY: true,
maxWidth: 256,
maxHeight: 256,
});
cardLayout.add(thumbnail, {
column: 0,
row: 2,
});

const features = anatomicalModelsData["Features"];
const featuresGrid = new qx.ui.layout.Grid(8, 8);
const featuresLayout = new qx.ui.container.Composite(featuresGrid);
let idx = 0;
[
"Name",
"Version",
"Sex",
"Age",
"Weight",
"Height",
"Date",
"Ethnicity",
"Functionality",
].forEach(key => {
if (key.toLowerCase() in features) {
const titleLabel = new qx.ui.basic.Label().set({
value: key,
font: "text-14",
alignX: "right",
});
featuresLayout.add(titleLabel, {
column: 0,
row: idx,
});

const nameLabel = new qx.ui.basic.Label().set({
value: features[key.toLowerCase()],
font: "text-14",
alignX: "left",
});
featuresLayout.add(nameLabel, {
column: 1,
row: idx,
});

idx++;
}
});

const doiTitle = new qx.ui.basic.Label().set({
value: "DOI",
font: "text-14",
alignX: "right",
marginTop: 16,
});
featuresLayout.add(doiTitle, {
column: 0,
row: idx,
});

const doiValue = new qx.ui.basic.Label().set({
value: anatomicalModelsData["DOI"] ? anatomicalModelsData["DOI"] : "-",
font: "text-14",
alignX: "left",
marginTop: 16,
});
featuresLayout.add(doiValue, {
column: 1,
row: idx,
});

cardLayout.add(featuresLayout, {
column: 1,
row: 2,
});

const buttonsLayout = new qx.ui.container.Composite(new qx.ui.layout.HBox(5));
if (anatomicalModelsData["leased"]) {
const leaseModelButton = new qx.ui.form.Button().set({
label: this.tr("3 seats Leased (27 days left)"),
appearance: "strong-button",
center: true,
enabled: false,
});
buttonsLayout.add(leaseModelButton, {
flex: 1
});
}
const leaseModelButton = new osparc.ui.form.FetchButton().set({
label: this.tr("Lease model (2 for months)"),
appearance: "strong-button",
center: true,
});
leaseModelButton.addListener("execute", () => {
leaseModelButton.setFetching(true);
setTimeout(() => {
leaseModelButton.setFetching(false);
this.fireDataEvent("modelLeased", this.getAnatomicalModelsData()["ID"]);
}, 2000);
});
buttonsLayout.add(leaseModelButton, {
flex: 1
});
cardLayout.add(buttonsLayout, {
column: 0,
row: 3,
colSpan: 2,
});

return cardLayout;
},
}
});
Loading

0 comments on commit 0c5a068

Please sign in to comment.