mirror of
https://github.com/lensapp/lens.git
synced 2025-05-20 05:10:56 +00:00
Fix race condition in LensViews.handleVisibleClusterChange (#4387)
This commit is contained in:
parent
8a1faa3eb8
commit
0e5fc65806
@ -19,7 +19,7 @@
|
|||||||
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
* CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { action, IReactionDisposer, makeObservable, observable, reaction, when } from "mobx";
|
import { action, IReactionDisposer, makeObservable, observable, when } from "mobx";
|
||||||
import logger from "../../../main/logger";
|
import logger from "../../../main/logger";
|
||||||
import { clusterVisibilityHandler } from "../../../common/cluster-ipc";
|
import { clusterVisibilityHandler } from "../../../common/cluster-ipc";
|
||||||
import { ClusterStore } from "../../../common/cluster-store";
|
import { ClusterStore } from "../../../common/cluster-store";
|
||||||
@ -34,12 +34,10 @@ export interface LensView {
|
|||||||
|
|
||||||
export class ClusterFrameHandler extends Singleton {
|
export class ClusterFrameHandler extends Singleton {
|
||||||
private views = observable.map<string, LensView>();
|
private views = observable.map<string, LensView>();
|
||||||
@observable private visibleCluster: string | null = null;
|
|
||||||
|
|
||||||
constructor() {
|
constructor() {
|
||||||
super();
|
super();
|
||||||
makeObservable(this);
|
makeObservable(this);
|
||||||
reaction(() => this.visibleCluster, this.handleVisibleClusterChange);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public hasLoadedView(clusterId: string): boolean {
|
public hasLoadedView(clusterId: string): boolean {
|
||||||
@ -97,39 +95,34 @@ export class ClusterFrameHandler extends Singleton {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
public setVisibleCluster(clusterId: ClusterId) {
|
|
||||||
this.visibleCluster = clusterId;
|
|
||||||
}
|
|
||||||
|
|
||||||
public clearVisibleCluster() {
|
|
||||||
this.visibleCluster = null;
|
|
||||||
}
|
|
||||||
|
|
||||||
private prevVisibleClusterChange?: IReactionDisposer;
|
private prevVisibleClusterChange?: IReactionDisposer;
|
||||||
|
|
||||||
private handleVisibleClusterChange = (clusterId: ClusterId | undefined) => {
|
public setVisibleCluster(clusterId: ClusterId | null) {
|
||||||
|
// Clear the previous when ASAP
|
||||||
|
this.prevVisibleClusterChange?.();
|
||||||
|
|
||||||
logger.info(`[LENS-VIEW]: refreshing iframe views, visible cluster id=${clusterId}`);
|
logger.info(`[LENS-VIEW]: refreshing iframe views, visible cluster id=${clusterId}`);
|
||||||
|
|
||||||
ipcRenderer.send(clusterVisibilityHandler);
|
ipcRenderer.send(clusterVisibilityHandler);
|
||||||
|
|
||||||
const cluster = ClusterStore.getInstance().getById(clusterId);
|
|
||||||
|
|
||||||
for (const { frame: view } of this.views.values()) {
|
for (const { frame: view } of this.views.values()) {
|
||||||
view.style.display = "none";
|
view.style.display = "none";
|
||||||
}
|
}
|
||||||
|
|
||||||
if (cluster) {
|
const cluster = ClusterStore.getInstance().getById(clusterId);
|
||||||
const lensView = this.views.get(clusterId);
|
|
||||||
|
|
||||||
this.prevVisibleClusterChange?.();
|
if (cluster) {
|
||||||
this.prevVisibleClusterChange = when(
|
this.prevVisibleClusterChange = when(
|
||||||
() => cluster.available && cluster.ready && lensView.isLoaded,
|
() => cluster.available && cluster.ready && this.views.get(clusterId)?.isLoaded,
|
||||||
() => {
|
() => {
|
||||||
logger.info(`[LENS-VIEW]: cluster id=${clusterId} should now be visible`);
|
logger.info(`[LENS-VIEW]: cluster id=${clusterId} should now be visible`);
|
||||||
lensView.frame.style.display = "flex";
|
this.views.get(clusterId).frame.style.display = "flex";
|
||||||
ipcRenderer.send(clusterVisibilityHandler, clusterId);
|
ipcRenderer.send(clusterVisibilityHandler, clusterId);
|
||||||
},
|
},
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
};
|
}
|
||||||
|
|
||||||
|
public clearVisibleCluster() {
|
||||||
|
this.setVisibleCluster(null);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user