Skip to content

Commit

Permalink
🎨 [Frontend] Enhance: syncing tree (ITISFoundation#6687)
Browse files Browse the repository at this point in the history
  • Loading branch information
odeimaiz authored Nov 8, 2024
1 parent 299c1ac commit 1564d50
Show file tree
Hide file tree
Showing 13 changed files with 144 additions and 97 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -39,7 +39,14 @@ qx.Class.define("osparc.dashboard.MoveResourceTo", {
const item = selection.getItem(0);
this.__selectedWorkspaceId = item.getWorkspaceId();
this.__selectedFolderId = item.getFolderId();
moveButton.setEnabled(this.__currentWorkspaceId !== this.__selectedWorkspaceId || this.__currentFolderId !== this.__selectedFolderId);
if (this.__selectedWorkspaceId === -1) {
// "Shared Workspaces"
moveButton.setEnabled(false);
} else {
// In principle, valid location
// disable if it's the current location
moveButton.setEnabled(this.__currentWorkspaceId !== this.__selectedWorkspaceId || this.__currentFolderId !== this.__selectedFolderId);
}
}
}, this);
moveButton.addListener("execute", () => {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -74,7 +74,7 @@ qx.Class.define("osparc.dashboard.WorkspacesAndFoldersTree", {

osparc.store.Workspaces.getInstance().addListener("workspaceRemoved", e => {
const workspace = e.getData();
this.__removeWorkspace(workspace);
this.__workspaceRemoved(workspace);
}, this);

this.getSelection().addListener("change", () => {
Expand Down Expand Up @@ -227,11 +227,21 @@ qx.Class.define("osparc.dashboard.WorkspacesAndFoldersTree", {
this.__populateFolder(workspaceModel, workspace.getWorkspaceId(), null);
},

__removeWorkspace: function(workspace) {
__workspaceRemoved: function(workspace) {
// remove it from the tree
const sharedWorkspaceModel = this.__getModel(-1, null);
const idx = sharedWorkspaceModel.getChildren().toArray().findIndex(w => workspace.getWorkspaceId() === w.getWorkspaceId());
if (idx > -1) {
sharedWorkspaceModel.getChildren().toArray().splice(idx, 1);
sharedWorkspaceModel.getChildren().removeAt(idx);
}

// remove it from the cached models
const modelFound = this.__getModel(workspace.getWorkspaceId(), null);
if (modelFound) {
const index = this.__models.indexOf(modelFound);
if (index > -1) { // only splice array when item is found
this.__models.splice(index, 1); // 2nd parameter means remove one item only
}
}
},

Expand Down Expand Up @@ -283,7 +293,19 @@ qx.Class.define("osparc.dashboard.WorkspacesAndFoldersTree", {
if (parentModel) {
const idx = parentModel.getChildren().toArray().findIndex(c => folder.getWorkspaceId() === c.getWorkspaceId() && folder.getFolderId() === c.getFolderId());
if (idx > -1) {
parentModel.getChildren().toArray().splice(idx, 1);
parentModel.getChildren().removeAt(idx);
}
}

if (oldParentFolderId === undefined) {
// it was removed, not moved
// remove it from the cached models
const modelFound = this.__getModel(folder.getWorkspaceId(), folder.getParentFolderId());
if (modelFound) {
const index = this.__models.indexOf(modelFound);
if (index > -1) { // only splice array when item is found
this.__models.splice(index, 1); // 2nd parameter means remove one item only
}
}
}
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,9 @@ qx.Class.define("osparc.data.model.IframeHandler", {
this.__unresponsiveRetries = 5;
this.__nodeState();

this.getIFrame().resetSource();
if (this.getIFrame()) {
this.getIFrame().resetSource();
}
},

__initIFrame: function() {
Expand Down Expand Up @@ -365,7 +367,9 @@ qx.Class.define("osparc.data.model.IframeHandler", {

// will switch to the loading page
node.resetServiceUrl();
this.getIFrame().resetSource();
if (this.getIFrame()) {
this.getIFrame().resetSource();
}
this.fireEvent("iframeChanged");
}
},
Expand Down Expand Up @@ -396,8 +400,10 @@ qx.Class.define("osparc.data.model.IframeHandler", {
const status = node.getStatus().getInteractive();
// it might have been stopped
if (["running", "ready"].includes(status)) {
this.getIFrame().resetSource();
this.getIFrame().setSource(node.getServiceUrl());
if (this.getIFrame()) {
this.getIFrame().resetSource();
this.getIFrame().setSource(node.getServiceUrl());
}

// fire event to force switching to iframe's content:
// it is required in those cases where the native 'load' event isn't triggered (voila)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -358,7 +358,8 @@ qx.Class.define("osparc.desktop.organizations.MembersList", {
}
})
.catch(err => {
osparc.FlashMessenger.getInstance().logAs(this.tr("Something went wrong adding the user"), "ERROR");
const errorMessage = err["message"] || this.tr("Something went wrong adding the user");
osparc.FlashMessenger.getInstance().logAs(errorMessage, "ERROR");
console.error(err);
});
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -101,7 +101,7 @@ qx.Class.define("osparc.desktop.organizations.OrganizationsList", {
createOrgBtn.addListener("execute", function() {
const newOrg = true;
const orgEditor = new osparc.editor.OrganizationEditor(newOrg);
const title = this.tr("Organization Details Editor");
const title = this.tr("New Organization");
const win = osparc.ui.window.Window.popUpInWindow(orgEditor, title, 400, 250);
orgEditor.addListener("createOrg", () => {
this.__createOrganization(win, orgEditor.getChildControl("create"), orgEditor);
Expand Down Expand Up @@ -298,7 +298,8 @@ qx.Class.define("osparc.desktop.organizations.OrganizationsList", {
});
})
.catch(err => {
osparc.FlashMessenger.getInstance().logAs(this.tr("Something went wrong creating ") + name, "ERROR");
const errorMessage = err["message"] || this.tr("Something went wrong creating ") + name;
osparc.FlashMessenger.getInstance().logAs(errorMessage, "ERROR");
button.setFetching(false);
console.error(err);
})
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,11 @@ qx.Class.define("osparc.editor.OrganizationEditor", {
this.getChildControl("description");
this.getChildControl("thumbnail");
newOrg ? this.getChildControl("create") : this.getChildControl("save");

this.addListener("appear", () => {
title.focus();
title.activate();
});
},

properties: {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,14 +20,14 @@ qx.Class.define("osparc.info.ServiceLarge", {
extend: osparc.info.CardLarge,

/**
* @param serviceData {Object} Serialized Service Object
* @param metadata {Object} Serialized Service Object
* @param instance {Object} instance related data
* @param openOptions {Boolean} open edit options in new window or fire event
*/
construct: function(serviceData, instance = null, openOptions = true) {
construct: function(metadata, instance = null, openOptions = true) {
this.base(arguments);

this.setService(serviceData);
this.setService(metadata);

if (instance) {
if ("nodeId" in instance) {
Expand Down Expand Up @@ -79,6 +79,19 @@ qx.Class.define("osparc.info.ServiceLarge", {
}
},

statics: {
popUpInWindow: function(serviceLarge) {
const metadata = serviceLarge.getService();
const versionDisplay = osparc.service.Utils.extractVersionDisplay(metadata);
const title = `${metadata["name"]} ${versionDisplay}`;
const width = osparc.info.CardLarge.WIDTH;
const height = osparc.info.CardLarge.HEIGHT;
osparc.ui.window.Window.popUpInWindow(serviceLarge, title, width, height).set({
maxHeight: height
});
},
},

members: {
_rebuildLayout: function() {
this._removeAll();
Expand All @@ -90,72 +103,85 @@ qx.Class.define("osparc.info.ServiceLarge", {
vBox.add(deprecated);
}

const title = this.__createTitle();
const titleLayout = this.__createViewWithEdit(title, this.__openTitleEditor);

const extraInfo = this.__extraInfo();
const extraInfoLayout = this.__createExtraInfo(extraInfo);

const bounds = this.getBounds();
const offset = 30;
const maxThumbnailHeight = extraInfo.length*20;
let widgetWidth = bounds ? bounds.width - offset : 500 - offset;
let thumbnailWidth = widgetWidth - 2 * osparc.info.CardLarge.PADDING - osparc.info.CardLarge.EXTRA_INFO_WIDTH;
thumbnailWidth = Math.min(thumbnailWidth - 20, osparc.info.CardLarge.THUMBNAIL_MAX_WIDTH);
const thumbnail = this.__createThumbnail(thumbnailWidth, maxThumbnailHeight);
const thumbnailLayout = this.__createViewWithEdit(thumbnail, this.__openThumbnailEditor);
thumbnailLayout.getLayout().set({
alignX: "center"
});

const infoAndThumbnail = new qx.ui.container.Composite(new qx.ui.layout.HBox(3).set({
alignX: "center"
}));
infoAndThumbnail.add(extraInfoLayout);
infoAndThumbnail.add(thumbnailLayout, {
flex: 1
});

let descriptionUi = null;
if (osparc.service.Utils.canIWrite(this.getService()["accessRights"])) {
descriptionUi = this.__createDescriptionUi();
}

const description = this.__createDescription();
const editInTitle = this.__createViewWithEdit(description.getChildren()[0], this.__openDescriptionEditor);
description.addAt(editInTitle, 0);

let resources = null;
if (!osparc.desktop.credits.Utils.areWalletsEnabled()) {
resources = this.__createResources();
}

const copyMetadataButton = new qx.ui.form.Button(this.tr("Copy Raw metadata"), "@FontAwesome5Solid/copy/12").set({
allowGrowX: false
});
copyMetadataButton.addListener("execute", () => osparc.utils.Utils.copyTextToClipboard(osparc.utils.Utils.prettifyJson(this.getService())), this);


if (
this.getService()["descriptionUi"] &&
!osparc.service.Utils.canIWrite(this.getService()["accessRights"]) &&
description.getChildren().length > 1
) {
// Show description only
vBox.add(description.getChildren()[1]);
// Show also the copy Id buttons too
const buttonsLayout = new qx.ui.container.Composite(new qx.ui.layout.HBox(10));
if (this.getNodeId()) {
const studyAlias = osparc.product.Utils.getStudyAlias({firstUpperCase: true});
const copyStudyIdButton = new qx.ui.form.Button(this.tr(`Copy ${studyAlias} Id`), "@FontAwesome5Solid/copy/12").set({
toolTipText: qx.locale.Manager.tr("Copy to clipboard"),
});
copyStudyIdButton.addListener("execute", this.__copyStudyIdToClipboard, this);
buttonsLayout.add(copyStudyIdButton);
vBox.add(buttonsLayout);

const copyNodeIdButton = new qx.ui.form.Button(this.tr("Copy Service Id"), "@FontAwesome5Solid/copy/12").set({
toolTipText: qx.locale.Manager.tr("Copy to clipboard"),
});
copyNodeIdButton.addListener("execute", this.__copyNodeIdToClipboard, this);
buttonsLayout.add(copyNodeIdButton);
vBox.add(buttonsLayout);
}
// Also copyMetadataButton if tester
if (osparc.data.Permissions.getInstance().isTester()) {
// Also copyMetadataButton if tester
vBox.add(copyMetadataButton);
buttonsLayout.add(copyMetadataButton);
vBox.add(buttonsLayout);
}
// Show description only
vBox.add(description.getChildren()[1]);
} else {
const title = this.__createTitle();
const titleLayout = this.__createViewWithEdit(title, this.__openTitleEditor);
vBox.add(titleLayout);

const extraInfo = this.__extraInfo();
const extraInfoLayout = this.__createExtraInfo(extraInfo);
const bounds = this.getBounds();
const offset = 30;
const maxThumbnailHeight = extraInfo.length*20;
let widgetWidth = bounds ? bounds.width - offset : 500 - offset;
let thumbnailWidth = widgetWidth - 2 * osparc.info.CardLarge.PADDING - osparc.info.CardLarge.EXTRA_INFO_WIDTH;
thumbnailWidth = Math.min(thumbnailWidth - 20, osparc.info.CardLarge.THUMBNAIL_MAX_WIDTH);
const thumbnail = this.__createThumbnail(thumbnailWidth, maxThumbnailHeight);
const thumbnailLayout = this.__createViewWithEdit(thumbnail, this.__openThumbnailEditor);
thumbnailLayout.getLayout().set({
alignX: "center"
});
const infoAndThumbnail = new qx.ui.container.Composite(new qx.ui.layout.HBox(3).set({
alignX: "center"
}));
infoAndThumbnail.add(extraInfoLayout);
infoAndThumbnail.add(thumbnailLayout, {
flex: 1
});
vBox.add(infoAndThumbnail);
if (descriptionUi) {
vBox.add(descriptionUi);

if (osparc.service.Utils.canIWrite(this.getService()["accessRights"])) {
const descriptionUi = this.__createDescriptionUi();
if (descriptionUi) {
vBox.add(descriptionUi);
}
}
vBox.add(description);
if (resources) {
vBox.add(resources);

if (!osparc.desktop.credits.Utils.areWalletsEnabled()) {
const resources = this.__createResources();
if (resources) {
vBox.add(resources);
}
}
vBox.add(copyMetadataButton);
}
Expand Down Expand Up @@ -429,6 +455,10 @@ qx.Class.define("osparc.info.ServiceLarge", {
titleEditor.open();
},

__copyStudyIdToClipboard: function() {
osparc.utils.Utils.copyTextToClipboard(this.getStudyId());
},

__copyNodeIdToClipboard: function() {
osparc.utils.Utils.copyTextToClipboard(this.getNodeId());
},
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,12 +147,7 @@ qx.Class.define("osparc.metadata.ServicesInStudy", {
studyId: this._studyData["uuid"],
label: node["label"]
});
const title = this.tr("Service information");
const width = osparc.info.CardLarge.WIDTH;
const height = osparc.info.CardLarge.HEIGHT;
osparc.ui.window.Window.popUpInWindow(serviceDetails, title, width, height).set({
maxHeight: height
});
osparc.info.ServiceLarge.popUpInWindow(serviceDetails);
}, this);
this._servicesGrid.add(infoButton, {
row: i,
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -217,17 +217,13 @@ qx.Class.define("osparc.node.slideshow.BaseNodeView", {

__openServiceDetails: function() {
const node = this.getNode();
const serviceDetails = new osparc.info.ServiceLarge(node.getMetaData(), {
const metadata = node.getMetaData();
const serviceDetails = new osparc.info.ServiceLarge(metadata, {
nodeId: node.getNodeId(),
label: node.getLabel(),
studyId: node.getStudy().getUuid()
});
const title = this.tr("Service information");
const width = osparc.info.CardLarge.WIDTH;
const height = osparc.info.CardLarge.HEIGHT;
osparc.ui.window.Window.popUpInWindow(serviceDetails, title, width, height).set({
maxHeight: height
});
osparc.info.ServiceLarge.popUpInWindow(serviceDetails);
},

__openInstructions: function() {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -161,12 +161,7 @@ qx.Class.define("osparc.service.ServiceListItem", {
osparc.store.Services.getService(key, version)
.then(serviceMetadata => {
const serviceDetails = new osparc.info.ServiceLarge(serviceMetadata);
const title = this.tr("Service information");
const width = osparc.info.CardLarge.WIDTH;
const height = osparc.info.CardLarge.HEIGHT;
osparc.ui.window.Window.popUpInWindow(serviceDetails, title, width, height).set({
maxHeight: height
});
osparc.info.ServiceLarge.popUpInWindow(serviceDetails);
});
},

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -290,15 +290,13 @@ qx.Class.define("osparc.widget.NodesTree", {
});
} else {
const node = study.getWorkbench().getNode(nodeId);
const serviceDetails = new osparc.info.ServiceLarge(node.getMetaData(), {
const metadata = node.getMetaData();
const serviceDetails = new osparc.info.ServiceLarge(metadata, {
nodeId,
label: node.getLabel(),
studyId: study.getUuid()
});
const title = this.tr("Service information");
osparc.ui.window.Window.popUpInWindow(serviceDetails, title, width, height).set({
maxHeight: height
});
osparc.info.ServiceLarge.popUpInWindow(serviceDetails);
}
}
},
Expand Down
Loading

0 comments on commit 1564d50

Please sign in to comment.