2020-05-25 21:30:55 -05:00
|
|
|
import * as ko from "knockout";
|
|
|
|
import * as React from "react";
|
|
|
|
import { ReactAdapter } from "../../Bindings/ReactBindingHandler";
|
2020-06-30 11:47:21 -07:00
|
|
|
import * as ViewModels from "../../Contracts/ViewModels";
|
|
|
|
import {
|
|
|
|
NotebookViewerComponent,
|
|
|
|
NotebookViewerComponentProps
|
|
|
|
} from "../Controls/NotebookViewer/NotebookViewerComponent";
|
|
|
|
import TabsBase from "./TabsBase";
|
2020-07-20 12:59:40 -05:00
|
|
|
import Explorer from "../Explorer";
|
2020-07-27 16:05:25 -05:00
|
|
|
import { DatabaseAccount } from "../../Contracts/DataModels";
|
|
|
|
import { CommandButtonComponentProps } from "../Controls/CommandButton/CommandButtonComponent";
|
|
|
|
|
|
|
|
interface NotebookViewerTabOptions extends ViewModels.TabOptions {
|
|
|
|
account: DatabaseAccount;
|
|
|
|
container: Explorer;
|
|
|
|
notebookUrl: string;
|
|
|
|
}
|
2020-05-25 21:30:55 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notebook Viewer tab
|
|
|
|
*/
|
|
|
|
class NotebookViewerComponentAdapter implements ReactAdapter {
|
|
|
|
// parameters: true: show, false: hide
|
|
|
|
public parameters: ko.Computed<boolean>;
|
2020-06-30 11:47:21 -07:00
|
|
|
constructor(private notebookUrl: string) {}
|
2020-05-25 21:30:55 -05:00
|
|
|
|
|
|
|
public renderComponent(): JSX.Element {
|
2020-06-30 11:47:21 -07:00
|
|
|
const props: NotebookViewerComponentProps = {
|
|
|
|
notebookUrl: this.notebookUrl,
|
|
|
|
backNavigationText: undefined,
|
|
|
|
onBackClick: undefined,
|
|
|
|
onTagClick: undefined
|
|
|
|
};
|
|
|
|
|
|
|
|
return this.parameters() ? <NotebookViewerComponent {...props} /> : <></>;
|
2020-05-25 21:30:55 -05:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-07-27 16:05:25 -05:00
|
|
|
export default class NotebookViewerTab extends TabsBase {
|
2020-07-20 12:59:40 -05:00
|
|
|
private container: Explorer;
|
2020-05-25 21:30:55 -05:00
|
|
|
public notebookUrl: string;
|
|
|
|
|
2020-06-30 11:47:21 -07:00
|
|
|
public notebookViewerComponentAdapter: NotebookViewerComponentAdapter;
|
|
|
|
|
2020-07-27 16:05:25 -05:00
|
|
|
constructor(options: NotebookViewerTabOptions) {
|
2020-05-25 21:30:55 -05:00
|
|
|
super(options);
|
|
|
|
this.container = options.container;
|
|
|
|
this.notebookUrl = options.notebookUrl;
|
2020-06-30 11:47:21 -07:00
|
|
|
|
|
|
|
this.notebookViewerComponentAdapter = new NotebookViewerComponentAdapter(options.notebookUrl);
|
2020-05-25 21:30:55 -05:00
|
|
|
|
|
|
|
this.notebookViewerComponentAdapter.parameters = ko.computed<boolean>(() => {
|
|
|
|
if (this.isTemplateReady() && this.container.isNotebookEnabled()) {
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
2020-07-20 12:59:40 -05:00
|
|
|
protected getContainer(): Explorer {
|
2020-05-25 21:30:55 -05:00
|
|
|
return this.container;
|
|
|
|
}
|
|
|
|
|
2020-07-27 16:05:25 -05:00
|
|
|
protected getTabsButtons(): CommandButtonComponentProps[] {
|
2020-05-25 21:30:55 -05:00
|
|
|
return [];
|
|
|
|
}
|
|
|
|
|
|
|
|
protected buildCommandBarOptions(): void {
|
|
|
|
this.updateNavbarWithTabsButtons();
|
|
|
|
}
|
|
|
|
}
|