2020-05-25 21:30:55 -05:00
|
|
|
import * as ko from "knockout";
|
|
|
|
import * as ViewModels from "../../Contracts/ViewModels";
|
|
|
|
import TabsBase from "./TabsBase";
|
|
|
|
import * as React from "react";
|
|
|
|
import { ReactAdapter } from "../../Bindings/ReactBindingHandler";
|
2020-06-05 04:04:15 +02:00
|
|
|
import { GalleryViewerContainerComponent } from "../Controls/NotebookGallery/GalleryViewerComponent";
|
2020-05-25 21:30:55 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notebook gallery tab
|
|
|
|
*/
|
|
|
|
class GalleryComponentAdapter implements ReactAdapter {
|
|
|
|
public parameters: ko.Computed<boolean>;
|
|
|
|
constructor(private getContainer: () => ViewModels.Explorer) {}
|
|
|
|
|
|
|
|
public renderComponent(): JSX.Element {
|
|
|
|
return this.parameters() ? <GalleryViewerContainerComponent container={this.getContainer()} /> : <></>;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
export default class GalleryTab extends TabsBase implements ViewModels.Tab {
|
|
|
|
private container: ViewModels.Explorer;
|
|
|
|
private galleryComponentAdapter: GalleryComponentAdapter;
|
|
|
|
|
|
|
|
constructor(options: ViewModels.GalleryTabOptions) {
|
|
|
|
super(options);
|
|
|
|
this.container = options.container;
|
|
|
|
this.galleryComponentAdapter = new GalleryComponentAdapter(() => this.getContainer());
|
|
|
|
|
|
|
|
this.galleryComponentAdapter.parameters = ko.computed<boolean>(() => {
|
|
|
|
return this.isTemplateReady() && this.container.isNotebookEnabled();
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
protected getContainer(): ViewModels.Explorer {
|
|
|
|
return this.container;
|
|
|
|
}
|
|
|
|
|
|
|
|
protected getTabsButtons(): ViewModels.NavbarButtonConfig[] {
|
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
protected buildCommandBarOptions(): void {
|
|
|
|
this.updateNavbarWithTabsButtons();
|
|
|
|
}
|
|
|
|
}
|