import { MainAreaWidget } from '@jupyterlab/apputils'; import { CodeEditor } from '@jupyterlab/codeeditor'; import { IChangedArgs } from '@jupyterlab/coreutils'; import { Contents } from '@jupyterlab/services'; import { ISharedFile } from '@jupyter/ydoc'; import { ITranslator } from '@jupyterlab/translation'; import { PartialJSONValue } from '@lumino/coreutils'; import { ISignal } from '@lumino/signaling'; import { Widget } from '@lumino/widgets'; import { DocumentRegistry, IDocumentWidget } from './index'; /** * The default implementation of a document model. */ export declare class DocumentModel extends CodeEditor.Model implements DocumentRegistry.ICodeModel { /** * Construct a new document model. */ constructor(options?: DocumentRegistry.IModelOptions); /** * A signal emitted when the document content changes. */ get contentChanged(): ISignal; /** * A signal emitted when the document state changes. */ get stateChanged(): ISignal>; /** * The dirty state of the document. */ get dirty(): boolean; set dirty(newValue: boolean); /** * The read only state of the document. */ get readOnly(): boolean; set readOnly(newValue: boolean); /** * The default kernel name of the document. * * #### Notes * This is a read-only property. */ get defaultKernelName(): string; /** * The default kernel language of the document. * * #### Notes * This is a read-only property. */ get defaultKernelLanguage(): string; /** * Whether the model is collaborative or not. */ get collaborative(): boolean; /** * Serialize the model to a string. */ toString(): string; /** * Deserialize the model from a string. * * #### Notes * Should emit a [contentChanged] signal. */ fromString(value: string): void; /** * Serialize the model to JSON. */ toJSON(): PartialJSONValue; /** * Deserialize the model from JSON. * * #### Notes * Should emit a [contentChanged] signal. */ fromJSON(value: PartialJSONValue): void; /** * Initialize the model with its current state. */ initialize(): void; /** * Trigger a state change signal. */ protected triggerStateChange(args: IChangedArgs): void; /** * Trigger a content changed signal. */ protected triggerContentChange(): void; private _onStateChanged; /** * The shared notebook model. */ readonly sharedModel: ISharedFile; private _defaultLang; private _dirty; private _readOnly; private _contentChanged; private _stateChanged; private _collaborationEnabled; } /** * An implementation of a model factory for text files. */ export declare class TextModelFactory implements DocumentRegistry.CodeModelFactory { /** * Instantiates a TextModelFactory. */ constructor(collaborative?: boolean); /** * The name of the model type. * * #### Notes * This is a read-only property. */ get name(): string; /** * The type of the file. * * #### Notes * This is a read-only property. */ get contentType(): Contents.ContentType; /** * The format of the file. * * This is a read-only property. */ get fileFormat(): Contents.FileFormat; /** * Whether the model is collaborative or not. */ get collaborative(): boolean; /** * Get whether the model factory has been disposed. */ get isDisposed(): boolean; /** * Dispose of the resources held by the model factory. */ dispose(): void; /** * Create a new model. * * @param options - Model options. * * @returns A new document model. */ createNew(options?: DocumentRegistry.IModelOptions): DocumentRegistry.ICodeModel; /** * Get the preferred kernel language given a file path. */ preferredLanguage(path: string): string; private _isDisposed; private _collaborative; } /** * An implementation of a model factory for base64 files. */ export declare class Base64ModelFactory extends TextModelFactory { /** * The name of the model type. * * #### Notes * This is a read-only property. */ get name(): string; /** * The type of the file. * * #### Notes * This is a read-only property. */ get contentType(): Contents.ContentType; /** * The format of the file. * * This is a read-only property. */ get fileFormat(): Contents.FileFormat; } /** * The default implementation of a widget factory. */ export declare abstract class ABCWidgetFactory implements DocumentRegistry.IWidgetFactory { /** * Construct a new `ABCWidgetFactory`. */ constructor(options: DocumentRegistry.IWidgetFactoryOptions); /** * A signal emitted when a widget is created. */ get widgetCreated(): ISignal, T>; /** * Get whether the model factory has been disposed. */ get isDisposed(): boolean; /** * Dispose of the resources used by the document manager. */ dispose(): void; /** * Whether the widget factory is read only. */ get readOnly(): boolean; /** * A unique name identifying of the widget. */ get name(): string; /** * The label of the widget to display in dialogs. * If not given, name is used instead. */ get label(): string; /** * The file types the widget can view. */ get fileTypes(): string[]; /** * The registered name of the model type used to create the widgets. */ get modelName(): string; /** * The file types for which the factory should be the default. */ get defaultFor(): string[]; /** * The file types for which the factory should be the default for * rendering a document model, if different from editing. */ get defaultRendered(): string[]; /** * Whether the widgets prefer having a kernel started. */ get preferKernel(): boolean; /** * Whether the widgets can start a kernel when opened. */ get canStartKernel(): boolean; /** * The application language translator. */ get translator(): ITranslator; /** * Whether the kernel should be shutdown when the widget is closed. */ get shutdownOnClose(): boolean; set shutdownOnClose(value: boolean); /** * Whether to automatically select the preferred kernel during a kernel start */ get autoStartDefault(): boolean; set autoStartDefault(value: boolean); /** * Create a new widget given a document model and a context. * * #### Notes * It should emit the [widgetCreated] signal with the new widget. */ createNew(context: DocumentRegistry.IContext, source?: T): T; /** * Create a widget for a context. */ protected abstract createNewWidget(context: DocumentRegistry.IContext, source?: T): T; /** * Default factory for toolbar items to be added after the widget is created. */ protected defaultToolbarFactory(widget: T): DocumentRegistry.IToolbarItem[]; private _toolbarFactory; private _isDisposed; private _translator; private _name; private _label; private _autoStartDefault; private _readOnly; private _canStartKernel; private _shutdownOnClose; private _preferKernel; private _modelName; private _fileTypes; private _defaultFor; private _defaultRendered; private _widgetCreated; } /** * A document widget implementation. */ export declare class DocumentWidget extends MainAreaWidget implements IDocumentWidget { constructor(options: DocumentWidget.IOptions); /** * Set URI fragment identifier. */ setFragment(fragment: string): void; /** * Handle a title change. */ private _onTitleChanged; /** * Handle a path change. */ private _onPathChanged; /** * Handle a change to the context model state. */ private _onModelStateChanged; /** * Handle the dirty state of the context model. */ private _handleDirtyState; readonly context: DocumentRegistry.IContext; protected readonly _trans: import("@jupyterlab/rendermime-interfaces").IRenderMime.TranslationBundle; /** * Whether the document has an auto-generated name or not. * * #### Notes * A document has auto-generated name if its name is untitled and up * to the instant the user saves it manually for the first time. */ isUntitled?: boolean; } export declare namespace DocumentWidget { interface IOptions extends MainAreaWidget.IOptions { context: DocumentRegistry.IContext; } interface IOptionsOptionalContent extends MainAreaWidget.IOptionsOptionalContent { context: DocumentRegistry.IContext; /** * The application language translator. */ translator?: ITranslator; } }