Skip to content

Commit

Permalink
Python-side structure selection
Browse files Browse the repository at this point in the history
  • Loading branch information
ceriottm committed Jan 6, 2024
1 parent 97fe788 commit ae0ef52
Show file tree
Hide file tree
Showing 3 changed files with 33 additions and 7 deletions.
11 changes: 7 additions & 4 deletions python/jupyter/src/widget.ts
Original file line number Diff line number Diff line change
Expand Up @@ -86,6 +86,8 @@ class ChemiscopeBaseView extends DOMWidgetView {

const selection = this.model.get('selection') as Indexes;
console.log("selection update", selection);

(this.visualizer as DefaultVisualizer).select(selection);
// for the moment does nothing
},
this
Expand All @@ -95,7 +97,7 @@ class ChemiscopeBaseView extends DOMWidgetView {
protected _updatePythonSelection(): void {
if (this.visualizer !== undefined) {
const selection = this.visualizer.getSelected();

console.log("getting selection ", selection);
// save current settings of settings_sync
const sync_state = this.model.get('_settings_sync') as unknown;

Expand Down Expand Up @@ -175,13 +177,14 @@ export class ChemiscopeView extends ChemiscopeBaseView {

const data = JSON.parse(this.model.get('value') as string) as Dataset;
void DefaultVisualizer.load(config, data)
.then((visualizer) => {
.then((visualizer) => {
this.visualizer = visualizer;
// update the Python side settings whenever a setting changes
this.visualizer.onSettingChange(() => this._updatePythonSettings());
this.visualizer.onSelection = (() => this._updatePythonSelection());
this.visualizer.onSettingChange(() => this._updatePythonSettings());
this.visualizer.info.onselection = (() => this._updatePythonSelection());
// and set them to the initial value right now
this._updatePythonSettings();
this._updatePythonSelection();
})
.catch((e: Error) => {
// eslint-disable-next-line no-console
Expand Down
17 changes: 14 additions & 3 deletions src/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -171,7 +171,7 @@ class DefaultVisualizer {
public map: PropertiesMap;
public info: EnvironmentInfo;
public meta: MetadataPanel;
public structure: ViewersGrid;
public structure: ViewersGrid;

private _indexer: EnvironmentIndexer;
// Stores raw input input so we can give it back later
Expand Down Expand Up @@ -214,7 +214,7 @@ class DefaultVisualizer {

this.structure.onselect = (indexes) => {
this.map.select(indexes);
this.info.show(indexes);
this.info.show(indexes);
};

this.structure.onremove = (guid) => {
Expand All @@ -240,8 +240,9 @@ class DefaultVisualizer {
);

this.map.onselect = (indexes) => {
console.log("map onselect");

Check failure on line 243 in src/index.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 243 in src/index.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
this.info.show(indexes);
this.structure.show(indexes);
this.structure.show(indexes);
};

this.map.activeChanged = (guid, indexes) => {
Expand All @@ -256,9 +257,14 @@ class DefaultVisualizer {
this._indexer,
dataset.parameters
);

this.info.onchange = (indexes) => {
this.map.select(indexes);
this.structure.show(indexes);
if (this.info.onselection !== undefined) {
console.log("info onchange", indexes);

Check failure on line 265 in src/index.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 265 in src/index.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
this.info.onselection();
}
};

this.structure.delayChanged = (delay) => {
Expand Down Expand Up @@ -407,6 +413,11 @@ class DefaultVisualizer {
return this.info.getSelected();
}

public select(indexes: Indexes) {
console.log("selecting");

Check failure on line 417 in src/index.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 417 in src/index.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
this.map.select(indexes);
this.info.show(indexes);
}
/*public onSelectedChange(callback: (keys: string[], value: unknown) => void): void {
this.info.onSelectedChange( (keys, value) ==> {
callback(keys, value);
Expand Down
12 changes: 12 additions & 0 deletions src/info/info.ts
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,10 @@ interface Info {
export class EnvironmentInfo {
/** Callback used when the user changes one of the sliders value */
public onchange: (indexes: Indexes) => void;

/** Callback used when the selection is changed, no matter the source */
public onselection?: () => void;;

/** delay in ms between "frames" during playback over structures/atoms */
public playbackDelay: number;

Expand Down Expand Up @@ -138,6 +142,7 @@ export class EnvironmentInfo {

/** Show properties for the given `indexes`, and update the sliders values */
public show(indexes: Indexes): void {
console.log("info/show");

Check failure on line 145 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 145 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
const previousStructure = this._indexes().structure;

this._structure.number.value = `${indexes.structure + 1}`;
Expand All @@ -163,6 +168,11 @@ export class EnvironmentInfo {
this._atom.table.show(indexes);
}
}

if (this.onselection !== undefined) {
console.log("info show trigger onselection");

Check failure on line 173 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 173 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
this.onselection();
}
}

/**
Expand Down Expand Up @@ -220,6 +230,7 @@ export class EnvironmentInfo {
};

slider.onchange = () => {
console.log("slider/onchange");

Check failure on line 233 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 233 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
const structure = this._structure.slider.value();

if (this._atom !== undefined) {
Expand Down Expand Up @@ -256,6 +267,7 @@ export class EnvironmentInfo {
number.max = this._indexer.structuresCount().toString();

number.onchange = () => {
console.log("number/onchange");

Check failure on line 270 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (16.x)

Unexpected console statement

Check failure on line 270 in src/info/info.ts

View workflow job for this annotation

GitHub Actions / npm-test (18.x)

Unexpected console statement
const value = parseInt(number.value, 10) - 1;
if (isNaN(value) || value < 0 || value >= parseInt(number.max, 10)) {
// reset to the current slider value if we got an invalid value
Expand Down

0 comments on commit ae0ef52

Please sign in to comment.